Files
cryptonum/test-generator/Database.hs

32 lines
923 B
Haskell

module Database(
Database,
emptyDatabase,
generateNum, genSign
)
where
import Data.Map.Strict(Map)
import qualified Data.Map.Strict as Map
import Math(modulate)
import System.Random(StdGen, random)
type Database = (Map String [Integer], StdGen)
emptyDatabase :: StdGen -> Database
emptyDatabase g0 = (Map.empty, g0)
generateNum :: Database -> String -> Int -> (Integer, Database)
generateNum (db, rng0) varname size =
let (x, rng1) = random rng0
x' = modulate x size
before = Map.findWithDefault [] varname db
in if length (filter (== x') before) < 10
then (x', (Map.insert varname (x':before) db, rng1))
else generateNum (db, rng1) varname size
genSign :: (Integer, Database) -> (Integer, Database)
genSign (x, (db, rng0)) =
let (n, rng1) = random rng0
in if n then (0 - x, (db, rng1)) else (x, (db, rng1))