annotate src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/traverser/InterfaceTraverser.java @ 170:383b08d1711c

change Index form TreeMap<String TreeMap<String , List<TreeNode>>> → TreeMap<String TreeMap<String , TreeMap<TreeNode,TreeNode>>>
author one
date Fri, 26 Dec 2014 03:58:47 +0900
parents 3cd075a445bf
children 809f813d1083
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
97
a1e20a440ddd add BruteForceTraverser
one
parents:
diff changeset
1 package jp.ac.u_ryukyu.ie.cr.shoshi.jungle.traverser;
a1e20a440ddd add BruteForceTraverser
one
parents:
diff changeset
2
169
3cd075a445bf create parent index order o(n^2) → log(n)
one
parents: 166
diff changeset
3 import java.io.BufferedWriter;
3cd075a445bf create parent index order o(n^2) → log(n)
one
parents: 166
diff changeset
4 import java.io.File;
3cd075a445bf create parent index order o(n^2) → log(n)
one
parents: 166
diff changeset
5 import java.io.FileWriter;
3cd075a445bf create parent index order o(n^2) → log(n)
one
parents: 166
diff changeset
6 import java.io.IOException;
3cd075a445bf create parent index order o(n^2) → log(n)
one
parents: 166
diff changeset
7 import java.io.PrintWriter;
98
95000ff9064d Create Query
one
parents: 97
diff changeset
8 import java.util.Iterator;
95000ff9064d Create Query
one
parents: 97
diff changeset
9
104
f9a0e7069811 delete worning halfway
one
parents: 103
diff changeset
10 import fj.data.List;
97
a1e20a440ddd add BruteForceTraverser
one
parents:
diff changeset
11 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.impl.TreeNode;
99
92d0c6e4655c refactoring to IteratorPathNode
one
parents: 98
diff changeset
12 import jp.ac.u_ryukyu.ie.cr.tatsuki.jungle.query.PathNodeIterator;
110
cf17350a2415 traverse find args change Query
one
parents: 107
diff changeset
13 import jp.ac.u_ryukyu.ie.cr.tatsuki.jungle.query.Query;
151
d9fbddf77bf6 add class Index
one
parents: 146
diff changeset
14 import jp.ac.u_ryukyu.ie.cr.tatsuki.jungle.store.index.Index;
169
3cd075a445bf create parent index order o(n^2) → log(n)
one
parents: 166
diff changeset
15 import jp.ac.u_ryukyu.ie.cr.tatsuki.jungle.store.index.IndexCreater;
134
f46a6e0e4594 add deleteIndexEditor
one
parents: 132
diff changeset
16 import jp.ac.u_ryukyu.ie.cr.tatsuki.jungle.store.index.IndexManager;
153
20af7f25ef32 miner change
one
parents: 152
diff changeset
17 import jp.ac.u_ryukyu.ie.cr.tatsuki.jungle.store.index.ParentIndex;
97
a1e20a440ddd add BruteForceTraverser
one
parents:
diff changeset
18
100
9a7b7af838e0 add index TreeNodeEditor
one
parents: 99
diff changeset
19 public class InterfaceTraverser {
124
75ba2f2d6ea3 searchQueryTest add index
one
parents: 122
diff changeset
20
139
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
21 TreeNode node;
151
d9fbddf77bf6 add class Index
one
parents: 146
diff changeset
22 Index index;
153
20af7f25ef32 miner change
one
parents: 152
diff changeset
23 ParentIndex parentIndex;
20af7f25ef32 miner change
one
parents: 152
diff changeset
24 boolean parentUpdateFlag;
139
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
25 IndexManager indexManager;
154
b8cef4b640a3 update index for commit
one
parents: 153
diff changeset
26 boolean useIndex;
139
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
27
154
b8cef4b640a3 update index for commit
one
parents: 153
diff changeset
28 public InterfaceTraverser(TreeNode root, IndexManager indexManager, boolean indexFlag) {
b8cef4b640a3 update index for commit
one
parents: 153
diff changeset
29 this(root, new Index(), new ParentIndex(), indexManager, indexFlag);
b8cef4b640a3 update index for commit
one
parents: 153
diff changeset
30 }
b8cef4b640a3 update index for commit
one
parents: 153
diff changeset
31
b8cef4b640a3 update index for commit
one
parents: 153
diff changeset
32 public InterfaceTraverser(TreeNode root, Index index, ParentIndex parentIndex, IndexManager indexManager,
b8cef4b640a3 update index for commit
one
parents: 153
diff changeset
33 boolean useIndex) {
b8cef4b640a3 update index for commit
one
parents: 153
diff changeset
34 this.node = root;
139
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
35 this.index = index;
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
36 this.indexManager = indexManager;
153
20af7f25ef32 miner change
one
parents: 152
diff changeset
37 this.parentIndex = parentIndex;
20af7f25ef32 miner change
one
parents: 152
diff changeset
38 if (parentIndex.isEmpty())
20af7f25ef32 miner change
one
parents: 152
diff changeset
39 parentUpdateFlag = true;
20af7f25ef32 miner change
one
parents: 152
diff changeset
40 else
20af7f25ef32 miner change
one
parents: 152
diff changeset
41 parentUpdateFlag = false;
154
b8cef4b640a3 update index for commit
one
parents: 153
diff changeset
42 this.useIndex = useIndex;
139
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
43 }
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
44
151
d9fbddf77bf6 add class Index
one
parents: 146
diff changeset
45 public Index getIndex() {
139
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
46 return index;
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
47 }
127
b2c1fd513feb push index thread add read log
one
parents: 126
diff changeset
48
153
20af7f25ef32 miner change
one
parents: 152
diff changeset
49 public void commit() {
20af7f25ef32 miner change
one
parents: 152
diff changeset
50 parentUpdateFlag = false;
20af7f25ef32 miner change
one
parents: 152
diff changeset
51 indexManager.commit(index, parentIndex);
20af7f25ef32 miner change
one
parents: 152
diff changeset
52 }
20af7f25ef32 miner change
one
parents: 152
diff changeset
53
20af7f25ef32 miner change
one
parents: 152
diff changeset
54 public ParentIndex getParentIndex() {
20af7f25ef32 miner change
one
parents: 152
diff changeset
55 return parentIndex;
20af7f25ef32 miner change
one
parents: 152
diff changeset
56 }
20af7f25ef32 miner change
one
parents: 152
diff changeset
57
151
d9fbddf77bf6 add class Index
one
parents: 146
diff changeset
58 public void setIndex(Index index) {
139
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
59 this.index = index;
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
60 }
127
b2c1fd513feb push index thread add read log
one
parents: 126
diff changeset
61
154
b8cef4b640a3 update index for commit
one
parents: 153
diff changeset
62 public void createIndex() {
153
20af7f25ef32 miner change
one
parents: 152
diff changeset
63
169
3cd075a445bf create parent index order o(n^2) → log(n)
one
parents: 166
diff changeset
64 long t1 = System.currentTimeMillis();
3cd075a445bf create parent index order o(n^2) → log(n)
one
parents: 166
diff changeset
65 IndexCreater creater = new IndexCreater(node);
3cd075a445bf create parent index order o(n^2) → log(n)
one
parents: 166
diff changeset
66 long t2 = System.currentTimeMillis();
3cd075a445bf create parent index order o(n^2) → log(n)
one
parents: 166
diff changeset
67 System.out.println("createIndex time = " + (t2 - t1));
170
383b08d1711c change Index form TreeMap<String TreeMap<String , List<TreeNode>>> → TreeMap<String TreeMap<String , TreeMap<TreeNode,TreeNode>>>
one
parents: 169
diff changeset
68 // File file = new File("./time/createParentIndex");
383b08d1711c change Index form TreeMap<String TreeMap<String , List<TreeNode>>> → TreeMap<String TreeMap<String , TreeMap<TreeNode,TreeNode>>>
one
parents: 169
diff changeset
69 // try {
383b08d1711c change Index form TreeMap<String TreeMap<String , List<TreeNode>>> → TreeMap<String TreeMap<String , TreeMap<TreeNode,TreeNode>>>
one
parents: 169
diff changeset
70 // PrintWriter pw = new PrintWriter(new BufferedWriter(new FileWriter(file,true)));
383b08d1711c change Index form TreeMap<String TreeMap<String , List<TreeNode>>> → TreeMap<String TreeMap<String , TreeMap<TreeNode,TreeNode>>>
one
parents: 169
diff changeset
71 // pw.println((t2 - t1));
383b08d1711c change Index form TreeMap<String TreeMap<String , List<TreeNode>>> → TreeMap<String TreeMap<String , TreeMap<TreeNode,TreeNode>>>
one
parents: 169
diff changeset
72 // pw.close();
383b08d1711c change Index form TreeMap<String TreeMap<String , List<TreeNode>>> → TreeMap<String TreeMap<String , TreeMap<TreeNode,TreeNode>>>
one
parents: 169
diff changeset
73 // } catch (IOException e) {
383b08d1711c change Index form TreeMap<String TreeMap<String , List<TreeNode>>> → TreeMap<String TreeMap<String , TreeMap<TreeNode,TreeNode>>>
one
parents: 169
diff changeset
74 // // TODO Auto-generated catch block
383b08d1711c change Index form TreeMap<String TreeMap<String , List<TreeNode>>> → TreeMap<String TreeMap<String , TreeMap<TreeNode,TreeNode>>>
one
parents: 169
diff changeset
75 // e.printStackTrace();
383b08d1711c change Index form TreeMap<String TreeMap<String , List<TreeNode>>> → TreeMap<String TreeMap<String , TreeMap<TreeNode,TreeNode>>>
one
parents: 169
diff changeset
76 // }
169
3cd075a445bf create parent index order o(n^2) → log(n)
one
parents: 166
diff changeset
77 index = creater.getIndex();
3cd075a445bf create parent index order o(n^2) → log(n)
one
parents: 166
diff changeset
78 parentIndex = creater.getParentIndex();
153
20af7f25ef32 miner change
one
parents: 152
diff changeset
79 }
20af7f25ef32 miner change
one
parents: 152
diff changeset
80
139
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
81 /**
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
82 * subTree以下のNodeに対してKey,Valueのペアでindexを使って探索を行う
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
83 *
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
84 * @param query
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
85 * @param subTree
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
86 * @param key
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
87 * @param searchValue
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
88 * @return
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
89 */
160
6b4aab79910d fix bag
one
parents: 154
diff changeset
90 public Iterator<TreeNode> findInSubTree(final Query query, TreeNode subTree, String key, String searchValue) {
139
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
91 /*
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
92 * indexを使って取ってきたNodeのPathと、subTreeのPathを先頭から1つずつ比較し、
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
93 * indexから取ってきたNodeのPathが一致した場合、そのNodeを返す
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
94 */
170
383b08d1711c change Index form TreeMap<String TreeMap<String , List<TreeNode>>> → TreeMap<String TreeMap<String , TreeMap<TreeNode,TreeNode>>>
one
parents: 169
diff changeset
95 Iterator<TreeNode> nodeIterator = index.get(key, searchValue);
383b08d1711c change Index form TreeMap<String TreeMap<String , List<TreeNode>>> → TreeMap<String TreeMap<String , TreeMap<TreeNode,TreeNode>>>
one
parents: 169
diff changeset
96 if (nodeIterator.hasNext() && useIndex) {
137
7334f78a92c3 name changed find to findInSubTree
one
parents: 136
diff changeset
97
153
20af7f25ef32 miner change
one
parents: 152
diff changeset
98 // ここでNode以下にあるか調べる
20af7f25ef32 miner change
one
parents: 152
diff changeset
99 List<TreeNode> filteredList = List.nil();
139
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
100
170
383b08d1711c change Index form TreeMap<String TreeMap<String , List<TreeNode>>> → TreeMap<String TreeMap<String , TreeMap<TreeNode,TreeNode>>>
one
parents: 169
diff changeset
101 for (;nodeIterator.hasNext();) {
383b08d1711c change Index form TreeMap<String TreeMap<String , List<TreeNode>>> → TreeMap<String TreeMap<String , TreeMap<TreeNode,TreeNode>>>
one
parents: 169
diff changeset
102 TreeNode targetNode = nodeIterator.next();
153
20af7f25ef32 miner change
one
parents: 152
diff changeset
103 TreeNode parent = targetNode;
20af7f25ef32 miner change
one
parents: 152
diff changeset
104 while (parent != null) {
20af7f25ef32 miner change
one
parents: 152
diff changeset
105 parent = parentIndex.get(parent);
20af7f25ef32 miner change
one
parents: 152
diff changeset
106 if (parent.equals(subTree))
20af7f25ef32 miner change
one
parents: 152
diff changeset
107 filteredList = filteredList.cons(targetNode);
20af7f25ef32 miner change
one
parents: 152
diff changeset
108 }
141
3071b1a471fd add getKeys
one
parents: 140
diff changeset
109 }
3071b1a471fd add getKeys
one
parents: 140
diff changeset
110
3071b1a471fd add getKeys
one
parents: 140
diff changeset
111 return filteredList.iterator();
139
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
112
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
113 } else {
141
3071b1a471fd add getKeys
one
parents: 140
diff changeset
114 final PathNodeIterator itNode = new PathNodeIterator(subTree);
153
20af7f25ef32 miner change
one
parents: 152
diff changeset
115 return new Iterator<TreeNode>() {
139
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
116
153
20af7f25ef32 miner change
one
parents: 152
diff changeset
117 private TreeNode matchNode = nextmatch(itNode);
139
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
118
153
20af7f25ef32 miner change
one
parents: 152
diff changeset
119 private TreeNode nextmatch(PathNodeIterator itNode) {
127
b2c1fd513feb push index thread add read log
one
parents: 126
diff changeset
120
139
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
121 for (; itNode.hasNext();) {
153
20af7f25ef32 miner change
one
parents: 152
diff changeset
122 TreeNode targetNode = itNode.next();
20af7f25ef32 miner change
one
parents: 152
diff changeset
123 if (query.condition(targetNode))
20af7f25ef32 miner change
one
parents: 152
diff changeset
124 return targetNode;
139
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
125 }
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
126 return null;
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
127 }
125
a0c4a4b8ad10 index test
one
parents: 124
diff changeset
128
139
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
129 @Override
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
130 public boolean hasNext() {
153
20af7f25ef32 miner change
one
parents: 152
diff changeset
131 if (matchNode == null) {
139
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
132 return false;
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
133 }
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
134 return true;
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
135 }
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
136
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
137 @Override
153
20af7f25ef32 miner change
one
parents: 152
diff changeset
138 public TreeNode next() {
20af7f25ef32 miner change
one
parents: 152
diff changeset
139 TreeNode currentNode = matchNode;
20af7f25ef32 miner change
one
parents: 152
diff changeset
140 matchNode = nextmatch(itNode);
20af7f25ef32 miner change
one
parents: 152
diff changeset
141 return currentNode;
139
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
142 }
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
143
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
144 @Override
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
145 public void remove() {
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
146 }
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
147
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
148 };
137
7334f78a92c3 name changed find to findInSubTree
one
parents: 136
diff changeset
149 }
139
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
150 }
137
7334f78a92c3 name changed find to findInSubTree
one
parents: 136
diff changeset
151
139
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
152 /**
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
153 * subTree以下のNodeに対してKeyに対応する値をindexを使って探索する
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
154 *
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
155 * @param query
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
156 * @param subTree
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
157 * @param key
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
158 * @param searchValue
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
159 * @return
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
160 */
160
6b4aab79910d fix bag
one
parents: 154
diff changeset
161 public Iterator<TreeNode> findInSubTreeAllValue(final Query query, TreeNode subTree, String key) {
139
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
162 /*
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
163 * indexからinnerIndexを取得 取得したinnerIndexが保有するKeyを取得
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
164 * そのKeyを保有するNodeとNodeのPathを取得する
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
165 * indexを使って取ってきたNodeのPathと、subTreeのPathを先頭から1つずつ比較し、
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
166 * indexから取ってきたNodeのPathが一致した場合、そのNodeを返す
137
7334f78a92c3 name changed find to findInSubTree
one
parents: 136
diff changeset
167 */
153
20af7f25ef32 miner change
one
parents: 152
diff changeset
168 Iterator<TreeNode> NodeIterator = index.getAll(key);
154
b8cef4b640a3 update index for commit
one
parents: 153
diff changeset
169 if (NodeIterator != null && useIndex) {
153
20af7f25ef32 miner change
one
parents: 152
diff changeset
170 List<TreeNode> filteredList = List.nil();
20af7f25ef32 miner change
one
parents: 152
diff changeset
171 for (; NodeIterator.hasNext();) {
20af7f25ef32 miner change
one
parents: 152
diff changeset
172 TreeNode targetNode = NodeIterator.next();
20af7f25ef32 miner change
one
parents: 152
diff changeset
173 TreeNode parent = targetNode;
20af7f25ef32 miner change
one
parents: 152
diff changeset
174 while (parent != null) {
20af7f25ef32 miner change
one
parents: 152
diff changeset
175 parent = parentIndex.get(parent);
20af7f25ef32 miner change
one
parents: 152
diff changeset
176 if (parent.equals(subTree))
20af7f25ef32 miner change
one
parents: 152
diff changeset
177 filteredList = filteredList.cons(targetNode);
143
afbe19c98f53 change Index form TreeMap<String,TreeMap<String<List<Pair<TreeNode,NodePath>>>> → TreeMap<String,TreeMap<String<List<NodePath>>>
one
parents: 141
diff changeset
178 }
139
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
179 }
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
180 return filteredList.iterator();
137
7334f78a92c3 name changed find to findInSubTree
one
parents: 136
diff changeset
181
139
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
182 } else {
153
20af7f25ef32 miner change
one
parents: 152
diff changeset
183
141
3071b1a471fd add getKeys
one
parents: 140
diff changeset
184 final PathNodeIterator itNode = new PathNodeIterator(subTree);
153
20af7f25ef32 miner change
one
parents: 152
diff changeset
185 return new Iterator<TreeNode>() {
139
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
186
153
20af7f25ef32 miner change
one
parents: 152
diff changeset
187 private TreeNode matchPair = nextmatch(itNode);
139
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
188
153
20af7f25ef32 miner change
one
parents: 152
diff changeset
189 private TreeNode nextmatch(PathNodeIterator itNode) {
137
7334f78a92c3 name changed find to findInSubTree
one
parents: 136
diff changeset
190
139
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
191 for (; itNode.hasNext();) {
153
20af7f25ef32 miner change
one
parents: 152
diff changeset
192 TreeNode targetNode = itNode.next();
20af7f25ef32 miner change
one
parents: 152
diff changeset
193 if (query.condition(targetNode))
20af7f25ef32 miner change
one
parents: 152
diff changeset
194 return targetNode;
139
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
195 }
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
196 return null;
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
197 }
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
198
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
199 @Override
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
200 public boolean hasNext() {
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
201 if (matchPair == null) {
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
202 return false;
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
203 }
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
204 return true;
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
205 }
124
75ba2f2d6ea3 searchQueryTest add index
one
parents: 122
diff changeset
206
139
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
207 @Override
153
20af7f25ef32 miner change
one
parents: 152
diff changeset
208 public TreeNode next() {
20af7f25ef32 miner change
one
parents: 152
diff changeset
209 TreeNode currentNode = matchPair;
139
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
210 matchPair = nextmatch(itNode);
153
20af7f25ef32 miner change
one
parents: 152
diff changeset
211 return currentNode;
20af7f25ef32 miner change
one
parents: 152
diff changeset
212 }
20af7f25ef32 miner change
one
parents: 152
diff changeset
213
20af7f25ef32 miner change
one
parents: 152
diff changeset
214 @Override
20af7f25ef32 miner change
one
parents: 152
diff changeset
215 public void remove() {
20af7f25ef32 miner change
one
parents: 152
diff changeset
216 }
20af7f25ef32 miner change
one
parents: 152
diff changeset
217
20af7f25ef32 miner change
one
parents: 152
diff changeset
218 };
20af7f25ef32 miner change
one
parents: 152
diff changeset
219 }
20af7f25ef32 miner change
one
parents: 152
diff changeset
220 }
20af7f25ef32 miner change
one
parents: 152
diff changeset
221
160
6b4aab79910d fix bag
one
parents: 154
diff changeset
222 public Iterator<TreeNode> find(final Query query, final String key, String searchValue) {
153
20af7f25ef32 miner change
one
parents: 152
diff changeset
223
170
383b08d1711c change Index form TreeMap<String TreeMap<String , List<TreeNode>>> → TreeMap<String TreeMap<String , TreeMap<TreeNode,TreeNode>>>
one
parents: 169
diff changeset
224 Iterator<TreeNode> nodeIterator = index.get(key, searchValue);
383b08d1711c change Index form TreeMap<String TreeMap<String , List<TreeNode>>> → TreeMap<String TreeMap<String , TreeMap<TreeNode,TreeNode>>>
one
parents: 169
diff changeset
225 if (nodeIterator.hasNext() && useIndex) {
383b08d1711c change Index form TreeMap<String TreeMap<String , List<TreeNode>>> → TreeMap<String TreeMap<String , TreeMap<TreeNode,TreeNode>>>
one
parents: 169
diff changeset
226 return nodeIterator;
153
20af7f25ef32 miner change
one
parents: 152
diff changeset
227 } else {
20af7f25ef32 miner change
one
parents: 152
diff changeset
228
20af7f25ef32 miner change
one
parents: 152
diff changeset
229 final PathNodeIterator itNode = new PathNodeIterator(node);
20af7f25ef32 miner change
one
parents: 152
diff changeset
230 return new Iterator<TreeNode>() {
20af7f25ef32 miner change
one
parents: 152
diff changeset
231
20af7f25ef32 miner change
one
parents: 152
diff changeset
232 private TreeNode matchNode = nextmatch(itNode);
20af7f25ef32 miner change
one
parents: 152
diff changeset
233
20af7f25ef32 miner change
one
parents: 152
diff changeset
234 private TreeNode nextmatch(PathNodeIterator itNode) {
20af7f25ef32 miner change
one
parents: 152
diff changeset
235
20af7f25ef32 miner change
one
parents: 152
diff changeset
236 for (; itNode.hasNext();) {
20af7f25ef32 miner change
one
parents: 152
diff changeset
237 TreeNode targetNode = itNode.next();
20af7f25ef32 miner change
one
parents: 152
diff changeset
238 String value = targetNode.getAttributes().getString(key);
154
b8cef4b640a3 update index for commit
one
parents: 153
diff changeset
239 if (useIndex) {
153
20af7f25ef32 miner change
one
parents: 152
diff changeset
240 if (value != null)
20af7f25ef32 miner change
one
parents: 152
diff changeset
241 index = index.set(key, value, targetNode);
20af7f25ef32 miner change
one
parents: 152
diff changeset
242 }
170
383b08d1711c change Index form TreeMap<String TreeMap<String , List<TreeNode>>> → TreeMap<String TreeMap<String , TreeMap<TreeNode,TreeNode>>>
one
parents: 169
diff changeset
243 if (parentUpdateFlag);
169
3cd075a445bf create parent index order o(n^2) → log(n)
one
parents: 166
diff changeset
244 // parentIndex = parentIndex.set(targetNode);
153
20af7f25ef32 miner change
one
parents: 152
diff changeset
245 if (query.condition(targetNode))
20af7f25ef32 miner change
one
parents: 152
diff changeset
246 return targetNode;
20af7f25ef32 miner change
one
parents: 152
diff changeset
247 }
154
b8cef4b640a3 update index for commit
one
parents: 153
diff changeset
248 if (useIndex || parentUpdateFlag)
b8cef4b640a3 update index for commit
one
parents: 153
diff changeset
249 commit();
153
20af7f25ef32 miner change
one
parents: 152
diff changeset
250 return null;
20af7f25ef32 miner change
one
parents: 152
diff changeset
251 }
20af7f25ef32 miner change
one
parents: 152
diff changeset
252
20af7f25ef32 miner change
one
parents: 152
diff changeset
253 @Override
20af7f25ef32 miner change
one
parents: 152
diff changeset
254 public boolean hasNext() {
20af7f25ef32 miner change
one
parents: 152
diff changeset
255 if (matchNode == null) {
20af7f25ef32 miner change
one
parents: 152
diff changeset
256 return false;
20af7f25ef32 miner change
one
parents: 152
diff changeset
257 }
20af7f25ef32 miner change
one
parents: 152
diff changeset
258 return true;
20af7f25ef32 miner change
one
parents: 152
diff changeset
259 }
20af7f25ef32 miner change
one
parents: 152
diff changeset
260
20af7f25ef32 miner change
one
parents: 152
diff changeset
261 @Override
20af7f25ef32 miner change
one
parents: 152
diff changeset
262 public TreeNode next() {
20af7f25ef32 miner change
one
parents: 152
diff changeset
263 TreeNode currentPair = matchNode;
20af7f25ef32 miner change
one
parents: 152
diff changeset
264 matchNode = nextmatch(itNode);
139
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
265 return currentPair;
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
266 }
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
267
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
268 @Override
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
269 public void remove() {
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
270 }
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
271
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
272 };
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
273 }
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
274 }
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
275
160
6b4aab79910d fix bag
one
parents: 154
diff changeset
276 public Iterator<TreeNode> findAll(final Query query, final String key) {
139
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
277
153
20af7f25ef32 miner change
one
parents: 152
diff changeset
278 Iterator<TreeNode> nodeList = index.getAll(key);
154
b8cef4b640a3 update index for commit
one
parents: 153
diff changeset
279 if (nodeList != null && useIndex) {
139
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
280
153
20af7f25ef32 miner change
one
parents: 152
diff changeset
281 return nodeList;
139
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
282
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
283 } else {
153
20af7f25ef32 miner change
one
parents: 152
diff changeset
284
20af7f25ef32 miner change
one
parents: 152
diff changeset
285 final PathNodeIterator itNode = new PathNodeIterator(node);
20af7f25ef32 miner change
one
parents: 152
diff changeset
286 return new Iterator<TreeNode>() {
137
7334f78a92c3 name changed find to findInSubTree
one
parents: 136
diff changeset
287
153
20af7f25ef32 miner change
one
parents: 152
diff changeset
288 private TreeNode matchNode = nextmatch(itNode);
139
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
289
153
20af7f25ef32 miner change
one
parents: 152
diff changeset
290 private TreeNode nextmatch(PathNodeIterator itNode) {
139
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
291
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
292 for (; itNode.hasNext();) {
153
20af7f25ef32 miner change
one
parents: 152
diff changeset
293 TreeNode targetNode = itNode.next();
20af7f25ef32 miner change
one
parents: 152
diff changeset
294 String value = targetNode.getAttributes().getString(key);
154
b8cef4b640a3 update index for commit
one
parents: 153
diff changeset
295 if (useIndex) {
153
20af7f25ef32 miner change
one
parents: 152
diff changeset
296 if (value != null)
20af7f25ef32 miner change
one
parents: 152
diff changeset
297 index = index.set(key, value, targetNode);
137
7334f78a92c3 name changed find to findInSubTree
one
parents: 136
diff changeset
298 }
170
383b08d1711c change Index form TreeMap<String TreeMap<String , List<TreeNode>>> → TreeMap<String TreeMap<String , TreeMap<TreeNode,TreeNode>>>
one
parents: 169
diff changeset
299 if (parentUpdateFlag);
169
3cd075a445bf create parent index order o(n^2) → log(n)
one
parents: 166
diff changeset
300 // parentIndex = parentIndex.set(targetNode);
153
20af7f25ef32 miner change
one
parents: 152
diff changeset
301 if (query.condition(targetNode))
20af7f25ef32 miner change
one
parents: 152
diff changeset
302 return targetNode;
139
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
303 }
154
b8cef4b640a3 update index for commit
one
parents: 153
diff changeset
304 if (useIndex || parentUpdateFlag)
b8cef4b640a3 update index for commit
one
parents: 153
diff changeset
305 commit();
139
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
306 return null;
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
307 }
136
0f68cd7b2838 add Node Search
one
parents: 134
diff changeset
308
139
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
309 @Override
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
310 public boolean hasNext() {
153
20af7f25ef32 miner change
one
parents: 152
diff changeset
311 if (matchNode == null) {
139
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
312 return false;
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
313 }
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
314 return true;
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
315 }
136
0f68cd7b2838 add Node Search
one
parents: 134
diff changeset
316
139
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
317 @Override
153
20af7f25ef32 miner change
one
parents: 152
diff changeset
318 public TreeNode next() {
20af7f25ef32 miner change
one
parents: 152
diff changeset
319 TreeNode currentPair = matchNode;
20af7f25ef32 miner change
one
parents: 152
diff changeset
320 matchNode = nextmatch(itNode);
139
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
321 return currentPair;
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
322 }
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
323
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
324 @Override
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
325 public void remove() {
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
326 }
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
327
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
328 };
137
7334f78a92c3 name changed find to findInSubTree
one
parents: 136
diff changeset
329 }
139
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 137
diff changeset
330 }
97
a1e20a440ddd add BruteForceTraverser
one
parents:
diff changeset
331 }