subtract_with_carry_01::seed

エンジンにシードを与えます。

template<class Gen>
    void seed(Gen& gen);
void seed(result_type x0 = 19780503UL);

パラメーター

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

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

  • x0
    シード値。

解説

前提条件 : 0 < x0

1 つ目のシード関数は、gen の連続呼び出しによって返された unsigned long 型の値から、long_lag の履歴値を生成します。それぞれの履歴値は、初期化シーケンスから得られた各 long_lag * (word_size + 31) / 32 値の下位 32 ビットを連結することによって生成されます。その結果の値が、2.0word_size で除算され、整数部分が破棄されます。したがって、各履歴値は、word_size の有効ビットを持つ、0.0 以上、1.0 未満の浮動小数点値となります。

2 つ目のシード関数は、実質的に次のコードを実行します。

    linear_congruential<unsigned long, 40014, 0, 2147483563> gen(x0);
    seed(gen);

使用例

 

// std_tr1__random__subtract_with_carry_01_seed.cpp 
// compile with: /EHsc 
#include <random> 
#include <iostream> 
 
typedef std::mt19937 Myeng; 
typedef std::subtract_with_carry_01<float, 24, 10, 24> Myceng; 
int main() 
    { 
    Myeng eng; 
    Myceng ceng; 
    Myceng::result_type compval = ceng(); 
 
    compval = compval;  // to quiet "unused" warnings 
 
    std::cout << "W == " << Myceng::word_size << std::endl; 
    std::cout << "S == " << Myceng::short_lag << std::endl; 
    std::cout << "R == " << Myceng::long_lag << 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 
 
    Myceng ceng3(5UL);  // construct with unsigned long seed 
    ceng3.seed(5UL);  // seed with unsigned long 
 
    return (0); 
    } 
 
  

必要条件

ヘッダー : <random>

名前空間: std

参照

関連項目

<random>

subtract_with_carry_01 クラス