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

org.semanticweb.elk.reasoner.taxonomy.hashing.InstanceTaxonomyEqualator Maven / Gradle / Ivy

package org.semanticweb.elk.reasoner.taxonomy.hashing;

/*
 * #%L
 * ELK Reasoner
 * $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 java.util.Set;

import org.semanticweb.elk.owl.interfaces.ElkEntity;
import org.semanticweb.elk.reasoner.taxonomy.model.InstanceNode;
import org.semanticweb.elk.reasoner.taxonomy.model.InstanceTaxonomy;
import org.semanticweb.elk.reasoner.taxonomy.model.Taxonomy;
import org.semanticweb.elk.reasoner.taxonomy.model.TypeNode;

/**
 * Compares two instance taxonomies for equality. Two instance taxonomies are
 * equal when they are equal according to {@link TaxonomyEqualator}, each type
 * node has the same set of instance nodes and each instance node has the same
 * set of members and type nodes. If at least one compared taxonomy is not an
 * instance taxonomy, the taxonomies are compared only by
 * {@link TaxonomyEqualator}.
 * 
 * @author Peter Skocovsky
 */
public class InstanceTaxonomyEqualator {

	/**
	 * Compares two instance taxonomies for equality. Two instance taxonomies
	 * are equal when they are equal according to {@link TaxonomyEqualator},
	 * each type node has the same set of instance nodes and each instance node
	 * has the same set of members and type nodes. If at least one compared
	 * taxonomy is not an instance taxonomy, the taxonomies are compared only by
	 * {@link TaxonomyEqualator}.
	 * 
	 * @param 
	 *            the type of types of the instance taxonomies
	 * @param 
	 *            the type of instances of the instance taxonomies
	 * @param taxonomy1
	 *            The first taxonomy.
	 * @param taxonomy2
	 *            The second taxonomy.
	 * @return true if and only if the taxonomies are equal.
	 */
	public static  boolean equals(
			final Taxonomy taxonomy1, final Taxonomy taxonomy2) {

		// Check null and type nodes
		final boolean areTaxonomiesEqual = TaxonomyEqualator.equals(taxonomy1,
				taxonomy2);

		if (!areTaxonomiesEqual) {
			return false;
		}

		if (!(taxonomy1 instanceof InstanceTaxonomy)
				|| !(taxonomy2 instanceof InstanceTaxonomy)) {
			// If some of the arguments is just a Taxonomy, compare them only as
			// Taxonomies (ignore instances).
			return areTaxonomiesEqual;
		}
		try {
			@SuppressWarnings("unchecked")
			final InstanceTaxonomy instanceTaxonomy1 = (InstanceTaxonomy) taxonomy1;
			@SuppressWarnings("unchecked")
			final InstanceTaxonomy instanceTaxonomy2 = (InstanceTaxonomy) taxonomy2;

			/*
			 * Each instance node must have the same sets of members and types,
			 * each type node must have the same set of instances.
			 */

			final Set> instanceNodes1 = instanceTaxonomy1
					.getInstanceNodes();
			final Set> instanceNodes2 = instanceTaxonomy2
					.getInstanceNodes();

			if (instanceNodes1.size() != instanceNodes2.size()) {
				return false;
			}
			for (final InstanceNode instanceNode1 : instanceNodes1) {

				final I member1 = instanceNode1.getCanonicalMember();
				final InstanceNode instanceNode2 = instanceTaxonomy2
						.getInstanceNode(member1);
				if (instanceNode2 == null) {
					return false;
				}

				// Members
				if (instanceNode1.size() != instanceNode2.size()) {
					return false;
				}
				for (final I member : instanceNode1) {
					if (!instanceNode2.contains(member)) {
						return false;
					}
				}

				// Types
				final Set> types1 = instanceNode1
						.getDirectTypeNodes();
				final Set> types2 = instanceNode2
						.getDirectTypeNodes();
				if (types1.size() != types2.size()) {
					return false;
				}
				for (final TypeNode type1 : types1) {
					// While all nodes must be the same, it is sufficient to
					// compare canonical members.
					final TypeNode type2 = instanceTaxonomy2
							.getNode(type1.getCanonicalMember());
					/*
					 * otherType is a node from otherTaxonomy (or null), so
					 * contains(Object) on a node set from otherTaxonomy should
					 * work for it as expected.
					 */
					if (!types2.contains(type2)) {
						return false;
					}
				}

			}

			// Instances
			for (final TypeNode typeNode1 : instanceTaxonomy1
					.getNodes()) {

				final T member1 = typeNode1.getCanonicalMember();
				final TypeNode typeNode2 = instanceTaxonomy2
						.getNode(member1);

				final Set> instances1 = typeNode1
						.getDirectInstanceNodes();
				final Set> instances2 = typeNode2
						.getDirectInstanceNodes();
				if (instances1.size() != instances2.size()) {
					return false;
				}
				for (final InstanceNode instance1 : instances1) {
					// While all nodes must be the same, it is sufficient to
					// compare canonical members.
					final InstanceNode instance2 = instanceTaxonomy2
							.getInstanceNode(instance1.getCanonicalMember());
					/*
					 * otherType is a node from otherTaxonomy (or null), so
					 * contains(Object) on a node set from otherTaxonomy should
					 * work for it as expected.
					 */
					if (!instances2.contains(instance2)) {
						return false;
					}
				}

			}

		} catch (ClassCastException e) {
			// Some taxonomy contains members of unexpected type.
			return false;
		}

		return true;
	}

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy