@hackage acts0.2.0.0

Semigroup actions, groups, and torsors.

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.