Skip to content

v1.8.1

Compare
Choose a tag to compare
@galabovaa galabovaa released this 13 Nov 17:11
· 136 commits to master since this release
4a7f24a

Build changes

Added wheels for Python 3.13

Updated command line options and moved them out of the library and into the executable

Code changes

When primal infeasiblity is detected in presolve, no dual ray is available so, previously, the has_dual_ray parameter of Highs::getDualRay returned false and that was it. Now, if a null pointer is not passed for dual_ray_value, Highs::getDualRay will compute a dual ray - at the cost of solving the feasiblility LP without presolve. The same is now true for Highs::getPrimalRay. Highs::getDualUnboundednessDirection has been introduced to determine the product between the constraint matrix and the dual ray, forcing the calculation of the latter if necessary. Once a dual ray is known for the incumbent model in HiGHS, subsequent calls to Highs::getDualRay and Highs::getDualUnboundednessDirection will be vastly cheaper

The method Highs::getDualObjectiveValue now exitsts to compute the dual objective value, returning HighsStatus::kError if it is not possible.

The method Highs::getStandardFormLp now exists to return the incumbent LP in standard form - overlooking any integrality or Hessian. To determine the sizes of the vectors of data, the method is called without specifying pointers to the data arrays.

Added documentation on the use of presolve when solving an incumbent model, and clarifying the use of the method Highs::presolve.

HiGHS will now read a MIPLIB solution file

Added time limit check to HPresolve::strengthenInequalities

Added getColIntegrality to highspy

Now computing the primal-dual integral, reporting it, and making it available as HighsInfo::primal_dual_integral

Trivial primal heuristics "all zero", "all lower bound", "all upper bound", and "lock point" added to the MIP solver