Safe Haskell | None |
---|---|
Language | Haskell98 |
A tropical semiring is an extension of another totally ordered
semiring with the operations of minimum or maximum as addition.
The extended semiring is given positive or negative infinity as
its zero
element, so that the following hold:
plus
Infinity
y = yplus
xInfinity
= x
i.e., In the max-plus tropical semiring (where plus
is max
),
Infinity
unifies with the typical interpretation of negative infinity,
and thus it is the identity for the maximum, and in the min-plus tropical
semiring (where plus
is min
), Infinity
unifies with the typical
interpretation of positive infinity, and thus it is the identity for the minimum.
Documentation
data Tropical (e :: Extrema) a Source #
The tropical semiring.
is equivalent to the semiring
\( (a \cup \{+\infty\}, \oplus, \otimes) \), where \( x \oplus y = min\{x,y\}\) and \(x \otimes y = x + y\).Tropical
'Minima
a
is equivalent to the semiring
\( (a \cup \{-\infty\}, \oplus, \otimes) \), where \( x \oplus y = max\{x,y\}\) and \(x \otimes y = x + y\).Tropical
'Maxima
a
In literature, the Semiring
instance of the Tropical
semiring lifts
the underlying semiring's additive structure. One might ask why this lifting doesn't
instead witness a Monoid
, since we only lift zero
and plus
- the reason is
that usually the additive structure of a semiring is monotonic, i.e.
a
, but in general this is not true.
For example, lifting +
(min
b c) == min
(a +
b) (a +
c)Product
Word
into Tropical
is lawful,
but Product
Int
is not, lacking distributivity: (-1)
.
So, we deviate from literature and instead
witness the lifting of a *
(min
0 1) /=
min
((-1) *
0) ((-1) *
1)Monoid
, so the user must take care to ensure
that their implementation of mappend
is monotonic.
Instances
Eq a => Eq (Tropical e a) Source # | |
(Typeable e, Data a) => Data (Tropical e a) Source # | |
Defined in Data.Semiring.Tropical gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> Tropical e a -> c (Tropical e a) # gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c (Tropical e a) # toConstr :: Tropical e a -> Constr # dataTypeOf :: Tropical e a -> DataType # dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c (Tropical e a)) # dataCast2 :: Typeable t => (forall d e0. (Data d, Data e0) => c (t d e0)) -> Maybe (c (Tropical e a)) # gmapT :: (forall b. Data b => b -> b) -> Tropical e a -> Tropical e a # gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> Tropical e a -> r # gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> Tropical e a -> r # gmapQ :: (forall d. Data d => d -> u) -> Tropical e a -> [u] # gmapQi :: Int -> (forall d. Data d => d -> u) -> Tropical e a -> u # gmapM :: Monad m => (forall d. Data d => d -> m d) -> Tropical e a -> m (Tropical e a) # gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> Tropical e a -> m (Tropical e a) # gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> Tropical e a -> m (Tropical e a) # | |
(Ord a, Extremum e) => Ord (Tropical e a) Source # | |
Defined in Data.Semiring.Tropical | |
Read a => Read (Tropical e a) Source # | |
Show a => Show (Tropical e a) Source # | |
(Ord a, Monoid a, Extremum e) => Semiring (Tropical e a) Source # | |
(Ord a, Monoid a, Extremum e) => Star (Tropical e a) Source # | |
A datatype to be used at the kind-level. Its only purpose is to decide the ordering for the tropical semiring in a type-safe way.