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 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103
|
{-# LANGUAGE AllowAmbiguousTypes #-}
{-# LANGUAGE BangPatterns #-}
{-# LANGUAGE DataKinds #-}
{-# LANGUAGE FlexibleContexts #-}
{-# LANGUAGE FlexibleInstances #-}
{-# LANGUAGE GADTs #-}
{-# LANGUAGE KindSignatures #-}
{-# LANGUAGE LambdaCase #-}
{-# LANGUAGE OverloadedStrings #-}
{-# LANGUAGE PackageImports #-}
{-# LANGUAGE ScopedTypeVariables #-}
{-# LANGUAGE RankNTypes #-}
{-# LANGUAGE TypeApplications #-}
{-# LANGUAGE TypeFamilies #-}
module Main
( main
) where
import Criterion
import Criterion.Main
import "base64-bytestring" Data.ByteString.Base64 as Bos
import "base64" Data.ByteString.Base64 as B64
import Data.ByteString.Random (random)
main :: IO ()
main =
defaultMain
[ env bs $ \ ~(bs25,bs100,bs1k,bs10k,bs100k,bs1mm) ->
bgroup "encode"
[ bgroup "25"
[ bench "base64-bytestring" $ whnf Bos.encode bs25
, bench "base64" $ whnf B64.encodeBase64' bs25
]
, bgroup "100"
[ bench "base64-bytestring" $ whnf Bos.encode bs100
, bench "base64" $ whnf B64.encodeBase64' bs100
]
, bgroup "1k"
[ bench "base64-bytestring" $ whnf Bos.encode bs1k
, bench "base64" $ whnf B64.encodeBase64' bs1k
]
, bgroup "10k"
[ bench "base64-bytestring" $ whnf Bos.encode bs10k
, bench "base64" $ whnf B64.encodeBase64' bs10k
]
, bgroup "100k"
[ bench "base64-bytestring" $ whnf Bos.encode bs100k
, bench "base64" $ whnf B64.encodeBase64' bs100k
]
, bgroup "1mm"
[ bench "base64-bytestring" $ whnf Bos.encode bs1mm
, bench "base64" $ whnf B64.encodeBase64' bs1mm
]
]
, env bs' $ \ ~(bs25,bs100,bs1k,bs10k,bs100k,bs1mm) ->
bgroup "decode"
[ bgroup "25"
[ bench "base64-bytestring" $ whnf Bos.decode bs25
, bench "base64" $ whnf B64.decodeBase64 bs25
]
, bgroup "100"
[ bench "base64-bytestring" $ whnf Bos.decode bs100
, bench "base64" $ whnf B64.decodeBase64 bs100
]
, bgroup "1k"
[ bench "base64-bytestring" $ whnf Bos.decode bs1k
, bench "base64" $ whnf B64.decodeBase64 bs1k
]
, bgroup "10k"
[ bench "base64-bytestring" $ whnf Bos.decode bs10k
, bench "base64" $ whnf B64.decodeBase64 bs10k
]
, bgroup "100k"
[ bench "base64-bytestring" $ whnf Bos.decode bs100k
, bench "base64" $ whnf B64.decodeBase64 bs100k
]
, bgroup "1mm"
[ bench "base64-bytestring" $ whnf Bos.decode bs1mm
, bench "base64" $ whnf B64.decodeBase64 bs1mm
]
]
]
where
bs = do
a <- random 25
b <- random 100
c <- random 1000
d <- random 10000
e <- random 100000
f <- random 1000000
return (a,b,c,d,e,f)
bs' = do
a <- B64.encodeBase64' <$> random 25
b <- B64.encodeBase64' <$> random 100
c <- B64.encodeBase64' <$> random 1000
d <- B64.encodeBase64' <$> random 10000
e <- B64.encodeBase64' <$> random 100000
f <- B64.encodeBase64' <$> random 1000000
return (a,b,c,d,e,f)
|