| Safe Haskell | Safe |
|---|---|
| Language | Haskell2010 |
GHC.Natural
Description
Compatibility module for pre ghc-bignum code.
Synopsis
- data Natural where
- data BigNat = BN# {
- unBigNat :: BigNat#
- mkNatural :: [Word] -> Natural
- isValidNatural :: Natural -> Bool
- plusNatural :: Natural -> Natural -> Natural
- minusNatural :: Natural -> Natural -> Natural
- minusNaturalMaybe :: Natural -> Natural -> Maybe Natural
- timesNatural :: Natural -> Natural -> Natural
- negateNatural :: Natural -> Natural
- signumNatural :: Natural -> Natural
- quotRemNatural :: Natural -> Natural -> (Natural, Natural)
- quotNatural :: Natural -> Natural -> Natural
- remNatural :: Natural -> Natural -> Natural
- gcdNatural :: Natural -> Natural -> Natural
- lcmNatural :: Natural -> Natural -> Natural
- andNatural :: Natural -> Natural -> Natural
- orNatural :: Natural -> Natural -> Natural
- xorNatural :: Natural -> Natural -> Natural
- bitNatural :: Int# -> Natural
- testBitNatural :: Natural -> Int -> Bool
- popCountNatural :: Natural -> Int
- shiftLNatural :: Natural -> Int -> Natural
- shiftRNatural :: Natural -> Int -> Natural
- naturalToInteger :: Natural -> Integer
- naturalToWord :: Natural -> Word
- naturalToWordMaybe :: Natural -> Maybe Word
- wordToNatural :: Word -> Natural
- wordToNatural# :: Word -> Natural
- naturalFromInteger :: Integer -> Natural
- powModNatural :: Natural -> Natural -> Natural -> Natural
Documentation
Natural number
Invariant: numbers <= 0xffffffffffffffff use the NS constructor
Instances
| PrintfArg Natural Source # | Since: base-4.8.0.0 |
Defined in Text.Printf Methods formatArg :: Natural -> FieldFormatter Source # parseFormat :: Natural -> ModifierParser Source # | |
| Bits Natural Source # | Since: base-4.8.0 |
Defined in GHC.Internal.Bits Methods (.&.) :: Natural -> Natural -> Natural Source # (.|.) :: Natural -> Natural -> Natural Source # xor :: Natural -> Natural -> Natural Source # complement :: Natural -> Natural Source # shift :: Natural -> Int -> Natural Source # rotate :: Natural -> Int -> Natural Source # bit :: Int -> Natural Source # setBit :: Natural -> Int -> Natural Source # clearBit :: Natural -> Int -> Natural Source # complementBit :: Natural -> Int -> Natural Source # testBit :: Natural -> Int -> Bool Source # bitSizeMaybe :: Natural -> Maybe Int Source # bitSize :: Natural -> Int Source # isSigned :: Natural -> Bool Source # shiftL :: Natural -> Int -> Natural Source # unsafeShiftL :: Natural -> Int -> Natural Source # shiftR :: Natural -> Int -> Natural Source # unsafeShiftR :: Natural -> Int -> Natural Source # rotateL :: Natural -> Int -> Natural Source # | |
| Eq Natural Source # | |
| Ord Natural Source # | |
Defined in GHC.Internal.Bignum.Natural | |
| Data Natural Source # | Since: base-4.8.0.0 |
Defined in GHC.Internal.Data.Data Methods gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> Natural -> c Natural Source # gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c Natural Source # toConstr :: Natural -> Constr Source # dataTypeOf :: Natural -> DataType Source # dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c Natural) Source # dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c Natural) Source # gmapT :: (forall b. Data b => b -> b) -> Natural -> Natural Source # gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> Natural -> r Source # gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> Natural -> r Source # gmapQ :: (forall d. Data d => d -> u) -> Natural -> [u] Source # gmapQi :: Int -> (forall d. Data d => d -> u) -> Natural -> u Source # gmapM :: Monad m => (forall d. Data d => d -> m d) -> Natural -> m Natural Source # gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> Natural -> m Natural Source # gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> Natural -> m Natural Source # | |
| Enum Natural Source # | Since: base-4.8.0.0 |
Defined in GHC.Internal.Enum Methods succ :: Natural -> Natural Source # pred :: Natural -> Natural Source # toEnum :: Int -> Natural Source # fromEnum :: Natural -> Int Source # enumFrom :: Natural -> [Natural] Source # enumFromThen :: Natural -> Natural -> [Natural] Source # enumFromTo :: Natural -> Natural -> [Natural] Source # enumFromThenTo :: Natural -> Natural -> Natural -> [Natural] Source # | |
| Ix Natural Source # | Since: base-4.8.0.0 |
Defined in GHC.Internal.Ix Methods range :: (Natural, Natural) -> [Natural] Source # index :: (Natural, Natural) -> Natural -> Int Source # unsafeIndex :: (Natural, Natural) -> Natural -> Int Source # inRange :: (Natural, Natural) -> Natural -> Bool Source # rangeSize :: (Natural, Natural) -> Int Source # unsafeRangeSize :: (Natural, Natural) -> Int Source # | |
| Num Natural Source # | Note that Since: base-4.8.0.0 |
Defined in GHC.Internal.Num | |
| Read Natural Source # | Since: base-4.8.0.0 |
| Integral Natural Source # | Since: base-4.8.0.0 |
Defined in GHC.Internal.Real Methods quot :: Natural -> Natural -> Natural Source # rem :: Natural -> Natural -> Natural Source # div :: Natural -> Natural -> Natural Source # mod :: Natural -> Natural -> Natural Source # quotRem :: Natural -> Natural -> (Natural, Natural) Source # | |
| Real Natural Source # | Since: base-4.8.0.0 |
Defined in GHC.Internal.Real Methods toRational :: Natural -> Rational Source # | |
| Show Natural Source # | Since: base-4.8.0.0 |
| KnownNat n => HasResolution (n :: Nat) Source # | For example, |
Defined in Data.Fixed Methods resolution :: p n -> Integer Source # | |
| TestCoercion SNat Source # | Since: base-4.18.0.0 |
| TestEquality SNat Source # | Since: base-4.18.0.0 |
| Lift Natural Source # | |
| type Compare (a :: Natural) (b :: Natural) Source # | |
A lifted BigNat
Represented as an array of limbs (Word#) stored in little-endian order (Word# themselves use machine order).
Invariant (canonical representation): higher Word# is non-zero.
As a consequence, zero is represented with a WordArray# whose size is 0.
Instances
| Eq BigNat Source # | |
| Ord BigNat Source # | |
isValidNatural :: Natural -> Bool Source #
Arithmetic
negateNatural :: Natural -> Natural Source #
signumNatural :: Natural -> Natural Source #
quotNatural :: Natural -> Natural -> Natural Source #
remNatural :: Natural -> Natural -> Natural Source #
gcdNatural :: Natural -> Natural -> Natural Source #
Compute greatest common divisor.
lcmNatural :: Natural -> Natural -> Natural Source #
Compute least common multiple.
Bits
andNatural :: Natural -> Natural -> Natural Source #
xorNatural :: Natural -> Natural -> Natural Source #
bitNatural :: Int# -> Natural Source #
testBitNatural :: Natural -> Int -> Bool Source #
popCountNatural :: Natural -> Int Source #
shiftLNatural :: Natural -> Int -> Natural Source #
shiftRNatural :: Natural -> Int -> Natural Source #
Conversions
naturalToInteger :: Natural -> Integer Source #
Since: base-4.12.0.0
naturalToWord :: Natural -> Word Source #
naturalToWordMaybe :: Natural -> Maybe Word Source #
wordToNatural# :: Word -> Natural Source #
naturalFromInteger :: Integer -> Natural Source #
Since: base-4.10.0.0
Modular arithmetic
powModNatural :: Natural -> Natural -> Natural -> Natural Source #
"" computes base powModNatural b e mb raised to
exponent e modulo m.
Since: base-4.8.0.0