Skip to content

Adaptive Gauss-Kronrod Integration in Rust

License

Notifications You must be signed in to change notification settings

wellcaffeinated/quad-rs

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

16 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

quad-rs

Gauss-Kronrod Integration in Rust.

Features

  • Adaptive integrator with high-accuracy
  • Native support for complex integrals and paths
  • Support for contour integration in the complex plane

Example - Real Integration

Dependencies:

[dependencies]
quad_rs = "0.1"

:

use quad_rs::prelude::*;

fn integrand(x: f64) -> f64 {
    x.exp()
}

fn main() {
    let integrator = GaussKronrod::default();
    let range = -1f64..1f64;

    let result = integrator
		        .integrate(&integrand, range, None)
            .unwrap();
}

Example - Complex Integration

Dependencies:

[dependencies]
num_complex = "0.4.0"
quad_rs = "0.1"

:

use quad_rs::prelude::*;
use num_complex::Complex;
use std::ops::Range;

fn integrand(z: Complex<f64>) -> Complex<f64> {
    z.exp()
}

fn main() {
    let integrator = GaussKronrod::default();
    let range = Range {
			start: Complex::new(-1f64, -1f64),
			end: Complex::new(1f64, 1f64)
		};

    let result = integrator
		        .integrate(&integrand, range, None)
            .unwrap();
}

Example - Contour Integration

Dependencies:

[dependencies]
num_complex = "0.4.0"
quad_rs = "0.1"

:

use quad_rs::{Contour, Direction, prelude::*};
use num_complex::Complex;

fn integrand(z: Complex<f64>) -> Complex<f64> {
    z.exp()
}

fn main() {
    let integrator = GaussKronrod::default();
    let x_range =-5f64..5f64;
    let y_range = -5f64..5f64;
    let contour = Contour::generate_rectangular(&x_range, &y_range, Direction::Clockwise);

    let result = integrator
		        .path_integrate(&integrand, contour)
            .unwrap();
}

About

Adaptive Gauss-Kronrod Integration in Rust

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Rust 100.0%