#![allow(non_upper_case_globals)]
#![allow(non_camel_case_types)]
#![allow(non_snake_case)]
include!(concat!(env!("OUT_DIR"), "/bindings.rs"));
#[repr(C)]
#[derive(Clone, Copy, Debug, PartialOrd, PartialEq, Ord, Eq)]
pub enum HighsModelStatus {
NOTSET = 0,
LOAD_ERROR = 1,
MODEL_ERROR = 2,
PRESOLVE_ERROR = 3,
SOLVE_ERROR = 4,
POSTSOLVE_ERROR = 5,
MODEL_EMPTY = 6,
PRIMAL_INFEASIBLE = 7,
PRIMAL_UNBOUNDED = 8,
OPTIMAL = 9,
REACHED_DUAL_OBJECTIVE_VALUE_UPPER_BOUND = 10,
REACHED_TIME_LIMIT = 11,
REACHED_ITERATION_LIMIT = 12,
PRIMAL_DUAL_INFEASIBLE = 13,
DUAL_INFEASIBLE = 14,
}
#[repr(C)]
#[derive(Clone, Copy, Debug, PartialOrd, PartialEq, Ord, Eq)]
pub enum HighsStatus {
OK = 0,
Warning = 1,
Error = 2,
}
#[cfg(test)]
mod tests {
use std::convert::TryInto;
use std::ffi::CString;
use std::os::raw::c_int;
use super::*;
#[test]
fn highs_call() {
let numcol: usize = 2;
let numrow: usize = 3;
let nnz: usize = 5;
let colcost: &mut [f64] = &mut [2.0, 3.0];
let collower: &mut [f64] = &mut [0.0, 1.0];
let colupper: &mut [f64] = &mut [3.0, 1.0e30];
let rowlower: &mut [f64] = &mut [-1.0e30, 10.0, 8.0];
let rowupper: &mut [f64] = &mut [6.0, 14.0, 1.0e30];
let astart: &mut [c_int] = &mut [0, 2];
let aindex: &mut [c_int] = &mut [1, 2, 0, 1, 2];
let avalue: &mut [f64] = &mut [1.0, 2.0, 1.0, 2.0, 1.0];
let colvalue: &mut [f64] = &mut vec![0.; numcol];
let coldual: &mut [f64] = &mut vec![0.; numcol];
let rowvalue: &mut [f64] = &mut vec![0.; numrow];
let rowdual: &mut [f64] = &mut vec![0.; numrow];
let colbasisstatus: &mut [c_int] = &mut vec![0; numcol];
let rowbasisstatus: &mut [c_int] = &mut vec![0; numrow];
let modelstatus: &mut c_int = &mut 0;
let status: c_int = unsafe {
Highs_call(
numcol.try_into().unwrap(),
numrow.try_into().unwrap(),
nnz.try_into().unwrap(),
colcost.as_mut_ptr(),
collower.as_mut_ptr(),
colupper.as_mut_ptr(),
rowlower.as_mut_ptr(),
rowupper.as_mut_ptr(),
astart.as_mut_ptr(),
aindex.as_mut_ptr(),
avalue.as_mut_ptr(),
colvalue.as_mut_ptr(),
coldual.as_mut_ptr(),
rowvalue.as_mut_ptr(),
rowdual.as_mut_ptr(),
colbasisstatus.as_mut_ptr(),
rowbasisstatus.as_mut_ptr(),
modelstatus,
)
};
assert_eq!(status, HighsStatus::OK as c_int);
assert_eq!(colvalue, &[2., 4.]);
}
fn c(n: usize) -> c_int {
n.try_into().unwrap()
}
fn ptr<T>(a: &mut [T]) -> *mut T {
a.as_mut_ptr()
}
#[test]
fn highs_functions() {
unsafe {
let highs = Highs_create();
let numcol: usize = 2;
let numrow: usize = 3;
let nnz: usize = 5;
let colcost: &mut [f64] = &mut [2.0, 3.0];
let collower: &mut [f64] = &mut [0.0, 1.0];
let colupper: &mut [f64] = &mut [3.0, 1.0e30];
let rowlower: &mut [f64] = &mut [-1.0e30, 10.0, 8.0];
let rowupper: &mut [f64] = &mut [6.0, 14.0, 1.0e30];
let arstart: &mut [c_int] = &mut [0, 1, 3];
let arindex: &mut [c_int] = &mut [1, 0, 1, 0, 1];
let arvalue: &mut [f64] = &mut [1.0, 1.0, 2.0, 2.0, 1.0];
use std::ptr::null;
let success = Highs_addCols(highs, c(numcol), ptr(colcost), ptr(collower), ptr(colupper), 0, null(), null(), null());
assert_ne!(0, success, "addCols");
let success = Highs_addRows(highs, c(numrow), ptr(rowlower), ptr(rowupper), c(nnz), ptr(arstart), ptr(arindex), ptr(arvalue));
assert_ne!(0, success, "addRows");
Highs_changeObjectiveSense(highs, -1);
let simplex_scale_strategy = 3;
let option_name = CString::new("simplex_scale_strategy").unwrap();
Highs_setHighsIntOptionValue(highs, option_name.as_ptr(), simplex_scale_strategy);
Highs_runQuiet(highs);
let status = Highs_run(highs);
assert_eq!(status, 0);
let model_status = Highs_getModelStatus(highs, 0);
assert_eq!(model_status, HighsModelStatus::OPTIMAL as c_int);
let mut objective_function_value = 0.;
let info_name = CString::new("objective_function_value").unwrap();
Highs_getHighsDoubleInfoValue(highs, info_name.as_ptr(), (&mut objective_function_value) as *mut f64);
assert_eq!(objective_function_value, 2. * 3. + 3. * 5.5);
let colvalue: &mut [f64] = &mut vec![0.; numcol];
let coldual: &mut [f64] = &mut vec![0.; numcol];
let rowvalue: &mut [f64] = &mut vec![0.; numrow];
let rowdual: &mut [f64] = &mut vec![0.; numrow];
Highs_getSolution(highs, ptr(colvalue), ptr(coldual), ptr(rowvalue), ptr(rowdual));
assert_eq!(colvalue, &[3.0, 5.5]);
let colbasisstatus: &mut [c_int] = &mut vec![0; numcol];
let rowbasisstatus: &mut [c_int] = &mut vec![0; numrow];
Highs_getBasis(highs, ptr(colbasisstatus), ptr(rowbasisstatus));
assert_eq!(colbasisstatus, &[2, 1]);
Highs_destroy(highs);
}
}
}