diff --git a/.appveyor.yml b/.appveyor.yml deleted file mode 100644 index 7b6a043..0000000 --- a/.appveyor.yml +++ /dev/null @@ -1,18 +0,0 @@ -build: off - -before_test: - # http://help.appveyor.com/discussions/problems/6312-curl-command-not-found - - set PATH=C:\Program Files\Git\mingw64\bin;%PATH% - - curl -sS -o stack.zip -L --insecure http://www.stackage.org/stack/windows-i386 - - 7z x stack.zip stack.exe - -clone_folder: "c:\\stack" -environment: - global: - STACK_ROOT: "c:\\sr" - -test_script: - - stack setup > nul - # The ugly echo "" hack is to avoid complaints about 0 being an invalid file - # descriptor - - echo "" | stack --no-terminal test mwc-random-bench:mwc-prop-tests \ No newline at end of file diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index b16d2bb..5e17be0 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -18,29 +18,40 @@ jobs: matrix: include: ### -- Linux -- - - { cabal: "3.4", os: ubuntu-latest, ghc: "7.10.3" } - - { cabal: "3.4", os: ubuntu-latest, ghc: "8.0.2" } - - { cabal: "3.4", os: ubuntu-latest, ghc: "8.2.2" } - - { cabal: "3.4", os: ubuntu-latest, ghc: "8.4.4" } - - { cabal: "3.4", os: ubuntu-latest, ghc: "8.6.5" } - - { cabal: "3.4", os: ubuntu-latest, ghc: "8.8.4" } - - { cabal: "3.4", os: ubuntu-latest, ghc: "8.10.7" } - - { cabal: "3.4", os: ubuntu-latest, ghc: "9.0.1" } - - { cabal: "3.6", os: ubuntu-latest, ghc: "9.2.1", skip-bench: "true" } + - { cabal: "3.10", os: ubuntu-latest, ghc: "8.0.2" } + - { cabal: "3.10", os: ubuntu-latest, ghc: "8.2.2" } + - { cabal: "3.10", os: ubuntu-latest, ghc: "8.4.4" } + - { cabal: "3.10", os: ubuntu-latest, ghc: "8.6.5" } + - { cabal: "3.10", os: ubuntu-latest, ghc: "8.8.4" } + - { cabal: "3.10", os: ubuntu-latest, ghc: "8.10.7" } + - { cabal: "3.10", os: ubuntu-latest, ghc: "9.0.2" } + - { cabal: "3.10", os: ubuntu-latest, ghc: "9.2.8" } + - { cabal: "3.10", os: ubuntu-latest, ghc: "9.4.8" } + - { cabal: "3.10", os: ubuntu-latest, ghc: "9.6.5" } + - { cabal: "3.10", os: ubuntu-latest, ghc: "9.6.5" } + - { cabal: "3.10", os: ubuntu-latest, ghc: "9.8.2" } ## -- Win -- - - { cabal: "3.4", os: windows-latest, ghc: "8.4.4" } - - { cabal: "3.4", os: windows-latest, ghc: "8.6.5" } - - { cabal: "3.4", os: windows-latest, ghc: "8.8.4" } - - { cabal: "3.4", os: windows-latest, ghc: "8.10.7" } - - { cabal: "3.4", os: windows-latest, ghc: "9.0.1" } - - { cabal: "3.6", os: windows-latest, ghc: "9.2.1", skip-bench: "true" } + - { cabal: "3.10", os: windows-latest, ghc: "8.4.4" } + - { cabal: "3.10", os: windows-latest, ghc: "8.6.5" } + - { cabal: "3.10", os: windows-latest, ghc: "8.8.4" } + - { cabal: "3.10", os: windows-latest, ghc: "8.10.7" } + - { cabal: "3.10", os: windows-latest, ghc: "9.0.2" } + - { cabal: "3.10", os: windows-latest, ghc: "9.2.8" } + - { cabal: "3.10", os: windows-latest, ghc: "9.4.8" } + - { cabal: "3.10", os: windows-latest, ghc: "9.6.5" } + - { cabal: "3.10", os: windows-latest, ghc: "9.6.5" } + - { cabal: "3.10", os: windows-latest, ghc: "9.8.2" } # MacOS - - { cabal: "3.4", os: macOS-latest, ghc: "8.4.4" } - - { cabal: "3.4", os: macOS-latest, ghc: "8.6.5" } - - { cabal: "3.4", os: macOS-latest, ghc: "8.8.4" } - - { cabal: "3.4", os: macOS-latest, ghc: "8.10.7" } - - { cabal: "3.4", os: macOS-latest, ghc: "9.0.1" } - - { cabal: "3.6", os: macOS-latest, ghc: "9.2.1", skip-bench: "true" } + - { cabal: "3.10", os: macOS-13, ghc: "8.4.4" } + - { cabal: "3.10", os: macOS-13, ghc: "8.6.5" } + - { cabal: "3.10", os: macOS-13, ghc: "8.8.4" } + - { cabal: "3.10", os: macOS-13, ghc: "8.10.7" } + - { cabal: "3.10", os: macOS-13, ghc: "9.0.2" } + - { cabal: "3.10", os: macOS-latest, ghc: "9.2.8" } + - { cabal: "3.10", os: macOS-latest, ghc: "9.4.8" } + - { cabal: "3.10", os: macOS-latest, ghc: "9.6.5" } + - { cabal: "3.10", os: macOS-latest, ghc: "9.6.5" } + - { cabal: "3.10", os: macOS-latest, ghc: "9.8.2" } fail-fast: false steps: @@ -50,21 +61,27 @@ jobs: echo M1 ${{ matrix.ghc }} echo M2 ${{ matrix.skip-bench }} # ---------------- - - uses: actions/checkout@v2 + - uses: actions/checkout@v4 # ---------------- - - uses: haskell/actions/setup@v1 + - uses: haskell-actions/setup@v2 id: setup-haskell-cabal name: Setup Haskell with: ghc-version: ${{ matrix.ghc }} cabal-version: ${{ matrix.cabal }} # ---------------- - - uses: actions/cache@v1 + - uses: actions/cache@v3 name: Cache ~/.cabal/store with: path: ${{ steps.setup-haskell-cabal.outputs.cabal-store }} key: ${{ runner.os }}-${{ matrix.ghc }}--${{ github.Shah }} # ---------------- + - name: "Install PAPI" + run: | + sudo apt-get install -y libpapi-dev + echo FLAG_PAPI=-fBenchPAPI >> "$GITHUB_ENV" + if: matrix.os == 'ubuntu-latest' + # ---------------- - name: Versions run: | cabal -V @@ -87,10 +104,16 @@ jobs: - name: Build run: | if [ "${{ matrix.skip-test }}" == "" ]; then FLAG_TEST=--enable-test; fi - if [ "${{ matrix.skip-bench }}" == "" ]; then FLAG_BENCH=--enable-benchmarks; fi - cabal configure $FLAG_TEST $FLAG_BENCH + if [ "${{ matrix.skip-bench }}" == "" ]; then + FLAG_BENCH="--enable-benchmarks --benchmark-option=-l" + fi + cabal configure $FLAG_TEST $FLAG_BENCH $FLAG_PAPI --haddock-all cabal build all --write-ghc-environment-files=always # ---------------- - name: Test run: | cabal test all + # ---------------- + - name: Bench + run: | + cabal bench all diff --git a/.hgignore b/.hgignore deleted file mode 100644 index bea5a60..0000000 --- a/.hgignore +++ /dev/null @@ -1,5 +0,0 @@ -^(?:benchmarks/dist|dist)$ -\.(?:aux|eventlog|h[ip]|log|[oa]|orig|prof|ps|swp)$ -~$ -syntax: glob -.\#* diff --git a/.hgtags b/.hgtags deleted file mode 100644 index 3853772..0000000 --- a/.hgtags +++ /dev/null @@ -1,38 +0,0 @@ -00b3f86bf9dd72a1e6057af18e7ca6514f50b284 0.4.1.1 -0875b35d18480666846683ed295926018957036b 0.5.1.3 -3e078fd211d814adbe3b11549e1686396b9ff860 0.4.1 -47bb0bcf7b1da329db82da8e39958003206e74f7 0.5.1.0 -c6e7fbd872c866a08a8458f4fcdd70a3f642aa7b 0.5.1.1 -50c7dc69d1f87b63443c1aaf1a950c812c7d2144 0.5.1.2 -5dab25696615958083a12f01f94c10c2183bc075 0.5.1.4 -7c11c654eeba3dbeb44ff7a3b638ef3c6a10c8d6 0.6.0.0 -80543563333435c78a51575c6a056dc6dc740af5 0.7.0.1 -c6e7fbd872c866a08a8458f4fcdd70a3f642aa7b 0.5.1.1 -45ae16e37f262f39a45d974d3e218e6ae6d3d26a 0.8.0.0 -be4127304f451ba126cef98e3d806105deaaf36b 0.8.0.1 -67f1bbc1490bdd6c5dac770f764d2c9cdbdab9d8 0.8.0.2 -67f1bbc1490bdd6c5dac770f764d2c9cdbdab9d8 0.8.0.2 -28a3a8dcbbf2146a823a79e31334215c14994222 0.8.0.2 -78e34a9a84dae6d29a4b2c7610fe63dc07765fc8 0.8.0.3 -a8d79db3a4adf97868c273a231b72a9827a3680a 0.8.0.4 -986216427670031a305db5544eb7bbdd9fbffe71 0.8.0.5 -1a631d80174f8ad197c1a44fc7d6cb4a93421c0c 0.9.0.0 -71191fcedf2305373c29a1bffdbedd41a7f0d404 0.10.0.0 -af221ff2479f829364d14ab50716426ff67b0bac 0.10.0.1 -e1d6653cb4be57d954ed21005ae06cbe9a6c6b73 0.11.0.0 -e1d6653cb4be57d954ed21005ae06cbe9a6c6b73 0.11.0.0 -2c176f268c27cee741f68c1271c40b676f956a1f 0.11.0.0 -f876b418646a3c4f7e6f5a1bcc482fd25cc13b8a 0.12.0.0 -6d927fbf8e83f59a857a986eff4c2309f5b82b98 0.12.0.1 -c8ef9b6ed671b719e83d33df0354580b4f8fb1f1 0.13.0.0 -dbda280e36a4f5d6ee4f542ece709937881a95d0 0.13.1.1 -4b27557f7467e5753a3da6ddd8a3dfb3483a85f0 0.13.1.2 -e0eebf73fcbe911bfb02c1c175f07e5f8076178f 0.13.2.0 -d47c186eda1c80f1dd7098e861f20de289892c1f 0.13.2.1 -e5acaeb916c79aa8c1ef50127346be271fc78ac7 0.13.2.2 -a033a78c2f33835779866db7dcd6087845c9f5e8 0.13.3.0 -b71f9e27689cf21ed6ad61ec84706ce06f9440db 0.13.3.1 -2b5be7401599dbbda6d20689b6067356e558fa67 0.13.3.2 -ab8886890748bd4f5034ce57b486b5125cb1333b 0.13.4.0 -b2647549015dd978857951f07612855491468839 0.13.5.0 -0b04e85d18b7dcce0e43a98ace4433a1483f3a9b 0.13.6.0 diff --git a/System/Random/MWC.hs b/System/Random/MWC.hs index 0efbc1a..726e603 100644 --- a/System/Random/MWC.hs +++ b/System/Random/MWC.hs @@ -1,6 +1,6 @@ {-# LANGUAGE BangPatterns, CPP, DeriveDataTypeable, FlexibleContexts, FlexibleInstances, MultiParamTypeClasses, MagicHash, Rank2Types, - ScopedTypeVariables, TypeFamilies, UnboxedTuples + ScopedTypeVariables, TypeFamilies, UnboxedTuples, TypeOperators #-} -- | -- Module : System.Random.MWC @@ -167,6 +167,7 @@ import Data.IORef (IORef, atomicModifyIORef, newIORef) import Data.Typeable (Typeable) import Data.Vector.Generic (Vector) import Data.Word +import Data.Kind import qualified Data.Vector.Generic as G import qualified Data.Vector.Generic.Mutable as GM import qualified Data.Vector.Unboxed as I @@ -623,7 +624,7 @@ uniform2 f (Gen q) = do -- Type family for fixed size integrals. For signed data types it's -- its unsigned counterpart with same size and for unsigned data types -- it's same type -type family Unsigned a :: * +type family Unsigned a :: Type type instance Unsigned Int8 = Word8 type instance Unsigned Int16 = Word16 diff --git a/System/Random/MWC/SeedSource.hs b/System/Random/MWC/SeedSource.hs index 6018ba0..31b1931 100644 --- a/System/Random/MWC/SeedSource.hs +++ b/System/Random/MWC/SeedSource.hs @@ -30,7 +30,7 @@ import System.IO (IOMode(..), hGetBuf, withBinaryFile) -- Windows system. acquireSeedTime :: IO [Word32] acquireSeedTime = do - c <- (numerator . (%cpuTimePrecision)) `liftM` getCPUTime + c <- (numerator . (% cpuTimePrecision)) `liftM` getCPUTime t <- toRational `liftM` getPOSIXTime let n = fromIntegral (numerator t) :: Word64 return [fromIntegral c, fromIntegral n, fromIntegral (n `shiftR` 32)] diff --git a/bench-papi/Bench.hs b/bench-papi/Bench.hs new file mode 100644 index 0000000..b1b748a --- /dev/null +++ b/bench-papi/Bench.hs @@ -0,0 +1,13 @@ +-- | +-- Here we reexport definitions of tasty-bench +module Bench + ( whnf + , nf + , nfIO + , whnfIO + , bench + , bgroup + , defaultMain + ) where + +import Test.Tasty.PAPI diff --git a/bench-time/Bench.hs b/bench-time/Bench.hs new file mode 100644 index 0000000..2eae909 --- /dev/null +++ b/bench-time/Bench.hs @@ -0,0 +1,13 @@ +-- | +-- Here we reexport definitions of tasty-bench +module Bench + ( whnf + , nf + , nfIO + , whnfIO + , bench + , bgroup + , defaultMain + ) where + +import Test.Tasty.Bench diff --git a/bench/Benchmark.hs b/bench/Benchmark.hs index 6a844bc..53726f9 100644 --- a/bench/Benchmark.hs +++ b/bench/Benchmark.hs @@ -1,8 +1,6 @@ {-# LANGUAGE BangPatterns #-} import Control.Exception import Control.Monad -import Control.Monad.ST -import Gauge.Main import Data.Int import Data.Word import qualified Data.Vector.Unboxed as U @@ -12,12 +10,14 @@ import System.Random.MWC.Distributions import System.Random.MWC.CondensedTable import qualified System.Random.Mersenne as M +import Bench + makeTableUniform :: Int -> CondensedTable U.Vector Int makeTableUniform n = tableFromProbabilities $ U.zip (U.enumFromN 0 n) (U.replicate n (1 / fromIntegral n)) {-# INLINE makeTableUniform #-} - +main :: IO () main = do mwc <- create mtg <- M.newMTGen . Just =<< uniform mwc diff --git a/bench/Quickie.hs b/bench/Quickie.hs deleted file mode 100644 index 2418b8f..0000000 --- a/bench/Quickie.hs +++ /dev/null @@ -1,13 +0,0 @@ -{-# LANGUAGE BangPatterns #-} -import System.Random.MWC (create, uniform) -import Control.Monad.ST (ST, runST) - -u :: ST s Double -u = do - let last = 1000000 :: Int - gen <- create - let loop !n !i | n == last = return i - | otherwise = uniform gen >>= loop (n+1) - loop 0 0 - -main = print (runST u) diff --git a/mwc-random.cabal b/mwc-random.cabal index 88f2be3..bcd5b3a 100644 --- a/mwc-random.cabal +++ b/mwc-random.cabal @@ -1,5 +1,17 @@ +cabal-version: 3.0 +build-type: Simple name: mwc-random version: 0.15.0.2 +license: BSD-2-Clause +license-file: LICENSE +copyright: 2009, 2010, 2011 Bryan O'Sullivan + +author: Bryan O'Sullivan +maintainer: Alexey Khudyakov +homepage: https://github.com/haskell/mwc-random +bug-reports: https://github.com/haskell/mwc-random/issues + +category: Math, Statistics synopsis: Fast, high quality pseudo random number generation description: This package contains code for generating high quality random @@ -15,29 +27,35 @@ description: convenient API, is faster, and supports more statistical distributions. -license: BSD3 -license-file: LICENSE -homepage: https://github.com/bos/mwc-random -bug-reports: https://github.com/bos/mwc-random/issues -author: Bryan O'Sullivan -maintainer: Bryan O'Sullivan -copyright: 2009, 2010, 2011 Bryan O'Sullivan -category: Math, Statistics -build-type: Simple -cabal-version: >= 1.10 + extra-source-files: changelog.md README.md tested-with: - GHC ==7.10.3 - || ==8.0.2 - || ==8.2.2 - || ==8.4.4 - || ==8.6.5 - || ==8.8.3 - || ==8.10.1 - , GHCJS ==8.4 + GHC ==8.0.2 + || ==8.2.2 + || ==8.4.4 + || ==8.6.5 + || ==8.8.4 + || ==8.10.7 + || ==9.0.2 + || ==9.2.8 + || ==9.4.8 + || ==9.6.5 + || ==9.6.5 + || ==9.8.2 + + +source-repository head + type: git + location: git://github.com/haskell/mwc-random + +flag BenchPAPI + Description: Enable building of benchmarks which use instruction counters. + It requires libpapi and only works on Linux so it's protected by flag + Default: False + Manual: True library default-language: Haskell2010 @@ -45,7 +63,7 @@ library System.Random.MWC.Distributions System.Random.MWC.CondensedTable System.Random.MWC.SeedSource - build-depends: base >= 4.8 && < 5 + build-depends: base >= 4.9 && < 5 , primitive >= 0.6.2 , random >= 1.2 , time @@ -55,27 +73,35 @@ library ghc-options: -Wall -funbox-strict-fields -fwarn-tabs -source-repository head - type: git - location: git://github.com/bos/mwc-random - -source-repository head - type: mercurial - location: https://bitbucket.org/bos/mwc-random - - -benchmark mwc-bench - type: exitcode-stdio-1.0 - hs-source-dirs: bench - main-is: Benchmark.hs +-- We want to be able to build benchmarks using both tasty-bench and tasty-papi. +-- They have similar API so we just create two shim modules which reexport +-- definitions from corresponding library and pick one in cabal file. +common bench-stanza + ghc-options: -Wall default-language: Haskell2010 build-depends: base < 5 , vector >= 0.11 - , gauge >= 0.2.5 , mersenne-random , mwc-random , random +benchmark mwc-bench + import: bench-stanza + type: exitcode-stdio-1.0 + hs-source-dirs: bench bench-time + main-is: Benchmark.hs + Other-modules: Bench + build-depends: tasty-bench >= 0.3 + +benchmark mwc-bench-papi + import: bench-stanza + type: exitcode-stdio-1.0 + if impl(ghcjs) || !flag(BenchPAPI) || impl(ghc < 8.2) + buildable: False + hs-source-dirs: bench bench-papi + main-is: Benchmark.hs + Other-modules: Bench + build-depends: tasty-papi >= 0.1.2 test-suite mwc-prop-tests type: exitcode-stdio-1.0 @@ -100,10 +126,15 @@ test-suite mwc-doctests default-language: Haskell2010 if impl(ghcjs) || impl(ghc < 8.0) Buildable: False + -- Linker on macos prints warnings to console which confuses doctests. + -- We simply disable doctests on ma for older GHC + -- > warning: -single_module is obsolete + if os(darwin) && impl(ghc < 9.6) + buildable: False build-depends: base -any , mwc-random -any - , doctest >=0.15 && <0.20 + , doctest >=0.15 && <0.23 -- , bytestring , primitive