Skip to content

Commit 5f2a07d

Browse files
committed
---
yaml --- r: 47609 b: refs/heads/incoming c: ebe9963 h: refs/heads/master i: 47607: d86a405 v: v3
1 parent 462e6cf commit 5f2a07d

File tree

3 files changed

+98
-1
lines changed

3 files changed

+98
-1
lines changed

[refs]

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -6,7 +6,7 @@ refs/heads/try: 2a8fb58d79e685d5ca07b039badcf2ae3ef077ea
66
refs/tags/release-0.1: 1f5c5126e96c79d22cb7862f75304136e204f105
77
refs/heads/ndm: f3868061cd7988080c30d6d5bf352a5a5fe2460b
88
refs/heads/try2: 147ecfdd8221e4a4d4e090486829a06da1e0ca3c
9-
refs/heads/incoming: 73280b0472afdcf4df7eb1a80a7ac0b74a791ca9
9+
refs/heads/incoming: ebe99637fda18617684a7ae720247315701f19d3
1010
refs/heads/dist-snap: 8b98e5a296d95c5e832db0756828e5bec31c6f50
1111
refs/tags/release-0.2: c870d2dffb391e14efb05aa27898f1f6333a9596
1212
refs/tags/release-0.3: b5f0d0f648d9a6153664837026ba1be43d3e2503

branches/incoming/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+
}

branches/incoming/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)