|
|
(44 intermediate revisions by 4 users not shown) |
Line 1: |
Line 1: |
− | == Ontohub == | + | <!-- BANNER ACROSS TOP OF PAGE --> |
| + | {| id="mp-topbanner" style="width:100%; background:#f9f9f9; margin:1.2em 0 6px 0; border:1px solid #ddd;" |
| + | | style="width:61%; color:#000;" | |
| + | <!-- "WELCOME" --> |
| + | {| style="width:280px; border:none; background:none;" |
| + | | style="width:280px; text-align:center; white-space:nowrap; color:#000;" | |
| + | <div style="font-size:162%; border:none; margin:0; padding:.1em; color:#000;">Welcome to [[Ontohub]],</div> |
| + | <div style="top:+0.2em; font-size:95%;">the free and open ontology repository engine.</div> |
| + | |} |
| + | <!-- PORTAL LIST ON RIGHT-HAND SIDE --> |
| + | | style="width:13%; font-size:95%;" | |
| + | * [[FAQ]] |
| + | * [[Glossary]] |
| + | * [[Ontohub]] |
| + | | style="width:13%; font-size:95%;" | |
| + | * [[Ontology|Ontologies]] |
| + | * [[Repository|Repositories]] |
| + | * [[Permission]]s |
| + | | style="width:13%; font-size:95%;" | |
| + | * [[Mapping|Mappings]] |
| + | * [[Logic]]s |
| + | * [[Team]]s |
| + | | style="width:13%; font-size:95%;" | |
| + | * [[DOL]] |
| + | * [[Ontohub team]] |
| + | | style="width:13%; font-size:95%;" | |
| + | * [[How to test Ontohub|Testing Ontohub]] |
| + | * [[Tutorial]] |
| + | |} |
| | | |
− | Ontohub is an [http://ontolog.cim3.net/cgi-bin/wiki.pl?OpenOntologyRepository#nid3652 open ontology repository] which supports organisation, collection, retrieval, development, mapping, translation, and evaluation of a wide array of ontologies formalised in diverse languages.
| |
| | | |
− | The Ontohub team is looking forward to providing technological infrastructure for the forthcoming [http://fois2014.inf.ufes.br/p/home.html FOIS 2014 Ontology Competition]. Accordingly, several new features are going to be launched on the [http://ontohub.org/ Ontohub] soon.
| + | [http://ontohub.org/ Ontohub] is an [http://oor.net open ontology repository] which supports organisation, collection, retrieval, development, mapping, translation, and evaluation of a wide array of [[ontology|ontologies]] formalised in diverse [[logic|languages]]. |
| + | |
| + | Ontohub has provided technological infrastructure for the [http://www.iaoa.org/fois/2014.html FOIS 2014] and [http://www.iaoa.org/fois2016/index.php?n=Main.SatelliteActivities#competition FOIS 2016] Ontology Competitions. |
| | | |
| This wiki entrance aims at providing instructions and support to the Ontohub users. See also [[FAQ]]. | | This wiki entrance aims at providing instructions and support to the Ontohub users. See also [[FAQ]]. |
| | | |
− | == User Interface ==
| + | Key features of Ontohub: |
− | | + | *OntoHub is an '''ontology [[repository]]''' that supports the ontology development and maintenance along the whole ontology lifecycle. |
− | ===Start===
| + | * publishing & retrieval: OntoHub is a free ontology repository that allows you to '''publish''' your [[ontology]] and '''find''' existing ontologies that are relevant for your work. |
− | | + | *development: OntoHub supports '''ontology development'''. Since OntoHub is based on '''[[Git]] [[repository|repositories]]''', OntoHub supports ontology versioning, branching, and merging. |
− | The home page of Ontohub provides access to all public repositories, ontologies, symbols, logics and ontology mappings stored in this hub of distributed, and yet interconnected, ontology repositories. Recently updated repositories and ontologies are listed as well.
| + | * evaluation: OntoHub is designed to be a platform for ontology evaluation tools. The goal is to support all kinds of evaluation; including syntactic validation, best-practices evaluation, and regression testing. |
− | | + | * multilingual: OntoHub supports a wide '''variety of languages and [[logic]]s'''. The same ontology may exist in more than one language. OntoHub supports the automatic translation between languages. |
− | ===Sign In===
| + | *open: OntoHub is based on '''[[Ontohub|open source software]]'''. |
− | | |
− | The full functionality of Ontohub (ontology and repository, creation, collaborative editing and development of ontologies, mapping across ontologies, visualisation, and evaluation) is available upon sign in. Every registered Ontohub user can modify and adjust its own version of interface, i.e. specific and highly personalised access to the repository content.
| |
− | | |
− | ===Repositories===
| |
− | | |
− | Besides serving as an ontology repository, Ontohub is also a hub that links other ontology repositories. Ontohub provides a single web interface to access various ontology repositories, either hosted or mirrored on Ontohub. The button ''Repositories'' (on the menu-bar) leads to the page where all public repositories are listed and the access to their content provided. In addition, Ontohub allows creation and hosting of new repositories, the function available to all registered Ontohub users. Along the opportunity of creating a new repository, Ontohub users can get advantage of the Ontohub collaborative environment in order to develop ontologies and/or repositories in either problem or domain oriented manner. Thus, Ontohub supports reuse of ontologies stored in other ontology repositories and creation of new repositories that organize ontologies resulting from the activities of a team focused around a particular project or a specific task.
| |
− | | |
− | It is also possible to create private repositories. These are visible only for users who have read-permission for the repository.
| |
− | | |
− | ===Ontologies===
| |
− | | |
− | Ontology search can be performed either over whole Ontohub content ('Ontology' tab on the menu bar) or over ontologies stored within a particular Ontohub repository (Ontology browser on the page of a particular Ontohub repository).
| |
− |
| |
− | Ontology retrieval is done by typing into the ontology browser one or many of the available search criteria:
| |
− | | |
− | - ontology name
| |
− | | |
− | - ontology acronym
| |
− | | |
− | - ontology language
| |
− | | |
− | - a symbol or a label that an ontology contains
| |
− | | |
− | - a particular domain (category) that an ontology belongs to (e.g. space, biology, etc.)
| |
− | | |
− | - ontology type (e.g. upper, domain, task, etc.) Please note that this feature has not been implemented yet.
| |
− | | |
− | Since the search engine uses metadata to retrieve an ontology, all Ontohub users are encouraged to specify metadata about their ontology during the ontology upload. Having described an ontology domain, type, task, etc. increases findability of an ontology.
| |
− | | |
− | | |
− | ===Symbols===
| |
− | ===Logics===
| |
− | ===Mappings===
| |
− | Under the mappings tab, you can see all mappings. Mappings always have a source and a target ontology, and provide mappings or relations between the symbols of these ontologies.
| |
− | | |
− | Currently, new mappings can only be created using e.g. an interpretation or an alignment in a [[DOL]] file, and uploading that DOL file.
| |
− | | |
− | ===Icons===
| |
− | | |
− | == Common Tasks ==
| |
− | | |
− | 2.1. '''Submitting an ontology'''
| |
− | | |
− | The submission of a new ontology into Ontohub consists of the following steps:
| |
− | | |
− | a. Register/'''sign in''' ontohub.org
| |
− | | |
− | b. Select an existing '''repository''' that fits best your specific target domain, task, and ontology type; All public repositories are listed upon clicking on the 'Repository' button in the main menu; alternatively, it is possible to create a new repository (as described in section 2.5); certain repositories are 'read-only' while others allow editing of the repository content;
| |
− | | |
− | c. If uploading an ontology to the existing repository you will need to get a '''permission''' via requesting the editing rights; the permission is provided by the administrator of the repository ('owner'); After selecting (or creating) an appropriate ontology repository and acquiring the editing rights, the ontology upload can proceed through the use of file system.
| |
− | | |
− | d. The ''''Edit'''' button appears on the page of each repository for which you have the editing rights. 'Edit' button leads to the interface with the editing option. So, the first step in editing is to to confirm that you want to 'Update repository'. The next step is to go to the section 'Ontology files and related files', where you can upload your ontology as a new file. The information provided there in gets stored into the file system, which can afterwords be accessed at the 'Ontology files and related files'. You might want to upload your ontology into an already existing folder that stores ontologies of your interest. In that case, in the section 'Target directory' you will need to type the exact name of the directory in which you want to store your ontology file. Into the section 'Target file name' you will need to type the ontology name together with its correct extension, e.g. name.owl, name.clif etc. A message that accompanies upload is optional but desirable as it can be helpful in tracking the history of activities and changes in repository. The next step is to 'Upload file'.
| |
− | | |
− | e. Since your submitted file is recognised as an ontology (via its extension), you will need to provide '''metadata''' that describe your ontology: ontology name, category (domain), ontology type, formality level, and a specific description. The inserted metadata are helpful in classification of ontologies in repository and their easier, a task specific retrieval.
| |
− | | |
− | When selecting metadata that describe the domain of your ontology ('Category') you can select multiple fields that will help to characterise your ontology as specific as possible. For instance, if an ontology is about anatomy of a biological species, then the appropriate categories would be 'biology' and 'space', while a geospatial ontology can be associated with the domains 'geography' and 'space', an ontology that describes chemical structures would be associated with 'chemistry' and 'space'.
| |
− | | |
− | ''''Ontology type'''' and ''''Formality level'''' provide specification of your ontology as a domain ontology, an upper level ontology etc. Please note that the classification of ontology types and formality levels mostly follows the OMV specifications. Modifications and revisions to this classification are work in progress.
| |
− | | |
− | ''''Description'''' of ontology provides an important narrative, i.e. information that will additionally help users (people and machines) to capture the targets and aims of the ontology designer.
| |
− | | |
− | ----
| |
− | | |
− | 2.2. '''Editing an ontology'''
| |
− | ----
| |
− | | |
− | 2.3. '''Visualising mappings'''
| |
− | ----
| |
− | | |
− | 2.4. '''Evaluating an ontology'''
| |
− | | |
− | ----
| |
− | | |
− | 2.5. '''Creating an ontology repository'''
| |
− | | |
− | ----
| |
− | | |
− | 2.6. '''Maintaining an ontology repository'''
| |
− | | |
− | == Infrastructure ==
| |
− | | |
− | ===Ontohub Git===
| |
− | | |
− | Ontohub infrastructure is powered by the open-source web framework [http://ruby.railstutorial.org/ruby-on-rails-tutorial-book Ruby on Rails] for building dynamic web applications. Accordingly, Ontohub has a git structure that supports versioning and management of the Ontohub content.
| |
− | | |
− | In addition, the git structure of Ontohub supports stability of the system. Having separate branches for development and staging, software developers are introducing new features of Ontohub on its develop branch. After going through all necessary tests for stability, new features are merged to the staging (and master, i.e. visible website). In that way, the UI on the main page is always stable.
| |
− | | |
− | The parsing and inference backend of Ontohub is the Heterogeneous Tool Set (Hets). A detailed architecture of Ontohub you can find on page 8 of [http://ontolog.cim3.net/file/work/OpenOntologyRepository/Ontohub/ontohub--TillMossakowski-et-al_20130621a.pdf Ontohub preprint paper] <ref name="Mossakowski">Mossakowski, Till, Oliver Kutz, and Mihai Codescu. "Ontohub - a repository engine for heterogeneous ontologies and alignments." preprint. [http://ontolog.cim3.net/file/work/OpenOntologyRepository/Ontohub/ontohub--TillMossakowski-et-al_20130621a.pdf PDF] </ref> | |
− | | |
− | ----
| |
− | | |
− | ===My Ontohub===
| |
− | ----
| |
− | | |
− | ===HETS===
| |
− | | |
− | Ontohub accesses the Heterogeneous Tool Set Hets via a RESTful web service interface for having the structure of ontologies analyzed. Hets already supports a large number of basic ontology languages and logics, and is capable of describing the structural outline of an ontology from the perspective of DOL, which is not committed to one particular logic.
| |
− | | |
− | ----
| |
− | | |
− | ===DOL===
| |
− | | |
− | '''D'''istributed '''O'''ntology '''L'''anguage (DOL) covers all state-of-the-art ontology languages, and provides a meta level on top of these. This meta level allows for the representation of logically heterogeneous ontologies. DOL ontologies may comprise of modules written in ontology languages with different underlying logics. Moreover, the DOL meta level constructs allow for links between ontologies such as relative interpretations or conservative extensions. <ref name="Mossakowski2">Mossakowski, Till, Christoph Lange, and Oliver Kutz. "Three Semantics for the Core of the Distributed Ontology Language." FOIS. 2012. [http://www.informatik.uni-bremen.de/~till/papers/DOLsemantics.pdf PDF] </ref> | |
− | | |
− | Since the Ontohub infrastructure supports DOL, it allows the Ontohub users
| |
− | | |
− | - to relate ontologies that are written in different formalisms;
| |
− | | |
− | - to re-use ontology modules even if they have been formulated in a different formalism;
| |
− | | |
− | - to re-use ontology tools like theorem provers and module extractors along translations between formalisms.
| |
− | | |
− | DOL is currently being standardised within the [http://about.ontohub.org/ontoiop.html OntoIOp] working group.
| |
− | | |
− | ----
| |
− | | |
− | ===LoLa Ontology===
| |
− | | |
− | LoLa is an ontology of (ontology) '''Lo'''gics and '''La'''nguages. Onthub implements [http://purl.net/dol/1.0/rdf# LoLa] for structuring the repository content. The OWL core of the LoLa ontology comprises classes for ontology languages, logics, mappings (translations or projections) between ontology languages and between logics, as well as serialisations. The LoLa properties relate all of the former classes to each other. Besides its OWL module, LoLa includes additional FOL axioms for closure rules not expressible in OWL, such as non-expressible role compositions and circumscription rules for minimising the extension of default translations. <ref name="Lange">Lange, Christoph, Till Mossakowski, and Oliver Kutz. "LoLa: A Modular Ontology of Logics, Languages, and Translations." Workshop on Modular Ontologies (WoMO) 2012. 2012. [ftp://ceur-ws.org/pub/publications/CEUR-WS/Vol-875.zip#page=60 PDF] </ref>
| |
− | | |
− | == Glossary ==
| |
− | {|class="wikitable sortable"
| |
− | ! data-sort-type="Term" | Term!!Description
| |
− | |-
| |
− | |Logical theory||set of expressions (like non-logical symbols, sentences and structuring elements) in a given logical language
| |
− | |-
| |
− | |Alignment||flexible, relational link that does not always have a formal, logic-based semantics
| |
− | |-
| |
− | |Matching||algorithmic procedure that generates an alignment for two given logical theories
| |
− | |-
| |
− | |Logical language||language that is used for writing down logical theories (e.g. formal ontologies, models and specification), equipped with a formal, declarative, logic-based semantics, plus non-logical annotations
| |
− | |-
| |
− | |Link||relationship between two logical theories, relating their non-logical symbols
| |
− | |-
| |
− | |Language translation||mapping from constructs in the source logical language to their equivalents in the target logical language
| |
− | |-
| |
− | |Interpretation||logical link that postulates a relation between two logical theories
| |
− | |-
| |
− | |Combination||aggregation of several logical theories along links to a new logical theory where (only) the linked non-logical symbols of the involved logical theeories are identified
| |
− | |-
| |
− | |Conservativity||property of an extension of theories, ensuring that the extension does not add new logical context
| |
− | |-
| |
− | |Basic logical theory||set of non-logical symbols, sentences, annotations about them, which is used as a building block for a larger logical theory
| |
− | |-
| |
− | |Axiom||sentence postulated to be valid (i.e. true in every model), party of a logical theory
| |
− | |-
| |
− | |Theorem||sentence that has been proven (in some logical theory) from other axioms and theorem
| |
− | |-
| |
− | |Structured logical theory||logical theory that results from other logical theories by import, union, combination, renaming or other structuring operations
| |
− | |-
| |
− | |Sentence||term that is either true or false in a given model, i.e. which is assigned a truth value in this model
| |
− | |-
| |
− | |Satisfaction relation||relation between models and sentences indicating which sentences hold true in the model
| |
− | |-
| |
− | |Non-logical symbol||atomic expression or syntactic constituent of a logical theory that requires an interpretation through a model
| |
− | |-
| |
− | |Module extraction||activity of obtaining from anlogical theory concrete modules to be used for a particular purpose (e.g. to contain a particular sub-signature of the original logical theory)
| |
− | |-
| |
− | |Module||subtheory that conservatively extends to the whole logical theory
| |
− | |-
| |
− | |Model||semantic interpretation of all non-logical symbols of a logical theory, satisfying the theory's axioms
| |
− | |-
| |
− | |Approximation||reduction of a theory to a less expressive logical language, such that the original theory implies the approximation
| |
− | |}
| |
− | | |
− | | |
− | | |
− | ----
| |
| | | |
− | == References == | + | ==Attention: use latest Protégé version== |
− | <references/>
| + | Since Ontohub uses HTTP redirects, you need to use the latest Protégé version in order to work with Ontohub. The same holds for the OWL API. |