3 releases (breaking)

Uses old Rust 2015

0.2.0 Apr 11, 2020
0.1.0 Jun 6, 2016
0.0.1 Apr 26, 2016

#1782 in Algorithms

Download history 246/week @ 2024-03-11 70/week @ 2024-03-18 38/week @ 2024-03-25 131/week @ 2024-04-01 210/week @ 2024-04-08 18/week @ 2024-04-15 60/week @ 2024-04-22 87/week @ 2024-04-29 125/week @ 2024-05-06 56/week @ 2024-05-13 27/week @ 2024-05-20 17/week @ 2024-05-27 21/week @ 2024-06-03 26/week @ 2024-06-10 113/week @ 2024-06-17 37/week @ 2024-06-24

199 downloads per month
Used in 2 crates (via finalytics)

MIT license

35KB
630 lines

optimization Build Status Coverage Status

Collection of optimization algorithms and strategies.

Usage

extern crate optimization;

use optimmization::{Minimizer, GradientDescent, NumericalDifferentiation, Func};

// numeric version of the Rosenbrock function
let function = NumericalDifferentiation::new(Func(|x: &[f64]| {
    (1.0 - x[0]).powi(2) + 100.0*(x[1] - x[0].powi(2)).powi(2)
}));

// we use a simple gradient descent scheme
let minimizer = GradientDescent::new();

// perform the actual minimization, depending on the task this may
// take some time, it may be useful to install a log sink to see
// what's going on
let solution = minimizer.minimize(&function, vec![-3.0, -4.0]);

println!("Found solution for Rosenbrock function at f({:?}) = {:?}",
    solution.position, solution.value);

Installation

Simply add it as a Cargo dependency:

[dependencies]
optimization = "*"

Documentation

For an exhaustive documentation head over to the API docs.

Development

Simply download this crate, add your stuff, write some tests and create a pull request. Pretty simple! :)

$ cargo test
$ cargo clippy

License

This software is licensed under the terms of the MIT license. Please see the LICENSE for full details.

Dependencies

~1MB
~16K SLoC