Plan 9 from Bell Labs’s /usr/web/sources/contrib/fernan/nhc98/tests/nofib/spectral/primetest/Random.lhs

Copyright © 2021 Plan 9 Foundation.
Distributed under the MIT License.
Download the Plan 9 distribution.


\section{Random Numbers}
%$Log: Random.lhs,v $
%Revision 1.1  2004/08/05 11:13:39  malcolm
%Add a regression testsuite for the nhc98 compiler.  It isn't very good,
%but it is better than nothing.  I've been using it for about four years
%on nightly builds, so it's about time it entered the repository!  It
%includes a slightly altered version of the nofib suite.
%Instructions are in the README.
%
%Revision 1.1  1996/01/08 20:04:20  partain
%Initial revision
%
%Revision 1.1  92/06/30  15:54:46  dlester
%Initial revision
%

A call to @randomInts@ with two @Int@ arguments generates a
pseudo-random sequence of @Int@'s.

> module Random (randomInts) where

Use seeds s1 in 1..2147483562 and s2 in 1..2147483398 to generate an
infinite list of random Ints. (Algorithm due to Lennart Augustsson)

> randomInts :: Int -> Int -> [Int]
> randomInts s1 s2 = if 1 <= s1 && s1 <= 2147483562 then
>                    if 1 <= s2 && s2 <= 2147483398 then rands s1 s2
>                    else error "randomInts: Bad second seed."
>                    else error "randomInts: Bad first seed."

> rands :: Int -> Int -> [Int]
> rands s1 s2 =
>     let
>       k    = s1 `div` 53668
>       s1'  = 40014 * (s1 - k * 53668) - k * 12211
>       s1'' = if s1' < 0 then s1' + 2147483563 else s1'
>       k'   = s2 `div` 52774
>       s2'  = 40692 * (s2 - k' * 52774) - k' * 3791
>       s2'' = if s2' < 0 then s2' + 2147483399 else s2'
>       z    = s1'' - s2''
>     in  if z < 1 then z + 2147483562 : rands s1'' s2''
>                  else z : rands s1'' s2''


Bell Labs OSI certified Powered by Plan 9

(Return to Plan 9 Home Page)

Copyright © 2021 Plan 9 Foundation. All Rights Reserved.
Comments to [email protected].