lpsolver 0.1.0 → 0.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (1165) hide show
  1. checksums.yaml +4 -4
  2. data/Gemfile +1 -0
  3. data/README.md +70 -26
  4. data/ext/lpsolver/Makefile +273 -0
  5. data/ext/lpsolver/ext.c +353 -0
  6. data/ext/lpsolver/ext.o +0 -0
  7. data/ext/lpsolver/extconf.rb +79 -0
  8. data/ext/lpsolver/native.so +0 -0
  9. data/ext/lpsolver-highs/AUTHORS +7 -0
  10. data/ext/lpsolver-highs/BUILD.bazel +243 -0
  11. data/ext/lpsolver-highs/CITATION.cff +29 -0
  12. data/ext/lpsolver-highs/CMakeCache.txt +406 -0
  13. data/ext/lpsolver-highs/CMakeFiles/3.31.4/CMakeCCompiler.cmake +81 -0
  14. data/ext/lpsolver-highs/CMakeFiles/3.31.4/CMakeCXXCompiler.cmake +101 -0
  15. data/ext/lpsolver-highs/CMakeFiles/3.31.4/CMakeDetermineCompilerABI_C.bin +0 -0
  16. data/ext/lpsolver-highs/CMakeFiles/3.31.4/CMakeDetermineCompilerABI_CXX.bin +0 -0
  17. data/ext/lpsolver-highs/CMakeFiles/3.31.4/CMakeSystem.cmake +15 -0
  18. data/ext/lpsolver-highs/CMakeFiles/3.31.4/CompilerIdC/CMakeCCompilerId.c +904 -0
  19. data/ext/lpsolver-highs/CMakeFiles/3.31.4/CompilerIdC/a.out +0 -0
  20. data/ext/lpsolver-highs/CMakeFiles/3.31.4/CompilerIdCXX/CMakeCXXCompilerId.cpp +919 -0
  21. data/ext/lpsolver-highs/CMakeFiles/3.31.4/CompilerIdCXX/a.out +0 -0
  22. data/ext/lpsolver-highs/CMakeFiles/CMakeConfigureLog.yaml +576 -0
  23. data/ext/lpsolver-highs/CMakeFiles/cmake.check_cache +1 -0
  24. data/ext/lpsolver-highs/CMakeLists.txt +983 -0
  25. data/ext/lpsolver-highs/CODE_OF_CONDUCT.md +128 -0
  26. data/ext/lpsolver-highs/CONTRIBUTING.md +31 -0
  27. data/ext/lpsolver-highs/FEATURES.md +61 -0
  28. data/ext/lpsolver-highs/LICENSE.txt +21 -0
  29. data/ext/lpsolver-highs/MODULE.bazel +38 -0
  30. data/ext/lpsolver-highs/README.md +281 -0
  31. data/ext/lpsolver-highs/THIRD_PARTY_NOTICES.md +78 -0
  32. data/ext/lpsolver-highs/Version.txt +4 -0
  33. data/ext/lpsolver-highs/WORKSPACE +33 -0
  34. data/ext/lpsolver-highs/app/CMakeLists.txt +110 -0
  35. data/ext/lpsolver-highs/app/HighsRuntimeOptions.h +292 -0
  36. data/ext/lpsolver-highs/app/RunHighs.cpp +147 -0
  37. data/ext/lpsolver-highs/app/highs_webdemo_shell.html +73 -0
  38. data/ext/lpsolver-highs/build/bin/highs +0 -0
  39. data/ext/lpsolver-highs/build/include/highs/HConfig.h +22 -0
  40. data/ext/lpsolver-highs/build/include/highs/Highs.h +1812 -0
  41. data/ext/lpsolver-highs/build/include/highs/interfaces/highs_c_api.h +2651 -0
  42. data/ext/lpsolver-highs/build/include/highs/io/Filereader.h +45 -0
  43. data/ext/lpsolver-highs/build/include/highs/io/FilereaderLp.h +49 -0
  44. data/ext/lpsolver-highs/build/include/highs/io/FilereaderMps.h +27 -0
  45. data/ext/lpsolver-highs/build/include/highs/io/HMPSIO.h +78 -0
  46. data/ext/lpsolver-highs/build/include/highs/io/HMpsFF.h +245 -0
  47. data/ext/lpsolver-highs/build/include/highs/io/HighsIO.h +118 -0
  48. data/ext/lpsolver-highs/build/include/highs/io/LoadOptions.h +24 -0
  49. data/ext/lpsolver-highs/build/include/highs/io/filereaderlp/builder.hpp +25 -0
  50. data/ext/lpsolver-highs/build/include/highs/io/filereaderlp/def.hpp +19 -0
  51. data/ext/lpsolver-highs/build/include/highs/io/filereaderlp/model.hpp +68 -0
  52. data/ext/lpsolver-highs/build/include/highs/io/filereaderlp/reader.hpp +10 -0
  53. data/ext/lpsolver-highs/build/include/highs/ipm/IpxSolution.h +32 -0
  54. data/ext/lpsolver-highs/build/include/highs/ipm/IpxWrapper.h +106 -0
  55. data/ext/lpsolver-highs/build/include/highs/ipm/basiclu/basiclu.h +161 -0
  56. data/ext/lpsolver-highs/build/include/highs/ipm/basiclu/basiclu_factorize.h +247 -0
  57. data/ext/lpsolver-highs/build/include/highs/ipm/basiclu/basiclu_get_factors.h +108 -0
  58. data/ext/lpsolver-highs/build/include/highs/ipm/basiclu/basiclu_initialize.h +119 -0
  59. data/ext/lpsolver-highs/build/include/highs/ipm/basiclu/basiclu_obj_factorize.h +34 -0
  60. data/ext/lpsolver-highs/build/include/highs/ipm/basiclu/basiclu_obj_free.h +19 -0
  61. data/ext/lpsolver-highs/build/include/highs/ipm/basiclu/basiclu_obj_get_factors.h +34 -0
  62. data/ext/lpsolver-highs/build/include/highs/ipm/basiclu/basiclu_obj_initialize.h +46 -0
  63. data/ext/lpsolver-highs/build/include/highs/ipm/basiclu/basiclu_obj_solve_dense.h +29 -0
  64. data/ext/lpsolver-highs/build/include/highs/ipm/basiclu/basiclu_obj_solve_for_update.h +42 -0
  65. data/ext/lpsolver-highs/build/include/highs/ipm/basiclu/basiclu_obj_solve_sparse.h +32 -0
  66. data/ext/lpsolver-highs/build/include/highs/ipm/basiclu/basiclu_obj_update.h +31 -0
  67. data/ext/lpsolver-highs/build/include/highs/ipm/basiclu/basiclu_object.h +30 -0
  68. data/ext/lpsolver-highs/build/include/highs/ipm/basiclu/basiclu_solve_dense.h +75 -0
  69. data/ext/lpsolver-highs/build/include/highs/ipm/basiclu/basiclu_solve_for_update.h +169 -0
  70. data/ext/lpsolver-highs/build/include/highs/ipm/basiclu/basiclu_solve_sparse.h +112 -0
  71. data/ext/lpsolver-highs/build/include/highs/ipm/basiclu/basiclu_update.h +125 -0
  72. data/ext/lpsolver-highs/build/include/highs/ipm/basiclu/lu_def.h +39 -0
  73. data/ext/lpsolver-highs/build/include/highs/ipm/basiclu/lu_file.h +21 -0
  74. data/ext/lpsolver-highs/build/include/highs/ipm/basiclu/lu_internal.h +220 -0
  75. data/ext/lpsolver-highs/build/include/highs/ipm/basiclu/lu_list.h +173 -0
  76. data/ext/lpsolver-highs/build/include/highs/ipm/ipx/basiclu_kernel.h +20 -0
  77. data/ext/lpsolver-highs/build/include/highs/ipm/ipx/basiclu_wrapper.h +47 -0
  78. data/ext/lpsolver-highs/build/include/highs/ipm/ipx/basis.h +350 -0
  79. data/ext/lpsolver-highs/build/include/highs/ipm/ipx/conjugate_residuals.h +74 -0
  80. data/ext/lpsolver-highs/build/include/highs/ipm/ipx/control.h +167 -0
  81. data/ext/lpsolver-highs/build/include/highs/ipm/ipx/crossover.h +157 -0
  82. data/ext/lpsolver-highs/build/include/highs/ipm/ipx/diagonal_precond.h +45 -0
  83. data/ext/lpsolver-highs/build/include/highs/ipm/ipx/forrest_tomlin.h +102 -0
  84. data/ext/lpsolver-highs/build/include/highs/ipm/ipx/guess_basis.h +21 -0
  85. data/ext/lpsolver-highs/build/include/highs/ipm/ipx/indexed_vector.h +113 -0
  86. data/ext/lpsolver-highs/build/include/highs/ipm/ipx/info.h +27 -0
  87. data/ext/lpsolver-highs/build/include/highs/ipm/ipx/ipm.h +94 -0
  88. data/ext/lpsolver-highs/build/include/highs/ipm/ipx/ipx_c.h +47 -0
  89. data/ext/lpsolver-highs/build/include/highs/ipm/ipx/ipx_config.h +9 -0
  90. data/ext/lpsolver-highs/build/include/highs/ipm/ipx/ipx_info.h +111 -0
  91. data/ext/lpsolver-highs/build/include/highs/ipm/ipx/ipx_internal.h +89 -0
  92. data/ext/lpsolver-highs/build/include/highs/ipm/ipx/ipx_parameters.h +76 -0
  93. data/ext/lpsolver-highs/build/include/highs/ipm/ipx/ipx_status.h +57 -0
  94. data/ext/lpsolver-highs/build/include/highs/ipm/ipx/iterate.h +331 -0
  95. data/ext/lpsolver-highs/build/include/highs/ipm/ipx/kkt_solver.h +70 -0
  96. data/ext/lpsolver-highs/build/include/highs/ipm/ipx/kkt_solver_basis.h +66 -0
  97. data/ext/lpsolver-highs/build/include/highs/ipm/ipx/kkt_solver_diag.h +48 -0
  98. data/ext/lpsolver-highs/build/include/highs/ipm/ipx/linear_operator.h +26 -0
  99. data/ext/lpsolver-highs/build/include/highs/ipm/ipx/lp_solver.h +204 -0
  100. data/ext/lpsolver-highs/build/include/highs/ipm/ipx/lu_factorization.h +79 -0
  101. data/ext/lpsolver-highs/build/include/highs/ipm/ipx/lu_update.h +129 -0
  102. data/ext/lpsolver-highs/build/include/highs/ipm/ipx/maxvolume.h +54 -0
  103. data/ext/lpsolver-highs/build/include/highs/ipm/ipx/model.h +413 -0
  104. data/ext/lpsolver-highs/build/include/highs/ipm/ipx/multistream.h +52 -0
  105. data/ext/lpsolver-highs/build/include/highs/ipm/ipx/normal_matrix.h +44 -0
  106. data/ext/lpsolver-highs/build/include/highs/ipm/ipx/power_method.h +44 -0
  107. data/ext/lpsolver-highs/build/include/highs/ipm/ipx/sparse_matrix.h +195 -0
  108. data/ext/lpsolver-highs/build/include/highs/ipm/ipx/sparse_utils.h +58 -0
  109. data/ext/lpsolver-highs/build/include/highs/ipm/ipx/splitted_normal_matrix.h +63 -0
  110. data/ext/lpsolver-highs/build/include/highs/ipm/ipx/starting_basis.h +39 -0
  111. data/ext/lpsolver-highs/build/include/highs/ipm/ipx/symbolic_invert.h +29 -0
  112. data/ext/lpsolver-highs/build/include/highs/ipm/ipx/timer.h +25 -0
  113. data/ext/lpsolver-highs/build/include/highs/ipm/ipx/utils.h +37 -0
  114. data/ext/lpsolver-highs/build/include/highs/lp_data/HConst.h +430 -0
  115. data/ext/lpsolver-highs/build/include/highs/lp_data/HStruct.h +213 -0
  116. data/ext/lpsolver-highs/build/include/highs/lp_data/HighsAnalysis.h +23 -0
  117. data/ext/lpsolver-highs/build/include/highs/lp_data/HighsCallback.h +104 -0
  118. data/ext/lpsolver-highs/build/include/highs/lp_data/HighsCallbackStruct.h +70 -0
  119. data/ext/lpsolver-highs/build/include/highs/lp_data/HighsDebug.h +34 -0
  120. data/ext/lpsolver-highs/build/include/highs/lp_data/HighsIis.h +139 -0
  121. data/ext/lpsolver-highs/build/include/highs/lp_data/HighsInfo.h +421 -0
  122. data/ext/lpsolver-highs/build/include/highs/lp_data/HighsInfoDebug.h +27 -0
  123. data/ext/lpsolver-highs/build/include/highs/lp_data/HighsLp.h +97 -0
  124. data/ext/lpsolver-highs/build/include/highs/lp_data/HighsLpSolverObject.h +47 -0
  125. data/ext/lpsolver-highs/build/include/highs/lp_data/HighsLpUtils.h +330 -0
  126. data/ext/lpsolver-highs/build/include/highs/lp_data/HighsModelUtils.h +129 -0
  127. data/ext/lpsolver-highs/build/include/highs/lp_data/HighsOptions.h +1715 -0
  128. data/ext/lpsolver-highs/build/include/highs/lp_data/HighsRanging.h +43 -0
  129. data/ext/lpsolver-highs/build/include/highs/lp_data/HighsSolution.h +179 -0
  130. data/ext/lpsolver-highs/build/include/highs/lp_data/HighsSolutionDebug.h +87 -0
  131. data/ext/lpsolver-highs/build/include/highs/lp_data/HighsSolve.h +29 -0
  132. data/ext/lpsolver-highs/build/include/highs/lp_data/HighsStatus.h +29 -0
  133. data/ext/lpsolver-highs/build/include/highs/mip/HighsCliqueTable.h +329 -0
  134. data/ext/lpsolver-highs/build/include/highs/mip/HighsConflictPool.h +109 -0
  135. data/ext/lpsolver-highs/build/include/highs/mip/HighsCutGeneration.h +108 -0
  136. data/ext/lpsolver-highs/build/include/highs/mip/HighsCutPool.h +168 -0
  137. data/ext/lpsolver-highs/build/include/highs/mip/HighsDebugSol.h +133 -0
  138. data/ext/lpsolver-highs/build/include/highs/mip/HighsDomain.h +657 -0
  139. data/ext/lpsolver-highs/build/include/highs/mip/HighsDomainChange.h +48 -0
  140. data/ext/lpsolver-highs/build/include/highs/mip/HighsDynamicRowMatrix.h +104 -0
  141. data/ext/lpsolver-highs/build/include/highs/mip/HighsGFkSolve.h +439 -0
  142. data/ext/lpsolver-highs/build/include/highs/mip/HighsImplications.h +194 -0
  143. data/ext/lpsolver-highs/build/include/highs/mip/HighsLpAggregator.h +50 -0
  144. data/ext/lpsolver-highs/build/include/highs/mip/HighsLpRelaxation.h +361 -0
  145. data/ext/lpsolver-highs/build/include/highs/mip/HighsMipAnalysis.h +71 -0
  146. data/ext/lpsolver-highs/build/include/highs/mip/HighsMipSolver.h +159 -0
  147. data/ext/lpsolver-highs/build/include/highs/mip/HighsMipSolverData.h +313 -0
  148. data/ext/lpsolver-highs/build/include/highs/mip/HighsModkSeparator.h +60 -0
  149. data/ext/lpsolver-highs/build/include/highs/mip/HighsNodeQueue.h +312 -0
  150. data/ext/lpsolver-highs/build/include/highs/mip/HighsObjectiveFunction.h +71 -0
  151. data/ext/lpsolver-highs/build/include/highs/mip/HighsPathSeparator.h +39 -0
  152. data/ext/lpsolver-highs/build/include/highs/mip/HighsPrimalHeuristics.h +75 -0
  153. data/ext/lpsolver-highs/build/include/highs/mip/HighsPseudocost.h +366 -0
  154. data/ext/lpsolver-highs/build/include/highs/mip/HighsRedcostFixing.h +42 -0
  155. data/ext/lpsolver-highs/build/include/highs/mip/HighsSearch.h +241 -0
  156. data/ext/lpsolver-highs/build/include/highs/mip/HighsSeparation.h +41 -0
  157. data/ext/lpsolver-highs/build/include/highs/mip/HighsSeparator.h +60 -0
  158. data/ext/lpsolver-highs/build/include/highs/mip/HighsTableauSeparator.h +34 -0
  159. data/ext/lpsolver-highs/build/include/highs/mip/HighsTransformedLp.h +63 -0
  160. data/ext/lpsolver-highs/build/include/highs/mip/MipTimer.h +544 -0
  161. data/ext/lpsolver-highs/build/include/highs/mip/feasibilityjump.hh +800 -0
  162. data/ext/lpsolver-highs/build/include/highs/model/HighsHessian.h +54 -0
  163. data/ext/lpsolver-highs/build/include/highs/model/HighsHessianUtils.h +47 -0
  164. data/ext/lpsolver-highs/build/include/highs/model/HighsModel.h +42 -0
  165. data/ext/lpsolver-highs/build/include/highs/parallel/HighsBinarySemaphore.h +108 -0
  166. data/ext/lpsolver-highs/build/include/highs/parallel/HighsCacheAlign.h +82 -0
  167. data/ext/lpsolver-highs/build/include/highs/parallel/HighsCombinable.h +116 -0
  168. data/ext/lpsolver-highs/build/include/highs/parallel/HighsMutex.h +124 -0
  169. data/ext/lpsolver-highs/build/include/highs/parallel/HighsParallel.h +128 -0
  170. data/ext/lpsolver-highs/build/include/highs/parallel/HighsRaceTimer.h +38 -0
  171. data/ext/lpsolver-highs/build/include/highs/parallel/HighsSchedulerConstants.h +19 -0
  172. data/ext/lpsolver-highs/build/include/highs/parallel/HighsSpinMutex.h +48 -0
  173. data/ext/lpsolver-highs/build/include/highs/parallel/HighsSplitDeque.h +606 -0
  174. data/ext/lpsolver-highs/build/include/highs/parallel/HighsTask.h +170 -0
  175. data/ext/lpsolver-highs/build/include/highs/parallel/HighsTaskExecutor.h +217 -0
  176. data/ext/lpsolver-highs/build/include/highs/pdlp/CupdlpWrapper.h +108 -0
  177. data/ext/lpsolver-highs/build/include/highs/pdlp/HiPdlpTimer.h +155 -0
  178. data/ext/lpsolver-highs/build/include/highs/pdlp/HiPdlpWrapper.h +26 -0
  179. data/ext/lpsolver-highs/build/include/highs/pdlp/cupdlp/cupdlp_cs.h +40 -0
  180. data/ext/lpsolver-highs/build/include/highs/pdlp/cupdlp/cupdlp_defs.h +447 -0
  181. data/ext/lpsolver-highs/build/include/highs/pdlp/cupdlp/cupdlp_linalg.h +189 -0
  182. data/ext/lpsolver-highs/build/include/highs/pdlp/cupdlp/cupdlp_proj.h +19 -0
  183. data/ext/lpsolver-highs/build/include/highs/pdlp/cupdlp/cupdlp_restart.h +31 -0
  184. data/ext/lpsolver-highs/build/include/highs/pdlp/cupdlp/cupdlp_scaling.h +26 -0
  185. data/ext/lpsolver-highs/build/include/highs/pdlp/cupdlp/cupdlp_solver.h +105 -0
  186. data/ext/lpsolver-highs/build/include/highs/pdlp/cupdlp/cupdlp_step.h +37 -0
  187. data/ext/lpsolver-highs/build/include/highs/pdlp/cupdlp/cupdlp_utils.c +1850 -0
  188. data/ext/lpsolver-highs/build/include/highs/pdlp/hipdlp/defs.hpp +222 -0
  189. data/ext/lpsolver-highs/build/include/highs/pdlp/hipdlp/linalg.hpp +61 -0
  190. data/ext/lpsolver-highs/build/include/highs/pdlp/hipdlp/logger.hpp +80 -0
  191. data/ext/lpsolver-highs/build/include/highs/pdlp/hipdlp/pdhg.hpp +358 -0
  192. data/ext/lpsolver-highs/build/include/highs/pdlp/hipdlp/restart.hpp +96 -0
  193. data/ext/lpsolver-highs/build/include/highs/pdlp/hipdlp/scaling.hpp +74 -0
  194. data/ext/lpsolver-highs/build/include/highs/pdlp/hipdlp/solver_results.hpp +65 -0
  195. data/ext/lpsolver-highs/build/include/highs/pdqsort/pdqsort.h +532 -0
  196. data/ext/lpsolver-highs/build/include/highs/presolve/HPresolve.h +505 -0
  197. data/ext/lpsolver-highs/build/include/highs/presolve/HPresolveAnalysis.h +52 -0
  198. data/ext/lpsolver-highs/build/include/highs/presolve/HighsPostsolveStack.h +943 -0
  199. data/ext/lpsolver-highs/build/include/highs/presolve/HighsSymmetry.h +284 -0
  200. data/ext/lpsolver-highs/build/include/highs/presolve/ICrash.h +124 -0
  201. data/ext/lpsolver-highs/build/include/highs/presolve/ICrashUtil.h +62 -0
  202. data/ext/lpsolver-highs/build/include/highs/presolve/ICrashX.h +23 -0
  203. data/ext/lpsolver-highs/build/include/highs/presolve/PresolveComponent.h +90 -0
  204. data/ext/lpsolver-highs/build/include/highs/qpsolver/a_asm.hpp +77 -0
  205. data/ext/lpsolver-highs/build/include/highs/qpsolver/a_quass.hpp +22 -0
  206. data/ext/lpsolver-highs/build/include/highs/qpsolver/basis.hpp +159 -0
  207. data/ext/lpsolver-highs/build/include/highs/qpsolver/crashsolution.hpp +20 -0
  208. data/ext/lpsolver-highs/build/include/highs/qpsolver/dantzigpricing.hpp +80 -0
  209. data/ext/lpsolver-highs/build/include/highs/qpsolver/devexpricing.hpp +108 -0
  210. data/ext/lpsolver-highs/build/include/highs/qpsolver/eventhandler.hpp +30 -0
  211. data/ext/lpsolver-highs/build/include/highs/qpsolver/factor.hpp +408 -0
  212. data/ext/lpsolver-highs/build/include/highs/qpsolver/feasibility_bounded.hpp +114 -0
  213. data/ext/lpsolver-highs/build/include/highs/qpsolver/feasibility_highs.hpp +301 -0
  214. data/ext/lpsolver-highs/build/include/highs/qpsolver/gradient.hpp +46 -0
  215. data/ext/lpsolver-highs/build/include/highs/qpsolver/instance.hpp +70 -0
  216. data/ext/lpsolver-highs/build/include/highs/qpsolver/matrix.hpp +342 -0
  217. data/ext/lpsolver-highs/build/include/highs/qpsolver/perturbation.hpp +15 -0
  218. data/ext/lpsolver-highs/build/include/highs/qpsolver/pricing.hpp +22 -0
  219. data/ext/lpsolver-highs/build/include/highs/qpsolver/qpconst.hpp +34 -0
  220. data/ext/lpsolver-highs/build/include/highs/qpsolver/qpvector.hpp +242 -0
  221. data/ext/lpsolver-highs/build/include/highs/qpsolver/quass.hpp +27 -0
  222. data/ext/lpsolver-highs/build/include/highs/qpsolver/ratiotest.hpp +26 -0
  223. data/ext/lpsolver-highs/build/include/highs/qpsolver/runtime.hpp +45 -0
  224. data/ext/lpsolver-highs/build/include/highs/qpsolver/scaling.hpp +15 -0
  225. data/ext/lpsolver-highs/build/include/highs/qpsolver/settings.hpp +84 -0
  226. data/ext/lpsolver-highs/build/include/highs/qpsolver/snippets.hpp +36 -0
  227. data/ext/lpsolver-highs/build/include/highs/qpsolver/statistics.hpp +30 -0
  228. data/ext/lpsolver-highs/build/include/highs/qpsolver/steepestedgepricing.hpp +173 -0
  229. data/ext/lpsolver-highs/build/include/highs/simplex/HApp.h +550 -0
  230. data/ext/lpsolver-highs/build/include/highs/simplex/HEkk.h +419 -0
  231. data/ext/lpsolver-highs/build/include/highs/simplex/HEkkDual.h +513 -0
  232. data/ext/lpsolver-highs/build/include/highs/simplex/HEkkDualRHS.h +134 -0
  233. data/ext/lpsolver-highs/build/include/highs/simplex/HEkkDualRow.h +201 -0
  234. data/ext/lpsolver-highs/build/include/highs/simplex/HEkkPrimal.h +191 -0
  235. data/ext/lpsolver-highs/build/include/highs/simplex/HSimplex.h +42 -0
  236. data/ext/lpsolver-highs/build/include/highs/simplex/HSimplexDebug.h +48 -0
  237. data/ext/lpsolver-highs/build/include/highs/simplex/HSimplexNla.h +158 -0
  238. data/ext/lpsolver-highs/build/include/highs/simplex/HSimplexReport.h +21 -0
  239. data/ext/lpsolver-highs/build/include/highs/simplex/HighsSimplexAnalysis.h +500 -0
  240. data/ext/lpsolver-highs/build/include/highs/simplex/SimplexConst.h +273 -0
  241. data/ext/lpsolver-highs/build/include/highs/simplex/SimplexStruct.h +263 -0
  242. data/ext/lpsolver-highs/build/include/highs/simplex/SimplexTimer.h +414 -0
  243. data/ext/lpsolver-highs/build/include/highs/test_kkt/DevKkt.h +143 -0
  244. data/ext/lpsolver-highs/build/include/highs/test_kkt/KktCh2.h +79 -0
  245. data/ext/lpsolver-highs/build/include/highs/util/FactorTimer.h +199 -0
  246. data/ext/lpsolver-highs/build/include/highs/util/HFactor.h +587 -0
  247. data/ext/lpsolver-highs/build/include/highs/util/HFactorConst.h +81 -0
  248. data/ext/lpsolver-highs/build/include/highs/util/HFactorDebug.h +55 -0
  249. data/ext/lpsolver-highs/build/include/highs/util/HSet.h +89 -0
  250. data/ext/lpsolver-highs/build/include/highs/util/HVector.h +22 -0
  251. data/ext/lpsolver-highs/build/include/highs/util/HVectorBase.h +102 -0
  252. data/ext/lpsolver-highs/build/include/highs/util/HighsCDouble.h +323 -0
  253. data/ext/lpsolver-highs/build/include/highs/util/HighsComponent.h +53 -0
  254. data/ext/lpsolver-highs/build/include/highs/util/HighsDataStack.h +83 -0
  255. data/ext/lpsolver-highs/build/include/highs/util/HighsDisjointSets.h +107 -0
  256. data/ext/lpsolver-highs/build/include/highs/util/HighsHash.h +1274 -0
  257. data/ext/lpsolver-highs/build/include/highs/util/HighsHashTree.h +1461 -0
  258. data/ext/lpsolver-highs/build/include/highs/util/HighsInt.h +36 -0
  259. data/ext/lpsolver-highs/build/include/highs/util/HighsIntegers.h +212 -0
  260. data/ext/lpsolver-highs/build/include/highs/util/HighsLinearSumBounds.h +203 -0
  261. data/ext/lpsolver-highs/build/include/highs/util/HighsMatrixPic.h +37 -0
  262. data/ext/lpsolver-highs/build/include/highs/util/HighsMatrixSlice.h +561 -0
  263. data/ext/lpsolver-highs/build/include/highs/util/HighsMatrixUtils.h +57 -0
  264. data/ext/lpsolver-highs/build/include/highs/util/HighsMemoryAllocation.h +63 -0
  265. data/ext/lpsolver-highs/build/include/highs/util/HighsRandom.h +242 -0
  266. data/ext/lpsolver-highs/build/include/highs/util/HighsRbTree.h +452 -0
  267. data/ext/lpsolver-highs/build/include/highs/util/HighsSort.h +131 -0
  268. data/ext/lpsolver-highs/build/include/highs/util/HighsSparseMatrix.h +151 -0
  269. data/ext/lpsolver-highs/build/include/highs/util/HighsSparseVectorSum.h +95 -0
  270. data/ext/lpsolver-highs/build/include/highs/util/HighsSplay.h +135 -0
  271. data/ext/lpsolver-highs/build/include/highs/util/HighsTimer.h +385 -0
  272. data/ext/lpsolver-highs/build/include/highs/util/HighsUtils.h +272 -0
  273. data/ext/lpsolver-highs/build/include/highs/util/stringutil.h +46 -0
  274. data/ext/lpsolver-highs/build/include/highs/zstr/strict_fstream.hpp +237 -0
  275. data/ext/lpsolver-highs/build/include/highs/zstr/zstr.hpp +473 -0
  276. data/ext/lpsolver-highs/build/include/highs_export.h +43 -0
  277. data/ext/lpsolver-highs/build/lib/cmake/highs/highs-config-version.cmake +65 -0
  278. data/ext/lpsolver-highs/build/lib/cmake/highs/highs-config.cmake +36 -0
  279. data/ext/lpsolver-highs/build/lib/cmake/highs/highs-targets-release.cmake +19 -0
  280. data/ext/lpsolver-highs/build/lib/cmake/highs/highs-targets.cmake +111 -0
  281. data/ext/lpsolver-highs/build/lib/libhighs.a +0 -0
  282. data/ext/lpsolver-highs/build/lib/pkgconfig/highs.pc +12 -0
  283. data/ext/lpsolver-highs/build/share/doc/HIGHS/AUTHORS +7 -0
  284. data/ext/lpsolver-highs/build/share/doc/HIGHS/CITATION.cff +29 -0
  285. data/ext/lpsolver-highs/build/share/doc/HIGHS/CODE_OF_CONDUCT.md +128 -0
  286. data/ext/lpsolver-highs/build/share/doc/HIGHS/CONTRIBUTING.md +31 -0
  287. data/ext/lpsolver-highs/build/share/doc/HIGHS/FEATURES.md +61 -0
  288. data/ext/lpsolver-highs/build/share/doc/HIGHS/LICENSE.txt +21 -0
  289. data/ext/lpsolver-highs/build/share/doc/HIGHS/README.md +281 -0
  290. data/ext/lpsolver-highs/build_webdemo.sh +46 -0
  291. data/ext/lpsolver-highs/check/Avgas.cpp +245 -0
  292. data/ext/lpsolver-highs/check/Avgas.h +44 -0
  293. data/ext/lpsolver-highs/check/CMakeLists.txt +573 -0
  294. data/ext/lpsolver-highs/check/HCheckConfig.h.bazel.in +6 -0
  295. data/ext/lpsolver-highs/check/HCheckConfig.h.in +12 -0
  296. data/ext/lpsolver-highs/check/HCheckConfig.h.meson.in +6 -0
  297. data/ext/lpsolver-highs/check/SpecialLps.h +405 -0
  298. data/ext/lpsolver-highs/check/TestAlienBasis.cpp +720 -0
  299. data/ext/lpsolver-highs/check/TestBasis.cpp +359 -0
  300. data/ext/lpsolver-highs/check/TestBasisSolves.cpp +669 -0
  301. data/ext/lpsolver-highs/check/TestCAPI.c +2513 -0
  302. data/ext/lpsolver-highs/check/TestCallbacks.cpp +608 -0
  303. data/ext/lpsolver-highs/check/TestCheckSolution.cpp +740 -0
  304. data/ext/lpsolver-highs/check/TestCrossover.cpp +111 -0
  305. data/ext/lpsolver-highs/check/TestDualize.cpp +172 -0
  306. data/ext/lpsolver-highs/check/TestEkk.cpp +100 -0
  307. data/ext/lpsolver-highs/check/TestFactor.cpp +389 -0
  308. data/ext/lpsolver-highs/check/TestFilereader.cpp +568 -0
  309. data/ext/lpsolver-highs/check/TestFortranAPI.f90 +65 -0
  310. data/ext/lpsolver-highs/check/TestHSet.cpp +80 -0
  311. data/ext/lpsolver-highs/check/TestHighsCDouble.cpp +109 -0
  312. data/ext/lpsolver-highs/check/TestHighsGFkSolve.cpp +102 -0
  313. data/ext/lpsolver-highs/check/TestHighsHash.cpp +126 -0
  314. data/ext/lpsolver-highs/check/TestHighsHessian.cpp +329 -0
  315. data/ext/lpsolver-highs/check/TestHighsIntegers.cpp +42 -0
  316. data/ext/lpsolver-highs/check/TestHighsModel.cpp +134 -0
  317. data/ext/lpsolver-highs/check/TestHighsParallel.cpp +277 -0
  318. data/ext/lpsolver-highs/check/TestHighsRbTree.cpp +109 -0
  319. data/ext/lpsolver-highs/check/TestHighsSparseMatrix.cpp +126 -0
  320. data/ext/lpsolver-highs/check/TestHighsVersion.cpp +61 -0
  321. data/ext/lpsolver-highs/check/TestHipo.cpp +122 -0
  322. data/ext/lpsolver-highs/check/TestICrash.cpp +46 -0
  323. data/ext/lpsolver-highs/check/TestIO.cpp +163 -0
  324. data/ext/lpsolver-highs/check/TestIis.cpp +1063 -0
  325. data/ext/lpsolver-highs/check/TestInfo.cpp +116 -0
  326. data/ext/lpsolver-highs/check/TestIpm.cpp +226 -0
  327. data/ext/lpsolver-highs/check/TestIpx.cpp +96 -0
  328. data/ext/lpsolver-highs/check/TestLPFileFormat.cpp +22 -0
  329. data/ext/lpsolver-highs/check/TestLogging.cpp +69 -0
  330. data/ext/lpsolver-highs/check/TestLpModification.cpp +2497 -0
  331. data/ext/lpsolver-highs/check/TestLpOrientation.cpp +121 -0
  332. data/ext/lpsolver-highs/check/TestLpSolvers.cpp +555 -0
  333. data/ext/lpsolver-highs/check/TestLpValidation.cpp +689 -0
  334. data/ext/lpsolver-highs/check/TestMain.cpp +6 -0
  335. data/ext/lpsolver-highs/check/TestMipSolver.cpp +1406 -0
  336. data/ext/lpsolver-highs/check/TestModelProperties.cpp +143 -0
  337. data/ext/lpsolver-highs/check/TestMultiObjective.cpp +198 -0
  338. data/ext/lpsolver-highs/check/TestNames.cpp +187 -0
  339. data/ext/lpsolver-highs/check/TestOptions.cpp +544 -0
  340. data/ext/lpsolver-highs/check/TestPdlp.cpp +327 -0
  341. data/ext/lpsolver-highs/check/TestPdlpHi.cpp +40 -0
  342. data/ext/lpsolver-highs/check/TestPresolve.cpp +912 -0
  343. data/ext/lpsolver-highs/check/TestQpSolver.cpp +1345 -0
  344. data/ext/lpsolver-highs/check/TestRanging.cpp +558 -0
  345. data/ext/lpsolver-highs/check/TestRays.cpp +1010 -0
  346. data/ext/lpsolver-highs/check/TestSemiVariables.cpp +329 -0
  347. data/ext/lpsolver-highs/check/TestSetup.cpp +12 -0
  348. data/ext/lpsolver-highs/check/TestSort.cpp +247 -0
  349. data/ext/lpsolver-highs/check/TestSpecialLps.cpp +775 -0
  350. data/ext/lpsolver-highs/check/TestThrow.cpp +83 -0
  351. data/ext/lpsolver-highs/check/TestTspSolver.cpp +19 -0
  352. data/ext/lpsolver-highs/check/TestUserScale.cpp +444 -0
  353. data/ext/lpsolver-highs/check/cublas_example.cpp +76 -0
  354. data/ext/lpsolver-highs/check/cublas_gpu_start.cpp +88 -0
  355. data/ext/lpsolver-highs/check/hipo_test_option_files/hipo_options_0 +1 -0
  356. data/ext/lpsolver-highs/check/instances/1448.lp +1 -0
  357. data/ext/lpsolver-highs/check/instances/1449a.lp +1 -0
  358. data/ext/lpsolver-highs/check/instances/1449b.lp +1 -0
  359. data/ext/lpsolver-highs/check/instances/1451.lp +8 -0
  360. data/ext/lpsolver-highs/check/instances/2122.lp +1822 -0
  361. data/ext/lpsolver-highs/check/instances/2171.mps +717 -0
  362. data/ext/lpsolver-highs/check/instances/25fv47.mps +6919 -0
  363. data/ext/lpsolver-highs/check/instances/2821-duplicate.mps +31 -0
  364. data/ext/lpsolver-highs/check/instances/2821-qmatrix.mps +31 -0
  365. data/ext/lpsolver-highs/check/instances/2821-quadobj.mps +29 -0
  366. data/ext/lpsolver-highs/check/instances/2821-summation.mps +30 -0
  367. data/ext/lpsolver-highs/check/instances/2821.mps +29 -0
  368. data/ext/lpsolver-highs/check/instances/2894.mps +89 -0
  369. data/ext/lpsolver-highs/check/instances/80bau3b.mps +23732 -0
  370. data/ext/lpsolver-highs/check/instances/WithInf.set +3 -0
  371. data/ext/lpsolver-highs/check/instances/adlittle.mps +335 -0
  372. data/ext/lpsolver-highs/check/instances/afiro.mps +83 -0
  373. data/ext/lpsolver-highs/check/instances/avgas.mps +51 -0
  374. data/ext/lpsolver-highs/check/instances/bell5.mps +384 -0
  375. data/ext/lpsolver-highs/check/instances/bgetam.mps +2112 -0
  376. data/ext/lpsolver-highs/check/instances/blending.mps +13 -0
  377. data/ext/lpsolver-highs/check/instances/box1.mps +1085 -0
  378. data/ext/lpsolver-highs/check/instances/chip.mps +13 -0
  379. data/ext/lpsolver-highs/check/instances/comment.mps +23 -0
  380. data/ext/lpsolver-highs/check/instances/cplex1.mps +9674 -0
  381. data/ext/lpsolver-highs/check/instances/dD2e.mps +10 -0
  382. data/ext/lpsolver-highs/check/instances/dcmulti.mps +2310 -0
  383. data/ext/lpsolver-highs/check/instances/e226.mps +1733 -0
  384. data/ext/lpsolver-highs/check/instances/egout-ac.mps +473 -0
  385. data/ext/lpsolver-highs/check/instances/egout.mps +403 -0
  386. data/ext/lpsolver-highs/check/instances/etamacro.mps +2084 -0
  387. data/ext/lpsolver-highs/check/instances/ex72a.mps +849 -0
  388. data/ext/lpsolver-highs/check/instances/fixed-binary.lp +11 -0
  389. data/ext/lpsolver-highs/check/instances/flugpl.mps +111 -0
  390. data/ext/lpsolver-highs/check/instances/flugpl_illegal_integer.sol +24 -0
  391. data/ext/lpsolver-highs/check/instances/flugpl_integer.sol +25 -0
  392. data/ext/lpsolver-highs/check/instances/forest6.mps +261 -0
  393. data/ext/lpsolver-highs/check/instances/galenet.mps +34 -0
  394. data/ext/lpsolver-highs/check/instances/gams10am.mps +478 -0
  395. data/ext/lpsolver-highs/check/instances/garbage.ems +3 -0
  396. data/ext/lpsolver-highs/check/instances/garbage.lp +3 -0
  397. data/ext/lpsolver-highs/check/instances/garbage.mps +3 -0
  398. data/ext/lpsolver-highs/check/instances/gas11.mps +2924 -0
  399. data/ext/lpsolver-highs/check/instances/gesa2.mps +5459 -0
  400. data/ext/lpsolver-highs/check/instances/greenbea.mps +19215 -0
  401. data/ext/lpsolver-highs/check/instances/gt2.mps +534 -0
  402. data/ext/lpsolver-highs/check/instances/infeasible-mip0.mps +140 -0
  403. data/ext/lpsolver-highs/check/instances/infeasible-mip1.mps +371 -0
  404. data/ext/lpsolver-highs/check/instances/israel.mps +1490 -0
  405. data/ext/lpsolver-highs/check/instances/issue-2095.mps +836 -0
  406. data/ext/lpsolver-highs/check/instances/issue-2173.mps +3331 -0
  407. data/ext/lpsolver-highs/check/instances/issue-2204.mps +143 -0
  408. data/ext/lpsolver-highs/check/instances/issue-2290.mps +158 -0
  409. data/ext/lpsolver-highs/check/instances/issue-2388.lp +76 -0
  410. data/ext/lpsolver-highs/check/instances/issue-2402.mps +435 -0
  411. data/ext/lpsolver-highs/check/instances/issue-2446.mps +9154 -0
  412. data/ext/lpsolver-highs/check/instances/issue-2585.lp +16 -0
  413. data/ext/lpsolver-highs/check/instances/issue-2874-3.mps +97 -0
  414. data/ext/lpsolver-highs/check/instances/klein1.mps +422 -0
  415. data/ext/lpsolver-highs/check/instances/lseu.mps +371 -0
  416. data/ext/lpsolver-highs/check/instances/model.xyz +1 -0
  417. data/ext/lpsolver-highs/check/instances/nan0.mps +13 -0
  418. data/ext/lpsolver-highs/check/instances/nan1.mps +13 -0
  419. data/ext/lpsolver-highs/check/instances/nan2.mps +13 -0
  420. data/ext/lpsolver-highs/check/instances/no-newline-eof.lp +5 -0
  421. data/ext/lpsolver-highs/check/instances/p01.mps +909 -0
  422. data/ext/lpsolver-highs/check/instances/p0548.mps +1992 -0
  423. data/ext/lpsolver-highs/check/instances/primal1.mps +3909 -0
  424. data/ext/lpsolver-highs/check/instances/qap04.mps +606 -0
  425. data/ext/lpsolver-highs/check/instances/qcqp.lp +8 -0
  426. data/ext/lpsolver-highs/check/instances/qjh.lp +9 -0
  427. data/ext/lpsolver-highs/check/instances/qjh.mps +18 -0
  428. data/ext/lpsolver-highs/check/instances/qjh_qmatrix.mps +19 -0
  429. data/ext/lpsolver-highs/check/instances/qjh_quadobj.mps +18 -0
  430. data/ext/lpsolver-highs/check/instances/qjh_quadobj_qmatrix.mps +25 -0
  431. data/ext/lpsolver-highs/check/instances/qjh_uncon.lp +10 -0
  432. data/ext/lpsolver-highs/check/instances/qjh_uncon.mps +17 -0
  433. data/ext/lpsolver-highs/check/instances/qpinfeasible.lp +8 -0
  434. data/ext/lpsolver-highs/check/instances/qptestnw.lp +7 -0
  435. data/ext/lpsolver-highs/check/instances/qpunbounded.lp +5 -0
  436. data/ext/lpsolver-highs/check/instances/refinery.mps +1882 -0
  437. data/ext/lpsolver-highs/check/instances/rgn.mps +559 -0
  438. data/ext/lpsolver-highs/check/instances/scrs8.mps +2717 -0
  439. data/ext/lpsolver-highs/check/instances/sctest.mps +66 -0
  440. data/ext/lpsolver-highs/check/instances/semi-continuous.lp +13 -0
  441. data/ext/lpsolver-highs/check/instances/semi-continuous.mps +24 -0
  442. data/ext/lpsolver-highs/check/instances/semi-integer.lp +15 -0
  443. data/ext/lpsolver-highs/check/instances/semi-integer.mps +22 -0
  444. data/ext/lpsolver-highs/check/instances/shell.mps +4039 -0
  445. data/ext/lpsolver-highs/check/instances/silly-names.mps +14 -0
  446. data/ext/lpsolver-highs/check/instances/small_mip.mps +87 -0
  447. data/ext/lpsolver-highs/check/instances/smalllp.mps +21 -0
  448. data/ext/lpsolver-highs/check/instances/sp150x300d.mps +1983 -0
  449. data/ext/lpsolver-highs/check/instances/stair.mps +2499 -0
  450. data/ext/lpsolver-highs/check/instances/standata.mps +2317 -0
  451. data/ext/lpsolver-highs/check/instances/standgub.mps +2428 -0
  452. data/ext/lpsolver-highs/check/instances/standmps.mps +2695 -0
  453. data/ext/lpsolver-highs/check/instances/test.mps +53 -0
  454. data/ext/lpsolver-highs/check/instances/vol1.mps +1895 -0
  455. data/ext/lpsolver-highs/check/instances/warnings.mps +68 -0
  456. data/ext/lpsolver-highs/check/instances/woodinfe.mps +216 -0
  457. data/ext/lpsolver-highs/check/matrix_multiplication.hpp +49 -0
  458. data/ext/lpsolver-highs/check/meson.build +92 -0
  459. data/ext/lpsolver-highs/check/pythontest.py +11 -0
  460. data/ext/lpsolver-highs/check/sample_options_file +8 -0
  461. data/ext/lpsolver-highs/cmake/CheckAtomic.cmake +74 -0
  462. data/ext/lpsolver-highs/cmake/FindCUDAConf.cmake +44 -0
  463. data/ext/lpsolver-highs/cmake/FindHipoDeps.cmake +351 -0
  464. data/ext/lpsolver-highs/cmake/README.md +243 -0
  465. data/ext/lpsolver-highs/cmake/cpp-highs.cmake +243 -0
  466. data/ext/lpsolver-highs/cmake/dotnet.cmake +94 -0
  467. data/ext/lpsolver-highs/cmake/highs-config.cmake.in +22 -0
  468. data/ext/lpsolver-highs/cmake/python-highs.cmake +74 -0
  469. data/ext/lpsolver-highs/cmake/set-version.cmake +26 -0
  470. data/ext/lpsolver-highs/cmake/sources-python.cmake +461 -0
  471. data/ext/lpsolver-highs/cmake/sources.cmake +618 -0
  472. data/ext/lpsolver-highs/docs/HiGHS_CopyrightHeader.pl +78 -0
  473. data/ext/lpsolver-highs/docs/HiGHS_CopyrightHeaderUpdateAll +32 -0
  474. data/ext/lpsolver-highs/docs/Project.toml +7 -0
  475. data/ext/lpsolver-highs/docs/README.md +27 -0
  476. data/ext/lpsolver-highs/docs/c_api_gen/HConfig.h +1 -0
  477. data/ext/lpsolver-highs/docs/c_api_gen/build.jl +48 -0
  478. data/ext/lpsolver-highs/docs/make.jl +115 -0
  479. data/ext/lpsolver-highs/docs/src/assets/logo.png +0 -0
  480. data/ext/lpsolver-highs/docs/src/callbacks.md +171 -0
  481. data/ext/lpsolver-highs/docs/src/executable.md +88 -0
  482. data/ext/lpsolver-highs/docs/src/guide/advanced.md +66 -0
  483. data/ext/lpsolver-highs/docs/src/guide/basic.md +116 -0
  484. data/ext/lpsolver-highs/docs/src/guide/further.md +193 -0
  485. data/ext/lpsolver-highs/docs/src/guide/gpu.md +58 -0
  486. data/ext/lpsolver-highs/docs/src/guide/index.md +18 -0
  487. data/ext/lpsolver-highs/docs/src/guide/kkt.md +219 -0
  488. data/ext/lpsolver-highs/docs/src/guide/numerics.md +55 -0
  489. data/ext/lpsolver-highs/docs/src/index.md +86 -0
  490. data/ext/lpsolver-highs/docs/src/installation.md +130 -0
  491. data/ext/lpsolver-highs/docs/src/interfaces/c_api.md +6 -0
  492. data/ext/lpsolver-highs/docs/src/interfaces/cpp/examples.md +1 -0
  493. data/ext/lpsolver-highs/docs/src/interfaces/cpp/index.md +29 -0
  494. data/ext/lpsolver-highs/docs/src/interfaces/cpp/library.md +107 -0
  495. data/ext/lpsolver-highs/docs/src/interfaces/csharp.md +55 -0
  496. data/ext/lpsolver-highs/docs/src/interfaces/fortran.md +11 -0
  497. data/ext/lpsolver-highs/docs/src/interfaces/julia/index.md +130 -0
  498. data/ext/lpsolver-highs/docs/src/interfaces/other.md +41 -0
  499. data/ext/lpsolver-highs/docs/src/interfaces/python/example-py.md +275 -0
  500. data/ext/lpsolver-highs/docs/src/interfaces/python/index.md +91 -0
  501. data/ext/lpsolver-highs/docs/src/interfaces/python/model-py.md +90 -0
  502. data/ext/lpsolver-highs/docs/src/options/definitions.md +529 -0
  503. data/ext/lpsolver-highs/docs/src/options/intro.md +46 -0
  504. data/ext/lpsolver-highs/docs/src/parallel.md +88 -0
  505. data/ext/lpsolver-highs/docs/src/solvers.md +168 -0
  506. data/ext/lpsolver-highs/docs/src/structures/classes/HighsHessian.md +9 -0
  507. data/ext/lpsolver-highs/docs/src/structures/classes/HighsIis.md +16 -0
  508. data/ext/lpsolver-highs/docs/src/structures/classes/HighsLp.md +19 -0
  509. data/ext/lpsolver-highs/docs/src/structures/classes/HighsModel.md +6 -0
  510. data/ext/lpsolver-highs/docs/src/structures/classes/HighsSparseMatrix.md +10 -0
  511. data/ext/lpsolver-highs/docs/src/structures/classes/index.md +11 -0
  512. data/ext/lpsolver-highs/docs/src/structures/enums.md +114 -0
  513. data/ext/lpsolver-highs/docs/src/structures/index.md +12 -0
  514. data/ext/lpsolver-highs/docs/src/structures/structs/HighsBasis.md +8 -0
  515. data/ext/lpsolver-highs/docs/src/structures/structs/HighsInfo.md +148 -0
  516. data/ext/lpsolver-highs/docs/src/structures/structs/HighsLinearObjective.md +11 -0
  517. data/ext/lpsolver-highs/docs/src/structures/structs/HighsSolution.md +10 -0
  518. data/ext/lpsolver-highs/docs/src/structures/structs/index.md +10 -0
  519. data/ext/lpsolver-highs/docs/src/terminology.md +163 -0
  520. data/ext/lpsolver-highs/examples/CMakeLists.txt +26 -0
  521. data/ext/lpsolver-highs/examples/Docs.py +104 -0
  522. data/ext/lpsolver-highs/examples/branch-and-price.py +465 -0
  523. data/ext/lpsolver-highs/examples/call_highs_from_c.c +685 -0
  524. data/ext/lpsolver-highs/examples/call_highs_from_c_minimal.c +659 -0
  525. data/ext/lpsolver-highs/examples/call_highs_from_cpp.cpp +178 -0
  526. data/ext/lpsolver-highs/examples/call_highs_from_csharp.cs +83 -0
  527. data/ext/lpsolver-highs/examples/call_highs_from_fortran.f90 +579 -0
  528. data/ext/lpsolver-highs/examples/call_highs_from_python.py +448 -0
  529. data/ext/lpsolver-highs/examples/call_highs_from_python_highspy.py +71 -0
  530. data/ext/lpsolver-highs/examples/call_highs_from_python_mps.py +59 -0
  531. data/ext/lpsolver-highs/examples/callback_gap.py +71 -0
  532. data/ext/lpsolver-highs/examples/chip.py +43 -0
  533. data/ext/lpsolver-highs/examples/chip0.py +29 -0
  534. data/ext/lpsolver-highs/examples/distillation.py +77 -0
  535. data/ext/lpsolver-highs/examples/knapsack.py +43 -0
  536. data/ext/lpsolver-highs/examples/minimal.py +11 -0
  537. data/ext/lpsolver-highs/examples/multi_objective.py +139 -0
  538. data/ext/lpsolver-highs/examples/multiple_objective.py +120 -0
  539. data/ext/lpsolver-highs/examples/network_flow.py +37 -0
  540. data/ext/lpsolver-highs/examples/nqueens.py +29 -0
  541. data/ext/lpsolver-highs/examples/plot_highs_log.py +134 -0
  542. data/ext/lpsolver-highs/extern/CLI11.hpp +11546 -0
  543. data/ext/lpsolver-highs/extern/LICENCE_1_0.txt +23 -0
  544. data/ext/lpsolver-highs/extern/amd/License.txt +35 -0
  545. data/ext/lpsolver-highs/extern/amd/SuiteSparse_config.c +54 -0
  546. data/ext/lpsolver-highs/extern/amd/SuiteSparse_config.h +56 -0
  547. data/ext/lpsolver-highs/extern/amd/amd.h +357 -0
  548. data/ext/lpsolver-highs/extern/amd/amd_1.c +172 -0
  549. data/ext/lpsolver-highs/extern/amd/amd_2.c +1761 -0
  550. data/ext/lpsolver-highs/extern/amd/amd_aat.c +179 -0
  551. data/ext/lpsolver-highs/extern/amd/amd_control.c +65 -0
  552. data/ext/lpsolver-highs/extern/amd/amd_defaults.c +37 -0
  553. data/ext/lpsolver-highs/extern/amd/amd_info.c +120 -0
  554. data/ext/lpsolver-highs/extern/amd/amd_internal.h +137 -0
  555. data/ext/lpsolver-highs/extern/amd/amd_order.c +195 -0
  556. data/ext/lpsolver-highs/extern/amd/amd_post_tree.c +105 -0
  557. data/ext/lpsolver-highs/extern/amd/amd_postorder.c +140 -0
  558. data/ext/lpsolver-highs/extern/amd/amd_preprocess.c +107 -0
  559. data/ext/lpsolver-highs/extern/amd/amd_valid.c +93 -0
  560. data/ext/lpsolver-highs/extern/amd/changes.txt +8 -0
  561. data/ext/lpsolver-highs/extern/catch.hpp +18861 -0
  562. data/ext/lpsolver-highs/extern/metis/Changes.txt +31 -0
  563. data/ext/lpsolver-highs/extern/metis/GKlib/GKlib.h +62 -0
  564. data/ext/lpsolver-highs/extern/metis/GKlib/error.c +21 -0
  565. data/ext/lpsolver-highs/extern/metis/GKlib/gk_arch.h +64 -0
  566. data/ext/lpsolver-highs/extern/metis/GKlib/gk_defs.h +19 -0
  567. data/ext/lpsolver-highs/extern/metis/GKlib/gk_macros.h +50 -0
  568. data/ext/lpsolver-highs/extern/metis/GKlib/gk_mkblas.h +51 -0
  569. data/ext/lpsolver-highs/extern/metis/GKlib/gk_mkmemory.h +80 -0
  570. data/ext/lpsolver-highs/extern/metis/GKlib/gk_mkpqueue.h +329 -0
  571. data/ext/lpsolver-highs/extern/metis/GKlib/gk_mkrandom.h +89 -0
  572. data/ext/lpsolver-highs/extern/metis/GKlib/gk_mksort.h +271 -0
  573. data/ext/lpsolver-highs/extern/metis/GKlib/gk_ms_inttypes.h +41 -0
  574. data/ext/lpsolver-highs/extern/metis/GKlib/gk_ms_stat.h +22 -0
  575. data/ext/lpsolver-highs/extern/metis/GKlib/gk_ms_stdint.h +41 -0
  576. data/ext/lpsolver-highs/extern/metis/GKlib/gk_proto.h +50 -0
  577. data/ext/lpsolver-highs/extern/metis/GKlib/gk_struct.h +66 -0
  578. data/ext/lpsolver-highs/extern/metis/GKlib/gk_types.h +15 -0
  579. data/ext/lpsolver-highs/extern/metis/GKlib/mcore.c +176 -0
  580. data/ext/lpsolver-highs/extern/metis/GKlib/memory.c +23 -0
  581. data/ext/lpsolver-highs/extern/metis/GKlib/random.c +37 -0
  582. data/ext/lpsolver-highs/extern/metis/LICENSE.txt +18 -0
  583. data/ext/lpsolver-highs/extern/metis/libmetis/auxapi.c +27 -0
  584. data/ext/lpsolver-highs/extern/metis/libmetis/balance.c +491 -0
  585. data/ext/lpsolver-highs/extern/metis/libmetis/bucketsort.c +44 -0
  586. data/ext/lpsolver-highs/extern/metis/libmetis/coarsen.c +895 -0
  587. data/ext/lpsolver-highs/extern/metis/libmetis/compress.c +231 -0
  588. data/ext/lpsolver-highs/extern/metis/libmetis/contig.c +83 -0
  589. data/ext/lpsolver-highs/extern/metis/libmetis/defs.h +39 -0
  590. data/ext/lpsolver-highs/extern/metis/libmetis/fm.c +527 -0
  591. data/ext/lpsolver-highs/extern/metis/libmetis/gklib.c +55 -0
  592. data/ext/lpsolver-highs/extern/metis/libmetis/gklib_defs.h +33 -0
  593. data/ext/lpsolver-highs/extern/metis/libmetis/graph.c +268 -0
  594. data/ext/lpsolver-highs/extern/metis/libmetis/initpart.c +385 -0
  595. data/ext/lpsolver-highs/extern/metis/libmetis/macros.h +59 -0
  596. data/ext/lpsolver-highs/extern/metis/libmetis/mcutil.c +162 -0
  597. data/ext/lpsolver-highs/extern/metis/libmetis/metislib.h +35 -0
  598. data/ext/lpsolver-highs/extern/metis/libmetis/mmd.c +598 -0
  599. data/ext/lpsolver-highs/extern/metis/libmetis/ometis.c +661 -0
  600. data/ext/lpsolver-highs/extern/metis/libmetis/options.c +260 -0
  601. data/ext/lpsolver-highs/extern/metis/libmetis/proto.h +172 -0
  602. data/ext/lpsolver-highs/extern/metis/libmetis/refine.c +99 -0
  603. data/ext/lpsolver-highs/extern/metis/libmetis/separator.c +57 -0
  604. data/ext/lpsolver-highs/extern/metis/libmetis/sfm.c +581 -0
  605. data/ext/lpsolver-highs/extern/metis/libmetis/srefine.c +152 -0
  606. data/ext/lpsolver-highs/extern/metis/libmetis/stdheaders.h +29 -0
  607. data/ext/lpsolver-highs/extern/metis/libmetis/struct.h +117 -0
  608. data/ext/lpsolver-highs/extern/metis/libmetis/util.c +59 -0
  609. data/ext/lpsolver-highs/extern/metis/libmetis/wspace.c +91 -0
  610. data/ext/lpsolver-highs/extern/metis/metis.h +271 -0
  611. data/ext/lpsolver-highs/extern/pdqsort/license.txt +16 -0
  612. data/ext/lpsolver-highs/extern/pdqsort/pdqsort.h +532 -0
  613. data/ext/lpsolver-highs/extern/rcm/LICENSE +19 -0
  614. data/ext/lpsolver-highs/extern/rcm/rcm.cpp +873 -0
  615. data/ext/lpsolver-highs/extern/rcm/rcm.h +22 -0
  616. data/ext/lpsolver-highs/extern/zstr/LICENSE +21 -0
  617. data/ext/lpsolver-highs/extern/zstr/strict_fstream.hpp +237 -0
  618. data/ext/lpsolver-highs/extern/zstr/zstr.hpp +473 -0
  619. data/ext/lpsolver-highs/flake.lock +61 -0
  620. data/ext/lpsolver-highs/flake.nix +73 -0
  621. data/ext/lpsolver-highs/highs/CMakeLists.txt +499 -0
  622. data/ext/lpsolver-highs/highs/HConfig.h.bazel.in +25 -0
  623. data/ext/lpsolver-highs/highs/HConfig.h.in +22 -0
  624. data/ext/lpsolver-highs/highs/HConfig.h.meson.in +17 -0
  625. data/ext/lpsolver-highs/highs/Highs.h +1812 -0
  626. data/ext/lpsolver-highs/highs/HighsRun.md +143 -0
  627. data/ext/lpsolver-highs/highs/highs_bindings.cpp +1826 -0
  628. data/ext/lpsolver-highs/highs/highspy/__init__.py +93 -0
  629. data/ext/lpsolver-highs/highs/highspy/__init__.pyi +91 -0
  630. data/ext/lpsolver-highs/highs/highspy/_core/__init__.pyi +1058 -0
  631. data/ext/lpsolver-highs/highs/highspy/_core/cb.pyi +118 -0
  632. data/ext/lpsolver-highs/highs/highspy/_core/simplex_constants.pyi +472 -0
  633. data/ext/lpsolver-highs/highs/highspy/highs.py +2430 -0
  634. data/ext/lpsolver-highs/highs/interfaces/highs_c_api.cpp +1812 -0
  635. data/ext/lpsolver-highs/highs/interfaces/highs_c_api.h +2651 -0
  636. data/ext/lpsolver-highs/highs/interfaces/highs_csharp_api.cs +1142 -0
  637. data/ext/lpsolver-highs/highs/interfaces/highs_fortran_api.f90 +873 -0
  638. data/ext/lpsolver-highs/highs/io/Filereader.cpp +87 -0
  639. data/ext/lpsolver-highs/highs/io/Filereader.h +45 -0
  640. data/ext/lpsolver-highs/highs/io/FilereaderLp.cpp +539 -0
  641. data/ext/lpsolver-highs/highs/io/FilereaderLp.h +49 -0
  642. data/ext/lpsolver-highs/highs/io/FilereaderMps.cpp +86 -0
  643. data/ext/lpsolver-highs/highs/io/FilereaderMps.h +27 -0
  644. data/ext/lpsolver-highs/highs/io/HMPSIO.cpp +1001 -0
  645. data/ext/lpsolver-highs/highs/io/HMPSIO.h +78 -0
  646. data/ext/lpsolver-highs/highs/io/HMpsFF.cpp +2113 -0
  647. data/ext/lpsolver-highs/highs/io/HMpsFF.h +245 -0
  648. data/ext/lpsolver-highs/highs/io/HighsIO.cpp +371 -0
  649. data/ext/lpsolver-highs/highs/io/HighsIO.h +118 -0
  650. data/ext/lpsolver-highs/highs/io/LoadOptions.cpp +60 -0
  651. data/ext/lpsolver-highs/highs/io/LoadOptions.h +24 -0
  652. data/ext/lpsolver-highs/highs/io/filereaderlp/LICENSE +19 -0
  653. data/ext/lpsolver-highs/highs/io/filereaderlp/builder.hpp +25 -0
  654. data/ext/lpsolver-highs/highs/io/filereaderlp/def.hpp +19 -0
  655. data/ext/lpsolver-highs/highs/io/filereaderlp/model.hpp +68 -0
  656. data/ext/lpsolver-highs/highs/io/filereaderlp/reader.cpp +1375 -0
  657. data/ext/lpsolver-highs/highs/io/filereaderlp/reader.hpp +10 -0
  658. data/ext/lpsolver-highs/highs/ipm/IpxSolution.h +32 -0
  659. data/ext/lpsolver-highs/highs/ipm/IpxWrapper.cpp +1526 -0
  660. data/ext/lpsolver-highs/highs/ipm/IpxWrapper.h +106 -0
  661. data/ext/lpsolver-highs/highs/ipm/basiclu/basiclu.h +161 -0
  662. data/ext/lpsolver-highs/highs/ipm/basiclu/basiclu_factorize.c +132 -0
  663. data/ext/lpsolver-highs/highs/ipm/basiclu/basiclu_factorize.h +247 -0
  664. data/ext/lpsolver-highs/highs/ipm/basiclu/basiclu_get_factors.c +148 -0
  665. data/ext/lpsolver-highs/highs/ipm/basiclu/basiclu_get_factors.h +108 -0
  666. data/ext/lpsolver-highs/highs/ipm/basiclu/basiclu_initialize.c +24 -0
  667. data/ext/lpsolver-highs/highs/ipm/basiclu/basiclu_initialize.h +119 -0
  668. data/ext/lpsolver-highs/highs/ipm/basiclu/basiclu_obj_factorize.h +34 -0
  669. data/ext/lpsolver-highs/highs/ipm/basiclu/basiclu_obj_free.h +19 -0
  670. data/ext/lpsolver-highs/highs/ipm/basiclu/basiclu_obj_get_factors.h +34 -0
  671. data/ext/lpsolver-highs/highs/ipm/basiclu/basiclu_obj_initialize.h +46 -0
  672. data/ext/lpsolver-highs/highs/ipm/basiclu/basiclu_obj_solve_dense.h +29 -0
  673. data/ext/lpsolver-highs/highs/ipm/basiclu/basiclu_obj_solve_for_update.h +42 -0
  674. data/ext/lpsolver-highs/highs/ipm/basiclu/basiclu_obj_solve_sparse.h +32 -0
  675. data/ext/lpsolver-highs/highs/ipm/basiclu/basiclu_obj_update.h +31 -0
  676. data/ext/lpsolver-highs/highs/ipm/basiclu/basiclu_object.c +325 -0
  677. data/ext/lpsolver-highs/highs/ipm/basiclu/basiclu_object.h +30 -0
  678. data/ext/lpsolver-highs/highs/ipm/basiclu/basiclu_solve_dense.c +46 -0
  679. data/ext/lpsolver-highs/highs/ipm/basiclu/basiclu_solve_dense.h +75 -0
  680. data/ext/lpsolver-highs/highs/ipm/basiclu/basiclu_solve_for_update.c +79 -0
  681. data/ext/lpsolver-highs/highs/ipm/basiclu/basiclu_solve_for_update.h +169 -0
  682. data/ext/lpsolver-highs/highs/ipm/basiclu/basiclu_solve_sparse.c +63 -0
  683. data/ext/lpsolver-highs/highs/ipm/basiclu/basiclu_solve_sparse.h +112 -0
  684. data/ext/lpsolver-highs/highs/ipm/basiclu/basiclu_update.c +44 -0
  685. data/ext/lpsolver-highs/highs/ipm/basiclu/basiclu_update.h +125 -0
  686. data/ext/lpsolver-highs/highs/ipm/basiclu/lu_build_factors.c +441 -0
  687. data/ext/lpsolver-highs/highs/ipm/basiclu/lu_condest.c +124 -0
  688. data/ext/lpsolver-highs/highs/ipm/basiclu/lu_def.h +39 -0
  689. data/ext/lpsolver-highs/highs/ipm/basiclu/lu_dfs.c +141 -0
  690. data/ext/lpsolver-highs/highs/ipm/basiclu/lu_factorize_bump.c +56 -0
  691. data/ext/lpsolver-highs/highs/ipm/basiclu/lu_file.c +184 -0
  692. data/ext/lpsolver-highs/highs/ipm/basiclu/lu_file.h +21 -0
  693. data/ext/lpsolver-highs/highs/ipm/basiclu/lu_garbage_perm.c +53 -0
  694. data/ext/lpsolver-highs/highs/ipm/basiclu/lu_initialize.c +56 -0
  695. data/ext/lpsolver-highs/highs/ipm/basiclu/lu_internal.c +352 -0
  696. data/ext/lpsolver-highs/highs/ipm/basiclu/lu_internal.h +220 -0
  697. data/ext/lpsolver-highs/highs/ipm/basiclu/lu_list.h +173 -0
  698. data/ext/lpsolver-highs/highs/ipm/basiclu/lu_markowitz.c +188 -0
  699. data/ext/lpsolver-highs/highs/ipm/basiclu/lu_matrix_norm.c +51 -0
  700. data/ext/lpsolver-highs/highs/ipm/basiclu/lu_pivot.c +1247 -0
  701. data/ext/lpsolver-highs/highs/ipm/basiclu/lu_residual_test.c +155 -0
  702. data/ext/lpsolver-highs/highs/ipm/basiclu/lu_setup_bump.c +198 -0
  703. data/ext/lpsolver-highs/highs/ipm/basiclu/lu_singletons.c +511 -0
  704. data/ext/lpsolver-highs/highs/ipm/basiclu/lu_solve_dense.c +129 -0
  705. data/ext/lpsolver-highs/highs/ipm/basiclu/lu_solve_for_update.c +360 -0
  706. data/ext/lpsolver-highs/highs/ipm/basiclu/lu_solve_sparse.c +284 -0
  707. data/ext/lpsolver-highs/highs/ipm/basiclu/lu_solve_symbolic.c +48 -0
  708. data/ext/lpsolver-highs/highs/ipm/basiclu/lu_solve_triangular.c +140 -0
  709. data/ext/lpsolver-highs/highs/ipm/basiclu/lu_update.c +908 -0
  710. data/ext/lpsolver-highs/highs/ipm/hipo/auxiliary/Auxiliary.cpp +301 -0
  711. data/ext/lpsolver-highs/highs/ipm/hipo/auxiliary/Auxiliary.h +104 -0
  712. data/ext/lpsolver-highs/highs/ipm/hipo/auxiliary/IntConfig.h +27 -0
  713. data/ext/lpsolver-highs/highs/ipm/hipo/auxiliary/KrylovMethods.cpp +193 -0
  714. data/ext/lpsolver-highs/highs/ipm/hipo/auxiliary/KrylovMethods.h +30 -0
  715. data/ext/lpsolver-highs/highs/ipm/hipo/auxiliary/Log.cpp +60 -0
  716. data/ext/lpsolver-highs/highs/ipm/hipo/auxiliary/Log.h +62 -0
  717. data/ext/lpsolver-highs/highs/ipm/hipo/auxiliary/OrderingPrint.h +10 -0
  718. data/ext/lpsolver-highs/highs/ipm/hipo/auxiliary/VectorOperations.cpp +117 -0
  719. data/ext/lpsolver-highs/highs/ipm/hipo/auxiliary/VectorOperations.h +59 -0
  720. data/ext/lpsolver-highs/highs/ipm/hipo/auxiliary/mycblas.h +85 -0
  721. data/ext/lpsolver-highs/highs/ipm/hipo/factorhighs/Analyse.cpp +1367 -0
  722. data/ext/lpsolver-highs/highs/ipm/hipo/factorhighs/Analyse.h +122 -0
  723. data/ext/lpsolver-highs/highs/ipm/hipo/factorhighs/CallAndTimeBlas.cpp +114 -0
  724. data/ext/lpsolver-highs/highs/ipm/hipo/factorhighs/CallAndTimeBlas.h +46 -0
  725. data/ext/lpsolver-highs/highs/ipm/hipo/factorhighs/CliqueStack.cpp +82 -0
  726. data/ext/lpsolver-highs/highs/ipm/hipo/factorhighs/CliqueStack.h +83 -0
  727. data/ext/lpsolver-highs/highs/ipm/hipo/factorhighs/DataCollector.cpp +326 -0
  728. data/ext/lpsolver-highs/highs/ipm/hipo/factorhighs/DataCollector.h +86 -0
  729. data/ext/lpsolver-highs/highs/ipm/hipo/factorhighs/DenseFact.h +48 -0
  730. data/ext/lpsolver-highs/highs/ipm/hipo/factorhighs/DenseFactHybrid.cpp +279 -0
  731. data/ext/lpsolver-highs/highs/ipm/hipo/factorhighs/DenseFactKernel.cpp +284 -0
  732. data/ext/lpsolver-highs/highs/ipm/hipo/factorhighs/DgemmParallel.cpp +38 -0
  733. data/ext/lpsolver-highs/highs/ipm/hipo/factorhighs/DgemmParallel.h +32 -0
  734. data/ext/lpsolver-highs/highs/ipm/hipo/factorhighs/FactorHiGHS.cpp +57 -0
  735. data/ext/lpsolver-highs/highs/ipm/hipo/factorhighs/FactorHiGHS.h +112 -0
  736. data/ext/lpsolver-highs/highs/ipm/hipo/factorhighs/FactorHiGHSSettings.h +63 -0
  737. data/ext/lpsolver-highs/highs/ipm/hipo/factorhighs/Factorise.cpp +405 -0
  738. data/ext/lpsolver-highs/highs/ipm/hipo/factorhighs/Factorise.h +85 -0
  739. data/ext/lpsolver-highs/highs/ipm/hipo/factorhighs/FormatHandler.cpp +46 -0
  740. data/ext/lpsolver-highs/highs/ipm/hipo/factorhighs/FormatHandler.h +95 -0
  741. data/ext/lpsolver-highs/highs/ipm/hipo/factorhighs/HybridHybridFormatHandler.cpp +238 -0
  742. data/ext/lpsolver-highs/highs/ipm/hipo/factorhighs/HybridHybridFormatHandler.h +31 -0
  743. data/ext/lpsolver-highs/highs/ipm/hipo/factorhighs/HybridSolveHandler.cpp +272 -0
  744. data/ext/lpsolver-highs/highs/ipm/hipo/factorhighs/HybridSolveHandler.h +26 -0
  745. data/ext/lpsolver-highs/highs/ipm/hipo/factorhighs/KrylovMethodsIpm.cpp +83 -0
  746. data/ext/lpsolver-highs/highs/ipm/hipo/factorhighs/KrylovMethodsIpm.h +45 -0
  747. data/ext/lpsolver-highs/highs/ipm/hipo/factorhighs/Numeric.cpp +54 -0
  748. data/ext/lpsolver-highs/highs/ipm/hipo/factorhighs/Numeric.h +46 -0
  749. data/ext/lpsolver-highs/highs/ipm/hipo/factorhighs/ReturnValues.h +19 -0
  750. data/ext/lpsolver-highs/highs/ipm/hipo/factorhighs/SolveHandler.cpp +10 -0
  751. data/ext/lpsolver-highs/highs/ipm/hipo/factorhighs/SolveHandler.h +48 -0
  752. data/ext/lpsolver-highs/highs/ipm/hipo/factorhighs/Swaps.cpp +70 -0
  753. data/ext/lpsolver-highs/highs/ipm/hipo/factorhighs/Swaps.h +19 -0
  754. data/ext/lpsolver-highs/highs/ipm/hipo/factorhighs/Symbolic.cpp +101 -0
  755. data/ext/lpsolver-highs/highs/ipm/hipo/factorhighs/Symbolic.h +220 -0
  756. data/ext/lpsolver-highs/highs/ipm/hipo/factorhighs/Timing.h +114 -0
  757. data/ext/lpsolver-highs/highs/ipm/hipo/ipm/Control.cpp +38 -0
  758. data/ext/lpsolver-highs/highs/ipm/hipo/ipm/Control.h +41 -0
  759. data/ext/lpsolver-highs/highs/ipm/hipo/ipm/FactorHiGHSSolver.cpp +887 -0
  760. data/ext/lpsolver-highs/highs/ipm/hipo/ipm/FactorHiGHSSolver.h +92 -0
  761. data/ext/lpsolver-highs/highs/ipm/hipo/ipm/Info.h +58 -0
  762. data/ext/lpsolver-highs/highs/ipm/hipo/ipm/IpmData.cpp +8 -0
  763. data/ext/lpsolver-highs/highs/ipm/hipo/ipm/IpmData.h +37 -0
  764. data/ext/lpsolver-highs/highs/ipm/hipo/ipm/Iterate.cpp +640 -0
  765. data/ext/lpsolver-highs/highs/ipm/hipo/ipm/Iterate.h +172 -0
  766. data/ext/lpsolver-highs/highs/ipm/hipo/ipm/LinearSolver.h +81 -0
  767. data/ext/lpsolver-highs/highs/ipm/hipo/ipm/LogHighs.cpp +71 -0
  768. data/ext/lpsolver-highs/highs/ipm/hipo/ipm/LogHighs.h +33 -0
  769. data/ext/lpsolver-highs/highs/ipm/hipo/ipm/Model.cpp +403 -0
  770. data/ext/lpsolver-highs/highs/ipm/hipo/ipm/Model.h +136 -0
  771. data/ext/lpsolver-highs/highs/ipm/hipo/ipm/Options.h +35 -0
  772. data/ext/lpsolver-highs/highs/ipm/hipo/ipm/Parameters.h +63 -0
  773. data/ext/lpsolver-highs/highs/ipm/hipo/ipm/PreProcess.cpp +646 -0
  774. data/ext/lpsolver-highs/highs/ipm/hipo/ipm/PreProcess.h +94 -0
  775. data/ext/lpsolver-highs/highs/ipm/hipo/ipm/Refine.cpp +214 -0
  776. data/ext/lpsolver-highs/highs/ipm/hipo/ipm/Solver.cpp +1346 -0
  777. data/ext/lpsolver-highs/highs/ipm/hipo/ipm/Solver.h +338 -0
  778. data/ext/lpsolver-highs/highs/ipm/hipo/ipm/Status.h +88 -0
  779. data/ext/lpsolver-highs/highs/ipm/ipx/basiclu_kernel.cc +71 -0
  780. data/ext/lpsolver-highs/highs/ipm/ipx/basiclu_kernel.h +20 -0
  781. data/ext/lpsolver-highs/highs/ipm/ipx/basiclu_wrapper.cc +299 -0
  782. data/ext/lpsolver-highs/highs/ipm/ipx/basiclu_wrapper.h +47 -0
  783. data/ext/lpsolver-highs/highs/ipm/ipx/basis.cc +966 -0
  784. data/ext/lpsolver-highs/highs/ipm/ipx/basis.h +350 -0
  785. data/ext/lpsolver-highs/highs/ipm/ipx/conjugate_residuals.cc +217 -0
  786. data/ext/lpsolver-highs/highs/ipm/ipx/conjugate_residuals.h +74 -0
  787. data/ext/lpsolver-highs/highs/ipm/ipx/control.cc +151 -0
  788. data/ext/lpsolver-highs/highs/ipm/ipx/control.h +167 -0
  789. data/ext/lpsolver-highs/highs/ipm/ipx/crossover.cc +479 -0
  790. data/ext/lpsolver-highs/highs/ipm/ipx/crossover.h +157 -0
  791. data/ext/lpsolver-highs/highs/ipm/ipx/diagonal_precond.cc +70 -0
  792. data/ext/lpsolver-highs/highs/ipm/ipx/diagonal_precond.h +45 -0
  793. data/ext/lpsolver-highs/highs/ipm/ipx/forrest_tomlin.cc +360 -0
  794. data/ext/lpsolver-highs/highs/ipm/ipx/forrest_tomlin.h +102 -0
  795. data/ext/lpsolver-highs/highs/ipm/ipx/guess_basis.cc +233 -0
  796. data/ext/lpsolver-highs/highs/ipm/ipx/guess_basis.h +21 -0
  797. data/ext/lpsolver-highs/highs/ipm/ipx/indexed_vector.cc +30 -0
  798. data/ext/lpsolver-highs/highs/ipm/ipx/indexed_vector.h +113 -0
  799. data/ext/lpsolver-highs/highs/ipm/ipx/info.cc +124 -0
  800. data/ext/lpsolver-highs/highs/ipm/ipx/info.h +27 -0
  801. data/ext/lpsolver-highs/highs/ipm/ipx/ipm.cc +897 -0
  802. data/ext/lpsolver-highs/highs/ipm/ipx/ipm.h +94 -0
  803. data/ext/lpsolver-highs/highs/ipm/ipx/ipx_c.cc +83 -0
  804. data/ext/lpsolver-highs/highs/ipm/ipx/ipx_c.h +47 -0
  805. data/ext/lpsolver-highs/highs/ipm/ipx/ipx_config.h +9 -0
  806. data/ext/lpsolver-highs/highs/ipm/ipx/ipx_info.h +111 -0
  807. data/ext/lpsolver-highs/highs/ipm/ipx/ipx_internal.h +89 -0
  808. data/ext/lpsolver-highs/highs/ipm/ipx/ipx_parameters.h +76 -0
  809. data/ext/lpsolver-highs/highs/ipm/ipx/ipx_status.h +57 -0
  810. data/ext/lpsolver-highs/highs/ipm/ipx/iterate.cc +683 -0
  811. data/ext/lpsolver-highs/highs/ipm/ipx/iterate.h +331 -0
  812. data/ext/lpsolver-highs/highs/ipm/ipx/kkt_solver.cc +23 -0
  813. data/ext/lpsolver-highs/highs/ipm/ipx/kkt_solver.h +70 -0
  814. data/ext/lpsolver-highs/highs/ipm/ipx/kkt_solver_basis.cc +387 -0
  815. data/ext/lpsolver-highs/highs/ipm/ipx/kkt_solver_basis.h +66 -0
  816. data/ext/lpsolver-highs/highs/ipm/ipx/kkt_solver_diag.cc +120 -0
  817. data/ext/lpsolver-highs/highs/ipm/ipx/kkt_solver_diag.h +48 -0
  818. data/ext/lpsolver-highs/highs/ipm/ipx/linear_operator.cc +10 -0
  819. data/ext/lpsolver-highs/highs/ipm/ipx/linear_operator.h +26 -0
  820. data/ext/lpsolver-highs/highs/ipm/ipx/lp_solver.cc +686 -0
  821. data/ext/lpsolver-highs/highs/ipm/ipx/lp_solver.h +204 -0
  822. data/ext/lpsolver-highs/highs/ipm/ipx/lu_factorization.cc +131 -0
  823. data/ext/lpsolver-highs/highs/ipm/ipx/lu_factorization.h +79 -0
  824. data/ext/lpsolver-highs/highs/ipm/ipx/lu_update.cc +62 -0
  825. data/ext/lpsolver-highs/highs/ipm/ipx/lu_update.h +129 -0
  826. data/ext/lpsolver-highs/highs/ipm/ipx/maxvolume.cc +337 -0
  827. data/ext/lpsolver-highs/highs/ipm/ipx/maxvolume.h +54 -0
  828. data/ext/lpsolver-highs/highs/ipm/ipx/model.cc +1528 -0
  829. data/ext/lpsolver-highs/highs/ipm/ipx/model.h +413 -0
  830. data/ext/lpsolver-highs/highs/ipm/ipx/multistream.h +52 -0
  831. data/ext/lpsolver-highs/highs/ipm/ipx/normal_matrix.cc +126 -0
  832. data/ext/lpsolver-highs/highs/ipm/ipx/normal_matrix.h +44 -0
  833. data/ext/lpsolver-highs/highs/ipm/ipx/power_method.h +44 -0
  834. data/ext/lpsolver-highs/highs/ipm/ipx/sparse_matrix.cc +382 -0
  835. data/ext/lpsolver-highs/highs/ipm/ipx/sparse_matrix.h +195 -0
  836. data/ext/lpsolver-highs/highs/ipm/ipx/sparse_utils.cc +92 -0
  837. data/ext/lpsolver-highs/highs/ipm/ipx/sparse_utils.h +58 -0
  838. data/ext/lpsolver-highs/highs/ipm/ipx/splitted_normal_matrix.cc +117 -0
  839. data/ext/lpsolver-highs/highs/ipm/ipx/splitted_normal_matrix.h +63 -0
  840. data/ext/lpsolver-highs/highs/ipm/ipx/starting_basis.cc +182 -0
  841. data/ext/lpsolver-highs/highs/ipm/ipx/starting_basis.h +39 -0
  842. data/ext/lpsolver-highs/highs/ipm/ipx/symbolic_invert.cc +183 -0
  843. data/ext/lpsolver-highs/highs/ipm/ipx/symbolic_invert.h +29 -0
  844. data/ext/lpsolver-highs/highs/ipm/ipx/timer.cc +16 -0
  845. data/ext/lpsolver-highs/highs/ipm/ipx/timer.h +25 -0
  846. data/ext/lpsolver-highs/highs/ipm/ipx/utils.cc +95 -0
  847. data/ext/lpsolver-highs/highs/ipm/ipx/utils.h +37 -0
  848. data/ext/lpsolver-highs/highs/lp_data/HConst.h +430 -0
  849. data/ext/lpsolver-highs/highs/lp_data/HStruct.h +213 -0
  850. data/ext/lpsolver-highs/highs/lp_data/Highs.cpp +4949 -0
  851. data/ext/lpsolver-highs/highs/lp_data/HighsAnalysis.h +23 -0
  852. data/ext/lpsolver-highs/highs/lp_data/HighsCallback.cpp +323 -0
  853. data/ext/lpsolver-highs/highs/lp_data/HighsCallback.h +104 -0
  854. data/ext/lpsolver-highs/highs/lp_data/HighsCallbackStruct.h +70 -0
  855. data/ext/lpsolver-highs/highs/lp_data/HighsDebug.cpp +54 -0
  856. data/ext/lpsolver-highs/highs/lp_data/HighsDebug.h +34 -0
  857. data/ext/lpsolver-highs/highs/lp_data/HighsDeprecated.cpp +181 -0
  858. data/ext/lpsolver-highs/highs/lp_data/HighsIis.cpp +1290 -0
  859. data/ext/lpsolver-highs/highs/lp_data/HighsIis.h +139 -0
  860. data/ext/lpsolver-highs/highs/lp_data/HighsInfo.cpp +426 -0
  861. data/ext/lpsolver-highs/highs/lp_data/HighsInfo.h +421 -0
  862. data/ext/lpsolver-highs/highs/lp_data/HighsInfoDebug.cpp +175 -0
  863. data/ext/lpsolver-highs/highs/lp_data/HighsInfoDebug.h +27 -0
  864. data/ext/lpsolver-highs/highs/lp_data/HighsInterface.cpp +4344 -0
  865. data/ext/lpsolver-highs/highs/lp_data/HighsLp.cpp +564 -0
  866. data/ext/lpsolver-highs/highs/lp_data/HighsLp.h +97 -0
  867. data/ext/lpsolver-highs/highs/lp_data/HighsLpSolverObject.h +47 -0
  868. data/ext/lpsolver-highs/highs/lp_data/HighsLpUtils.cpp +3794 -0
  869. data/ext/lpsolver-highs/highs/lp_data/HighsLpUtils.h +330 -0
  870. data/ext/lpsolver-highs/highs/lp_data/HighsModelUtils.cpp +1650 -0
  871. data/ext/lpsolver-highs/highs/lp_data/HighsModelUtils.h +129 -0
  872. data/ext/lpsolver-highs/highs/lp_data/HighsOptions.cpp +1176 -0
  873. data/ext/lpsolver-highs/highs/lp_data/HighsOptions.h +1715 -0
  874. data/ext/lpsolver-highs/highs/lp_data/HighsRanging.cpp +733 -0
  875. data/ext/lpsolver-highs/highs/lp_data/HighsRanging.h +43 -0
  876. data/ext/lpsolver-highs/highs/lp_data/HighsSolution.cpp +2194 -0
  877. data/ext/lpsolver-highs/highs/lp_data/HighsSolution.h +179 -0
  878. data/ext/lpsolver-highs/highs/lp_data/HighsSolutionDebug.cpp +490 -0
  879. data/ext/lpsolver-highs/highs/lp_data/HighsSolutionDebug.h +87 -0
  880. data/ext/lpsolver-highs/highs/lp_data/HighsSolve.cpp +747 -0
  881. data/ext/lpsolver-highs/highs/lp_data/HighsSolve.h +29 -0
  882. data/ext/lpsolver-highs/highs/lp_data/HighsStatus.cpp +48 -0
  883. data/ext/lpsolver-highs/highs/lp_data/HighsStatus.h +29 -0
  884. data/ext/lpsolver-highs/highs/lp_data/Iis.md +113 -0
  885. data/ext/lpsolver-highs/highs/meson.build +433 -0
  886. data/ext/lpsolver-highs/highs/mip/HighsCliqueTable.cpp +2236 -0
  887. data/ext/lpsolver-highs/highs/mip/HighsCliqueTable.h +329 -0
  888. data/ext/lpsolver-highs/highs/mip/HighsConflictPool.cpp +201 -0
  889. data/ext/lpsolver-highs/highs/mip/HighsConflictPool.h +109 -0
  890. data/ext/lpsolver-highs/highs/mip/HighsCutGeneration.cpp +1491 -0
  891. data/ext/lpsolver-highs/highs/mip/HighsCutGeneration.h +108 -0
  892. data/ext/lpsolver-highs/highs/mip/HighsCutPool.cpp +526 -0
  893. data/ext/lpsolver-highs/highs/mip/HighsCutPool.h +168 -0
  894. data/ext/lpsolver-highs/highs/mip/HighsDebugSol.cpp +313 -0
  895. data/ext/lpsolver-highs/highs/mip/HighsDebugSol.h +133 -0
  896. data/ext/lpsolver-highs/highs/mip/HighsDomain.cpp +3861 -0
  897. data/ext/lpsolver-highs/highs/mip/HighsDomain.h +657 -0
  898. data/ext/lpsolver-highs/highs/mip/HighsDomainChange.h +48 -0
  899. data/ext/lpsolver-highs/highs/mip/HighsDynamicRowMatrix.cpp +199 -0
  900. data/ext/lpsolver-highs/highs/mip/HighsDynamicRowMatrix.h +104 -0
  901. data/ext/lpsolver-highs/highs/mip/HighsFeasibilityJump.cpp +139 -0
  902. data/ext/lpsolver-highs/highs/mip/HighsGFkSolve.cpp +106 -0
  903. data/ext/lpsolver-highs/highs/mip/HighsGFkSolve.h +439 -0
  904. data/ext/lpsolver-highs/highs/mip/HighsImplications.cpp +915 -0
  905. data/ext/lpsolver-highs/highs/mip/HighsImplications.h +194 -0
  906. data/ext/lpsolver-highs/highs/mip/HighsLpAggregator.cpp +56 -0
  907. data/ext/lpsolver-highs/highs/mip/HighsLpAggregator.h +50 -0
  908. data/ext/lpsolver-highs/highs/mip/HighsLpRelaxation.cpp +1609 -0
  909. data/ext/lpsolver-highs/highs/mip/HighsLpRelaxation.h +361 -0
  910. data/ext/lpsolver-highs/highs/mip/HighsMipAnalysis.cpp +313 -0
  911. data/ext/lpsolver-highs/highs/mip/HighsMipAnalysis.h +71 -0
  912. data/ext/lpsolver-highs/highs/mip/HighsMipSolver.cpp +1002 -0
  913. data/ext/lpsolver-highs/highs/mip/HighsMipSolver.h +159 -0
  914. data/ext/lpsolver-highs/highs/mip/HighsMipSolverData.cpp +2936 -0
  915. data/ext/lpsolver-highs/highs/mip/HighsMipSolverData.h +313 -0
  916. data/ext/lpsolver-highs/highs/mip/HighsModkSeparator.cpp +267 -0
  917. data/ext/lpsolver-highs/highs/mip/HighsModkSeparator.h +60 -0
  918. data/ext/lpsolver-highs/highs/mip/HighsNodeQueue.cpp +443 -0
  919. data/ext/lpsolver-highs/highs/mip/HighsNodeQueue.h +312 -0
  920. data/ext/lpsolver-highs/highs/mip/HighsObjectiveFunction.cpp +124 -0
  921. data/ext/lpsolver-highs/highs/mip/HighsObjectiveFunction.h +71 -0
  922. data/ext/lpsolver-highs/highs/mip/HighsPathSeparator.cpp +549 -0
  923. data/ext/lpsolver-highs/highs/mip/HighsPathSeparator.h +39 -0
  924. data/ext/lpsolver-highs/highs/mip/HighsPrimalHeuristics.cpp +1673 -0
  925. data/ext/lpsolver-highs/highs/mip/HighsPrimalHeuristics.h +75 -0
  926. data/ext/lpsolver-highs/highs/mip/HighsPseudocost.cpp +129 -0
  927. data/ext/lpsolver-highs/highs/mip/HighsPseudocost.h +366 -0
  928. data/ext/lpsolver-highs/highs/mip/HighsRedcostFixing.cpp +316 -0
  929. data/ext/lpsolver-highs/highs/mip/HighsRedcostFixing.h +42 -0
  930. data/ext/lpsolver-highs/highs/mip/HighsSearch.cpp +1881 -0
  931. data/ext/lpsolver-highs/highs/mip/HighsSearch.h +241 -0
  932. data/ext/lpsolver-highs/highs/mip/HighsSeparation.cpp +186 -0
  933. data/ext/lpsolver-highs/highs/mip/HighsSeparation.h +41 -0
  934. data/ext/lpsolver-highs/highs/mip/HighsSeparator.cpp +39 -0
  935. data/ext/lpsolver-highs/highs/mip/HighsSeparator.h +60 -0
  936. data/ext/lpsolver-highs/highs/mip/HighsTableauSeparator.cpp +244 -0
  937. data/ext/lpsolver-highs/highs/mip/HighsTableauSeparator.h +34 -0
  938. data/ext/lpsolver-highs/highs/mip/HighsTransformedLp.cpp +563 -0
  939. data/ext/lpsolver-highs/highs/mip/HighsTransformedLp.h +63 -0
  940. data/ext/lpsolver-highs/highs/mip/MipTimer.h +544 -0
  941. data/ext/lpsolver-highs/highs/mip/feasibilityjump.hh +800 -0
  942. data/ext/lpsolver-highs/highs/model/HighsHessian.cpp +263 -0
  943. data/ext/lpsolver-highs/highs/model/HighsHessian.h +54 -0
  944. data/ext/lpsolver-highs/highs/model/HighsHessianUtils.cpp +584 -0
  945. data/ext/lpsolver-highs/highs/model/HighsHessianUtils.h +47 -0
  946. data/ext/lpsolver-highs/highs/model/HighsModel.cpp +46 -0
  947. data/ext/lpsolver-highs/highs/model/HighsModel.h +42 -0
  948. data/ext/lpsolver-highs/highs/parallel/HighsBinarySemaphore.h +108 -0
  949. data/ext/lpsolver-highs/highs/parallel/HighsCacheAlign.h +82 -0
  950. data/ext/lpsolver-highs/highs/parallel/HighsCombinable.h +116 -0
  951. data/ext/lpsolver-highs/highs/parallel/HighsMutex.h +124 -0
  952. data/ext/lpsolver-highs/highs/parallel/HighsParallel.h +128 -0
  953. data/ext/lpsolver-highs/highs/parallel/HighsRaceTimer.h +38 -0
  954. data/ext/lpsolver-highs/highs/parallel/HighsSchedulerConstants.h +19 -0
  955. data/ext/lpsolver-highs/highs/parallel/HighsSpinMutex.h +48 -0
  956. data/ext/lpsolver-highs/highs/parallel/HighsSplitDeque.h +606 -0
  957. data/ext/lpsolver-highs/highs/parallel/HighsTask.h +170 -0
  958. data/ext/lpsolver-highs/highs/parallel/HighsTaskExecutor.cpp +43 -0
  959. data/ext/lpsolver-highs/highs/parallel/HighsTaskExecutor.h +217 -0
  960. data/ext/lpsolver-highs/highs/pdlp/CupdlpWrapper.cpp +848 -0
  961. data/ext/lpsolver-highs/highs/pdlp/CupdlpWrapper.h +108 -0
  962. data/ext/lpsolver-highs/highs/pdlp/HiPdlpTimer.h +155 -0
  963. data/ext/lpsolver-highs/highs/pdlp/HiPdlpWrapper.cpp +141 -0
  964. data/ext/lpsolver-highs/highs/pdlp/HiPdlpWrapper.h +26 -0
  965. data/ext/lpsolver-highs/highs/pdlp/cupdlp/Diff +12 -0
  966. data/ext/lpsolver-highs/highs/pdlp/cupdlp/Meld +7 -0
  967. data/ext/lpsolver-highs/highs/pdlp/cupdlp/Merge +2 -0
  968. data/ext/lpsolver-highs/highs/pdlp/cupdlp/README.md +95 -0
  969. data/ext/lpsolver-highs/highs/pdlp/cupdlp/cuda/CMakeLists.txt +58 -0
  970. data/ext/lpsolver-highs/highs/pdlp/cupdlp/cuda/cupdlp_cuda_kernels.cu +338 -0
  971. data/ext/lpsolver-highs/highs/pdlp/cupdlp/cuda/cupdlp_cuda_kernels.cuh +319 -0
  972. data/ext/lpsolver-highs/highs/pdlp/cupdlp/cuda/cupdlp_cudalinalg.cu +386 -0
  973. data/ext/lpsolver-highs/highs/pdlp/cupdlp/cuda/cupdlp_cudalinalg.cuh +149 -0
  974. data/ext/lpsolver-highs/highs/pdlp/cupdlp/cuda/test_cublas.c +154 -0
  975. data/ext/lpsolver-highs/highs/pdlp/cupdlp/cuda/test_cuda_linalg.c +79 -0
  976. data/ext/lpsolver-highs/highs/pdlp/cupdlp/cupdlp.h +16 -0
  977. data/ext/lpsolver-highs/highs/pdlp/cupdlp/cupdlp_cs.c +214 -0
  978. data/ext/lpsolver-highs/highs/pdlp/cupdlp/cupdlp_cs.h +40 -0
  979. data/ext/lpsolver-highs/highs/pdlp/cupdlp/cupdlp_defs.h +447 -0
  980. data/ext/lpsolver-highs/highs/pdlp/cupdlp/cupdlp_linalg.c +802 -0
  981. data/ext/lpsolver-highs/highs/pdlp/cupdlp/cupdlp_linalg.h +189 -0
  982. data/ext/lpsolver-highs/highs/pdlp/cupdlp/cupdlp_proj.c +148 -0
  983. data/ext/lpsolver-highs/highs/pdlp/cupdlp/cupdlp_proj.h +19 -0
  984. data/ext/lpsolver-highs/highs/pdlp/cupdlp/cupdlp_restart.c +124 -0
  985. data/ext/lpsolver-highs/highs/pdlp/cupdlp/cupdlp_restart.h +31 -0
  986. data/ext/lpsolver-highs/highs/pdlp/cupdlp/cupdlp_scaling.c +425 -0
  987. data/ext/lpsolver-highs/highs/pdlp/cupdlp/cupdlp_scaling.h +26 -0
  988. data/ext/lpsolver-highs/highs/pdlp/cupdlp/cupdlp_solver.c +1498 -0
  989. data/ext/lpsolver-highs/highs/pdlp/cupdlp/cupdlp_solver.h +105 -0
  990. data/ext/lpsolver-highs/highs/pdlp/cupdlp/cupdlp_step.c +478 -0
  991. data/ext/lpsolver-highs/highs/pdlp/cupdlp/cupdlp_step.h +37 -0
  992. data/ext/lpsolver-highs/highs/pdlp/cupdlp/cupdlp_utils.c +1850 -0
  993. data/ext/lpsolver-highs/highs/pdlp/cupdlp/cupdlp_utils.h +212 -0
  994. data/ext/lpsolver-highs/highs/pdlp/cupdlp/glbopts.h +342 -0
  995. data/ext/lpsolver-highs/highs/pdlp/hipdlp/defs.hpp +222 -0
  996. data/ext/lpsolver-highs/highs/pdlp/hipdlp/linalg.cc +231 -0
  997. data/ext/lpsolver-highs/highs/pdlp/hipdlp/linalg.hpp +61 -0
  998. data/ext/lpsolver-highs/highs/pdlp/hipdlp/logger.cc +225 -0
  999. data/ext/lpsolver-highs/highs/pdlp/hipdlp/logger.hpp +80 -0
  1000. data/ext/lpsolver-highs/highs/pdlp/hipdlp/pdhg.cc +2798 -0
  1001. data/ext/lpsolver-highs/highs/pdlp/hipdlp/pdhg.cu +497 -0
  1002. data/ext/lpsolver-highs/highs/pdlp/hipdlp/pdhg.hpp +358 -0
  1003. data/ext/lpsolver-highs/highs/pdlp/hipdlp/pdhg_kernels.hpp +77 -0
  1004. data/ext/lpsolver-highs/highs/pdlp/hipdlp/pdlp_gpu_debug.hpp +62 -0
  1005. data/ext/lpsolver-highs/highs/pdlp/hipdlp/restart.cc +132 -0
  1006. data/ext/lpsolver-highs/highs/pdlp/hipdlp/restart.hpp +96 -0
  1007. data/ext/lpsolver-highs/highs/pdlp/hipdlp/scaling.cc +307 -0
  1008. data/ext/lpsolver-highs/highs/pdlp/hipdlp/scaling.hpp +74 -0
  1009. data/ext/lpsolver-highs/highs/pdlp/hipdlp/solver_results.hpp +65 -0
  1010. data/ext/lpsolver-highs/highs/presolve/HPresolve.cpp +8511 -0
  1011. data/ext/lpsolver-highs/highs/presolve/HPresolve.h +505 -0
  1012. data/ext/lpsolver-highs/highs/presolve/HPresolveAnalysis.cpp +239 -0
  1013. data/ext/lpsolver-highs/highs/presolve/HPresolveAnalysis.h +52 -0
  1014. data/ext/lpsolver-highs/highs/presolve/HighsPostsolveStack.cpp +1368 -0
  1015. data/ext/lpsolver-highs/highs/presolve/HighsPostsolveStack.h +943 -0
  1016. data/ext/lpsolver-highs/highs/presolve/HighsSymmetry.cpp +1921 -0
  1017. data/ext/lpsolver-highs/highs/presolve/HighsSymmetry.h +284 -0
  1018. data/ext/lpsolver-highs/highs/presolve/ICrash.cpp +474 -0
  1019. data/ext/lpsolver-highs/highs/presolve/ICrash.h +124 -0
  1020. data/ext/lpsolver-highs/highs/presolve/ICrashUtil.cpp +267 -0
  1021. data/ext/lpsolver-highs/highs/presolve/ICrashUtil.h +62 -0
  1022. data/ext/lpsolver-highs/highs/presolve/ICrashX.cpp +173 -0
  1023. data/ext/lpsolver-highs/highs/presolve/ICrashX.h +23 -0
  1024. data/ext/lpsolver-highs/highs/presolve/PresolveComponent.cpp +45 -0
  1025. data/ext/lpsolver-highs/highs/presolve/PresolveComponent.h +90 -0
  1026. data/ext/lpsolver-highs/highs/qpsolver/README.md +185 -0
  1027. data/ext/lpsolver-highs/highs/qpsolver/a_asm.cpp +139 -0
  1028. data/ext/lpsolver-highs/highs/qpsolver/a_asm.hpp +77 -0
  1029. data/ext/lpsolver-highs/highs/qpsolver/a_quass.cpp +194 -0
  1030. data/ext/lpsolver-highs/highs/qpsolver/a_quass.hpp +22 -0
  1031. data/ext/lpsolver-highs/highs/qpsolver/basis.cpp +443 -0
  1032. data/ext/lpsolver-highs/highs/qpsolver/basis.hpp +159 -0
  1033. data/ext/lpsolver-highs/highs/qpsolver/crashsolution.hpp +20 -0
  1034. data/ext/lpsolver-highs/highs/qpsolver/dantzigpricing.hpp +80 -0
  1035. data/ext/lpsolver-highs/highs/qpsolver/devexharrispricing.hpp +98 -0
  1036. data/ext/lpsolver-highs/highs/qpsolver/devexpricing.hpp +108 -0
  1037. data/ext/lpsolver-highs/highs/qpsolver/eventhandler.hpp +30 -0
  1038. data/ext/lpsolver-highs/highs/qpsolver/factor.hpp +408 -0
  1039. data/ext/lpsolver-highs/highs/qpsolver/feasibility_bounded.hpp +114 -0
  1040. data/ext/lpsolver-highs/highs/qpsolver/feasibility_highs.hpp +301 -0
  1041. data/ext/lpsolver-highs/highs/qpsolver/gradient.hpp +46 -0
  1042. data/ext/lpsolver-highs/highs/qpsolver/instance.hpp +70 -0
  1043. data/ext/lpsolver-highs/highs/qpsolver/matrix.hpp +342 -0
  1044. data/ext/lpsolver-highs/highs/qpsolver/perturbation.cpp +41 -0
  1045. data/ext/lpsolver-highs/highs/qpsolver/perturbation.hpp +15 -0
  1046. data/ext/lpsolver-highs/highs/qpsolver/pricing.hpp +22 -0
  1047. data/ext/lpsolver-highs/highs/qpsolver/qpconst.hpp +34 -0
  1048. data/ext/lpsolver-highs/highs/qpsolver/qpvector.hpp +242 -0
  1049. data/ext/lpsolver-highs/highs/qpsolver/quass.cpp +551 -0
  1050. data/ext/lpsolver-highs/highs/qpsolver/quass.hpp +27 -0
  1051. data/ext/lpsolver-highs/highs/qpsolver/ratiotest.cpp +146 -0
  1052. data/ext/lpsolver-highs/highs/qpsolver/ratiotest.hpp +26 -0
  1053. data/ext/lpsolver-highs/highs/qpsolver/reducedcosts.hpp +46 -0
  1054. data/ext/lpsolver-highs/highs/qpsolver/reducedgradient.hpp +95 -0
  1055. data/ext/lpsolver-highs/highs/qpsolver/runtime.hpp +45 -0
  1056. data/ext/lpsolver-highs/highs/qpsolver/scaling.cpp +123 -0
  1057. data/ext/lpsolver-highs/highs/qpsolver/scaling.hpp +15 -0
  1058. data/ext/lpsolver-highs/highs/qpsolver/settings.hpp +84 -0
  1059. data/ext/lpsolver-highs/highs/qpsolver/snippets.hpp +36 -0
  1060. data/ext/lpsolver-highs/highs/qpsolver/statistics.hpp +30 -0
  1061. data/ext/lpsolver-highs/highs/qpsolver/steepestedgepricing.hpp +173 -0
  1062. data/ext/lpsolver-highs/highs/simplex/HApp.h +550 -0
  1063. data/ext/lpsolver-highs/highs/simplex/HEkk.cpp +4404 -0
  1064. data/ext/lpsolver-highs/highs/simplex/HEkk.h +419 -0
  1065. data/ext/lpsolver-highs/highs/simplex/HEkkControl.cpp +146 -0
  1066. data/ext/lpsolver-highs/highs/simplex/HEkkDebug.cpp +1722 -0
  1067. data/ext/lpsolver-highs/highs/simplex/HEkkDual.cpp +3003 -0
  1068. data/ext/lpsolver-highs/highs/simplex/HEkkDual.h +513 -0
  1069. data/ext/lpsolver-highs/highs/simplex/HEkkDualMulti.cpp +1020 -0
  1070. data/ext/lpsolver-highs/highs/simplex/HEkkDualRHS.cpp +535 -0
  1071. data/ext/lpsolver-highs/highs/simplex/HEkkDualRHS.h +134 -0
  1072. data/ext/lpsolver-highs/highs/simplex/HEkkDualRow.cpp +697 -0
  1073. data/ext/lpsolver-highs/highs/simplex/HEkkDualRow.h +201 -0
  1074. data/ext/lpsolver-highs/highs/simplex/HEkkInterface.cpp +26 -0
  1075. data/ext/lpsolver-highs/highs/simplex/HEkkPrimal.cpp +2984 -0
  1076. data/ext/lpsolver-highs/highs/simplex/HEkkPrimal.h +191 -0
  1077. data/ext/lpsolver-highs/highs/simplex/HSimplex.cpp +330 -0
  1078. data/ext/lpsolver-highs/highs/simplex/HSimplex.h +42 -0
  1079. data/ext/lpsolver-highs/highs/simplex/HSimplexDebug.cpp +145 -0
  1080. data/ext/lpsolver-highs/highs/simplex/HSimplexDebug.h +48 -0
  1081. data/ext/lpsolver-highs/highs/simplex/HSimplexNla.cpp +517 -0
  1082. data/ext/lpsolver-highs/highs/simplex/HSimplexNla.h +158 -0
  1083. data/ext/lpsolver-highs/highs/simplex/HSimplexNlaDebug.cpp +373 -0
  1084. data/ext/lpsolver-highs/highs/simplex/HSimplexNlaFreeze.cpp +28 -0
  1085. data/ext/lpsolver-highs/highs/simplex/HSimplexNlaProductForm.cpp +113 -0
  1086. data/ext/lpsolver-highs/highs/simplex/HSimplexReport.cpp +77 -0
  1087. data/ext/lpsolver-highs/highs/simplex/HSimplexReport.h +21 -0
  1088. data/ext/lpsolver-highs/highs/simplex/HighsSimplexAnalysis.cpp +1495 -0
  1089. data/ext/lpsolver-highs/highs/simplex/HighsSimplexAnalysis.h +500 -0
  1090. data/ext/lpsolver-highs/highs/simplex/SimplexConst.h +273 -0
  1091. data/ext/lpsolver-highs/highs/simplex/SimplexStruct.h +263 -0
  1092. data/ext/lpsolver-highs/highs/simplex/SimplexTimer.h +414 -0
  1093. data/ext/lpsolver-highs/highs/test_kkt/DevKkt.cpp +469 -0
  1094. data/ext/lpsolver-highs/highs/test_kkt/DevKkt.h +143 -0
  1095. data/ext/lpsolver-highs/highs/test_kkt/KktCh2.cpp +305 -0
  1096. data/ext/lpsolver-highs/highs/test_kkt/KktCh2.h +79 -0
  1097. data/ext/lpsolver-highs/highs/util/FactorTimer.h +199 -0
  1098. data/ext/lpsolver-highs/highs/util/HFactor.cpp +2597 -0
  1099. data/ext/lpsolver-highs/highs/util/HFactor.h +587 -0
  1100. data/ext/lpsolver-highs/highs/util/HFactorConst.h +81 -0
  1101. data/ext/lpsolver-highs/highs/util/HFactorDebug.cpp +231 -0
  1102. data/ext/lpsolver-highs/highs/util/HFactorDebug.h +55 -0
  1103. data/ext/lpsolver-highs/highs/util/HFactorExtend.cpp +229 -0
  1104. data/ext/lpsolver-highs/highs/util/HFactorRefactor.cpp +304 -0
  1105. data/ext/lpsolver-highs/highs/util/HFactorUtils.cpp +122 -0
  1106. data/ext/lpsolver-highs/highs/util/HSet.cpp +197 -0
  1107. data/ext/lpsolver-highs/highs/util/HSet.h +89 -0
  1108. data/ext/lpsolver-highs/highs/util/HVector.h +22 -0
  1109. data/ext/lpsolver-highs/highs/util/HVectorBase.cpp +271 -0
  1110. data/ext/lpsolver-highs/highs/util/HVectorBase.h +102 -0
  1111. data/ext/lpsolver-highs/highs/util/HighsCDouble.h +323 -0
  1112. data/ext/lpsolver-highs/highs/util/HighsComponent.h +53 -0
  1113. data/ext/lpsolver-highs/highs/util/HighsDataStack.h +83 -0
  1114. data/ext/lpsolver-highs/highs/util/HighsDisjointSets.h +107 -0
  1115. data/ext/lpsolver-highs/highs/util/HighsHash.cpp +10 -0
  1116. data/ext/lpsolver-highs/highs/util/HighsHash.h +1274 -0
  1117. data/ext/lpsolver-highs/highs/util/HighsHashTree.h +1461 -0
  1118. data/ext/lpsolver-highs/highs/util/HighsInt.h +36 -0
  1119. data/ext/lpsolver-highs/highs/util/HighsIntegers.h +212 -0
  1120. data/ext/lpsolver-highs/highs/util/HighsLinearSumBounds.cpp +267 -0
  1121. data/ext/lpsolver-highs/highs/util/HighsLinearSumBounds.h +203 -0
  1122. data/ext/lpsolver-highs/highs/util/HighsMatrixPic.cpp +146 -0
  1123. data/ext/lpsolver-highs/highs/util/HighsMatrixPic.h +37 -0
  1124. data/ext/lpsolver-highs/highs/util/HighsMatrixSlice.h +561 -0
  1125. data/ext/lpsolver-highs/highs/util/HighsMatrixUtils.cpp +407 -0
  1126. data/ext/lpsolver-highs/highs/util/HighsMatrixUtils.h +57 -0
  1127. data/ext/lpsolver-highs/highs/util/HighsMemoryAllocation.h +63 -0
  1128. data/ext/lpsolver-highs/highs/util/HighsRandom.h +242 -0
  1129. data/ext/lpsolver-highs/highs/util/HighsRbTree.h +452 -0
  1130. data/ext/lpsolver-highs/highs/util/HighsSort.cpp +364 -0
  1131. data/ext/lpsolver-highs/highs/util/HighsSort.h +131 -0
  1132. data/ext/lpsolver-highs/highs/util/HighsSparseMatrix.cpp +1746 -0
  1133. data/ext/lpsolver-highs/highs/util/HighsSparseMatrix.h +151 -0
  1134. data/ext/lpsolver-highs/highs/util/HighsSparseVectorSum.h +95 -0
  1135. data/ext/lpsolver-highs/highs/util/HighsSplay.h +135 -0
  1136. data/ext/lpsolver-highs/highs/util/HighsTimer.h +385 -0
  1137. data/ext/lpsolver-highs/highs/util/HighsUtils.cpp +1259 -0
  1138. data/ext/lpsolver-highs/highs/util/HighsUtils.h +272 -0
  1139. data/ext/lpsolver-highs/highs/util/stringutil.cpp +131 -0
  1140. data/ext/lpsolver-highs/highs/util/stringutil.h +46 -0
  1141. data/ext/lpsolver-highs/highs.pc.in +12 -0
  1142. data/ext/lpsolver-highs/meson.build +198 -0
  1143. data/ext/lpsolver-highs/meson_options.txt +31 -0
  1144. data/ext/lpsolver-highs/nuget/HiGHS_Logo.png +0 -0
  1145. data/ext/lpsolver-highs/nuget/Highs.csproj +25 -0
  1146. data/ext/lpsolver-highs/nuget/Highs.csproj.in +36 -0
  1147. data/ext/lpsolver-highs/nuget/HowToAlternative.md +77 -0
  1148. data/ext/lpsolver-highs/nuget/README.md +38 -0
  1149. data/ext/lpsolver-highs/nuget/arm-toolchain.cmake +15 -0
  1150. data/ext/lpsolver-highs/nuget/build_linux-arm.sh +13 -0
  1151. data/ext/lpsolver-highs/nuget/build_linux.sh +10 -0
  1152. data/ext/lpsolver-highs/nuget/build_windows.ps1 +27 -0
  1153. data/ext/lpsolver-highs/nuget/generatePackage.ps1 +28 -0
  1154. data/ext/lpsolver-highs/pyproject.toml +221 -0
  1155. data/ext/lpsolver-highs/subprojects/pybind11.wrap +13 -0
  1156. data/ext/lpsolver-highs/tests/test_highspy.py +2310 -0
  1157. data/ext/lpsolver-highs/version.rc.in +50 -0
  1158. data/lib/lpsolver/highs +0 -0
  1159. data/lib/lpsolver/model.rb +28 -4
  1160. data/lib/lpsolver/native.so +0 -0
  1161. data/lib/lpsolver/native_model.rb +261 -0
  1162. data/lib/lpsolver/solution.rb +72 -7
  1163. data/lib/lpsolver/version.rb +1 -1
  1164. data/lpsolver.gemspec +4 -1
  1165. metadata +1176 -4
@@ -0,0 +1,1063 @@
1
+ #include <algorithm>
2
+ #include <cstdio>
3
+
4
+ #include "HCheckConfig.h"
5
+ #include "Highs.h"
6
+ #include "catch.hpp"
7
+
8
+ const bool dev_run = false; // true; //
9
+ const bool write_model = false;
10
+
11
+ const double inf = kHighsInf;
12
+
13
+ const HighsInt kIisStrategyFromRayColPriority =
14
+ kIisStrategyFromRay + kIisStrategyColPriority;
15
+ const HighsInt kIisStrategyFromLpColPriority =
16
+ kIisStrategyFromLp + kIisStrategyColPriority;
17
+
18
+ void reportIisInfo(const HighsLogOptions& log_options,
19
+ const HighsIisInfo& iis_info) {
20
+ highsLogUser(log_options, HighsLogType::kInfo, "IIS Info:\n");
21
+ highsLogUser(log_options, HighsLogType::kInfo, "Solved %d LPs\n",
22
+ int(iis_info.num_lp_solved));
23
+ highsLogUser(log_options, HighsLogType::kInfo,
24
+ " Simplex iteration count (min / sum / max) = %d / %d / %d\n",
25
+ int(iis_info.min_simplex_iteration_count),
26
+ int(iis_info.sum_simplex_iteration_counts),
27
+ int(iis_info.max_simplex_iteration_count));
28
+ highsLogUser(log_options, HighsLogType::kInfo,
29
+ " Simplex time (min / sum / max) = %g / %g / %g\n",
30
+ iis_info.min_simplex_time, iis_info.sum_simplex_times,
31
+ iis_info.max_simplex_time);
32
+ }
33
+ void testMps(std::string& model, const HighsInt iis_strategy,
34
+ const HighsModelStatus require_model_status =
35
+ HighsModelStatus::kInfeasible);
36
+
37
+ void testFeasibilityRelaxation(
38
+ std::string& model, const double lower_penalty, const double upper_penalty,
39
+ const double rhs_penalty,
40
+ const double require_feasibility_objective_function_value);
41
+
42
+ TEST_CASE("lp-incompatible-bounds", "[iis]") {
43
+ // LP has row0 and col2 with inconsistent bounds.
44
+ //
45
+ // When prioritising rows, row0 and its constituent columns (1, 2) should be
46
+ // found
47
+ //
48
+ // When prioritising columns, col2 and its constituent rows (0, 1) should be
49
+ // found
50
+ HighsLp lp;
51
+ lp.num_col_ = 3;
52
+ lp.num_row_ = 2;
53
+ lp.col_cost_ = {0, 0, 0};
54
+ lp.col_lower_ = {0, 0, 0};
55
+ lp.col_upper_ = {1, 1, -1};
56
+ lp.row_lower_ = {1, 0};
57
+ lp.row_upper_ = {0, 1};
58
+ lp.a_matrix_.format_ = MatrixFormat::kRowwise;
59
+ lp.a_matrix_.start_ = {0, 2, 4};
60
+ lp.a_matrix_.index_ = {1, 2, 0, 2};
61
+ lp.a_matrix_.value_ = {1, 1, 1, 1};
62
+ Highs highs;
63
+ highs.setOptionValue("output_flag", dev_run);
64
+ highs.passModel(lp);
65
+ // Perform the default (light) IIS check
66
+ HighsIis iis;
67
+ REQUIRE(highs.getIis(iis) == HighsStatus::kOk);
68
+ REQUIRE(highs.getModelStatus() == HighsModelStatus::kInfeasible);
69
+ REQUIRE(iis.valid_ == true);
70
+ REQUIRE(iis.status_ == kIisModelStatusIrreducible);
71
+
72
+ // Perform full IIS
73
+ REQUIRE(highs.run() == HighsStatus::kOk);
74
+ REQUIRE(highs.getModelStatus() == HighsModelStatus::kInfeasible);
75
+
76
+ highs.setOptionValue("iis_strategy", kIisStrategyFromLp);
77
+ REQUIRE(highs.getIis(iis) == HighsStatus::kOk);
78
+ REQUIRE(highs.getModelStatus() == HighsModelStatus::kInfeasible);
79
+ REQUIRE(iis.valid_ == true);
80
+ REQUIRE(iis.status_ == kIisModelStatusIrreducible);
81
+ REQUIRE(iis.col_index_.size() == 0);
82
+ REQUIRE(iis.row_index_.size() == 1);
83
+ REQUIRE(iis.row_index_[0] == 0);
84
+ REQUIRE(iis.row_bound_[0] == kIisBoundStatusBoxed);
85
+ for (HighsInt iCol = 0; iCol < lp.num_col_; iCol++)
86
+ REQUIRE(iis.col_status_[iCol] == kIisStatusNotInConflict);
87
+ for (HighsInt iRow = 0; iRow < lp.num_row_; iRow++) {
88
+ if (iRow == iis.row_index_[0]) {
89
+ REQUIRE(iis.row_status_[iRow] == kIisStatusInConflict);
90
+ } else {
91
+ REQUIRE(iis.row_status_[iRow] == kIisStatusNotInConflict);
92
+ }
93
+ }
94
+
95
+ highs.setOptionValue("iis_strategy", kIisStrategyFromLpColPriority);
96
+ REQUIRE(highs.getIis(iis) == HighsStatus::kOk);
97
+ REQUIRE(highs.getModelStatus() == HighsModelStatus::kInfeasible);
98
+ REQUIRE(iis.valid_ == true);
99
+ REQUIRE(iis.status_ == kIisModelStatusIrreducible);
100
+ REQUIRE(iis.col_index_.size() == 1);
101
+ REQUIRE(iis.row_index_.size() == 0);
102
+ REQUIRE(iis.col_index_[0] == 2);
103
+ REQUIRE(iis.col_bound_[0] == kIisBoundStatusBoxed);
104
+ for (HighsInt iCol = 0; iCol < lp.num_col_; iCol++) {
105
+ if (iCol == iis.col_index_[0]) {
106
+ REQUIRE(iis.col_status_[iCol] == kIisStatusInConflict);
107
+ } else {
108
+ REQUIRE(iis.col_status_[iCol] == kIisStatusNotInConflict);
109
+ }
110
+ }
111
+ for (HighsInt iRow = 0; iRow < lp.num_row_; iRow++)
112
+ REQUIRE(iis.row_status_[iRow] == kIisStatusNotInConflict);
113
+
114
+ // Now give two columns and two rows incompatible bounds, and ensure
115
+ // that just one of each (the first encountered) is found
116
+ lp.col_upper_[0] = -1;
117
+ lp.row_upper_[1] = -1;
118
+ const bool two_inconsistent_rows = lp.row_upper_[0] < lp.row_lower_[0] &&
119
+ lp.row_upper_[1] < lp.row_lower_[1];
120
+ const bool two_inconsistent_cols = lp.col_upper_[0] < lp.col_lower_[0] &&
121
+ lp.col_upper_[2] < lp.col_lower_[2];
122
+ REQUIRE(two_inconsistent_cols);
123
+ REQUIRE(two_inconsistent_rows);
124
+
125
+ highs.passModel(lp);
126
+ highs.setOptionValue("iis_strategy", kIisStrategyFromLp);
127
+ REQUIRE(highs.getIis(iis) == HighsStatus::kOk);
128
+ REQUIRE(highs.getModelStatus() == HighsModelStatus::kInfeasible);
129
+ REQUIRE(iis.valid_ == true);
130
+ REQUIRE(iis.status_ == kIisModelStatusIrreducible);
131
+ REQUIRE(iis.col_index_.size() == 0);
132
+ REQUIRE(iis.row_index_.size() == 1);
133
+ REQUIRE(iis.row_index_[0] == 0);
134
+ REQUIRE(iis.row_bound_[0] == kIisBoundStatusBoxed);
135
+ for (HighsInt iCol = 0; iCol < lp.num_col_; iCol++)
136
+ REQUIRE(iis.col_status_[iCol] == kIisStatusNotInConflict);
137
+ for (HighsInt iRow = 0; iRow < lp.num_row_; iRow++) {
138
+ if (iRow == iis.row_index_[0]) {
139
+ REQUIRE(iis.row_status_[iRow] == kIisStatusInConflict);
140
+ } else {
141
+ REQUIRE(iis.row_status_[iRow] == kIisStatusNotInConflict);
142
+ }
143
+ }
144
+
145
+ highs.setOptionValue("iis_strategy", kIisStrategyFromLpColPriority);
146
+ REQUIRE(highs.getModelStatus() == HighsModelStatus::kInfeasible);
147
+ REQUIRE(highs.getIis(iis) == HighsStatus::kOk);
148
+ REQUIRE(iis.valid_ == true);
149
+ REQUIRE(iis.status_ == kIisModelStatusIrreducible);
150
+ REQUIRE(iis.col_index_.size() == 1);
151
+ REQUIRE(iis.row_index_.size() == 0);
152
+ REQUIRE(iis.col_index_[0] == 0);
153
+ REQUIRE(iis.col_bound_[0] == kIisBoundStatusBoxed);
154
+ for (HighsInt iCol = 0; iCol < lp.num_col_; iCol++) {
155
+ if (iCol == iis.col_index_[0]) {
156
+ REQUIRE(iis.col_status_[iCol] == kIisStatusInConflict);
157
+ } else {
158
+ REQUIRE(iis.col_status_[iCol] == kIisStatusNotInConflict);
159
+ }
160
+ }
161
+ for (HighsInt iRow = 0; iRow < lp.num_row_; iRow++)
162
+ REQUIRE(iis.row_status_[iRow] == kIisStatusNotInConflict);
163
+
164
+ highs.resetGlobalScheduler(true);
165
+ }
166
+
167
+ TEST_CASE("lp-empty-infeasible-row", "[iis]") {
168
+ // Second row is empty, with bounds of [1, 2]
169
+ const HighsInt empty_row = 1;
170
+ HighsLp lp;
171
+ lp.num_col_ = 2;
172
+ lp.num_row_ = 3;
173
+ lp.col_cost_ = {0, 0};
174
+ lp.col_lower_ = {0, 0};
175
+ lp.col_upper_ = {inf, inf};
176
+ lp.row_lower_ = {-inf, 1, -inf};
177
+ lp.row_upper_ = {8, 2, 9};
178
+ lp.a_matrix_.format_ = MatrixFormat::kRowwise;
179
+ lp.a_matrix_.start_ = {0, 2, 2, 4};
180
+ lp.a_matrix_.index_ = {0, 1, 0, 1};
181
+ lp.a_matrix_.value_ = {2, 1, 1, 3};
182
+ Highs highs;
183
+ highs.setOptionValue("output_flag", dev_run);
184
+ highs.passModel(lp);
185
+
186
+ HighsIis iis;
187
+ // Get IIS for empty row with positive lower bound
188
+ REQUIRE(highs.getIis(iis) == HighsStatus::kOk);
189
+ REQUIRE(highs.getModelStatus() == HighsModelStatus::kInfeasible);
190
+ REQUIRE(iis.valid_ == true);
191
+ REQUIRE(iis.status_ == kIisModelStatusIrreducible);
192
+ if (dev_run && write_model) {
193
+ highs.writeModel("");
194
+ highs.writeIisModel("");
195
+ }
196
+ REQUIRE(iis.col_index_.size() == 0);
197
+ REQUIRE(iis.row_index_.size() == 1);
198
+ REQUIRE(iis.row_index_[0] == empty_row);
199
+ REQUIRE(iis.row_bound_[0] == kIisBoundStatusLower);
200
+ for (HighsInt iCol = 0; iCol < lp.num_col_; iCol++)
201
+ REQUIRE(iis.col_status_[iCol] == kIisStatusNotInConflict);
202
+ for (HighsInt iRow = 0; iRow < lp.num_row_; iRow++) {
203
+ if (iRow == iis.row_index_[0]) {
204
+ REQUIRE(iis.row_status_[iRow] == kIisStatusInConflict);
205
+ } else {
206
+ REQUIRE(iis.row_status_[iRow] == kIisStatusNotInConflict);
207
+ }
208
+ }
209
+
210
+ // Get IIS for empty row with negative upper bound
211
+ double new_lower = -2;
212
+ double new_upper = -1;
213
+ assert(new_upper < 0);
214
+ REQUIRE(highs.changeRowBounds(empty_row, new_lower, new_upper) ==
215
+ HighsStatus::kOk);
216
+ lp.row_lower_[empty_row] = new_lower;
217
+ lp.row_upper_[empty_row] = new_upper;
218
+ REQUIRE(highs.getIis(iis) == HighsStatus::kOk);
219
+ REQUIRE(highs.getModelStatus() == HighsModelStatus::kInfeasible);
220
+ REQUIRE(iis.valid_ == true);
221
+ REQUIRE(iis.status_ == kIisModelStatusIrreducible);
222
+ REQUIRE(iis.col_index_.size() == 0);
223
+ REQUIRE(iis.row_index_.size() == 1);
224
+ REQUIRE(iis.row_index_[0] == empty_row);
225
+ REQUIRE(iis.row_bound_[0] == kIisBoundStatusUpper);
226
+ for (HighsInt iCol = 0; iCol < lp.num_col_; iCol++)
227
+ REQUIRE(iis.col_status_[iCol] == kIisStatusNotInConflict);
228
+ for (HighsInt iRow = 0; iRow < lp.num_row_; iRow++) {
229
+ if (iRow == iis.row_index_[0]) {
230
+ REQUIRE(iis.row_status_[iRow] == kIisStatusInConflict);
231
+ } else {
232
+ REQUIRE(iis.row_status_[iRow] == kIisStatusNotInConflict);
233
+ }
234
+ }
235
+
236
+ highs.resetGlobalScheduler(true);
237
+ }
238
+
239
+ TEST_CASE("lp-get-iis-light", "[iis]") {
240
+ HighsLp lp;
241
+ lp.model_name_ = "lp-get-iis-light";
242
+ lp.num_col_ = 4;
243
+ lp.num_row_ = 3;
244
+ lp.col_cost_ = {0, 0, 0, 0};
245
+ lp.col_lower_ = {10, 10, 10, 10};
246
+ lp.col_upper_ = {20, 20, 20, 20};
247
+ lp.row_lower_ = {-inf, -10, -34};
248
+ lp.row_upper_ = {30, 15, inf};
249
+ lp.a_matrix_.format_ = MatrixFormat::kRowwise;
250
+ lp.a_matrix_.num_col_ = lp.num_col_;
251
+ lp.a_matrix_.num_row_ = lp.num_row_;
252
+ lp.a_matrix_.start_ = {0, 3, 7, 10};
253
+ lp.a_matrix_.index_ = {0, 1, 2, 0, 1, 2, 3, 1, 2, 3};
254
+ lp.a_matrix_.value_ = {1.5, 2, 1, 4, -2, 1, 2, -2, -1.5, -1};
255
+ //
256
+ // Each of the three constraints constitutes an IIS. Find each by
257
+ // freeing the upper bounds in turn.
258
+ //
259
+ // 1.5w + 2x + y <= 30
260
+ //
261
+ // -10 <= 4w - 2x + y + 2z <= 15
262
+ //
263
+ // -34 <= - 2x -1.5y - z
264
+ //
265
+ Highs highs;
266
+ highs.setOptionValue("output_flag", dev_run);
267
+ highs.passModel(lp);
268
+ HighsIis iis;
269
+
270
+ for (int l = 0; l < 3; l++) {
271
+ for (int k = 0; k < 2; k++) {
272
+ REQUIRE(highs.getIis(iis) == HighsStatus::kOk);
273
+ REQUIRE(highs.getModelStatus() == HighsModelStatus::kInfeasible);
274
+ REQUIRE(iis.valid_ == true);
275
+ REQUIRE(iis.status_ == kIisModelStatusIrreducible);
276
+ REQUIRE(iis.row_index_.size() == 1);
277
+ HighsInt iis_row = iis.row_index_[0];
278
+ if (lp.a_matrix_.isColwise()) {
279
+ for (HighsInt iCol = 0; iCol < lp.num_col_; iCol++) {
280
+ for (HighsInt iEl = lp.a_matrix_.start_[iCol];
281
+ iEl < lp.a_matrix_.start_[iCol + 1]; iEl++) {
282
+ if (lp.a_matrix_.index_[iEl] == iis_row) {
283
+ REQUIRE(iis.col_status_[iCol] == kIisStatusInConflict);
284
+ break;
285
+ }
286
+ }
287
+ }
288
+ } else {
289
+ for (HighsInt iEl = lp.a_matrix_.start_[iis_row];
290
+ iEl < lp.a_matrix_.start_[iis_row + 1]; iEl++) {
291
+ HighsInt iCol = lp.a_matrix_.index_[iEl];
292
+ REQUIRE(iis.col_status_[iCol] == kIisStatusInConflict);
293
+ }
294
+ }
295
+ for (HighsInt iRow = 0; iRow < lp.num_row_; iRow++) {
296
+ if (iRow == iis.row_index_[0]) {
297
+ REQUIRE(iis.row_status_[iRow] == kIisStatusInConflict);
298
+ } else {
299
+ REQUIRE(iis.row_status_[iRow] == kIisStatusNotInConflict);
300
+ }
301
+ }
302
+ if (dev_run && write_model) {
303
+ highs.writeModel("");
304
+ highs.writeIisModel("");
305
+ highs.writeIisModel(lp.model_name_ + ".lp");
306
+ }
307
+ if (k == 0) {
308
+ // Now flip to column-wise for code coverage
309
+ lp.a_matrix_.ensureColwise();
310
+ highs.passModel(lp);
311
+ }
312
+ }
313
+ // Prevent the first and then the second constraints from being an
314
+ // IIS
315
+ if (l == 0) {
316
+ lp.row_upper_[0] = inf;
317
+ } else if (l == 1) {
318
+ lp.row_upper_[1] = inf;
319
+ }
320
+ highs.passModel(lp);
321
+ }
322
+ highs.resetGlobalScheduler(true);
323
+ }
324
+
325
+ TEST_CASE("lp-get-iis", "[iis]") {
326
+ HighsLp lp;
327
+ lp.model_name_ = "lp-get-iis";
328
+ lp.num_col_ = 2;
329
+ lp.num_row_ = 3;
330
+ lp.col_cost_ = {0, 0};
331
+ lp.col_lower_ = {0, 0};
332
+ lp.col_upper_ = {inf, inf};
333
+ lp.row_lower_ = {-inf, -inf, -inf};
334
+ lp.row_upper_ = {8, 9, -2};
335
+ lp.a_matrix_.format_ = MatrixFormat::kRowwise;
336
+ lp.a_matrix_.num_col_ = lp.num_col_;
337
+ lp.a_matrix_.num_row_ = lp.num_row_;
338
+ lp.a_matrix_.start_ = {0, 2, 4, 6};
339
+ lp.a_matrix_.index_ = {0, 1, 0, 1, 0, 1};
340
+ lp.a_matrix_.value_ = {2, 1, 1, 3, 1, 1};
341
+ //
342
+ // 2x + y <= 8
343
+ //
344
+ // x + 3y <= 9
345
+ //
346
+ // x + y <= -2
347
+ //
348
+ // x, y \in [0, inf)
349
+ //
350
+ // lp.col_name_ = {"Col0", "Col1"};
351
+ // lp.row_name_ = {"Row0", "Row1", "Row2"};
352
+ Highs highs;
353
+ highs.setOptionValue("output_flag", dev_run);
354
+ highs.passModel(lp);
355
+ HighsIis iis;
356
+ const HighsLp& highs_lp = highs.getLp();
357
+ // First pass with incumbent matrix colwise; second with it
358
+ // rowwise
359
+ highs.ensureColwise();
360
+ REQUIRE(highs_lp.a_matrix_.isColwise());
361
+ for (HighsInt k = 0; k < 2; k++) {
362
+ REQUIRE(highs.getIis(iis) == HighsStatus::kOk);
363
+ REQUIRE(highs.getModelStatus() == HighsModelStatus::kInfeasible);
364
+ REQUIRE(iis.valid_ == true);
365
+ REQUIRE(iis.status_ == kIisModelStatusIrreducible);
366
+ REQUIRE(iis.col_index_.size() == 2);
367
+ REQUIRE(iis.row_index_.size() == 1);
368
+ REQUIRE(iis.col_index_[0] == 0);
369
+ REQUIRE(iis.col_index_[1] == 1);
370
+ REQUIRE(iis.row_index_[0] == 2);
371
+
372
+ HighsInt iis_row = iis.row_index_[0];
373
+ if (lp.a_matrix_.isColwise()) {
374
+ for (HighsInt iCol = 0; iCol < lp.num_col_; iCol++) {
375
+ for (HighsInt iEl = lp.a_matrix_.start_[iCol];
376
+ iEl < lp.a_matrix_.start_[iCol + 1]; iEl++) {
377
+ if (lp.a_matrix_.index_[iEl] == iis_row) {
378
+ REQUIRE(iis.col_status_[iCol] == kIisStatusInConflict);
379
+ break;
380
+ }
381
+ }
382
+ }
383
+ } else {
384
+ for (HighsInt iEl = lp.a_matrix_.start_[iis_row];
385
+ iEl < lp.a_matrix_.start_[iis_row + 1]; iEl++) {
386
+ HighsInt iCol = lp.a_matrix_.index_[iEl];
387
+ REQUIRE(iis.col_status_[iCol] == kIisStatusInConflict);
388
+ }
389
+ }
390
+ for (HighsInt iRow = 0; iRow < lp.num_row_; iRow++) {
391
+ if (iRow == iis.row_index_[0]) {
392
+ REQUIRE(iis.row_status_[iRow] == kIisStatusInConflict);
393
+ } else {
394
+ REQUIRE(iis.row_status_[iRow] == kIisStatusNotInConflict);
395
+ }
396
+ }
397
+ highs.clearSolver();
398
+ highs.ensureRowwise();
399
+ REQUIRE(highs_lp.a_matrix_.isRowwise());
400
+ }
401
+ highs.resetGlobalScheduler(true);
402
+ }
403
+
404
+ TEST_CASE("lp-get-iis-woodinfe", "[iis]") {
405
+ std::string model = "woodinfe";
406
+ testMps(model, kIisStrategyLight);
407
+ testMps(model, kIisStrategyFromLp);
408
+ // testMps(model, kIisStrategyFromRay);
409
+ //
410
+ // No need for a +kIisStrategyIrreducible test, since kIisStrategyFromLp
411
+ // yields IIS
412
+ }
413
+
414
+ TEST_CASE("lp-get-iis-galenet", "[iis]") {
415
+ // Dual ray corresponds to constraints
416
+ //
417
+ // r0: 0 <= c0 + c1 - c3 - c4 <=0
418
+ //
419
+ // r1: 20 <= c2 + c3
420
+ //
421
+ // r2: 30 <= c4
422
+ //
423
+ // Where
424
+ //
425
+ // 0 <= c0 <= 10
426
+ //
427
+ // 0 <= c1 <= 10
428
+ //
429
+ // 0 <= c2 <= 2
430
+ //
431
+ // 0 <= c3 <= 20
432
+ //
433
+ // 0 <= c4 <= 30
434
+ //
435
+ // This is infeasible since c4 >= 30 and c4 <= 30 fixes c4 = 30,
436
+ // then c0 + c1 >= c3 + c4 >= 30 cannot be satisfied due to the
437
+ // upper bounds of 10 on these variables
438
+ //
439
+ // r1 can be removed and infeasibility is retained, but not r0 or r2
440
+ //
441
+ // The upper bound on r0 can be removed
442
+ //
443
+ // The lower bounds on c0 and c1 can be removed, but not their upper
444
+ // bounds
445
+ //
446
+ // c2 can be removed, as it is empty once r1 is removed
447
+ //
448
+ // c3 can be removed, as the value of c4 is sufficient to make r0
449
+ // infeasible
450
+ //
451
+ // The bounds on c4 can be removed, since it's the lower bound from
452
+ // r2 that makes r0 infeasible
453
+ //
454
+ // Hence only empty columns can be removed
455
+ //
456
+ // If the elasticity filter is used, then it identifies the
457
+ // following infeasibility system
458
+ //
459
+ // r4: 0 <= c2 + c3 - c6 - c7
460
+ //
461
+ // r6: 20 <= c5 + c6
462
+ //
463
+ // r7: 30 <= c7
464
+ //
465
+ // This is infeasible since c7 >= 30 gives 30 <= c2 + c3, but c2 and
466
+ // c3 have upper bounds of 10
467
+ //
468
+ // Hence the IIS does not require r6 or c5, and consists of r4 and r7
469
+ // (>=0) with c2 <= 10; c3 <= 10; c6 free; c7 free
470
+
471
+ std::string model = "galenet";
472
+ testMps(model, kIisStrategyLight, HighsModelStatus::kNotset);
473
+ testMps(model, kIisStrategyFromLp);
474
+ testMps(model, kIisStrategyFromLp + kIisStrategyIrreducible);
475
+ }
476
+
477
+ TEST_CASE("lp-get-iis-avgas", "[iis]") {
478
+ std::string model = "avgas";
479
+ // For the whole LP calculation feasibility is established prior to elasticity
480
+ // filter so the model status will be optimal
481
+ testMps(model, kIisStrategyFromLp, HighsModelStatus::kOptimal);
482
+ // For the ray calculation the model is solved, so its status is
483
+ // known
484
+ // testMps(model, kIisStrategyFromRay,
485
+ // HighsModelStatus::kOptimal);
486
+ }
487
+
488
+ TEST_CASE("lp-get-iis-time-limit-feasible", "[iis]") {
489
+ std::string model_file =
490
+ std::string(HIGHS_DIR) + "/check/instances/avgas.mps";
491
+
492
+ Highs highs;
493
+ highs.setOptionValue("output_flag", dev_run);
494
+
495
+ REQUIRE(highs.readModel(model_file) == HighsStatus::kOk);
496
+
497
+ // Run first, so that non-infeasibility can be established
498
+ REQUIRE(highs.run() == HighsStatus::kOk);
499
+
500
+ // Set iis time limit to zero to force immediate timeout
501
+ highs.setOptionValue("iis_time_limit", 0.0);
502
+
503
+ // Use kIisStrategyFromLp strategy - this would require solving the
504
+ // LP, but it's not necessary so time limit isn't tested
505
+ highs.setOptionValue("iis_strategy", kIisStrategyFromLp);
506
+
507
+ HighsIis iis;
508
+ // Should return OK since the LP is known to be non-infeasibile
509
+ REQUIRE(highs.getIis(iis) == HighsStatus::kOk);
510
+
511
+ // IIS should be valid since feasibility status is set
512
+ REQUIRE(iis.valid_ == true);
513
+
514
+ // IIS status should be kIisModelStatusFeasible
515
+ REQUIRE(iis.status_ == kIisModelStatusFeasible);
516
+
517
+ // IIS should be empty - no rows or columns identified
518
+ REQUIRE(iis.col_index_.size() == 0);
519
+ REQUIRE(iis.row_index_.size() == 0);
520
+
521
+ // Model status should be kOptimal
522
+ REQUIRE(highs.getModelStatus() == HighsModelStatus::kOptimal);
523
+
524
+ // no LPs solved: min/sum/max simplex iteration counts and min/sum/max
525
+ // simplex times are all zero
526
+ reportIisInfo(highs.getOptions().log_options, iis.info_);
527
+
528
+ highs.resetGlobalScheduler(true);
529
+ }
530
+
531
+ TEST_CASE("lp-get-iis-time-limit-infeasible", "[iis]") {
532
+ std::string model_file =
533
+ std::string(HIGHS_DIR) + "/check/instances/forest6.mps";
534
+
535
+ Highs highs;
536
+ highs.setOptionValue("output_flag", dev_run);
537
+
538
+ REQUIRE(highs.readModel(model_file) == HighsStatus::kOk);
539
+
540
+ // Run first, so that infeasibility can be established
541
+ REQUIRE(highs.run() == HighsStatus::kOk);
542
+
543
+ // Set iis time limit to zero to force immediate timeout
544
+ highs.setOptionValue("iis_time_limit", 0.0);
545
+
546
+ // Use kIisStrategyFromLp strategy - this requires solving the LP
547
+ // which should fail due to time limit
548
+ highs.setOptionValue("iis_strategy", kIisStrategyFromLp);
549
+
550
+ HighsIis iis;
551
+ // Should return error due to time limit being reached
552
+ REQUIRE(highs.getIis(iis) == HighsStatus::kError);
553
+
554
+ // IIS should be invalid since computation could not complete
555
+ REQUIRE(iis.valid_ == false);
556
+
557
+ // IIS status should be kIisModelStatusTimeLimit
558
+ REQUIRE(iis.status_ == kIisModelStatusTimeLimit);
559
+
560
+ // IIS should be empty - no rows or columns identified
561
+ REQUIRE(iis.col_index_.size() == 0);
562
+ REQUIRE(iis.row_index_.size() == 0);
563
+
564
+ // Model status should be kInfeasible, since this is known from HiGHS::run()
565
+ REQUIRE(highs.getModelStatus() == HighsModelStatus::kInfeasible);
566
+
567
+ // 1 LP solved during elastic filtering: see min/sum/max
568
+ // simplex iteration counts and min/sum/max simplex times
569
+ reportIisInfo(highs.getOptions().log_options, iis.info_);
570
+
571
+ highs.resetGlobalScheduler(true);
572
+ }
573
+
574
+ TEST_CASE("lp-get-iis-time-limit", "[iis]") {
575
+ // Test that setting time limit to zero causes getIis() to return
576
+ // an error with an invalid and empty IIS
577
+ //
578
+ // Using forest6 model which is known to be infeasible, but with
579
+ // time_limit = 0, the IIS computation should fail immediately
580
+ //
581
+ // Expected behavior:
582
+ // - getIis() returns HighsStatus::kError
583
+ // - IIS is marked as invalid (valid_ = false)
584
+ // - IIS contains no rows or columns
585
+
586
+ std::string model_file =
587
+ std::string(HIGHS_DIR) + "/check/instances/forest6.mps";
588
+
589
+ Highs highs;
590
+ highs.setOptionValue("output_flag", dev_run);
591
+
592
+ REQUIRE(highs.readModel(model_file) == HighsStatus::kOk);
593
+
594
+ // Set iis time limit to zero to force immediate timeout
595
+ highs.setOptionValue("iis_time_limit", 0.0);
596
+
597
+ // Use kIisStrategyFromLp strategy - this requires solving the LP
598
+ // which should fail due to time limit
599
+ highs.setOptionValue("iis_strategy", kIisStrategyFromLp);
600
+
601
+ HighsIis iis;
602
+ // Should return error due to time limit being reached
603
+ REQUIRE(highs.getIis(iis) == HighsStatus::kError);
604
+
605
+ // IIS should be invalid since computation could not complete
606
+ REQUIRE(iis.valid_ == false);
607
+
608
+ // IIS status should be kIisModelStatusTimeLimit
609
+ REQUIRE(iis.status_ == kIisModelStatusTimeLimit);
610
+
611
+ // IIS should be empty - no rows or columns identified
612
+ REQUIRE(iis.col_index_.size() == 0);
613
+ REQUIRE(iis.row_index_.size() == 0);
614
+
615
+ highs.resetGlobalScheduler(true);
616
+ }
617
+
618
+ TEST_CASE("lp-get-iis-partial", "[iis]") {
619
+ // Test that IIS computation with irreducible strategy on vol1.mps
620
+ // returns a warning status and a candidate IS
621
+ //
622
+ // The vol1.mps model is known to be infeasible but the result found
623
+ // is not irreducible due to encountering kUnknown model statuses during
624
+ // deletion filtering
625
+ //
626
+ // Expected behavior:
627
+ // - getIis() returns HighsStatus::kWarning
628
+ // - IIS contains both columns and rows
629
+
630
+ std::string model_file = std::string(HIGHS_DIR) + "/check/instances/vol1.mps";
631
+
632
+ Highs highs;
633
+ highs.setOptionValue("output_flag", dev_run);
634
+
635
+ REQUIRE(highs.readModel(model_file) == HighsStatus::kOk);
636
+
637
+ // Use kIisStrategyIrreducible strategy
638
+ highs.setOptionValue("iis_strategy", kIisStrategyIrreducible);
639
+
640
+ HighsIis iis;
641
+ // Should return warning since the IIS found is not irreducible
642
+ REQUIRE(highs.getIis(iis) == HighsStatus::kWarning);
643
+
644
+ // Should have identified some potentially conflicting columns and rows
645
+ REQUIRE(iis.col_index_.size() > 0);
646
+ REQUIRE(iis.row_index_.size() > 0);
647
+
648
+ highs.resetGlobalScheduler(true);
649
+ }
650
+
651
+ TEST_CASE("lp-get-iis-time-limit-deletion", "[iis]") {
652
+ // Test that IIS computation with deletion strategy respects time limits
653
+ // and returns partial results when time limit is reached
654
+ //
655
+ // Using cplex1.mps model with a short time limit (1 seconds) to force
656
+ // the deletion strategy to terminate before completing the irreducibility
657
+ // check
658
+ //
659
+ // Expected behavior:
660
+ // - getIis() returns HighsStatus::kWarning
661
+ // - IS is valid but incomplete due to time limit
662
+ // - IIS status indicates time limit was reached
663
+ // - Partial IS contains some columns and rows identified before timeout
664
+
665
+ std::string model_file =
666
+ std::string(HIGHS_DIR) + "/check/instances/cplex1.mps";
667
+
668
+ Highs highs;
669
+ highs.setOptionValue("output_flag", dev_run);
670
+
671
+ REQUIRE(highs.readModel(model_file) == HighsStatus::kOk);
672
+
673
+ // Run the model
674
+ REQUIRE(highs.run() == HighsStatus::kOk);
675
+
676
+ // Use deletion strategy to find irreducible IIS
677
+ highs.setOptionValue("iis_strategy", kIisStrategyIrreducible);
678
+
679
+ // Set a short time limit to force early termination
680
+ highs.setOptionValue("iis_time_limit", 1);
681
+
682
+ HighsIis iis;
683
+ // Should return warning (not error) since partial results are available
684
+ REQUIRE(highs.getIis(iis) == HighsStatus::kWarning);
685
+
686
+ // IIS should be valid even though computation didn't complete
687
+ REQUIRE(iis.valid_ == true);
688
+
689
+ // Status should indicate time limit was reached during deletion
690
+ REQUIRE(iis.status_ == kIisModelStatusTimeLimit);
691
+
692
+ // Should have identified some conflicting columns and rows before timeout
693
+ REQUIRE(iis.col_index_.size() > 0);
694
+ REQUIRE(iis.row_index_.size() > 0);
695
+
696
+ highs.resetGlobalScheduler(true);
697
+ }
698
+
699
+ TEST_CASE("lp-feasibility-relaxation", "[iis]") {
700
+ // Using infeasible MIP from AMPL documentation
701
+ //
702
+ // https://mp.ampl.com/features-guide.html#feasibility-relaxation
703
+ //
704
+ // min x-2y
705
+ //
706
+ // 2 <= -x + 21y
707
+ //
708
+ // -3x + 2y <= 1
709
+ //
710
+ // 20x + y <= 20
711
+ //
712
+ // 5 <= x; y free
713
+ //
714
+ // Vanilla feasibility relaxation
715
+ //
716
+ // min e0 + e1 + e2 + e3
717
+ //
718
+ // 2 <= e1 - x + 21y
719
+ //
720
+ // -3x + 2y - e2 <= 1
721
+ //
722
+ // 20x + y - e3 <= 20
723
+ //
724
+ // 5 <= e0 + x
725
+ //
726
+ // x, y free
727
+ //
728
+ HighsLp lp;
729
+ lp.model_name_ = "ampl_infeas";
730
+ lp.num_col_ = 2;
731
+ lp.num_row_ = 3;
732
+ lp.col_cost_ = {1, -2};
733
+ lp.col_lower_ = {5, -inf};
734
+ lp.col_upper_ = {inf, inf};
735
+ lp.col_names_ = {"X", "Y"};
736
+ lp.row_lower_ = {2, -inf, -inf};
737
+ lp.row_upper_ = {inf, 1, 20};
738
+ lp.row_names_ = {"R0", "R1", "R2"};
739
+ lp.a_matrix_.start_ = {0, 3, 6};
740
+ lp.a_matrix_.index_ = {0, 1, 2, 0, 1, 2};
741
+ lp.a_matrix_.value_ = {-1, -3, 20, 21, 2, 1};
742
+ lp.integrality_ = {HighsVarType::kInteger, HighsVarType::kInteger};
743
+ Highs h;
744
+ h.setOptionValue("output_flag", dev_run);
745
+ const HighsSolution& solution = h.getSolution();
746
+ h.passModel(lp);
747
+
748
+ const bool all_tests = true;
749
+ const bool test0 = true || all_tests;
750
+ const bool test1 = true || all_tests;
751
+ const bool test2 = true || all_tests;
752
+ const bool test3 = true || all_tests;
753
+ if (test0) {
754
+ // Vanilla feasibility relaxation
755
+ if (dev_run)
756
+ printf(
757
+ "==============================\n"
758
+ "Vanilla feasibility relaxation\n"
759
+ "==============================\n");
760
+ REQUIRE(h.feasibilityRelaxation(1, 1, 1) == HighsStatus::kOk);
761
+ // Should get solution (1, 1)
762
+ h.writeSolution("", 1);
763
+ REQUIRE(solution.col_value[0] == 1);
764
+ REQUIRE(solution.col_value[1] == 1);
765
+ }
766
+
767
+ if (test1) {
768
+ // Now we want to force all variable lower bounds to be respected
769
+ if (dev_run)
770
+ printf(
771
+ "========================\n"
772
+ "Respect all lower bounds\n"
773
+ "========================\n");
774
+ h.feasibilityRelaxation(-1, 1, 1);
775
+ // Should get solution (5, 1)
776
+ h.writeSolution("", 1);
777
+ REQUIRE(solution.col_value[0] == 5);
778
+ REQUIRE(solution.col_value[1] == 1);
779
+ }
780
+
781
+ if (test2) {
782
+ if (dev_run)
783
+ printf(
784
+ "===============================\n"
785
+ "Local penalties RHS {1, -1, 10}\n"
786
+ "===============================\n");
787
+ // Now test local penalties, allowing lower bounds to be violated,
788
+ // but not upper bounds
789
+ //
790
+ // constraint 0: normal weight
791
+ //
792
+ // constraint 1: cannot be violated
793
+ //
794
+ // constraint 2: rather not violate
795
+ //
796
+ std::vector<double> local_rhs_penalty = {1, -1, 10};
797
+ h.feasibilityRelaxation(1, 1, 0, nullptr, nullptr,
798
+ local_rhs_penalty.data());
799
+ // AMPL says: Should get slacks (-3, 4, 0) corresponding to (x, y)
800
+ // = (1, 0), giving objective = 4 + 3 = 7
801
+ //
802
+ // However, (x, y) = (0, 0) gives slacks (-2, 1, 20) and also
803
+ // objective = 5 + 2 = 7
804
+ //
805
+ // The 64-bit integer build (11/11/25) gives (x, y) = (1, 0), and
806
+ // the 32-bit integer build gives (x, y) = (0, 0). Since this may
807
+ // vary randomly in future, the test below is dependent on whether
808
+ // x = 0 or x = 1
809
+ const bool solution0 = solution.col_value[0] == 0;
810
+ double r0_slack = solution0 ? -2 : -3;
811
+ double r1_slack = solution0 ? 1 : 4;
812
+ double r2_slack = solution0 ? 20 : 0;
813
+ h.writeSolution("", 1);
814
+ REQUIRE(solution.row_value[0] == lp.row_lower_[0] + r0_slack);
815
+ REQUIRE(solution.row_value[1] == lp.row_upper_[1] - r1_slack);
816
+ REQUIRE(solution.row_value[2] == lp.row_upper_[2] - r2_slack);
817
+ }
818
+
819
+ if (test3) {
820
+ if (dev_run)
821
+ printf(
822
+ "==============================\n"
823
+ "Local penalties RHS {10, 1, 1}\n"
824
+ "==============================\n");
825
+ //
826
+ // constraint 0: rather not violate
827
+ //
828
+ // constraint 1: normal weight
829
+ //
830
+ // constraint 2: normal weight
831
+ //
832
+ std::vector<double> local_rhs_penalty = {10, 1, 1};
833
+ h.feasibilityRelaxation(1, 1, 0, nullptr, nullptr,
834
+ local_rhs_penalty.data());
835
+ // Should get slacks (18, 2, -1)
836
+ h.writeSolution("", 1);
837
+ REQUIRE(solution.row_value[0] == lp.row_lower_[0] + 18);
838
+ REQUIRE(solution.row_value[1] == lp.row_upper_[1] - 2);
839
+ REQUIRE(solution.row_value[2] == lp.row_upper_[2] + 1);
840
+ }
841
+ std::string model = "galenet";
842
+ testFeasibilityRelaxation(model, 1, 1, 1, 28.0);
843
+ model = "woodinfe";
844
+ testFeasibilityRelaxation(model, 1, 1, 1, 15.0);
845
+ model = "avgas";
846
+ testFeasibilityRelaxation(model, 1, 1, 1, 0);
847
+
848
+ h.resetGlobalScheduler(true);
849
+ }
850
+
851
+ void testMps(std::string& model, const HighsInt iis_strategy,
852
+ const HighsModelStatus require_model_status) {
853
+ std::string model_file =
854
+ std::string(HIGHS_DIR) + "/check/instances/" + model + ".mps";
855
+ Highs highs;
856
+ highs.setOptionValue("output_flag", dev_run);
857
+
858
+ REQUIRE(highs.readModel(model_file) == HighsStatus::kOk);
859
+ // if (iis_strategy == kIisStrategyFromRay ||
860
+ // iis_strategy == kIisStrategyFromRayColPriority) {
861
+ // // For a ray strategy, solve the LP first
862
+ // REQUIRE(highs.run() == HighsStatus::kOk);
863
+ // }
864
+ highs.setOptionValue("iis_strategy", iis_strategy);
865
+ HighsIis iis;
866
+ REQUIRE(highs.getIis(iis) == HighsStatus::kOk);
867
+ if (dev_run && write_model) {
868
+ highs.writeModel("");
869
+ highs.writeIisModel("");
870
+ }
871
+ HighsInt num_iis_col = iis.col_index_.size();
872
+ HighsInt num_iis_row = iis.row_index_.size();
873
+ HighsModelStatus model_status = highs.getModelStatus();
874
+ REQUIRE(model_status == require_model_status);
875
+ if (model_status == HighsModelStatus::kInfeasible) {
876
+ REQUIRE(num_iis_col > 0);
877
+ REQUIRE(num_iis_row > 0);
878
+ if (dev_run)
879
+ printf("Model %s has IIS with %d columns and %d rows\n", model.c_str(),
880
+ int(num_iis_col), int(num_iis_row));
881
+ REQUIRE(iis.valid_ == true);
882
+ const bool find_irreducible = kIisStrategyIrreducible & iis_strategy;
883
+ if (find_irreducible) REQUIRE(iis.status_ == kIisModelStatusIrreducible);
884
+ const HighsInt in_iis_status = iis.status_ == kIisModelStatusIrreducible
885
+ ? kIisStatusInConflict
886
+ : kIisStatusMaybeInConflict;
887
+ for (HighsInt iX = 0; iX < num_iis_col; iX++)
888
+ REQUIRE(iis.col_status_[iis.col_index_[iX]] == in_iis_status);
889
+ for (HighsInt iX = 0; iX < num_iis_row; iX++)
890
+ REQUIRE(iis.row_status_[iis.row_index_[iX]] == in_iis_status);
891
+ } else {
892
+ REQUIRE(num_iis_col == 0);
893
+ REQUIRE(num_iis_row == 0);
894
+ }
895
+ }
896
+
897
+ void testFeasibilityRelaxation(
898
+ std::string& model, const double lower_penalty, const double upper_penalty,
899
+ const double rhs_penalty,
900
+ const double require_feasibility_objective_function_value) {
901
+ std::string model_file =
902
+ std::string(HIGHS_DIR) + "/check/instances/" + model + ".mps";
903
+ Highs h;
904
+ h.setOptionValue("output_flag", dev_run);
905
+ h.readModel(model_file);
906
+ REQUIRE(h.feasibilityRelaxation(lower_penalty, upper_penalty, rhs_penalty) ==
907
+ HighsStatus::kOk);
908
+ REQUIRE(h.getInfo().objective_function_value ==
909
+ require_feasibility_objective_function_value);
910
+ }
911
+
912
+ TEST_CASE("feasible-lp-iis", "[iis]") {
913
+ HighsLp lp;
914
+ lp.model_name_ = "chip";
915
+ lp.sense_ = ObjSense::kMaximize;
916
+ lp.num_col_ = 2;
917
+ lp.num_row_ = 2;
918
+ lp.col_cost_ = {10, 25};
919
+ lp.col_lower_ = {0, 0};
920
+ lp.col_upper_ = {inf, inf};
921
+ lp.col_names_ = {"Tables", "SetsOfChairs"};
922
+ lp.row_lower_ = {-inf, -inf};
923
+ lp.row_upper_ = {80, 120};
924
+ lp.row_names_ = {"Assembly", "Finishng"};
925
+ lp.a_matrix_.start_ = {0, 2, 4};
926
+ lp.a_matrix_.index_ = {0, 1, 0, 1};
927
+ lp.a_matrix_.value_ = {1, 1, 2, 4};
928
+ Highs h;
929
+ h.setOptionValue("output_flag", dev_run);
930
+ h.passModel(lp);
931
+ HighsIis iis;
932
+ // With kIisStrategyLight, feasibility of the LP is not determined
933
+ // until it's been solved
934
+ h.getIis(iis);
935
+ REQUIRE(iis.col_index_.size() == 0);
936
+ REQUIRE(iis.row_index_.size() == 0);
937
+ REQUIRE(iis.col_status_[0] == kIisStatusMaybeInConflict);
938
+ REQUIRE(iis.col_status_[1] == kIisStatusMaybeInConflict);
939
+ REQUIRE(iis.row_status_[0] == kIisStatusMaybeInConflict);
940
+ REQUIRE(iis.row_status_[1] == kIisStatusMaybeInConflict);
941
+
942
+ h.run();
943
+
944
+ h.getIis(iis);
945
+ REQUIRE(h.getModelStatus() == HighsModelStatus::kOptimal);
946
+ REQUIRE(iis.col_index_.size() == 0);
947
+ REQUIRE(iis.row_index_.size() == 0);
948
+ REQUIRE(iis.col_status_[0] == kIisStatusNotInConflict);
949
+ REQUIRE(iis.col_status_[1] == kIisStatusNotInConflict);
950
+ REQUIRE(iis.row_status_[0] == kIisStatusNotInConflict);
951
+ REQUIRE(iis.row_status_[1] == kIisStatusNotInConflict);
952
+
953
+ h.passModel(lp);
954
+ // With kIisStrategyFromLp, feasibility of the LP is determined
955
+ h.setOptionValue("iis_strategy", kIisStrategyFromLp);
956
+
957
+ h.getIis(iis);
958
+ REQUIRE(iis.col_index_.size() == 0);
959
+ REQUIRE(iis.row_index_.size() == 0);
960
+ REQUIRE(iis.col_status_[0] == kIisStatusNotInConflict);
961
+ REQUIRE(iis.col_status_[1] == kIisStatusNotInConflict);
962
+ REQUIRE(iis.row_status_[0] == kIisStatusNotInConflict);
963
+ REQUIRE(iis.row_status_[1] == kIisStatusNotInConflict);
964
+
965
+ h.resetGlobalScheduler(true);
966
+ }
967
+
968
+ TEST_CASE("write-iis_model-file", "[iis]") {
969
+ // Reproduces #2635, and adds code coverage for writing IIS model
970
+ // and solution at runtime
971
+ const std::string test_name = Catch::getResultCapture().getCurrentTestName();
972
+ const std::string test_mps = test_name + ".mps";
973
+ const std::string test_sol = test_name + ".sol";
974
+ HighsLp lp;
975
+ lp.model_name_ = "2635";
976
+ lp.num_col_ = 5;
977
+ lp.num_row_ = 4;
978
+ lp.col_cost_ = {-1, -1, 0, 0, 0};
979
+ lp.col_lower_ = {0, 0, 10, 0, 0};
980
+ lp.col_upper_ = {kHighsInf, kHighsInf, 10, kHighsInf, kHighsInf};
981
+ lp.row_lower_ = {0, 0, 0, 20};
982
+ lp.row_upper_ = {0, 0, 0, kHighsInf};
983
+ lp.a_matrix_.start_ = {0, 2, 4, 5, 7, 10};
984
+ lp.a_matrix_.index_ = {1, 3, 2, 3, 1, 0, 2, 0, 1, 2};
985
+ lp.a_matrix_.value_ = {-1, 1, -1, 1, 1, 1, 1, -0.5, -1, 1};
986
+ lp.col_names_ = {"x0", "x1", "x2", "x3", "x4"};
987
+ lp.row_names_ = {"x3-.5x4=0", "x2-x4-x0=0", "x3+x4-x1=0", "x0+x1>=20"};
988
+ Highs h;
989
+ h.setOptionValue("output_flag", dev_run);
990
+ h.setOptionValue("log_file", "highs.log");
991
+ h.setOptionValue("write_iis_model_file", test_mps);
992
+ h.setOptionValue("solution_file", test_sol);
993
+ const HighsInt to_k = 2;
994
+ for (HighsInt k = 0; k <= to_k; k++) {
995
+ if (k == 0) {
996
+ h.setOptionValue("iis_strategy", kIisStrategyLight);
997
+ } else if (k == 1) {
998
+ h.setOptionValue("iis_strategy", kIisStrategyFromLp);
999
+ } else {
1000
+ assert(k == 2);
1001
+ h.setOptionValue("iis_strategy",
1002
+ kIisStrategyFromLp + kIisStrategyIrreducible);
1003
+ }
1004
+ if (dev_run)
1005
+ printf(
1006
+ "\nPass %d with iis_strategy = %d\n============================\n\n",
1007
+ int(k), int(h.getOptions().iis_strategy));
1008
+ h.passModel(lp);
1009
+ h.run();
1010
+ h.readModel(test_mps);
1011
+ if (k == 0) {
1012
+ REQUIRE(h.getLp().num_col_ == 0);
1013
+ REQUIRE(h.getLp().num_row_ == 0);
1014
+ } else {
1015
+ // Use h.optimizeModel(); to avoid unnecessary MPS and solution
1016
+ // file
1017
+ h.optimizeModel();
1018
+ REQUIRE(h.getModelStatus() == HighsModelStatus::kInfeasible);
1019
+ }
1020
+ }
1021
+ std::remove(test_mps.c_str());
1022
+ std::remove(test_sol.c_str());
1023
+ h.resetGlobalScheduler(true);
1024
+ }
1025
+
1026
+ char iis_printed_log[kIoBufferSize];
1027
+
1028
+ /*
1029
+ static void iisLogCallback0(HighsLogType type, const char* message,
1030
+ void* user_log_callback_data) {
1031
+ if (dev_run) printf("iisLogCallback0: %s", message);
1032
+ }
1033
+ */
1034
+
1035
+ HighsCallbackFunctionType iisLogCallback1 =
1036
+ [](int callback_type, const std::string& message,
1037
+ const HighsCallbackOutput* data_out, HighsCallbackInput* data_in,
1038
+ void* user_callback_data) {
1039
+ if (dev_run) printf("iisLogCallback1: %s", message.c_str());
1040
+ };
1041
+
1042
+ TEST_CASE("iis-callback", "[highs-callback]") {
1043
+ std::string model = "galenet";
1044
+ std::string model_file =
1045
+ std::string(HIGHS_DIR) + "/check/instances/" + model + ".mps";
1046
+ Highs highs;
1047
+ highs.setOptionValue("log_to_console", dev_run);
1048
+ HighsInt iis_strategy = kIisStrategyFromLp + kIisStrategyIrreducible;
1049
+ highs.setOptionValue("iis_strategy", iis_strategy);
1050
+ // Set both the deprecated and current logging callbacks
1051
+ // REQUIRE(highs.setLogCallback(iisLogCallback0) == HighsStatus::kOk);
1052
+ REQUIRE(highs.setCallback(iisLogCallback1) == HighsStatus::kOk);
1053
+
1054
+ REQUIRE(highs.startCallback(kCallbackLogging) == HighsStatus::kOk);
1055
+ REQUIRE(highs.startCallback(kCallbackSimplexInterrupt) == HighsStatus::kOk);
1056
+
1057
+ REQUIRE(highs.readModel(model_file) == HighsStatus::kOk);
1058
+
1059
+ HighsIis iis;
1060
+ REQUIRE(highs.getIis(iis) == HighsStatus::kOk);
1061
+
1062
+ highs.resetGlobalScheduler(true);
1063
+ }