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 |