farthestsinglelink.java

来自「mallet是自然语言处理、机器学习领域的一个开源项目。」· Java 代码 · 共 62 行

JAVA
62
字号
/* Copyright (C) 2002 Univ. of Massachusetts Amherst, Computer Science Dept.   This file is part of "MALLET" (MAchine Learning for LanguagE Toolkit).   http://www.cs.umass.edu/~mccallum/mallet   This software is provided under the terms of the Common Public License,   version 1.0, as published by http://www.opensource.org.  For further   information, see the file `LICENSE' included with this distribution. */package edu.umass.cs.mallet.projects.seg_plus_coref.condclust.pipe;import edu.umass.cs.mallet.projects.seg_plus_coref.condclust.types.*;import edu.umass.cs.mallet.projects.seg_plus_coref.coreference.*;import edu.umass.cs.mallet.base.types.*;import edu.umass.cs.mallet.base.classify.*;import edu.umass.cs.mallet.base.pipe.*;import java.util.*;/** Feature is similarity between node and farthest node in cluster, as * determined by the classifier*/public class FarthestSingleLink extends Pipe{	Classifier classifier;		public FarthestSingleLink (Classifier _classifier)		{		this.classifier = _classifier;	}	public Instance pipe (Instance carrier) {		NodeClusterPair pair = (NodeClusterPair)carrier.getData();		Citation node = (Citation)pair.getNode();		Collection cluster = (Collection)pair.getCluster();		Iterator iter = cluster.iterator ();		double minVal = 99999999.9;		while (iter.hasNext()) {			Citation c = (Citation) iter.next();			NodePair np = new NodePair (c, node);			Instance inst = new Instance (np, "unknown", null, np, classifier.getInstancePipe());			Classification classification = classifier.classify (inst);			Labeling labeling = classification.getLabeling();			double val = 0.0;			if (labeling.labelAtLocation(0).toString().equals("no")) 				val =  labeling.valueAtLocation(1)-labeling.valueAtLocation(0);			else 				val =  labeling.valueAtLocation(0)-labeling.valueAtLocation(1);			if (val < minVal) {				minVal = val;			}		}		if (minVal > 0.9)			pair.setFeatureValue ("FarthestNodeSimilarityHigh", 1.0);		else if (minVal > 0.75)			pair.setFeatureValue ("FarthestNodeSimilarityMed", 1.0);		else if (minVal > 0.5)			pair.setFeatureValue ("FarthestNodeSimilarityWeak", 1.0);		else if (minVal > 0.3)			pair.setFeatureValue ("FarthestNodeSimilarityMin", 1.0);		else			pair.setFeatureValue ("FarthestNodeSimilarityNone", 1.0); 		return carrier;	}}

⌨️ 快捷键说明

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