Scalable Ontology-Based Information Systems Ian Horrocks Information Systems Group Oxford University Computing Laboratory
What is an Ontology?
A model of (some aspect of) the world
What is an Ontology? A model of (some aspect of) the world Introduces vocabulary relevant to domain, e.g.: –Anatomy
What is an Ontology? A model of (some aspect of) the world Introduces vocabulary relevant to domain, e.g.: –Anatomy –Cellular biology
What is an Ontology? A model of (some aspect of) the world Introduces vocabulary relevant to domain, e.g.: –Anatomy –Cellular biology –Aerospace
What is an Ontology? A model of (some aspect of) the world Introduces vocabulary relevant to domain, e.g.: –Anatomy –Cellular biology –Aerospace –Dogs
What is an Ontology? A model of (some aspect of) the world Introduces vocabulary relevant to domain, e.g.: –Anatomy –Cellular biology –Aerospace –Dogs –Hotdogs –…
What is an Ontology? A model of (some aspect of) the world Introduces vocabulary relevant to domain Specifies meaning (semantics) of terms Heart is a muscular organ that is part of the circulatory system
What is an Ontology? A model of (some aspect of) the world Introduces vocabulary relevant to domain Specifies meaning (semantics) of terms Heart is a muscular organ that is part of the circulatory system Formalised using suitable logic
recommendation(s) Motivated by Semantic Web activity Add meaning to web content by annotating it with terms defined in ontologies Supported by tools and infrastructure –APIs (e.g., OWL API, Thea, OWLink) –Development environments (e.g., Protégé, Swoop, TopBraid Composer) –Reasoners & Information Systems (e.g., Pellet, Racer, HermiT, Quonto, …) Based on a Description Logics (SHOIN / SROIQ) Web Ontology Language OWL (2)
Fragments of first order logic designed for KR Desirable computational properties –Decidable (essential) –Low complexity (desirable) Succinct and variable free syntax Description Logics (DLs)
DL Knowledge Base (KB) consists of two parts: –Ontology (aka TBox) axioms define terminology (schema) –Ground facts (aka ABox) use the terminology (data) Description Logics (DLs)
Why Care About Semantics?
Herasy!
Why Care About Semantics? Why should I care about semantics?
Why Care About Semantics? Why should I care about semantics?
Why Care About Semantics? Well, from a philosophical POV, we need to specify the relationship between statements in the logic and the existential phenomena they describe. Why should I care about semantics?
Why Care About Semantics? Well, from a philosophical POV, we need to specify the relationship between statements in the logic and the existential phenomena they describe. That’s OK, but I don’t get paid for philosophy. Why should I care about semantics?
Why Care About Semantics? Why should I care about semantics? Well, from a philosophical POV, we need to specify the relationship between statements in the logic and the existential phenomena they describe. That’s OK, but I don’t get paid for philosophy. From a practical POV, in order to specify and test ontology-based information systems we need to precisely define their intended behaviour
In FOL we define the semantics in terms of models (a model theory). A model is supposed to be an analogue of (part of) the world being modeled. FOL uses a very simple kind of model, in which “objects” in the world (not necessarily physical objects) are modeled as elements of a set, and relationships between objects are modeled as sets of tuples. Why Care About Semantics?
In FOL we define the semantics in terms of models (a model theory). A model is supposed to be an analogue of (part of) the world being modeled. FOL uses a very simple kind of model, in which “objects” in the world (not necessarily physical objects) are modeled as elements of a set, and relationships between objects are modeled as sets of tuples. This is exactly the same kind of model as used in a database: objects in the world are modeled as values (elements) and relationships as tables (sets of tuples).
What are Ontologies Good For? Coherent user-centric view of domain –Help identify and resolve disagreements Ontology-based Information Systems –View of data that is independent of logical/physical schema –Queries use terms familiar to users –Answers reflect schema & data, e.g.: “Patients suffering from Vascular Disease” –Query expansion/navigation/refinement –Incomplete and semi-structured data –Integration of heterogeneous sources Now... that should clear up a few things around here
Healthcare UK NHS £6.2 billion “Connecting for Health” IT programme Key component is Care Records Service (CRS) –“Live, interactive patient record service accessible 24/7” –Patient data distributed across local centres in 5 regional clusters, and a national DB Detailed records held by local service providers Diverse applications support radiology, pharmacy, etc Summaries sent to national database –SNOMED-CT ontology provides common vocabulary for data Clinical data uses terms drawn from ontology
SNOMED-CT It’s BIG − over 400,000 concepts Language used is EL profile of OWL 2 Multiple hierarchies and rich definitions
Pulmonary Tuberculosis kind of Pulmonary disease due to Mycobacteria kind of tuberculosis kind of pneumonitis found in lung structure caused by Mycobacterium tuberculosis complex
SNOMED-CT Over 400,000 concepts Language used is EL fragment of OWL 2 Multiple hierarchies and rich definitions Supports, e.g., retrieving details of all patients having pulmonary TB
SNOMED-CT Over 400,000 concepts Language used is EL fragment of OWL 2 Multiple hierarchies and rich definitions Supports, e.g., retrieving details of all patients having pulmonary TB –information used e.g., to improve Quality of Care, for Reporting, in epidemiological research, in Decision Support,... Building and maintenance is a huge task –supported by reasoning tools, e.g., to enrich hierarchies
What About Scalability? Only useful in practice if we can deal with large ontologies and/or large data sets Unfortunately, many ontology languages are highly intractable –Satisfiability for OWL 2 ontologies is 2NEXPTIME-complete Problem addressed in practice by –Algorithms that work well in typical cases –Highly optimised implementations –Use of tractable fragments (aka profiles)
Tableau Reasoning Algorithms
Standard technique based on (hyper-) tableau –Reasoning tasks reducible to (un)satisfiability E.g., KB ² HeartDisease v VascularDisease iff KB [ {x:(HeartDisease u :VascularDisease)} is not satisfiable
Tableau Reasoning Algorithms Standard technique based on (hyper-) tableau –Reasoning tasks reducible to (un)satisfiability E.g., KB ² HeartDisease v VascularDisease iff KB [ {x:(HeartDisease u :VascularDisease)} is not satisfiable –Algorithm tries to construct (an abstraction of) a model in which some individual (x) is an instance of HeartDisease and not an instance of VascularDisease such a model is a counter-example for postulated subsumption
Highly Optimised Implementations Lazy unfolding Simplification and rewriting, e.g., HyperTableau (reduces non-determinism) Fast semi-decision procedures Search optimisations Reuse of previous computations Heuristics Not computationally optimal, but effective with many realistic ontologies
Scalability Issues Problems with very large and/or cyclical ontologies Ontologies may define 10s/100s of thousands of terms –can lead to construction of very large models –requires many (worst case n 2 ) tests to construct taxonomy
Scalability Issues Problems with large data sets (ABoxes) –Main reasoning problem is (conjunctive) query answering, e.g., retrieve all patients suffering from vascular disease: Decidability still open for OWL, although minor restrictions (on cycles in non-distinguished variables) restore decidability –Query answering reduced to standard decision problem, e.g., by checking for each individual x if KB ² Q(x) –Model construction starts with all ground facts (data) Typical applications may use data sets with 10s/100s of millions of individuals (or more)
OWL 2 Profiles OWL recommendation now updated to OWL 2 OWL 2 defines several profiles – fragments with desirable computational properties –OWL 2 EL targeted at very large ontologies –OWL 2 QL targeted at very large data sets
OWL 2 EL A (near maximal) fragment of OWL 2 such that –Satisfiability checking is in PTime (PTime-Complete) –Data complexity of query answering also PTime-Complete Based on EL family of description logics Can exploit saturation based reasoning techniques –Computes classification in “one pass” –Computationally optimal –Can be extended to Horn fragment of OWL DL
Saturation-based Technique (basics) Normalise ontology axioms to standard form: Saturate using inference rules: Extension to Horn fragment requires (many) more rules
Saturation-based Technique (basics) Example:
Saturation-based Technique (basics) Example:
Saturation-based Technique (basics) Example:
Saturation-based Technique (basics) Example:
Saturation-based Technique (basics) Example:
Saturation-based Technique (basics) Example:
Saturation-based Technique (basics) Example:
Saturation-based Technique (basics) Example:
Saturation-based Technique (basics) Example:
Saturation-based Technique (basics) Example:
Saturation-based Technique (basics) Example:
Saturation-based Technique (basics) Example:
Performance with large bio-medical ontologies: Saturation-based Technique
OWL 2 QL A (near maximal) fragment of OWL 2 such that –Data complexity of conjunctive query answering in AC 0, i.e., query answering is first order reducible Based on DL-Lite family of description logics Can exploit query rewriting based reasoning technique –Computationally optimal –Data storage and query evaluation can be delegated to standard RDBMS –Can be extended to more expressive languages (beyond AC 0 ) by delegating query answering to a Datalog engine
Query Rewriting Technique (basics) Given ontology O and query Q, use O to rewrite Q as Q 0 such that, for any set of ground facts A: –ans(Q, O, A) = ans(Q 0, ;, A)
Query Rewriting Technique (basics) Given ontology O and query Q, use O to rewrite Q as Q 0 such that, for any set of ground facts A: –ans(Q, O, A) = ans(Q 0, ;, A) A Rewrite O Q Q0Q0 Map SQL M Ans
Query Rewriting Technique (basics) Given ontology O and query Q, use O to rewrite Q as Q 0 such that, for any set of ground facts A: –ans(Q, O, A) = ans(Q 0, ;, A) A Rewrite O Q Q0Q0 Map SQL M Ans
Query Rewriting Technique (basics) Given ontology O and query Q, use O to rewrite Q as Q 0 such that, for any set of ground facts A: –ans(Q, O, A) = ans(Q 0, ;, A) A Rewrite O Q Q0Q0 Map SQL M Ans
Query Rewriting Technique (basics) Given ontology O and query Q, use O to rewrite Q as Q 0 such that, for any set of ground facts A: –ans(Q, O, A) = ans(Q 0, ;, A) Resolution based query rewriting –Clausify ontology axioms –Saturate (clausified) ontology and query using resolution –Prune redundant query clauses
Query Rewriting Technique (basics) Example:
Query Rewriting Technique (basics) Example:
Query Rewriting Technique (basics) Example:
Query Rewriting Technique (basics) Example:
Query Rewriting Technique (basics) Example:
Query Rewriting Technique (basics) Example:
Query Rewriting Technique (basics) Example:
Query Rewriting Technique (basics) Example:
Query Rewriting Technique (basics) Example:
Query Rewriting Technique (basics) Example:
Query Rewriting Technique (basics) Example:
Query Rewriting Technique (basics) Example:
Query Rewriting Technique (basics) Example: For DL-Lite, result is a union of conjunctive queries
Query Rewriting Technique (basics) Data can be stored/left in RDBMS Relationship between ontology and DB defined by mappings, e.g.: UCQ translated into SQL query:
Some Research Challenges Extend saturation-based techniques to non-Horn fragments –SNOMED users want negation and/or disjunction Non infectious Pneumonia Infectious or Malignant disorder of lung Burn injury of face neck or scalp Extend reasoning support –Modularity –Explanation –...
Some (more) Research Challenges Open questions w.r.t. query rewriting –FO rewritability (AC 0 ) only for very weak ontology languages –Even for AC 0 languages, queries can get very large (order ), and existing RDBMSs may behave poorly –Larger fragments require (at least) Datalog engines and/or extension to technique (e.g., partial materialisation) Integrating DL/DB research –Ontologies -v- dependencies –Open world -v- closed world
Thanks To Boris Motik Yevgeny Kazakov Héctor Pérez-Urbina Rob Shearer
Select Bibliography [1]Baader, Horrocks, and Sattler. Description Logics. In Handbook of Knowledge Representation. Elsevier, [2] Motik, Shearer, and Horrocks. Hypertableau reasoning for description logics. J. of Artificial Intelligence Research, [3]Baader, Brandt, and Lutz. Pushing the EL envelope. IJCAI 2005, pages 364–369, [4]Kazakov. Consequence-driven reasoning for Horn-SHIQ ontologies. IJCAI 2009, pages 2040–2045, [5] Calvanese, De Giacomo, Lembo, Lenzerini, and Rosati. Tractable reasoning and efficient query answering in description logics: The DL-Lite family. J. of Automated Reasoning, 39(3):385 – 429, [6]Perez-Urbina, Motik, and Horrocks. Tractable query answering and rewriting under description logic constraints. J. of Applied Logic, [7]Andrea Calì, Georg Gottlob, Thomas Lukasiewicz. Datalog±: a unified approach to ontologies and integrity constraints. ICDT 2009: 14–30.