type-level: Type-level programming library
This library permits performing computations on the type-level. Type-level functions are implemented using functional dependencies of multi parameter type classes. To date, Booleans and Numerals (Naturals and Positives) are supported. With regard to Numerals, there is support for common arithmetic operations (addition, substraction, multiplication, division, exponientation, logarithm, maximum, comparison, GCD) over natural numbers (using a decimal representation to make compile-time errors friendlier). Although making use of type-level computations might seem devious and obfuscated at first sight, it is indeed useful in practice to implement lightweight dependent types such us number-parameterized types (e.g. an array type parameterized by the array's size or a modular group type Zn parameterized by the modulus). Here is a tutorial on type-level numerals and how to use them to implement numerically-parameterized vectors: http://www.ict.kth.se/org/ict/ecs/sam/projects/forsyde/www/files/tutorial/tutorial.html#FSVec
[Skip to Readme]
Modules
[Index]
Downloads
- type-level-0.2.3.tar.gz [browse] (Cabal source package)
- Package description (as included in the package)
Maintainer's Corner
For package maintainers and hackage trustees
Candidates
- No Candidates
Versions [RSS] | 0.1, 0.2, 0.2.1, 0.2.2, 0.2.3, 0.2.4, 0.3.0 |
---|---|
Dependencies | base (>=3 && <5), template-haskell (>2.0) [details] |
Tested with | ghc ==6.8.2 |
License | BSD-3-Clause |
Copyright | Copyright (c) 2008 Alfonso Acosta, Oleg Kiselyov, Wolfgang Jeltsch and KTH's SAM group |
Author | Alfonso Acosta |
Maintainer | alfonso.acosta@gmail.com |
Category | Data |
Home page | http://code.haskell.org/type-level |
Uploaded | by LennartAugustsson at 2009-07-27T08:31:47Z |
Distributions | NixOS:0.3.0 |
Reverse Dependencies | 18 direct, 78 indirect [details] |
Downloads | 7553 total (33 in the last 30 days) |
Rating | (no votes yet) [estimated by Bayesian average] |
Your Rating | |
Status | Docs uploaded by user Build status unknown [no reports yet] |