diff options
Diffstat (limited to 'lib/notion.cpp')
-rw-r--r-- | lib/notion.cpp | 94 |
1 files changed, 94 insertions, 0 deletions
diff --git a/lib/notion.cpp b/lib/notion.cpp new file mode 100644 index 0000000..16794d3 --- /dev/null +++ b/lib/notion.cpp | |||
@@ -0,0 +1,94 @@ | |||
1 | #include "notion.h" | ||
2 | #include <sqlite3.h> | ||
3 | #include <sstream> | ||
4 | |||
5 | namespace verbly { | ||
6 | |||
7 | const object notion::objectType = object::notion; | ||
8 | |||
9 | const std::list<std::string> notion::select = {"notion_id", "part_of_speech", "wnid", "images"}; | ||
10 | |||
11 | const field notion::id = field::integerField(object::notion, "notion_id"); | ||
12 | const field notion::partOfSpeech = field::integerField(object::notion, "part_of_speech"); | ||
13 | const field notion::wnid = field::integerField(object::notion, "wnid", true); | ||
14 | const field notion::numOfImages = field::integerField(object::notion, "images", true); | ||
15 | |||
16 | const field notion::word = field::joinField(object::notion, "word_id", object::word); | ||
17 | |||
18 | const field notion::hypernyms = field::selfJoin(object::notion, "notion_id", "hypernymy", "hyponym_id", "hypernym_id"); | ||
19 | const field notion::hyponyms = field::selfJoin(object::notion, "notion_id", "hypernymy", "hypernym_id", "hyponym_id"); | ||
20 | |||
21 | const field notion::fullHypernyms = field::hierarchalSelfJoin(object::notion, "notion_id", "hypernymy", "hyponym_id", "hypernym_id"); | ||
22 | const field notion::fullHyponyms = field::hierarchalSelfJoin(object::notion, "notion_id", "hypernymy", "hypernym_id", "hyponym_id"); | ||
23 | |||
24 | const field notion::instances = field::selfJoin(object::notion, "notion_id", "instantiation", "class_id", "instance_id"); | ||
25 | const field notion::classes = field::selfJoin(object::notion, "notion_id", "instantiation", "instance_id", "class_id"); | ||
26 | |||
27 | const field notion::memberMeronyms = field::selfJoin(object::notion, "notion_id", "member_meronymy", "holonym_id", "meronym_id"); | ||
28 | const field notion::memberHolonyms = field::selfJoin(object::notion, "notion_id", "member_meronymy", "meronym_id", "holonym_id"); | ||
29 | |||
30 | const field notion::fullMemberMeronyms = field::hierarchalSelfJoin(object::notion, "notion_id", "member_meronymy", "holonym_id", "meronym_id"); | ||
31 | const field notion::fullMemberHolonyms = field::hierarchalSelfJoin(object::notion, "notion_id", "member_meronymy", "meronym_id", "holonym_id"); | ||
32 | |||
33 | const field notion::partMeronyms = field::selfJoin(object::notion, "notion_id", "part_meronymy", "holonym_id", "meronym_id"); | ||
34 | const field notion::partHolonyms = field::selfJoin(object::notion, "notion_id", "part_meronymy", "meronym_id", "holonym_id"); | ||
35 | |||
36 | const field notion::fullPartMeronyms = field::hierarchalSelfJoin(object::notion, "notion_id", "part_meronymy", "holonym_id", "meronym_id"); | ||
37 | const field notion::fullPartHolonyms = field::hierarchalSelfJoin(object::notion, "notion_id", "part_meronymy", "meronym_id", "holonym_id"); | ||
38 | |||
39 | const field notion::substanceMeronyms = field::selfJoin(object::notion, "notion_id", "substance_meronymy", "holonym_id", "meronym_id"); | ||
40 | const field notion::substanceHolonyms = field::selfJoin(object::notion, "notion_id", "substance_meronymy", "meronym_id", "holonym_id"); | ||
41 | |||
42 | const field notion::fullSubstanceMeronyms = field::hierarchalSelfJoin(object::notion, "notion_id", "substance_meronymy", "holonym_id", "meronym_id"); | ||
43 | const field notion::fullSubstanceHolonyms = field::hierarchalSelfJoin(object::notion, "notion_id", "substance_meronymy", "meronym_id", "holonym_id"); | ||
44 | |||
45 | const field notion::variants = field::selfJoin(object::notion, "notion_id", "variation", "noun_id", "adjective_id"); | ||
46 | const field notion::attributes = field::selfJoin(object::notion, "notion_id", "variation", "adjective_id", "noun_id"); | ||
47 | |||
48 | const field notion::similarAdjectives = field::selfJoin(object::notion, "notion_id", "similarity", "adjective_2_id", "adjective_1_id"); | ||
49 | |||
50 | const field notion::entails = field::selfJoin(object::notion, "notion_id", "entailment", "given_id", "entailment_id"); | ||
51 | const field notion::entailedBy = field::selfJoin(object::notion, "notion_id", "entailment", "entailment_id", "given_id"); | ||
52 | |||
53 | const field notion::causes = field::selfJoin(object::notion, "notion_id", "causality", "effect_id", "cause_id"); | ||
54 | const field notion::effects = field::selfJoin(object::notion, "notion_id", "causality", "cause_id", "effect_id"); | ||
55 | |||
56 | const notion::preposition_group_field prepositionGroup = {}; | ||
57 | |||
58 | const field notion::preposition_group_field::isA = field::joinField(object::notion, "notion_id", "is_a"); | ||
59 | const field notion::preposition_group_field::groupNameField = field::stringField("is_a", "groupname"); | ||
60 | |||
61 | notion::notion(const database& db, sqlite3_stmt* row) : db_(&db), valid_(true) | ||
62 | { | ||
63 | id_ = sqlite3_column_int(row, 0); | ||
64 | partOfSpeech_ = static_cast<part_of_speech>(sqlite3_column_int(row, 1)); | ||
65 | |||
66 | if (sqlite3_column_type(row, 2) != SQLITE_NULL) | ||
67 | { | ||
68 | hasWnid_ = true; | ||
69 | wnid_ = sqlite3_column_int(row, 2); | ||
70 | } | ||
71 | |||
72 | if (sqlite3_column_type(row, 3) != SQLITE_NULL) | ||
73 | { | ||
74 | hasNumOfImages_ = true; | ||
75 | numOfImages_ = sqlite3_column_int(row, 3); | ||
76 | } | ||
77 | } | ||
78 | |||
79 | std::string notion::getImageNetUrl() const | ||
80 | { | ||
81 | std::stringstream url; | ||
82 | url << "http://www.image-net.org/api/text/imagenet.synset.geturls?wnid=n"; | ||
83 | url.width(8); | ||
84 | url.fill('0'); | ||
85 | url << (getWnid() % 100000000); | ||
86 | return url.str(); | ||
87 | } | ||
88 | |||
89 | filter notion::preposition_group_field::operator==(std::string groupName) const | ||
90 | { | ||
91 | return (isA %= (groupNameField == groupName)); | ||
92 | } | ||
93 | |||
94 | }; | ||