Skip to content

Files

Latest commit

 

History

History
45 lines (32 loc) · 1.29 KB

readme.md

File metadata and controls

45 lines (32 loc) · 1.29 KB

Ball Tree

A very fast python-wrapped fortran implementation of a ball tree, includes fast argsort and argselect codes for flat arrays as well.

INSTALLATION:

pip install git+https://github.com/tchlux/balltree.git

USAGE:

Python

import numpy as np
import balltree

points = np.random.random(size=(100000,1000))
tree = balltree.BallTree(points, leaf_size=1)
distances, indices = tree.query(points[:1,:], k=3)
# 'distances' will have the distances to the `k` nearest points to points[0]
# 'indices' will have the index of the `k` nearest points to points[0]


x = np.random.random(size=(10000,))
x, i = balltree.argsort(x, indices=np.arange(len(x)))
# `x` is sorted in place
# `i` is sorted symmetrically with `x` in place, in this case it
#     shows the original indices of the elements of `x` (before sort).


x = np.random.random(size=(10000,))
k = 0
x, i = balltree.argselect(x, k, indices=np.arange(len(x)))
# `x` is rearranged such that the element at `x[k]` has rank `k`
# `i` is rearranged symmetrically with `x` in place, in this case it
#     shows the original indices of the elements of `x` (before sort).

In general, see the help documentation of each function for detailed descriptions of functions.