/*********************************************************************** This file is part of KEEL-software, the Data Mining tool for regression, classification, clustering, pattern mining and so on. Copyright (C) 2004-2010 F. Herrera (herrera@decsai.ugr.es) L. S�nchez (luciano@uniovi.es) J. Alcal�-Fdez (jalcala@decsai.ugr.es) S. Garc�a (sglopez@ujaen.es) A. Fern�ndez (alberto.fernandez@ujaen.es) J. Luengo (julianlm@decsai.ugr.es) This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program. If not, see http://www.gnu.org/licenses/ **********************************************************************/ package keel.Algorithms.Fuzzy_Rule_Learning.Shared.Fuzzy; /** * <p> * Represents a right-angled triangular fuzzy number with the right-angle in right side. * Each support member upper than center has the membership value of 1.0 and right represent the extreme of the triangular fuzzy number. * </p> * * <p> * @author Written by Luciano S�nchez (University of Oviedo) 20/01/2004 * @author Modified by Enrique A. de la Cal (University of Oviedo) 13/12/2008 * @version 1.0 * @since JDK1.4 * </p> */ class FuzzyNumberTRRIGHT extends Fuzzy { //the center and the extreme of the triangular fuzzy number double left, center; /** * <p> * A constructor for a right right-angled triangle fuzzy number, given the extremes. * * </p> * @param l the lower extreme of the triangular fuzzy number. * @param c the center element of the triangular fuzzy number. * */ public FuzzyNumberTRRIGHT(double l, double c) { left=l; center=c; } /** * <p> * A copy constructor for a right right-angled triangle fuzzy number, given other right right-angled triangle fuzzy number. * * </p> * @param b to be copied. */ public FuzzyNumberTRRIGHT(FuzzyNumberTRRIGHT b) { left=b.left; center=b.center; } /** * <p> * Copies the FuzzyNumberTRRIGHT parameter over the present instance. * * </p> * @param pa a FuzzyNumberTRRIGHT object to be copied */ public void asigna(FuzzyNumberTRRIGHT b) { left=b.left; center=b.center; } /** * <p> * Indicates whether some other object is "equal to" this one. * * </p> * @param B the reference object with which to compare. * @return true if this object is the same as the B argument; false otherwise. */ public boolean equals(Fuzzy b) { if (!(b instanceof FuzzyNumberTRRIGHT)) return false; FuzzyNumberTRRIGHT bt=(FuzzyNumberTRRIGHT) b; if (left!=bt.left) return false; if (center!=bt.center) return false; return true; } /** * <p> * Creates and returns a copy of this object. * * </p> * @return a clone of this instance. */ public Fuzzy clone() { return new FuzzyNumberTRRIGHT(this); } /** * <p> * Returns the membership level for the individual x. * * * </p> * @param x the individual which membership is to be calculated. * @return the membership level for individual x. */ public double evaluateMembership(double x) { if (x<left) return 0; if (x<center) return 1-(center-x)/(center-left); return 1; } /** * <p> * Returns the centroid of the present fuzzy number. * * </p> * @return the centroid of the present fuzzy number. */ public double massCentre() { return center; } /** * <p> * Creates and returns a FuzzyInterval with the extremes of the support set. * * </p> * @return an interval with the extremes of the support set. */ public FuzzyInterval support() { return new FuzzyInterval(left,POSITIVEINF); } /** * <p> * Returns a printable version of the instance. * * </p> * @return a String with a printable version of the right right-angled triangular fuzzy number. */ public String aString() { return "TRAPRI("+left+","+center+")"; } };