File: Bench.hs

package info (click to toggle)
haskell-bitvec 1.1.5.0-4
  • links: PTS
  • area: main
  • in suites: forky, sid
  • size: 332 kB
  • sloc: haskell: 3,408; ansic: 397; makefile: 5
file content (42 lines) | stat: -rw-r--r-- 1,481 bytes parent folder | download
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
module Main where

import Test.Tasty.Bench
import Test.Tasty.Patterns.Printer

import Bench.BitIndex
import Bench.Common
import Bench.GCD
import Bench.Intersection
import Bench.Invert
import Bench.Product
import Bench.RandomFlip
import Bench.RandomRead
import Bench.RandomWrite
import Bench.Remainder
import Bench.Reverse
import Bench.Sum
import Bench.Union

main :: IO ()
main = defaultMain $ map (mapLeafBenchmarks addCompare)
  [ bgroup "add"          $ map benchAdd          [5..14]
  , bgroup "bitIndex"     $ map benchBitIndex     [5..14]
  , bgroup "flip"         $ map benchRandomFlip   [5..14]
  , bgroup "gcdExt"       $ map benchGCD          [5..14]
  , bgroup "intersection" $ map benchIntersection [5..14]
  , bgroup "invert"       $ map benchInvert       [5..14]
  , bgroup "product"      $ map benchProduct      [5..14]
  , bgroup "productShort" $ map benchProductShort [5..14]
  , bgroup "read"         $ map benchRandomRead   [5..14]
  , bgroup "remainder"    $ map benchRemainder    [5..11]
  , bgroup "reverse"      $ map benchReverse      [5..14]
  , bgroup "square"       $ map benchSquare       [5..14]
  , bgroup "sum"          $ map benchSum          [5..14]
  , bgroup "union"        $ map benchUnion        [5..20]
  , bgroup "write"        $ map benchRandomWrite  [5..14]
  ]

addCompare :: ([String] -> Benchmark -> Benchmark)
addCompare (name : path)
  | name /= labelBit = bcompare (printAwkExpr (locateBenchmark (labelBit : path)))
addCompare _ = id