19

我正在尝试使用 PHP 计算 Z 分数。本质上,我正在寻找最有效的方法来计算数据集(PHP 数组)的平均值和标准差。关于如何在 PHP 中执行此操作的任何建议?

我试图以最少的步骤来做到这一点。

4

5 回答 5

34

计算你可以做的平均值:

$mean = array_sum($array)/count($array)

标准差是这样的:

// Function to calculate square of value - mean
function sd_square($x, $mean) { return pow($x - $mean,2); }

// Function to calculate standard deviation (uses sd_square)    
function sd($array) {
    // square root of sum of squares devided by N-1
    return sqrt(array_sum(array_map("sd_square", $array, array_fill(0,count($array), (array_sum($array) / count($array)) ) ) ) / (count($array)-1) );
}

就在这个页面

于 2011-03-25T15:37:09.637 回答
14

如何使用内置的统计包,如stats_standard_deviationstats_harmonic_mean。我找不到标准方法的函数,但如果您对统计有所了解,我相信您可以使用内置函数计算出一些东西。

于 2011-03-25T15:41:46.950 回答
5
   function standard_deviation($aValues)
{
    $fMean = array_sum($aValues) / count($aValues);
    //print_r($fMean);
    $fVariance = 0.0;
    foreach ($aValues as $i)
    {
        $fVariance += pow($i - $fMean, 2);

    }       
    $size = count($aValues) - 1;
    return (float) sqrt($fVariance)/sqrt($size);
}
于 2013-03-18T12:47:28.523 回答
0

这是来自顶级答案中提到的 php 页面的相同 std dev 代码,但现代化了一点,没有单行数组魔术和单独的辅助函数:

/**
 * Calculates the standard deviation of an array of numbers.
 * @param   array   $array  The array of numbers to calculate the standard deviation of.
 * @return  float   The standard deviation of the numbers in the given array.
 */
function calculateStdDev(array $array): float
{
    $size = count($array);
    $mean = array_sum($array) / $size;
    $squares = array_map(function ($x) use ($mean) {
        return pow($x - $mean, 2);
    }, $array);

    return sqrt(array_sum($squares) / ($size - 1));
}
于 2019-08-28T13:57:14.337 回答
-1

这个话题很老了,但实际上我想你可以使用下面的函数轻松地从 Excel 中获取 STDEV.P 函数的替代品。

function stdev_p($arr) {
    $arr2 = array();
    $mean = array_sum($arr)/count($arr);
    for ($x = 0; $x <count($arr); $x++) {
        $arr2[$x] = pow($arr[$x] - $mean,2);
    }
    return sqrt(array_sum($arr2)/count($arr));
}
于 2020-10-07T12:40:23.327 回答