15a83710eSEric Fiselier //===----------------------------------------------------------------------===// 25a83710eSEric Fiselier // 357b08b09SChandler Carruth // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. 457b08b09SChandler Carruth // See https://llvm.org/LICENSE.txt for license information. 557b08b09SChandler Carruth // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception 65a83710eSEric Fiselier // 75a83710eSEric Fiselier //===----------------------------------------------------------------------===// 85a83710eSEric Fiselier 95a83710eSEric Fiselier // <random> 105a83710eSEric Fiselier 115a83710eSEric Fiselier // template<class UIntType, size_t w, size_t s, size_t r> 125a83710eSEric Fiselier // class subtract_with_carry_engine; 135a83710eSEric Fiselier 145a83710eSEric Fiselier // explicit subtract_with_carry_engine(); 155a83710eSEric Fiselier 165a83710eSEric Fiselier #include <random> 175a83710eSEric Fiselier #include <cassert> 185a83710eSEric Fiselier 19*7fc6a556SMarshall Clow #include "test_macros.h" 20*7fc6a556SMarshall Clow 215a83710eSEric Fiselier void test1()225a83710eSEric Fiseliertest1() 235a83710eSEric Fiselier { 245a83710eSEric Fiselier std::ranlux24_base e1; 255a83710eSEric Fiselier std::ranlux24_base e2(std::ranlux24_base::default_seed); 265a83710eSEric Fiselier assert(e1 == e2); 275a83710eSEric Fiselier assert(e1() == 15039276); 285a83710eSEric Fiselier } 295a83710eSEric Fiselier 305a83710eSEric Fiselier void test2()315a83710eSEric Fiseliertest2() 325a83710eSEric Fiselier { 335a83710eSEric Fiselier std::ranlux48_base e1; 345a83710eSEric Fiselier std::ranlux48_base e2(std::ranlux48_base::default_seed); 355a83710eSEric Fiselier assert(e1 == e2); 365a83710eSEric Fiselier assert(e1() == 23459059301164ull); 375a83710eSEric Fiselier } 385a83710eSEric Fiselier main(int,char **)392df59c50SJF Bastienint main(int, char**) 405a83710eSEric Fiselier { 415a83710eSEric Fiselier test1(); 425a83710eSEric Fiselier test2(); 432df59c50SJF Bastien 442df59c50SJF Bastien return 0; 455a83710eSEric Fiselier } 46