commit 92bd48531642c277923c6615a2e018ff2963ea70
parent a5dc1f5f0420e53aa484ff27b0925363387aff05
Author: Jared Tobin <jared@jtobin.ca>
Date: Fri, 28 Oct 2016 15:35:04 +1300
Version bump, doc updates.
Diffstat:
4 files changed, 35 insertions(+), 15 deletions(-)
diff --git a/mwc-probability.cabal b/mwc-probability.cabal
@@ -1,5 +1,5 @@
name: mwc-probability
-version: 1.2.1
+version: 1.2.2
homepage: http://github.com/jtobin/mwc-probability
license: MIT
license-file: LICENSE
@@ -51,8 +51,8 @@ library
default-language: Haskell2010
hs-source-dirs: src
build-depends:
- base < 5
- , mwc-random
+ base > 4 && < 6
+ , mwc-random > 0.13 && < 0.14
, primitive
, transformers
diff --git a/src/System/Random/MWC/Probability.hs b/src/System/Random/MWC/Probability.hs
@@ -103,13 +103,13 @@ samples n model gen = replicateM n (sample model gen)
{-# INLINABLE samples #-}
instance Monad m => Functor (Prob m) where
- fmap h (Prob f) = Prob $ liftM h . f
+ fmap h (Prob f) = Prob $ fmap h . f
instance Monad m => Applicative (Prob m) where
pure = return
(<*>) = ap
-instance (Applicative m, Monad m, Num a) => Num (Prob m a) where
+instance (Monad m, Num a) => Num (Prob m a) where
(+) = liftA2 (+)
(-) = liftA2 (-)
(*) = liftA2 (*)
@@ -135,24 +135,39 @@ instance PrimMonad m => PrimMonad (Prob m) where
primitive = lift . primitive
{-# INLINE primitive #-}
--- | The uniform distribution.
+-- | The uniform distribution over a type.
+--
+-- >>> gen <- create
+-- >>> sample uniform gen :: IO Double
+-- 0.29308497534914946
+-- >>> sample uniform gen :: IO Bool
+-- False
uniform :: (PrimMonad m, Variate a) => Prob m a
uniform = Prob QMWC.uniform
{-# INLINABLE uniform #-}
-- | The uniform distribution over the provided interval.
+--
+-- >>> sample (uniformR (0, 1)) gen
+-- 0.44984153252922365
uniformR :: (PrimMonad m, Variate a) => (a, a) -> Prob m a
uniformR r = Prob $ QMWC.uniformR r
{-# INLINABLE uniformR #-}
-- | The discrete uniform distribution.
+--
+-- >>> sample (discreteUniform [0..10]) gen
+-- 6
+-- >>> sample (discreteUniform "abcdefghijklmnopqrstuvwxyz") gen
+-- 'a'
discreteUniform :: (PrimMonad m, Foldable f) => f a -> Prob m a
discreteUniform cs = do
j <- uniformR (0, length cs - 1)
return $ F.toList cs !! j
{-# INLINABLE discreteUniform #-}
--- | The standard normal distribution (a Gaussian with mean 0 and variance 1).
+-- | The standard normal or Gaussian distribution (with mean 0 and standard
+-- deviation 1).
standard :: PrimMonad m => Prob m Double
standard = Prob MWC.Dist.standard
{-# INLINABLE standard #-}
@@ -168,12 +183,18 @@ logNormal :: PrimMonad m => Double -> Double -> Prob m Double
logNormal m sd = exp <$> normal m sd
{-# INLINABLE logNormal #-}
--- | The exponential distribution.
+-- | The exponential distribution with provided rate parameter.
exponential :: PrimMonad m => Double -> Prob m Double
exponential r = Prob $ MWC.Dist.exponential r
{-# INLINABLE exponential #-}
--- | The gamma distribution.
+-- | The gamma distribution with shape parameter a and scale parameter b.
+--
+-- This is the parameterization used more traditionally in frequentist
+-- statistics. It has the following corresponding probability density
+-- function:
+--
+-- f(x; a, b) = 1 / (Gamma(a) * b ^ a) x ^ (a - 1) e ^ (- x / b)
gamma :: PrimMonad m => Double -> Double -> Prob m Double
gamma a b = Prob $ MWC.Dist.gamma a b
{-# INLINABLE gamma #-}
@@ -204,8 +225,7 @@ dirichlet as = do
return $ fmap (/ sum zs) zs
{-# INLINABLE dirichlet #-}
--- | The symmetric Dirichlet distribution (with equal concentration
--- parameters).
+-- | The symmetric Dirichlet distribution of dimension n.
symmetricDirichlet :: PrimMonad m => Int -> Double -> Prob m [Double]
symmetricDirichlet n a = dirichlet (replicate n a)
{-# INLINABLE symmetricDirichlet #-}
@@ -217,7 +237,7 @@ bernoulli p = (< p) <$> uniform
-- | The binomial distribution.
binomial :: PrimMonad m => Int -> Double -> Prob m Int
-binomial n p = liftM (length . filter id) $ replicateM n (bernoulli p)
+binomial n p = fmap (length . filter id) $ replicateM n (bernoulli p)
{-# INLINABLE binomial #-}
-- | The multinomial distribution.
diff --git a/stack-travis.yaml b/stack-travis.yaml
@@ -2,7 +2,7 @@ flags: {}
packages:
- '.'
extra-deps: []
-resolver: lts-5.1
-compiler: ghc-7.10.3
+resolver: lts-7.0
+compiler: ghc-8.0.1
system-ghc: false
install-ghc: true
diff --git a/stack.yaml b/stack.yaml
@@ -2,4 +2,4 @@ flags: {}
packages:
- '.'
extra-deps: []
-resolver: lts-5.1
+resolver: lts-7.0