確率統計確率統計
ワイブル分布サンプリング; Weibull Distribution Sampling

概要
ワイブル分布とは以下の式で表現される確率分布。

$$f(x)=\frac{\alpha}{\beta} \left( \frac{x-\lambda}{\beta} \right)^{\alpha-1} exp \left( - \left( \frac{x-\lambda}{\beta} \right)^{\alpha} \right) $$

ワイブル分布

ソースコード

namespace ExRandom.Continuous {
    public class WeibullRandom : Random{
        readonly MT19937 mt;
        readonly double inv_alpha, beta, lambda;

        public WeibullRandom(MT19937 mt, double alpha = 1, double beta = 1, double lambda = 0) {
            if(mt == null) {
                throw new ArgumentNullException();
            }

            if(!(alpha > 0) || !(beta > 0)) {
                throw new ArgumentException();
            }

            this.mt = mt;
            this.inv_alpha = 1 / alpha;
            this.beta = beta;
            this.lambda = lambda;
        }

        public override double Next() {
            double u = mt.NextDouble_OpenInterval0();

            return lambda + beta * Math.Pow(-Math.Log(u), inv_alpha);
        }
    }
}

関連項目
メルセンヌ・ツイスタ
各種確率分布サンプリング基本クラス

ライブラリライブラリ
確率統計確率統計
線形代数線形代数
幾何学幾何学
最適化最適化
微分方程式微分方程式
画像処理画像処理
補間補間
機械学習機械学習
クラスタリングクラスタリング
パズルゲーム・パズル
未分類未分類