標準偏差を求める

統計

概要

 閲覧数:1916  投稿日:2014-05-03  更新日:2014-05-05  

PECLライブラリに入っている関数


コード

$data = array(1, 2, 3, 4, 5, 6, 7, 8, 9, 10);
 
$result = stats_standard_deviation($data);
 
var_dump($result); //float(31.84399472428)
 
/******************************************************************
 * 標準偏差取得
 *****************************************************************/
function stats_standard_deviation($ary) {
        // 平均取得
        $avg = array_sum($ary)/count($ary);
 
        // 各値の平均値との差の二乗【(値-平均値)^2】を算出
        $diff_ary = array();
        foreach ($ary as $val) {
                $diff = $val-$avg;
                $diff_ary[] = pow($diff,2);
        }
 
        // 上記差の二乗の合計を算出
        $diff_total = array_sum($diff_ary);
        // 平均を算出
        $diff_avg   = $diff_total/count($diff_ary);
 
        // 平方根を取る(標準偏差)
        $stdev = sqrt($diff_avg);
 
        // 標準偏差を返す
        return $stdev;
}



結果

float(2.872281323269)



タグ


array_sum 





平均値、分散、標準偏差を求める



週間人気ページランキング / 6-17 → 6-23
順位 ページタイトル抜粋 アクセス数
1 PHPコード 23
2 文字列を「複数の区切り文字」で配列へ変換 / preg_split使用案。採用 | 文字列(テキスト処理) 4
3 文字列の改行文字を削除 | 文字列(テキスト処理) 3
3 配列キー内に「指定文字列が含まれるキー」と「その値」を抽出して、新しい配列を返す | 配列(型) 3
3 指定文字が2回目に出現する位置以降の文字列を取得 | 文字列(テキスト処理) 3
3 引数(複数)に指定したデータを、予め指定した文字形式(フォーマット)へ変換 | 文字列(テキスト処理) 3
3 全ての配列要素へ対して順番に処理を実施 | 配列(型) 3
3 配列要素を置換 | 配列(型) 3
3 「指定配列要素が配列内で重複している数」をカウント後、配列要素として追加 | 配列(型) 3
3 指定文字列より前を取得 | 文字列(テキスト処理) 3
3 array_map()第3引数 / 「2つの配列の要素数同士を順番に掛け合わせた配列」を返す | 配列(型) 3
3 配列要素を、文字列連結して表示(元配列を上書) … foreach文+implode | 配列(型) 3
4 Smartyのテンプレートにincludeしたファイルを表示 | Smarty(テンプレートエンジン) 2
4 複数テーブルロック | MySQL 2
4 指定文字列を削除 | 文字列(テキスト処理) 2
4 多次元配列で「二次元目にある指定値のカウント数 +1 」 を返す | 配列(型) 2
4 'xxxx_数字'キーの数だけ、数字毎に分けて二次元配列へ格納(キーのサフィックスは削除する) / array_walk | 配列(型) 2
4 インスタンスオブジェクト経由で、メンバ(プロパティ・メソッド)へアクセス … PHP5 | クラス 2
4 配列キーを置換して返すユーザ定義関数 | 配列(型) 2
4 現在のセッション名を取得、表示 | セッション 2
2026/6/24 5:05 更新