fin

Nat and Fin: peano naturals and finite numbers

https://github.com/phadej/vec

Version on this page:0.0.3
LTS Haskell 22.42:0.3@rev:2
Stackage Nightly 2024-11-18:0.3.2
Latest on Hackage:0.3.2

See all snapshots fin appears in

BSD-3-Clause licensed by Oleg Grenrus
Maintained by Oleg.Grenrus
This version can be pinned in stack with:fin-0.0.3@sha256:265dbb2ba5b8b206e5d3c3bba1cfd78ff18aba8c793acb3e03dde497cea68ecd,3492
Depends on 4 packages(full list with versions):
Used by 2 packages in lts-13.28(full list with versions):

This package provides two simple types, and some tools to work with them. Also on type level as DataKinds.

-- Peano naturals
data Nat = Z | S Nat

-- Finite naturals
data Fin (n :: Nat) where
    Z :: Fin ('S n)
    S :: Fin n -> Fin ('Nat.S n)

vec implements length-indexed (sized) lists using this package for indexes.

The Data.Fin.Enum module let's work generically with enumerations.

See Hasochism: the pleasure and pain of dependently typed haskell programming by Sam Lindley and Conor McBride for answers to how and why. Read APLicative Programming with Naperian Functors by Jeremy Gibbons for (not so) different ones.

Similar packages

Changes

Revision history for fin

0.0.3

  • Add Data.Type.Nat.LE, Data.Type.Nat.LT and Data.Type.Nat.LE.ReflStep modules
  • Add withSNat and discreteNat

0.0.2

  • In Fin add: append and split
  • Add (Enum a, Enum b) => Enum (Either a b) instance

0.0.1

  • GHC-8.4.1 / base-4.11 support

0

  • First version. Released on an unsuspecting world.