-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathnode_aggregates.go
More file actions
117 lines (101 loc) · 2.79 KB
/
node_aggregates.go
File metadata and controls
117 lines (101 loc) · 2.79 KB
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
116
117
package constdp
import (
"github.com/TopoSimplify/common"
"github.com/TopoSimplify/hdb"
"github.com/TopoSimplify/knn"
"github.com/TopoSimplify/merge"
"github.com/TopoSimplify/node"
"github.com/intdxdt/iter"
"sort"
)
//Merge segment fragments where possible
func (self *ConstDP) AggregateSimpleSegments(
id *iter.Igen, db *hdb.Hdb, constVertexSet []int,
validateMerge func(*node.Node, *hdb.Hdb) bool,
) {
var fragmentSize = 1
var neighbours []*node.Node
var cache = make(map[[CacheKeySize]int]bool)
var objects = db.All()
var hull *node.Node
sort.Sort(node.NodePtrs(objects))
var score = self.Score
var relation = self.ScoreRelation
if self.SquareScore != nil {
score = self.SquareScore
relation = self.SquareScoreRelation
}
for len(objects) != 0 {
hull = objects[0]
objects = objects[1:]
if hull.Range.Size() != fragmentSize {
continue
}
//make sure hull index is not part of vertex with degree > 2
if iter.SortedSearchInts(constVertexSet, hull.Range.I) &&
iter.SortedSearchInts(constVertexSet, hull.Range.J) {
continue
}
var withNext, withPrev = !iter.SortedSearchInts(constVertexSet, hull.Range.J),
!iter.SortedSearchInts(constVertexSet, hull.Range.I)
db.Remove(hull)
// find context neighbours
//neighbours = common.NodesFromObjects(knn.FindNodeNeighbours(db, hull, knn.EpsilonDist))
neighbours = knn.NodeNeighbours(db, hull, knn.EpsilonDist)
// find context neighbours
var prev, nxt = node.Neighbours(hull, neighbours)
// find mergeable neighbours contiguous
var key [CacheKeySize]int
var mergePrev, mergeNxt node.Node
var mergeprevBln, mergenxtBln bool
if withPrev && prev != nil {
key = CacheKey(prev, hull)
if !cache[key] {
cache[key] = true
mergeprevBln, mergePrev = merge.ContiguousFragmentsAtThreshold(
id, score, prev, hull, relation, common.Geometry,
)
}
}
if withNext && nxt != nil {
key = CacheKey(hull, nxt)
if !cache[key] {
cache[key] = true
mergenxtBln, mergeNxt = merge.ContiguousFragmentsAtThreshold(
id, score, hull, nxt, relation, common.Geometry,
)
}
}
var insertList []node.Node
var merged bool
//nxt, prev
if !merged && mergenxtBln {
db.Remove(nxt)
if validateMerge(&mergeNxt, db) {
if objects[0] == nxt {
objects = objects[1:]
}
insertList = append(insertList, mergeNxt)
merged = true
} else {
merged = false
insertList = append(insertList, *nxt)
}
}
if !merged && mergeprevBln {
db.Remove(prev)
//prev cannot exist since moving from left --- right
if validateMerge(&mergePrev, db) {
insertList = append(insertList, mergePrev)
merged = true
} else {
merged = false
insertList = append(insertList, *prev)
}
}
if !merged {
insertList = append(insertList, *hull)
}
db.Load(insertList)
}
}