Skip to content

Latest commit

 

History

History
24 lines (17 loc) · 775 Bytes

README.md

File metadata and controls

24 lines (17 loc) · 775 Bytes

orx-interval-tree

Interval trees intend to speed-up point in interval queries. Specifically in cases with a large set of items with a given fixed start and end time.

For more information on interval trees read the wikipedia page.

Usage

// -- the item class we want to search for
class Item(val start: Double, val end: Double)

// -- the items we want to search in
val items = List(100000) { Item(Math.random(), 1.0 + Math.random()) }

// -- build the interval tree, note how buildIntervalTree accepts a function that returns the start and end of the interval.
val tree = buildIntervalTree(items) {
    Pair(it.start, it.end)
}

// -- search for all items that intersect 0.05
val results = tree.queryPoint(0.05)