forked from angus-c/just
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathindex.js
More file actions
30 lines (27 loc) · 660 Bytes
/
Copy pathindex.js
File metadata and controls
30 lines (27 loc) · 660 Bytes
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
module.exports = stdev;
function stdev(arr) {
if (!Array.isArray(arr)) {
arr = [].slice.call(arguments);
}
if (!arr.length || arr.length < 2) {
throw new Error('less than one value was passed to `standard deviation`');
}
var sum = 0;
var len = arr.length;
for (var i = 0; i < len; i++) {
var n = arr[i];
if (!Number.isFinite(n)) {
throw new Error(
'all values passed to `standard deviation` must be numeric'
);
}
sum += n;
}
var mean = sum / len;
var acc = 0;
for (var i = 0; i < len; i++) {
var n = arr[i];
acc += (n - mean) * (n - mean);
}
return Math.sqrt(acc / (len - 1));
}