-
Notifications
You must be signed in to change notification settings - Fork 538
/
TrainSeparateNerExample.java
115 lines (103 loc) · 5.47 KB
/
TrainSeparateNerExample.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
import edu.mit.ll.mitie.*;
/**
* Created by wihoho on 26/12/15.
*/
public class TrainSeparateNerExample {
public static void main(String[] args) {
// train models using the separation API
StringVector stringVector = new StringVector();
stringVector.add("My");
stringVector.add("name");
stringVector.add("is");
stringVector.add("Davis");
stringVector.add("King");
stringVector.add("and");
stringVector.add("I");
stringVector.add("work");
stringVector.add("for");
stringVector.add("MIT");
stringVector.add(".");
// Now that we have the tokens stored, we add the entity annotations. The first
// annotation indicates that the token at index 3 and consisting of 2 tokens is a
// person. I.e. "Davis King" is a person name. Note that you can use any strings
// as the labels. Here we use "person" and "org" but you could use any labels you
// like.
NerTrainingInstance nerTrainingInstance = new NerTrainingInstance(stringVector);
nerTrainingInstance.addEntity(3, 2, "person");
nerTrainingInstance.addEntity(9, 1, "org");
StringVector stringVector12 = new StringVector();
stringVector12.add("The");
stringVector12.add("other");
stringVector12.add("day");
stringVector12.add("at");
stringVector12.add("work");
stringVector12.add("I");
stringVector12.add("saw");
stringVector12.add("Brian");
stringVector12.add("Smith");
stringVector12.add("from");
stringVector12.add("CMU");
stringVector12.add(".");
NerTrainingInstance nerTrainingInstance1 = new NerTrainingInstance(stringVector12);
nerTrainingInstance1.addEntity(7, 2, "person");
nerTrainingInstance1.addEntity(10, 1, "org");
// Now that we have some annotated example sentences we can create the object that does
// the actual training, the NerTrainer. The constructor for this object takes a string
// that should contain the file name for a saved mitie::total_word_feature_extractor C++ object.
// The total_word_feature_extractor is MITIE's primary method for analyzing words and
// is created by the tool in the MITIE/tools/wordrep folder. The wordrep tool analyzes
// a large document corpus, learns important word statistics, and then outputs a
// total_word_feature_extractor that is knowledgeable about a particular language (e.g.
// English). MITIE comes with a total_word_feature_extractor for English so that is
// what we use here. But if you need to make your own you do so using a command line
// statement like:
// wordrep -e a_folder_containing_only_text_files
// and wordrep will create a total_word_feature_extractor.dat based on the supplied
// text files. Note that wordrep can take a long time to run or require a lot of RAM
// if a large text dataset is given. So use a powerful machine and be patient.
NerTrainer nerTrainer = new NerTrainer("../../MITIE-models/english/total_word_feature_extractor.dat");
// Don't forget to add the training data. Here we have only two examples, but for real
// uses you need to have thousands.
nerTrainer.add(nerTrainingInstance);
nerTrainer.add(nerTrainingInstance1);
// The trainer can take advantage of a multi-core CPU. So set the number of threads
// equal to the number of processing cores for maximum training speed.
nerTrainer.setThreadNum(4);
// This function does the work of training. Note that it can take a long time to run
// when using larger training datasets. So be patient. When it finishes it will
// save the resulting pure model
nerTrainer.trainSeparateModels("pure_ner_model.dat");
// restore the model using the pure model and extractor
NamedEntityExtractor ner = new NamedEntityExtractor(
"pure_ner_model.dat",
"../../MITIE-models/english/total_word_feature_extractor.dat"
);
// Finally, lets test out our new model on an example sentence
StringVector testStringVector = new StringVector();
testStringVector.add("I");
testStringVector.add("met");
testStringVector.add("with");
testStringVector.add("John");
testStringVector.add("Becker");
testStringVector.add("at");
testStringVector.add("HBU");
testStringVector.add(".");
System.out.println("Tags output by this NER model are: ");
StringVector possibleTags = ner.getPossibleNerTags();
for (int i = 0; i < possibleTags.size(); ++i)
System.out.println(possibleTags.get(i));
// Now ask MITIE to find all the named entities in the file we just loaded.
EntityMentionVector entities = ner.extractEntities(testStringVector);
System.out.println("Number of entities found: " + entities.size());
// Now print out all the named entities and their tags
for (int i = 0; i < entities.size(); ++i)
{
EntityMention entity = entities.get(i);
String tag = possibleTags.get(entity.getTag());
Double score = entity.getScore();
String scoreStr = String.format("%1$,.3f",score);
System.out.print(" Score: " + scoreStr + ": " + tag + ":");
NerExample.printEntity(testStringVector, entity);
}
}
}