All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.protege.editor.owl.model.util.ObjectPropertyDefinitionExtractor Maven / Gradle / Ivy

package org.protege.editor.owl.model.util;

import org.semanticweb.owlapi.model.*;

import javax.annotation.Nonnull;
import java.util.ArrayList;
import java.util.Collection;
import java.util.List;
import java.util.Set;
import java.util.stream.Stream;

import static com.google.common.base.Preconditions.checkNotNull;
import static java.util.stream.Collectors.toSet;

/**
 * Matthew Horridge
 * Stanford Center for Biomedical Informatics Research
 * 29 Aug 2017
 */
public class ObjectPropertyDefinitionExtractor {

    @Nonnull
    private final OWLObjectProperty property;

    @Nonnull
    private final OWLOntology ontology;

    @Nonnull
    private final OWLDataFactory dataFactory;

    public ObjectPropertyDefinitionExtractor(@Nonnull OWLObjectProperty property,
                                             @Nonnull OWLOntology ontology,
                                             @Nonnull OWLDataFactory dataFactory) {
        this.property = checkNotNull(property);
        this.ontology = checkNotNull(ontology);
        this.dataFactory = checkNotNull(dataFactory);
    }

    public Set getDefiningAxioms() {
        return Stream.concat(getUnaryAxioms(),
                             ontology.getDisjointObjectPropertiesAxioms(property).stream())
                     .collect(toSet());
    }

    private Stream getUnaryAxioms() {
        return Stream.of(
                ontology.getObjectSubPropertyAxiomsForSubProperty(property),
                ontology.getEquivalentObjectPropertiesAxioms(property),
                ontology.getFunctionalObjectPropertyAxioms(property),
                ontology.getInverseFunctionalObjectPropertyAxioms(property),
                ontology.getSymmetricObjectPropertyAxioms(property),
                ontology.getTransitiveObjectPropertyAxioms(property),
                ontology.getAsymmetricObjectPropertyAxioms(property),
                ontology.getReflexiveObjectPropertyAxioms(property),
                ontology.getIrreflexiveObjectPropertyAxioms(property),
                ontology.getObjectPropertyDomainAxioms(property),
                ontology.getObjectPropertyRangeAxioms(property))
                     .flatMap(Collection::stream);
    }


    public List getChangesToRemoveDefinition() {
        List changes = new ArrayList<>();
        getUnaryAxioms().forEach(ax -> changes.add(new RemoveAxiom(ontology, ax)));
        ontology.getDisjointObjectPropertiesAxioms(property).forEach(ax -> {
            changes.add(new RemoveAxiom(ontology, ax));
            if(ax.getProperties().size() > 2) {
                OWLDisjointObjectPropertiesAxiom replacement = dataFactory.getOWLDisjointObjectPropertiesAxiom(
                        ax.getPropertiesMinus(property),
                        ax.getAnnotations()
                );
                changes.add(new RemoveAxiom(ontology, replacement));
            }
        });
        return changes;
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy