good_lp 1.4.0

Mixed Integer Linear Programming for Rust, with an user-friendly API. This crate allows modeling LP problems, and lets you solve them with various solvers.
Documentation
use good_lp::{constraint, variables, Solution, SolverModel, StaticSolver};

// See: https://github.com/rust-or/good_lp/pull/5

fn generic_solve_example<S: StaticSolver>(solver: S) -> Result<(), Box<dyn std::error::Error>> {
    variables! {
        vars:
               a <= 1;
          2 <= b <= 4;
    };
    let solution = vars
        .maximise(10 * (a - b / 5) - b)
        .using(solver)
        .with(constraint!(a + 2 <= b))
        .with(constraint!(1 + a >= 4 - b))
        .solve()?;
    println!("a={}   b={}", solution.value(a), solution.value(b));
    Ok(())
}

#[test]
fn concrete() {
    generic_solve_example(good_lp::default_solver).expect("solve")
}