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

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