org.semanticweb.elk.matching.inferences.SubClassInclusionDecomposedSecondConjunctMatch2 Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of elk-proofs Show documentation
Show all versions of elk-proofs Show documentation
Utilities to present tracing results (encoded proofs) to the
user
package org.semanticweb.elk.matching.inferences;
/*
* #%L
* ELK Proofs Package
* $Id:$
* $HeadURL:$
* %%
* Copyright (C) 2011 - 2016 Department of Computer Science, University of Oxford
* %%
* 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.
* #L%
*/
import org.semanticweb.elk.matching.conclusions.ConclusionMatchExpressionFactory;
import org.semanticweb.elk.matching.conclusions.SubClassInclusionDecomposedMatch2;
import org.semanticweb.elk.matching.root.IndexedContextRootMatch;
import org.semanticweb.elk.matching.subsumers.IndexedObjectIntersectionOfMatch;
import org.semanticweb.elk.owl.interfaces.ElkObjectIntersectionOf;
public class SubClassInclusionDecomposedSecondConjunctMatch2 extends
AbstractInferenceMatch {
private final IndexedContextRootMatch extendedOriginMatch_;
private final ElkObjectIntersectionOf fullSubsumerMatch_;
private final int premiseSubsumerPrefixLength_;
SubClassInclusionDecomposedSecondConjunctMatch2(
SubClassInclusionDecomposedSecondConjunctMatch1 parent,
SubClassInclusionDecomposedMatch2 premiseMatch) {
super(parent);
this.extendedOriginMatch_ = premiseMatch.getExtendedDestinationMatch();
IndexedObjectIntersectionOfMatch premiseSubsumerMatch = premiseMatch
.getSubsumerIndexedObjectIntersectionOfMatch();
this.fullSubsumerMatch_ = premiseSubsumerMatch.getFullValue();
this.premiseSubsumerPrefixLength_ = premiseSubsumerMatch
.getPrefixLength();
checkEquals(premiseMatch, getPremiseMatch(DEBUG_FACTORY));
}
public IndexedContextRootMatch getExtendedOriginMatch() {
return extendedOriginMatch_;
}
public ElkObjectIntersectionOf getFullSubsumerMatch() {
return fullSubsumerMatch_;
}
public int getPremiseSubsumerPrefixLength() {
return premiseSubsumerPrefixLength_;
}
SubClassInclusionDecomposedMatch2 getPremiseMatch(
ConclusionMatchExpressionFactory factory) {
return factory.getSubClassInclusionDecomposedMatch2(
getParent().getPremiseMatch(factory), getExtendedOriginMatch(),
getFullSubsumerMatch(), getPremiseSubsumerPrefixLength());
}
public SubClassInclusionDecomposedMatch2 getConclusionMatch(
ConclusionMatchExpressionFactory factory) {
return factory.getSubClassInclusionDecomposedMatch2(
getParent().getConclusionMatch(factory),
getExtendedOriginMatch(),
getFullSubsumerMatch().getClassExpressions()
.get(getPremiseSubsumerPrefixLength() - 1));
}
@Override
public O accept(InferenceMatch.Visitor visitor) {
return visitor.visit(this);
}
/**
* The visitor pattern for instances
*
* @author Yevgeny Kazakov
*
* @param
* the type of the output
*/
public interface Visitor {
O visit(SubClassInclusionDecomposedSecondConjunctMatch2 inferenceMatch2);
}
/**
* A factory for creating instances
*
* @author Yevgeny Kazakov
*
*/
public interface Factory {
SubClassInclusionDecomposedSecondConjunctMatch2 getSubClassInclusionDecomposedSecondConjunctMatch2(
SubClassInclusionDecomposedSecondConjunctMatch1 parent,
SubClassInclusionDecomposedMatch2 premiseMatch);
}
}