module Data.Random.Source.MWC
( Gen, RealWorld
, create, initialize
, save, restore
) where
import Data.Random.Internal.Words
import Data.Random.Source
import System.Random.MWC
import Control.Monad.ST
$(randomSource
[d| instance RandomSource (ST s) (Gen s) where
getRandomWord8From = uniform
getRandomWord16From = uniform
getRandomWord32From = uniform
getRandomWord64From = uniform
getRandomDoubleFrom = fmap wordToDouble . uniform
|])
$(randomSource
[d| instance RandomSource IO (Gen RealWorld) where
getRandomWord8From = uniform
getRandomWord16From = uniform
getRandomWord32From = uniform
getRandomWord64From = uniform
getRandomDoubleFrom = fmap wordToDouble . uniform
|])