2019-10-06 21:47:54 +02:00
|
|
|
/*
|
|
|
|
* 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)
|
|
|
|
*/
|
|
|
|
|
2020-01-20 23:24:04 +01:00
|
|
|
#include <catch2/catch_test_macros.hpp>
|
2019-12-02 12:23:10 +01:00
|
|
|
#include <catch2/catch_random_number_generator.h>
|
2019-10-06 21:47:54 +02:00
|
|
|
|
|
|
|
TEST_CASE("Our PCG implementation provides expected results for known seeds", "[rng]") {
|
|
|
|
Catch::SimplePcg32 rng;
|
|
|
|
SECTION("Default seeded") {
|
|
|
|
REQUIRE(rng() == 0xfcdb943b);
|
|
|
|
REQUIRE(rng() == 0x6f55b921);
|
|
|
|
REQUIRE(rng() == 0x4c17a916);
|
|
|
|
REQUIRE(rng() == 0x71eae25f);
|
|
|
|
REQUIRE(rng() == 0x6ce7909c);
|
|
|
|
}
|
|
|
|
SECTION("Specific seed") {
|
|
|
|
rng.seed(0xabcd1234);
|
|
|
|
REQUIRE(rng() == 0x57c08495);
|
|
|
|
REQUIRE(rng() == 0x33c956ac);
|
|
|
|
REQUIRE(rng() == 0x2206fd76);
|
|
|
|
REQUIRE(rng() == 0x3501a35b);
|
|
|
|
REQUIRE(rng() == 0xfdffb30f);
|
|
|
|
|
|
|
|
// Also check repeated output after reseeding
|
|
|
|
rng.seed(0xabcd1234);
|
|
|
|
REQUIRE(rng() == 0x57c08495);
|
|
|
|
REQUIRE(rng() == 0x33c956ac);
|
|
|
|
REQUIRE(rng() == 0x2206fd76);
|
|
|
|
REQUIRE(rng() == 0x3501a35b);
|
|
|
|
REQUIRE(rng() == 0xfdffb30f);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_CASE("Comparison ops", "[rng]") {
|
|
|
|
using Catch::SimplePcg32;
|
|
|
|
REQUIRE(SimplePcg32{} == SimplePcg32{});
|
|
|
|
REQUIRE(SimplePcg32{ 0 } != SimplePcg32{});
|
|
|
|
REQUIRE_FALSE(SimplePcg32{ 1 } == SimplePcg32{ 2 });
|
|
|
|
REQUIRE_FALSE(SimplePcg32{ 1 } != SimplePcg32{ 1 });
|
|
|
|
}
|