{-# LANGUAGE BangPatterns #-}
{-# LANGUAGE FlexibleContexts #-}
{-# LANGUAGE FlexibleInstances #-}
{-# LANGUAGE MagicHash #-}
{-# LANGUAGE MultiParamTypeClasses #-}
{-# LANGUAGE NamedFieldPuns #-}
{-# LANGUAGE ScopedTypeVariables #-}
{-# LANGUAGE TypeFamilies #-}
{-# LANGUAGE UnboxedTuples #-}
{-# LANGUAGE UndecidableInstances #-}
module Data.Massiv.Array.Manifest.Primitive (
P (..),
Array (..),
MArray (..),
Prim,
toPrimitiveVector,
toPrimitiveMVector,
fromPrimitiveVector,
fromPrimitiveMVector,
toByteArray,
toByteArrayM,
unwrapByteArray,
unwrapByteArrayOffset,
unwrapMutableByteArray,
unwrapMutableByteArrayOffset,
fromByteArray,
fromByteArrayM,
fromByteArrayOffsetM,
toMutableByteArray,
toMutableByteArrayM,
fromMutableByteArrayM,
fromMutableByteArrayOffsetM,
fromMutableByteArray,
shrinkMutableByteArray,
unsafeAtomicReadIntArray,
unsafeAtomicWriteIntArray,
unsafeCasIntArray,
unsafeAtomicModifyIntArray,
unsafeAtomicAddIntArray,
unsafeAtomicSubIntArray,
unsafeAtomicAndIntArray,
unsafeAtomicNandIntArray,
unsafeAtomicOrIntArray,
unsafeAtomicXorIntArray,
) where
import Control.DeepSeq (NFData (..), deepseq)
import Control.Monad
import Control.Monad.Primitive (PrimMonad (..), primitive_)
import Data.Massiv.Array.Delayed.Pull
import Data.Massiv.Array.Manifest.Internal
import Data.Massiv.Array.Manifest.List as A
import Data.Massiv.Array.Mutable
import Data.Massiv.Core.Common
import Data.Massiv.Core.List
import Data.Massiv.Core.Operations
import Data.Massiv.Vector.Stream as S (isteps, steps)
import Data.Maybe (fromMaybe)
import Data.Primitive (Prim, sizeOf)
import Data.Primitive.ByteArray
import qualified Data.Vector.Primitive as VP
import qualified Data.Vector.Primitive.Mutable as MVP
import GHC.Exts as GHC
import System.IO.Unsafe (unsafePerformIO)
import Prelude hiding (mapM)
data P = P deriving (Int -> P -> ShowS
[P] -> ShowS
P -> String
(Int -> P -> ShowS) -> (P -> String) -> ([P] -> ShowS) -> Show P
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
$cshowsPrec :: Int -> P -> ShowS
showsPrec :: Int -> P -> ShowS
$cshow :: P -> String
show :: P -> String
$cshowList :: [P] -> ShowS
showList :: [P] -> ShowS
Show)
data instance Array P ix e = PArray
{ forall ix e. Array P ix e -> Comp
pComp :: !Comp
, forall ix e. Array P ix e -> Sz ix
pSize :: !(Sz ix)
, forall ix e. Array P ix e -> Int
pOffset :: {-# UNPACK #-} !Int
, forall ix e. Array P ix e -> ByteArray
pData :: {-# UNPACK #-} !ByteArray
}
data instance MArray s P ix e
= MPArray !(Sz ix) {-# UNPACK #-} !Int {-# UNPACK #-} !(MutableByteArray s)
instance (Ragged L ix e, Show e, Prim e) => Show (Array P ix e) where
showsPrec :: Int -> Array P ix e -> ShowS
showsPrec = (Array P ix e -> Array P ix e) -> Int -> Array P ix e -> ShowS
forall r r' ix e.
(Ragged L ix e, Load r ix e, Load r' ix e, Source r' e, Show e) =>
(Array r ix e -> Array r' ix e) -> Int -> Array r ix e -> ShowS
showsArrayPrec Array P ix e -> Array P ix e
forall a. a -> a
id
showList :: [Array P ix e] -> ShowS
showList = [Array P ix e] -> ShowS
forall arr. Show arr => [arr] -> ShowS
showArrayList
instance Index ix => NFData (Array P ix e) where
rnf :: Array P ix e -> ()
rnf (PArray Comp
c Sz ix
sz Int
o ByteArray
a) = Comp
c Comp -> () -> ()
forall a b. NFData a => a -> b -> b
`deepseq` Sz ix
sz Sz ix -> () -> ()
forall a b. NFData a => a -> b -> b
`deepseq` Int
o Int -> () -> ()
forall a b. a -> b -> b
`seq` ByteArray
a ByteArray -> () -> ()
forall a b. a -> b -> b
`seq` ()
{-# INLINE rnf #-}
instance NFData ix => NFData (MArray s P ix e) where
rnf :: MArray s P ix e -> ()
rnf (MPArray Sz ix
sz Int
_o MutableByteArray s
_mb) = Sz ix
sz Sz ix -> () -> ()
forall a b. NFData a => a -> b -> b
`deepseq` ()
{-# INLINE rnf #-}
instance (Prim e, Eq e, Index ix) => Eq (Array P ix e) where
== :: Array P ix e -> Array P ix e -> Bool
(==) = (e -> e -> Bool) -> Array P ix e -> Array P ix e -> Bool
forall ix r1 e1 r2 e2.
(Index ix, Source r1 e1, Source r2 e2) =>
(e1 -> e2 -> Bool) -> Array r1 ix e1 -> Array r2 ix e2 -> Bool
eqArrays e -> e -> Bool
forall a. Eq a => a -> a -> Bool
(==)
{-# INLINE (==) #-}
instance (Prim e, Ord e, Index ix) => Ord (Array P ix e) where
compare :: Array P ix e -> Array P ix e -> Ordering
compare = (e -> e -> Ordering) -> Array P ix e -> Array P ix e -> Ordering
forall ix r1 e1 r2 e2.
(Index ix, Source r1 e1, Source r2 e2) =>
(e1 -> e2 -> Ordering)
-> Array r1 ix e1 -> Array r2 ix e2 -> Ordering
compareArrays e -> e -> Ordering
forall a. Ord a => a -> a -> Ordering
compare
{-# INLINE compare #-}
instance Strategy P where
getComp :: forall ix e. Array P ix e -> Comp
getComp = Array P ix e -> Comp
forall ix e. Array P ix e -> Comp
pComp
{-# INLINE getComp #-}
setComp :: forall ix e. Comp -> Array P ix e -> Array P ix e
setComp Comp
c Array P ix e
arr = Array P ix e
arr{pComp = c}
{-# INLINE setComp #-}
repr :: P
repr = P
P
instance Index ix => Shape P ix where
maxLinearSize :: forall e. Array P ix e -> Maybe Sz1
maxLinearSize = Sz1 -> Maybe Sz1
forall a. a -> Maybe a
Just (Sz1 -> Maybe Sz1)
-> (Array P ix e -> Sz1) -> Array P ix e -> Maybe Sz1
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Int -> Sz1
forall ix. ix -> Sz ix
SafeSz (Int -> Sz1) -> (Array P ix e -> Int) -> Array P ix e -> Sz1
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Array P ix e -> Int
forall ix r e. (Index ix, Size r) => Array r ix e -> Int
elemsCount
{-# INLINE maxLinearSize #-}
instance Size P where
size :: forall ix e. Array P ix e -> Sz ix
size = Array P ix e -> Sz ix
forall ix e. Array P ix e -> Sz ix
pSize
{-# INLINE size #-}
unsafeResize :: forall ix ix' e.
(Index ix, Index ix') =>
Sz ix' -> Array P ix e -> Array P ix' e
unsafeResize !Sz ix'
sz !Array P ix e
arr = Array P ix e
arr{pSize = sz}
{-# INLINE unsafeResize #-}
instance Prim e => Source P e where
unsafeLinearIndex :: forall ix. Index ix => Array P ix e -> Int -> e
unsafeLinearIndex _arr :: Array P ix e
_arr@(PArray Comp
_ Sz ix
_ Int
o ByteArray
a) Int
i =
String
-> (ByteArray -> Sz1)
-> (ByteArray -> Int -> e)
-> ByteArray
-> Int
-> e
forall a ix e.
String -> (a -> Sz ix) -> (a -> ix -> e) -> a -> ix -> e
indexAssert String
"P.unsafeLinearIndex" (Int -> Sz1
forall ix. ix -> Sz ix
SafeSz (Int -> Sz1) -> (ByteArray -> Int) -> ByteArray -> Sz1
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Array P ix e -> ByteArray -> Int
forall (proxy :: * -> *) e. Prim e => proxy e -> ByteArray -> Int
elemsBA Array P ix e
_arr) ByteArray -> Int -> e
forall a. Prim a => ByteArray -> Int -> a
indexByteArray ByteArray
a (Int
i Int -> Int -> Int
forall a. Num a => a -> a -> a
+ Int
o)
{-# INLINE unsafeLinearIndex #-}
unsafeOuterSlice :: forall ix.
(Index ix, Index (Lower ix)) =>
Array P ix e -> Sz (Lower ix) -> Int -> Array P (Lower ix) e
unsafeOuterSlice (PArray Comp
c Sz ix
_ Int
o ByteArray
a) Sz (Lower ix)
szL Int
i =
Comp -> Sz (Lower ix) -> Int -> ByteArray -> Array P (Lower ix) e
forall ix e. Comp -> Sz ix -> Int -> ByteArray -> Array P ix e
PArray Comp
c Sz (Lower ix)
szL (Int
i Int -> Int -> Int
forall a. Num a => a -> a -> a
* Sz (Lower ix) -> Int
forall ix. Index ix => Sz ix -> Int
totalElem Sz (Lower ix)
szL Int -> Int -> Int
forall a. Num a => a -> a -> a
+ Int
o) ByteArray
a
{-# INLINE unsafeOuterSlice #-}
unsafeLinearSlice :: forall ix. Index ix => Int -> Sz1 -> Array P ix e -> Array P Int e
unsafeLinearSlice Int
i Sz1
k (PArray Comp
c Sz ix
_ Int
o ByteArray
a) = Comp -> Sz1 -> Int -> ByteArray -> Array P Int e
forall ix e. Comp -> Sz ix -> Int -> ByteArray -> Array P ix e
PArray Comp
c Sz1
k (Int
i Int -> Int -> Int
forall a. Num a => a -> a -> a
+ Int
o) ByteArray
a
{-# INLINE unsafeLinearSlice #-}
instance Prim e => Manifest P e where
unsafeLinearIndexM :: forall ix. Index ix => Array P ix e -> Int -> e
unsafeLinearIndexM _pa :: Array P ix e
_pa@(PArray Comp
_ Sz ix
_sz Int
o ByteArray
a) Int
i =
String
-> (ByteArray -> Sz1)
-> (ByteArray -> Int -> e)
-> ByteArray
-> Int
-> e
forall a ix e.
String -> (a -> Sz ix) -> (a -> ix -> e) -> a -> ix -> e
indexAssert String
"P.unsafeLinearIndexM" (Sz1 -> ByteArray -> Sz1
forall a b. a -> b -> a
const (Int -> Sz1
forall ix. Index ix => ix -> Sz ix
Sz (Sz ix -> Int
forall ix. Index ix => Sz ix -> Int
totalElem Sz ix
_sz))) ByteArray -> Int -> e
forall a. Prim a => ByteArray -> Int -> a
indexByteArray ByteArray
a (Int
i Int -> Int -> Int
forall a. Num a => a -> a -> a
+ Int
o)
{-# INLINE unsafeLinearIndexM #-}
sizeOfMArray :: forall ix s. Index ix => MArray s P ix e -> Sz ix
sizeOfMArray (MPArray Sz ix
sz Int
_ MutableByteArray s
_) = Sz ix
sz
{-# INLINE sizeOfMArray #-}
unsafeResizeMArray :: forall ix' ix s.
(Index ix', Index ix) =>
Sz ix' -> MArray s P ix e -> MArray s P ix' e
unsafeResizeMArray Sz ix'
sz (MPArray Sz ix
_ Int
off MutableByteArray s
marr) = Sz ix' -> Int -> MutableByteArray s -> MArray s P ix' e
forall s ix e.
Sz ix -> Int -> MutableByteArray s -> MArray s P ix e
MPArray Sz ix'
sz Int
off MutableByteArray s
marr
{-# INLINE unsafeResizeMArray #-}
unsafeLinearSliceMArray :: forall ix s.
Index ix =>
Int -> Sz1 -> MArray s P ix e -> MVector s P e
unsafeLinearSliceMArray Int
i Sz1
k (MPArray Sz ix
_ Int
o MutableByteArray s
a) = Sz1 -> Int -> MutableByteArray s -> MArray s P Int e
forall s ix e.
Sz ix -> Int -> MutableByteArray s -> MArray s P ix e
MPArray Sz1
k (Int
i Int -> Int -> Int
forall a. Num a => a -> a -> a
+ Int
o) MutableByteArray s
a
{-# INLINE unsafeLinearSliceMArray #-}
unsafeThaw :: forall ix (m :: * -> *).
(Index ix, PrimMonad m) =>
Array P ix e -> m (MArray (PrimState m) P ix e)
unsafeThaw (PArray Comp
_ Sz ix
sz Int
o ByteArray
a) = Sz ix
-> Int
-> MutableByteArray (PrimState m)
-> MArray (PrimState m) P ix e
forall s ix e.
Sz ix -> Int -> MutableByteArray s -> MArray s P ix e
MPArray Sz ix
sz Int
o (MutableByteArray (PrimState m) -> MArray (PrimState m) P ix e)
-> m (MutableByteArray (PrimState m))
-> m (MArray (PrimState m) P ix e)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> ByteArray -> m (MutableByteArray (PrimState m))
forall (m :: * -> *).
PrimMonad m =>
ByteArray -> m (MutableByteArray (PrimState m))
unsafeThawByteArray ByteArray
a
{-# INLINE unsafeThaw #-}
unsafeFreeze :: forall ix (m :: * -> *).
(Index ix, PrimMonad m) =>
Comp -> MArray (PrimState m) P ix e -> m (Array P ix e)
unsafeFreeze Comp
comp (MPArray Sz ix
sz Int
o MutableByteArray (PrimState m)
a) = Comp -> Sz ix -> Int -> ByteArray -> Array P ix e
forall ix e. Comp -> Sz ix -> Int -> ByteArray -> Array P ix e
PArray Comp
comp Sz ix
sz Int
o (ByteArray -> Array P ix e) -> m ByteArray -> m (Array P ix e)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> MutableByteArray (PrimState m) -> m ByteArray
forall (m :: * -> *).
PrimMonad m =>
MutableByteArray (PrimState m) -> m ByteArray
unsafeFreezeByteArray MutableByteArray (PrimState m)
a
{-# INLINE unsafeFreeze #-}
unsafeNew :: forall ix (m :: * -> *).
(Index ix, PrimMonad m) =>
Sz ix -> m (MArray (PrimState m) P ix e)
unsafeNew Sz ix
sz
| Int
n Int -> Int -> Bool
forall a. Ord a => a -> a -> Bool
<= (Int
forall a. Bounded a => a
maxBound :: Int) Int -> Int -> Int
forall a. Integral a => a -> a -> a
`div` Int
eSize = Sz ix
-> Int
-> MutableByteArray (PrimState m)
-> MArray (PrimState m) P ix e
forall s ix e.
Sz ix -> Int -> MutableByteArray s -> MArray s P ix e
MPArray Sz ix
sz Int
0 (MutableByteArray (PrimState m) -> MArray (PrimState m) P ix e)
-> m (MutableByteArray (PrimState m))
-> m (MArray (PrimState m) P ix e)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Int -> m (MutableByteArray (PrimState m))
forall (m :: * -> *).
PrimMonad m =>
Int -> m (MutableByteArray (PrimState m))
newByteArray (Int
n Int -> Int -> Int
forall a. Num a => a -> a -> a
* Int
eSize)
| Bool
otherwise = String -> m (MArray (PrimState m) P ix e)
forall a. HasCallStack => String -> a
error (String -> m (MArray (PrimState m) P ix e))
-> String -> m (MArray (PrimState m) P ix e)
forall a b. (a -> b) -> a -> b
$ String
"Array size is too big: " String -> ShowS
forall a. [a] -> [a] -> [a]
++ Sz ix -> String
forall a. Show a => a -> String
show Sz ix
sz
where
!n :: Int
n = Sz ix -> Int
forall ix. Index ix => Sz ix -> Int
totalElem Sz ix
sz
!eSize :: Int
eSize = e -> Int
forall a. Prim a => a -> Int
sizeOf (e
forall a. HasCallStack => a
undefined :: e)
{-# INLINE unsafeNew #-}
initialize :: forall ix (m :: * -> *).
(Index ix, PrimMonad m) =>
MArray (PrimState m) P ix e -> m ()
initialize (MPArray Sz ix
sz Int
o MutableByteArray (PrimState m)
mba) =
let k :: Int
k = Sz ix -> Int
forall ix. Index ix => Sz ix -> Int
totalElem Sz ix
sz Int -> Int -> Int
forall a. Num a => a -> a -> a
* e -> Int
forall a. Prim a => a -> Int
sizeOf (e
forall a. HasCallStack => a
undefined :: e)
in Bool -> m () -> m ()
forall (f :: * -> *). Applicative f => Bool -> f () -> f ()
when (Int
k Int -> Int -> Bool
forall a. Ord a => a -> a -> Bool
> Int
0) (m () -> m ()) -> m () -> m ()
forall a b. (a -> b) -> a -> b
$ MutableByteArray (PrimState m) -> Int -> Int -> Word8 -> m ()
forall (m :: * -> *).
PrimMonad m =>
MutableByteArray (PrimState m) -> Int -> Int -> Word8 -> m ()
fillByteArray MutableByteArray (PrimState m)
mba Int
o Int
k Word8
0
{-# INLINE initialize #-}
unsafeLinearRead :: forall ix (m :: * -> *).
(Index ix, PrimMonad m) =>
MArray (PrimState m) P ix e -> Int -> m e
unsafeLinearRead _mpa :: MArray (PrimState m) P ix e
_mpa@(MPArray Sz ix
_sz Int
o MutableByteArray (PrimState m)
ma) Int
i =
String
-> (MutableByteArray (PrimState m) -> Sz1)
-> (MutableByteArray (PrimState m) -> Int -> m e)
-> MutableByteArray (PrimState m)
-> Int
-> m e
forall a ix e.
String -> (a -> Sz ix) -> (a -> ix -> e) -> a -> ix -> e
indexAssert String
"P.unsafeLinearRead" (Sz1 -> MutableByteArray (PrimState m) -> Sz1
forall a b. a -> b -> a
const (Int -> Sz1
forall ix. Index ix => ix -> Sz ix
Sz (Sz ix -> Int
forall ix. Index ix => Sz ix -> Int
totalElem Sz ix
_sz))) MutableByteArray (PrimState m) -> Int -> m e
forall a (m :: * -> *).
(Prim a, PrimMonad m) =>
MutableByteArray (PrimState m) -> Int -> m a
readByteArray MutableByteArray (PrimState m)
ma (Int
i Int -> Int -> Int
forall a. Num a => a -> a -> a
+ Int
o)
{-# INLINE unsafeLinearRead #-}
unsafeLinearWrite :: forall ix (m :: * -> *).
(Index ix, PrimMonad m) =>
MArray (PrimState m) P ix e -> Int -> e -> m ()
unsafeLinearWrite _mpa :: MArray (PrimState m) P ix e
_mpa@(MPArray Sz ix
_sz Int
o MutableByteArray (PrimState m)
ma) Int
i =
String
-> (MutableByteArray (PrimState m) -> Sz1)
-> (MutableByteArray (PrimState m) -> Int -> e -> m ())
-> MutableByteArray (PrimState m)
-> Int
-> e
-> m ()
forall a ix e.
String -> (a -> Sz ix) -> (a -> ix -> e) -> a -> ix -> e
indexAssert String
"P.unsafeLinearWrite" (Sz1 -> MutableByteArray (PrimState m) -> Sz1
forall a b. a -> b -> a
const (Int -> Sz1
forall ix. Index ix => ix -> Sz ix
Sz (Sz ix -> Int
forall ix. Index ix => Sz ix -> Int
totalElem Sz ix
_sz))) MutableByteArray (PrimState m) -> Int -> e -> m ()
forall a (m :: * -> *).
(Prim a, PrimMonad m) =>
MutableByteArray (PrimState m) -> Int -> a -> m ()
writeByteArray MutableByteArray (PrimState m)
ma (Int
i Int -> Int -> Int
forall a. Num a => a -> a -> a
+ Int
o)
{-# INLINE unsafeLinearWrite #-}
unsafeLinearSet :: forall ix (m :: * -> *).
(Index ix, PrimMonad m) =>
MArray (PrimState m) P ix e -> Int -> Sz1 -> e -> m ()
unsafeLinearSet (MPArray Sz ix
_ Int
o MutableByteArray (PrimState m)
ma) Int
offset (SafeSz Int
sz) = MutableByteArray (PrimState m) -> Int -> Int -> e -> m ()
forall a (m :: * -> *).
(Prim a, PrimMonad m) =>
MutableByteArray (PrimState m) -> Int -> Int -> a -> m ()
setByteArray MutableByteArray (PrimState m)
ma (Int
offset Int -> Int -> Int
forall a. Num a => a -> a -> a
+ Int
o) Int
sz
{-# INLINE unsafeLinearSet #-}
unsafeLinearCopy :: forall ix' ix (m :: * -> *).
(Index ix', Index ix, PrimMonad m) =>
MArray (PrimState m) P ix' e
-> Int -> MArray (PrimState m) P ix e -> Int -> Sz1 -> m ()
unsafeLinearCopy (MPArray Sz ix'
_ Int
oFrom MutableByteArray (PrimState m)
maFrom) Int
iFrom (MPArray Sz ix
_ Int
oTo MutableByteArray (PrimState m)
maTo) Int
iTo (Sz Int
k) =
MutableByteArray (PrimState m)
-> Int -> MutableByteArray (PrimState m) -> Int -> Int -> m ()
forall (m :: * -> *).
PrimMonad m =>
MutableByteArray (PrimState m)
-> Int -> MutableByteArray (PrimState m) -> Int -> Int -> m ()
copyMutableByteArray MutableByteArray (PrimState m)
maTo ((Int
oTo Int -> Int -> Int
forall a. Num a => a -> a -> a
+ Int
iTo) Int -> Int -> Int
forall a. Num a => a -> a -> a
* Int
esz) MutableByteArray (PrimState m)
maFrom ((Int
oFrom Int -> Int -> Int
forall a. Num a => a -> a -> a
+ Int
iFrom) Int -> Int -> Int
forall a. Num a => a -> a -> a
* Int
esz) (Int
k Int -> Int -> Int
forall a. Num a => a -> a -> a
* Int
esz)
where
esz :: Int
esz = e -> Int
forall a. Prim a => a -> Int
sizeOf (e
forall a. HasCallStack => a
undefined :: e)
{-# INLINE unsafeLinearCopy #-}
unsafeArrayLinearCopy :: forall ix' ix (m :: * -> *).
(Index ix', Index ix, PrimMonad m) =>
Array P ix' e
-> Int -> MArray (PrimState m) P ix e -> Int -> Sz1 -> m ()
unsafeArrayLinearCopy (PArray Comp
_ Sz ix'
_ Int
oFrom ByteArray
aFrom) Int
iFrom (MPArray Sz ix
_ Int
oTo MutableByteArray (PrimState m)
maTo) Int
iTo (Sz Int
k) =
MutableByteArray (PrimState m)
-> Int -> ByteArray -> Int -> Int -> m ()
forall (m :: * -> *).
PrimMonad m =>
MutableByteArray (PrimState m)
-> Int -> ByteArray -> Int -> Int -> m ()
copyByteArray MutableByteArray (PrimState m)
maTo ((Int
oTo Int -> Int -> Int
forall a. Num a => a -> a -> a
+ Int
iTo) Int -> Int -> Int
forall a. Num a => a -> a -> a
* Int
esz) ByteArray
aFrom ((Int
oFrom Int -> Int -> Int
forall a. Num a => a -> a -> a
+ Int
iFrom) Int -> Int -> Int
forall a. Num a => a -> a -> a
* Int
esz) (Int
k Int -> Int -> Int
forall a. Num a => a -> a -> a
* Int
esz)
where
esz :: Int
esz = e -> Int
forall a. Prim a => a -> Int
sizeOf (e
forall a. HasCallStack => a
undefined :: e)
{-# INLINE unsafeArrayLinearCopy #-}
unsafeLinearShrink :: forall ix (m :: * -> *).
(Index ix, PrimMonad m) =>
MArray (PrimState m) P ix e
-> Sz ix -> m (MArray (PrimState m) P ix e)
unsafeLinearShrink (MPArray Sz ix
_ Int
o MutableByteArray (PrimState m)
ma) Sz ix
sz = do
MutableByteArray (PrimState m) -> Int -> m ()
forall (m :: * -> *).
PrimMonad m =>
MutableByteArray (PrimState m) -> Int -> m ()
shrinkMutableByteArray MutableByteArray (PrimState m)
ma ((Int
o Int -> Int -> Int
forall a. Num a => a -> a -> a
+ Sz ix -> Int
forall ix. Index ix => Sz ix -> Int
totalElem Sz ix
sz) Int -> Int -> Int
forall a. Num a => a -> a -> a
* e -> Int
forall a. Prim a => a -> Int
sizeOf (e
forall a. HasCallStack => a
undefined :: e))
MArray (PrimState m) P ix e -> m (MArray (PrimState m) P ix e)
forall a. a -> m a
forall (f :: * -> *) a. Applicative f => a -> f a
pure (MArray (PrimState m) P ix e -> m (MArray (PrimState m) P ix e))
-> MArray (PrimState m) P ix e -> m (MArray (PrimState m) P ix e)
forall a b. (a -> b) -> a -> b
$ Sz ix
-> Int
-> MutableByteArray (PrimState m)
-> MArray (PrimState m) P ix e
forall s ix e.
Sz ix -> Int -> MutableByteArray s -> MArray s P ix e
MPArray Sz ix
sz Int
o MutableByteArray (PrimState m)
ma
{-# INLINE unsafeLinearShrink #-}
unsafeLinearGrow :: forall ix (m :: * -> *).
(Index ix, PrimMonad m) =>
MArray (PrimState m) P ix e
-> Sz ix -> m (MArray (PrimState m) P ix e)
unsafeLinearGrow (MPArray Sz ix
_ Int
o MutableByteArray (PrimState m)
ma) Sz ix
sz =
Sz ix
-> Int
-> MutableByteArray (PrimState m)
-> MArray (PrimState m) P ix e
forall s ix e.
Sz ix -> Int -> MutableByteArray s -> MArray s P ix e
MPArray Sz ix
sz Int
o (MutableByteArray (PrimState m) -> MArray (PrimState m) P ix e)
-> m (MutableByteArray (PrimState m))
-> m (MArray (PrimState m) P ix e)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> MutableByteArray (PrimState m)
-> Int -> m (MutableByteArray (PrimState m))
forall (m :: * -> *).
PrimMonad m =>
MutableByteArray (PrimState m)
-> Int -> m (MutableByteArray (PrimState m))
resizeMutableByteArray MutableByteArray (PrimState m)
ma ((Int
o Int -> Int -> Int
forall a. Num a => a -> a -> a
+ Sz ix -> Int
forall ix. Index ix => Sz ix -> Int
totalElem Sz ix
sz) Int -> Int -> Int
forall a. Num a => a -> a -> a
* e -> Int
forall a. Prim a => a -> Int
sizeOf (e
forall a. HasCallStack => a
undefined :: e))
{-# INLINE unsafeLinearGrow #-}
instance (Prim e, Index ix) => Load P ix e where
makeArray :: Comp -> Sz ix -> (ix -> e) -> Array P ix e
makeArray Comp
comp Sz ix
sz ix -> e
f = Array D ix e -> Array P ix e
forall r ix e r'.
(Manifest r e, Load r' ix e) =>
Array r' ix e -> Array r ix e
compute (Comp -> Sz ix -> (ix -> e) -> Array D ix e
forall r ix e.
Load r ix e =>
Comp -> Sz ix -> (ix -> e) -> Array r ix e
makeArray Comp
comp Sz ix
sz ix -> e
f :: Array D ix e)
{-# INLINE makeArray #-}
makeArrayLinear :: Comp -> Sz ix -> (Int -> e) -> Array P ix e
makeArrayLinear !Comp
comp !Sz ix
sz Int -> e
f = IO (Array P ix e) -> Array P ix e
forall a. IO a -> a
unsafePerformIO (IO (Array P ix e) -> Array P ix e)
-> IO (Array P ix e) -> Array P ix e
forall a b. (a -> b) -> a -> b
$ Comp -> Sz ix -> (Int -> IO e) -> IO (Array P ix e)
forall r ix e (m :: * -> *).
(MonadUnliftIO m, Manifest r e, Index ix) =>
Comp -> Sz ix -> (Int -> m e) -> m (Array r ix e)
generateArrayLinear Comp
comp Sz ix
sz (e -> IO e
forall a. a -> IO a
forall (f :: * -> *) a. Applicative f => a -> f a
pure (e -> IO e) -> (Int -> e) -> Int -> IO e
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Int -> e
f)
{-# INLINE makeArrayLinear #-}
replicate :: Comp -> Sz ix -> e -> Array P ix e
replicate Comp
comp !Sz ix
sz !e
e = (forall s. ST s (Array P ix e)) -> Array P ix e
forall a. (forall s. ST s a) -> a
runST (Sz ix -> e -> ST s (MArray (PrimState (ST s)) P ix e)
forall r e ix (m :: * -> *).
(Manifest r e, Index ix, PrimMonad m) =>
Sz ix -> e -> m (MArray (PrimState m) r ix e)
forall ix (m :: * -> *).
(Index ix, PrimMonad m) =>
Sz ix -> e -> m (MArray (PrimState m) P ix e)
newMArray Sz ix
sz e
e ST s (MArray s P ix e)
-> (MArray s P ix e -> ST s (Array P ix e)) -> ST s (Array P ix e)
forall a b. ST s a -> (a -> ST s b) -> ST s b
forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
>>= Comp -> MArray (PrimState (ST s)) P ix e -> ST s (Array P ix e)
forall r e ix (m :: * -> *).
(Manifest r e, Index ix, PrimMonad m) =>
Comp -> MArray (PrimState m) r ix e -> m (Array r ix e)
forall ix (m :: * -> *).
(Index ix, PrimMonad m) =>
Comp -> MArray (PrimState m) P ix e -> m (Array P ix e)
unsafeFreeze Comp
comp)
{-# INLINE replicate #-}
iterArrayLinearST_ :: forall s.
Scheduler s () -> Array P ix e -> (Int -> e -> ST s ()) -> ST s ()
iterArrayLinearST_ !Scheduler s ()
scheduler !Array P ix e
arr =
Scheduler s ()
-> Int -> (Int -> e) -> (Int -> e -> ST s ()) -> ST s ()
forall s (m :: * -> *) b.
MonadPrimBase s m =>
Scheduler s () -> Int -> (Int -> b) -> (Int -> b -> m ()) -> m ()
splitLinearlyWith_ Scheduler s ()
scheduler (Array P ix e -> Int
forall ix r e. (Index ix, Size r) => Array r ix e -> Int
elemsCount Array P ix e
arr) (Array P ix e -> Int -> e
forall ix. Index ix => Array P ix e -> Int -> e
forall r e ix. (Source r e, Index ix) => Array r ix e -> Int -> e
unsafeLinearIndex Array P ix e
arr)
{-# INLINE iterArrayLinearST_ #-}
instance (Prim e, Index ix) => StrideLoad P ix e
instance (Prim e, Index ix) => Stream P ix e where
toStream :: Array P ix e -> Steps Id e
toStream = Array P ix e -> Steps Id e
forall r ix e (m :: * -> *).
(Monad m, Index ix, Source r e) =>
Array r ix e -> Steps m e
S.steps
{-# INLINE toStream #-}
toStreamIx :: Array P ix e -> Steps Id (ix, e)
toStreamIx = Array P ix e -> Steps Id (ix, e)
forall r ix e (m :: * -> *).
(Monad m, Index ix, Source r e) =>
Array r ix e -> Steps m (ix, e)
S.isteps
{-# INLINE toStreamIx #-}
instance (Prim e, Num e) => FoldNumeric P e where
unsafeDotProduct :: forall ix. Index ix => Array P ix e -> Array P ix e -> e
unsafeDotProduct = Array P ix e -> Array P ix e -> e
forall e ix r.
(Num e, Index ix, Source r e) =>
Array r ix e -> Array r ix e -> e
defaultUnsafeDotProduct
{-# INLINE unsafeDotProduct #-}
powerSumArray :: forall ix. Index ix => Array P ix e -> Int -> e
powerSumArray = Array P ix e -> Int -> e
forall ix r e.
(Index ix, Source r e, Num e) =>
Array r ix e -> Int -> e
defaultPowerSumArray
{-# INLINE powerSumArray #-}
foldArray :: forall ix. Index ix => (e -> e -> e) -> e -> Array P ix e -> e
foldArray = (e -> e -> e) -> e -> Array P ix e -> e
forall ix r e.
(Index ix, Source r e) =>
(e -> e -> e) -> e -> Array r ix e -> e
defaultFoldArray
{-# INLINE foldArray #-}
instance (Prim e, Num e) => Numeric P e where
unsafeLiftArray :: forall ix. Index ix => (e -> e) -> Array P ix e -> Array P ix e
unsafeLiftArray = (e -> e) -> Array P ix e -> Array P ix e
forall r ix e.
(Load r ix e, Source r e) =>
(e -> e) -> Array r ix e -> Array r ix e
defaultUnsafeLiftArray
{-# INLINE unsafeLiftArray #-}
unsafeLiftArray2 :: forall ix.
Index ix =>
(e -> e -> e) -> Array P ix e -> Array P ix e -> Array P ix e
unsafeLiftArray2 = (e -> e -> e) -> Array P ix e -> Array P ix e -> Array P ix e
forall r ix e.
(Load r ix e, Source r e) =>
(e -> e -> e) -> Array r ix e -> Array r ix e -> Array r ix e
defaultUnsafeLiftArray2
{-# INLINE unsafeLiftArray2 #-}
instance (Prim e, Floating e) => NumericFloat P e
instance (Prim e, IsList (Array L ix e), Ragged L ix e) => IsList (Array P ix e) where
type Item (Array P ix e) = Item (Array L ix e)
fromList :: [Item (Array P ix e)] -> Array P ix e
fromList = Comp -> [ListItem ix e] -> Array P ix e
forall r ix e.
(HasCallStack, Ragged L ix e, Manifest r e) =>
Comp -> [ListItem ix e] -> Array r ix e
A.fromLists' Comp
Seq
{-# INLINE fromList #-}
toList :: Array P ix e -> [Item (Array P ix e)]
toList = Array L ix e -> [Item (Array L ix e)]
Array L ix e -> [ListItem ix e]
forall l. IsList l => l -> [Item l]
GHC.toList (Array L ix e -> [ListItem ix e])
-> (Array P ix e -> Array L ix e)
-> Array P ix e
-> [ListItem ix e]
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Array P ix e -> Array L ix e
forall ix e r.
(Ragged L ix e, Shape r ix, Source r e) =>
Array r ix e -> Array L ix e
toListArray
{-# INLINE toList #-}
elemsBA :: forall proxy e. Prim e => proxy e -> ByteArray -> Int
elemsBA :: forall (proxy :: * -> *) e. Prim e => proxy e -> ByteArray -> Int
elemsBA proxy e
_ ByteArray
a = ByteArray -> Int
sizeofByteArray ByteArray
a Int -> Int -> Int
forall a. Integral a => a -> a -> a
`div` e -> Int
forall a. Prim a => a -> Int
sizeOf (e
forall a. HasCallStack => a
undefined :: e)
{-# INLINE elemsBA #-}
elemsMBA :: forall proxy e s. Prim e => proxy e -> MutableByteArray s -> Int
elemsMBA :: forall (proxy :: * -> *) e s.
Prim e =>
proxy e -> MutableByteArray s -> Int
elemsMBA proxy e
_ MutableByteArray s
a = MutableByteArray s -> Int
forall s. MutableByteArray s -> Int
sizeofMutableByteArray MutableByteArray s
a Int -> Int -> Int
forall a. Integral a => a -> a -> a
`div` e -> Int
forall a. Prim a => a -> Int
sizeOf (e
forall a. HasCallStack => a
undefined :: e)
{-# INLINE elemsMBA #-}
toByteArray :: (Index ix, Prim e) => Array P ix e -> ByteArray
toByteArray :: forall ix e. (Index ix, Prim e) => Array P ix e -> ByteArray
toByteArray Array P ix e
arr = ByteArray -> Maybe ByteArray -> ByteArray
forall a. a -> Maybe a -> a
fromMaybe (Array P ix e -> ByteArray
forall ix e. Array P ix e -> ByteArray
unwrapByteArray (Array P ix e -> ByteArray) -> Array P ix e -> ByteArray
forall a b. (a -> b) -> a -> b
$ Array P ix e -> Array P ix e
forall r e ix.
(Manifest r e, Index ix) =>
Array r ix e -> Array r ix e
clone Array P ix e
arr) (Maybe ByteArray -> ByteArray) -> Maybe ByteArray -> ByteArray
forall a b. (a -> b) -> a -> b
$ Array P ix e -> Maybe ByteArray
forall e ix (m :: * -> *).
(Prim e, Index ix, MonadThrow m) =>
Array P ix e -> m ByteArray
toByteArrayM Array P ix e
arr
{-# INLINE toByteArray #-}
unwrapByteArray :: Array P ix e -> ByteArray
unwrapByteArray :: forall ix e. Array P ix e -> ByteArray
unwrapByteArray = Array P ix e -> ByteArray
forall ix e. Array P ix e -> ByteArray
pData
{-# INLINE unwrapByteArray #-}
unwrapByteArrayOffset :: Array P ix e -> Int
unwrapByteArrayOffset :: forall ix e. Array P ix e -> Int
unwrapByteArrayOffset = Array P ix e -> Int
forall ix e. Array P ix e -> Int
pOffset
{-# INLINE unwrapByteArrayOffset #-}
toByteArrayM :: (Prim e, Index ix, MonadThrow m) => Array P ix e -> m ByteArray
toByteArrayM :: forall e ix (m :: * -> *).
(Prim e, Index ix, MonadThrow m) =>
Array P ix e -> m ByteArray
toByteArrayM arr :: Array P ix e
arr@PArray{Sz ix
pSize :: forall ix e. Array P ix e -> Sz ix
pSize :: Sz ix
pSize, ByteArray
pData :: forall ix e. Array P ix e -> ByteArray
pData :: ByteArray
pData} = do
ByteArray
pData ByteArray -> m () -> m ByteArray
forall a b. a -> m b -> m a
forall (f :: * -> *) a b. Functor f => a -> f b -> f a
<$ Sz ix -> Sz1 -> m ()
forall (m :: * -> *) ix ix'.
(MonadThrow m, Index ix, Index ix') =>
Sz ix -> Sz ix' -> m ()
guardNumberOfElements Sz ix
pSize (Int -> Sz1
forall ix. Index ix => ix -> Sz ix
Sz (Array P ix e -> ByteArray -> Int
forall (proxy :: * -> *) e. Prim e => proxy e -> ByteArray -> Int
elemsBA Array P ix e
arr ByteArray
pData))
{-# INLINE toByteArrayM #-}
fromByteArrayM :: (MonadThrow m, Index ix, Prim e) => Comp -> Sz ix -> ByteArray -> m (Array P ix e)
fromByteArrayM :: forall (m :: * -> *) ix e.
(MonadThrow m, Index ix, Prim e) =>
Comp -> Sz ix -> ByteArray -> m (Array P ix e)
fromByteArrayM Comp
comp Sz ix
sz = Comp -> Sz ix -> Int -> ByteArray -> m (Array P ix e)
forall (m :: * -> *) ix e.
(MonadThrow m, Index ix, Prim e) =>
Comp -> Sz ix -> Int -> ByteArray -> m (Array P ix e)
fromByteArrayOffsetM Comp
comp Sz ix
sz Int
0
{-# INLINE fromByteArrayM #-}
fromByteArrayOffsetM
:: (MonadThrow m, Index ix, Prim e) => Comp -> Sz ix -> Int -> ByteArray -> m (Array P ix e)
fromByteArrayOffsetM :: forall (m :: * -> *) ix e.
(MonadThrow m, Index ix, Prim e) =>
Comp -> Sz ix -> Int -> ByteArray -> m (Array P ix e)
fromByteArrayOffsetM Comp
comp Sz ix
sz Int
off ByteArray
ba =
Array P ix e
arr Array P ix e -> m () -> m (Array P ix e)
forall a b. a -> m b -> m a
forall (f :: * -> *) a b. Functor f => a -> f b -> f a
<$ Sz ix -> Sz1 -> m ()
forall (m :: * -> *) ix ix'.
(MonadThrow m, Index ix, Index ix') =>
Sz ix -> Sz ix' -> m ()
guardNumberOfElements Sz ix
sz (Int -> Sz1
forall ix. ix -> Sz ix
SafeSz (Array P ix e -> ByteArray -> Int
forall (proxy :: * -> *) e. Prim e => proxy e -> ByteArray -> Int
elemsBA Array P ix e
arr ByteArray
ba Int -> Int -> Int
forall a. Num a => a -> a -> a
- Int
off))
where
arr :: Array P ix e
arr = Comp -> Sz ix -> Int -> ByteArray -> Array P ix e
forall ix e. Comp -> Sz ix -> Int -> ByteArray -> Array P ix e
PArray Comp
comp Sz ix
sz Int
off ByteArray
ba
{-# INLINE fromByteArrayOffsetM #-}
fromByteArray :: forall e. Prim e => Comp -> ByteArray -> Array P Ix1 e
fromByteArray :: forall e. Prim e => Comp -> ByteArray -> Array P Int e
fromByteArray Comp
comp ByteArray
ba = Comp -> Sz1 -> Int -> ByteArray -> Array P Int e
forall ix e. Comp -> Sz ix -> Int -> ByteArray -> Array P ix e
PArray Comp
comp (Int -> Sz1
forall ix. ix -> Sz ix
SafeSz (Proxy e -> ByteArray -> Int
forall (proxy :: * -> *) e. Prim e => proxy e -> ByteArray -> Int
elemsBA (Proxy e
forall {k} (t :: k). Proxy t
Proxy :: Proxy e) ByteArray
ba)) Int
0 ByteArray
ba
{-# INLINE fromByteArray #-}
unwrapMutableByteArray :: MArray s P ix e -> MutableByteArray s
unwrapMutableByteArray :: forall s ix e. MArray s P ix e -> MutableByteArray s
unwrapMutableByteArray (MPArray Sz ix
_ Int
_ MutableByteArray s
mba) = MutableByteArray s
mba
{-# INLINE unwrapMutableByteArray #-}
unwrapMutableByteArrayOffset :: MArray s P ix e -> Int
unwrapMutableByteArrayOffset :: forall s ix e. MArray s P ix e -> Int
unwrapMutableByteArrayOffset (MPArray Sz ix
_ Int
off MutableByteArray s
_) = Int
off
{-# INLINE unwrapMutableByteArrayOffset #-}
toMutableByteArray
:: forall ix e m
. (Prim e, Index ix, PrimMonad m)
=> MArray (PrimState m) P ix e
-> m (Bool, MutableByteArray (PrimState m))
toMutableByteArray :: forall ix e (m :: * -> *).
(Prim e, Index ix, PrimMonad m) =>
MArray (PrimState m) P ix e
-> m (Bool, MutableByteArray (PrimState m))
toMutableByteArray marr :: MArray (PrimState m) P ix e
marr@(MPArray Sz ix
sz Int
offset MutableByteArray (PrimState m)
mbas) =
case MArray (PrimState m) P ix e
-> Maybe (MutableByteArray (PrimState m))
forall ix e (m :: * -> *) s.
(Index ix, Prim e, MonadThrow m) =>
MArray s P ix e -> m (MutableByteArray s)
toMutableByteArrayM MArray (PrimState m) P ix e
marr of
Just MutableByteArray (PrimState m)
mba -> (Bool, MutableByteArray (PrimState m))
-> m (Bool, MutableByteArray (PrimState m))
forall a. a -> m a
forall (f :: * -> *) a. Applicative f => a -> f a
pure (Bool
True, MutableByteArray (PrimState m)
mba)
Maybe (MutableByteArray (PrimState m))
Nothing -> do
let eSize :: Int
eSize = e -> Int
forall a. Prim a => a -> Int
sizeOf (e
forall a. HasCallStack => a
undefined :: e)
szBytes :: Int
szBytes = Sz ix -> Int
forall ix. Index ix => Sz ix -> Int
totalElem Sz ix
sz Int -> Int -> Int
forall a. Num a => a -> a -> a
* Int
eSize
MutableByteArray (PrimState m)
mbad <- Int -> m (MutableByteArray (PrimState m))
forall (m :: * -> *).
PrimMonad m =>
Int -> m (MutableByteArray (PrimState m))
newPinnedByteArray Int
szBytes
MutableByteArray (PrimState m)
-> Int -> MutableByteArray (PrimState m) -> Int -> Int -> m ()
forall (m :: * -> *).
PrimMonad m =>
MutableByteArray (PrimState m)
-> Int -> MutableByteArray (PrimState m) -> Int -> Int -> m ()
copyMutableByteArray MutableByteArray (PrimState m)
mbad Int
0 MutableByteArray (PrimState m)
mbas (Int
offset Int -> Int -> Int
forall a. Num a => a -> a -> a
* Int
eSize) Int
szBytes
(Bool, MutableByteArray (PrimState m))
-> m (Bool, MutableByteArray (PrimState m))
forall a. a -> m a
forall (f :: * -> *) a. Applicative f => a -> f a
pure (Bool
False, MutableByteArray (PrimState m)
mbad)
{-# INLINE toMutableByteArray #-}
toMutableByteArrayM :: (Index ix, Prim e, MonadThrow m) => MArray s P ix e -> m (MutableByteArray s)
toMutableByteArrayM :: forall ix e (m :: * -> *) s.
(Index ix, Prim e, MonadThrow m) =>
MArray s P ix e -> m (MutableByteArray s)
toMutableByteArrayM marr :: MArray s P ix e
marr@(MPArray Sz ix
sz Int
_ MutableByteArray s
mba) =
MutableByteArray s
mba MutableByteArray s -> m () -> m (MutableByteArray s)
forall a b. a -> m b -> m a
forall (f :: * -> *) a b. Functor f => a -> f b -> f a
<$ Sz ix -> Sz1 -> m ()
forall (m :: * -> *) ix ix'.
(MonadThrow m, Index ix, Index ix') =>
Sz ix -> Sz ix' -> m ()
guardNumberOfElements Sz ix
sz (Int -> Sz1
forall ix. Index ix => ix -> Sz ix
Sz (MArray s P ix e -> MutableByteArray s -> Int
forall (proxy :: * -> *) e s.
Prim e =>
proxy e -> MutableByteArray s -> Int
elemsMBA MArray s P ix e
marr MutableByteArray s
mba))
{-# INLINE toMutableByteArrayM #-}
fromMutableByteArrayM
:: (MonadThrow m, Index ix, Prim e) => Sz ix -> MutableByteArray s -> m (MArray s P ix e)
fromMutableByteArrayM :: forall (m :: * -> *) ix e s.
(MonadThrow m, Index ix, Prim e) =>
Sz ix -> MutableByteArray s -> m (MArray s P ix e)
fromMutableByteArrayM Sz ix
sz = Sz ix -> Int -> MutableByteArray s -> m (MArray s P ix e)
forall (m :: * -> *) ix e s.
(MonadThrow m, Index ix, Prim e) =>
Sz ix -> Int -> MutableByteArray s -> m (MArray s P ix e)
fromMutableByteArrayOffsetM Sz ix
sz Int
0
{-# INLINE fromMutableByteArrayM #-}
fromMutableByteArrayOffsetM
:: (MonadThrow m, Index ix, Prim e) => Sz ix -> Ix1 -> MutableByteArray s -> m (MArray s P ix e)
fromMutableByteArrayOffsetM :: forall (m :: * -> *) ix e s.
(MonadThrow m, Index ix, Prim e) =>
Sz ix -> Int -> MutableByteArray s -> m (MArray s P ix e)
fromMutableByteArrayOffsetM Sz ix
sz Int
off MutableByteArray s
mba =
MArray s P ix e
marr MArray s P ix e -> m () -> m (MArray s P ix e)
forall a b. a -> m b -> m a
forall (f :: * -> *) a b. Functor f => a -> f b -> f a
<$ Sz ix -> Sz1 -> m ()
forall (m :: * -> *) ix ix'.
(MonadThrow m, Index ix, Index ix') =>
Sz ix -> Sz ix' -> m ()
guardNumberOfElements Sz ix
sz (Int -> Sz1
forall ix. ix -> Sz ix
SafeSz (MArray s P ix e -> MutableByteArray s -> Int
forall (proxy :: * -> *) e s.
Prim e =>
proxy e -> MutableByteArray s -> Int
elemsMBA MArray s P ix e
marr MutableByteArray s
mba Int -> Int -> Int
forall a. Num a => a -> a -> a
- Int
off))
where
marr :: MArray s P ix e
marr = Sz ix -> Int -> MutableByteArray s -> MArray s P ix e
forall s ix e.
Sz ix -> Int -> MutableByteArray s -> MArray s P ix e
MPArray Sz ix
sz Int
off MutableByteArray s
mba
{-# INLINE fromMutableByteArrayOffsetM #-}
fromMutableByteArray :: forall e s. Prim e => MutableByteArray s -> MArray s P Ix1 e
fromMutableByteArray :: forall e s. Prim e => MutableByteArray s -> MArray s P Int e
fromMutableByteArray MutableByteArray s
mba = Sz1 -> Int -> MutableByteArray s -> MArray s P Int e
forall s ix e.
Sz ix -> Int -> MutableByteArray s -> MArray s P ix e
MPArray (Int -> Sz1
forall ix. ix -> Sz ix
SafeSz (Proxy e -> MutableByteArray s -> Int
forall (proxy :: * -> *) e s.
Prim e =>
proxy e -> MutableByteArray s -> Int
elemsMBA (Proxy e
forall {k} (t :: k). Proxy t
Proxy :: Proxy e) MutableByteArray s
mba)) Int
0 MutableByteArray s
mba
{-# INLINE fromMutableByteArray #-}
toPrimitiveVector :: Index ix => Array P ix e -> VP.Vector e
toPrimitiveVector :: forall ix e. Index ix => Array P ix e -> Vector e
toPrimitiveVector PArray{Sz ix
pSize :: forall ix e. Array P ix e -> Sz ix
pSize :: Sz ix
pSize, Int
pOffset :: forall ix e. Array P ix e -> Int
pOffset :: Int
pOffset, ByteArray
pData :: forall ix e. Array P ix e -> ByteArray
pData :: ByteArray
pData} = Int -> Int -> ByteArray -> Vector e
forall a. Int -> Int -> ByteArray -> Vector a
VP.Vector Int
pOffset (Sz ix -> Int
forall ix. Index ix => Sz ix -> Int
totalElem Sz ix
pSize) ByteArray
pData
{-# INLINE toPrimitiveVector #-}
toPrimitiveMVector :: Index ix => MArray s P ix e -> MVP.MVector s e
toPrimitiveMVector :: forall ix s e. Index ix => MArray s P ix e -> MVector s e
toPrimitiveMVector (MPArray Sz ix
sz Int
offset MutableByteArray s
mba) = Int -> Int -> MutableByteArray s -> MVector s e
forall s a. Int -> Int -> MutableByteArray s -> MVector s a
MVP.MVector Int
offset (Sz ix -> Int
forall ix. Index ix => Sz ix -> Int
totalElem Sz ix
sz) MutableByteArray s
mba
{-# INLINE toPrimitiveMVector #-}
fromPrimitiveVector :: VP.Vector e -> Array P Ix1 e
fromPrimitiveVector :: forall e. Vector e -> Array P Int e
fromPrimitiveVector (VP.Vector Int
offset Int
len ByteArray
ba) =
PArray{pComp :: Comp
pComp = Comp
Seq, pSize :: Sz1
pSize = Int -> Sz1
forall ix. ix -> Sz ix
SafeSz Int
len, pOffset :: Int
pOffset = Int
offset, pData :: ByteArray
pData = ByteArray
ba}
{-# INLINE fromPrimitiveVector #-}
fromPrimitiveMVector :: MVP.MVector s e -> MArray s P Ix1 e
fromPrimitiveMVector :: forall s e. MVector s e -> MArray s P Int e
fromPrimitiveMVector (MVP.MVector Int
offset Int
len MutableByteArray s
mba) = Sz1 -> Int -> MutableByteArray s -> MArray s P Int e
forall s ix e.
Sz ix -> Int -> MutableByteArray s -> MArray s P ix e
MPArray (Int -> Sz1
forall ix. ix -> Sz ix
SafeSz Int
len) Int
offset MutableByteArray s
mba
{-# INLINE fromPrimitiveMVector #-}
unsafeAtomicReadIntArray
:: (Index ix, PrimMonad m) => MArray (PrimState m) P ix Int -> ix -> m Int
unsafeAtomicReadIntArray :: forall ix (m :: * -> *).
(Index ix, PrimMonad m) =>
MArray (PrimState m) P ix Int -> ix -> m Int
unsafeAtomicReadIntArray _mpa :: MArray (PrimState m) P ix Int
_mpa@(MPArray Sz ix
sz Int
o MutableByteArray (PrimState m)
mba) ix
ix =
String
-> (MutableByteArray (PrimState m) -> Sz1)
-> (MutableByteArray (PrimState m) -> Int -> m Int)
-> MutableByteArray (PrimState m)
-> Int
-> m Int
forall a ix e.
String -> (a -> Sz ix) -> (a -> ix -> e) -> a -> ix -> e
indexAssert
String
"P.unsafeAtomicReadIntArray"
(Int -> Sz1
forall ix. ix -> Sz ix
SafeSz (Int -> Sz1)
-> (MutableByteArray (PrimState m) -> Int)
-> MutableByteArray (PrimState m)
-> Sz1
forall b c a. (b -> c) -> (a -> b) -> a -> c
. MArray (PrimState m) P ix Int
-> MutableByteArray (PrimState m) -> Int
forall (proxy :: * -> *) e s.
Prim e =>
proxy e -> MutableByteArray s -> Int
elemsMBA MArray (PrimState m) P ix Int
_mpa)
( \(MutableByteArray MutableByteArray# (PrimState m)
mba#) (I# Int#
i#) ->
(State# (PrimState m) -> (# State# (PrimState m), Int #)) -> m Int
forall a.
(State# (PrimState m) -> (# State# (PrimState m), a #)) -> m a
forall (m :: * -> *) a.
PrimMonad m =>
(State# (PrimState m) -> (# State# (PrimState m), a #)) -> m a
primitive ((State# (PrimState m) -> (# State# (PrimState m), Int #))
-> m Int)
-> (State# (PrimState m) -> (# State# (PrimState m), Int #))
-> m Int
forall a b. (a -> b) -> a -> b
$ \State# (PrimState m)
s# ->
case MutableByteArray# (PrimState m)
-> Int# -> State# (PrimState m) -> (# State# (PrimState m), Int# #)
forall d.
MutableByteArray# d -> Int# -> State# d -> (# State# d, Int# #)
atomicReadIntArray# MutableByteArray# (PrimState m)
mba# Int#
i# State# (PrimState m)
s# of
(# State# (PrimState m)
s'#, Int#
e# #) -> (# State# (PrimState m)
s'#, Int# -> Int
I# Int#
e# #)
)
MutableByteArray (PrimState m)
mba
(Int
o Int -> Int -> Int
forall a. Num a => a -> a -> a
+ Sz ix -> ix -> Int
forall ix. Index ix => Sz ix -> ix -> Int
toLinearIndex Sz ix
sz ix
ix)
{-# INLINE unsafeAtomicReadIntArray #-}
unsafeAtomicWriteIntArray
:: (Index ix, PrimMonad m) => MArray (PrimState m) P ix Int -> ix -> Int -> m ()
unsafeAtomicWriteIntArray :: forall ix (m :: * -> *).
(Index ix, PrimMonad m) =>
MArray (PrimState m) P ix Int -> ix -> Int -> m ()
unsafeAtomicWriteIntArray _mpa :: MArray (PrimState m) P ix Int
_mpa@(MPArray Sz ix
sz Int
o MutableByteArray (PrimState m)
mba) ix
ix (I# Int#
e#) =
String
-> (MutableByteArray (PrimState m) -> Sz1)
-> (MutableByteArray (PrimState m) -> Int -> m ())
-> MutableByteArray (PrimState m)
-> Int
-> m ()
forall a ix e.
String -> (a -> Sz ix) -> (a -> ix -> e) -> a -> ix -> e
indexAssert
String
"P.unsafeAtomicWriteIntArray"
(Int -> Sz1
forall ix. ix -> Sz ix
SafeSz (Int -> Sz1)
-> (MutableByteArray (PrimState m) -> Int)
-> MutableByteArray (PrimState m)
-> Sz1
forall b c a. (b -> c) -> (a -> b) -> a -> c
. MArray (PrimState m) P ix Int
-> MutableByteArray (PrimState m) -> Int
forall (proxy :: * -> *) e s.
Prim e =>
proxy e -> MutableByteArray s -> Int
elemsMBA MArray (PrimState m) P ix Int
_mpa)
( \(MutableByteArray MutableByteArray# (PrimState m)
mba#) (I# Int#
i#) ->
(State# (PrimState m) -> State# (PrimState m)) -> m ()
forall (m :: * -> *).
PrimMonad m =>
(State# (PrimState m) -> State# (PrimState m)) -> m ()
primitive_ (MutableByteArray# (PrimState m)
-> Int# -> Int# -> State# (PrimState m) -> State# (PrimState m)
forall d.
MutableByteArray# d -> Int# -> Int# -> State# d -> State# d
atomicWriteIntArray# MutableByteArray# (PrimState m)
mba# Int#
i# Int#
e#)
)
MutableByteArray (PrimState m)
mba
(Int
o Int -> Int -> Int
forall a. Num a => a -> a -> a
+ Sz ix -> ix -> Int
forall ix. Index ix => Sz ix -> ix -> Int
toLinearIndex Sz ix
sz ix
ix)
{-# INLINE unsafeAtomicWriteIntArray #-}
unsafeCasIntArray
:: (Index ix, PrimMonad m) => MArray (PrimState m) P ix Int -> ix -> Int -> Int -> m Int
unsafeCasIntArray :: forall ix (m :: * -> *).
(Index ix, PrimMonad m) =>
MArray (PrimState m) P ix Int -> ix -> Int -> Int -> m Int
unsafeCasIntArray _mpa :: MArray (PrimState m) P ix Int
_mpa@(MPArray Sz ix
sz Int
o MutableByteArray (PrimState m)
mba) ix
ix (I# Int#
e#) (I# Int#
n#) =
String
-> (MutableByteArray (PrimState m) -> Sz1)
-> (MutableByteArray (PrimState m) -> Int -> m Int)
-> MutableByteArray (PrimState m)
-> Int
-> m Int
forall a ix e.
String -> (a -> Sz ix) -> (a -> ix -> e) -> a -> ix -> e
indexAssert
String
"P.unsafeCasIntArray"
(Int -> Sz1
forall ix. ix -> Sz ix
SafeSz (Int -> Sz1)
-> (MutableByteArray (PrimState m) -> Int)
-> MutableByteArray (PrimState m)
-> Sz1
forall b c a. (b -> c) -> (a -> b) -> a -> c
. MArray (PrimState m) P ix Int
-> MutableByteArray (PrimState m) -> Int
forall (proxy :: * -> *) e s.
Prim e =>
proxy e -> MutableByteArray s -> Int
elemsMBA MArray (PrimState m) P ix Int
_mpa)
( \(MutableByteArray MutableByteArray# (PrimState m)
mba#) (I# Int#
i#) ->
(State# (PrimState m) -> (# State# (PrimState m), Int #)) -> m Int
forall a.
(State# (PrimState m) -> (# State# (PrimState m), a #)) -> m a
forall (m :: * -> *) a.
PrimMonad m =>
(State# (PrimState m) -> (# State# (PrimState m), a #)) -> m a
primitive ((State# (PrimState m) -> (# State# (PrimState m), Int #))
-> m Int)
-> (State# (PrimState m) -> (# State# (PrimState m), Int #))
-> m Int
forall a b. (a -> b) -> a -> b
$ \State# (PrimState m)
s# ->
case MutableByteArray# (PrimState m)
-> Int#
-> Int#
-> Int#
-> State# (PrimState m)
-> (# State# (PrimState m), Int# #)
forall d.
MutableByteArray# d
-> Int# -> Int# -> Int# -> State# d -> (# State# d, Int# #)
casIntArray# MutableByteArray# (PrimState m)
mba# Int#
i# Int#
e# Int#
n# State# (PrimState m)
s# of
(# State# (PrimState m)
s'#, Int#
o# #) -> (# State# (PrimState m)
s'#, Int# -> Int
I# Int#
o# #)
)
MutableByteArray (PrimState m)
mba
(Int
o Int -> Int -> Int
forall a. Num a => a -> a -> a
+ Sz ix -> ix -> Int
forall ix. Index ix => Sz ix -> ix -> Int
toLinearIndex Sz ix
sz ix
ix)
{-# INLINE unsafeCasIntArray #-}
unsafeAtomicModifyIntArray
:: (Index ix, PrimMonad m) => MArray (PrimState m) P ix Int -> ix -> (Int -> Int) -> m Int
unsafeAtomicModifyIntArray :: forall ix (m :: * -> *).
(Index ix, PrimMonad m) =>
MArray (PrimState m) P ix Int -> ix -> (Int -> Int) -> m Int
unsafeAtomicModifyIntArray _mpa :: MArray (PrimState m) P ix Int
_mpa@(MPArray Sz ix
sz Int
o MutableByteArray (PrimState m)
mba) ix
ix Int -> Int
f =
String
-> (MutableByteArray (PrimState m) -> Sz1)
-> (MutableByteArray (PrimState m) -> Int -> m Int)
-> MutableByteArray (PrimState m)
-> Int
-> m Int
forall a ix e.
String -> (a -> Sz ix) -> (a -> ix -> e) -> a -> ix -> e
indexAssert
String
"P.unsafeAtomicModifyIntArray"
(Int -> Sz1
forall ix. ix -> Sz ix
SafeSz (Int -> Sz1)
-> (MutableByteArray (PrimState m) -> Int)
-> MutableByteArray (PrimState m)
-> Sz1
forall b c a. (b -> c) -> (a -> b) -> a -> c
. MArray (PrimState m) P ix Int
-> MutableByteArray (PrimState m) -> Int
forall (proxy :: * -> *) e s.
Prim e =>
proxy e -> MutableByteArray s -> Int
elemsMBA MArray (PrimState m) P ix Int
_mpa)
MutableByteArray (PrimState m) -> Int -> m Int
atomicModify
MutableByteArray (PrimState m)
mba
(Int
o Int -> Int -> Int
forall a. Num a => a -> a -> a
+ Sz ix -> ix -> Int
forall ix. Index ix => Sz ix -> ix -> Int
toLinearIndex Sz ix
sz ix
ix)
where
atomicModify :: MutableByteArray (PrimState m) -> Int -> m Int
atomicModify (MutableByteArray MutableByteArray# (PrimState m)
mba#) (I# Int#
i#) =
let go :: State# (PrimState m) -> Int# -> (# State# (PrimState m), Int #)
go State# (PrimState m)
s# Int#
o# =
let !(I# Int#
n#) = Int -> Int
f (Int# -> Int
I# Int#
o#)
in case MutableByteArray# (PrimState m)
-> Int#
-> Int#
-> Int#
-> State# (PrimState m)
-> (# State# (PrimState m), Int# #)
forall d.
MutableByteArray# d
-> Int# -> Int# -> Int# -> State# d -> (# State# d, Int# #)
casIntArray# MutableByteArray# (PrimState m)
mba# Int#
i# Int#
o# Int#
n# State# (PrimState m)
s# of
(# State# (PrimState m)
s'#, Int#
o'# #) ->
case Int#
o# Int# -> Int# -> Int#
==# Int#
o'# of
Int#
0# -> State# (PrimState m) -> Int# -> (# State# (PrimState m), Int #)
go State# (PrimState m)
s# Int#
o'#
Int#
_ -> (# State# (PrimState m)
s'#, Int# -> Int
I# Int#
o# #)
in (State# (PrimState m) -> (# State# (PrimState m), Int #)) -> m Int
forall a.
(State# (PrimState m) -> (# State# (PrimState m), a #)) -> m a
forall (m :: * -> *) a.
PrimMonad m =>
(State# (PrimState m) -> (# State# (PrimState m), a #)) -> m a
primitive ((State# (PrimState m) -> (# State# (PrimState m), Int #))
-> m Int)
-> (State# (PrimState m) -> (# State# (PrimState m), Int #))
-> m Int
forall a b. (a -> b) -> a -> b
$ \State# (PrimState m)
s# ->
case MutableByteArray# (PrimState m)
-> Int# -> State# (PrimState m) -> (# State# (PrimState m), Int# #)
forall d.
MutableByteArray# d -> Int# -> State# d -> (# State# d, Int# #)
atomicReadIntArray# MutableByteArray# (PrimState m)
mba# Int#
i# State# (PrimState m)
s# of
(# State# (PrimState m)
s'#, Int#
o# #) -> State# (PrimState m) -> Int# -> (# State# (PrimState m), Int #)
go State# (PrimState m)
s'# Int#
o#
{-# INLINE atomicModify #-}
{-# INLINE unsafeAtomicModifyIntArray #-}
unsafeAtomicAddIntArray
:: (Index ix, PrimMonad m) => MArray (PrimState m) P ix Int -> ix -> Int -> m Int
unsafeAtomicAddIntArray :: forall ix (m :: * -> *).
(Index ix, PrimMonad m) =>
MArray (PrimState m) P ix Int -> ix -> Int -> m Int
unsafeAtomicAddIntArray _mpa :: MArray (PrimState m) P ix Int
_mpa@(MPArray Sz ix
sz Int
o MutableByteArray (PrimState m)
mba) ix
ix (I# Int#
e#) =
String
-> (MutableByteArray (PrimState m) -> Sz1)
-> (MutableByteArray (PrimState m) -> Int -> m Int)
-> MutableByteArray (PrimState m)
-> Int
-> m Int
forall a ix e.
String -> (a -> Sz ix) -> (a -> ix -> e) -> a -> ix -> e
indexAssert
String
"P.unsafeAtomicAddIntArray"
(Int -> Sz1
forall ix. ix -> Sz ix
SafeSz (Int -> Sz1)
-> (MutableByteArray (PrimState m) -> Int)
-> MutableByteArray (PrimState m)
-> Sz1
forall b c a. (b -> c) -> (a -> b) -> a -> c
. MArray (PrimState m) P ix Int
-> MutableByteArray (PrimState m) -> Int
forall (proxy :: * -> *) e s.
Prim e =>
proxy e -> MutableByteArray s -> Int
elemsMBA MArray (PrimState m) P ix Int
_mpa)
( \(MutableByteArray MutableByteArray# (PrimState m)
mba#) (I# Int#
i#) ->
(State# (PrimState m) -> (# State# (PrimState m), Int #)) -> m Int
forall a.
(State# (PrimState m) -> (# State# (PrimState m), a #)) -> m a
forall (m :: * -> *) a.
PrimMonad m =>
(State# (PrimState m) -> (# State# (PrimState m), a #)) -> m a
primitive ((State# (PrimState m) -> (# State# (PrimState m), Int #))
-> m Int)
-> (State# (PrimState m) -> (# State# (PrimState m), Int #))
-> m Int
forall a b. (a -> b) -> a -> b
$ \State# (PrimState m)
s# ->
case MutableByteArray# (PrimState m)
-> Int#
-> Int#
-> State# (PrimState m)
-> (# State# (PrimState m), Int# #)
forall d.
MutableByteArray# d
-> Int# -> Int# -> State# d -> (# State# d, Int# #)
fetchAddIntArray# MutableByteArray# (PrimState m)
mba# Int#
i# Int#
e# State# (PrimState m)
s# of
(# State# (PrimState m)
s'#, Int#
p# #) -> (# State# (PrimState m)
s'#, Int# -> Int
I# Int#
p# #)
)
MutableByteArray (PrimState m)
mba
(Int
o Int -> Int -> Int
forall a. Num a => a -> a -> a
+ Sz ix -> ix -> Int
forall ix. Index ix => Sz ix -> ix -> Int
toLinearIndex Sz ix
sz ix
ix)
{-# INLINE unsafeAtomicAddIntArray #-}
unsafeAtomicSubIntArray
:: (Index ix, PrimMonad m) => MArray (PrimState m) P ix Int -> ix -> Int -> m Int
unsafeAtomicSubIntArray :: forall ix (m :: * -> *).
(Index ix, PrimMonad m) =>
MArray (PrimState m) P ix Int -> ix -> Int -> m Int
unsafeAtomicSubIntArray _mpa :: MArray (PrimState m) P ix Int
_mpa@(MPArray Sz ix
sz Int
o MutableByteArray (PrimState m)
mba) ix
ix (I# Int#
e#) =
String
-> (MutableByteArray (PrimState m) -> Sz1)
-> (MutableByteArray (PrimState m) -> Int -> m Int)
-> MutableByteArray (PrimState m)
-> Int
-> m Int
forall a ix e.
String -> (a -> Sz ix) -> (a -> ix -> e) -> a -> ix -> e
indexAssert
String
"P.unsafeAtomicSubIntArray"
(Int -> Sz1
forall ix. ix -> Sz ix
SafeSz (Int -> Sz1)
-> (MutableByteArray (PrimState m) -> Int)
-> MutableByteArray (PrimState m)
-> Sz1
forall b c a. (b -> c) -> (a -> b) -> a -> c
. MArray (PrimState m) P ix Int
-> MutableByteArray (PrimState m) -> Int
forall (proxy :: * -> *) e s.
Prim e =>
proxy e -> MutableByteArray s -> Int
elemsMBA MArray (PrimState m) P ix Int
_mpa)
( \(MutableByteArray MutableByteArray# (PrimState m)
mba#) (I# Int#
i#) ->
(State# (PrimState m) -> (# State# (PrimState m), Int #)) -> m Int
forall a.
(State# (PrimState m) -> (# State# (PrimState m), a #)) -> m a
forall (m :: * -> *) a.
PrimMonad m =>
(State# (PrimState m) -> (# State# (PrimState m), a #)) -> m a
primitive ((State# (PrimState m) -> (# State# (PrimState m), Int #))
-> m Int)
-> (State# (PrimState m) -> (# State# (PrimState m), Int #))
-> m Int
forall a b. (a -> b) -> a -> b
$ \State# (PrimState m)
s# ->
case MutableByteArray# (PrimState m)
-> Int#
-> Int#
-> State# (PrimState m)
-> (# State# (PrimState m), Int# #)
forall d.
MutableByteArray# d
-> Int# -> Int# -> State# d -> (# State# d, Int# #)
fetchSubIntArray# MutableByteArray# (PrimState m)
mba# Int#
i# Int#
e# State# (PrimState m)
s# of
(# State# (PrimState m)
s'#, Int#
p# #) -> (# State# (PrimState m)
s'#, Int# -> Int
I# Int#
p# #)
)
MutableByteArray (PrimState m)
mba
(Int
o Int -> Int -> Int
forall a. Num a => a -> a -> a
+ Sz ix -> ix -> Int
forall ix. Index ix => Sz ix -> ix -> Int
toLinearIndex Sz ix
sz ix
ix)
{-# INLINE unsafeAtomicSubIntArray #-}
unsafeAtomicAndIntArray
:: (Index ix, PrimMonad m) => MArray (PrimState m) P ix Int -> ix -> Int -> m Int
unsafeAtomicAndIntArray :: forall ix (m :: * -> *).
(Index ix, PrimMonad m) =>
MArray (PrimState m) P ix Int -> ix -> Int -> m Int
unsafeAtomicAndIntArray _mpa :: MArray (PrimState m) P ix Int
_mpa@(MPArray Sz ix
sz Int
o MutableByteArray (PrimState m)
mba) ix
ix (I# Int#
e#) =
String
-> (MutableByteArray (PrimState m) -> Sz1)
-> (MutableByteArray (PrimState m) -> Int -> m Int)
-> MutableByteArray (PrimState m)
-> Int
-> m Int
forall a ix e.
String -> (a -> Sz ix) -> (a -> ix -> e) -> a -> ix -> e
indexAssert
String
"P.unsafeAtomicAndIntArray"
(Int -> Sz1
forall ix. ix -> Sz ix
SafeSz (Int -> Sz1)
-> (MutableByteArray (PrimState m) -> Int)
-> MutableByteArray (PrimState m)
-> Sz1
forall b c a. (b -> c) -> (a -> b) -> a -> c
. MArray (PrimState m) P ix Int
-> MutableByteArray (PrimState m) -> Int
forall (proxy :: * -> *) e s.
Prim e =>
proxy e -> MutableByteArray s -> Int
elemsMBA MArray (PrimState m) P ix Int
_mpa)
( \(MutableByteArray MutableByteArray# (PrimState m)
mba#) (I# Int#
i#) ->
(State# (PrimState m) -> (# State# (PrimState m), Int #)) -> m Int
forall a.
(State# (PrimState m) -> (# State# (PrimState m), a #)) -> m a
forall (m :: * -> *) a.
PrimMonad m =>
(State# (PrimState m) -> (# State# (PrimState m), a #)) -> m a
primitive ((State# (PrimState m) -> (# State# (PrimState m), Int #))
-> m Int)
-> (State# (PrimState m) -> (# State# (PrimState m), Int #))
-> m Int
forall a b. (a -> b) -> a -> b
$ \State# (PrimState m)
s# ->
case MutableByteArray# (PrimState m)
-> Int#
-> Int#
-> State# (PrimState m)
-> (# State# (PrimState m), Int# #)
forall d.
MutableByteArray# d
-> Int# -> Int# -> State# d -> (# State# d, Int# #)
fetchAndIntArray# MutableByteArray# (PrimState m)
mba# Int#
i# Int#
e# State# (PrimState m)
s# of
(# State# (PrimState m)
s'#, Int#
p# #) -> (# State# (PrimState m)
s'#, Int# -> Int
I# Int#
p# #)
)
MutableByteArray (PrimState m)
mba
(Int
o Int -> Int -> Int
forall a. Num a => a -> a -> a
+ Sz ix -> ix -> Int
forall ix. Index ix => Sz ix -> ix -> Int
toLinearIndex Sz ix
sz ix
ix)
{-# INLINE unsafeAtomicAndIntArray #-}
unsafeAtomicNandIntArray
:: (Index ix, PrimMonad m) => MArray (PrimState m) P ix Int -> ix -> Int -> m Int
unsafeAtomicNandIntArray :: forall ix (m :: * -> *).
(Index ix, PrimMonad m) =>
MArray (PrimState m) P ix Int -> ix -> Int -> m Int
unsafeAtomicNandIntArray _mpa :: MArray (PrimState m) P ix Int
_mpa@(MPArray Sz ix
sz Int
o MutableByteArray (PrimState m)
mba) ix
ix (I# Int#
e#) =
String
-> (MutableByteArray (PrimState m) -> Sz1)
-> (MutableByteArray (PrimState m) -> Int -> m Int)
-> MutableByteArray (PrimState m)
-> Int
-> m Int
forall a ix e.
String -> (a -> Sz ix) -> (a -> ix -> e) -> a -> ix -> e
indexAssert
String
"P.unsafeAtomicNandIntArray"
(Int -> Sz1
forall ix. ix -> Sz ix
SafeSz (Int -> Sz1)
-> (MutableByteArray (PrimState m) -> Int)
-> MutableByteArray (PrimState m)
-> Sz1
forall b c a. (b -> c) -> (a -> b) -> a -> c
. MArray (PrimState m) P ix Int
-> MutableByteArray (PrimState m) -> Int
forall (proxy :: * -> *) e s.
Prim e =>
proxy e -> MutableByteArray s -> Int
elemsMBA MArray (PrimState m) P ix Int
_mpa)
( \(MutableByteArray MutableByteArray# (PrimState m)
mba#) (I# Int#
i#) ->
(State# (PrimState m) -> (# State# (PrimState m), Int #)) -> m Int
forall a.
(State# (PrimState m) -> (# State# (PrimState m), a #)) -> m a
forall (m :: * -> *) a.
PrimMonad m =>
(State# (PrimState m) -> (# State# (PrimState m), a #)) -> m a
primitive ((State# (PrimState m) -> (# State# (PrimState m), Int #))
-> m Int)
-> (State# (PrimState m) -> (# State# (PrimState m), Int #))
-> m Int
forall a b. (a -> b) -> a -> b
$ \State# (PrimState m)
s# ->
case MutableByteArray# (PrimState m)
-> Int#
-> Int#
-> State# (PrimState m)
-> (# State# (PrimState m), Int# #)
forall d.
MutableByteArray# d
-> Int# -> Int# -> State# d -> (# State# d, Int# #)
fetchNandIntArray# MutableByteArray# (PrimState m)
mba# Int#
i# Int#
e# State# (PrimState m)
s# of
(# State# (PrimState m)
s'#, Int#
p# #) -> (# State# (PrimState m)
s'#, Int# -> Int
I# Int#
p# #)
)
MutableByteArray (PrimState m)
mba
(Int
o Int -> Int -> Int
forall a. Num a => a -> a -> a
+ Sz ix -> ix -> Int
forall ix. Index ix => Sz ix -> ix -> Int
toLinearIndex Sz ix
sz ix
ix)
{-# INLINE unsafeAtomicNandIntArray #-}
unsafeAtomicOrIntArray
:: (Index ix, PrimMonad m) => MArray (PrimState m) P ix Int -> ix -> Int -> m Int
unsafeAtomicOrIntArray :: forall ix (m :: * -> *).
(Index ix, PrimMonad m) =>
MArray (PrimState m) P ix Int -> ix -> Int -> m Int
unsafeAtomicOrIntArray _mpa :: MArray (PrimState m) P ix Int
_mpa@(MPArray Sz ix
sz Int
o MutableByteArray (PrimState m)
mba) ix
ix (I# Int#
e#) =
String
-> (MutableByteArray (PrimState m) -> Sz1)
-> (MutableByteArray (PrimState m) -> Int -> m Int)
-> MutableByteArray (PrimState m)
-> Int
-> m Int
forall a ix e.
String -> (a -> Sz ix) -> (a -> ix -> e) -> a -> ix -> e
indexAssert
String
"P.unsafeAtomicOrIntArray"
(Int -> Sz1
forall ix. ix -> Sz ix
SafeSz (Int -> Sz1)
-> (MutableByteArray (PrimState m) -> Int)
-> MutableByteArray (PrimState m)
-> Sz1
forall b c a. (b -> c) -> (a -> b) -> a -> c
. MArray (PrimState m) P ix Int
-> MutableByteArray (PrimState m) -> Int
forall (proxy :: * -> *) e s.
Prim e =>
proxy e -> MutableByteArray s -> Int
elemsMBA MArray (PrimState m) P ix Int
_mpa)
( \(MutableByteArray MutableByteArray# (PrimState m)
mba#) (I# Int#
i#) ->
(State# (PrimState m) -> (# State# (PrimState m), Int #)) -> m Int
forall a.
(State# (PrimState m) -> (# State# (PrimState m), a #)) -> m a
forall (m :: * -> *) a.
PrimMonad m =>
(State# (PrimState m) -> (# State# (PrimState m), a #)) -> m a
primitive ((State# (PrimState m) -> (# State# (PrimState m), Int #))
-> m Int)
-> (State# (PrimState m) -> (# State# (PrimState m), Int #))
-> m Int
forall a b. (a -> b) -> a -> b
$ \State# (PrimState m)
s# ->
case MutableByteArray# (PrimState m)
-> Int#
-> Int#
-> State# (PrimState m)
-> (# State# (PrimState m), Int# #)
forall d.
MutableByteArray# d
-> Int# -> Int# -> State# d -> (# State# d, Int# #)
fetchOrIntArray# MutableByteArray# (PrimState m)
mba# Int#
i# Int#
e# State# (PrimState m)
s# of
(# State# (PrimState m)
s'#, Int#
p# #) -> (# State# (PrimState m)
s'#, Int# -> Int
I# Int#
p# #)
)
MutableByteArray (PrimState m)
mba
(Int
o Int -> Int -> Int
forall a. Num a => a -> a -> a
+ Sz ix -> ix -> Int
forall ix. Index ix => Sz ix -> ix -> Int
toLinearIndex Sz ix
sz ix
ix)
{-# INLINE unsafeAtomicOrIntArray #-}
unsafeAtomicXorIntArray
:: (Index ix, PrimMonad m) => MArray (PrimState m) P ix Int -> ix -> Int -> m Int
unsafeAtomicXorIntArray :: forall ix (m :: * -> *).
(Index ix, PrimMonad m) =>
MArray (PrimState m) P ix Int -> ix -> Int -> m Int
unsafeAtomicXorIntArray _mpa :: MArray (PrimState m) P ix Int
_mpa@(MPArray Sz ix
sz Int
o MutableByteArray (PrimState m)
mba) ix
ix (I# Int#
e#) =
String
-> (MutableByteArray (PrimState m) -> Sz1)
-> (MutableByteArray (PrimState m) -> Int -> m Int)
-> MutableByteArray (PrimState m)
-> Int
-> m Int
forall a ix e.
String -> (a -> Sz ix) -> (a -> ix -> e) -> a -> ix -> e
indexAssert
String
"P.unsafeAtomicXorIntArray"
(Int -> Sz1
forall ix. ix -> Sz ix
SafeSz (Int -> Sz1)
-> (MutableByteArray (PrimState m) -> Int)
-> MutableByteArray (PrimState m)
-> Sz1
forall b c a. (b -> c) -> (a -> b) -> a -> c
. MArray (PrimState m) P ix Int
-> MutableByteArray (PrimState m) -> Int
forall (proxy :: * -> *) e s.
Prim e =>
proxy e -> MutableByteArray s -> Int
elemsMBA MArray (PrimState m) P ix Int
_mpa)
( \(MutableByteArray MutableByteArray# (PrimState m)
mba#) (I# Int#
i#) ->
(State# (PrimState m) -> (# State# (PrimState m), Int #)) -> m Int
forall a.
(State# (PrimState m) -> (# State# (PrimState m), a #)) -> m a
forall (m :: * -> *) a.
PrimMonad m =>
(State# (PrimState m) -> (# State# (PrimState m), a #)) -> m a
primitive ((State# (PrimState m) -> (# State# (PrimState m), Int #))
-> m Int)
-> (State# (PrimState m) -> (# State# (PrimState m), Int #))
-> m Int
forall a b. (a -> b) -> a -> b
$ \State# (PrimState m)
s# ->
case MutableByteArray# (PrimState m)
-> Int#
-> Int#
-> State# (PrimState m)
-> (# State# (PrimState m), Int# #)
forall d.
MutableByteArray# d
-> Int# -> Int# -> State# d -> (# State# d, Int# #)
fetchXorIntArray# MutableByteArray# (PrimState m)
mba# Int#
i# Int#
e# State# (PrimState m)
s# of
(# State# (PrimState m)
s'#, Int#
p# #) -> (# State# (PrimState m)
s'#, Int# -> Int
I# Int#
p# #)
)
MutableByteArray (PrimState m)
mba
(Int
o Int -> Int -> Int
forall a. Num a => a -> a -> a
+ Sz ix -> ix -> Int
forall ix. Index ix => Sz ix -> ix -> Int
toLinearIndex Sz ix
sz ix
ix)
{-# INLINE unsafeAtomicXorIntArray #-}