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

#2245 in Algorithms

Download history 34/week @ 2024-11-16 66/week @ 2024-11-23 189/week @ 2024-11-30 58/week @ 2024-12-07 88/week @ 2024-12-14 4/week @ 2024-12-21 4/week @ 2024-12-28 96/week @ 2025-01-04 39/week @ 2025-01-11 14/week @ 2025-01-18 11/week @ 2025-01-25 40/week @ 2025-02-01 49/week @ 2025-02-08 68/week @ 2025-02-15 51/week @ 2025-02-22 153/week @ 2025-03-01

325 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

~1.7–2.4MB
~43K SLoC