File: RealToFracBenchmark.hs

package info (click to toggle)
ghc 9.6.6-4
  • links: PTS, VCS
  • area: main
  • in suites: forky, trixie
  • size: 158,216 kB
  • sloc: haskell: 648,228; ansic: 81,656; cpp: 11,808; javascript: 8,444; sh: 5,831; fortran: 3,527; python: 3,277; asm: 2,523; makefile: 2,298; yacc: 1,570; lisp: 532; xml: 196; perl: 145; csh: 2
file content (23 lines) | stat: -rw-r--r-- 665 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
{- Contributed by Liyang HU <haskell.org@liyang.hu> -}
module Main where

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

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