blob: b45a82610ee624ecaa34e4530c8357698e69a865 (
plain)
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
|
#include "grammar.h"
#include <iomanip>
#include "rule.h"
using namespace std;
namespace extractor {
Grammar::Grammar(const vector<Rule>& rules,
const vector<string>& feature_names) :
rules(rules), feature_names(feature_names) {}
vector<Rule> Grammar::GetRules() const {
return rules;
}
vector<string> Grammar::GetFeatureNames() const {
return feature_names;
}
ostream& operator<<(ostream& os, const Grammar& grammar) {
vector<Rule> rules = grammar.GetRules();
vector<string> feature_names = grammar.GetFeatureNames();
os << setprecision(12);
for (Rule rule: rules) {
os << "[X] ||| " << rule.source_phrase << " ||| "
<< rule.target_phrase << " |||";
for (size_t i = 0; i < rule.scores.size(); ++i) {
os << " " << feature_names[i] << "=" << rule.scores[i];
}
os << " |||";
for (auto link: rule.alignment) {
os << " " << link.first << "-" << link.second;
}
os << '\n';
}
return os;
}
} // namespace extractor
|