指数分布は、特定の分布に従う乱数を生成することがあるそれを実装する必要があります。 が指数分布を使用するには、そのような何かを:
#include <iostream>
#include <boost/random.hpp>
int main() {
boost::mt19937 seed(5u);
boost::variate_generator<boost::mt19937&, boost::exponential_distribution<>> random_n(seed, boost::exponential_distribution<>()) ;
cout << random_n() << endl; return 0;
}
は今、私はあなたが何かをしたいが、それは私のためそれほど明確ではないと思います。あなたは何かを並べ替えたいですか?あなたのベクトルの乱数を選びますか?
編集: OK。要約すると、たとえC++ 11へのアクセス権があっても、それほど遠くに行くことはできません。ほとんどのランダムジェネレータは標準になっています。しかし、PDFではありません。なぜあなたが好奇心が強いのであれば、ここにそれがあります:http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2002/n1398.html。 boost.mathツールキットが必要です。これはPDFを計算する唯一の方法です。ここではあなたのためにいくつかのサンプルコードは次のとおりです。
要するに
#include <boost/math/distributions/exponential.hpp>
int main() {
const auto lbda = 1.0;
const auto d = exponential_distribution<> { lbda };
cout << pdf(d, 0) << endl; // e(0) = 1
cout << pdf(d, 1) << endl; // e(-1) = 0.3678
return 0;
}
:ブーストPDF
を使用するために、あなたは、ベクターは、PDF機能は、その分布を計算する方法を知っている原因そのものは必要ありません。
編集2:ベクターをいくつかのディストリビューションに取り込む必要がある場合は、単にstd::generate
を使用してディストリビューションを適用してください。ここにはstd::exponential_distribution
の例があります(C++ 11ですが、 。
std::vector<float> v(20);
random_device rd;
mt19937_64 gen(rd());
exponential_distribution<float> dis(1);
auto rand = bind(dis, gen);
generate(begin(v), end(v), rand);
for (auto& e : v) cout << e << endl;
私はここに示していますコードは、指数分布vector
20の要素を充填されています。 std::array
に切り替えることができます。必要に応じて浮動小数点数を変更し、ベクトルまたは配列のサイズを増やします。
また、必要なことをするこの古いC++ライブラリ(今はピノニックなもの)を見てみることもできます:http://myfitter.hepforge.org/。これはおそらくあなたの最善の策です。それは非パラメトリックな方法を使用します。 C++のバージョンはかなり古いですが、私は完全に機能しているとは確信していませんが、おそらくこれはあなたのために行くでしょう。
AFAIK boostには、データをディストリビューションに適合させる方法はありません。データを生成するためにのみ使用します。私は数値レシピが持っていることを覚えている、あなたの正気のためのボット私はあなたがより良いオプションを見つけることを願っています。あなたはできます。すべての要素を記録し、線形回帰を適用します。 – peterchen