if (params.getDetailedF()) {
detailedFListener = new TokenNameFinderDetailedFMeasureListener();
listeners.add(detailedFListener);
}
TokenNameFinderEvaluator evaluator = new TokenNameFinderEvaluator(
new NameFinderME(model),
listeners.toArray(new TokenNameFinderEvaluationMonitor[listeners.size()]));
final ObjectStream<NameSample> sampleStream = TokenNameFinderTrainerTool.openSampleData("Test",
testData, encoding);
final PerformanceMonitor monitor = new PerformanceMonitor("sent");
ObjectStream<NameSample> measuredSampleStream = new ObjectStream<NameSample>() {
public NameSample read() throws IOException {
monitor.incrementCounter();
return sampleStream.read();
}
public void reset() throws IOException {
sampleStream.reset();
}
public void close() throws IOException {
sampleStream.close();
}
};
monitor.startAndPrintThroughput();
try {
evaluator.evaluate(measuredSampleStream);
} catch (IOException e) {
System.err.println("failed");
System.err.println("Reading test data error " + e.getMessage());
throw new TerminateToolException(-1);
} finally {
try {
measuredSampleStream.close();
} catch (IOException e) {
// sorry that this can fail
}
}
monitor.stopAndPrintFinalResult();
System.out.println();
if(detailedFListener == null) {
System.out.println(evaluator.getFMeasure());
} else {
System.out.println(detailedFListener.toString());
}
}