random: Pseudo-random number generation
This package provides basic pseudo-random number generation, including the ability to split random number generators.
System.Random: pure pseudo-random number interface
In pure code, use System.Random.uniform
and System.Random.uniformR
from
System.Random to generate pseudo-random numbers with a pure pseudo-random
number generator like System.Random.StdGen
.
As an example, here is how you can simulate rolls of a six-sided die using
System.Random.uniformR
:
>>>
let roll = uniformR (1, 6) :: RandomGen g => g -> (Word, g)
>>>
let rolls = unfoldr (Just . roll) :: RandomGen g => g -> [Word]
>>>
let pureGen = mkStdGen 42
>>>
take 10 (rolls pureGen) :: [Word]
[1,1,3,2,4,5,3,4,6,2]
See System.Random for more details.
System.Random.Stateful: monadic pseudo-random number interface
In monadic code, use System.Random.Stateful.uniformM
and
System.Random.Stateful.uniformRM
from System.Random.Stateful to generate
pseudo-random numbers with a monadic pseudo-random number generator, or
using a monadic adapter.
As an example, here is how you can simulate rolls of a six-sided die using
System.Random.Stateful.uniformRM
:
>>>
let rollM = uniformRM (1, 6) :: StatefulGen g m => g -> m Word
>>>
let pureGen = mkStdGen 42
>>>
runStateGen_ pureGen (replicateM 10 . rollM) :: [Word]
[1,1,3,2,4,5,3,4,6,2]
The monadic adapter System.Random.Stateful.runStateGen_
is used here to lift
the pure pseudo-random number generator pureGen
into the
System.Random.Stateful.StatefulGen
context.
The monadic interface can also be used with existing monadic pseudo-random number generators. In this example, we use the one provided in the mwc-random package:
>>>
import System.Random.MWC as MWC
>>>
let rollM = uniformRM (1, 6) :: StatefulGen g m => g -> m Word
>>>
monadicGen <- MWC.create
>>>
replicateM 10 (rollM monadicGen) :: IO [Word]
[2,3,6,6,4,4,3,1,5,4]
See System.Random.Stateful for more details.
[Skip to Readme]
Downloads
- random-1.3.0.tar.gz [browse] (Cabal source package)
- Package description (as included in the package)
Maintainer's Corner
For package maintainers and hackage trustees
Candidates
- No Candidates
Versions [RSS] | 1.0.0.0, 1.0.0.1, 1.0.0.2, 1.0.0.3, 1.0.1.0, 1.0.1.1, 1.0.1.3, 1.1, 1.2.0, 1.2.1, 1.2.1.1, 1.2.1.2, 1.2.1.3, 1.3.0 (info) |
---|---|
Change log | CHANGELOG.md |
Dependencies | base (>=4.9 && <5), bytestring (>=0.10.4 && <0.13), data-array-byte, deepseq (>=1.1 && <2), mtl (>=2.2 && <2.4), splitmix (>=0.1 && <0.2), transformers (>=0.4 && <0.7) [details] |
Tested with | ghc ==8.0.2, ghc ==8.2.2, ghc ==8.4.4, ghc ==8.6.5, ghc ==8.8.4, ghc ==8.10.7, ghc ==9.0.2, ghc ==9.2.8, ghc ==9.4.8, ghc ==9.6.6, ghc ==9.8.4, ghc ==9.10.1, ghc ==9.12.1 |
License | BSD-3-Clause |
Author | |
Maintainer | core-libraries-committee@haskell.org |
Category | System |
Bug tracker | https://github.com/haskell/random/issues |
Source repo | head: git clone https://github.com/haskell/random.git |
Uploaded | by lehins at 2025-01-06T04:03:08Z |
Distributions | Arch:1.2.1.2, Debian:1.1, Fedora:1.2.1.1, FreeBSD:1.1, LTSHaskell:1.2.1.3, NixOS:1.2.1.2, Stackage:1.2.1.3, openSUSE:1.2.1.3 |
Reverse Dependencies | 1028 direct, 9571 indirect [details] |
Downloads | 436179 total (745 in the last 30 days) |
Rating | 2.5 (votes: 5) [estimated by Bayesian average] |
Your Rating | |
Status | Docs available [build log] Last success reported on 2025-01-06 [all 1 reports] |