linear_congruential::linear_congruential

エンジンを構築します。

explicit linear_congruential(UIntType x0 = default_seed)
template<class Gen>
    linear_congruential(Gen& gen);
linear_congruential(const linear_congruential& right);
linear_congruential(linear_congruential& right);

パラメーター

  • x0
    シード値。

  • Gen
    シード ジェネレーターの型。

  • gen
    シード ジェネレーター。

  • right
    linear_congruential オブジェクト。

解説

1 つ目のコンストラクターは、seed(x0) を呼び出すことによって linear_congruential オブジェクトを構築し、初期化します。2 つ目のコンストラクターは、seed(gen) を呼び出すことによって linear_congruential オブジェクトを構築し、初期化します。3 つ目と 4 つ目のコンストラクターは、linear_congruential オブジェクトをコピーして linear_congruential オブジェクトを作成します。

使用例

 

// std_tr1__random__linear_congruential_construct.cpp 
// compile with: /EHsc 
#include <random> 
#include <iostream> 
 
typedef std::mt19937 Myeng; 
typedef std::linear_congruential<int, 16807, 0, 
    (int)((1U << 31) - 1)> Myceng;  // same as minstd_rand0 
int main() 
    { 
    Myeng eng; 
    Myceng ceng; 
    Myceng::result_type compval = ceng(); 
 
    compval = compval;  // to quiet "unused" warnings 
 
    std::cout << "A == " << Myceng::multiplier << std::endl; 
    std::cout << "C == " << Myceng::increment << std::endl; 
    std::cout << "M == " << Myceng::modulus << std::endl; 
    std::cout << "min == " << ceng.min() << std::endl; 
    std::cout << "max == " << ceng.max() << std::endl; 
 
    ceng.seed(); // reseed base engine 
    std::cout << "a random value == " << ceng() << std::endl; 
    std::cout << "a random value == " << ceng() << std::endl; 
    std::cout << "a random value == " << ceng() << std::endl; 
 
    Myceng ceng2(eng); // construct with generator 
    ceng2.seed(eng);  // seed with generator 
 
    return (0); 
    } 
 
  

必要条件

ヘッダー : <random>

名前空間: std

参照

関連項目

<random>

linear_congruential クラス