/* }}} */
-static long double php_population_variance(zval *arr)
+static long double php_population_variance(zval *arr, zend_bool sample)
{
double mean, sum = 0.0, vr = 0.0;
zval **entry;
HashPosition pos;
+ int elements_num;
+
+ elements_num = zend_hash_num_elements(Z_ARRVAL_P(arr));
zend_hash_internal_pointer_reset_ex(Z_ARRVAL_P(arr), &pos);
while (zend_hash_get_current_data_ex(Z_ARRVAL_P(arr), (void **)&entry, &pos) == SUCCESS) {
sum += Z_DVAL_PP(entry);
zend_hash_move_forward_ex(Z_ARRVAL_P(arr), &pos);
}
- mean = sum / zend_hash_num_elements(Z_ARRVAL_P(arr));
+ mean = sum / elements_num;
zend_hash_internal_pointer_reset_ex(Z_ARRVAL_P(arr), &pos);
while (zend_hash_get_current_data_ex(Z_ARRVAL_P(arr), (void **)&entry, &pos) == SUCCESS) {
vr += d*d;
zend_hash_move_forward_ex(Z_ARRVAL_P(arr), &pos);
}
- return (vr / zend_hash_num_elements(Z_ARRVAL_P(arr)));
+ if (sample) {
+ --elements_num;
+ }
+ return (vr / elements_num);
}
/* {{{ proto float math_variance(array a)
PHP_FUNCTION(math_variance)
{
zval *arr;
+ zend_bool sample = 0;
- if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "a", &arr) == FAILURE) {
+ if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "a|b", &arr, &sample) == FAILURE) {
return;
}
if (zend_hash_num_elements(Z_ARRVAL_P(arr)) == 0) {
php_error_docref(NULL TSRMLS_CC, E_WARNING, "The array has zero elements");
RETURN_FALSE;
}
- RETURN_DOUBLE(php_population_variance(arr));
+ RETURN_DOUBLE(php_population_variance(arr, sample));
}
/* }}} */
PHP_FUNCTION(math_std_dev)
{
zval *arr;
+ zend_bool sample = 0;
- if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "a", &arr) == FAILURE) {
+ if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "a|b", &arr, &sample) == FAILURE) {
return;
}
if (zend_hash_num_elements(Z_ARRVAL_P(arr)) == 0) {
php_error_docref(NULL TSRMLS_CC, E_WARNING, "The array has zero elements");
RETURN_FALSE;
}
- RETURN_DOUBLE(sqrt(php_population_variance(arr)));
+ RETURN_DOUBLE(sqrt(php_population_variance(arr, sample)));
}
/* }}} */
$dev=math_std_dev($a);
var_dump(sprintf("%2.9f", $dev));
var_dump(math_std_dev(array()));
+$a=array(5,7,8,10,10);
+var_dump(math_std_dev($a,1));
echo "---Variance---\n";
$a=array(5,7,8,10,10);
var_dump(math_variance($a));
+var_dump(math_variance($a, true));
?>
--EXPECTF--
string(11) "2.449489743"
Warning: math_std_dev(): The array has zero elements in %s on line %d
bool(false)
+float(2.1213203435596)
---Variance---
-float(3.6)
\ No newline at end of file
+float(3.6)
+float(4.5)
\ No newline at end of file