Skip to content

sile/fanova

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

73 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

fanova

fanova Documentation Actions Status License

A Rust fANOVA (functional analysis of variance) implementation.

fANOVA provides a way to calculate feature importance.

Examples

use fanova::{FanovaOptions, RandomForestOptions};
use rand::{RngExt, SeedableRng};

let mut feature1 = Vec::new();
let mut feature2 = Vec::new();
let mut feature3 = Vec::new();
let mut target = Vec::new();

let mut rng = rand::rngs::StdRng::seed_from_u64(0);
for _ in 0..100 {
    let f1 = rng.random();
    let f2 = rng.random();
    let f3 = rng.random();
    let t = f1 + f2 * 2.0 + f3 * 3.0;

    feature1.push(f1);
    feature2.push(f2);
    feature3.push(f3);
    target.push(t);
}

let mut fanova = FanovaOptions::new()
    .random_forest(RandomForestOptions::new().seed(0))
    .fit(vec![&feature1, &feature2, &feature3], &target).unwrap();
let importances = (0..3)
    .map(|i| fanova.quantify_importance(&[i]).mean)
    .collect::<Vec<_>>();

assert_eq!(
    importances,
    vec![0.03949614161205558, 0.24001507447005044, 0.5934922097988682]
);

References

About

A Rust implementation of fANOVA (functional analysis of variance)

Topics

Resources

License

Stars

Watchers

Forks

Packages

 
 
 

Contributors

Languages