Kelas poisson_distribution
Menghasilkan distribusi Poisson.
Sintaks
template<class IntType = int>
class poisson_distribution
{
public:
// types
typedef IntType result_type;
struct param_type;
// constructors and reset functions
explicit poisson_distribution(double mean = 1.0);
explicit poisson_distribution(const param_type& parm);
void reset();
// generating functions
template <class URNG>
result_type operator()(URNG& gen);
template <class URNG>
result_type operator()(URNG& gen, const param_type& parm);
// property functions
double mean() const;
param_type param() const;
void param(const param_type& parm);
result_type min() const;
result_type max() const;
};
Parameter
IntType
Jenis hasil bilangan bulat, default ke int
. Untuk jenis yang mungkin, lihat acak>.<
Keterangan
Templat kelas menjelaskan distribusi yang menghasilkan nilai jenis integral yang ditentukan pengguna dengan distribusi Poisson. Tabel berikut ini menautkan ke artikel tentang masing-masing anggota.
poisson_distribution
param_type
Fungsi mean()
properti mengembalikan nilai untuk rata-rata parameter distribusi tersimpan.
Anggota param()
properti menetapkan atau mengembalikan paket parameter distribusi tersimpan param_type
.
Fungsi min()
anggota dan max()
mengembalikan hasil sekecil mungkin dan hasil terbesar yang mungkin, masing-masing.
Fungsi reset()
anggota membuang nilai cache apa pun, sehingga hasil panggilan operator()
berikutnya tidak bergantung pada nilai apa pun yang diperoleh dari mesin sebelum panggilan.
Fungsi operator()
anggota mengembalikan nilai yang dihasilkan berikutnya berdasarkan mesin URNG, baik dari paket parameter saat ini, atau paket parameter yang ditentukan.
Untuk informasi selengkapnya tentang kelas distribusi dan anggotanya, lihat acak>.<
Untuk informasi terperinci tentang distribusi Poisson, lihat artikel Wolfram MathWorld Distribusi Poisson.
Contoh
// compile with: /EHsc /W4
#include <random>
#include <iostream>
#include <iomanip>
#include <string>
#include <map>
void test(const double p, const int s) {
// uncomment to use a non-deterministic generator
// std::random_device gen;
std::mt19937 gen(1701);
std::poisson_distribution<> distr(p);
std::cout << std::endl;
std::cout << "min() == " << distr.min() << std::endl;
std::cout << "max() == " << distr.max() << std::endl;
std::cout << "p() == " << std::fixed << std::setw(11) << std::setprecision(10) << distr.mean() << std::endl;
// generate the distribution as a histogram
std::map<int, int> histogram;
for (int i = 0; i < s; ++i) {
++histogram[distr(gen)];
}
// print results
std::cout << "Distribution for " << s << " samples:" << std::endl;
for (const auto& elem : histogram) {
std::cout << std::setw(5) << elem.first << ' ' << std::string(elem.second, ':') << std::endl;
}
std::cout << std::endl;
}
int main()
{
double p_dist = 1.0;
int samples = 100;
std::cout << "Use CTRL-Z to bypass data entry and run using default values." << std::endl;
std::cout << "Enter a floating point value for the 'mean' distribution parameter (must be greater than zero): ";
std::cin >> p_dist;
std::cout << "Enter an integer value for the sample count: ";
std::cin >> samples;
test(p_dist, samples);
}
Tes pertama:
Use CTRL-Z to bypass data entry and run using default values.
Enter a floating point value for the 'mean' distribution parameter (must be greater than zero): 1
Enter an integer value for the sample count: 100
min() == 0
max() == 2147483647
p() == 1.0000000000
Distribution for 100 samples:
0 ::::::::::::::::::::::::::::::
1 ::::::::::::::::::::::::::::::::::::::
2 :::::::::::::::::::::::
3 ::::::::
5 :
Tes kedua:
Use CTRL-Z to bypass data entry and run using default values.
Enter a floating point value for the 'mean' distribution parameter (must be greater than zero): 10
Enter an integer value for the sample count: 100
min() == 0
max() == 2147483647
p() == 10.0000000000
Distribution for 100 samples:
3 :
4 ::
5 ::
6 ::::::::
7 ::::
8 ::::::::
9 ::::::::::::::
10 ::::::::::::
11 ::::::::::::::::
12 :::::::::::::::
13 ::::::::
14 ::::::
15 :
16 ::
17 :
Persyaratan
Header:<acak>
Namespace: std
poisson_distribution::p oisson_distribution
Membangun distribusi.
explicit poisson_distribution(RealType mean = 1.0);
explicit binomial_distribution(const param_type& parm);
Parameter
mean
Parameter mean
distribusi.
parm
Struktur parameter yang digunakan untuk membangun distribusi.
Keterangan
Prasyarat: 0.0 < mean
Konstruktor pertama membangun objek yang nilai tersimpannya mean
menyimpan nilai rata-rata.
Konstruktor kedua membuat objek yang parameter tersimpan diinisialisasi dari parm. Anda dapat memperoleh dan mengatur parameter saat ini dari distribusi yang ada dengan memanggil param()
fungsi anggota.
poisson_distribution::p aram_type
Menyimpan parameter distribusi.
struct param_type {
typedef poisson_distribution<IntType> distribution_type;
param_type(double mean = 1.0);
double mean() const;
bool operator==(const param_type& right) const;
bool operator!=(const param_type& right) const;
};
Parameter
Lihat parameter konstruktor untuk poisson_distribution.
Keterangan
Prasyarat: 0.0 < mean
Struktur ini dapat diteruskan ke konstruktor kelas distribusi saat instansiasi, ke param()
fungsi anggota untuk mengatur parameter tersimpan dari distribusi yang ada, dan untuk operator()
digunakan sebagai pengganti parameter tersimpan.