美文网首页
C++ STL mt19937 使用说明

C++ STL mt19937 使用说明

作者: book_02 | 来源:发表于2019-10-11 20:36 被阅读0次

说明

std::mt19937是伪随机数产生器,用于产生高性能的随机数。 C++11引入。
返回值为unsigned int

std::mt19937接收一个unsigned int数作为种子。所以可以如下定义:

std::mt19937 mt_rand(std::random_device{}());
std::mt19937 mt_rand(time(0));
std::mt19937 mt_rand(std::chrono::system_clock::now().time_since_epoch().count());

名称由来

A Mersenne Twister pseudo-random generator of 32-bit numbers with a state size of 19937 bits.

mt是因为这个伪随机数产生器基于Mersenne Twister算法。
19937是因为产生随的机数的周期长,可达到2^19937-1。

头文件

#include <random>

例子:产生5个伪随机数

#include <iostream>
#include <random>

using namespace std;

int main()
{
    std::mt19937 rng(std::random_device{}());
    for (int i = 0; i < 5; i++) {
        cout << rng() << endl;
    }

    return 0;
}

一种可能结果如下:

476574181
3603119624
1741191339
2689635839
2835258576

std::random_device本身是均匀分布整数随机数生成器,通常仅用于播种

std::random_device rd;
std::mt19937 rng(rd());

通常一步写成std::mt19937 rng(std::random_device{}());

例子:使用特定分布的随机数

分布有很多种,如均匀分布、正态分布等,可参考(https://zh.cppreference.com/w/cpp/numeric/random)
产生特定分布的随机数,需要使用分布函数

产生正态分布的随机数的例子如下:

#include <iostream>
#include <random>

using namespace std;

int main()
{
    std::mt19937 rng(std::random_device{}());
    std::normal_distribution<double> nd(5, 2);
    for (int i = 0; i < 5; i++) {
        cout << nd(rng) << endl;
    }

    return 0;
}

正态接收两个参数:均值和标准差,这里分别输入5,2. 一种可能结果如下:

8.80156
5.78055
4.99761
7.6995
1.21933

参考

http://www.cplusplus.com/reference/random/mt19937/
https://www.cnblogs.com/egmkang/archive/2012/09/06/2673253.html
https://zh.cppreference.com/w/cpp/numeric/random

相关文章

  • C++ STL mt19937 使用说明

    说明 std::mt19937是伪随机数产生器,用于产生高性能的随机数。 C++11引入。返回值为unsigned...

  • 读书笔记17.06.03

    C++ STL:Listlist是C++标准模版库(STL,Standard Template Library)中...

  • [C++] STL 容器

    参考:[C++] STL 容器 (一) - 基本介紹[C++] STL 容器 (二) - Iterator 部分示例:

  • C++ STL 学习笔记

    C++ STL 学习笔记

  • STL之参考文献

    C++标准库是离不开模板的,STL占了C++标准库80%以上。 学习STL(c++ 98)的主要参考: gcc 3...

  • C++ STL multiplies 使用说明

    说明 std::multiplies是乘法的二元函数对象。 常被用于std::transform或者std::ac...

  • C++ STL accumulate 使用说明

    说明 std::accumulate 用于对容器[first,last)内的元素和初始值init进行累积运算。 前...

  • C++ STL shuffle 使用说明

    说明 使用一个随机数产生器来打乱[first, last)之间元素的顺序。 有3个参数,前2个参数指定容器的范围,...

  • 任务列表

    C++ 《C++ primer》、《STL源码解析》、《effective C++》、《深度搜索c++对象模型》 ...

  • STL初认识

    一 C++ 与STL 历史 STL全称standard template library,由Alexander S...

网友评论

      本文标题:C++ STL mt19937 使用说明

      本文链接:https://www.haomeiwen.com/subject/kcwxmctx.html