This library provides safe access to the Cuba integration library (version 4.2.1).
Below we show an example of an integration of a test function with user data (this can be of any type):
```rust extern crate cuba; use cuba::{CubaIntegrator, CubaVerbosity};
struct UserData { f1: f64, f2: f64, }
fn integrand( x: &[f64], f: &mut [f64], userdata: &mut UserData, nvec: usize, _core: i32, _weight: &[f64], _iter: usize, ) -> Result<(), &'static str> { for i in 0..nvec { f[i * 2] = (x[i * 2] * x[i * 2]).sin() * userdata.f1; f[i * 2 + 1] = (x[i * 2 + 1] * x[i * 2 + 1]).cos() * user_data.f2; }
Ok(())
}
fn main() { let mut ci = CubaIntegrator::new(); ci.setmineval(10) .setmaxeval(10000000) .setepsrel(0.0001) .setseed(0) // use quasi-random numbers .set_cores(2, 1000);
let data = UserData { f1: 5., f2: 7. };
let r = ci.vegas(2, 2, 4, CubaVerbosity::Progress, 0, integrand, data);
println!("{:#?}", r);
} ```