npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

node-interval-tree

v2.1.2

Published

Implementation of interval tree data structure.

Downloads

178,099

Readme

node-interval-tree

An Interval Tree data structure implemented as an augmented AVL Tree where each node maintains a list of records and their search intervals. Record is composed of an interval and its underlying data, sent by a client. This allows the interval tree to have the same interval inserted multiple times, as long as its data is different. Both insertion and deletion require O(log n) time. Searching requires O(min(n, k * log n)) time, where k is the number of intervals in the output list.

NPM

NPM

Usage

import IntervalTree from 'node-interval-tree'
const intervalTree = new IntervalTree<string>()

Insert

intervalTree.insert(low, high, 'foo')

Insert an interval with associated data into the tree. Intervals with the same low and high value can be inserted, as long as their data is different. Data can be any JS primitive or object. low and high have to be numbers where low <= high (also the case for all other operations with low and high). Returns true if successfully inserted, false if nothing inserted.

Search

intervalTree.search(low, high)

Search all intervals that overlap low and high arguments, both of them inclusive. Low and high values don't need to be in the tree themselves. Returns an array of all data objects of the intervals in the range [low, high]; doesn't return the intervals themselves.

Remove

intervalTree.remove(low, high, 'foo')

Remove an interval from the tree. To remove an interval, all arguments must match the one in the tree. Returns true if successfully removed, false if nothing removed.

Advanced usage

The default export is convenient to use but can be too limiting for some. exports.IntervalTree operate on Interval directly, giving you access to the low and high values in the results. You can attach extra properties to Interval but they should not be modified after insertion as objects in the tree are compared according to shallow equality.

import { Interval, IntervalTree } from 'node-interval-tree'

interface StringInterval extends Interval {
  name: string
}

const intervalTree = new IntervalTree<StringInterval>()

Insert

intervalTree.insert({ low, high })
intervalTree.insert({ low, high, name: 'foo' })

Insert an interval into the tree. Intervals are compared according to shallow equality and only inserted if unique. Returns true if successfully inserted, false if nothing inserted.

Search

intervalTree.search(low, high)

Search all intervals that overlap low and high arguments, both of them inclusive. Low and high values don't need to be in the tree themselves. Returns an array of all intervals in the range [low, high].

Remove

intervalTree.remove({ low, high })
intervalTree.remove({ low, high, name: 'foo' })

Remove an interval from the tree. Intervals are compared according to shallow equality and only removed if all properties match. Returns true if successfully removed, false if nothing removed.

BigInt support

The low and high values of the interval are of type number by default. However, the library offers support to use bigint type for interval keys instead.

With default export:

import IntervalTree from 'node-interval-tree'
const intervalTree = new IntervalTree<string, bigint>()

With advanced export:

import { Interval, IntervalTree } from 'node-interval-tree'

interface StringInterval extends Interval<bigint> {
  name: string
}

const intervalTree = new IntervalTree<StringInterval, bigint>()

Example

import IntervalTree from 'node-interval-tree'

const intervalTree = new IntervalTree<string>()
intervalTree.insert(10, 15, 'foo') // -> true
intervalTree.insert(35, 50, 'baz') // -> true

intervalTree.search(12, 20) // -> ['foo']

intervalTree.remove(35, 50, 'baz') // -> true
intervalTree.insert(10, 15, 'baz') // -> true

intervalTree.search(12, 20) // -> ['foo', 'baz']

More examples can be found in the demo folder.

License

MIT