{-# LANGUAGE BangPatterns #-}
{-# LANGUAGE CPP #-}
{-# LANGUAGE FlexibleContexts #-}
{-# LANGUAGE FlexibleInstances #-}
{-# LANGUAGE MultiParamTypeClasses #-}
{-# LANGUAGE PatternSynonyms #-}
{-# LANGUAGE ScopedTypeVariables #-}
{-# LANGUAGE TypeFamilies #-}
module Data.Massiv.Array.Manifest
(
Manifest
, generateArray
, generateArrayLinear
, generateArrayS
, generateArrayLinearS
, generateSplitSeedArray
, generateArrayWS
, generateArrayLinearWS
, unfoldrPrimM_
, iunfoldrPrimM_
, unfoldrPrimM
, iunfoldrPrimM
, unfoldlPrimM_
, iunfoldlPrimM_
, unfoldlPrimM
, iunfoldlPrimM
, forPrimM
, forPrimM_
, iforPrimM
, iforPrimM_
, iforLinearPrimM
, iforLinearPrimM_
, for2PrimM_
, ifor2PrimM_
, B(..)
, BL(..)
, BN(..)
, N
, pattern N
, Uninitialized(..)
, findIndex
, toLazyArray
, evalLazyArray
, forceLazyArray
, unwrapNormalForm
, evalNormalForm
, unwrapLazyArray
, wrapLazyArray
, unwrapArray
, evalArray
, unwrapMutableArray
, unwrapMutableLazyArray
, evalMutableArray
, unwrapNormalFormArray
, evalNormalFormArray
, unwrapNormalFormMutableArray
, evalNormalFormMutableArray
, toBoxedVector
, toBoxedMVector
, fromBoxedVector
, fromBoxedMVector
, evalBoxedVector
, evalBoxedMVector
, P(..)
, Prim
, toByteArray
, toByteArrayM
, unwrapByteArray
, unwrapByteArrayOffset
, fromByteArray
, fromByteArrayM
, fromByteArrayOffsetM
, toMutableByteArray
, unwrapMutableByteArray
, unwrapMutableByteArrayOffset
, fromMutableByteArray
, fromMutableByteArrayM
, fromMutableByteArrayOffsetM
, toPrimitiveVector
, toPrimitiveMVector
, fromPrimitiveVector
, fromPrimitiveMVector
, S(..)
, Storable
, mallocCompute
, mallocCopy
, toStorableVector
, toStorableMVector
, fromStorableVector
, fromStorableMVector
, withPtr
, U(..)
, Unbox
, toUnboxedVector
, toUnboxedMVector
, fromUnboxedVector
, fromUnboxedMVector
, fromByteString
, castFromByteString
, toByteString
, castToByteString
, toBuilder
, castToBuilder
) where
import Control.Monad
import Data.ByteString as S hiding (findIndex)
import Data.ByteString.Builder
import Data.ByteString.Internal
import Data.ByteString.Unsafe as SU
import Data.Massiv.Array.Manifest.Boxed
import Data.Massiv.Array.Manifest.Internal
import Data.Massiv.Array.Manifest.Primitive
import Data.Massiv.Array.Manifest.Storable
import Data.Massiv.Array.Manifest.Unboxed
import Data.Massiv.Array.Mutable
import Data.Massiv.Array.Ops.Fold
import Data.Massiv.Core.Common
import Data.Word (Word8)
fromByteString ::
Load r Ix1 Word8
=> Comp
-> ByteString
-> Vector r Word8
fromByteString :: forall r. Load r Ix1 Word8 => Comp -> ByteString -> Vector r Word8
fromByteString Comp
comp ByteString
bs = Comp -> Sz Ix1 -> (Ix1 -> Word8) -> Array r Ix1 Word8
forall r ix e.
Load r ix e =>
Comp -> Sz ix -> (Ix1 -> e) -> Array r ix e
makeArrayLinear Comp
comp (Ix1 -> Sz Ix1
forall ix. ix -> Sz ix
SafeSz (ByteString -> Ix1
S.length ByteString
bs)) (ByteString -> Ix1 -> Word8
SU.unsafeIndex ByteString
bs)
{-# INLINE fromByteString #-}
toByteString ::
Load r ix Word8
=> Array r ix Word8
-> ByteString
toByteString :: forall r ix. Load r ix Word8 => Array r ix Word8 -> ByteString
toByteString = Array S ix Word8 -> ByteString
forall ix. Index ix => Array S ix Word8 -> ByteString
castToByteString (Array S ix Word8 -> ByteString)
-> (Array r ix Word8 -> Array S ix Word8)
-> Array r ix Word8
-> ByteString
forall b c a. (b -> c) -> (a -> b) -> a -> c
.
#if __GLASGOW_HASKELL__ >= 820
Array r ix Word8 -> Array S ix Word8
forall r ix e r'.
(Manifest r e, Load r' ix e) =>
Array r' ix e -> Array r ix e
convert
#else
compute
#endif
{-# INLINE toByteString #-}
toBuilder :: (Index ix, Source r e) => (e -> Builder) -> Array r ix e -> Builder
toBuilder :: forall ix r e.
(Index ix, Source r e) =>
(e -> Builder) -> Array r ix e -> Builder
toBuilder = (e -> Builder) -> Array r ix e -> Builder
forall ix r e m.
(Index ix, Source r e, Monoid m) =>
(e -> m) -> Array r ix e -> m
foldMono
{-# INLINE toBuilder #-}
castToBuilder :: Index ix => Array S ix Word8 -> Builder
castToBuilder :: forall ix. Index ix => Array S ix Word8 -> Builder
castToBuilder = ByteString -> Builder
byteString (ByteString -> Builder)
-> (Array S ix Word8 -> ByteString) -> Array S ix Word8 -> Builder
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Array S ix Word8 -> ByteString
forall ix. Index ix => Array S ix Word8 -> ByteString
castToByteString
{-# INLINE castToBuilder #-}
castToByteString :: Index ix => Array S ix Word8 -> ByteString
castToByteString :: forall ix. Index ix => Array S ix Word8 -> ByteString
castToByteString = (\(ForeignPtr Word8
fp, Ix1
len) -> ForeignPtr Word8 -> Ix1 -> Ix1 -> ByteString
PS ForeignPtr Word8
fp Ix1
0 Ix1
len) ((ForeignPtr Word8, Ix1) -> ByteString)
-> (Array S ix Word8 -> (ForeignPtr Word8, Ix1))
-> Array S ix Word8
-> ByteString
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Array S ix Word8 -> (ForeignPtr Word8, Ix1)
forall ix e. Index ix => Array S ix e -> (ForeignPtr e, Ix1)
unsafeArrayToForeignPtr
{-# INLINE castToByteString #-}
castFromByteString :: Comp -> ByteString -> Vector S Word8
castFromByteString :: Comp -> ByteString -> Vector S Word8
castFromByteString Comp
comp (PS ForeignPtr Word8
fp Ix1
offset Ix1
len) = Comp -> ForeignPtr Word8 -> Ix1 -> Sz Ix1 -> Vector S Word8
forall e.
Storable e =>
Comp -> ForeignPtr e -> Ix1 -> Sz Ix1 -> Array S Ix1 e
unsafeArrayFromForeignPtr Comp
comp ForeignPtr Word8
fp Ix1
offset (Ix1 -> Sz Ix1
forall ix. Index ix => ix -> Sz ix
Sz Ix1
len)
{-# INLINE castFromByteString #-}
findIndex :: (Index ix, Manifest r e) => (e -> Bool) -> Array r ix e -> Maybe ix
findIndex :: forall ix r e.
(Index ix, Manifest r e) =>
(e -> Bool) -> Array r ix e -> Maybe ix
findIndex e -> Bool
f Array r ix e
arr = Ix1 -> Maybe ix
go Ix1
0
where
!sz :: Sz ix
sz = Array r ix e -> Sz ix
forall r ix e. Size r => Array r ix e -> Sz ix
forall ix e. Array r ix e -> Sz ix
size Array r ix e
arr
!k :: Ix1
k = Sz ix -> Ix1
forall ix. Index ix => Sz ix -> Ix1
totalElem Sz ix
sz
go :: Ix1 -> Maybe ix
go !Ix1
i = do
Bool -> Maybe ()
forall (f :: * -> *). Alternative f => Bool -> f ()
guard (Ix1
i Ix1 -> Ix1 -> Bool
forall a. Ord a => a -> a -> Bool
< Ix1
k)
if e -> Bool
f (Array r ix e -> Ix1 -> e
forall ix. Index ix => Array r ix e -> Ix1 -> e
forall r e ix. (Source r e, Index ix) => Array r ix e -> Ix1 -> e
unsafeLinearIndex Array r ix e
arr Ix1
i)
then ix -> Maybe ix
forall a. a -> Maybe a
Just (ix -> Maybe ix) -> ix -> Maybe ix
forall a b. (a -> b) -> a -> b
$ Sz ix -> Ix1 -> ix
forall ix. Index ix => Sz ix -> Ix1 -> ix
fromLinearIndex Sz ix
sz Ix1
i
else Ix1 -> Maybe ix
go (Ix1
i Ix1 -> Ix1 -> Ix1
forall a. Num a => a -> a -> a
+ Ix1
1)
{-# INLINE findIndex #-}
mallocCompute :: forall r ix e. (Size r, Load r ix e, Storable e) => Array r ix e -> IO (Array S ix e)
mallocCompute :: forall r ix e.
(Size r, Load r ix e, Storable e) =>
Array r ix e -> IO (Array S ix e)
mallocCompute Array r ix e
arr = do
let sz :: Sz ix
sz = Array r ix e -> Sz ix
forall r ix e. Size r => Array r ix e -> Sz ix
forall ix e. Array r ix e -> Sz ix
size Array r ix e
arr
MArray RealWorld S ix e
marr <- Sz ix -> IO (MArray (PrimState IO) S ix e)
forall ix e (m :: * -> *).
(Index ix, Storable e, PrimMonad m) =>
Sz ix -> m (MArray (PrimState m) S ix e)
unsafeMallocMArray Sz ix
sz
MArray RealWorld S ix e -> Array r ix e -> IO ()
forall r' ix' e r ix (m :: * -> *).
(Load r' ix' e, Manifest r e, Index ix, MonadIO m) =>
MArray RealWorld r ix e -> Array r' ix' e -> m ()
computeInto MArray RealWorld S ix e
marr Array r ix e
arr
Comp -> MArray (PrimState IO) S ix e -> IO (Array S 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) S ix e -> m (Array S ix e)
unsafeFreeze (Array r ix e -> Comp
forall r ix e. Strategy r => Array r ix e -> Comp
forall ix e. Array r ix e -> Comp
getComp Array r ix e
arr) MArray RealWorld S ix e
MArray (PrimState IO) S ix e
marr
{-# INLINE mallocCompute #-}
mallocCopy :: forall ix e. (Index ix, Storable e) => Array S ix e -> IO (Array S ix e)
mallocCopy :: forall ix e.
(Index ix, Storable e) =>
Array S ix e -> IO (Array S ix e)
mallocCopy Array S ix e
arr = do
let sz :: Sz ix
sz = Array S ix e -> Sz ix
forall r ix e. Size r => Array r ix e -> Sz ix
forall ix e. Array S ix e -> Sz ix
size Array S ix e
arr
MArray RealWorld S ix e
marr <- Sz ix -> IO (MArray (PrimState IO) S ix e)
forall ix e (m :: * -> *).
(Index ix, Storable e, PrimMonad m) =>
Sz ix -> m (MArray (PrimState m) S ix e)
unsafeMallocMArray Sz ix
sz
Array S ix e
-> Ix1 -> MArray (PrimState IO) S ix e -> Ix1 -> Sz Ix1 -> IO ()
forall r e ix' ix (m :: * -> *).
(Manifest r e, Index ix', Index ix, PrimMonad m) =>
Array r ix' e
-> Ix1 -> MArray (PrimState m) r ix e -> Ix1 -> Sz Ix1 -> m ()
forall ix' ix (m :: * -> *).
(Index ix', Index ix, PrimMonad m) =>
Array S ix' e
-> Ix1 -> MArray (PrimState m) S ix e -> Ix1 -> Sz Ix1 -> m ()
unsafeArrayLinearCopy Array S ix e
arr Ix1
0 MArray RealWorld S ix e
MArray (PrimState IO) S ix e
marr Ix1
0 (Ix1 -> Sz Ix1
forall ix. ix -> Sz ix
SafeSz (Sz ix -> Ix1
forall ix. Index ix => Sz ix -> Ix1
totalElem Sz ix
sz))
Comp -> MArray (PrimState IO) S ix e -> IO (Array S 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) S ix e -> m (Array S ix e)
unsafeFreeze (Array S ix e -> Comp
forall r ix e. Strategy r => Array r ix e -> Comp
forall ix e. Array S ix e -> Comp
getComp Array S ix e
arr) MArray RealWorld S ix e
MArray (PrimState IO) S ix e
marr
{-# INLINE mallocCopy #-}