File: Numbers.hs

package info (click to toggle)
haskell-attoparsec 0.14.4-4
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 880 kB
  • sloc: haskell: 4,749; ansic: 170; makefile: 22
file content (81 lines) | stat: -rw-r--r-- 2,840 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
{-# LANGUAGE BangPatterns #-}
{-# OPTIONS_GHC -fno-warn-deprecations #-}

module Numbers (numbers) where

import Test.Tasty.Bench (Benchmark, bench, bgroup, nf)
import Data.Scientific (Scientific(..))
import Text.Parsec.Text ()
import Text.Parsec.Text.Lazy ()
import qualified Data.Attoparsec.ByteString.Char8 as AC
import qualified Data.Attoparsec.Text as AT
import qualified Data.ByteString.Char8 as BC
import qualified Data.Text as T

strN, strNePos, strNeNeg :: String
strN     = "1234.56789"
strNePos = "1234.56789e3"
strNeNeg = "1234.56789e-3"

numbers :: Benchmark
numbers = bgroup "numbers" [
  let !tN     = T.pack strN
      !tNePos = T.pack strNePos
      !tNeNeg = T.pack strNeNeg
  in bgroup "Text"
  [
    bgroup "no power"
    [ bench "double" $ nf (AT.parseOnly AT.double) tN
    , bench "number" $ nf (AT.parseOnly AT.number) tN
    , bench "rational" $
      nf (AT.parseOnly (AT.rational :: AT.Parser Rational)) tN
    , bench "scientific" $
      nf (AT.parseOnly (AT.rational :: AT.Parser Scientific)) tN
    ]
  , bgroup "positive power"
    [ bench "double" $ nf (AT.parseOnly AT.double) tNePos
    , bench "number" $ nf (AT.parseOnly AT.number) tNePos
    , bench "rational" $
      nf (AT.parseOnly (AT.rational :: AT.Parser Rational)) tNePos
    , bench "scientific" $
      nf (AT.parseOnly (AT.rational :: AT.Parser Scientific)) tNePos
    ]
  , bgroup "negative power"
    [ bench "double" $ nf (AT.parseOnly AT.double) tNeNeg
    , bench "number" $ nf (AT.parseOnly AT.number) tNeNeg
    , bench "rational" $
      nf (AT.parseOnly (AT.rational :: AT.Parser Rational))  tNeNeg
    , bench "scientific" $
      nf (AT.parseOnly (AT.rational :: AT.Parser Scientific)) tNeNeg
    ]
  ]
  , let !bN     = BC.pack strN
        !bNePos = BC.pack strNePos
        !bNeNeg = BC.pack strNeNeg
  in bgroup "ByteString"
  [ bgroup "no power"
    [ bench "double" $ nf (AC.parseOnly AC.double) bN
    , bench "number" $ nf (AC.parseOnly AC.number) bN
    , bench "rational" $
      nf (AC.parseOnly (AC.rational :: AC.Parser Rational))   bN
    , bench "scientific" $
      nf (AC.parseOnly (AC.rational :: AC.Parser Scientific)) bN
    ]
  , bgroup "positive power"
    [ bench "double" $ nf (AC.parseOnly AC.double) bNePos
    , bench "number" $ nf (AC.parseOnly AC.number) bNePos
    , bench "rational" $
      nf (AC.parseOnly (AC.rational :: AC.Parser Rational)) bNePos
    , bench "scientific" $
      nf (AC.parseOnly (AC.rational :: AC.Parser Scientific)) bNePos
    ]
  , bgroup "negative power"
    [ bench "double" $ nf (AC.parseOnly AC.double) bNeNeg
    , bench "number" $ nf (AC.parseOnly AC.number) bNeNeg
    , bench "rational" $
      nf (AC.parseOnly (AC.rational :: AC.Parser Rational)) bNeNeg
    , bench "scientific" $
      nf (AC.parseOnly (AC.rational :: AC.Parser Scientific)) bNeNeg
    ]
  ]
 ]