trait Semigroup[F] extends AnyRef
An associative binary operation, circumscribed by type and the semigroup laws. Unlike scalaz.Monoid, there is not necessarily a zero.
- Self Type
- Semigroup[F]
- Source
- Semigroup.scala
- See also
- Alphabetic
- By Inheritance
- Semigroup
- AnyRef
- Any
- Hide All
- Show All
- Public
- Protected
Type Members
- trait SemigroupApply extends Apply[[α]F]
- Attributes
- protected[this]
- trait SemigroupCompose extends Compose[[α, β]F]
- Attributes
- protected[this]
- trait SemigroupLaw extends AnyRef
A semigroup in type F must satisfy two laws:
A semigroup in type F must satisfy two laws:
- closure:
∀ a, b in F, append(a, b)
is also inF
. This is enforced by the type system. - associativity:
∀ a, b, c
inF
, the equationappend(append(a, b), c) = append(a, append(b , c))
holds.
- closure:
Abstract Value Members
- abstract def append(f1: F, f2: => F): F
The binary operation to combine
f1
andf2
.The binary operation to combine
f1
andf2
.Implementations should not evaluate the by-name parameter
f2
if result can be determined byf1
.
Concrete Value Members
- final def !=(arg0: Any): Boolean
- Definition Classes
- AnyRef → Any
- final def ##: Int
- Definition Classes
- AnyRef → Any
- final def ==(arg0: Any): Boolean
- Definition Classes
- AnyRef → Any
- final def apply: Apply[[α]F]
An scalaz.Apply, that implements
ap
withappend
.An scalaz.Apply, that implements
ap
withappend
. Note that the type parameterα
inApply[λ[α => F]]
is discarded; it is a phantom type. As such, the functor cannot support scalaz.Bind. - final def asInstanceOf[T0]: T0
- Definition Classes
- Any
- def clone(): AnyRef
- Attributes
- protected[lang]
- Definition Classes
- AnyRef
- Annotations
- @throws(classOf[java.lang.CloneNotSupportedException]) @native()
- final def compose: Compose[[α, β]F]
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.- Note
compose.semigroup
=this
- final def eq(arg0: AnyRef): Boolean
- Definition Classes
- AnyRef
- def equals(arg0: AnyRef): Boolean
- Definition Classes
- AnyRef → Any
- def finalize(): Unit
- Attributes
- protected[lang]
- Definition Classes
- AnyRef
- Annotations
- @throws(classOf[java.lang.Throwable])
- final def getClass(): Class[_ <: AnyRef]
- Definition Classes
- AnyRef → Any
- Annotations
- @native()
- def hashCode(): Int
- Definition Classes
- AnyRef → Any
- Annotations
- @native()
- final def isInstanceOf[T0]: Boolean
- Definition Classes
- Any
- def multiply1(value: F, n: Int): F
For
n = 0
,value
Forn = 1
,append(value, value)
Forn = 2
,append(append(value, value), value)
For
n = 0
,value
Forn = 1
,append(value, value)
Forn = 2
,append(append(value, value), value)
The default definition uses peasant multiplication, exploiting associativity to only require
O(log n)
uses of append - final def ne(arg0: AnyRef): Boolean
- Definition Classes
- AnyRef
- final def notify(): Unit
- Definition Classes
- AnyRef
- Annotations
- @native()
- final def notifyAll(): Unit
- Definition Classes
- AnyRef
- Annotations
- @native()
- def semigroupLaw: SemigroupLaw
- val semigroupSyntax: SemigroupSyntax[F]
- final def synchronized[T0](arg0: => T0): T0
- Definition Classes
- AnyRef
- def toString(): String
- Definition Classes
- AnyRef → Any
- def unfoldlSumOpt[S](seed: S)(f: (S) => Maybe[(S, F)]): Maybe[F]
Unfold
seed
to the left and sum using #append.Unfold
seed
to the left and sum using #append. Semigroups with right absorbing elements may override this method to not unfold more than is necessary to determine the result. - def unfoldrSumOpt[S](seed: S)(f: (S) => Maybe[(F, S)]): Maybe[F]
Unfold
seed
to the right and sum using #append.Unfold
seed
to the right and sum using #append. Semigroups with left absorbing elements may override this method to not unfold more than is necessary to determine the result. - final def wait(): Unit
- Definition Classes
- AnyRef
- Annotations
- @throws(classOf[java.lang.InterruptedException])
- final def wait(arg0: Long, arg1: Int): Unit
- Definition Classes
- AnyRef
- Annotations
- @throws(classOf[java.lang.InterruptedException])
- final def wait(arg0: Long): Unit
- Definition Classes
- AnyRef
- Annotations
- @throws(classOf[java.lang.InterruptedException]) @native()