}
}
else if( term.getAFun().equals( ATermUtils.DISJOINTSFUN ) ) {
Set<OWLClassExpression> descriptions = new HashSet<OWLClassExpression>();
ATermList concepts = (ATermList) term.getArgument( 0 );
for( ; !concepts.isEmpty(); concepts = concepts.getNext() ) {
ATermAppl concept = (ATermAppl) concepts.getFirst();
OWLClassExpression c = (OWLClassExpression) conceptConverter.convert( concept );
if( c == null ) {
break;
}
descriptions.add( c );
}
// if no error occurred list will be empty
if( concepts.isEmpty() ) {
axiom = factory.getOWLDisjointClassesAxiom( descriptions );
}
}
else if( term.getAFun().equals( ATermUtils.DISJOINTFUN ) ) {
OWLClassExpression c1 = (OWLClassExpression) conceptConverter.convert( (ATermAppl) term
.getArgument( 0 ) );
OWLClassExpression c2 = (OWLClassExpression) conceptConverter.convert( (ATermAppl) term
.getArgument( 1 ) );
Set<OWLClassExpression> descriptions = new HashSet<OWLClassExpression>();
descriptions.add( c1 );
descriptions.add( c2 );
if( c1 != null && c2 != null ) {
axiom = factory.getOWLDisjointClassesAxiom( descriptions );
}
}
else if( term.getAFun().equals( ATermUtils.DISJOINTPROPSFUN ) ) {
Set<OWLObjectProperty> objProperties = new HashSet<OWLObjectProperty>();
Set<OWLDataProperty> dataProperties = new HashSet<OWLDataProperty>();
ATermList props = (ATermList) term.getArgument( 0 );
for( ; !props.isEmpty(); props = props.getNext() ) {
OWLObject p = conceptConverter.convert( (ATermAppl) term.getArgument( 0 ) );
if( p == null ) {
break;
}
else if( p instanceof OWLObjectProperty ) {
if( !dataProperties.isEmpty() ) {
break;
}
else {
objProperties.add( (OWLObjectProperty) p );
}
}
else {
if( !objProperties.isEmpty() ) {
break;
}
else {
dataProperties.add( (OWLDataProperty) p );
}
}
}
// if no error occurred list will be empty
if( props.isEmpty() ) {
if( !objProperties.isEmpty() ) {
axiom = factory
.getOWLDisjointObjectPropertiesAxiom( objProperties );
}
else {
axiom = factory
.getOWLDisjointDataPropertiesAxiom( dataProperties );
}
}
}
else if( term.getAFun().equals( ATermUtils.DISJOINTPROPFUN ) ) {
OWLObject p1 = conceptConverter.convert( (ATermAppl) term.getArgument( 0 ) );
OWLObject p2 = conceptConverter.convert( (ATermAppl) term.getArgument( 1 ) );
if( p1 != null && p2 != null ) {
if( p1 instanceof OWLObjectProperty && p2 instanceof OWLObjectProperty ) {
axiom = factory.getOWLDisjointObjectPropertiesAxiom( SetUtils.create(
(OWLObjectProperty) p1, (OWLObjectProperty) p2 ) );
}
else if( p1 instanceof OWLDataProperty && p2 instanceof OWLDataProperty ) {
axiom = factory.getOWLDisjointDataPropertiesAxiom( SetUtils.create(
(OWLDataProperty) p1, (OWLDataProperty) p2 ) );
}
}
}
else if( term.getAFun().equals( ATermUtils.SUBPROPFUN ) ) {
if( term.getArgument( 0 ) instanceof ATermList ) {
List<OWLObjectPropertyExpression> subs = new ArrayList<OWLObjectPropertyExpression>();
for( ATermList list = (ATermList) term.getArgument( 0 ); !list.isEmpty(); list = list
.getNext() ) {
OWLObjectPropertyExpression p = (OWLObjectPropertyExpression) conceptConverter
.convert( (ATermAppl) list.getFirst() );
if( p == null ) {
subs = null;
break;
}
subs.add( p );
}
OWLObjectProperty sup = (OWLObjectProperty) conceptConverter
.convert( (ATermAppl) term.getArgument( 1 ) );
if( subs != null && sup != null ) {
axiom = factory.getOWLSubPropertyChainOfAxiom( subs, sup );
}
}
else {
OWLObject p1 = conceptConverter.convert( (ATermAppl) term.getArgument( 0 ) );
OWLObject p2 = conceptConverter.convert( (ATermAppl) term.getArgument( 1 ) );
if( p1 != null && p2 != null ) {
if( p1 instanceof OWLObjectPropertyExpression && p2 instanceof OWLObjectPropertyExpression ) {
axiom = factory.getOWLSubObjectPropertyOfAxiom( (OWLObjectPropertyExpression) p1,
(OWLObjectPropertyExpression) p2 );
}
else if( p1 instanceof OWLDataProperty && p2 instanceof OWLDataProperty ) {
axiom = factory.getOWLSubDataPropertyOfAxiom( (OWLDataProperty) p1,
(OWLDataProperty) p2 );
}
}
}
}
else if( term.getAFun().equals( ATermUtils.EQPROPFUN ) ) {
OWLObject p1 = conceptConverter.convert( (ATermAppl) term.getArgument( 0 ) );
OWLObject p2 = conceptConverter.convert( (ATermAppl) term.getArgument( 1 ) );
if( p1 != null && p2 != null ) {
if( p1 instanceof OWLObjectProperty && p2 instanceof OWLObjectProperty ) {
axiom = factory.getOWLEquivalentObjectPropertiesAxiom( SetUtils.create(
(OWLObjectProperty) p1, (OWLObjectProperty) p2 ) );
}
else if( p1 instanceof OWLDataProperty && p2 instanceof OWLDataProperty ) {
axiom = factory.getOWLEquivalentDataPropertiesAxiom( SetUtils.create(
(OWLDataProperty) p1, (OWLDataProperty) p2 ) );
}
}
}
else if( term.getAFun().equals( ATermUtils.DOMAINFUN ) ) {
OWLObject p = conceptConverter.convert( (ATermAppl) term.getArgument( 0 ) );
OWLClassExpression c = (OWLClassExpression) conceptConverter.convert( (ATermAppl) term
.getArgument( 1 ) );
if( c != null && p != null ) {
if( p instanceof OWLObjectProperty ) {
axiom = factory.getOWLObjectPropertyDomainAxiom(
(OWLObjectPropertyExpression) p, c );
}
else {
axiom = factory
.getOWLDataPropertyDomainAxiom( (OWLDataPropertyExpression) p, c );
}
}
}
else if( term.getAFun().equals( ATermUtils.RANGEFUN ) ) {
OWLPropertyRange e = (OWLPropertyRange) conceptConverter.convert( (ATermAppl) term
.getArgument( 1 ) );
if( e != null ) {
if( e instanceof OWLClassExpression ) {
OWLObjectProperty p = (OWLObjectProperty) conceptConverter
.convert( (ATermAppl) term.getArgument( 0 ) );
if( p != null ) {
axiom = factory.getOWLObjectPropertyRangeAxiom( p, (OWLClassExpression) e );
}
}
else {
OWLDataProperty p = (OWLDataProperty) conceptConverter
.convert( (ATermAppl) term.getArgument( 0 ) );
if( p != null ) {
axiom = factory.getOWLDataPropertyRangeAxiom( p, (OWLDataRange) e );
}
}
}
}
else if( term.getAFun().equals( ATermUtils.INVPROPFUN ) ) {
OWLObjectProperty p1 = (OWLObjectProperty) conceptConverter.convert( (ATermAppl) term
.getArgument( 0 ) );
OWLObjectProperty p2 = (OWLObjectProperty) conceptConverter.convert( (ATermAppl) term
.getArgument( 1 ) );
if( p1 != null && p2 != null ) {
axiom = factory.getOWLInverseObjectPropertiesAxiom( p1, p2 );
}
}
else if( term.getAFun().equals( ATermUtils.TRANSITIVEFUN ) ) {
OWLObjectProperty p = (OWLObjectProperty) conceptConverter.convert( (ATermAppl) term
.getArgument( 0 ) );
if( p != null ) {
axiom = factory.getOWLTransitiveObjectPropertyAxiom( p );
}
}
else if( term.getAFun().equals( ATermUtils.FUNCTIONALFUN ) ) {
OWLObject p = conceptConverter.convert( (ATermAppl) term.getArgument( 0 ) );
if( p != null ) {
if( p instanceof OWLObjectProperty ) {
axiom = factory
.getOWLFunctionalObjectPropertyAxiom( (OWLObjectPropertyExpression) p );
}
else if( p instanceof OWLDataProperty ) {
axiom = factory
.getOWLFunctionalDataPropertyAxiom( (OWLDataPropertyExpression) p );
}
}
}
else if( term.getAFun().equals( ATermUtils.INVFUNCTIONALFUN ) ) {
OWLObjectProperty p = (OWLObjectProperty) conceptConverter.convert( (ATermAppl) term
.getArgument( 0 ) );
if( p != null ) {
axiom = factory.getOWLInverseFunctionalObjectPropertyAxiom( p );
}
}
else if( term.getAFun().equals( ATermUtils.SYMMETRICFUN ) ) {
OWLObject p = conceptConverter.convert( (ATermAppl) term.getArgument( 0 ) );
if( p != null && p instanceof OWLObjectPropertyExpression ) {
axiom = factory
.getOWLSymmetricObjectPropertyAxiom( (OWLObjectPropertyExpression) p );
}
}
else if( term.getAFun().equals( ATermUtils.ASYMMETRICFUN ) ) {
OWLObject p = conceptConverter.convert( (ATermAppl) term.getArgument( 0 ) );
if( p != null && p instanceof OWLObjectPropertyExpression ) {
axiom = factory
.getOWLAsymmetricObjectPropertyAxiom( (OWLObjectPropertyExpression) p );
}
}
else if( term.getAFun().equals( ATermUtils.REFLEXIVEFUN ) ) {
OWLObject p = conceptConverter.convert( (ATermAppl) term.getArgument( 0 ) );
if( p != null && p instanceof OWLObjectPropertyExpression ) {
axiom = factory
.getOWLReflexiveObjectPropertyAxiom( (OWLObjectPropertyExpression) p );
}
}
else if( term.getAFun().equals( ATermUtils.IRREFLEXIVEFUN ) ) {
OWLObject p = conceptConverter.convert( (ATermAppl) term.getArgument( 0 ) );
if( p != null && p instanceof OWLObjectPropertyExpression ) {
axiom = factory
.getOWLIrreflexiveObjectPropertyAxiom( (OWLObjectPropertyExpression) p );
}
}
else if( term.getAFun().equals( ATermUtils.TYPEFUN ) ) {
OWLIndividual i = conceptConverter.convertIndividual((ATermAppl) term
.getArgument( 0 ) );
OWLClassExpression c = (OWLClassExpression) conceptConverter.convert( (ATermAppl) term
.getArgument( 1 ) );
if( i != null && c != null ) {
axiom = factory.getOWLClassAssertionAxiom( c, i );
}
}
else if( term.getAFun().equals( ATermUtils.PROPFUN ) ) {
OWLIndividual subj = conceptConverter.convertIndividual((ATermAppl) term
.getArgument( 1 ) );
if( subj == null ) {
axiom = null;
}
else if( ATermUtils.isLiteral( (ATermAppl) term.getArgument( 2 ) ) ) {
OWLDataProperty pred = (OWLDataProperty) conceptConverter.convert( (ATermAppl) term
.getArgument( 0 ) );
OWLLiteral obj = (OWLLiteral) conceptConverter.convert( (ATermAppl) term
.getArgument( 2 ) );
if( pred != null && obj != null ) {
axiom = factory.getOWLDataPropertyAssertionAxiom( pred, subj, obj );
}
}
else {
OWLObjectProperty pred = (OWLObjectProperty) conceptConverter
.convert( (ATermAppl) term.getArgument( 0 ) );
OWLIndividual obj = conceptConverter.convertIndividual((ATermAppl) term
.getArgument( 2 ) );
if( pred != null && obj != null ) {
axiom = factory.getOWLObjectPropertyAssertionAxiom( pred, subj, obj );
}
}
}
else if( term.getAFun().equals( ATermUtils.NOTFUN )
&& ((ATermAppl) term.getArgument( 0 )).getAFun().equals( ATermUtils.PROPFUN ) ) {
term = (ATermAppl) term.getArgument( 0 );
OWLIndividual subj = conceptConverter.convertIndividual((ATermAppl) term
.getArgument( 1 ) );
if( subj == null ) {
axiom = null;
}
else if( ATermUtils.isLiteral( (ATermAppl) term.getArgument( 2 ) ) ) {
OWLDataProperty pred = (OWLDataProperty) conceptConverter.convert( (ATermAppl) term
.getArgument( 0 ) );
OWLLiteral obj = (OWLLiteral) conceptConverter.convert( (ATermAppl) term
.getArgument( 2 ) );
if( pred != null && obj != null ) {
axiom = factory.getOWLNegativeDataPropertyAssertionAxiom( pred, subj, obj );
}
}
else {
OWLObjectProperty pred = (OWLObjectProperty) conceptConverter
.convert( (ATermAppl) term.getArgument( 0 ) );
OWLIndividual obj = conceptConverter.convertIndividual((ATermAppl) term
.getArgument( 2 ) );
if( pred != null && obj != null ) {
axiom = factory.getOWLNegativeObjectPropertyAssertionAxiom( pred, subj, obj );
}
}
}
else if( term.getAFun().equals( ATermUtils.SAMEASFUN ) ) {
OWLIndividual ind1 = conceptConverter.convertIndividual((ATermAppl) term
.getArgument( 0 ) );
OWLIndividual ind2 = conceptConverter.convertIndividual((ATermAppl) term
.getArgument( 1 ) );
Set<OWLIndividual> inds = new HashSet<OWLIndividual>();
inds.add( ind1 );
inds.add( ind2 );
if( ind1 != null && ind2 != null ) {
axiom = factory.getOWLSameIndividualAxiom( inds );
}
}
else if( term.getAFun().equals( ATermUtils.DIFFERENTFUN ) ) {
OWLIndividual ind1 = conceptConverter.convertIndividual((ATermAppl) term
.getArgument( 0 ) );
OWLIndividual ind2 = conceptConverter.convertIndividual((ATermAppl) term
.getArgument( 1 ) );
Set<OWLIndividual> inds = new HashSet<OWLIndividual>();
inds.add( ind1 );
inds.add( ind2 );
if( ind1 != null && ind2 != null ) {
axiom = factory.getOWLDifferentIndividualsAxiom( inds );
}
}
else if( term.getAFun().equals( ATermUtils.ALLDIFFERENTFUN ) ) {
Set<OWLIndividual> individuals = new HashSet<OWLIndividual>();
ATermList list = (ATermList) term.getArgument( 0 );
for( ; !list.isEmpty(); list = list.getNext() ) {
ATermAppl ind = (ATermAppl) list.getFirst();
OWLIndividual i = conceptConverter.convertIndividual(ind);
if( i == null ) {
break;
}
individuals.add( i );
}
// if no error occurred list will be empty
if( list.isEmpty() ) {
axiom = factory.getOWLDifferentIndividualsAxiom( individuals );
}
}
else if( term.getAFun().equals( ATermUtils.RULEFUN ) ) {
Set<SWRLAtom> antecedent = new HashSet<SWRLAtom>(); // Body
Set<SWRLAtom> consequent = new HashSet<SWRLAtom>(); // Head
ATermList head = (ATermList) term.getArgument( 1 );
ATermList body = (ATermList) term.getArgument( 2 );
for( ; !body.isEmpty(); body = body.getNext() ) {
antecedent.add( parseToSWRLAtom( (ATermAppl) body.getFirst() ) );
}
for( ; !head.isEmpty(); head = head.getNext() ) {
consequent.add( parseToSWRLAtom( (ATermAppl) head.getFirst() ) );
}