| Conditions | 6 |
| Paths | 6 |
| Total Lines | 25 |
| Code Lines | 14 |
| Lines | 0 |
| Ratio | 0 % |
| Changes | 2 | ||
| Bugs | 0 | Features | 1 |
| 1 | <?php |
||
| 19 | public static function population(array $a, $sample = true) |
||
| 20 | { |
||
| 21 | if (empty($a)) { |
||
| 22 | throw InvalidArgumentException::arrayCantBeEmpty(); |
||
| 23 | } |
||
| 24 | |||
| 25 | $n = count($a); |
||
| 26 | |||
| 27 | if ($sample && $n === 1) { |
||
| 28 | throw InvalidArgumentException::arraySizeToSmall(2); |
||
| 29 | } |
||
| 30 | |||
| 31 | $mean = Mean::arithmetic($a); |
||
| 32 | $carry = 0.0; |
||
| 33 | foreach ($a as $val) { |
||
| 34 | $d = $val - $mean; |
||
| 35 | $carry += $d * $d; |
||
| 36 | }; |
||
| 37 | |||
| 38 | if ($sample) { |
||
| 39 | --$n; |
||
| 40 | } |
||
| 41 | |||
| 42 | return sqrt($carry / $n); |
||
| 43 | } |
||
| 44 | } |
||
| 45 |