forked from rob05c/quadtree
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathqt_test.go
49 lines (46 loc) · 1.14 KB
/
qt_test.go
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
package quadtree
import (
"math/rand"
"runtime"
"testing"
"time"
"strconv"
)
/// note the number of points inserted is only approximately points
/// the actual number inserted is the closest power of threads
func testInsert(t *testing.T, points int, threads int) (inserted int, tree Quadtree) {
runtime.GOMAXPROCS(threads / 4)
rand.Seed(time.Now().UnixNano())
nodeCapacity := 4
qt := New(&BoundingBox{
Center: Point{100.0, 100.0},
HalfDimension: Point{50.0, 50.0},
}, nodeCapacity)
tpoints := points / threads
done := make(chan bool)
insertPoint := func() {
for i := 0; i != tpoints; i++ {
p := &Point{rand.Float64()*100.0 + 50.0, rand.Float64()*100.0 + 50.0}
if !qt.Insert(p) {
t.Log("insert failed")
t.FailNow()
}
}
done <- true
}
for i := 0; i != threads; i++ {
go insertPoint()
}
for i := 0; i != threads; i++ {
<-done
}
return tpoints * threads, qt
}
func TestInsertQuery(t *testing.T) {
inserted, qt := testInsert(t, 1000000, 100)
queried := len(qt.Query(qt.Boundary()))
if inserted != queried {
t.Log("inserted " + strconv.Itoa(inserted) + " but queried " + strconv.Itoa(queried))
t.FailNow()
}
}