/////////////////////////////////////////////////////////////////////////////// // Copyright (C) 2001 Jason Baldridge and Gann Bierner // // This library is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 2.1 of the License, or (at your option) any later version. // // This library 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 Lesser General Public // License along with this program; if not, write to the Free Software // Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. ////////////////////////////////////////////////////////////////////////////// package opennlp.maxent; /** * A maxent predicate representation which we can use to sort based on the * outcomes. This allows us to make the mapping of features to their parameters * much more compact. * * @author Jason Baldridge * @version $Revision: 1.1.1.1 $, $Date: 2001/10/23 14:06:53 $ */ public class ComparablePredicate implements Comparable { public String name; public int[] outcomes; public double[] params; public ComparablePredicate(String n, int[] ocs, double[] ps) { name = n; outcomes = ocs; params = ps; } public int compareTo(Object o) { ComparablePredicate cp = (ComparablePredicate)o; int smallerLength = (outcomes.length > cp.outcomes.length? cp.outcomes.length : outcomes.length); for (int i=0; i<smallerLength; i++) { if (outcomes[i] < cp.outcomes[i]) return -1; else if (outcomes[i] > cp.outcomes[i]) return 1; } if (outcomes.length < cp.outcomes.length) return -1; else if (outcomes.length > cp.outcomes.length) return 1; return 0; } public String toString() { String s = ""; for (int i=0; i<outcomes.length; i++) s+= " "+outcomes[i]; return s; } }