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

org.metacsp.spatial.RCC.RCCConstraint Maven / Gradle / Ivy

/*******************************************************************************
 * Copyright (c) 2010-2013 Masoumeh Mansouri 
 * 
 * Permission is hereby granted, free of charge, to any person obtaining
 * a copy of this software and associated documentation files (the
 * "Software"), to deal in the Software without restriction, including
 * without limitation the rights to use, copy, modify, merge, publish,
 * distribute, sublicense, and/or sell copies of the Software, and to
 * permit persons to whom the Software is furnished to do so, subject to
 * the following conditions:
 * 
 * The above copyright notice and this permission notice shall be
 * included in all copies or substantial portions of the Software.
 * 
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
 * LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
 * OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
 * WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
 ******************************************************************************/
package org.metacsp.spatial.RCC;

import java.util.Arrays;

import org.metacsp.framework.BinaryConstraint;
import org.metacsp.framework.Constraint;

/**
 * Implementation of RCC-8 (Region Connection Calculus) constraints.
 * @author Masoumeh Mansouri
 *
 */
public class RCCConstraint extends BinaryConstraint{

	//protected Type type;
	
	/**
	 * 
	 */
	private static final long serialVersionUID = 1948378025485351843L;
	protected Type[] types;

	public RCCConstraint(Type... types) {
		this.types = types;
	}
	
	
	public Type[] getTypes() {
		return types;
	}

	
	public void setTypes(Type[] types) {
		this.types = types;
	}
	
//	public RCCConstraint(Type type){
//		
//		this.type = type;
//	}
	
	@Override
	public String getEdgeLabel() {
		// TODO Auto-generated method stub
		return Arrays.toString(this.types);
	}

	@Override
	public Object clone() {
		return new RCCConstraint(this.types);
	}

	@Override
	public boolean isEquivalent(Constraint c) {
		// TODO Auto-generated method stub
		return false;
	}
	
	public String toString() {
		String ret = "[";
		for (int i = 0; i < types.length; i++) {
			ret +="(" + this.getFrom() + ") --" + this.types[i] + "--> (" + this.getTo() + ")"; 
		}
		ret += "]";
		return ret;
	}
	
	
	public static enum Type {
		
		/**
		 * 
   Semantics: A DISCONNECTED B

       */ DC, //DisConnected /** *
   Semantics: A EXTERNALLY-CONNECTED B

       */ EC, //Externally Connected /** *
   Semantics: A PARTIALLY-OVERLAPPING B

       */ PO, //Partially Overlapping /** *
   Semantics: A TANGENTIAL-PROPER-PART B

       */ TPP, //Tangential Proper Part /** *
   Semantics: A NON-TANGENTIAL-PROPER-PART B

       */ NTPP, //Non-Tangential Proper Part /** *
   Semantics: A INVERSE-OF-TANGENTIAL-PROPER-PART B

       */ TPPI, //Inverse of Tangential Proper Part /** *
   Semantics: A INVERSE-OF-NON-TANGENTIAL-PROPER-PART B

       */ NTPPI, //inverse of Non-Tangential Proper Part /** *
   Semantics: A EQUALS B

       */ EQ //EQual }; //Type.DC, Type.EC, Type.PO, Type.TPP, Type.NTPP, Type.TPPI, Type.NTPPI, Type.EQ public static Type[][][] transitionTable = { { {Type.DC, Type.EC, Type.PO, Type.TPP, Type.NTPP, Type.TPPI, Type.NTPPI, Type.EQ}, {Type.DC, Type.EC, Type.PO, Type.TPP, Type.NTPP}, {Type.DC, Type.EC, Type.PO, Type.TPP, Type.NTPP}, {Type.DC, Type.EC, Type.PO, Type.TPP, Type.NTPP}, {Type.DC, Type.EC, Type.PO, Type.TPP, Type.NTPP}, {Type.DC}, {Type.DC}, {Type.DC} }, { {Type.DC, Type.EC, Type.PO, Type.TPPI, Type.NTPPI}, {Type.DC, Type.EC, Type.PO, Type.TPP, Type.TPPI, Type.EQ}, {Type.DC, Type.EC, Type.PO, Type.TPP, Type.NTPP}, {Type.EC, Type.PO, Type.TPP, Type.NTPP}, {Type.PO, Type.TPP, Type.NTPP}, {Type.DC, Type.EC}, {Type.DC}, {Type.EC} }, { {Type.DC, Type.EC, Type.PO, Type.TPPI, Type.NTPPI}, {Type.DC, Type.EC, Type.PO, Type.TPPI, Type.NTPPI}, {Type.DC, Type.EC, Type.PO, Type.TPP, Type.NTPP, Type.TPPI, Type.NTPPI, Type.EQ}, {Type.PO, Type.TPP, Type.NTPP}, {Type.PO, Type.TPP, Type.NTPP}, {Type.DC, Type.EC, Type.PO, Type.TPPI, Type.NTPPI}, {Type.DC, Type.EC, Type.PO, Type.TPPI, Type.NTPPI}, {Type.PO} }, { {Type.DC}, {Type.DC, Type.EC}, {Type.DC, Type.EC, Type.PO, Type.TPP, Type.NTPP}, {Type.TPP, Type.NTPP}, {Type.NTPP}, {Type.DC, Type.EC, Type.PO, Type.TPPI, Type.NTPPI, Type.EQ}, {Type.DC, Type.EC, Type.PO, Type.TPPI, Type.NTPPI}, {Type.TPP} }, { {Type.DC}, {Type.DC}, {Type.DC, Type.EC, Type.PO, Type.TPP, Type.NTPP}, {Type.NTPP}, {Type.NTPP}, {Type.DC, Type.EC, Type.PO, Type.TPP, Type.NTPP}, {Type.DC, Type.EC, Type.PO, Type.TPP, Type.NTPP, Type.TPPI, Type.NTPPI, Type.EQ}, {Type.NTPP} }, { {Type.DC, Type.EC, Type.PO, Type.TPPI, Type.NTPPI}, {Type.EC, Type.PO, Type.TPPI, Type.NTPPI}, {Type.PO, Type.TPPI, Type.NTPPI}, {Type.PO, Type.EQ, Type.TPP, Type.TPPI}, {Type.PO, Type.TPP, Type.NTPP}, {Type.TPPI, Type.NTPPI}, {Type.NTPPI}, {Type.TPPI} }, { {Type.DC, Type.EC, Type.PO, Type.TPPI, Type.NTPPI}, {Type.PO, Type.TPPI, Type.NTPPI}, {Type.PO, Type.TPPI, Type.NTPPI}, {Type.PO, Type.TPPI, Type.NTPPI}, {Type.PO, Type.TPPI, Type.TPP, Type.NTPP, Type.NTPPI, Type.EQ}, {Type.NTPPI}, {Type.NTPPI}, {Type.NTPPI} }, { {Type.DC}, {Type.EC}, {Type.PO}, {Type.TPP}, {Type.NTPP}, {Type.TPPI}, {Type.NTPPI}, {Type.EQ} }, };//3 by 3 composition Table public static Type getInverseRelation(Type t) { if (t.equals(Type.TPP)) return Type.TPPI; else if (t.equals(Type.NTPP)) return Type.NTPPI; else return t; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy