class XHProfAggregator in XHProf 7
Same name and namespace in other branches
- 6 XHProfLib/XHProfAggregator.php \XHProfAggregator
Hierarchy
- class \XHProfAggregator
Expanded class hierarchy of XHProfAggregator
File
- XHProfLib/
XHProfAggregator.php, line 3
View source
class XHProfAggregator {
public $runs = array();
/**
* @param $run_data
* @return void
*/
public function addRun($run_data) {
$this->runs[] = $run_data;
}
/**
* @return array
*/
public function average() {
$keys = array();
foreach ($this->runs as $data) {
$keys = $keys + array_keys($data);
}
$agg_run = array();
$run_count = count($runs);
foreach ($keys as $key) {
$agg_key = array();
// Check which runs have this parent_child function key, collect metrics if so.
foreach ($runs as $data) {
if (isset($data[$key])) {
foreach ($data[$key] as $metric => $val) {
$agg_key[$metric][] = $val;
}
}
}
// Average each metric for the key into the aggregated run.
$agg_run[$key] = array();
foreach ($agg_key as $metric => $vals) {
$sd = self::sd($vals);
$mean = array_sum($vals) / count($vals);
$good_vals = array();
if ($sd == 0) {
$agg_run[$key][$metric] = array_sum($vals) / count($vals);
}
else {
foreach ($vals as $v) {
$diff = abs($mean - $v);
if (abs($mean - $v) < $sd * 2) {
$good_vals[] = $v;
}
}
$agg_run[$key][$metric] = array_sum($good_vals) / count($good_vals);
}
}
}
return $agg_run;
}
/**
* @return array
*/
public function sum() {
$keys = array();
foreach ($this->runs as $data) {
$keys = $keys + array_keys($data);
}
$agg_run = array();
foreach ($keys as $key) {
$agg_key = array();
// Check which runs have this parent_child function key, collect metrics if so.
foreach ($this->runs as $data) {
if (isset($data[$key])) {
foreach ($data[$key] as $metric => $val) {
$agg_key[$metric][] = $val;
}
}
}
// Sum each metric for the key into the aggregated run.
$agg_run[$key] = array();
foreach ($agg_key as $metric => $vals) {
$agg_run[$key][$metric] = array_sum($vals);
}
}
return $agg_run;
}
public static function sd_square($x, $mean) {
return pow($x - $mean, 2);
}
/**
* Function to calculate standard deviation (uses sd_square)
*/
public static function sd($array) {
// square root of sum of squares devided by N-1
return sqrt(array_sum(array_map(array(
'XHProfTools',
'sd_square',
), $array, array_fill(0, count($array), array_sum($array) / count($array)))) / (count($array) - 1));
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
XHProfAggregator:: |
public | property | ||
XHProfAggregator:: |
public | function | ||
XHProfAggregator:: |
public | function | ||
XHProfAggregator:: |
public static | function | Function to calculate standard deviation (uses sd_square) | |
XHProfAggregator:: |
public static | function | ||
XHProfAggregator:: |
public | function |