Skip to content
/ kdbush Public
forked from MadAppGang/kdbush

Golang port of kdbush, a fast static spatial index for 2D points.

License

Notifications You must be signed in to change notification settings

k0nsta/kdbush

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

5 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

KDBsuh

Godoc is here

Package kdbush provides a very fast static spatial index for 2D points based on a flat KD-tree. Very fast, but limited:

  • Points only, no rectangles
  • 2 dimensional
  • indexing 16-40 times faster then rtreego(https: github.com/dhconnelly/rtreego) (TODO: benchmark)
  • Implements radius search (rtreego and go.geo only have range search)

There are three amazing other options for geospatial indexing:

This implementation is based on:

  • JS library: https: github.com/mourner/kdbush
  • C++11 port: https: github.com/mourner/kdbush.hpp

##Create Index example All Items should implement Point interface:

type Point interface {
	Coordinates() (X, Y float64)
}

Package represents simple struct, that implements that protocol, you could use it:

type SimplePoint struct {
	X, Y float64
}
func (sp *SimplePoint)Coordinates()(float64, float64) {
	return sp.X, sp.Y
}

To create index, just supply array of points and nodeSize. NodeSize is size of the KD-tree node, 64 by default. Higher means faster indexing but slower search, and vise versa.

points := []Point{
  &SimplePoint{X:10,Y:10}, //0
  &SimplePoint{X:15,Y:11}, //1
  &SimplePoint{X:1,Y:22},
  &SimplePoint{X:22,Y:22},
  &SimplePoint{X:34,Y:12},
  &SimplePoint{X:19,Y:19}, //5
  &SimplePoint{X:32,Y:34},
}
bush := NewBush(points, 10)

##Search in range

kdbush implements Range function to find points in bounding box. Returns an array of indices that refer to the items in the original points input slice.

points := []Point{
  &SimplePoint{X:10,Y:10}, //0
  &SimplePoint{X:15,Y:11}, //1
  &SimplePoint{X:1,Y:22},
  &SimplePoint{X:22,Y:22},
  &SimplePoint{X:34,Y:12},
  &SimplePoint{X:19,Y:19}, //5
  &SimplePoint{X:32,Y:34},
}
bush := NewBush(points, 10)
result :=  bush.Range(10, 10, 21, 21)
fmt.Println(result)
// Output: [0 1 5]

About

Golang port of kdbush, a fast static spatial index for 2D points.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Go 100.0%