combinatorial

Count, enumerate, rank and unrank combinatorial objects

http://hub.darcs.net/thielema/combinatorial/

Version on this page:0.1@rev:1
LTS Haskell 24.16:0.1.1@rev:2
Stackage Nightly 2025-10-24:0.1.1@rev:2
Latest on Hackage:0.1.1@rev:2

See all snapshots combinatorial appears in

BSD-3-Clause licensed and maintained by Henning Thielemann
This version can be pinned in stack with:combinatorial-0.1@sha256:07eaebcb1fa8ee0f9d94925d4c5ac3bc66a9a64fd20c1b2c99b821c209780caf,2380

Module documentation for 0.1

  • Combinatorics
    • Combinatorics.BellNumbers
    • Combinatorics.CardPairs
    • Combinatorics.Coin
    • Combinatorics.Mastermind
    • Combinatorics.MaxNim
    • Combinatorics.PaperStripGame
    • Combinatorics.Partitions
    • Combinatorics.Permutation
      • Combinatorics.Permutation.WithoutSomeFixpoints
    • Combinatorics.TreeDepth

Counting, enumerating, ranking and unranking of combinatorial objects. Well-known and less well-known basic combinatoric problems and examples.

The functions are not implemented in obviously stupid ways, but they are also not optimized to the maximum extent. The package is plain Haskell 98.

See also:

  • exact-combinatorics: Efficient computations of large combinatoric numbers.

  • combinat: Library for a similar purpose with a different structure and selection of problems.

Changes

Change log for the combinatorial package

0.1

  • added explicit export lists, thus hide some helper functions and alternative implementations

  • use alternative implementations in tests

  • chooseToIndex -> chooseRank, chooseFromIndex -> chooseUnrank

0.0

  • Tests: replaced (==>) and custom cardinal types by QC.forAll.

  • extracted from HTam package