lpsolver 0.1.0 → 0.2.1

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 +104 -26
  4. data/ext/lpsolver/Makefile +269 -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 +35 -7
  1160. data/lib/lpsolver/native.so +0 -0
  1161. data/lib/lpsolver/native_model.rb +261 -0
  1162. data/lib/lpsolver/solution.rb +93 -8
  1163. data/lib/lpsolver/version.rb +1 -1
  1164. data/lpsolver.gemspec +4 -1
  1165. metadata +1176 -4
@@ -0,0 +1,1461 @@
1
+ /* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2
+ /* */
3
+ /* This file is part of the HiGHS linear optimization suite */
4
+ /* */
5
+ /* Available as open-source under the MIT License */
6
+ /* */
7
+ /* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
8
+ #ifndef HIGHS_UTIL_HASH_TREE_H_
9
+ #define HIGHS_UTIL_HASH_TREE_H_
10
+
11
+ #include <stdexcept>
12
+
13
+ #include "util/HighsHash.h"
14
+
15
+ using std::memcpy;
16
+ using std::memmove;
17
+
18
+ template <typename K, typename V = void>
19
+ class HighsHashTree {
20
+ using Entry = HighsHashTableEntry<K, V>;
21
+ using ValueType =
22
+ typename std::remove_reference<decltype(Entry().value())>::type;
23
+
24
+ enum Type {
25
+ kEmpty = 0,
26
+ kListLeaf = 1,
27
+ kInnerLeafSizeClass1 = 2,
28
+ kInnerLeafSizeClass2 = 3,
29
+ kInnerLeafSizeClass3 = 4,
30
+ kInnerLeafSizeClass4 = 5,
31
+ kBranchNode = 6,
32
+ };
33
+
34
+ enum Constants {
35
+ kBitsPerLevel = 6,
36
+ kBranchFactor = 1 << kBitsPerLevel,
37
+ // even though we could use up to 64 bits of the hash this would require
38
+ // additional handling in the last levels to avoid negative shift values
39
+ // up to 9 depth levels are Ok though as up to index 8 the
40
+ // get_hash_chunks16() function shifts right by a non-negative amount
41
+ kMaxDepth = 9,
42
+ kMinLeafSize = 6,
43
+ kLeafBurstThreshold = 54,
44
+ };
45
+
46
+ static uint64_t compute_hash(const K& key) {
47
+ return HighsHashHelpers::hash(key);
48
+ }
49
+
50
+ static uint8_t get_hash_chunk(uint64_t hash, int pos) {
51
+ return (hash >> (64 - kBitsPerLevel - pos * kBitsPerLevel)) &
52
+ (kBranchFactor - 1);
53
+ }
54
+
55
+ static uint16_t get_hash_chunks16(uint64_t hash, int pos) {
56
+ return (hash >> (48 - pos * kBitsPerLevel));
57
+ }
58
+
59
+ static uint8_t get_first_chunk16(uint16_t chunks) {
60
+ return chunks >> (16 - kBitsPerLevel);
61
+ }
62
+
63
+ static void set_hash_chunk(uint64_t& hash, uint64_t chunk, int chunkPos) {
64
+ const int shiftAmount = (60 - kBitsPerLevel - chunkPos * kBitsPerLevel);
65
+ chunk ^= (hash >> shiftAmount) & (kBranchFactor - 1);
66
+ hash ^= chunk << shiftAmount;
67
+ }
68
+
69
+ struct Occupation {
70
+ uint64_t occupation;
71
+
72
+ Occupation() {}
73
+ Occupation(uint64_t occupation) : occupation(occupation) {}
74
+ operator uint64_t() const { return occupation; }
75
+
76
+ void set(uint8_t pos) { occupation |= uint64_t{1} << (pos); }
77
+
78
+ void flip(uint8_t pos) { occupation ^= uint64_t{1} << (pos); }
79
+
80
+ bool test(uint8_t pos) const { return occupation & (uint64_t{1} << pos); }
81
+
82
+ int num_set_until(uint8_t pos) const {
83
+ return HighsHashHelpers::popcnt(occupation >> pos);
84
+ }
85
+
86
+ int num_set_after(uint8_t pos) const {
87
+ return HighsHashHelpers::popcnt(occupation << (63 - (pos)));
88
+ }
89
+
90
+ int num_set() const { return HighsHashHelpers::popcnt(occupation); }
91
+ };
92
+
93
+ static constexpr int entries_to_size_class(unsigned int numEntries) {
94
+ return 1 + unsigned(numEntries + ((kLeafBurstThreshold - kMinLeafSize) / 3 -
95
+ kMinLeafSize - 1)) /
96
+ ((kLeafBurstThreshold - kMinLeafSize) / 3);
97
+ }
98
+
99
+ template <int kSizeClass>
100
+ struct InnerLeaf {
101
+ static constexpr int capacity() {
102
+ return kMinLeafSize +
103
+ (kSizeClass - 1) * (kLeafBurstThreshold - kMinLeafSize) / 3;
104
+ }
105
+ // the leaf stores entries the same way as inner nodes
106
+ // but handles collisions on the occupation flag like a
107
+ // linear probing hash table.
108
+ // Since the occupation flag has 64 bits and we only use
109
+ // 15 collisions should be rare and most often we won't need
110
+ // to do a linear scan and key comparisons at all
111
+ Occupation occupation;
112
+ int size;
113
+ std::array<uint64_t, capacity() + 1> hashes;
114
+ std::array<Entry, capacity()> entries;
115
+
116
+ InnerLeaf() : occupation(0), size(0) { hashes[0] = 0; }
117
+
118
+ template <int kOtherSize>
119
+ InnerLeaf(InnerLeaf<kOtherSize>&& other) {
120
+ assert(other.size <= capacity());
121
+ occupation = other.occupation;
122
+ size = other.size;
123
+ std::copy(other.hashes.cbegin(),
124
+ std::next(other.hashes.cbegin(), size + 1), hashes.begin());
125
+ std::move(other.entries.begin(), std::next(other.entries.begin(), size),
126
+ entries.begin());
127
+ }
128
+
129
+ int get_num_entries() const { return size; }
130
+
131
+ std::pair<ValueType*, bool> insert_entry(uint64_t fullHash, int hashPos,
132
+ Entry& entry) {
133
+ assert(size < capacity());
134
+ uint16_t hash = get_hash_chunks16(fullHash, hashPos);
135
+ uint8_t hashChunk = get_first_chunk16(hash);
136
+
137
+ int pos = occupation.num_set_until(hashChunk);
138
+
139
+ if (occupation.test(hashChunk)) {
140
+ // since the occupation flag is set we need to start searching from
141
+ // pos-1 and can rely on a hash chunk with the same value existing for
142
+ // the scan
143
+ --pos;
144
+ while (hashes[pos] > hash) ++pos;
145
+
146
+ if (find_key(entry.key(), hash, pos))
147
+ return std::make_pair(&entries[pos].value(), false);
148
+
149
+ } else {
150
+ occupation.set(hashChunk);
151
+
152
+ if (pos < size)
153
+ while (hashes[pos] > hash) ++pos;
154
+ }
155
+
156
+ if (pos < size) move_backward(pos, size);
157
+ entries[pos] = std::move(entry);
158
+ hashes[pos] = hash;
159
+ ++size;
160
+ hashes[size] = 0;
161
+
162
+ return std::make_pair(&entries[pos].value(), true);
163
+ }
164
+
165
+ ValueType* find_entry(uint64_t fullHash, int hashPos, const K& key) {
166
+ uint16_t hash = get_hash_chunks16(fullHash, hashPos);
167
+ uint8_t hashChunk = get_first_chunk16(hash);
168
+ if (!occupation.test(hashChunk)) return nullptr;
169
+
170
+ int pos = occupation.num_set_until(hashChunk) - 1;
171
+ while (hashes[pos] > hash) ++pos;
172
+
173
+ if (find_key(key, hash, pos)) return &entries[pos].value();
174
+
175
+ return nullptr;
176
+ }
177
+
178
+ bool erase_entry(uint64_t fullHash, int hashPos, const K& key) {
179
+ uint16_t hash = get_hash_chunks16(fullHash, hashPos);
180
+ uint8_t hashChunk = get_first_chunk16(hash);
181
+ if (!occupation.test(hashChunk)) return false;
182
+
183
+ int startPos = occupation.num_set_until(hashChunk) - 1;
184
+ while (get_first_chunk16(hashes[startPos]) > hashChunk) ++startPos;
185
+
186
+ int pos = startPos;
187
+ while (hashes[pos] > hash) ++pos;
188
+
189
+ if (!find_key(key, hash, pos)) return false;
190
+
191
+ --size;
192
+ if (pos < size) {
193
+ std::move(std::next(entries.begin(), pos + 1),
194
+ std::next(entries.begin(), size + 1),
195
+ std::next(entries.begin(), pos));
196
+ memmove(&hashes[pos], &hashes[pos + 1],
197
+ sizeof(hashes[0]) * (size - pos));
198
+ if (get_first_chunk16(hashes[startPos]) != hashChunk)
199
+ occupation.flip(hashChunk);
200
+ } else if (startPos == pos)
201
+ occupation.flip(hashChunk);
202
+
203
+ hashes[size] = 0;
204
+ return true;
205
+ }
206
+
207
+ void rehash(int hashPos) {
208
+ // function needs to possibly reorder elements by a different hash value
209
+ // chances are very high we are already ordered correctly as we use 16
210
+ // bits of the hash and one level is uses 6 bits, so the new values
211
+ // are guaranteed to be ordered correctly by their 10 most significant
212
+ // bits if increasing the hash position by 1 and only if the 10 bits of
213
+ // the hash had a collision the new 6 bits might break a tie differently.
214
+ // It is, however, important to maintain the exact ordering as otherwise
215
+ // elements may not be found.
216
+ occupation = 0;
217
+ for (int i = 0; i < size; ++i) {
218
+ hashes[i] = get_hash_chunks16(compute_hash(entries[i].key()), hashPos);
219
+ occupation.set(get_first_chunk16(hashes[i]));
220
+ }
221
+
222
+ int i = 0;
223
+ while (i < size) {
224
+ uint8_t hashChunk = get_first_chunk16(hashes[i]);
225
+ int pos = occupation.num_set_until(hashChunk) - 1;
226
+
227
+ // if the position is after i the element definitely comes later, so we
228
+ // swap it to that position and proceed without increasing i until
229
+ // eventually an element appears that comes at position i or before
230
+ if (pos > i) {
231
+ std::swap(hashes[pos], hashes[i]);
232
+ std::swap(entries[pos], entries[i]);
233
+ continue;
234
+ }
235
+
236
+ // the position is before or at i, now check where the exact location
237
+ // should be for the ordering by hash so that the invariant is that all
238
+ // elements up to i are properly sorted. Essentially insertion sort but
239
+ // with the modification of having a high chance to guess the correct
240
+ // position already using the occupation flags.
241
+ while (pos < i && hashes[pos] >= hashes[i]) ++pos;
242
+
243
+ // if the final position is before i we need to move elements to
244
+ // make space at that position, otherwise nothing needs to be done but
245
+ // incrementing i increasing the sorted range by 1.
246
+ if (pos < i) {
247
+ uint64_t hash = hashes[i];
248
+ auto entry = std::move(entries[i]);
249
+ move_backward(pos, i);
250
+ hashes[pos] = hash;
251
+ entries[pos] = std::move(entry);
252
+ }
253
+ ++i;
254
+ }
255
+ }
256
+
257
+ void move_backward(const int& first, const int& last) {
258
+ // move elements backwards
259
+ std::move_backward(std::next(entries.begin(), first),
260
+ std::next(entries.begin(), last),
261
+ std::next(entries.begin(), last + 1));
262
+ memmove(&hashes[first + 1], &hashes[first],
263
+ sizeof(hashes[0]) * (last - first));
264
+ }
265
+
266
+ bool find_key(const K& key, const uint16_t& hash, int& pos) const {
267
+ // find key
268
+ while (pos != size && hashes[pos] == hash) {
269
+ if (key == entries[pos].key()) return true;
270
+ ++pos;
271
+ }
272
+ return false;
273
+ }
274
+ };
275
+
276
+ struct ListNode {
277
+ ListNode* next;
278
+ HighsHashTableEntry<K, V> entry;
279
+ ListNode(HighsHashTableEntry<K, V>&& entry)
280
+ : next(nullptr), entry(std::move(entry)) {}
281
+ };
282
+ struct ListLeaf {
283
+ ListNode first;
284
+ int count;
285
+
286
+ ListLeaf(HighsHashTableEntry<K, V>&& entry)
287
+ : first(std::move(entry)), count(1) {}
288
+ };
289
+
290
+ struct BranchNode;
291
+
292
+ struct NodePtr {
293
+ uintptr_t ptrAndType;
294
+
295
+ NodePtr() : ptrAndType(kEmpty) {}
296
+ NodePtr(std::nullptr_t) : ptrAndType(kEmpty) {}
297
+ NodePtr(ListLeaf* ptr)
298
+ : ptrAndType(reinterpret_cast<uintptr_t>(ptr) | kListLeaf) {}
299
+ NodePtr(InnerLeaf<1>* ptr)
300
+ : ptrAndType(reinterpret_cast<uintptr_t>(ptr) | kInnerLeafSizeClass1) {}
301
+ NodePtr(InnerLeaf<2>* ptr)
302
+ : ptrAndType(reinterpret_cast<uintptr_t>(ptr) | kInnerLeafSizeClass2) {}
303
+ NodePtr(InnerLeaf<3>* ptr)
304
+ : ptrAndType(reinterpret_cast<uintptr_t>(ptr) | kInnerLeafSizeClass3) {}
305
+ NodePtr(InnerLeaf<4>* ptr)
306
+ : ptrAndType(reinterpret_cast<uintptr_t>(ptr) | kInnerLeafSizeClass4) {}
307
+ NodePtr(BranchNode* ptr)
308
+ : ptrAndType(reinterpret_cast<uintptr_t>(ptr) | kBranchNode) {
309
+ assert(ptr != nullptr);
310
+ }
311
+
312
+ Type getType() const { return Type(ptrAndType & 7u); }
313
+
314
+ int numEntriesEstimate() const {
315
+ switch (getType()) {
316
+ case kEmpty:
317
+ return 0;
318
+ case kListLeaf:
319
+ return 1;
320
+ case kInnerLeafSizeClass1:
321
+ return InnerLeaf<1>::capacity();
322
+ case kInnerLeafSizeClass2:
323
+ return InnerLeaf<2>::capacity();
324
+ case kInnerLeafSizeClass3:
325
+ return InnerLeaf<3>::capacity();
326
+ case kInnerLeafSizeClass4:
327
+ return InnerLeaf<4>::capacity();
328
+ case kBranchNode:
329
+ // something large should be returned so that the number of entries
330
+ // is estimated above the threshold to merge when the parent checks
331
+ // its children after deletion
332
+ return kBranchFactor;
333
+ default:
334
+ throw std::logic_error("Unexpected type in hash tree");
335
+ }
336
+ }
337
+
338
+ int numEntries() const {
339
+ switch (getType()) {
340
+ case kEmpty:
341
+ return 0;
342
+ case kListLeaf:
343
+ return getListLeaf()->count;
344
+ case kInnerLeafSizeClass1:
345
+ return getInnerLeafSizeClass1()->size;
346
+ case kInnerLeafSizeClass2:
347
+ return getInnerLeafSizeClass2()->size;
348
+ case kInnerLeafSizeClass3:
349
+ return getInnerLeafSizeClass3()->size;
350
+ case kInnerLeafSizeClass4:
351
+ return getInnerLeafSizeClass4()->size;
352
+ case kBranchNode:
353
+ // something large should be returned so that the number of entries
354
+ // is estimated above the threshold to merge when the parent checks
355
+ // its children after deletion
356
+ return kBranchFactor;
357
+ default:
358
+ throw std::logic_error("Unexpected type in hash tree");
359
+ }
360
+ }
361
+
362
+ ListLeaf* getListLeaf() const {
363
+ assert(getType() == kListLeaf);
364
+ return reinterpret_cast<ListLeaf*>(ptrAndType & ~uintptr_t{7});
365
+ }
366
+
367
+ InnerLeaf<1>* getInnerLeafSizeClass1() const {
368
+ assert(getType() == kInnerLeafSizeClass1);
369
+ return reinterpret_cast<InnerLeaf<1>*>(ptrAndType & ~uintptr_t{7});
370
+ }
371
+ InnerLeaf<2>* getInnerLeafSizeClass2() const {
372
+ assert(getType() == kInnerLeafSizeClass2);
373
+ return reinterpret_cast<InnerLeaf<2>*>(ptrAndType & ~uintptr_t{7});
374
+ }
375
+
376
+ InnerLeaf<3>* getInnerLeafSizeClass3() const {
377
+ assert(getType() == kInnerLeafSizeClass3);
378
+ return reinterpret_cast<InnerLeaf<3>*>(ptrAndType & ~uintptr_t{7});
379
+ }
380
+
381
+ InnerLeaf<4>* getInnerLeafSizeClass4() const {
382
+ assert(getType() == kInnerLeafSizeClass4);
383
+ return reinterpret_cast<InnerLeaf<4>*>(ptrAndType & ~uintptr_t{7});
384
+ }
385
+
386
+ BranchNode* getBranchNode() const {
387
+ assert(getType() == kBranchNode);
388
+ return reinterpret_cast<BranchNode*>(ptrAndType & ~uintptr_t{7});
389
+ }
390
+ };
391
+
392
+ struct BranchNode {
393
+ Occupation occupation;
394
+
395
+ NodePtr* children() { return reinterpret_cast<NodePtr*>(this + 1); }
396
+
397
+ const NodePtr* children() const {
398
+ return reinterpret_cast<const NodePtr*>(this + 1);
399
+ }
400
+
401
+ NodePtr& child(int index) { return children()[index]; }
402
+
403
+ const NodePtr& child(int index) const { return children()[index]; }
404
+
405
+ NodePtr* childPtr(int index) { return children() + index; }
406
+
407
+ const NodePtr* childPtr(int index) const { return children() + index; }
408
+ };
409
+
410
+ static_assert(sizeof(BranchNode) % alignof(NodePtr) == 0,
411
+ "BranchNode trailing storage must stay NodePtr aligned");
412
+
413
+ // allocate branch nodes in multiples of 64 bytes to reduce allocator stress
414
+ // with different sizes and reduce reallocations of nodes
415
+ static constexpr size_t getBranchNodeSize(int numChilds) {
416
+ return (sizeof(BranchNode) + size_t(numChilds) * sizeof(NodePtr) + 63) &
417
+ ~size_t(63);
418
+ };
419
+
420
+ static BranchNode* createBranchingNode(int numChilds) {
421
+ BranchNode* branch =
422
+ (BranchNode*)::operator new(getBranchNodeSize(numChilds));
423
+ branch->occupation = 0;
424
+ return branch;
425
+ }
426
+
427
+ static void destroyBranchingNode(void* innerNode) {
428
+ ::operator delete(innerNode);
429
+ }
430
+
431
+ static BranchNode* addChildToBranchNode(BranchNode* branch, uint8_t hashValue,
432
+ int location) {
433
+ int rightChilds = branch->occupation.num_set_after(hashValue);
434
+ assert(rightChilds + location == branch->occupation.num_set());
435
+
436
+ size_t newSize = getBranchNodeSize(location + rightChilds + 1);
437
+ size_t rightSize = rightChilds * sizeof(NodePtr);
438
+
439
+ if (newSize == getBranchNodeSize(location + rightChilds)) {
440
+ memmove(branch->childPtr(location + 1), branch->childPtr(location),
441
+ rightSize);
442
+
443
+ return branch;
444
+ }
445
+
446
+ BranchNode* newBranch = (BranchNode*)::operator new(newSize);
447
+ // copy the header plus the pointers left of the insertion index into the
448
+ // new storage
449
+ size_t leftSize = sizeof(BranchNode) + size_t(location) * sizeof(NodePtr);
450
+
451
+ memcpy(newBranch, branch, leftSize);
452
+ memcpy(newBranch->childPtr(location + 1), branch->childPtr(location),
453
+ rightSize);
454
+
455
+ destroyBranchingNode(branch);
456
+
457
+ return newBranch;
458
+ }
459
+
460
+ template <int SizeClass1, int SizeClass2>
461
+ static void mergeIntoLeaf(InnerLeaf<SizeClass1>* leaf,
462
+ InnerLeaf<SizeClass2>* mergeLeaf, int hashPos) {
463
+ for (int i = 0; i < mergeLeaf->size; ++i)
464
+ leaf->insert_entry(compute_hash(mergeLeaf->entries[i].key()), hashPos,
465
+ mergeLeaf->entries[i]);
466
+ }
467
+
468
+ template <int SizeClass>
469
+ static void mergeIntoLeaf(InnerLeaf<SizeClass>* leaf, int hashPos,
470
+ NodePtr mergeNode) {
471
+ switch (mergeNode.getType()) {
472
+ case kListLeaf: {
473
+ ListLeaf* mergeLeaf = mergeNode.getListLeaf();
474
+ leaf->insert_entry(compute_hash(mergeLeaf->first.entry.key()), hashPos,
475
+ mergeLeaf->first.entry);
476
+ ListNode* iter = mergeLeaf->first.next;
477
+ while (iter != nullptr) {
478
+ ListNode* next = iter->next;
479
+ leaf->insert_entry(compute_hash(iter->entry.key()), hashPos,
480
+ iter->entry);
481
+ delete iter;
482
+ iter = next;
483
+ }
484
+ break;
485
+ }
486
+ case kInnerLeafSizeClass1:
487
+ mergeIntoLeaf(leaf, mergeNode.getInnerLeafSizeClass1(), hashPos);
488
+ delete mergeNode.getInnerLeafSizeClass1();
489
+ break;
490
+ case kInnerLeafSizeClass2:
491
+ mergeIntoLeaf(leaf, mergeNode.getInnerLeafSizeClass2(), hashPos);
492
+ delete mergeNode.getInnerLeafSizeClass2();
493
+ break;
494
+ case kInnerLeafSizeClass3:
495
+ mergeIntoLeaf(leaf, mergeNode.getInnerLeafSizeClass3(), hashPos);
496
+ delete mergeNode.getInnerLeafSizeClass3();
497
+ break;
498
+ case kInnerLeafSizeClass4:
499
+ mergeIntoLeaf(leaf, mergeNode.getInnerLeafSizeClass4(), hashPos);
500
+ delete mergeNode.getInnerLeafSizeClass4();
501
+ break;
502
+ default:
503
+ break;
504
+ }
505
+ }
506
+
507
+ template <int SizeClass1, int SizeClass2>
508
+ static HighsHashTableEntry<K, V>* findCommonInLeaf(
509
+ InnerLeaf<SizeClass1>* leaf1, InnerLeaf<SizeClass2>* leaf2, int hashPos) {
510
+ uint64_t matchMask = leaf1->occupation & leaf2->occupation;
511
+ if (matchMask == 0) return nullptr;
512
+
513
+ int offset1 = -1;
514
+ int offset2 = -1;
515
+ while (matchMask) {
516
+ int pos = HighsHashHelpers::log2i(matchMask);
517
+ matchMask ^= (uint64_t{1} << pos);
518
+
519
+ int i =
520
+ leaf1->occupation.num_set_until(static_cast<uint8_t>(pos)) + offset1;
521
+ while (get_first_chunk16(leaf1->hashes[i]) != pos) {
522
+ ++i;
523
+ ++offset1;
524
+ }
525
+
526
+ int j =
527
+ leaf2->occupation.num_set_until(static_cast<uint8_t>(pos)) + offset2;
528
+ while (get_first_chunk16(leaf2->hashes[j]) != pos) {
529
+ ++j;
530
+ ++offset2;
531
+ }
532
+
533
+ while (true) {
534
+ if (leaf1->hashes[i] > leaf2->hashes[j]) {
535
+ ++i;
536
+ if (i == leaf1->size || get_first_chunk16(leaf1->hashes[i]) != pos)
537
+ break;
538
+ } else if (leaf2->hashes[j] > leaf1->hashes[i]) {
539
+ ++j;
540
+ if (j == leaf2->size || get_first_chunk16(leaf2->hashes[j]) != pos)
541
+ break;
542
+ } else {
543
+ if (leaf1->entries[i].key() == leaf2->entries[j].key())
544
+ return &leaf1->entries[i];
545
+
546
+ ++i;
547
+ if (i == leaf1->size || get_first_chunk16(leaf1->hashes[i]) != pos)
548
+ break;
549
+ ++j;
550
+ if (j == leaf2->size || get_first_chunk16(leaf2->hashes[j]) != pos)
551
+ break;
552
+ }
553
+ };
554
+ }
555
+
556
+ return nullptr;
557
+ }
558
+
559
+ template <int SizeClass>
560
+ static HighsHashTableEntry<K, V>* findCommonInLeaf(InnerLeaf<SizeClass>* leaf,
561
+ NodePtr n2, int hashPos) {
562
+ switch (n2.getType()) {
563
+ case kInnerLeafSizeClass1:
564
+ return findCommonInLeaf(leaf, n2.getInnerLeafSizeClass1(), hashPos);
565
+ case kInnerLeafSizeClass2:
566
+ return findCommonInLeaf(leaf, n2.getInnerLeafSizeClass2(), hashPos);
567
+ case kInnerLeafSizeClass3:
568
+ return findCommonInLeaf(leaf, n2.getInnerLeafSizeClass3(), hashPos);
569
+ case kInnerLeafSizeClass4:
570
+ return findCommonInLeaf(leaf, n2.getInnerLeafSizeClass4(), hashPos);
571
+ case kBranchNode: {
572
+ BranchNode* branch = n2.getBranchNode();
573
+ uint64_t matchMask = branch->occupation & leaf->occupation;
574
+
575
+ int offset = -1;
576
+ while (matchMask) {
577
+ int pos = HighsHashHelpers::log2i(matchMask);
578
+ matchMask ^= (uint64_t{1} << pos);
579
+
580
+ int i = leaf->occupation.num_set_until(static_cast<uint8_t>(pos)) +
581
+ offset;
582
+ while (get_first_chunk16(leaf->hashes[i]) != pos) {
583
+ ++i;
584
+ ++offset;
585
+ }
586
+
587
+ int j =
588
+ branch->occupation.num_set_until(static_cast<uint8_t>(pos)) - 1;
589
+
590
+ do {
591
+ if (find_recurse(branch->child(j),
592
+ compute_hash(leaf->entries[i].key()), hashPos + 1,
593
+ leaf->entries[i].key()))
594
+ return &leaf->entries[i];
595
+ ++i;
596
+ } while (i < leaf->size && get_first_chunk16(leaf->hashes[i]) == pos);
597
+ }
598
+ break;
599
+ }
600
+ default:
601
+ break;
602
+ }
603
+
604
+ return nullptr;
605
+ }
606
+
607
+ static NodePtr removeChildFromBranchNode(BranchNode* branch, int location,
608
+ uint64_t hash, int hashPos) {
609
+ NodePtr newNode;
610
+ int newNumChild = branch->occupation.num_set();
611
+
612
+ // first check if we might be able to merge all children into one new leaf
613
+ // based on the node numbers and assuming all of them might be in the
614
+ // smallest size class
615
+ if (newNumChild * InnerLeaf<1>::capacity() <= kLeafBurstThreshold) {
616
+ // since we have a good chance of merging we now check the actual size
617
+ // classes to see if that yields a number of entries at most the burst
618
+ // threshold
619
+ int childEntries = 0;
620
+ for (int i = 0; i <= newNumChild; ++i) {
621
+ childEntries += branch->child(i).numEntriesEstimate();
622
+ if (childEntries > kLeafBurstThreshold) break;
623
+ }
624
+
625
+ if (childEntries < kLeafBurstThreshold) {
626
+ // create a new merged inner leaf node containing all entries of
627
+ // children first recompute the number of entries, but this time access
628
+ // each child to get the actual number of entries needed and determine
629
+ // this nodes size class since before we estimated the number of child
630
+ // entries from the capacities of our child leaf node types which are
631
+ // stored in the branch nodes pointers directly and avoid unnecessary
632
+ // accesses of nodes that are not in cache.
633
+ childEntries = 0;
634
+ for (int i = 0; i <= newNumChild; ++i)
635
+ childEntries += branch->child(i).numEntries();
636
+
637
+ // check again if we exceed due to the extremely unlikely case
638
+ // of having less than 5 list nodes with together more than 30 entries
639
+ // as list nodes are only created in the last depth level
640
+ if (childEntries < kLeafBurstThreshold) {
641
+ switch (entries_to_size_class(childEntries)) {
642
+ case 1: {
643
+ InnerLeaf<1>* newLeafSize1 = new InnerLeaf<1>;
644
+ newNode = newLeafSize1;
645
+ for (int i = 0; i <= newNumChild; ++i)
646
+ mergeIntoLeaf(newLeafSize1, hashPos, branch->child(i));
647
+ break;
648
+ }
649
+ case 2: {
650
+ InnerLeaf<2>* newLeafSize2 = new InnerLeaf<2>;
651
+ newNode = newLeafSize2;
652
+ for (int i = 0; i <= newNumChild; ++i)
653
+ mergeIntoLeaf(newLeafSize2, hashPos, branch->child(i));
654
+ break;
655
+ }
656
+ case 3: {
657
+ InnerLeaf<3>* newLeafSize3 = new InnerLeaf<3>;
658
+ newNode = newLeafSize3;
659
+ for (int i = 0; i <= newNumChild; ++i)
660
+ mergeIntoLeaf(newLeafSize3, hashPos, branch->child(i));
661
+ break;
662
+ }
663
+ case 4: {
664
+ InnerLeaf<4>* newLeafSize4 = new InnerLeaf<4>;
665
+ newNode = newLeafSize4;
666
+ for (int i = 0; i <= newNumChild; ++i)
667
+ mergeIntoLeaf(newLeafSize4, hashPos, branch->child(i));
668
+ break;
669
+ }
670
+ default:
671
+ // Unexpected result from 'entries_to_size_class'
672
+ assert(false);
673
+ }
674
+
675
+ destroyBranchingNode(branch);
676
+ return newNode;
677
+ }
678
+ }
679
+ }
680
+
681
+ size_t newSize = getBranchNodeSize(newNumChild);
682
+ size_t rightSize = (newNumChild - location) * sizeof(NodePtr);
683
+ if (newSize == getBranchNodeSize(newNumChild + 1)) {
684
+ // allocated size class is the same, so we do not allocate a new node
685
+ memmove(branch->childPtr(location), branch->childPtr(location + 1),
686
+ rightSize);
687
+ newNode = branch;
688
+ } else {
689
+ // allocated size class changed, so we allocate a smaller branch node
690
+ BranchNode* compressedBranch = (BranchNode*)::operator new(newSize);
691
+ newNode = compressedBranch;
692
+
693
+ size_t leftSize = sizeof(BranchNode) + size_t(location) * sizeof(NodePtr);
694
+ memcpy(compressedBranch, branch, leftSize);
695
+ memcpy(compressedBranch->childPtr(location),
696
+ branch->childPtr(location + 1), rightSize);
697
+
698
+ destroyBranchingNode(branch);
699
+ }
700
+
701
+ return newNode;
702
+ }
703
+
704
+ NodePtr root;
705
+
706
+ template <int SizeClass>
707
+ static std::pair<ValueType*, bool> insert_into_leaf(
708
+ NodePtr* insertNode, InnerLeaf<SizeClass>* leaf, uint64_t hash,
709
+ int hashPos, HighsHashTableEntry<K, V>& entry) {
710
+ if (leaf->size == InnerLeaf<SizeClass>::capacity()) {
711
+ auto existingEntry = leaf->find_entry(hash, hashPos, entry.key());
712
+ if (existingEntry) return std::make_pair(existingEntry, false);
713
+
714
+ InnerLeaf<SizeClass + 1>* newLeaf =
715
+ new InnerLeaf<SizeClass + 1>(std::move(*leaf));
716
+ *insertNode = newLeaf;
717
+ delete leaf;
718
+ return newLeaf->insert_entry(hash, hashPos, entry);
719
+ }
720
+
721
+ return leaf->insert_entry(hash, hashPos, entry);
722
+ }
723
+
724
+ static std::pair<ValueType*, bool> insert_recurse(
725
+ NodePtr* insertNode, uint64_t hash, int hashPos,
726
+ HighsHashTableEntry<K, V>& entry) {
727
+ switch (insertNode->getType()) {
728
+ case kEmpty: {
729
+ if (hashPos == kMaxDepth) {
730
+ ListLeaf* leaf = new ListLeaf(std::move(entry));
731
+ *insertNode = leaf;
732
+ return std::make_pair(&leaf->first.entry.value(), true);
733
+ } else {
734
+ InnerLeaf<1>* leaf = new InnerLeaf<1>;
735
+ *insertNode = leaf;
736
+ return leaf->insert_entry(hash, hashPos, entry);
737
+ }
738
+ }
739
+ case kListLeaf: {
740
+ ListLeaf* leaf = insertNode->getListLeaf();
741
+ ListNode* iter = &leaf->first;
742
+ while (true) {
743
+ // check for existing key
744
+ if (iter->entry.key() == entry.key())
745
+ return std::make_pair(&iter->entry.value(), false);
746
+
747
+ if (iter->next == nullptr) {
748
+ // reached the end of the list and key is not duplicate, so insert
749
+ iter->next = new ListNode(std::move(entry));
750
+ ++leaf->count;
751
+ return std::make_pair(&iter->next->entry.value(), true);
752
+ }
753
+ iter = iter->next;
754
+ }
755
+
756
+ break;
757
+ }
758
+ case kInnerLeafSizeClass1:
759
+ return insert_into_leaf(insertNode,
760
+ insertNode->getInnerLeafSizeClass1(), hash,
761
+ hashPos, entry);
762
+ break;
763
+ case kInnerLeafSizeClass2:
764
+ return insert_into_leaf(insertNode,
765
+ insertNode->getInnerLeafSizeClass2(), hash,
766
+ hashPos, entry);
767
+ break;
768
+ case kInnerLeafSizeClass3:
769
+ return insert_into_leaf(insertNode,
770
+ insertNode->getInnerLeafSizeClass3(), hash,
771
+ hashPos, entry);
772
+ break;
773
+ case kInnerLeafSizeClass4: {
774
+ InnerLeaf<4>* leaf = insertNode->getInnerLeafSizeClass4();
775
+ if (leaf->size < InnerLeaf<4>::capacity())
776
+ return leaf->insert_entry(hash, hashPos, entry);
777
+
778
+ auto existingEntry = leaf->find_entry(hash, hashPos, entry.key());
779
+ if (existingEntry) return std::make_pair(existingEntry, false);
780
+ Occupation occupation = leaf->occupation;
781
+
782
+ uint8_t hashChunk = get_hash_chunk(hash, hashPos);
783
+ occupation.set(hashChunk);
784
+
785
+ int branchSize = occupation.num_set();
786
+
787
+ BranchNode* branch = createBranchingNode(branchSize);
788
+ *insertNode = branch;
789
+ branch->occupation = occupation;
790
+
791
+ if (hashPos + 1 == kMaxDepth) {
792
+ for (int i = 0; i < branchSize; ++i) branch->child(i) = nullptr;
793
+
794
+ for (int i = 0; i < leaf->size; ++i) {
795
+ int pos =
796
+ occupation.num_set_until(get_first_chunk16(leaf->hashes[i])) -
797
+ 1;
798
+ if (branch->child(pos).getType() == kEmpty)
799
+ branch->child(pos) = new ListLeaf(std::move(leaf->entries[i]));
800
+ else {
801
+ ListLeaf* listLeaf = branch->child(pos).getListLeaf();
802
+ ListNode* newNode = new ListNode(std::move(listLeaf->first));
803
+ listLeaf->first.next = newNode;
804
+ listLeaf->first.entry = std::move(leaf->entries[i]);
805
+ ++listLeaf->count;
806
+ }
807
+ }
808
+
809
+ delete leaf;
810
+
811
+ ListLeaf* listLeaf;
812
+
813
+ int pos = occupation.num_set_until(get_hash_chunk(hash, hashPos)) - 1;
814
+ if (branch->child(pos).getType() == kEmpty) {
815
+ listLeaf = new ListLeaf(std::move(entry));
816
+ branch->child(pos) = listLeaf;
817
+ } else {
818
+ listLeaf = branch->child(pos).getListLeaf();
819
+ ListNode* newNode = new ListNode(std::move(listLeaf->first));
820
+ listLeaf->first.next = newNode;
821
+ listLeaf->first.entry = std::move(entry);
822
+ ++listLeaf->count;
823
+ }
824
+
825
+ return std::make_pair(&listLeaf->first.entry.value(), true);
826
+ }
827
+
828
+ if (branchSize > 1) {
829
+ // maxsize in one bucket = number of items - (num buckets-1)
830
+ // since each bucket has at least 1 item the largest one can only
831
+ // have all remaining ones After adding the item: If it does not
832
+ // collide
833
+ int maxEntriesPerLeaf = 2 + leaf->size - branchSize;
834
+
835
+ if (maxEntriesPerLeaf <= InnerLeaf<1>::capacity()) {
836
+ // all items can go into the smallest leaf size
837
+ for (int i = 0; i < branchSize; ++i)
838
+ branch->child(i) = new InnerLeaf<1>;
839
+
840
+ for (int i = 0; i < leaf->size; ++i) {
841
+ int pos =
842
+ occupation.num_set_until(get_first_chunk16(leaf->hashes[i])) -
843
+ 1;
844
+ branch->child(pos).getInnerLeafSizeClass1()->insert_entry(
845
+ compute_hash(leaf->entries[i].key()), hashPos + 1,
846
+ leaf->entries[i]);
847
+ }
848
+
849
+ delete leaf;
850
+
851
+ int pos =
852
+ occupation.num_set_until(get_hash_chunk(hash, hashPos)) - 1;
853
+ return branch->child(pos).getInnerLeafSizeClass1()->insert_entry(
854
+ hash, hashPos + 1, entry);
855
+ } else {
856
+ // there are many collisions, determine the exact sizes first
857
+ std::array<uint8_t, InnerLeaf<4>::capacity() + 1> sizes = {};
858
+ sizes[occupation.num_set_until(hashChunk) - 1] += 1;
859
+ for (int i = 0; i < leaf->size; ++i) {
860
+ int pos =
861
+ occupation.num_set_until(get_first_chunk16(leaf->hashes[i])) -
862
+ 1;
863
+ sizes[pos] += 1;
864
+ }
865
+
866
+ for (int i = 0; i < branchSize; ++i) {
867
+ switch (entries_to_size_class(sizes[i])) {
868
+ case 1:
869
+ branch->child(i) = new InnerLeaf<1>;
870
+ break;
871
+ case 2:
872
+ branch->child(i) = new InnerLeaf<2>;
873
+ break;
874
+ case 3:
875
+ branch->child(i) = new InnerLeaf<3>;
876
+ break;
877
+ case 4:
878
+ branch->child(i) = new InnerLeaf<4>;
879
+ break;
880
+ default:
881
+ // Unexpected result from 'entries_to_size_class'
882
+ assert(false);
883
+ }
884
+ }
885
+
886
+ for (int i = 0; i < leaf->size; ++i) {
887
+ int pos =
888
+ occupation.num_set_until(get_first_chunk16(leaf->hashes[i])) -
889
+ 1;
890
+
891
+ switch (branch->child(pos).getType()) {
892
+ case kInnerLeafSizeClass1:
893
+ branch->child(pos).getInnerLeafSizeClass1()->insert_entry(
894
+ compute_hash(leaf->entries[i].key()), hashPos + 1,
895
+ leaf->entries[i]);
896
+ break;
897
+ case kInnerLeafSizeClass2:
898
+ branch->child(pos).getInnerLeafSizeClass2()->insert_entry(
899
+ compute_hash(leaf->entries[i].key()), hashPos + 1,
900
+ leaf->entries[i]);
901
+ break;
902
+ case kInnerLeafSizeClass3:
903
+ branch->child(pos).getInnerLeafSizeClass3()->insert_entry(
904
+ compute_hash(leaf->entries[i].key()), hashPos + 1,
905
+ leaf->entries[i]);
906
+ break;
907
+ case kInnerLeafSizeClass4:
908
+ branch->child(pos).getInnerLeafSizeClass4()->insert_entry(
909
+ compute_hash(leaf->entries[i].key()), hashPos + 1,
910
+ leaf->entries[i]);
911
+ break;
912
+ default:
913
+ break;
914
+ }
915
+ }
916
+ }
917
+
918
+ delete leaf;
919
+
920
+ int pos = occupation.num_set_until(hashChunk) - 1;
921
+ insertNode = branch->childPtr(pos);
922
+ ++hashPos;
923
+ } else {
924
+ // extremely unlikely that the new branch node only gets one
925
+ // child in that case create it and defer the insertion into
926
+ // the next depth
927
+ branch->child(0) = leaf;
928
+ insertNode = branch->childPtr(0);
929
+ ++hashPos;
930
+ leaf->rehash(hashPos);
931
+ }
932
+
933
+ break;
934
+ }
935
+ case kBranchNode: {
936
+ BranchNode* branch = insertNode->getBranchNode();
937
+
938
+ int location =
939
+ branch->occupation.num_set_until(get_hash_chunk(hash, hashPos));
940
+
941
+ if (branch->occupation.test(get_hash_chunk(hash, hashPos))) {
942
+ --location;
943
+ } else {
944
+ branch = addChildToBranchNode(branch, get_hash_chunk(hash, hashPos),
945
+ location);
946
+
947
+ branch->child(location) = nullptr;
948
+ branch->occupation.set(get_hash_chunk(hash, hashPos));
949
+ }
950
+
951
+ *insertNode = branch;
952
+ insertNode = branch->childPtr(location);
953
+ ++hashPos;
954
+ }
955
+ }
956
+
957
+ return insert_recurse(insertNode, hash, hashPos, entry);
958
+ }
959
+
960
+ static void erase_recurse(NodePtr* erase_node, uint64_t hash, int hashPos,
961
+ const K& key) {
962
+ switch (erase_node->getType()) {
963
+ case kEmpty: {
964
+ return;
965
+ }
966
+ case kListLeaf: {
967
+ ListLeaf* leaf = erase_node->getListLeaf();
968
+
969
+ // check for existing key
970
+ ListNode* iter = &leaf->first;
971
+
972
+ do {
973
+ ListNode* next = iter->next;
974
+ if (iter->entry.key() == key) {
975
+ // key found, decrease count
976
+ --leaf->count;
977
+ if (next != nullptr) {
978
+ // if we have a next node after replace the entry in iter by
979
+ // moving that node into it
980
+ *iter = std::move(*next);
981
+ // delete memory of that node
982
+ delete next;
983
+ }
984
+
985
+ break;
986
+ }
987
+
988
+ iter = next;
989
+ } while (iter != nullptr);
990
+
991
+ if (leaf->count == 0) {
992
+ delete leaf;
993
+ *erase_node = nullptr;
994
+ }
995
+
996
+ return;
997
+ }
998
+ case kInnerLeafSizeClass1: {
999
+ InnerLeaf<1>* leaf = erase_node->getInnerLeafSizeClass1();
1000
+ if (leaf->erase_entry(hash, hashPos, key)) {
1001
+ if (leaf->size == 0) {
1002
+ delete leaf;
1003
+ *erase_node = nullptr;
1004
+ }
1005
+ }
1006
+
1007
+ return;
1008
+ }
1009
+ case kInnerLeafSizeClass2: {
1010
+ InnerLeaf<2>* leaf = erase_node->getInnerLeafSizeClass2();
1011
+
1012
+ if (leaf->erase_entry(hash, hashPos, key)) {
1013
+ if (leaf->size == InnerLeaf<1>::capacity()) {
1014
+ InnerLeaf<1>* newLeaf = new InnerLeaf<1>(std::move(*leaf));
1015
+ *erase_node = newLeaf;
1016
+ delete leaf;
1017
+ }
1018
+ }
1019
+
1020
+ return;
1021
+ }
1022
+ case kInnerLeafSizeClass3: {
1023
+ InnerLeaf<3>* leaf = erase_node->getInnerLeafSizeClass3();
1024
+
1025
+ if (leaf->erase_entry(hash, hashPos, key)) {
1026
+ if (leaf->size == InnerLeaf<2>::capacity()) {
1027
+ InnerLeaf<2>* newLeaf = new InnerLeaf<2>(std::move(*leaf));
1028
+ *erase_node = newLeaf;
1029
+ delete leaf;
1030
+ }
1031
+ }
1032
+
1033
+ return;
1034
+ }
1035
+ case kInnerLeafSizeClass4: {
1036
+ InnerLeaf<4>* leaf = erase_node->getInnerLeafSizeClass4();
1037
+
1038
+ if (leaf->erase_entry(hash, hashPos, key)) {
1039
+ if (leaf->size == InnerLeaf<3>::capacity()) {
1040
+ InnerLeaf<3>* newLeaf = new InnerLeaf<3>(std::move(*leaf));
1041
+ *erase_node = newLeaf;
1042
+ delete leaf;
1043
+ }
1044
+ }
1045
+
1046
+ return;
1047
+ }
1048
+ case kBranchNode: {
1049
+ BranchNode* branch = erase_node->getBranchNode();
1050
+
1051
+ if (!branch->occupation.test(get_hash_chunk(hash, hashPos))) return;
1052
+
1053
+ int location =
1054
+ branch->occupation.num_set_until(get_hash_chunk(hash, hashPos)) - 1;
1055
+ erase_recurse(branch->childPtr(location), hash, hashPos + 1, key);
1056
+
1057
+ if (branch->child(location).getType() != kEmpty) return;
1058
+
1059
+ branch->occupation.flip(get_hash_chunk(hash, hashPos));
1060
+
1061
+ *erase_node =
1062
+ removeChildFromBranchNode(branch, location, hash, hashPos);
1063
+ break;
1064
+ }
1065
+ }
1066
+ }
1067
+
1068
+ static const ValueType* find_recurse(NodePtr node, uint64_t hash, int hashPos,
1069
+ const K& key) {
1070
+ int startPos = hashPos;
1071
+ switch (node.getType()) {
1072
+ case kEmpty:
1073
+ return nullptr;
1074
+ case kListLeaf: {
1075
+ ListLeaf* leaf = node.getListLeaf();
1076
+ ListNode* iter = &leaf->first;
1077
+ do {
1078
+ if (iter->entry.key() == key) return &iter->entry.value();
1079
+ iter = iter->next;
1080
+ } while (iter != nullptr);
1081
+ return nullptr;
1082
+ }
1083
+ case kInnerLeafSizeClass1: {
1084
+ InnerLeaf<1>* leaf = node.getInnerLeafSizeClass1();
1085
+ return leaf->find_entry(hash, hashPos, key);
1086
+ }
1087
+ case kInnerLeafSizeClass2: {
1088
+ InnerLeaf<2>* leaf = node.getInnerLeafSizeClass2();
1089
+ return leaf->find_entry(hash, hashPos, key);
1090
+ }
1091
+ case kInnerLeafSizeClass3: {
1092
+ InnerLeaf<3>* leaf = node.getInnerLeafSizeClass3();
1093
+ return leaf->find_entry(hash, hashPos, key);
1094
+ }
1095
+ case kInnerLeafSizeClass4: {
1096
+ InnerLeaf<4>* leaf = node.getInnerLeafSizeClass4();
1097
+ return leaf->find_entry(hash, hashPos, key);
1098
+ }
1099
+ case kBranchNode: {
1100
+ BranchNode* branch = node.getBranchNode();
1101
+ if (!branch->occupation.test(get_hash_chunk(hash, hashPos)))
1102
+ return nullptr;
1103
+ int location =
1104
+ branch->occupation.num_set_until(get_hash_chunk(hash, hashPos)) - 1;
1105
+ node = branch->child(location);
1106
+ ++hashPos;
1107
+ }
1108
+ }
1109
+
1110
+ assert(hashPos > startPos);
1111
+
1112
+ return find_recurse(node, hash, hashPos, key);
1113
+ }
1114
+
1115
+ static const HighsHashTableEntry<K, V>* find_common_recurse(NodePtr n1,
1116
+ NodePtr n2,
1117
+ int hashPos) {
1118
+ if (n1.getType() > n2.getType()) std::swap(n1, n2);
1119
+
1120
+ switch (n1.getType()) {
1121
+ case kEmpty:
1122
+ return nullptr;
1123
+ case kListLeaf: {
1124
+ ListLeaf* leaf = n1.getListLeaf();
1125
+ ListNode* iter = &leaf->first;
1126
+ do {
1127
+ if (find_recurse(n2, compute_hash(iter->entry.key()), hashPos,
1128
+ iter->entry.key()))
1129
+ return &iter->entry;
1130
+ iter = iter->next;
1131
+ } while (iter != nullptr);
1132
+ return nullptr;
1133
+ }
1134
+ case kInnerLeafSizeClass1:
1135
+ return findCommonInLeaf(n1.getInnerLeafSizeClass1(), n2, hashPos);
1136
+ case kInnerLeafSizeClass2:
1137
+ return findCommonInLeaf(n1.getInnerLeafSizeClass2(), n2, hashPos);
1138
+ case kInnerLeafSizeClass3:
1139
+ return findCommonInLeaf(n1.getInnerLeafSizeClass3(), n2, hashPos);
1140
+ case kInnerLeafSizeClass4:
1141
+ return findCommonInLeaf(n1.getInnerLeafSizeClass4(), n2, hashPos);
1142
+ case kBranchNode: {
1143
+ BranchNode* branch1 = n1.getBranchNode();
1144
+ BranchNode* branch2 = n2.getBranchNode();
1145
+
1146
+ uint64_t matchMask = branch1->occupation & branch2->occupation;
1147
+
1148
+ while (matchMask) {
1149
+ int pos = HighsHashHelpers::log2i(matchMask);
1150
+ assert((branch1->occupation >> pos) & 1);
1151
+ assert((branch2->occupation >> pos) & 1);
1152
+ assert((matchMask >> pos) & 1);
1153
+
1154
+ matchMask ^= (uint64_t{1} << pos);
1155
+
1156
+ assert(((matchMask >> pos) & 1) == 0);
1157
+
1158
+ int location1 =
1159
+ branch1->occupation.num_set_until(static_cast<uint8_t>(pos)) - 1;
1160
+ int location2 =
1161
+ branch2->occupation.num_set_until(static_cast<uint8_t>(pos)) - 1;
1162
+
1163
+ const HighsHashTableEntry<K, V>* match =
1164
+ find_common_recurse(branch1->child(location1),
1165
+ branch2->child(location2), hashPos + 1);
1166
+ if (match != nullptr) return match;
1167
+ }
1168
+
1169
+ return nullptr;
1170
+ }
1171
+ default:
1172
+ throw std::logic_error("Unexpected type in hash tree");
1173
+ }
1174
+ }
1175
+
1176
+ static void destroy_recurse(NodePtr node) {
1177
+ switch (node.getType()) {
1178
+ case kEmpty:
1179
+ break;
1180
+ case kListLeaf: {
1181
+ ListLeaf* leaf = node.getListLeaf();
1182
+ ListNode* iter = leaf->first.next;
1183
+ delete leaf;
1184
+ while (iter != nullptr) {
1185
+ ListNode* next = iter->next;
1186
+ delete iter;
1187
+ iter = next;
1188
+ }
1189
+
1190
+ break;
1191
+ }
1192
+ case kInnerLeafSizeClass1:
1193
+ delete node.getInnerLeafSizeClass1();
1194
+ break;
1195
+ case kInnerLeafSizeClass2:
1196
+ delete node.getInnerLeafSizeClass2();
1197
+ break;
1198
+ case kInnerLeafSizeClass3:
1199
+ delete node.getInnerLeafSizeClass3();
1200
+ break;
1201
+ case kInnerLeafSizeClass4:
1202
+ delete node.getInnerLeafSizeClass4();
1203
+ break;
1204
+ case kBranchNode: {
1205
+ BranchNode* branch = node.getBranchNode();
1206
+ int size = branch->occupation.num_set();
1207
+
1208
+ for (int i = 0; i < size; ++i) destroy_recurse(branch->child(i));
1209
+
1210
+ destroyBranchingNode(branch);
1211
+ }
1212
+ }
1213
+ }
1214
+
1215
+ static NodePtr copy_recurse(NodePtr node) {
1216
+ switch (node.getType()) {
1217
+ case kEmpty:
1218
+ throw std::logic_error("Unexpected node type in empty in hash tree");
1219
+ case kListLeaf: {
1220
+ ListLeaf* leaf = node.getListLeaf();
1221
+
1222
+ ListLeaf* copyLeaf = new ListLeaf(*leaf);
1223
+
1224
+ ListNode* iter = &leaf->first;
1225
+ ListNode* copyIter = &copyLeaf->first;
1226
+ do {
1227
+ copyIter->next = new ListNode(*iter->next);
1228
+ iter = iter->next;
1229
+ copyIter = copyIter->next;
1230
+ } while (iter->next != nullptr);
1231
+
1232
+ return copyLeaf;
1233
+ }
1234
+ case kInnerLeafSizeClass1: {
1235
+ InnerLeaf<1>* leaf = node.getInnerLeafSizeClass1();
1236
+ return new InnerLeaf<1>(*leaf);
1237
+ }
1238
+ case kInnerLeafSizeClass2: {
1239
+ InnerLeaf<2>* leaf = node.getInnerLeafSizeClass2();
1240
+ return new InnerLeaf<2>(*leaf);
1241
+ }
1242
+ case kInnerLeafSizeClass3: {
1243
+ InnerLeaf<3>* leaf = node.getInnerLeafSizeClass3();
1244
+ return new InnerLeaf<3>(*leaf);
1245
+ }
1246
+ case kInnerLeafSizeClass4: {
1247
+ InnerLeaf<4>* leaf = node.getInnerLeafSizeClass4();
1248
+ return new InnerLeaf<4>(*leaf);
1249
+ }
1250
+ case kBranchNode: {
1251
+ BranchNode* branch = node.getBranchNode();
1252
+ int size = branch->occupation.num_set();
1253
+ BranchNode* newBranch =
1254
+ (BranchNode*)::operator new(getBranchNodeSize(size));
1255
+ newBranch->occupation = branch->occupation;
1256
+ for (int i = 0; i < size; ++i)
1257
+ newBranch->child(i) = copy_recurse(branch->child(i));
1258
+
1259
+ return newBranch;
1260
+ }
1261
+ default:
1262
+ throw std::logic_error("Unexpected type in hash tree");
1263
+ }
1264
+ }
1265
+
1266
+ template <typename R, typename F,
1267
+ typename std::enable_if<std::is_void<R>::value, int>::type = 0>
1268
+ static void for_each_recurse(NodePtr node, F&& f) {
1269
+ switch (node.getType()) {
1270
+ case kEmpty:
1271
+ break;
1272
+ case kListLeaf: {
1273
+ ListLeaf* leaf = node.getListLeaf();
1274
+ ListNode* iter = &leaf->first;
1275
+ do {
1276
+ iter->entry.forward(f);
1277
+ iter = iter->next;
1278
+ } while (iter != nullptr);
1279
+ break;
1280
+ }
1281
+ case kInnerLeafSizeClass1: {
1282
+ InnerLeaf<1>* leaf = node.getInnerLeafSizeClass1();
1283
+ for (int i = 0; i < leaf->size; ++i) leaf->entries[i].forward(f);
1284
+
1285
+ break;
1286
+ }
1287
+ case kInnerLeafSizeClass2: {
1288
+ InnerLeaf<2>* leaf = node.getInnerLeafSizeClass2();
1289
+ for (int i = 0; i < leaf->size; ++i) leaf->entries[i].forward(f);
1290
+
1291
+ break;
1292
+ }
1293
+ case kInnerLeafSizeClass3: {
1294
+ InnerLeaf<3>* leaf = node.getInnerLeafSizeClass3();
1295
+ for (int i = 0; i < leaf->size; ++i) leaf->entries[i].forward(f);
1296
+
1297
+ break;
1298
+ }
1299
+ case kInnerLeafSizeClass4: {
1300
+ InnerLeaf<4>* leaf = node.getInnerLeafSizeClass4();
1301
+ for (int i = 0; i < leaf->size; ++i) leaf->entries[i].forward(f);
1302
+
1303
+ break;
1304
+ }
1305
+ case kBranchNode: {
1306
+ BranchNode* branch = node.getBranchNode();
1307
+ int size = branch->occupation.num_set();
1308
+
1309
+ for (int i = 0; i < size; ++i) for_each_recurse<R>(branch->child(i), f);
1310
+ }
1311
+ }
1312
+ }
1313
+
1314
+ template <typename R, typename F,
1315
+ typename std::enable_if<!std::is_void<R>::value, int>::type = 0>
1316
+ static R for_each_recurse(NodePtr node, F&& f) {
1317
+ switch (node.getType()) {
1318
+ case kEmpty:
1319
+ break;
1320
+ case kListLeaf: {
1321
+ ListLeaf* leaf = node.getListLeaf();
1322
+ ListNode* iter = &leaf->first;
1323
+ do {
1324
+ auto x = iter->entry.forward(f);
1325
+ if (x) return x;
1326
+ iter = iter->next;
1327
+ } while (iter != nullptr);
1328
+ break;
1329
+ }
1330
+ case kInnerLeafSizeClass1: {
1331
+ InnerLeaf<1>* leaf = node.getInnerLeafSizeClass1();
1332
+ for (int i = 0; i < leaf->size; ++i) {
1333
+ auto x = leaf->entries[i].forward(f);
1334
+ if (x) return x;
1335
+ }
1336
+
1337
+ break;
1338
+ }
1339
+ case kInnerLeafSizeClass2: {
1340
+ InnerLeaf<2>* leaf = node.getInnerLeafSizeClass2();
1341
+ for (int i = 0; i < leaf->size; ++i) {
1342
+ auto x = leaf->entries[i].forward(f);
1343
+ if (x) return x;
1344
+ }
1345
+
1346
+ break;
1347
+ }
1348
+ case kInnerLeafSizeClass3: {
1349
+ InnerLeaf<3>* leaf = node.getInnerLeafSizeClass3();
1350
+ for (int i = 0; i < leaf->size; ++i) {
1351
+ auto x = leaf->entries[i].forward(f);
1352
+ if (x) return x;
1353
+ }
1354
+
1355
+ break;
1356
+ }
1357
+ case kInnerLeafSizeClass4: {
1358
+ InnerLeaf<4>* leaf = node.getInnerLeafSizeClass4();
1359
+ for (int i = 0; i < leaf->size; ++i) {
1360
+ auto x = leaf->entries[i].forward(f);
1361
+ if (x) return x;
1362
+ }
1363
+
1364
+ break;
1365
+ }
1366
+ case kBranchNode: {
1367
+ BranchNode* branch = node.getBranchNode();
1368
+ int size = branch->occupation.num_set();
1369
+
1370
+ for (int i = 0; i < size; ++i) {
1371
+ auto x = for_each_recurse<R>(branch->child(i), f);
1372
+ if (x) return x;
1373
+ }
1374
+ }
1375
+ }
1376
+
1377
+ return R();
1378
+ }
1379
+
1380
+ public:
1381
+ template <typename... Args>
1382
+ bool insert(Args&&... args) {
1383
+ HighsHashTableEntry<K, V> entry(std::forward<Args>(args)...);
1384
+ uint64_t hash = compute_hash(entry.key());
1385
+ return insert_recurse(&root, hash, 0, entry).second;
1386
+ }
1387
+
1388
+ template <typename... Args>
1389
+ std::pair<ValueType*, bool> insert_or_get(Args&&... args) {
1390
+ HighsHashTableEntry<K, V> entry(std::forward<Args>(args)...);
1391
+ uint64_t hash = compute_hash(entry.key());
1392
+ return insert_recurse(&root, hash, 0, entry);
1393
+ }
1394
+
1395
+ void erase(const K& key) {
1396
+ uint64_t hash = compute_hash(key);
1397
+
1398
+ erase_recurse(&root, hash, 0, key);
1399
+ }
1400
+
1401
+ bool contains(const K& key) const {
1402
+ uint64_t hash = compute_hash(key);
1403
+ return find_recurse(root, hash, 0, key) != nullptr;
1404
+ }
1405
+
1406
+ const ValueType* find(const K& key) const {
1407
+ uint64_t hash = compute_hash(key);
1408
+
1409
+ return find_recurse(root, hash, 0, key);
1410
+ }
1411
+
1412
+ ValueType* find(const K& key) {
1413
+ uint64_t hash = compute_hash(key);
1414
+
1415
+ return find_recurse(root, hash, 0, key);
1416
+ }
1417
+
1418
+ const HighsHashTableEntry<K, V>* find_common(
1419
+ const HighsHashTree<K, V>& other) const {
1420
+ return find_common_recurse(root, other.root, 0);
1421
+ }
1422
+
1423
+ bool empty() const { return root.getType() == kEmpty; }
1424
+
1425
+ void clear() {
1426
+ destroy_recurse(root);
1427
+ root = nullptr;
1428
+ }
1429
+
1430
+ template <typename F>
1431
+ auto for_each(F&& f) const
1432
+ -> decltype(HighsHashTableEntry<K, V>().forward(f)) {
1433
+ using R = decltype(for_each(f));
1434
+ return for_each_recurse<R>(root, f);
1435
+ }
1436
+
1437
+ HighsHashTree() = default;
1438
+
1439
+ HighsHashTree(HighsHashTree&& other) : root(other.root) {
1440
+ other.root = nullptr;
1441
+ }
1442
+
1443
+ HighsHashTree(const HighsHashTree& other) : root(copy_recurse(other.root)) {}
1444
+
1445
+ HighsHashTree& operator=(HighsHashTree&& other) {
1446
+ destroy_recurse(root);
1447
+ root = other.root;
1448
+ other.root = nullptr;
1449
+ return *this;
1450
+ }
1451
+
1452
+ HighsHashTree& operator=(const HighsHashTree& other) {
1453
+ destroy_recurse(root);
1454
+ root = copy_recurse(other.root);
1455
+ return *this;
1456
+ }
1457
+
1458
+ ~HighsHashTree() { destroy_recurse(root); }
1459
+ };
1460
+
1461
+ #endif