Not
Bu sayfaya erişim yetkilendirme gerektiriyor. Oturum açmayı veya dizinleri değiştirmeyi deneyebilirsiniz.
Bu sayfaya erişim yetkilendirme gerektiriyor. Dizinleri değiştirmeyi deneyebilirsiniz.
Binom dağılımı oluşturur.
Sözdizimi
template<class IntType = int>
class binomial_distribution
{
public:
// types
typedef IntType result_type;
struct param_type;
// constructors and reset functions
explicit binomial_distribution(result_type t = 1, double p = 0.5);
explicit binomial_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
result_type t() const;
double p() const;
param_type param() const;
void param(const param_type& parm);
result_type min() const;
result_type max() const;
};
Parametreler
IntType
Tamsayı sonuç türü, varsayılan olarak olarak intayarlanır. Olası türler için bkz <. rastgele>.
URNG
Tekdüzen rastgele sayı oluşturucu altyapısı. Olası türler için bkz <. rastgele>.
Açıklamalar
Sınıf şablonu, Binom Dağılımı ayrık olasılık işlevine göre dağıtılan, kullanıcı tarafından belirtilen tam sayı türü veya sağlanmayan tür int değerlerini üreten bir dağılımı açıklar. Aşağıdaki tabloda, tek tek üyeler hakkındaki makalelere bağlantılar yer alır.
binomial_distribution
param_type
Özellik üyeleri t() ve p() şu anda depolanan dağıtım parametresi değerlerini sırasıyla t ve p döndürür.
Özellik üyesi param() depolanan dağıtım parametresi paketini ayarlar veya döndürür param_type .
min() ve max() üye işlevleri sırasıyla mümkün olan en küçük sonucu ve mümkün olan en büyük sonucu döndürür.
reset() Üye işlevi önbelleğe alınmış değerleri atar, böylece bir sonraki çağrısının sonucu, çağrıdan operator() önce altyapıdan alınan hiçbir değere bağımlı olmaz.
operator() Üye işlevleri, geçerli parametre paketinden veya belirtilen parametre paketinden ÜRNG altyapısını temel alarak bir sonraki oluşturulan değeri döndürür.
Dağıtım sınıfları ve üyeleri hakkında daha fazla bilgi için bkz <. rastgele>.
Binom dağılımı ayrık olasılık işlevi hakkında ayrıntılı bilgi için Wolfram MathWorld Makalesi Binom Dağılımı'na bakın.
Örnek
// compile with: /EHsc /W4
#include <random>
#include <iostream>
#include <iomanip>
#include <string>
#include <map>
void test(const int t, const double p, const int& s) {
// uncomment to use a non-deterministic seed
// std::random_device rd;
// std::mt19937 gen(rd());
std::mt19937 gen(1729);
std::binomial_distribution<> distr(t, p);
std::cout << std::endl;
std::cout << "p == " << distr.p() << std::endl;
std::cout << "t == " << distr.t() << 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 << "Histogram 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()
{
int t_dist = 1;
double p_dist = 0.5;
int samples = 100;
std::cout << "Use CTRL-Z to bypass data entry and run using default values." << std::endl;
std::cout << "Enter an integer value for t distribution (where 0 <= t): ";
std::cin >> t_dist;
std::cout << "Enter a double value for p distribution (where 0.0 <= p <= 1.0): ";
std::cin >> p_dist;
std::cout << "Enter an integer value for a sample count: ";
std::cin >> samples;
test(t_dist, p_dist, samples);
}
İlk çalıştırma:
Use CTRL-Z to bypass data entry and run using default values.
Enter an integer value for t distribution (where 0 <= t): 22
Enter a double value for p distribution (where 0.0 <= p <= 1.0): .25
Enter an integer value for a sample count: 100
p == 0.25
t == 22
Histogram for 100 samples:
1 :
2 ::
3 :::::::::::::
4 ::::::::::::::
5 :::::::::::::::::::::::::
6 ::::::::::::::::::
7 :::::::::::::
8 ::::::
9 ::::::
11 :
12 :
İkinci çalıştırma:
Use CTRL-Z to bypass data entry and run using default values.
Enter an integer value for t distribution (where 0 <= t): 22
Enter a double value for p distribution (where 0.0 <= p <= 1.0): .5
Enter an integer value for a sample count: 100
p == 0.5
t == 22
Histogram for 100 samples:
6 :
7 ::
8 :::::::::
9 ::::::::::
10 ::::::::::::::::
11 :::::::::::::::::::
12 :::::::::::
13 :::::::::::::
14 :::::::::::::::
15 ::
16 ::
Üçüncü çalıştırma:
Use CTRL-Z to bypass data entry and run using default values.
Enter an integer value for t distribution (where 0 <= t): 22
Enter a double value for p distribution (where 0.0 <= p <= 1.0): .75
Enter an integer value for a sample count: 100
p == 0.75
t == 22
Histogram for 100 samples:
13 ::::
14 :::::::::::
15 :::::::::::::::
16 :::::::::::::::::::::
17 ::::::::::::::
18 :::::::::::::::::
19 :::::::::::
20 ::::::
21 :
Gereksinimler
Üst bilgi:<rastgele>
Ad alanı: std
binomial_distribution::binomial_distribution
Dağıtımı oluşturur.
explicit binomial_distribution(result_type t = 1, double p = 0.5);
explicit binomial_distribution(const param_type& parm);
Parametreler
t
t Dağıtım parametresi.
p
p Dağıtım parametresi.
parm
Dağıtımı param_type oluşturmak için kullanılan yapı.
Açıklamalar
Önkoşul: 0 ≤ t ve 0.0 ≤ p ≤ 1.0
İlk oluşturucu, depolanan p değeri p değerini ve depolanan t değeri t değerini tutan bir nesne oluşturur.
İkinci oluşturucu, depolanan parametreleri parm'den başlatılan bir nesne oluşturur. Üye işlevini çağırarak param() mevcut bir dağıtımın geçerli parametrelerini alabilir ve ayarlayabilirsiniz.
binomial_distribution::p aram_type
Dağıtımın tüm parametrelerini depolar.
struct param_type {
typedef binomial_distribution<result_type> distribution_type;
param_type(result_type t = 1, double p = 0.5);
result_type t() const;
double p() const;
.....
bool operator==(const param_type& right) const;
bool operator!=(const param_type& right) const;
};
Parametreler
t
t Dağıtım parametresi.
p
p Dağıtım parametresi.
Sağ
Bununla param_type karşılaştıracak nesne.
Açıklamalar
Önkoşul: 0 ≤ t ve 0.0 ≤ p ≤ 1.0
Bu yapı, örnek oluşturma sırasında dağıtımın sınıf oluşturucusunun, mevcut bir dağıtımın param() depolanmış parametrelerini ayarlamak için üye işlevine operator() geçirilebilir ve depolanan parametrelerin yerine kullanılacaktır.