1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
//! Quadratic programming via the active set method.
//!
//! Solves problems of the form:
//!
//! ```text
//! minimize 0.5 x^T H x + c^T x
//! subject to A_ub x <= b_ub
//! ```
//!
//! where `H` is symmetric positive semi-definite.
pub use quadprog;
use Float;
/// Result of a quadratic programming solve.
///
/// # Examples
///
/// ```
/// # use scivex_optim::quadprog::quadprog;
/// // minimize 0.5*(x^2+y^2) s.t. x+y <= 1
/// let result = quadprog(
/// &[vec![1.0_f64, 0.0], vec![0.0, 1.0]],
/// &[0.0, 0.0],
/// &[vec![1.0, 1.0]], &[1.0], 100,
/// ).unwrap();
/// assert!(result.converged);
/// ```