devel/hs-psqueues - The NetBSD Packages Collection

Pure priority search queues

The psqueues package provides Priority Search Queues in three
different flavors.

* OrdPSQ k p v, which uses the Ord k instance to provide fast
  insertion, deletion and lookup. This implementation is based on Ralf
  Hinze's A Simple Implementation Technique for Priority Search
  Queues. Hence, it is similar to the PSQueue library, although it is
  considerably faster and provides a slightly different API.

* IntPSQ p v is a far more efficient implementation. It fixes the key
  type to Int and uses a radix tree (like IntMap) with an additional
  min-heap property.

* HashPSQ k p v is a fairly straightforward extension of IntPSQ: it
  simply uses the keys' hashes as indices in the IntPSQ. If there are
  any hash collisions, it uses an OrdPSQ to resolve those. The
  performance of this implementation is comparable to that of IntPSQ,
  but it is more widely applicable since the keys are not restricted
  to Int, but rather to any Hashable datatype.

Each of the three implementations provides the same API, so they can
be used interchangeably. The benchmarks show how they perform relative
to one another, and also compared to the other Priority Search Queue
implementations on Hackage: PSQueue and fingertree-psqueue.

Build dependencies

pkgtools/mktools pkgtools/cwrappers

Runtime dependencies

lang/ghc910 devel/hs-hashable devel/hs-hashable

Binary packages

OSArchitectureVersion
NetBSD 10.0aarch64hs-psqueues-0.2.8.1nb2.tgz
NetBSD 10.0aarch64hs-psqueues-0.2.8.0nb1.tgz
NetBSD 10.0aarch64hs-psqueues-0.2.8.1nb2.tgz
NetBSD 10.0aarch64hs-psqueues-0.2.8.1nb3.tgz
NetBSD 10.0x86_64hs-psqueues-0.2.8.1nb3.tgz
NetBSD 10.0x86_64hs-psqueues-0.2.8.1nb2.tgz
NetBSD 11.0aarch64hs-psqueues-0.2.8.1nb3.tgz
NetBSD 11.0x86_64hs-psqueues-0.2.8.1nb3.tgz
NetBSD 9.0aarch64hs-psqueues-0.2.8.1nb2.tgz
NetBSD 9.0aarch64hs-psqueues-0.2.8.1nb2.tgz
NetBSD 9.0aarch64hs-psqueues-0.2.8.1nb3.tgz
NetBSD 9.0x86_64hs-psqueues-0.2.8.1nb2.tgz
NetBSD 9.0x86_64hs-psqueues-0.2.8.1nb3.tgz
NetBSD 9.3x86_64hs-psqueues-0.2.8.1nb1.tgz

Binary packages can be installed with the high-level tool pkgin (which can be installed with pkg_add) or pkg_add(1) (installed by default). The NetBSD packages collection is also designed to permit easy installation from source.

Available build options

(none)

Known vulnerabilities

The pkg_admin audit command locates any installed package which has been mentioned in security advisories as having vulnerabilities.

Please note the vulnerabilities database might not be fully accurate, and not every bug is exploitable with every configuration.


Problem reports, updates or suggestions for this package should be reported with send-pr.