1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46
|
/***************************************************************************
* tests/common/test_random.cpp
*
* Part of the STXXL. See http://stxxl.sourceforge.net
*
* Copyright (C) 2007, 2008 Andreas Beckmann <beckmann@cs.uni-frankfurt.de>
*
* Distributed under the Boost Software License, Version 1.0.
* (See accompanying file LICENSE_1_0.txt or copy at
* http://www.boost.org/LICENSE_1_0.txt)
**************************************************************************/
#include <iostream>
#include <stxxl/random>
#include <stxxl/bits/verbose.h>
int main()
{
//stxxl::set_seed(42);
std::cout << "seed = " << stxxl::get_next_seed() << std::endl;
stxxl::srandom_number32(stxxl::get_next_seed());
stxxl::random_number32 random_number32;
stxxl::random_number32_r random_number32_r;
stxxl::random_uniform_fast random_uniform_fast;
stxxl::random_uniform_slow random_uniform_slow;
stxxl::random_number<> random_number_fast;
stxxl::random_number<stxxl::random_uniform_slow> random_number_slow;
stxxl::random_number64 random_number64;
for (int i = 0; i < 3; ++i) {
std::cout << "r32 " << random_number32() << std::endl;
std::cout << "r3r " << random_number32_r() << std::endl;
std::cout << "ruf " << random_uniform_fast() << std::endl;
std::cout << "rus " << random_uniform_slow() << std::endl;
std::cout << "rnf " << random_number_fast(42) << std::endl;
std::cout << "rns " << random_number_slow(42) << std::endl;
std::cout << "r64 " << random_number64() << std::endl;
std::cout << std::endl;
}
stxxl::set_seed(42);
STXXL_CHECK(stxxl::get_next_seed() == 42);
STXXL_CHECK(stxxl::get_next_seed() != 42);
}
|