comparablepredicate.java

来自「垃圾邮件过滤器源代码」· Java 代码 · 共 64 行

JAVA
64
字号
///////////////////////////////////////////////////////////////////////////////// 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;    }}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?