Monoid instances must satisfy scalaz.Semigroup.SemigroupLaw and 2 additional laws:
A semigroup in type F must satisfy two laws:
The binary operation to combine f1 and f2.
The binary operation to combine f1 and f2.
Implementations should not evaluate tbe by-name parameter f2 if result
can be determined by f1.
A monoidal applicative functor, that implements point and ap
with the operations zero and append respectively.
A monoidal applicative functor, that implements point and ap
with the operations zero and append respectively. Note that
the type parameter α in Applicative[({type λ[α]=F})#λ] is
discarded; it is a phantom type. As such, the functor cannot
support scalaz.Bind.
An scalaz.Apply, that implements ap with append.
An scalaz.Apply, that implements ap with append. Note
that the type parameter α in Apply[({type λ[α]=F})#λ] is
discarded; it is a phantom type. As such, the functor cannot
support scalaz.Bind.
Every Monoid gives rise to a scalaz.Category, for which
the type parameters are phantoms.
Every Monoid gives rise to a scalaz.Category, for which
the type parameters are phantoms.
category.monoid = this
Every Semigroup gives rise to a scalaz.Compose, for which
the type parameters are phantoms.
Every Semigroup gives rise to a scalaz.Compose, for which
the type parameters are phantoms.
compose.semigroup = this
Whether a == zero.
Whether a == zero.
For n = 0, zero
For n = 1, append(zero, value)
For n = 2, append(append(zero, value), value)
For n = 0, zero
For n = 1, append(zero, value)
For n = 2, append(append(zero, value), value)
The identity element for append.
The identity element for append.