{-# LANGUAGE BangPatterns #-}
{-# LANGUAGE FlexibleContexts #-}
{-# LANGUAGE FlexibleInstances #-}
{-# LANGUAGE MultiParamTypeClasses #-}
{-# LANGUAGE TypeFamilies #-}
{-# LANGUAGE UndecidableInstances #-}
module Data.Massiv.Array.Delayed.Interleaved
( DI(..)
, toInterleaved
, fromInterleaved
) where
import Data.Massiv.Array.Delayed.Internal
import Data.Massiv.Core.Common
import Data.Massiv.Core.Scheduler
data DI = DI
type instance EltRepr DI ix = DI
newtype instance Array DI ix e = DIArray { diArray :: Array D ix e }
instance Index ix => Construct DI ix e where
getComp = dComp . diArray
{-# INLINE getComp #-}
setComp c arr = arr { diArray = (diArray arr) { dComp = c } }
{-# INLINE setComp #-}
unsafeMakeArray c sz = DIArray . unsafeMakeArray c sz
{-# INLINE unsafeMakeArray #-}
instance Functor (Array DI ix) where
fmap f (DIArray arr) = DIArray (fmap f arr)
instance Index ix => Size DI ix e where
size (DIArray arr) = size arr
{-# INLINE size #-}
unsafeResize sz = DIArray . unsafeResize sz . diArray
{-# INLINE unsafeResize #-}
unsafeExtract sIx newSz = DIArray . unsafeExtract sIx newSz . diArray
{-# INLINE unsafeExtract #-}
instance Index ix => Load DI ix e where
loadS (DIArray arr) = loadS arr
{-# INLINE loadS #-}
loadP wIds (DIArray (DArray _ sz f)) _ unsafeWrite =
withScheduler_ wIds $ \scheduler -> do
let !totalLength = totalElem sz
loopM_ 0 (< numWorkers scheduler) (+ 1) $ \ !start ->
scheduleWork scheduler $
iterLinearM_ sz start totalLength (numWorkers scheduler) (<) $ \ !k !ix ->
unsafeWrite k $ f ix
{-# INLINE loadP #-}
loadArray numWorkers' scheduleWork' (DIArray (DArray _ sz f)) _ unsafeWrite =
loopM_ 0 (< numWorkers') (+ 1) $ \ !start ->
scheduleWork' $
iterLinearM_ sz start (totalElem sz) numWorkers' (<) $ \ !k -> unsafeWrite k . f
{-# INLINE loadArray #-}
loadArrayWithStride numWorkers' scheduleWork' stride resultSize arr _ unsafeWrite =
let strideIx = unStride stride
DIArray (DArray _ _ f) = arr
in loopM_ 0 (< numWorkers') (+ 1) $ \ !start ->
scheduleWork' $
iterLinearM_ resultSize start (totalElem resultSize) numWorkers' (<) $
\ !i ix -> unsafeWrite i (f (liftIndex2 (*) strideIx ix))
{-# INLINE loadArrayWithStride #-}
toInterleaved :: Source r ix e => Array r ix e -> Array DI ix e
toInterleaved = DIArray . delay
{-# INLINE toInterleaved #-}
fromInterleaved :: Array DI ix e -> Array D ix e
fromInterleaved = diArray
{-# INLINE fromInterleaved #-}