package rtree import ( "fmt" "math/rand" "runtime" "testing" ) func randf(min, max float64) float64 { return rand.Float64()*(max-min) + min } func randMinMax() (min, max []float64) { minX, maxX := randf(-180, 180), randf(-180, 180) minY, maxY := randf(-90, 90), randf(-90, 90) minZ, maxZ := randf(0, 1000), randf(0, 1000) min4, max4 := randf(0, 1000), randf(0, 1000) if maxX < minX { minX, maxX = maxX, minX } if maxY < minY { minY, maxY = maxY, minY } if maxZ < minZ { minZ, maxZ = maxZ, minZ } if max4 < min4 { min4, max4 = max4, min4 } return []float64{minX, minY, minZ, min4}, []float64{maxX, maxY, maxZ, max4} } func wp(min, max []float64) *Rect { return &Rect{ MinX: min[0], MinY: min[1], MaxX: max[0], MaxY: max[1], } } func wpp(x, y, z float64) *Rect { return &Rect{ x, y, z, x, y, z, } } func TestA(t *testing.T) { tr := New() item1 := wp([]float64{10, 10, 10, 10}, []float64{20, 20, 20, 20}) item2 := wp([]float64{5, 5, 5, 5}, []float64{25, 25, 25, 25}) tr.Insert(item1) tr.Insert(item2) var itemA Item tr.Search(21, 20, 0, 25, 25, 0, func(item Item) bool { itemA = item return true }) if tr.Count() != 2 { t.Fatalf("tr.Count() == %d, expect 2", tr.Count()) } if itemA != item2 { t.Fatalf("itemA == %v, expect %v", itemA, item2) } } func TestMemory(t *testing.T) { rand.Seed(0) tr := New() for i := 0; i < 100000; i++ { min, max := randMinMax() tr.Insert(wp(min, max)) } runtime.GC() var m runtime.MemStats runtime.ReadMemStats(&m) println(int(m.HeapAlloc)/tr.Count(), "bytes/rect") } func TestBounds(t *testing.T) { tr := New() tr.Insert(wpp(10, 10, 0)) tr.Insert(wpp(10, 20, 0)) tr.Insert(wpp(10, 30, 0)) tr.Insert(wpp(20, 10, 0)) tr.Insert(wpp(30, 10, 0)) minX, minY, minZ, maxX, maxY, maxZ := tr.Bounds() if minX != 10 || minY != 10 || minZ != 0 || maxX != 30 || maxY != 30 || maxZ != 0 { t.Fatalf("expected 10,10,0 30,30,0, got %v,%v %v,%v\n", minX, minY, minZ, maxX, maxY, maxZ) } } func TestKNN(t *testing.T) { x, y, z := 20., 20., 0. tr := New() tr.Insert(wpp(5, 5, 0)) tr.Insert(wpp(19, 19, 0)) tr.Insert(wpp(12, 19, 0)) tr.Insert(wpp(-5, 5, 0)) tr.Insert(wpp(33, 21, 0)) var items []Item tr.NearestNeighbors(x, y, z, func(item Item, dist float64) bool { items = append(items, item) return true }) var res string for i, item := range items { ix, iy, _, _, _, _ := item.Rect() res += fmt.Sprintf("%d:%v,%v\n", i, ix, iy) } if res != "0:19,19\n1:12,19\n2:33,21\n3:5,5\n4:-5,5\n" { t.Fatal("invalid response") } } func BenchmarkInsert(b *testing.B) { var rects []*Rect for i := 0; i < b.N; i++ { rects = append(rects, wp(randMinMax())) } rand.Seed(0) b.ReportAllocs() b.ResetTimer() tr := New() for i := 0; i < b.N; i++ { tr.Insert(rects[i]) } }