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.
Weibull dağılımı oluşturur.
Sözdizimi
class weibull_distribution
{
public:
// types
typedef RealType result_type;
struct param_type;
// constructor and reset functions
explicit weibull_distribution(result_type a = 1.0, result_type b = 1.0);
explicit weibull_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 a() const;
result_type b() const;
param_type param() const;
void param(const param_type& parm);
result_type min() const;
result_type max() const;
};
Parametreler
RealType
Kayan nokta sonuç türü varsayılan olarak olarak doublegösterilir. Olası türler için bkz <. rastgele>.
Açıklamalar
Sınıf şablonu, kullanıcı tarafından belirtilen kayan nokta türünün değerlerini üreten bir dağıtımı açıklar veya hiçbiri sağlanmazsa türü double Weibull Dağılımına göre dağıtılır. Aşağıdaki tabloda, tek tek üyeler hakkındaki makalelere bağlantılar yer alır.
weibull_distribution
param_type|
özellik işlevi görür a() ve a ve b() b depolanan dağıtım parametreleri için ilgili değerlerini 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>.
Weibull dağıtımı hakkında ayrıntılı bilgi için Wolfram MathWorld makalesine bakın Weibull Dağılımı.
Örnek
// compile with: /EHsc /W4
#include <random>
#include <iostream>
#include <iomanip>
#include <string>
#include <map>
void test(const double a, const double b, const int s) {
// uncomment to use a non-deterministic generator
// std::random_device gen;
std::mt19937 gen(1701);
std::weibull_distribution<> distr(a, b);
std::cout << std::endl;
std::cout << "min() == " << distr.min() << std::endl;
std::cout << "max() == " << distr.max() << std::endl;
std::cout << "a() == " << std::fixed << std::setw(11) << std::setprecision(10) << distr.a() << std::endl;
std::cout << "b() == " << std::fixed << std::setw(11) << std::setprecision(10) << distr.b() << std::endl;
// generate the distribution as a histogram
std::map<double, int> histogram;
for (int i = 0; i < s; ++i) {
++histogram[distr(gen)];
}
// print results
std::cout << "Distribution for " << s << " samples:" << std::endl;
int counter = 0;
for (const auto& elem : histogram) {
std::cout << std::fixed << std::setw(11) << ++counter << ": "
<< std::setw(14) << std::setprecision(10) << elem.first << std::endl;
}
std::cout << std::endl;
}
int main()
{
double a_dist = 0.0;
double b_dist = 1;
int samples = 10;
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 'a' distribution parameter (must be greater than zero): ";
std::cin >> a_dist;
std::cout << "Enter a floating point value for the 'b' distribution parameter (must be greater than zero): ";
std::cin >> b_dist;
std::cout << "Enter an integer value for the sample count: ";
std::cin >> samples;
test(a_dist, b_dist, samples);
}
Çıktı
İlk çalıştırma:
Use CTRL-Z to bypass data entry and run using default values.
Enter a floating point value for the 'a' distribution parameter (must be greater than zero): 1
Enter a floating point value for the 'b' distribution parameter (must be greater than zero): 1
Enter an integer value for the sample count: 10
min() == 0
max() == 1.79769e+308
a() == 1.0000000000
b() == 1.0000000000
Distribution for 10 samples:
1: 0.0936880533
2: 0.1225944894
3: 0.6443593183
4: 0.6551171649
5: 0.7313457551
6: 0.7313557977
7: 0.7590097389
8: 1.4466885214
9: 1.6434088411
10: 2.1201210996
İkinci çalıştırma:
Use CTRL-Z to bypass data entry and run using default values.
Enter a floating point value for the 'a' distribution parameter (must be greater than zero): .5
Enter a floating point value for the 'b' distribution parameter (must be greater than zero): 5.5
Enter an integer value for the sample count: 10
min() == 0
max() == 1.79769e+308
a() == 0.5000000000
b() == 5.5000000000
Distribution for 10 samples:
1: 0.0482759823
2: 0.0826617486
3: 2.2835941207
4: 2.3604817485
5: 2.9417663742
6: 2.9418471657
7: 3.1685268104
8: 11.5109922290
9: 14.8543594043
10: 24.7220241239
Gereksinimler
Üst bilgi:<rastgele>
Ad alanı: std
weibull_distribution::weibull_distribution
explicit weibull_distribution(result_type a = 1.0, result_type b = 1.0);
explicit weibull_distribution(const param_type& parm);
Parametreler
a
a Dağıtım parametresi.
b
b Dağıtım parametresi.
parm
Dağıtımı param_type oluşturmak için kullanılan yapı.
Açıklamalar
Önkoşul: 0.0 < a ve 0.0 < b
İlk oluşturucu, depolanan değeri a değerini tutan ve depolanan a b değeri b 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.
weibull_distribution::p aram_type
Dağıtımın parametrelerini depolar.
struct param_type {
typedef weibull_distribution<result_type> distribution_type;
param_type(result_type a = 1.0, result_type b = 1.0);
result_type a() const;
result_type b() const;
bool operator==(const param_type& right) const;
bool operator!=(const param_type& right) const;
};
Parametreler
a
a Dağıtım parametresi.
b
b Dağıtım parametresi.
Sağ
Bununla param_type karşılaştıracak nesne.
Açıklamalar
Önkoşul: 0.0 < a ve 0.0 < b
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.