PHP Conference Japan 2024

stats_covariance

(PECL stats >= 1.0.0)

stats_covariance计算两个数据集的协方差

描述

stats_covariance(数组 $a, 数组 $b): 浮点数

返回 ab 的协方差。

参数

a

第一个数组

b

第二个数组

返回值

返回 ab 的协方差,或者在失败时返回 false

添加注释

用户贡献的注释 2 个注释

Angel J. Salinas
8 年前
// kanniprabu 的函数是错误的。
// 你可以使用 Excel 函数 COVARIANCE.P 检查此函数

function getCovariance( $valuesA, $valuesB )
{
$countA = count($valuesA);
$countB = count($valuesB);
if ( $countA != $countB ) {
trigger_error( '数组大小不同:countA='. $countA .', countB='. $countB, E_USER_WARNING );
return false;
}

if ( $countA < 0 ) {
trigger_error( '空数组', E_USER_WARNING );
return false;
}

// 如果可用,则使用库函数
if ( function_exists( 'stats_covariance' ) ) {
return stats_covariance( $valuesA, $valuesB );
}

$meanA = array_sum( $valuesA ) / floatval( $countA );
$meanB = array_sum( $valuesB ) / floatval( $countB );
$add = 0.0;

for ( $pos = 0; $pos < $countA; $pos++ ) {
$valueA = $valuesA[ $pos ];
if ( ! is_numeric( $valueA ) ) {
trigger_error( '数组 A 中位置 '. $pos .' 处的值不是数值,值为 '. $valueA, E_USER_WARNING );
return false;
}

$valueB = $valuesB[ $pos ];
if ( ! is_numeric( $valueB ) ) {
trigger_error( '数组 B 中位置 '. $pos .' 处的值不是数值,值为 '. $valueB, E_USER_WARNING );
return false;
}

$difA = $valueA - $meanA;
$difB = $valueB - $meanB;
$add += ( $difA * $difB );
} // for

return $add / floatval( $countA );
}
kanniprabu at gmail dot com
11 年前
<?php
//协方差计算
function standard_covariance($aValues,$bValues)
{
$a= (array_sum($aValues)*array_sum($bValues))/count($aValues);
$ret = array();
for(
$i=0;$i<count($aValues);$i++)
{
$ret[$i]=$aValues[$i]*$bValues[$i];
}
$b=(array_sum($ret)-$a)/(count($aValues)-1);
return (float)
$b;
}
$aValues=array(3,4,5,7);
$bValues=array(10,11,13,14);
echo
standard_covariance($aValues,$bValues);
?>
To Top