15         define(
"NAN_HANDLING_REMOVE", 0);
 
   16         define(
"NAN_HANDLING_ZERO", 1);
 
   46                 $this->stat_data = array();
 
  108                 if (
count($this->stat_data))
 
  110                         $min = 
min($this->stat_data);
 
  127                 if (
count($this->stat_data))
 
  129                         $max = 
max($this->stat_data);
 
  145                 return count($this->stat_data);
 
  157                 if (
count($this->stat_data))
 
  160                         foreach ($this->stat_data as $value)
 
  162                                 $sum_n += pow((
double)$value, (
double)
$n);
 
  175                 return $this->
sum_n(1);
 
  186                 return $this->
sum_n(2);
 
  198                 if (
count($this->stat_data))
 
  200                         if ($this->
min() === 0)
 
  205                         foreach ($this->stat_data as $value)
 
  207                                 $prod_n *= pow((
double)$value, (
double)
$n);
 
  237                 $count = $this->
count();
 
  242                 return (
double)($sum/$count);
 
  258                 if (($prod === 
false) or ($prod === 0))
 
  262                 $count = $this->
count();
 
  267                 return pow((
double)$prod, (
double)(1/$count));
 
  279                 if (($min === 
false) or ($min === 0))
 
  283                 $count = $this->
count();
 
  289                 foreach ($this->stat_data as $value)
 
  304                 if (
count($this->stat_data))
 
  307                         $count = $this->
count();
 
  308                         if ((
count($this->stat_data) % 2) == 0)
 
  310                                 $median = ($this->stat_data[($count / 2) - 1] + $this->stat_data[($count / 2)]) / 2;
 
  314                                 $median = $this->stat_data[(($count + 1) / 2) - 1];
 
  328                 if (!is_numeric($value))
 
  332                 $rank = array_search($value, $this->stat_data);
 
  335                         $rank = $this->
count() - $rank;
 
  352                 $count = $this->
count();
 
  358                 if (($count % 2) == 0)
 
  360                         $rank_median = ($count + 1) / 2;
 
  364                         $rank_median = ($count + 1) / 2;
 
  377                 $count = $this->
count();
 
  382                 $nprod = (
$n/100)*$count;
 
  383                 if (intval($nprod) == $nprod)
 
  388                                 return $this->stat_data[$k];
 
  390                         else if ($k == $count)
 
  392                                 return $this->stat_data[$k-1];
 
  396                                 return ($this->stat_data[$k-1] + $this->stat_data[$k])/2;
 
  402                         return $this->stat_data[$k-1];
 
  417                 foreach ($this->stat_data as $key => $value)
 
  419                         if (!is_numeric($value)) {
 
  420                                 switch ($this->nan_handling) {
 
  422                                                 unset($this->stat_data[$key]);
 
  425                                                 $this->stat_data[$key] = 0;
 
  432                 sort($this->stat_data);