exotic-list-monads: Non-standard monads on lists and non-empty lists

[ library, list, mit, monads ] [ Propose Tags ] [ Report a vulnerability ]

The usual list monad is only one of infinitely many ways to turn the list functor into a monad. The same applies to the usual non-empty list monad and the non-empty list functor. This library collects such non-standard "list" and "non-empty list" monads.


[Skip to Readme]

Downloads

Maintainer's Corner

Package maintainers

For package maintainers and hackage trustees

Candidates

  • No Candidates
Versions [RSS] 1.0.0, 1.0.1, 1.1.0, 1.1.1
Change log CHANGELOG.md
Dependencies base (>=4.9 && <5) [details]
Tested with ghc ==8.0.2 || ==8.2.2 || ==8.4.4 || ==8.6.5 || ==8.8.3 || ==8.10.1
License MIT
Copyright (c) 2020 Dylan McDermott, Maciej Piróg, Tarmo Uustalu
Author Maciej Piróg <maciej.adam.pirog@gmial.com>
Maintainer Maciej Piróg <maciej.adam.pirog@gmail.com>
Category List, Monads
Home page http://github.com/maciejpirog/exotic-list-monads
Bug tracker http://github.com/maciejpirog/exotic-list-monads/issues
Source repo head: git clone https://github.com/maciejpirog/exotic-list-monads
Uploaded by maciejpirog at 2023-11-21T11:47:40Z
Distributions NixOS:1.1.1
Downloads 549 total (17 in the last 30 days)
Rating (no votes yet) [estimated by Bayesian average]
Your Rating
  • λ
  • λ
  • λ
Status Docs available [build log]
Last success reported on 2023-11-21 [all 1 reports]

Readme for exotic-list-monads-1.1.1

[back to package description]

exotic-list-monads

The usual list monad is only one of infinitely many ways to turn the list functor into a monad. The same applies to the usual non-empty list monad and the non-empty list functor. This library collects such non-standard "list" and "non-empty list" monads.

It is quite possible that there exist "list" and "non-empty list" monads that we are not aware of, so pull requests are appreciated. Moreover, not every monad in this library has been formally verified to be a monad (it is not a trivial task because of combinatorial explosions of the number of cases to be considered in some proofs of associativity), so if you're currently playing around with tools like Coq and have a spare afternoon...

Most of the monads defined in this module have been introduced in the following papers (although there are some new specimens as well):