This libarie implements Gaussian Process Regression, also known as Kriging, in Rust. Our goal is to provide a building block for other algorithms (such as Bayesian Optimization).
Gaussian process have both the ability to extract a lot of information from their training data and to return a prediction and an uncertainty on their prediction. Furthermore, they can handle non-linear phenomenons, take uncertainty on the inputs into account and encode a prior on the output.
All of those properties make them an algorithm of choice to perform regression when data is scarce or when having uncertainty bars on the ouput is a desirable property.
However, the o(n^3)
complexity of the algorithm makes the classical implementation unsuitable for large datasets.
This implementation lets you :
```rust use friedrich::gaussian_process::GaussianProcess;
// trains a gaussian process on a dataset of one dimension vectors let traininginputs = vec![vec![0.8], vec![1.2], vec![3.8], vec![4.2]]; let trainingoutputs = vec![3.0, 4.0, -2.0, -2.0]; let gp = GaussianProcess::default(traininginputs, trainingoutputs);
// predicts the mean and variance of a single point let input = vec![1.]; let mean = gp.predict(&input); let var = gp.predict_variance(&input); println!("prediction: {} ± {}", mean, var.sqrt());
// makes several prediction let inputs = vec![vec![1.0], vec![2.0], vec![3.0]]; let outputs = gp.predict(&inputs); println!("predictions: {:?}", outputs);
// samples from the distribution let newinputs = vec![vec![1.0], vec![2.0]]; let sampler = gp.sampleat(&newinputs); let mut rng = rand::threadrng(); println!("samples: {:?}", sampler.sample(&mut rng)); ```
Most methods of this library can currently work with the following input -> ouput
pairs :
Vec<Vec<f64>> -> Vec<f64>
each inner vector is a multidimentional training sampleVec<f64> -> f64
a single multidimensional sampleDMatrix<f64> -> DVector<f64>
using a nalgebra matrix with one row per sampleA trait is provided to add your own pairs.
The list of things that could be done to improve on the current implementation includes :
Do not hesitate to send pull request or ask for features.