File: Benchmarks.hs

package info (click to toggle)
haskell-cprng-aes 0.5.2-1
  • links: PTS, VCS
  • area: main
  • in suites: jessie, jessie-kfreebsd
  • size: 80 kB
  • sloc: haskell: 174; makefile: 2
file content (40 lines) | stat: -rw-r--r-- 1,158 bytes parent folder | download | duplicates (5)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
module Main where

import Criterion.Main

import qualified Data.ByteString as B
import Crypto.Random.AESCtr
import Crypto.Random
import System.IO.Unsafe (unsafePerformIO)
import Data.IORef

gen rng n = fst (cprgGenerate n rng)

gen2 rngref n = unsafePerformIO $ do
    rng <- readIORef rngref
    let (b, rng2) = cprgGenerate n rng
    writeIORef rngref rng2
    return b

main = do
    rng <- makeSystem
    rngref <- newIORef rng

    defaultMain
        [ bgroup "generate random bytes (init)"
            [ bench "1"    $ nf (gen rng) 1
            , bench "8"    $ nf (gen rng) 8
            , bench "16"   $ nf (gen rng) 16
            , bench "256"  $ nf (gen rng) 256
            , bench "1024" $ nf (gen rng) 1024
            , bench "4096" $ nf (gen rng) 4096
            ]
        , bgroup "generate random bytes (continous)"
            [ bench "1"    $ nf (gen2 rngref) 1
            , bench "8"    $ nf (gen2 rngref) 8
            , bench "16"   $ nf (gen2 rngref) 16
            , bench "256"  $ nf (gen2 rngref) 256
            , bench "1024" $ nf (gen2 rngref) 1024
            , bench "4096" $ nf (gen2 rngref) 4096
            ]
        ]