{-# LANGUAGE RankNTypes #-}
{-# LANGUAGE TypeOperators #-}
module Data.Array.Accelerate.Examples.Internal.Random.Array (
(:~>),
uniform, uniformR,
randomArray, randomArrayWithSeed, randomArrayWithSystemRandom,
) where
import System.Random.MWC hiding ( uniform, uniformR )
import qualified System.Random.MWC as R
import Data.Array.Accelerate as A
import Data.Array.Accelerate.Array.Data as A
import Data.Array.Accelerate.Array.Sugar as Sugar
type sh :~> e = sh -> GenIO -> IO e
uniform :: Variate e => sh :~> e
uniform _ = R.uniform
uniformR :: Variate e => (e, e) -> sh :~> e
uniformR bounds _ = R.uniformR bounds
randomArray :: (Shape sh, Elt e) => sh :~> e -> sh -> Array sh e
randomArray f sh
= let
(adata, _) = runArrayData $ do
gen <- create
arr <- runRandomArray f sh gen
return (arr, undefined)
in
adata `seq` Array (fromElt sh) adata
randomArrayWithSeed :: (Shape sh, Elt e) => Seed -> sh :~> e -> sh -> Array sh e
randomArrayWithSeed seed f sh
= let
(adata, _) = runArrayData $ do
gen <- restore seed
arr <- runRandomArray f sh gen
return (arr, undefined)
in
adata `seq` Array (fromElt sh) adata
randomArrayWithSystemRandom
:: forall sh e. (Shape sh, Elt e)
=> sh :~> e
-> sh
-> IO (Array sh e)
randomArrayWithSystemRandom f sh
= do
seed <- withSystemRandom (asGenIO save)
return $! randomArrayWithSeed seed f sh
runRandomArray
:: (Shape sh, Elt e)
=> sh :~> e
-> sh
-> GenIO
-> IO (MutableArrayData (EltRepr e))
runRandomArray f sh gen
= do
arr <- newArrayData $! Sugar.size sh
let write ix = unsafeWriteArrayData arr (Sugar.toIndex sh ix)
. fromElt =<< f ix gen
iter sh write (>>) (return ())
return arr