org.semanticweb.elk.reasoner.saturation.rules.RuleCounter Maven / Gradle / Ivy
package org.semanticweb.elk.reasoner.saturation.rules;
/*
* #%L
* ELK Reasoner
* $Id:$
* $HeadURL:$
* %%
* Copyright (C) 2011 - 2012 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.reasoner.saturation.rules.backwardlinks.BackwardLinkChainFromBackwardLinkRule;
import org.semanticweb.elk.reasoner.saturation.rules.backwardlinks.ContradictionOverBackwardLinkRule;
import org.semanticweb.elk.reasoner.saturation.rules.backwardlinks.SubsumerBackwardLinkRule;
import org.semanticweb.elk.reasoner.saturation.rules.contextinit.OwlThingContextInitRule;
import org.semanticweb.elk.reasoner.saturation.rules.contextinit.RootContextInitializationRule;
import org.semanticweb.elk.reasoner.saturation.rules.contradiction.ContradictionPropagationRule;
import org.semanticweb.elk.reasoner.saturation.rules.disjointsubsumer.ContradictionCompositionRule;
import org.semanticweb.elk.reasoner.saturation.rules.forwardlink.BackwardLinkFromForwardLinkRule;
import org.semanticweb.elk.reasoner.saturation.rules.forwardlink.NonReflexiveBackwardLinkCompositionRule;
import org.semanticweb.elk.reasoner.saturation.rules.forwardlink.ReflexiveBackwardLinkCompositionRule;
import org.semanticweb.elk.reasoner.saturation.rules.propagations.SubsumerPropagationRule;
import org.semanticweb.elk.reasoner.saturation.rules.subcontextinit.PropagationInitializationRule;
import org.semanticweb.elk.reasoner.saturation.rules.subsumers.ComposedFromDecomposedSubsumerRule;
import org.semanticweb.elk.reasoner.saturation.rules.subsumers.ContradictionFromNegationRule;
import org.semanticweb.elk.reasoner.saturation.rules.subsumers.ContradictionFromOwlNothingRule;
import org.semanticweb.elk.reasoner.saturation.rules.subsumers.DisjointSubsumerFromMemberRule;
import org.semanticweb.elk.reasoner.saturation.rules.subsumers.EquivalentClassFirstFromSecondRule;
import org.semanticweb.elk.reasoner.saturation.rules.subsumers.EquivalentClassSecondFromFirstRule;
import org.semanticweb.elk.reasoner.saturation.rules.subsumers.IndexedClassDecompositionRule;
import org.semanticweb.elk.reasoner.saturation.rules.subsumers.IndexedClassFromDefinitionRule;
import org.semanticweb.elk.reasoner.saturation.rules.subsumers.IndexedObjectComplementOfDecomposition;
import org.semanticweb.elk.reasoner.saturation.rules.subsumers.IndexedObjectHasSelfDecomposition;
import org.semanticweb.elk.reasoner.saturation.rules.subsumers.IndexedObjectIntersectionOfDecomposition;
import org.semanticweb.elk.reasoner.saturation.rules.subsumers.IndexedObjectSomeValuesFromDecomposition;
import org.semanticweb.elk.reasoner.saturation.rules.subsumers.ObjectIntersectionFromFirstConjunctRule;
import org.semanticweb.elk.reasoner.saturation.rules.subsumers.ObjectIntersectionFromSecondConjunctRule;
import org.semanticweb.elk.reasoner.saturation.rules.subsumers.ObjectUnionFromDisjunctRule;
import org.semanticweb.elk.reasoner.saturation.rules.subsumers.PropagationFromExistentialFillerRule;
import org.semanticweb.elk.reasoner.saturation.rules.subsumers.SuperClassFromSubClassRule;
/**
* An object which can be used to measure the methods invocations of a
* {@link RuleVisitor}. The fields of the counter correspond to the methods of
* {@link RuleVisitor}.
*
* @author "Yevgeny Kazakov"
*/
public class RuleCounter {
/**
* counter for {@link BackwardLinkChainFromBackwardLinkRule}
*/
long countBackwardLinkChainFromBackwardLinkRule;
/**
* counter for {@link BackwardLinkFromForwardLinkRule}
*/
long countBackwardLinkFromForwardLinkRule;
/**
* counter for {@link ComposedFromDecomposedSubsumerRule}
*/
long countComposedFromDecomposedSubsumerRule;
/**
* counter for {@link ContradictionCompositionRule}
*/
long countContradictionCompositionRule;
/**
* counter for {@link ContradictionFromNegationRule}
*/
long countContradictionFromNegationRule;
/**
* counter for {@link ContradictionFromOwlNothingRule}
*/
long countContradictionFromOwlNothingRule;
/**
* counter for {@link ContradictionOverBackwardLinkRule}
*/
long countContradictionOverBackwardLinkRule;
/**
* counter for {@link ContradictionPropagationRule}
*/
long countContradictionPropagationRule;
/**
* counter for {@link DisjointSubsumerFromMemberRule}
*/
long countDisjointSubsumerFromMemberRule;
/**
* counter for {@link IndexedClassDecompositionRule}
*/
long countIndexedClassDecompositionRule;
/**
* counter for {@link IndexedClassFromDefinitionRule}
*/
long countIndexedClassFromDefinitionRule;
/**
* counter for {@link IndexedObjectComplementOfDecomposition}
*/
long countIndexedObjectComplementOfDecomposition;
/**
* counter for {@link IndexedObjectHasSelfDecomposition}
*/
long countIndexedObjectHasSelfDecomposition;
/**
* counter for {@link IndexedObjectIntersectionOfDecomposition}
*/
long countIndexedObjectIntersectionOfDecomposition;
/**
* counter for {@link IndexedObjectSomeValuesFromDecomposition}
*/
long countIndexedObjectSomeValuesFromDecomposition;
/**
* counter for {@link NonReflexiveBackwardLinkCompositionRule}
*/
long countNonReflexiveBackwardLinkCompositionRule;
/**
* counter for {@link ObjectIntersectionFromFirstConjunctRule}
*/
long countObjectIntersectionFromFirstConjunctRule;
/**
* counter for {@link ObjectIntersectionFromSecondConjunctRule}
*/
long countObjectIntersectionFromSecondConjunctRule;
/**
* counter for {@link ObjectUnionFromDisjunctRule}
*/
long countObjectUnionFromDisjunctRule;
/**
* counter for {@link OwlNothingDecompositionRule}
*/
long countOwlNothingDecompositionRule;
/**
* counter for {@link OwlThingContextInitRule}
*/
long countOwlThingContextInitRule;
/**
* counter for {@link PropagationFromExistentialFillerRule}
*/
long countPropagationFromExistentialFillerRule;
/**
* counter for {@link PropagationInitializationRule}
*/
long countPropagationInitializationRule;
/**
* counter for {@link ReflexiveBackwardLinkCompositionRule}
*/
long countReflexiveBackwardLinkCompositionRule;
/**
* counter for {@link RootContextInitializationRule}
*/
long countRootContextInitializationRule;
/**
* counter for {@link SubsumerBackwardLinkRule}
*/
long countSubsumerBackwardLinkRule;
/**
* counter for {@link SubsumerPropagationRule}
*/
long countSubsumerPropagationRule;
/**
* counter for {@link SuperClassFromSubClassRule}
*/
long countSuperClassFromSubClassRule;
/**
* counter for {@link EquivalentClassFirstFromSecondRule}
*/
long countEquivalentClassFirstFromSecondRule;
/**
* counter for {@link EquivalentClassSecondFromFirstRule}
*/
long countEquivalentClassSecondFromFirstRule;
/**
* Add the values to the corresponding values of the given counter
*
* @param counter
* the counter to which the values should be added
*/
public synchronized void add(RuleCounter counter) {
countOwlThingContextInitRule += counter.countOwlThingContextInitRule;
countRootContextInitializationRule += counter.countRootContextInitializationRule;
countDisjointSubsumerFromMemberRule += counter.countDisjointSubsumerFromMemberRule;
countContradictionFromNegationRule += counter.countContradictionFromNegationRule;
countObjectIntersectionFromFirstConjunctRule += counter.countObjectIntersectionFromFirstConjunctRule;
countObjectIntersectionFromSecondConjunctRule += counter.countObjectIntersectionFromSecondConjunctRule;
countSuperClassFromSubClassRule += counter.countSuperClassFromSubClassRule;
countPropagationFromExistentialFillerRule += counter.countPropagationFromExistentialFillerRule;
countObjectUnionFromDisjunctRule += counter.countObjectUnionFromDisjunctRule;
countOwlNothingDecompositionRule += counter.countOwlNothingDecompositionRule;
countBackwardLinkChainFromBackwardLinkRule += counter.countBackwardLinkChainFromBackwardLinkRule;
countSubsumerBackwardLinkRule += counter.countSubsumerBackwardLinkRule;
countContradictionOverBackwardLinkRule += counter.countContradictionOverBackwardLinkRule;
countContradictionPropagationRule += counter.countContradictionPropagationRule;
countContradictionCompositionRule += counter.countContradictionCompositionRule;
countNonReflexiveBackwardLinkCompositionRule += counter.countNonReflexiveBackwardLinkCompositionRule;
countIndexedObjectIntersectionOfDecomposition += counter.countIndexedObjectIntersectionOfDecomposition;
countIndexedObjectSomeValuesFromDecomposition += counter.countIndexedObjectSomeValuesFromDecomposition;
countIndexedObjectComplementOfDecomposition += counter.countIndexedObjectComplementOfDecomposition;
countIndexedObjectHasSelfDecomposition += counter.countIndexedObjectHasSelfDecomposition;
countContradictionFromOwlNothingRule += counter.countContradictionFromOwlNothingRule;
countSubsumerPropagationRule += counter.countSubsumerPropagationRule;
countReflexiveBackwardLinkCompositionRule += counter.countReflexiveBackwardLinkCompositionRule;
countPropagationInitializationRule += counter.countPropagationInitializationRule;
countBackwardLinkFromForwardLinkRule += counter.countBackwardLinkFromForwardLinkRule;
countComposedFromDecomposedSubsumerRule += counter.countComposedFromDecomposedSubsumerRule;
countIndexedClassDecompositionRule += counter.countIndexedClassDecompositionRule;
countIndexedClassFromDefinitionRule += counter.countIndexedClassFromDefinitionRule;
countEquivalentClassFirstFromSecondRule += counter.countEquivalentClassFirstFromSecondRule;
countEquivalentClassSecondFromFirstRule += counter.countEquivalentClassSecondFromFirstRule;
}
public long getTotalRuleAppCount() {
return countOwlThingContextInitRule + countRootContextInitializationRule
+ countDisjointSubsumerFromMemberRule
+ countContradictionFromNegationRule
+ countObjectIntersectionFromFirstConjunctRule
+ countObjectIntersectionFromSecondConjunctRule
+ countSuperClassFromSubClassRule
+ countPropagationFromExistentialFillerRule
+ countObjectUnionFromDisjunctRule
+ countOwlNothingDecompositionRule
+ countBackwardLinkChainFromBackwardLinkRule
+ countSubsumerBackwardLinkRule
+ countContradictionOverBackwardLinkRule
+ countContradictionPropagationRule
+ countContradictionCompositionRule
+ countNonReflexiveBackwardLinkCompositionRule
+ countReflexiveBackwardLinkCompositionRule
+ countIndexedObjectIntersectionOfDecomposition
+ countIndexedObjectSomeValuesFromDecomposition
+ countIndexedObjectComplementOfDecomposition
+ countIndexedObjectHasSelfDecomposition
+ countContradictionFromOwlNothingRule
+ countSubsumerPropagationRule
+ countPropagationInitializationRule
+ countBackwardLinkFromForwardLinkRule
+ countComposedFromDecomposedSubsumerRule
+ countIndexedClassDecompositionRule
+ countIndexedClassFromDefinitionRule
+ countEquivalentClassFirstFromSecondRule
+ countEquivalentClassSecondFromFirstRule;
}
/**
* Reset all counters to zero.
*/
public void reset() {
countOwlThingContextInitRule = 0;
countRootContextInitializationRule = 0;
countDisjointSubsumerFromMemberRule = 0;
countContradictionFromNegationRule = 0;
countObjectIntersectionFromFirstConjunctRule = 0;
countObjectIntersectionFromSecondConjunctRule = 0;
countSuperClassFromSubClassRule = 0;
countPropagationFromExistentialFillerRule = 0;
countObjectUnionFromDisjunctRule = 0;
countOwlNothingDecompositionRule = 0;
countBackwardLinkChainFromBackwardLinkRule = 0;
countSubsumerBackwardLinkRule = 0;
countContradictionOverBackwardLinkRule = 0;
countContradictionPropagationRule = 0;
countContradictionCompositionRule = 0;
countNonReflexiveBackwardLinkCompositionRule = 0;
countReflexiveBackwardLinkCompositionRule = 0;
countIndexedObjectIntersectionOfDecomposition = 0;
countIndexedObjectSomeValuesFromDecomposition = 0;
countIndexedObjectComplementOfDecomposition = 0;
countIndexedObjectHasSelfDecomposition = 0;
countContradictionFromOwlNothingRule = 0;
countSubsumerPropagationRule = 0;
countPropagationInitializationRule = 0;
countBackwardLinkFromForwardLinkRule = 0;
countComposedFromDecomposedSubsumerRule = 0;
countIndexedClassDecompositionRule = 0;
countIndexedClassFromDefinitionRule = 0;
countEquivalentClassFirstFromSecondRule = 0;
countEquivalentClassSecondFromFirstRule = 0;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy