6

これらの関数、標準正規累積分布関数、正規累積分布関数、またはエラー関数のいずれかを javascript で確実に計算できますか?

WindowsでPECLが利用できないことを考慮して、完全にクライアント側のソリューションが必要です。

方法を教えてください。

よろしくお願いします!

4

1 に答える 1

26

私はこれらの実装を使用します:

function cdf(x, mean, variance) {
  return 0.5 * (1 + erf((x - mean) / (Math.sqrt(2 * variance))));
}

function erf(x) {
  // save the sign of x
  var sign = (x >= 0) ? 1 : -1;
  x = Math.abs(x);

  // constants
  var a1 =  0.254829592;
  var a2 = -0.284496736;
  var a3 =  1.421413741;
  var a4 = -1.453152027;
  var a5 =  1.061405429;
  var p  =  0.3275911;

  // A&S formula 7.1.26
  var t = 1.0/(1.0 + p*x);
  var y = 1.0 - (((((a5 * t + a4) * t) + a3) * t + a2) * t + a1) * t * Math.exp(-x * x);
  return sign * y; // erf(-x) = -erf(x);
}

ソース:

エラーは erf の実装に縛られていると思いますが、これは私にとってはそれほど重要ではありません。したがって、エラーが重要な場合は、その詳細を調べる必要があるかもしれません。

明らかに、標準正規累積分布関数を取得するには、平均 = 0 と分散 = 1 を cdf 関数に渡します。

function std_n_cdf(x) {
  return cdf(x, 0, 1);
}
于 2013-02-14T11:00:44.760 に答える