Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance. Project price only 1 $
You can buy this project and download/modify it how often you want.
/*
* This file is part of the OWL API.
*
* The contents of this file are subject to the LGPL License, Version 3.0.
*
* Copyright (C) 2011, The University of Manchester
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see http://www.gnu.org/licenses/.
*
*
* Alternatively, the contents of this file may be used under the terms of the Apache License, Version 2.0
* in which case, the provisions of the Apache License Version 2.0 are applicable instead of those above.
*
* Copyright 2011, University of Manchester
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.semanticweb.owlapi.model;
import java.util.Set;
/**
* Represents Entities in the OWL 2 Specification.
*
* @author Matthew Horridge, The University Of Manchester, Bio-Health
* Informatics Group Date: 24-Oct-2006
*/
public interface OWLEntity extends OWLObject, OWLNamedObject, OWLPrimitive {
/**
* Gets the entity type for this entity
*
* @return The entity type
*/
EntityType getEntityType();
/**
* Gets an entity that has the same IRI as this entity but is of the
* specified type.
*
* @param entityType
* The type of the entity to obtain. This entity is not affected in
* any way.
* @return An entity that has the same IRI as this entity and is of the
* specified type
* @param
* entity type
* @deprecated use a datafactory instead
*/
@Deprecated
E getOWLEntity(EntityType entityType);
/**
* Tests to see if this entity is of the specified type
*
* @param entityType
* The entity type
* @return {@code true} if this entity is of the specified type, otherwise
* {@code false}.
*/
boolean isType(EntityType entityType);
/**
* Gets the annotations for this entity. These are deemed to be annotations
* in annotation assertion axioms that have a subject that is an IRI that is
* equal to the IRI of this entity.
*
* @param ontology
* The ontology to be examined for annotation assertion axioms
* @return The annotations that participate directly in an annotation
* assertion whose subject is an IRI corresponding to the IRI of
* this entity.
*/
Set getAnnotations(OWLOntology ontology);
/**
* Obtains the annotations on this entity where the annotation has the
* specified annotation property.
*
* @param ontology
* The ontology to examine for annotation axioms
* @param annotationProperty
* The annotation property
* @return A set of {@code OWLAnnotation} objects that have the specified
* URI.
*/
Set getAnnotations(OWLOntology ontology,
OWLAnnotationProperty annotationProperty);
/**
* @param ontology
* the ontology to use
* @return the annotation assertion axioms about this entity in the provided
* ontology
*/
Set getAnnotationAssertionAxioms(
OWLOntology ontology);
/**
* Determines if this entity is a built in entity. The entity is a built in
* entity if it is:
*
*
a class and the URI corresponds to owl:Thing or owl:Nothing
*
an object property and the URI corresponds to owl:topObjectProperty
* or owl:bottomObjectProperty
*
a data property and the URI corresponds to owl:topDataProperty or
* owl:bottomDataProperty
*
a datatype and the IRI is rdfs:Literal or is in the OWL 2 datatype
* map or is rdf:PlainLiteral
*
an annotation property and the URI is in the set of built in
* annotation property URIs, i.e. one of:
*
*
rdfs:label
*
rdfs:comment
*
rdfs:seeAlso
*
rdfs:isDefinedBy
*
owl:deprecated
*
owl:priorVersion
*
owl:backwardCompatibleWith
*
owl:incompatibleWith
*
*
*
*
* @return {@code true} if this entity is a built in entity, or
* {@code false} if this entity is not a builtin entity.
*/
boolean isBuiltIn();
/**
* A convenience method that determines if this entity is an OWLClass
*
* @return {@code true} if this entity is an OWLClass, otherwise
* {@code false}
*/
boolean isOWLClass();
/**
* A convenience method that obtains this entity as an OWLClass (in order to
* avoid explicit casting).
*
* @return The entity as an OWLClass.
* @throws OWLRuntimeException
* if this entity is not an OWLClass (check with the isOWLClass
* method first).
*/
OWLClass asOWLClass();
/**
* A convenience method that determines if this entity is an
* OWLObjectProperty
*
* @return {@code true} if this entity is an OWLObjectProperty, otherwise
* {@code false}
*/
boolean isOWLObjectProperty();
/**
* A convenience method that obtains this entity as an OWLObjectProperty (in
* order to avoid explicit casting).
*
* @return The entity as an OWLObjectProperty.
* @throws OWLRuntimeException
* if this entity is not an OWLObjectProperty (check with the
* isOWLObjectProperty method first).
*/
OWLObjectProperty asOWLObjectProperty();
/**
* A convenience method that determines if this entity is an OWLDataProperty
*
* @return {@code true} if this entity is an OWLDataProperty, otherwise
* {@code false}
*/
boolean isOWLDataProperty();
/**
* A convenience method that obtains this entity as an OWLDataProperty (in
* order to avoid explicit casting).
*
* @return The entity as an OWLDataProperty.
* @throws OWLRuntimeException
* if this entity is not an OWLDataProperty (check with the
* isOWLDataProperty method first).
*/
OWLDataProperty asOWLDataProperty();
/**
* A convenience method that determines if this entity is an
* OWLNamedIndividual
*
* @return {@code true} if this entity is an OWLNamedIndividual, otherwise
* {@code false}
*/
boolean isOWLNamedIndividual();
/**
* A convenience method that obtains this entity as an OWLNamedIndividual
* (in order to avoid explicit casting).
*
* @return The entity as an OWLNamedIndividual.
* @throws OWLRuntimeException
* if this entity is not an OWLIndividual (check with the
* isOWLIndividual method first).
*/
OWLNamedIndividual asOWLNamedIndividual();
/**
* A convenience method that determines if this entity is an OWLDatatype
*
* @return {@code true} if this entity is an OWLDatatype, otherwise
* {@code false}
*/
boolean isOWLDatatype();
/**
* A convenience method that obtains this entity as an OWLDatatype (in order
* to avoid explicit casting).
*
* @return The entity as an OWLDatatype.
* @throws OWLRuntimeException
* if this entity is not an OWLDatatype (check with the
* isOWLDatatype method first).
*/
OWLDatatype asOWLDatatype();
/**
* A convenience method that determines if this entity is an
* OWLAnnotationProperty
*
* @return {@code true} if this entity is an OWLAnnotationProperty,
* otherwise {@code false}
*/
boolean isOWLAnnotationProperty();
/**
* A convenience method that obtains this entity as an OWLAnnotationProperty
* (in order to avoid explicit casting).
*
* @return The entity as an OWLAnnotationProperty.
* @throws OWLRuntimeException
* if this entity is not an OWLAnnotationProperty
*/
OWLAnnotationProperty asOWLAnnotationProperty();
/**
* Returns a string representation that can be used as the ID of this
* entity. This is the toString representation of the IRI
*
* @return A string representing the toString of the IRI of this entity.
*/
String toStringID();
/**
* Gets the axioms in the specified ontology that contain this entity in
* their signature.
*
* @param ontology
* The ontology that will be searched for axioms
* @return The axioms in the specified ontology whose signature contains
* this entity.
*/
Set getReferencingAxioms(OWLOntology ontology);
/**
* Gets the axioms in the specified ontology and possibly its imports
* closure that contain this entity in their signature.
*
* @param ontology
* The ontology that will be searched for axioms
* @param includeImports
* If {@code true} then axioms in the imports closure will also be
* returned, if {@code false} then only the axioms in the specified
* ontology will be returned.
* @return The axioms in the specified ontology whose signature contains
* this entity.
*/
Set getReferencingAxioms(OWLOntology ontology,
boolean includeImports);
/**
* Accepts a visitor
*
* @param visitor
* The visitor
*/
void accept(OWLEntityVisitor visitor);
/**
* Accepts a visitor
*
* @param visitor
* The visitor
* @param
* visitor return type
* @return visitor value
*/
O accept(OWLEntityVisitorEx visitor);
}