{-# LANGUAGE DeriveAnyClass, DeriveGeneric, FlexibleInstances, StandaloneDeriving #-} {-# OPTIONS_GHC -fno-warn-orphans #-} module Main where import Criterion.Main import Data.String import Patch import Prologue import Test.QuickCheck hiding (Fixed) main :: IO () main = do benchmarks <- sequenceA [] defaultMain benchmarks instance NFData a => NFData (Patch a) -- | Defines a named group of n benchmarks over inputs generated by an `Arbitrary` instance. -- | -- | The inputs’ sizes at each iteration are measured by a metric function, which gives the name of the benchmark. This makes it convenient to correlate a benchmark of some function over lists with e.g. input `length`. generativeBenchmark :: (Arbitrary a, Show m, Ord m) => String -> Int -> (a -> m) -> (a -> Benchmarkable) -> IO Benchmark generativeBenchmark name n metric benchmark = do benchmarks <- traverse measure (replicate n defaultSize) pure $! bgroup name (snd <$> (sortOn fst benchmarks)) where measure n = do input <- generate (resize n arbitrary) let measurement = metric input pure $! (measurement, bench (show measurement) (benchmark input)) defaultSize = 100