{-# LANGUAGE CPP #-}
{-# LANGUAGE ViewPatterns #-}
module Numeric.Algebra.Multiplicative.MMonoid
( MMonoid (..),
pattern One,
pattern NonOne,
)
where
import Data.Coerce (coerce)
import Data.Complex (Complex)
import Data.Fixed (Fixed, HasResolution)
import Data.Int (Int16, Int32, Int64, Int8)
import Data.Kind (Constraint, Type)
import Data.Ratio (Ratio)
import Data.Word (Word16, Word32, Word64, Word8)
import GHC.Natural (Natural)
import Numeric.Algebra.Deriving
( FromFractional (MkFromFractional),
FromIntegral (MkFromIntegral),
FromNum (MkFromNum),
)
import Numeric.Algebra.Multiplicative.MSemigroup (MSemigroup)
type MMonoid :: Type -> Constraint
class (MSemigroup m) => MMonoid m where
one :: m
pattern One :: (MMonoid m, Eq m) => m
pattern $bOne :: forall m. (MMonoid m, Eq m) => m
$mOne :: forall {r} {m}.
(MMonoid m, Eq m) =>
m -> ((# #) -> r) -> ((# #) -> r) -> r
One <- ((== one) -> True)
where
One = m
forall m. MMonoid m => m
one
pattern NonOne :: (MMonoid m, Eq m) => m -> m
pattern $mNonOne :: forall {r} {m}.
(MMonoid m, Eq m) =>
m -> (m -> r) -> ((# #) -> r) -> r
NonOne y <- (\m
x -> (m
x m -> m -> Bool
forall a. Eq a => a -> a -> Bool
== m
forall m. MMonoid m => m
one, m
x) -> (False, y))
#if MIN_VERSION_base(4, 16, 0)
{-# COMPLETE One, NonOne #-}
#endif
deriving via (FromNum a) instance (Num a) => MMonoid (FromFractional a)
deriving via (FromNum a) instance (Num a) => MMonoid (FromIntegral a)
instance (Num a) => MMonoid (FromNum a) where
one :: FromNum a
one = forall a b. Coercible a b => a -> b
forall a b. Coercible a b => a -> b
coerce @a a
1
{-# INLINE one #-}
deriving via (FromNum Double) instance MMonoid Double
deriving via (FromNum Float) instance MMonoid Float
deriving via (FromNum Int) instance MMonoid Int
deriving via (FromNum Int8) instance MMonoid Int8
deriving via (FromNum Int16) instance MMonoid Int16
deriving via (FromNum Int32) instance MMonoid Int32
deriving via (FromNum Int64) instance MMonoid Int64
deriving via (FromNum Integer) instance MMonoid Integer
deriving via (FromNum Word) instance MMonoid Word
deriving via (FromNum Word8) instance MMonoid Word8
deriving via (FromNum Word16) instance MMonoid Word16
deriving via (FromNum Word32) instance MMonoid Word32
deriving via (FromNum Word64) instance MMonoid Word64
deriving via (FromNum Natural) instance MMonoid Natural
deriving via (FromNum (Ratio Integer)) instance MMonoid (Ratio Integer)
deriving via (FromNum (Ratio Natural)) instance MMonoid (Ratio Natural)
deriving via (FromNum (Complex a)) instance (RealFloat a) => MMonoid (Complex a)
deriving via (FromNum (Fixed k)) instance (HasResolution k) => MMonoid (Fixed k)