15 unstable releases (5 breaking)

0.6.0 Apr 22, 2024
0.5.1 Oct 19, 2023
0.4.0 Oct 6, 2023
0.3.3 Aug 24, 2023
0.1.2 Jan 21, 2021

#614 in Algorithms

Download history 406/week @ 2024-09-25 151/week @ 2024-10-02 55/week @ 2024-10-09 245/week @ 2024-10-16 70/week @ 2024-10-23 55/week @ 2024-10-30 275/week @ 2024-11-06 69/week @ 2024-11-13 40/week @ 2024-11-20 89/week @ 2024-11-27 23/week @ 2024-12-04 58/week @ 2024-12-11 131/week @ 2024-12-18 1/week @ 2024-12-25 479/week @ 2025-01-01 24/week @ 2025-01-08

640 downloads per month
Used in 4 crates (2 directly)

Custom license

1MB
17K SLoC

Rust 14K SLoC // 0.0% comments C 3.5K SLoC // 0.2% comments

cobyla - a pure Rust implementation

tests crates.io docs

COBYLA is an algorithm for minimizing a function of many variables. The method is derivatives-free (only the function values are needed) and take into account constraints on the variables. The algorithm is described in:

M.J.D. Powell, "A direct search optimization method that models the objective and constraint functions by linear interpolation," in Advances in Optimization and Numerical Analysis Mathematics and Its Applications, vol. 275 (eds. Susana Gomez and Jean-Pierre Hennart), Kluwer Academic Publishers, pp. 51-67 (1994).

The algorithm comes into two flavours :

  • As an argmin solver, the Rust code was generated from the C code from here
  • As a function minimize, the Rust code was generated from the C code of the NLopt project (version 2.7.1)

In both cases, an initial transpilation was done with c2rust then the code was manually edited to make it work. The callback mechanismn is inspired from the Rust binding of NLopt, namely rust-nlopt

Example

cargo run --example paraboloid

License

The project is released under MIT License.

Dependencies

~4–12MB
~124K SLoC