Skip to content

Commit ebe9963

Browse files
committed
std: add stats.
1 parent 73280b0 commit ebe9963

File tree

2 files changed

+97
-0
lines changed

2 files changed

+97
-0
lines changed

src/libstd/stats.rs

Lines changed: 96 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,96 @@
1+
// Copyright 2012 The Rust Project Developers. See the COPYRIGHT
2+
// file at the top-level directory of this distribution and at
3+
// http://rust-lang.org/COPYRIGHT.
4+
//
5+
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
6+
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
7+
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
8+
// option. This file may not be copied, modified, or distributed
9+
// except according to those terms.
10+
11+
use core::vec;
12+
use core::f64;
13+
use core::cmp;
14+
use core::num;
15+
use sort;
16+
17+
// NB: this can probably be rewritten in terms of num::Num
18+
// to be less f64-specific.
19+
20+
pub trait Stats {
21+
fn sum(self) -> f64;
22+
fn min(self) -> f64;
23+
fn max(self) -> f64;
24+
fn mean(self) -> f64;
25+
fn median(self) -> f64;
26+
fn var(self) -> f64;
27+
fn std_dev(self) -> f64;
28+
fn std_dev_pct(self) -> f64;
29+
fn median_abs_dev(self) -> f64;
30+
fn median_abs_dev_pct(self) -> f64;
31+
}
32+
33+
impl &[f64] : Stats {
34+
fn sum(self) -> f64 {
35+
vec::foldl(0.0, self, |p,q| p + *q)
36+
}
37+
38+
fn min(self) -> f64 {
39+
assert self.len() != 0;
40+
vec::foldl(self[0], self, |p,q| cmp::min(p, *q))
41+
}
42+
43+
fn max(self) -> f64 {
44+
assert self.len() != 0;
45+
vec::foldl(self[0], self, |p,q| cmp::max(p, *q))
46+
}
47+
48+
fn mean(self) -> f64 {
49+
assert self.len() != 0;
50+
self.sum() / (self.len() as f64)
51+
}
52+
53+
fn median(self) -> f64 {
54+
assert self.len() != 0;
55+
let tmp = vec::to_mut(vec::from_slice(self));
56+
sort::tim_sort(tmp);
57+
if tmp.len() & 1 == 0 {
58+
let m = tmp.len() / 2;
59+
(tmp[m] + tmp[m-1]) / 2.0
60+
} else {
61+
tmp[tmp.len() / 2]
62+
}
63+
}
64+
65+
fn var(self) -> f64 {
66+
if self.len() == 0 {
67+
0.0
68+
} else {
69+
let mean = self.mean();
70+
let mut v = 0.0;
71+
for self.each |s| {
72+
let x = *s - mean;
73+
v += x*x;
74+
}
75+
v/(self.len() as f64)
76+
}
77+
}
78+
79+
fn std_dev(self) -> f64 {
80+
f64::sqrt(self.var())
81+
}
82+
83+
fn std_dev_pct(self) -> f64 {
84+
(self.std_dev() / self.mean()) * 100.0
85+
}
86+
87+
fn median_abs_dev(self) -> f64 {
88+
let med = self.median();
89+
let abs_devs = self.map(|v| num::abs(med - *v));
90+
abs_devs.median()
91+
}
92+
93+
fn median_abs_dev_pct(self) -> f64 {
94+
(self.median_abs_dev() / self.median()) * 100.0
95+
}
96+
}

src/libstd/std.rc

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -98,6 +98,7 @@ pub mod base64;
9898
pub mod rl;
9999
pub mod workcache;
100100
pub mod bigint;
101+
pub mod stats;
101102

102103
#[cfg(unicode)]
103104
mod unicode;

0 commit comments

Comments
 (0)