--- a/src/Tools/Metis/src/PortableIsabelle.sml Wed Dec 19 23:06:16 2007 +0100
+++ b/src/Tools/Metis/src/PortableIsabelle.sml Wed Dec 19 23:06:16 2007 +0100
@@ -33,27 +33,13 @@
(* Generating random values. *)
(* ------------------------------------------------------------------------- *)
-(* ------------------------------------------------------------------------- *)
-(* Generating random values. *)
-(* ------------------------------------------------------------------------- *)
-
-local
- val gen = Random.newgenseed 1.0;
-in
- fun randomInt max = Random.range (0,max) gen;
+val randomWord = RandomWord.next;
+val randomBool = RandomWord.next_bit;
+fun randomInt n = Word.toInt (Word.mod (randomWord (), Word.fromInt n));
- fun randomReal () = Random.random gen;
-end;
-
-fun randomBool () = randomInt 2 = 0;
-
-fun randomWord () =
- let
- val h = Word.fromInt (randomInt 65536)
- and l = Word.fromInt (randomInt 65536)
- in
- Word.orb (Word.<< (h,0w16), l)
- end;
+val real_word = real o Word.toInt;
+val normalizer = 1.0 / real_word RandomWord.range;
+fun randomReal () = real_word (RandomWord.next ()) * normalizer;
end