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
use crate::bandwidth::Bandwidth;
use crate::internal::{variance, Float};
#[derive(Clone, Copy, Debug)]
pub struct Scott;
impl Bandwidth for Scott {
fn bandwidth(&self, data: &[Float]) -> Float {
let prefactor = 1.06;
let n = data.len() as Float;
let var = variance(data);
(prefactor * Float::sqrt(var)) / n.powf(1. / 5.)
}
}
#[cfg(test)]
mod tests {
use super::{Bandwidth, Scott};
use approx::*;
#[test]
fn scott() {
let data = vec![1.0, 1.5, 2.0, 2.5, 3.0];
let res = Scott.bandwidth(&data);
assert_relative_eq!(res, 0.60736, epsilon = 1.0e-5);
}
}