File: Base64Bench.hs

package info (click to toggle)
haskell-base64 0.4.2.4-2
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 252 kB
  • sloc: haskell: 2,145; makefile: 3
file content (103 lines) | stat: -rw-r--r-- 3,127 bytes parent folder | download | duplicates (2)
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)