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

#1794 in Algorithms

Download history 62/week @ 2023-11-26 15/week @ 2023-12-03 13/week @ 2023-12-10 9/week @ 2023-12-17 2/week @ 2023-12-24 166/week @ 2023-12-31 66/week @ 2024-01-07 64/week @ 2024-01-14 6/week @ 2024-01-21 1/week @ 2024-01-28 19/week @ 2024-02-04 14/week @ 2024-02-11 45/week @ 2024-02-18 70/week @ 2024-02-25 51/week @ 2024-03-03 28/week @ 2024-03-10

196 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