{-# LANGUAGE CPP #-}
{-# LANGUAGE DataKinds #-}
{-# LANGUAGE DerivingVia #-}
{-# LANGUAGE MultiParamTypeClasses #-}
{-# LANGUAGE StandaloneDeriving #-}
{-# OPTIONS_GHC -Wno-orphans -Wno-unused-imports #-}
module Numeric.Rounded.Hardware.Backend.Default
() where
import qualified Numeric.Rounded.Hardware.Backend.ViaRational as VR
import Numeric.Rounded.Hardware.Internal.Class
#ifdef USE_FFI
import qualified Numeric.Rounded.Hardware.Backend.C as C
#ifdef USE_GHC_PRIM
import qualified Numeric.Rounded.Hardware.Backend.FastFFI as FastFFI
#endif
#ifdef USE_X87_LONG_DOUBLE
import Numeric.Rounded.Hardware.Backend.X87LongDouble ()
#endif
#ifdef USE_FLOAT128
import Numeric.Rounded.Hardware.Backend.Float128 ()
#endif
#endif
import Data.Coerce
import qualified Data.Vector.Storable as VS
import qualified Data.Vector.Unboxed as VU
import Numeric.Floating.IEEE
import Unsafe.Coerce
#ifdef USE_FFI
#ifdef USE_GHC_PRIM
type FloatImpl = C.CFloat
type DoubleImpl = FastFFI.CDouble
#else
type FloatImpl = C.CFloat
type DoubleImpl = C.CDouble
#endif
#else
type FloatImpl = VR.ViaRational Float
type DoubleImpl = VR.ViaRational Double
#endif
deriving via FloatImpl instance RoundedRing Float
deriving via FloatImpl instance RoundedFractional Float
deriving via FloatImpl instance RoundedSqrt Float
deriving via FloatImpl instance RoundedRing_Vector VU.Vector Float
deriving via FloatImpl instance RoundedFractional_Vector VU.Vector Float
deriving via FloatImpl instance RoundedSqrt_Vector VU.Vector Float
instance RoundedRing_Vector VS.Vector Float where
roundedSum :: RoundingMode -> Vector Float -> Float
roundedSum RoundingMode
mode Vector Float
vec = FloatImpl -> Float
forall a b. Coercible a b => a -> b
coerce (RoundingMode -> Vector FloatImpl -> FloatImpl
forall (vector :: * -> *) a.
RoundedRing_Vector vector a =>
RoundingMode -> vector a -> a
roundedSum RoundingMode
mode (Vector Float -> Vector FloatImpl
forall a b. a -> b
unsafeCoerce Vector Float
vec :: VS.Vector FloatImpl))
zipWith_roundedAdd :: RoundingMode -> Vector Float -> Vector Float -> Vector Float
zipWith_roundedAdd RoundingMode
mode Vector Float
vec Vector Float
vec' = Vector FloatImpl -> Vector Float
forall a b. a -> b
unsafeCoerce (RoundingMode
-> Vector FloatImpl -> Vector FloatImpl -> Vector FloatImpl
forall (vector :: * -> *) a.
RoundedRing_Vector vector a =>
RoundingMode -> vector a -> vector a -> vector a
zipWith_roundedAdd RoundingMode
mode (Vector Float -> Vector FloatImpl
forall a b. a -> b
unsafeCoerce Vector Float
vec) (Vector Float -> Vector FloatImpl
forall a b. a -> b
unsafeCoerce Vector Float
vec') :: VS.Vector FloatImpl)
zipWith_roundedSub :: RoundingMode -> Vector Float -> Vector Float -> Vector Float
zipWith_roundedSub RoundingMode
mode Vector Float
vec Vector Float
vec' = Vector FloatImpl -> Vector Float
forall a b. a -> b
unsafeCoerce (RoundingMode
-> Vector FloatImpl -> Vector FloatImpl -> Vector FloatImpl
forall (vector :: * -> *) a.
RoundedRing_Vector vector a =>
RoundingMode -> vector a -> vector a -> vector a
zipWith_roundedSub RoundingMode
mode (Vector Float -> Vector FloatImpl
forall a b. a -> b
unsafeCoerce Vector Float
vec) (Vector Float -> Vector FloatImpl
forall a b. a -> b
unsafeCoerce Vector Float
vec') :: VS.Vector FloatImpl)
zipWith_roundedMul :: RoundingMode -> Vector Float -> Vector Float -> Vector Float
zipWith_roundedMul RoundingMode
mode Vector Float
vec Vector Float
vec' = Vector FloatImpl -> Vector Float
forall a b. a -> b
unsafeCoerce (RoundingMode
-> Vector FloatImpl -> Vector FloatImpl -> Vector FloatImpl
forall (vector :: * -> *) a.
RoundedRing_Vector vector a =>
RoundingMode -> vector a -> vector a -> vector a
zipWith_roundedMul RoundingMode
mode (Vector Float -> Vector FloatImpl
forall a b. a -> b
unsafeCoerce Vector Float
vec) (Vector Float -> Vector FloatImpl
forall a b. a -> b
unsafeCoerce Vector Float
vec') :: VS.Vector FloatImpl)
{-# INLINE roundedSum #-}
{-# INLINE zipWith_roundedAdd #-}
{-# INLINE zipWith_roundedSub #-}
{-# INLINE zipWith_roundedMul #-}
instance RoundedFractional_Vector VS.Vector Float where
zipWith_roundedDiv :: RoundingMode -> Vector Float -> Vector Float -> Vector Float
zipWith_roundedDiv RoundingMode
mode Vector Float
vec Vector Float
vec' = Vector FloatImpl -> Vector Float
forall a b. a -> b
unsafeCoerce (RoundingMode
-> Vector FloatImpl -> Vector FloatImpl -> Vector FloatImpl
forall (vector :: * -> *) a.
RoundedFractional_Vector vector a =>
RoundingMode -> vector a -> vector a -> vector a
zipWith_roundedDiv RoundingMode
mode (Vector Float -> Vector FloatImpl
forall a b. a -> b
unsafeCoerce Vector Float
vec) (Vector Float -> Vector FloatImpl
forall a b. a -> b
unsafeCoerce Vector Float
vec') :: VS.Vector FloatImpl)
{-# INLINE zipWith_roundedDiv #-}
instance RoundedSqrt_Vector VS.Vector Float where
map_roundedSqrt :: RoundingMode -> Vector Float -> Vector Float
map_roundedSqrt RoundingMode
mode Vector Float
vec = Vector FloatImpl -> Vector Float
forall a b. a -> b
unsafeCoerce (RoundingMode -> Vector FloatImpl -> Vector FloatImpl
forall (vector :: * -> *) a.
RoundedSqrt_Vector vector a =>
RoundingMode -> vector a -> vector a
map_roundedSqrt RoundingMode
mode (Vector Float -> Vector FloatImpl
forall a b. a -> b
unsafeCoerce Vector Float
vec) :: VS.Vector FloatImpl)
{-# INLINE map_roundedSqrt #-}
deriving via DoubleImpl instance RoundedRing Double
deriving via DoubleImpl instance RoundedFractional Double
deriving via DoubleImpl instance RoundedSqrt Double
deriving via DoubleImpl instance RoundedRing_Vector VU.Vector Double
deriving via DoubleImpl instance RoundedFractional_Vector VU.Vector Double
deriving via DoubleImpl instance RoundedSqrt_Vector VU.Vector Double
instance RoundedRing_Vector VS.Vector Double where
roundedSum :: RoundingMode -> Vector Double -> Double
roundedSum RoundingMode
mode Vector Double
vec = DoubleImpl -> Double
forall a b. Coercible a b => a -> b
coerce (RoundingMode -> Vector DoubleImpl -> DoubleImpl
forall (vector :: * -> *) a.
RoundedRing_Vector vector a =>
RoundingMode -> vector a -> a
roundedSum RoundingMode
mode (Vector Double -> Vector DoubleImpl
forall a b. a -> b
unsafeCoerce Vector Double
vec :: VS.Vector DoubleImpl))
zipWith_roundedAdd :: RoundingMode -> Vector Double -> Vector Double -> Vector Double
zipWith_roundedAdd RoundingMode
mode Vector Double
vec Vector Double
vec' = Vector DoubleImpl -> Vector Double
forall a b. a -> b
unsafeCoerce (RoundingMode
-> Vector DoubleImpl -> Vector DoubleImpl -> Vector DoubleImpl
forall (vector :: * -> *) a.
RoundedRing_Vector vector a =>
RoundingMode -> vector a -> vector a -> vector a
zipWith_roundedAdd RoundingMode
mode (Vector Double -> Vector DoubleImpl
forall a b. a -> b
unsafeCoerce Vector Double
vec) (Vector Double -> Vector DoubleImpl
forall a b. a -> b
unsafeCoerce Vector Double
vec') :: VS.Vector DoubleImpl)
zipWith_roundedSub :: RoundingMode -> Vector Double -> Vector Double -> Vector Double
zipWith_roundedSub RoundingMode
mode Vector Double
vec Vector Double
vec' = Vector DoubleImpl -> Vector Double
forall a b. a -> b
unsafeCoerce (RoundingMode
-> Vector DoubleImpl -> Vector DoubleImpl -> Vector DoubleImpl
forall (vector :: * -> *) a.
RoundedRing_Vector vector a =>
RoundingMode -> vector a -> vector a -> vector a
zipWith_roundedSub RoundingMode
mode (Vector Double -> Vector DoubleImpl
forall a b. a -> b
unsafeCoerce Vector Double
vec) (Vector Double -> Vector DoubleImpl
forall a b. a -> b
unsafeCoerce Vector Double
vec') :: VS.Vector DoubleImpl)
zipWith_roundedMul :: RoundingMode -> Vector Double -> Vector Double -> Vector Double
zipWith_roundedMul RoundingMode
mode Vector Double
vec Vector Double
vec' = Vector DoubleImpl -> Vector Double
forall a b. a -> b
unsafeCoerce (RoundingMode
-> Vector DoubleImpl -> Vector DoubleImpl -> Vector DoubleImpl
forall (vector :: * -> *) a.
RoundedRing_Vector vector a =>
RoundingMode -> vector a -> vector a -> vector a
zipWith_roundedMul RoundingMode
mode (Vector Double -> Vector DoubleImpl
forall a b. a -> b
unsafeCoerce Vector Double
vec) (Vector Double -> Vector DoubleImpl
forall a b. a -> b
unsafeCoerce Vector Double
vec') :: VS.Vector DoubleImpl)
{-# INLINE roundedSum #-}
{-# INLINE zipWith_roundedAdd #-}
{-# INLINE zipWith_roundedSub #-}
{-# INLINE zipWith_roundedMul #-}
instance RoundedFractional_Vector VS.Vector Double where
zipWith_roundedDiv :: RoundingMode -> Vector Double -> Vector Double -> Vector Double
zipWith_roundedDiv RoundingMode
mode Vector Double
vec Vector Double
vec' = Vector DoubleImpl -> Vector Double
forall a b. a -> b
unsafeCoerce (RoundingMode
-> Vector DoubleImpl -> Vector DoubleImpl -> Vector DoubleImpl
forall (vector :: * -> *) a.
RoundedFractional_Vector vector a =>
RoundingMode -> vector a -> vector a -> vector a
zipWith_roundedDiv RoundingMode
mode (Vector Double -> Vector DoubleImpl
forall a b. a -> b
unsafeCoerce Vector Double
vec) (Vector Double -> Vector DoubleImpl
forall a b. a -> b
unsafeCoerce Vector Double
vec') :: VS.Vector DoubleImpl)
{-# INLINE zipWith_roundedDiv #-}
instance RoundedSqrt_Vector VS.Vector Double where
map_roundedSqrt :: RoundingMode -> Vector Double -> Vector Double
map_roundedSqrt RoundingMode
mode Vector Double
vec = Vector DoubleImpl -> Vector Double
forall a b. a -> b
unsafeCoerce (RoundingMode -> Vector DoubleImpl -> Vector DoubleImpl
forall (vector :: * -> *) a.
RoundedSqrt_Vector vector a =>
RoundingMode -> vector a -> vector a
map_roundedSqrt RoundingMode
mode (Vector Double -> Vector DoubleImpl
forall a b. a -> b
unsafeCoerce Vector Double
vec) :: VS.Vector DoubleImpl)
{-# INLINE map_roundedSqrt #-}
#if !MIN_VERSION_base(4, 16, 0)
{-# RULES
"fromIntegral/a->Rounded ToNearest Float"
fromIntegral = \x -> (Rounded (fromIntegralTiesToEven x) :: Rounded 'ToNearest Float)
"fromIntegral/a->Rounded TowardInf Float"
fromIntegral = \x -> (Rounded (fromIntegralTowardPositive x) :: Rounded 'TowardInf Float)
"fromIntegral/a->Rounded TowardNegInf Float"
fromIntegral = \x -> (Rounded (fromIntegralTowardNegative x) :: Rounded 'TowardNegInf Float)
"fromIntegral/a->Rounded TowardZero Float"
fromIntegral = \x -> (Rounded (fromIntegralTowardZero x) :: Rounded 'TowardZero Float)
"fromIntegral/a->Rounded ToNearest Double"
fromIntegral = \x -> (Rounded (fromIntegralTiesToEven x) :: Rounded 'ToNearest Double)
"fromIntegral/a->Rounded TowardInf Double"
fromIntegral = \x -> (Rounded (fromIntegralTowardPositive x) :: Rounded 'TowardInf Double)
"fromIntegral/a->Rounded TowardNegInf Double"
fromIntegral = \x -> (Rounded (fromIntegralTowardNegative x) :: Rounded 'TowardNegInf Double)
"fromIntegral/a->Rounded TowardZero Double"
fromIntegral = \x -> (Rounded (fromIntegralTowardZero x) :: Rounded 'TowardZero Double)
#-}
#endif