File: RealToFracBenchmark.hs

package info (click to toggle)
ghc 8.0.1-17
  • links: PTS, VCS
  • area: main
  • in suites: stretch
  • size: 55,080 kB
  • ctags: 9,332
  • sloc: haskell: 363,120; ansic: 54,900; sh: 4,782; makefile: 974; perl: 542; asm: 315; python: 306; xml: 154; lisp: 7
file content (22 lines) | stat: -rw-r--r-- 616 bytes parent folder | download | duplicates (8)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
{- Contributed by Liyang HU <haskell.org@liyang.hu> -}
module Main where

import Prelude
import Control.Applicative
import Control.Monad
import Control.DeepSeq
import Data.Time
import Data.Time.Clock.POSIX
import System.Random

main :: IO ()
main = do
    ts <- replicateM 100000 $ do
        t <- posixSecondsToUTCTime . realToFrac <$>
            ( (*) . fromInteger <$> randomRIO (-15*10^21, 15*10^21) <*>
                randomIO :: IO Double ) :: IO UTCTime
        rnf t `seq` return t
    now <- getCurrentTime
    print . sum $ map (diffUTCTime now) ts
    print =<< flip diffUTCTime now <$> getCurrentTime