一様分布で乱数生成したい(TRandomMixMax::Uniform)
1#include <TRandomMixMax.h>
2// 乱数生成器を初期化
3TRandomMixMax rng;
4// 0から1の一様乱数を生成
5double randomValue = rng.Uniform(0, 1);
TRandomMixMax::Uniformで一様乱数を生成できます。
引数に下限と上限を指定することで、その範囲内の乱数を取得できます。
一様分布のヒストグラムを作りたい
1#include <TCanvas.h>
2#include <TH1D.h>
3#include <TRandomMixMax.h>
4
5TCanvas *c = new TCanvas("c", "Uniform Distribution", 800, 600);
6TH1D *h = new TH1D("h", "Uniform Distribution", 100, 0, 1);
7
8TRandomMixMax rng;
9for (int i = 0; i < 10000; i++) {
10 h->Fill(rng.Uniform(0, 1));
11}
12
13h->Draw();
このサンプルでは、0から1の一様分布にしたがう乱数を10000個生成し、その分布をヒストグラムで可視化しています。