acts: Semigroup actions, groups, and torsors.

[ algebra, bsd3, library, math ] [ Propose Tags ]

Acts and torsors model types which can be transformed under the action of another type.

A prototypical example is affine space, which has an action by translation: given any two points in affine space, there is a unique translation that brings one to the other.

This can be useful in a library keeping track of time: on top of needing to keep track of units, one also needs to distinguish between absolute time (time stamps) and relative time (time differences). The operations one expects in this situation are:

  • Addition and subtraction of time differences: time differences form a (commutative) group.

  • Translation of an absolute time by a time difference: there is an action of relative time on absolute time.

  • Given two absolute times, one can obtain the time difference between them: absolute time is a torsor under relative time.

This library provides a convenient framework which helps to avoid mixing up these two different notions.

A fleshed out example is available at Acts.Examples.MusicalIntervals, which showcases the use of actions and torsors in the context of musical intervals and harmony. It also demonstrates common usage patterns of this library, such as how to automatically derive instances.

See also the project readme, which includes a simple example with 2D affine space.

Downloads

Maintainer's Corner

Package maintainers

For package maintainers and hackage trustees

Candidates

Versions [RSS] 0.1.0.0, 0.2.0.0, 0.3.0.0, 0.3.1.0, 0.3.1.1
Change log changelog.md
Dependencies acts, base (>=4.12 && <4.15), deepseq (>=1.4.4.0 && <1.5), finite-typelits (>=0.1.4.2 && <0.2), generic-data (>=0.6.0.1 && <0.7.0.0) [details]
License BSD-3-Clause
Author Sam Derbyshire
Maintainer Sam Derbyshire
Category Algebra, Math
Home page https://github.com/sheaf/acts
Bug tracker https://github.com/sheaf/acts/issues
Source repo head: git clone git://github.com/sheaf/acts.git
Uploaded by sheaf at 2020-02-13T14:38:44Z
Distributions
Downloads 1293 total (14 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]