blob: f7e906050c3b6ae68d017a08461a89060a1f9d7b [file] [log] [blame]
// Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file
// for details. All rights reserved. Use of this source code is governed by a
// BSD-style license that can be found in the LICENSE file.
// Test that the default PRNG does uniformly distribute values when not using
// a power of 2.
import "package:expect/expect.dart";
import 'dart:math';
void main() {
var n = (2 * 0x100000000) ~/ 3;
var n2 = n ~/ 2;
var iterations = 200000;
var seed = new Random().nextInt(1 << 16);
print("low_test seed: $seed");
var prng = new Random(seed);
var low = 0;
for (var i = 0; i < iterations; i++) {
if (prng.nextInt(n) < n2) {
low++;
}
}
var diff = (low - (iterations ~/ 2)).abs();
print("$low, $diff");
Expect.isTrue(diff < (iterations ~/ 20));
}