ruby-cbc 0.1.9

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 (303) hide show
  1. checksums.yaml +7 -0
  2. data/.gitignore +9 -0
  3. data/.rspec +2 -0
  4. data/.travis.yml +4 -0
  5. data/Gemfile +4 -0
  6. data/README.md +203 -0
  7. data/Rakefile +40 -0
  8. data/bin/console +14 -0
  9. data/bin/setup +7 -0
  10. data/ext/ruby-cbc/cbc.i +15 -0
  11. data/ext/ruby-cbc/cbc_wrap.c +4618 -0
  12. data/ext/ruby-cbc/extconf.rb +60 -0
  13. data/ext/ruby-cbc/install/bin/cbc +0 -0
  14. data/ext/ruby-cbc/install/bin/clp +0 -0
  15. data/ext/ruby-cbc/install/include/coin/CbcBranchActual.hpp +24 -0
  16. data/ext/ruby-cbc/install/include/coin/CbcBranchAllDifferent.hpp +62 -0
  17. data/ext/ruby-cbc/install/include/coin/CbcBranchBase.hpp +78 -0
  18. data/ext/ruby-cbc/install/include/coin/CbcBranchCut.hpp +183 -0
  19. data/ext/ruby-cbc/install/include/coin/CbcBranchDecision.hpp +129 -0
  20. data/ext/ruby-cbc/install/include/coin/CbcBranchDefaultDecision.hpp +100 -0
  21. data/ext/ruby-cbc/install/include/coin/CbcBranchDynamic.hpp +206 -0
  22. data/ext/ruby-cbc/install/include/coin/CbcBranchLotsize.hpp +242 -0
  23. data/ext/ruby-cbc/install/include/coin/CbcBranchToFixLots.hpp +94 -0
  24. data/ext/ruby-cbc/install/include/coin/CbcBranchingObject.hpp +236 -0
  25. data/ext/ruby-cbc/install/include/coin/CbcClique.hpp +303 -0
  26. data/ext/ruby-cbc/install/include/coin/CbcCompare.hpp +39 -0
  27. data/ext/ruby-cbc/install/include/coin/CbcCompareActual.hpp +14 -0
  28. data/ext/ruby-cbc/install/include/coin/CbcCompareBase.hpp +142 -0
  29. data/ext/ruby-cbc/install/include/coin/CbcCompareDefault.hpp +120 -0
  30. data/ext/ruby-cbc/install/include/coin/CbcCompareDepth.hpp +47 -0
  31. data/ext/ruby-cbc/install/include/coin/CbcCompareEstimate.hpp +48 -0
  32. data/ext/ruby-cbc/install/include/coin/CbcCompareObjective.hpp +49 -0
  33. data/ext/ruby-cbc/install/include/coin/CbcConfig.h +14 -0
  34. data/ext/ruby-cbc/install/include/coin/CbcConsequence.hpp +49 -0
  35. data/ext/ruby-cbc/install/include/coin/CbcCountRowCut.hpp +168 -0
  36. data/ext/ruby-cbc/install/include/coin/CbcCutGenerator.hpp +482 -0
  37. data/ext/ruby-cbc/install/include/coin/CbcCutModifier.hpp +57 -0
  38. data/ext/ruby-cbc/install/include/coin/CbcCutSubsetModifier.hpp +66 -0
  39. data/ext/ruby-cbc/install/include/coin/CbcDummyBranchingObject.hpp +83 -0
  40. data/ext/ruby-cbc/install/include/coin/CbcEventHandler.hpp +245 -0
  41. data/ext/ruby-cbc/install/include/coin/CbcFathom.hpp +137 -0
  42. data/ext/ruby-cbc/install/include/coin/CbcFathomDynamicProgramming.hpp +169 -0
  43. data/ext/ruby-cbc/install/include/coin/CbcFeasibilityBase.hpp +56 -0
  44. data/ext/ruby-cbc/install/include/coin/CbcFixVariable.hpp +67 -0
  45. data/ext/ruby-cbc/install/include/coin/CbcFollowOn.hpp +207 -0
  46. data/ext/ruby-cbc/install/include/coin/CbcFullNodeInfo.hpp +161 -0
  47. data/ext/ruby-cbc/install/include/coin/CbcGeneral.hpp +60 -0
  48. data/ext/ruby-cbc/install/include/coin/CbcGeneralDepth.hpp +279 -0
  49. data/ext/ruby-cbc/install/include/coin/CbcHeuristic.hpp +682 -0
  50. data/ext/ruby-cbc/install/include/coin/CbcHeuristicDINS.hpp +96 -0
  51. data/ext/ruby-cbc/install/include/coin/CbcHeuristicDW.hpp +309 -0
  52. data/ext/ruby-cbc/install/include/coin/CbcHeuristicDive.hpp +192 -0
  53. data/ext/ruby-cbc/install/include/coin/CbcHeuristicDiveCoefficient.hpp +52 -0
  54. data/ext/ruby-cbc/install/include/coin/CbcHeuristicDiveFractional.hpp +52 -0
  55. data/ext/ruby-cbc/install/include/coin/CbcHeuristicDiveGuided.hpp +55 -0
  56. data/ext/ruby-cbc/install/include/coin/CbcHeuristicDiveLineSearch.hpp +52 -0
  57. data/ext/ruby-cbc/install/include/coin/CbcHeuristicDivePseudoCost.hpp +60 -0
  58. data/ext/ruby-cbc/install/include/coin/CbcHeuristicDiveVectorLength.hpp +52 -0
  59. data/ext/ruby-cbc/install/include/coin/CbcHeuristicFPump.hpp +340 -0
  60. data/ext/ruby-cbc/install/include/coin/CbcHeuristicGreedy.hpp +280 -0
  61. data/ext/ruby-cbc/install/include/coin/CbcHeuristicLocal.hpp +271 -0
  62. data/ext/ruby-cbc/install/include/coin/CbcHeuristicPivotAndFix.hpp +58 -0
  63. data/ext/ruby-cbc/install/include/coin/CbcHeuristicRENS.hpp +77 -0
  64. data/ext/ruby-cbc/install/include/coin/CbcHeuristicRINS.hpp +102 -0
  65. data/ext/ruby-cbc/install/include/coin/CbcHeuristicRandRound.hpp +58 -0
  66. data/ext/ruby-cbc/install/include/coin/CbcHeuristicVND.hpp +94 -0
  67. data/ext/ruby-cbc/install/include/coin/CbcLinked.hpp +1406 -0
  68. data/ext/ruby-cbc/install/include/coin/CbcMessage.hpp +94 -0
  69. data/ext/ruby-cbc/install/include/coin/CbcMipStartIO.hpp +26 -0
  70. data/ext/ruby-cbc/install/include/coin/CbcModel.hpp +2952 -0
  71. data/ext/ruby-cbc/install/include/coin/CbcNWay.hpp +166 -0
  72. data/ext/ruby-cbc/install/include/coin/CbcNode.hpp +351 -0
  73. data/ext/ruby-cbc/install/include/coin/CbcNodeInfo.hpp +349 -0
  74. data/ext/ruby-cbc/install/include/coin/CbcObject.hpp +272 -0
  75. data/ext/ruby-cbc/install/include/coin/CbcObjectUpdateData.hpp +64 -0
  76. data/ext/ruby-cbc/install/include/coin/CbcOrClpParam.cpp +4134 -0
  77. data/ext/ruby-cbc/install/include/coin/CbcOrClpParam.hpp +532 -0
  78. data/ext/ruby-cbc/install/include/coin/CbcParam.hpp +324 -0
  79. data/ext/ruby-cbc/install/include/coin/CbcPartialNodeInfo.hpp +110 -0
  80. data/ext/ruby-cbc/install/include/coin/CbcSOS.hpp +279 -0
  81. data/ext/ruby-cbc/install/include/coin/CbcSimpleInteger.hpp +286 -0
  82. data/ext/ruby-cbc/install/include/coin/CbcSimpleIntegerDynamicPseudoCost.hpp +564 -0
  83. data/ext/ruby-cbc/install/include/coin/CbcSimpleIntegerPseudoCost.hpp +114 -0
  84. data/ext/ruby-cbc/install/include/coin/CbcSolver.hpp +447 -0
  85. data/ext/ruby-cbc/install/include/coin/CbcStrategy.hpp +258 -0
  86. data/ext/ruby-cbc/install/include/coin/CbcSubProblem.hpp +83 -0
  87. data/ext/ruby-cbc/install/include/coin/CbcTree.hpp +490 -0
  88. data/ext/ruby-cbc/install/include/coin/CbcTreeLocal.hpp +372 -0
  89. data/ext/ruby-cbc/install/include/coin/Cbc_C_Interface.h +381 -0
  90. data/ext/ruby-cbc/install/include/coin/Cgl012cut.hpp +464 -0
  91. data/ext/ruby-cbc/install/include/coin/CglAllDifferent.hpp +115 -0
  92. data/ext/ruby-cbc/install/include/coin/CglClique.hpp +308 -0
  93. data/ext/ruby-cbc/install/include/coin/CglConfig.h +19 -0
  94. data/ext/ruby-cbc/install/include/coin/CglCutGenerator.hpp +121 -0
  95. data/ext/ruby-cbc/install/include/coin/CglDuplicateRow.hpp +189 -0
  96. data/ext/ruby-cbc/install/include/coin/CglFlowCover.hpp +371 -0
  97. data/ext/ruby-cbc/install/include/coin/CglGMI.hpp +364 -0
  98. data/ext/ruby-cbc/install/include/coin/CglGMIParam.hpp +313 -0
  99. data/ext/ruby-cbc/install/include/coin/CglGomory.hpp +204 -0
  100. data/ext/ruby-cbc/install/include/coin/CglKnapsackCover.hpp +310 -0
  101. data/ext/ruby-cbc/install/include/coin/CglLandP.hpp +306 -0
  102. data/ext/ruby-cbc/install/include/coin/CglLandPValidator.hpp +130 -0
  103. data/ext/ruby-cbc/install/include/coin/CglLiftAndProject.hpp +104 -0
  104. data/ext/ruby-cbc/install/include/coin/CglMessage.hpp +50 -0
  105. data/ext/ruby-cbc/install/include/coin/CglMixedIntegerRounding.hpp +429 -0
  106. data/ext/ruby-cbc/install/include/coin/CglMixedIntegerRounding2.hpp +427 -0
  107. data/ext/ruby-cbc/install/include/coin/CglOddHole.hpp +160 -0
  108. data/ext/ruby-cbc/install/include/coin/CglParam.hpp +93 -0
  109. data/ext/ruby-cbc/install/include/coin/CglPreProcess.hpp +492 -0
  110. data/ext/ruby-cbc/install/include/coin/CglProbing.hpp +543 -0
  111. data/ext/ruby-cbc/install/include/coin/CglRedSplit.hpp +448 -0
  112. data/ext/ruby-cbc/install/include/coin/CglRedSplit2.hpp +494 -0
  113. data/ext/ruby-cbc/install/include/coin/CglRedSplit2Param.hpp +495 -0
  114. data/ext/ruby-cbc/install/include/coin/CglRedSplitParam.hpp +272 -0
  115. data/ext/ruby-cbc/install/include/coin/CglResidualCapacity.hpp +240 -0
  116. data/ext/ruby-cbc/install/include/coin/CglSimpleRounding.hpp +174 -0
  117. data/ext/ruby-cbc/install/include/coin/CglStored.hpp +125 -0
  118. data/ext/ruby-cbc/install/include/coin/CglTreeInfo.hpp +180 -0
  119. data/ext/ruby-cbc/install/include/coin/CglTwomir.hpp +565 -0
  120. data/ext/ruby-cbc/install/include/coin/CglZeroHalf.hpp +133 -0
  121. data/ext/ruby-cbc/install/include/coin/ClpAmplObjective.hpp +113 -0
  122. data/ext/ruby-cbc/install/include/coin/ClpCholeskyBase.hpp +294 -0
  123. data/ext/ruby-cbc/install/include/coin/ClpCholeskyDense.hpp +162 -0
  124. data/ext/ruby-cbc/install/include/coin/ClpConfig.h +17 -0
  125. data/ext/ruby-cbc/install/include/coin/ClpConstraint.hpp +125 -0
  126. data/ext/ruby-cbc/install/include/coin/ClpConstraintAmpl.hpp +108 -0
  127. data/ext/ruby-cbc/install/include/coin/ClpConstraintLinear.hpp +110 -0
  128. data/ext/ruby-cbc/install/include/coin/ClpConstraintQuadratic.hpp +119 -0
  129. data/ext/ruby-cbc/install/include/coin/ClpDualRowDantzig.hpp +71 -0
  130. data/ext/ruby-cbc/install/include/coin/ClpDualRowPivot.hpp +129 -0
  131. data/ext/ruby-cbc/install/include/coin/ClpDualRowSteepest.hpp +153 -0
  132. data/ext/ruby-cbc/install/include/coin/ClpDummyMatrix.hpp +183 -0
  133. data/ext/ruby-cbc/install/include/coin/ClpDynamicExampleMatrix.hpp +186 -0
  134. data/ext/ruby-cbc/install/include/coin/ClpDynamicMatrix.hpp +381 -0
  135. data/ext/ruby-cbc/install/include/coin/ClpEventHandler.hpp +187 -0
  136. data/ext/ruby-cbc/install/include/coin/ClpFactorization.hpp +432 -0
  137. data/ext/ruby-cbc/install/include/coin/ClpGubDynamicMatrix.hpp +247 -0
  138. data/ext/ruby-cbc/install/include/coin/ClpGubMatrix.hpp +358 -0
  139. data/ext/ruby-cbc/install/include/coin/ClpInterior.hpp +570 -0
  140. data/ext/ruby-cbc/install/include/coin/ClpLinearObjective.hpp +103 -0
  141. data/ext/ruby-cbc/install/include/coin/ClpMatrixBase.hpp +524 -0
  142. data/ext/ruby-cbc/install/include/coin/ClpMessage.hpp +131 -0
  143. data/ext/ruby-cbc/install/include/coin/ClpModel.hpp +1307 -0
  144. data/ext/ruby-cbc/install/include/coin/ClpNetworkMatrix.hpp +229 -0
  145. data/ext/ruby-cbc/install/include/coin/ClpNode.hpp +349 -0
  146. data/ext/ruby-cbc/install/include/coin/ClpNonLinearCost.hpp +401 -0
  147. data/ext/ruby-cbc/install/include/coin/ClpObjective.hpp +134 -0
  148. data/ext/ruby-cbc/install/include/coin/ClpPackedMatrix.hpp +638 -0
  149. data/ext/ruby-cbc/install/include/coin/ClpParameters.hpp +126 -0
  150. data/ext/ruby-cbc/install/include/coin/ClpPdcoBase.hpp +103 -0
  151. data/ext/ruby-cbc/install/include/coin/ClpPlusMinusOneMatrix.hpp +290 -0
  152. data/ext/ruby-cbc/install/include/coin/ClpPresolve.hpp +299 -0
  153. data/ext/ruby-cbc/install/include/coin/ClpPrimalColumnDantzig.hpp +72 -0
  154. data/ext/ruby-cbc/install/include/coin/ClpPrimalColumnPivot.hpp +155 -0
  155. data/ext/ruby-cbc/install/include/coin/ClpPrimalColumnSteepest.hpp +247 -0
  156. data/ext/ruby-cbc/install/include/coin/ClpQuadraticObjective.hpp +155 -0
  157. data/ext/ruby-cbc/install/include/coin/ClpSimplex.hpp +1797 -0
  158. data/ext/ruby-cbc/install/include/coin/ClpSimplexDual.hpp +300 -0
  159. data/ext/ruby-cbc/install/include/coin/ClpSimplexNonlinear.hpp +117 -0
  160. data/ext/ruby-cbc/install/include/coin/ClpSimplexOther.hpp +277 -0
  161. data/ext/ruby-cbc/install/include/coin/ClpSimplexPrimal.hpp +244 -0
  162. data/ext/ruby-cbc/install/include/coin/ClpSolve.hpp +446 -0
  163. data/ext/ruby-cbc/install/include/coin/Clp_C_Interface.h +525 -0
  164. data/ext/ruby-cbc/install/include/coin/CoinAlloc.hpp +176 -0
  165. data/ext/ruby-cbc/install/include/coin/CoinBuild.hpp +149 -0
  166. data/ext/ruby-cbc/install/include/coin/CoinDenseFactorization.hpp +419 -0
  167. data/ext/ruby-cbc/install/include/coin/CoinDenseVector.hpp +383 -0
  168. data/ext/ruby-cbc/install/include/coin/CoinDistance.hpp +48 -0
  169. data/ext/ruby-cbc/install/include/coin/CoinError.hpp +257 -0
  170. data/ext/ruby-cbc/install/include/coin/CoinFactorization.hpp +2044 -0
  171. data/ext/ruby-cbc/install/include/coin/CoinFileIO.hpp +166 -0
  172. data/ext/ruby-cbc/install/include/coin/CoinFinite.hpp +34 -0
  173. data/ext/ruby-cbc/install/include/coin/CoinFloatEqual.hpp +177 -0
  174. data/ext/ruby-cbc/install/include/coin/CoinHelperFunctions.hpp +1111 -0
  175. data/ext/ruby-cbc/install/include/coin/CoinIndexedVector.hpp +1164 -0
  176. data/ext/ruby-cbc/install/include/coin/CoinLpIO.hpp +805 -0
  177. data/ext/ruby-cbc/install/include/coin/CoinMessage.hpp +96 -0
  178. data/ext/ruby-cbc/install/include/coin/CoinMessageHandler.hpp +666 -0
  179. data/ext/ruby-cbc/install/include/coin/CoinModel.hpp +1054 -0
  180. data/ext/ruby-cbc/install/include/coin/CoinModelUseful.hpp +441 -0
  181. data/ext/ruby-cbc/install/include/coin/CoinMpsIO.hpp +1056 -0
  182. data/ext/ruby-cbc/install/include/coin/CoinOslFactorization.hpp +280 -0
  183. data/ext/ruby-cbc/install/include/coin/CoinPackedMatrix.hpp +947 -0
  184. data/ext/ruby-cbc/install/include/coin/CoinPackedVector.hpp +657 -0
  185. data/ext/ruby-cbc/install/include/coin/CoinPackedVectorBase.hpp +269 -0
  186. data/ext/ruby-cbc/install/include/coin/CoinParam.hpp +644 -0
  187. data/ext/ruby-cbc/install/include/coin/CoinPragma.hpp +26 -0
  188. data/ext/ruby-cbc/install/include/coin/CoinPresolveDoubleton.hpp +73 -0
  189. data/ext/ruby-cbc/install/include/coin/CoinPresolveDual.hpp +85 -0
  190. data/ext/ruby-cbc/install/include/coin/CoinPresolveDupcol.hpp +226 -0
  191. data/ext/ruby-cbc/install/include/coin/CoinPresolveEmpty.hpp +116 -0
  192. data/ext/ruby-cbc/install/include/coin/CoinPresolveFixed.hpp +181 -0
  193. data/ext/ruby-cbc/install/include/coin/CoinPresolveForcing.hpp +61 -0
  194. data/ext/ruby-cbc/install/include/coin/CoinPresolveImpliedFree.hpp +60 -0
  195. data/ext/ruby-cbc/install/include/coin/CoinPresolveIsolated.hpp +51 -0
  196. data/ext/ruby-cbc/install/include/coin/CoinPresolveMatrix.hpp +1842 -0
  197. data/ext/ruby-cbc/install/include/coin/CoinPresolveMonitor.hpp +105 -0
  198. data/ext/ruby-cbc/install/include/coin/CoinPresolvePsdebug.hpp +166 -0
  199. data/ext/ruby-cbc/install/include/coin/CoinPresolveSingleton.hpp +112 -0
  200. data/ext/ruby-cbc/install/include/coin/CoinPresolveSubst.hpp +101 -0
  201. data/ext/ruby-cbc/install/include/coin/CoinPresolveTighten.hpp +55 -0
  202. data/ext/ruby-cbc/install/include/coin/CoinPresolveTripleton.hpp +66 -0
  203. data/ext/ruby-cbc/install/include/coin/CoinPresolveUseless.hpp +63 -0
  204. data/ext/ruby-cbc/install/include/coin/CoinPresolveZeros.hpp +60 -0
  205. data/ext/ruby-cbc/install/include/coin/CoinRational.hpp +44 -0
  206. data/ext/ruby-cbc/install/include/coin/CoinSearchTree.hpp +465 -0
  207. data/ext/ruby-cbc/install/include/coin/CoinShallowPackedVector.hpp +148 -0
  208. data/ext/ruby-cbc/install/include/coin/CoinSignal.hpp +117 -0
  209. data/ext/ruby-cbc/install/include/coin/CoinSimpFactorization.hpp +431 -0
  210. data/ext/ruby-cbc/install/include/coin/CoinSmartPtr.hpp +528 -0
  211. data/ext/ruby-cbc/install/include/coin/CoinSnapshot.hpp +476 -0
  212. data/ext/ruby-cbc/install/include/coin/CoinSort.hpp +678 -0
  213. data/ext/ruby-cbc/install/include/coin/CoinStructuredModel.hpp +247 -0
  214. data/ext/ruby-cbc/install/include/coin/CoinTime.hpp +310 -0
  215. data/ext/ruby-cbc/install/include/coin/CoinTypes.hpp +64 -0
  216. data/ext/ruby-cbc/install/include/coin/CoinUtility.hpp +19 -0
  217. data/ext/ruby-cbc/install/include/coin/CoinUtilsConfig.h +34 -0
  218. data/ext/ruby-cbc/install/include/coin/CoinWarmStart.hpp +58 -0
  219. data/ext/ruby-cbc/install/include/coin/CoinWarmStartBasis.hpp +456 -0
  220. data/ext/ruby-cbc/install/include/coin/CoinWarmStartDual.hpp +166 -0
  221. data/ext/ruby-cbc/install/include/coin/CoinWarmStartPrimalDual.hpp +211 -0
  222. data/ext/ruby-cbc/install/include/coin/CoinWarmStartVector.hpp +488 -0
  223. data/ext/ruby-cbc/install/include/coin/Coin_C_defines.h +115 -0
  224. data/ext/ruby-cbc/install/include/coin/Idiot.hpp +298 -0
  225. data/ext/ruby-cbc/install/include/coin/OsiAuxInfo.hpp +206 -0
  226. data/ext/ruby-cbc/install/include/coin/OsiBranchingObject.hpp +1005 -0
  227. data/ext/ruby-cbc/install/include/coin/OsiCbcSolverInterface.hpp +764 -0
  228. data/ext/ruby-cbc/install/include/coin/OsiChooseVariable.hpp +534 -0
  229. data/ext/ruby-cbc/install/include/coin/OsiClpSolverInterface.hpp +1509 -0
  230. data/ext/ruby-cbc/install/include/coin/OsiColCut.hpp +324 -0
  231. data/ext/ruby-cbc/install/include/coin/OsiCollections.hpp +35 -0
  232. data/ext/ruby-cbc/install/include/coin/OsiConfig.h +19 -0
  233. data/ext/ruby-cbc/install/include/coin/OsiCut.hpp +245 -0
  234. data/ext/ruby-cbc/install/include/coin/OsiCuts.hpp +474 -0
  235. data/ext/ruby-cbc/install/include/coin/OsiPresolve.hpp +252 -0
  236. data/ext/ruby-cbc/install/include/coin/OsiRowCut.hpp +331 -0
  237. data/ext/ruby-cbc/install/include/coin/OsiRowCutDebugger.hpp +187 -0
  238. data/ext/ruby-cbc/install/include/coin/OsiSolverBranch.hpp +152 -0
  239. data/ext/ruby-cbc/install/include/coin/OsiSolverInterface.hpp +2143 -0
  240. data/ext/ruby-cbc/install/include/coin/OsiSolverParameters.hpp +142 -0
  241. data/ext/ruby-cbc/install/include/coin/OsiUnitTests.hpp +374 -0
  242. data/ext/ruby-cbc/install/lib/libCbc.la +35 -0
  243. data/ext/ruby-cbc/install/lib/libCbc.so +0 -0
  244. data/ext/ruby-cbc/install/lib/libCbc.so.3 +0 -0
  245. data/ext/ruby-cbc/install/lib/libCbc.so.3.9.7 +0 -0
  246. data/ext/ruby-cbc/install/lib/libCbcSolver.la +35 -0
  247. data/ext/ruby-cbc/install/lib/libCbcSolver.so +0 -0
  248. data/ext/ruby-cbc/install/lib/libCbcSolver.so.3 +0 -0
  249. data/ext/ruby-cbc/install/lib/libCbcSolver.so.3.9.7 +0 -0
  250. data/ext/ruby-cbc/install/lib/libCgl.la +35 -0
  251. data/ext/ruby-cbc/install/lib/libCgl.so +0 -0
  252. data/ext/ruby-cbc/install/lib/libCgl.so.1 +0 -0
  253. data/ext/ruby-cbc/install/lib/libCgl.so.1.9.7 +0 -0
  254. data/ext/ruby-cbc/install/lib/libClp.la +35 -0
  255. data/ext/ruby-cbc/install/lib/libClp.so +0 -0
  256. data/ext/ruby-cbc/install/lib/libClp.so.1 +0 -0
  257. data/ext/ruby-cbc/install/lib/libClp.so.1.13.9 +0 -0
  258. data/ext/ruby-cbc/install/lib/libClpSolver.la +35 -0
  259. data/ext/ruby-cbc/install/lib/libClpSolver.so +0 -0
  260. data/ext/ruby-cbc/install/lib/libClpSolver.so.1 +0 -0
  261. data/ext/ruby-cbc/install/lib/libClpSolver.so.1.13.9 +0 -0
  262. data/ext/ruby-cbc/install/lib/libCoinUtils.la +35 -0
  263. data/ext/ruby-cbc/install/lib/libCoinUtils.so +0 -0
  264. data/ext/ruby-cbc/install/lib/libCoinUtils.so.3 +0 -0
  265. data/ext/ruby-cbc/install/lib/libCoinUtils.so.3.10.11 +0 -0
  266. data/ext/ruby-cbc/install/lib/libOsi.la +35 -0
  267. data/ext/ruby-cbc/install/lib/libOsi.so +0 -0
  268. data/ext/ruby-cbc/install/lib/libOsi.so.1 +0 -0
  269. data/ext/ruby-cbc/install/lib/libOsi.so.1.12.6 +0 -0
  270. data/ext/ruby-cbc/install/lib/libOsiCbc.la +35 -0
  271. data/ext/ruby-cbc/install/lib/libOsiCbc.so +0 -0
  272. data/ext/ruby-cbc/install/lib/libOsiCbc.so.3 +0 -0
  273. data/ext/ruby-cbc/install/lib/libOsiCbc.so.3.9.7 +0 -0
  274. data/ext/ruby-cbc/install/lib/libOsiClp.la +35 -0
  275. data/ext/ruby-cbc/install/lib/libOsiClp.so +0 -0
  276. data/ext/ruby-cbc/install/lib/libOsiClp.so.1 +0 -0
  277. data/ext/ruby-cbc/install/lib/libOsiClp.so.1.13.9 +0 -0
  278. data/ext/ruby-cbc/install/lib/libOsiCommonTests.la +35 -0
  279. data/ext/ruby-cbc/install/lib/libOsiCommonTests.so +0 -0
  280. data/ext/ruby-cbc/install/lib/libOsiCommonTests.so.1 +0 -0
  281. data/ext/ruby-cbc/install/lib/libOsiCommonTests.so.1.12.6 +0 -0
  282. data/ext/ruby-cbc/install/lib/pkgconfig/cbc.pc +12 -0
  283. data/ext/ruby-cbc/install/lib/pkgconfig/cgl.pc +12 -0
  284. data/ext/ruby-cbc/install/lib/pkgconfig/clp.pc +12 -0
  285. data/ext/ruby-cbc/install/lib/pkgconfig/coindatamiplib3.pc +9 -0
  286. data/ext/ruby-cbc/install/lib/pkgconfig/coindatasample.pc +9 -0
  287. data/ext/ruby-cbc/install/lib/pkgconfig/coinutils.pc +12 -0
  288. data/ext/ruby-cbc/install/lib/pkgconfig/osi-cbc.pc +12 -0
  289. data/ext/ruby-cbc/install/lib/pkgconfig/osi-clp.pc +12 -0
  290. data/ext/ruby-cbc/install/lib/pkgconfig/osi-unittests.pc +12 -0
  291. data/ext/ruby-cbc/install/lib/pkgconfig/osi.pc +12 -0
  292. data/lib/ruby-cbc/ilp/constant.rb +44 -0
  293. data/lib/ruby-cbc/ilp/constraint.rb +32 -0
  294. data/lib/ruby-cbc/ilp/objective.rb +26 -0
  295. data/lib/ruby-cbc/ilp/term.rb +47 -0
  296. data/lib/ruby-cbc/ilp/term_array.rb +80 -0
  297. data/lib/ruby-cbc/ilp/var.rb +62 -0
  298. data/lib/ruby-cbc/model.rb +125 -0
  299. data/lib/ruby-cbc/problem.rb +170 -0
  300. data/lib/ruby-cbc/version.rb +3 -0
  301. data/lib/ruby-cbc.rb +21 -0
  302. data/ruby-cbc.gemspec +36 -0
  303. metadata +431 -0
@@ -0,0 +1,564 @@
1
+ // $Id: CbcSimpleIntegerDynamicPseudoCost.hpp 2094 2014-11-18 11:15:36Z forrest $
2
+ // Copyright (C) 2005, International Business Machines
3
+ // Corporation and others. All Rights Reserved.
4
+ // This code is licensed under the terms of the Eclipse Public License (EPL).
5
+
6
+ // Edwin 11/17/2009 - carved out of CbcBranchDynamic
7
+
8
+ #ifndef CbcSimpleIntegerDynamicPseudoCost_H
9
+ #define CbcSimpleIntegerDynamicPseudoCost_H
10
+
11
+ #include "CbcSimpleInteger.hpp"
12
+
13
+ #define TYPERATIO 0.9
14
+ #define MINIMUM_MOVEMENT 0.1
15
+ #define TYPE2 0
16
+ // was 1 - but that looks flakey
17
+ #define INFEAS 1
18
+ #define MOD_SHADOW 1
19
+ // weight at 1.0 is max min
20
+ #define WEIGHT_AFTER 0.8
21
+ #define WEIGHT_BEFORE 0.1
22
+ //Stolen from Constraint Integer Programming book (with epsilon change)
23
+ #define WEIGHT_PRODUCT
24
+
25
+
26
+ /** Define a single integer class but with dynamic pseudo costs.
27
+ Based on work by Achterberg, Koch and Martin.
28
+
29
+ It is wild overkill but to keep design all twiddly things are in each.
30
+ This could be used for fine tuning.
31
+
32
+ */
33
+
34
+
35
+ class CbcSimpleIntegerDynamicPseudoCost : public CbcSimpleInteger {
36
+
37
+ public:
38
+
39
+ // Default Constructor
40
+ CbcSimpleIntegerDynamicPseudoCost ();
41
+
42
+ // Useful constructor - passed model index
43
+ CbcSimpleIntegerDynamicPseudoCost (CbcModel * model, int iColumn, double breakEven = 0.5);
44
+
45
+ // Useful constructor - passed model index and pseudo costs
46
+ CbcSimpleIntegerDynamicPseudoCost (CbcModel * model, int iColumn,
47
+ double downDynamicPseudoCost, double upDynamicPseudoCost);
48
+
49
+ // Useful constructor - passed model index and pseudo costs
50
+ CbcSimpleIntegerDynamicPseudoCost (CbcModel * model, int dummy, int iColumn,
51
+ double downDynamicPseudoCost, double upDynamicPseudoCost);
52
+
53
+ // Copy constructor
54
+ CbcSimpleIntegerDynamicPseudoCost ( const CbcSimpleIntegerDynamicPseudoCost &);
55
+
56
+ /// Clone
57
+ virtual CbcObject * clone() const;
58
+
59
+ // Assignment operator
60
+ CbcSimpleIntegerDynamicPseudoCost & operator=( const CbcSimpleIntegerDynamicPseudoCost& rhs);
61
+
62
+ // Destructor
63
+ virtual ~CbcSimpleIntegerDynamicPseudoCost ();
64
+
65
+ /// Infeasibility - large is 0.5
66
+ virtual double infeasibility(const OsiBranchingInformation * info,
67
+ int &preferredWay) const;
68
+
69
+ /// Creates a branching object
70
+ virtual CbcBranchingObject * createCbcBranch(OsiSolverInterface * solver, const OsiBranchingInformation * info, int way) ;
71
+
72
+
73
+ /// Fills in a created branching object
74
+ // void fillCreateBranch(CbcIntegerBranchingObject * branching, const OsiBranchingInformation * info, int way) ;
75
+
76
+
77
+ /** Pass in information on branch just done and create CbcObjectUpdateData instance.
78
+ If object does not need data then backward pointer will be NULL.
79
+ Assumes can get information from solver */
80
+ virtual CbcObjectUpdateData createUpdateInformation(const OsiSolverInterface * solver,
81
+ const CbcNode * node,
82
+ const CbcBranchingObject * branchingObject);
83
+ /// Update object by CbcObjectUpdateData
84
+ virtual void updateInformation(const CbcObjectUpdateData & data) ;
85
+ /// Copy some information i.e. just variable stuff
86
+ void copySome(const CbcSimpleIntegerDynamicPseudoCost * otherObject);
87
+ /// Updates stuff like pseudocosts before threads
88
+ virtual void updateBefore(const OsiObject * rhs) ;
89
+ /// Updates stuff like pseudocosts after threads finished
90
+ virtual void updateAfter(const OsiObject * rhs, const OsiObject * baseObject) ;
91
+ /// Updates stuff like pseudocosts after mini branch and bound
92
+ void updateAfterMini(int numberDown, int numberDownInfeasible, double sumDown,
93
+ int numberUp, int numberUpInfeasible, double sumUp);
94
+
95
+ using CbcSimpleInteger::solverBranch ;
96
+ /** Create an OsiSolverBranch object
97
+
98
+ This returns NULL if branch not represented by bound changes
99
+ */
100
+ virtual OsiSolverBranch * solverBranch() const;
101
+
102
+ /// Down pseudo cost
103
+ inline double downDynamicPseudoCost() const {
104
+ return downDynamicPseudoCost_;
105
+ }
106
+ /// Set down pseudo cost
107
+ void setDownDynamicPseudoCost(double value) ;
108
+ /// Modify down pseudo cost in a slightly different way
109
+ void updateDownDynamicPseudoCost(double value);
110
+
111
+ /// Up pseudo cost
112
+ inline double upDynamicPseudoCost() const {
113
+ return upDynamicPseudoCost_;
114
+ }
115
+ /// Set up pseudo cost
116
+ void setUpDynamicPseudoCost(double value);
117
+ /// Modify up pseudo cost in a slightly different way
118
+ void updateUpDynamicPseudoCost(double value);
119
+
120
+ /// Down pseudo shadow price cost
121
+ inline double downShadowPrice() const {
122
+ return downShadowPrice_;
123
+ }
124
+ /// Set down pseudo shadow price cost
125
+ inline void setDownShadowPrice(double value) {
126
+ downShadowPrice_ = value;
127
+ }
128
+ /// Up pseudo shadow price cost
129
+ inline double upShadowPrice() const {
130
+ return upShadowPrice_;
131
+ }
132
+ /// Set up pseudo shadow price cost
133
+ inline void setUpShadowPrice(double value) {
134
+ upShadowPrice_ = value;
135
+ }
136
+
137
+ /// Up down separator
138
+ inline double upDownSeparator() const {
139
+ return upDownSeparator_;
140
+ }
141
+ /// Set up down separator
142
+ inline void setUpDownSeparator(double value) {
143
+ upDownSeparator_ = value;
144
+ }
145
+
146
+ /// Down sum cost
147
+ inline double sumDownCost() const {
148
+ return sumDownCost_;
149
+ }
150
+ /// Set down sum cost
151
+ inline void setSumDownCost(double value) {
152
+ sumDownCost_ = value;
153
+ }
154
+ /// Add to down sum cost and set last and square
155
+ inline void addToSumDownCost(double value) {
156
+ sumDownCost_ += value;
157
+ lastDownCost_ = value;
158
+ }
159
+
160
+ /// Up sum cost
161
+ inline double sumUpCost() const {
162
+ return sumUpCost_;
163
+ }
164
+ /// Set up sum cost
165
+ inline void setSumUpCost(double value) {
166
+ sumUpCost_ = value;
167
+ }
168
+ /// Add to up sum cost and set last and square
169
+ inline void addToSumUpCost(double value) {
170
+ sumUpCost_ += value;
171
+ lastUpCost_ = value;
172
+ }
173
+
174
+ /// Down sum change
175
+ inline double sumDownChange() const {
176
+ return sumDownChange_;
177
+ }
178
+ /// Set down sum change
179
+ inline void setSumDownChange(double value) {
180
+ sumDownChange_ = value;
181
+ }
182
+ /// Add to down sum change
183
+ inline void addToSumDownChange(double value) {
184
+ sumDownChange_ += value;
185
+ }
186
+
187
+ /// Up sum change
188
+ inline double sumUpChange() const {
189
+ return sumUpChange_;
190
+ }
191
+ /// Set up sum change
192
+ inline void setSumUpChange(double value) {
193
+ sumUpChange_ = value;
194
+ }
195
+ /// Add to up sum change and set last and square
196
+ inline void addToSumUpChange(double value) {
197
+ sumUpChange_ += value;
198
+ }
199
+
200
+ /// Sum down decrease number infeasibilities from strong or actual
201
+ inline double sumDownDecrease() const {
202
+ return sumDownDecrease_;
203
+ }
204
+ /// Set sum down decrease number infeasibilities from strong or actual
205
+ inline void setSumDownDecrease(double value) {
206
+ sumDownDecrease_ = value;
207
+ }
208
+ /// Add to sum down decrease number infeasibilities from strong or actual
209
+ inline void addToSumDownDecrease(double value) {
210
+ sumDownDecrease_ += value;/*lastDownDecrease_ = (int) value;*/
211
+ }
212
+
213
+ /// Sum up decrease number infeasibilities from strong or actual
214
+ inline double sumUpDecrease() const {
215
+ return sumUpDecrease_;
216
+ }
217
+ /// Set sum up decrease number infeasibilities from strong or actual
218
+ inline void setSumUpDecrease(double value) {
219
+ sumUpDecrease_ = value;
220
+ }
221
+ /// Add to sum up decrease number infeasibilities from strong or actual
222
+ inline void addToSumUpDecrease(double value) {
223
+ sumUpDecrease_ += value;/*lastUpDecrease_ = (int) value;*/
224
+ }
225
+
226
+ /// Down number times
227
+ inline int numberTimesDown() const {
228
+ return numberTimesDown_;
229
+ }
230
+ /// Set down number times
231
+ inline void setNumberTimesDown(int value) {
232
+ numberTimesDown_ = value;
233
+ }
234
+ /// Increment down number times
235
+ inline void incrementNumberTimesDown() {
236
+ numberTimesDown_++;
237
+ }
238
+
239
+ /// Up number times
240
+ inline int numberTimesUp() const {
241
+ return numberTimesUp_;
242
+ }
243
+ /// Set up number times
244
+ inline void setNumberTimesUp(int value) {
245
+ numberTimesUp_ = value;
246
+ }
247
+ /// Increment up number times
248
+ inline void incrementNumberTimesUp() {
249
+ numberTimesUp_++;
250
+ }
251
+
252
+ /// Number times branched
253
+ inline int numberTimesBranched() const {
254
+ return numberTimesDown_ + numberTimesUp_;
255
+ }
256
+ /// Down number times infeasible
257
+ inline int numberTimesDownInfeasible() const {
258
+ return numberTimesDownInfeasible_;
259
+ }
260
+ /// Set down number times infeasible
261
+ inline void setNumberTimesDownInfeasible(int value) {
262
+ numberTimesDownInfeasible_ = value;
263
+ }
264
+ /// Increment down number times infeasible
265
+ inline void incrementNumberTimesDownInfeasible() {
266
+ numberTimesDownInfeasible_++;
267
+ }
268
+
269
+ /// Up number times infeasible
270
+ inline int numberTimesUpInfeasible() const {
271
+ return numberTimesUpInfeasible_;
272
+ }
273
+ /// Set up number times infeasible
274
+ inline void setNumberTimesUpInfeasible(int value) {
275
+ numberTimesUpInfeasible_ = value;
276
+ }
277
+ /// Increment up number times infeasible
278
+ inline void incrementNumberTimesUpInfeasible() {
279
+ numberTimesUpInfeasible_++;
280
+ }
281
+
282
+ /// Number of times before trusted
283
+ inline int numberBeforeTrust() const {
284
+ return numberBeforeTrust_;
285
+ }
286
+ /// Set number of times before trusted
287
+ inline void setNumberBeforeTrust(int value) {
288
+ numberBeforeTrust_ = value;
289
+ }
290
+ /// Increment number of times before trusted
291
+ inline void incrementNumberBeforeTrust() {
292
+ numberBeforeTrust_++;
293
+ }
294
+
295
+ /// Return "up" estimate
296
+ virtual double upEstimate() const;
297
+ /// Return "down" estimate (default 1.0e-5)
298
+ virtual double downEstimate() const;
299
+
300
+ /// method - see below for details
301
+ inline int method() const {
302
+ return method_;
303
+ }
304
+ /// Set method
305
+ inline void setMethod(int value) {
306
+ method_ = value;
307
+ }
308
+
309
+ /// Pass in information on a down branch
310
+ void setDownInformation(double changeObjectiveDown, int changeInfeasibilityDown);
311
+ /// Pass in information on a up branch
312
+ void setUpInformation(double changeObjectiveUp, int changeInfeasibilityUp);
313
+ /// Pass in probing information
314
+ void setProbingInformation(int fixedDown, int fixedUp);
315
+
316
+ /// Print - 0 -summary, 1 just before strong
317
+ void print(int type = 0, double value = 0.0) const;
318
+ /// Same - returns true if contents match(ish)
319
+ bool same(const CbcSimpleIntegerDynamicPseudoCost * obj) const;
320
+ protected:
321
+ /// data
322
+
323
+ /// Down pseudo cost
324
+ double downDynamicPseudoCost_;
325
+ /// Up pseudo cost
326
+ double upDynamicPseudoCost_;
327
+ /** Up/down separator
328
+ If >0.0 then do first branch up if value-floor(value)
329
+ >= this value
330
+ */
331
+ double upDownSeparator_;
332
+ /// Sum down cost from strong or actual
333
+ double sumDownCost_;
334
+ /// Sum up cost from strong or actual
335
+ double sumUpCost_;
336
+ /// Sum of all changes to x when going down
337
+ double sumDownChange_;
338
+ /// Sum of all changes to x when going up
339
+ double sumUpChange_;
340
+ /// Current pseudo-shadow price estimate down
341
+ mutable double downShadowPrice_;
342
+ /// Current pseudo-shadow price estimate up
343
+ mutable double upShadowPrice_;
344
+ /// Sum down decrease number infeasibilities from strong or actual
345
+ double sumDownDecrease_;
346
+ /// Sum up decrease number infeasibilities from strong or actual
347
+ double sumUpDecrease_;
348
+ /// Last down cost from strong (i.e. as computed by last strong)
349
+ double lastDownCost_;
350
+ /// Last up cost from strong (i.e. as computed by last strong)
351
+ double lastUpCost_;
352
+ /// Last down decrease number infeasibilities from strong (i.e. as computed by last strong)
353
+ mutable int lastDownDecrease_;
354
+ /// Last up decrease number infeasibilities from strong (i.e. as computed by last strong)
355
+ mutable int lastUpDecrease_;
356
+ /// Number of times we have gone down
357
+ int numberTimesDown_;
358
+ /// Number of times we have gone up
359
+ int numberTimesUp_;
360
+ /// Number of times we have been infeasible going down
361
+ int numberTimesDownInfeasible_;
362
+ /// Number of times we have been infeasible going up
363
+ int numberTimesUpInfeasible_;
364
+ /// Number of branches before we trust
365
+ int numberBeforeTrust_;
366
+ /// Number of local probing fixings going down
367
+ int numberTimesDownLocalFixed_;
368
+ /// Number of local probing fixings going up
369
+ int numberTimesUpLocalFixed_;
370
+ /// Number of total probing fixings going down
371
+ double numberTimesDownTotalFixed_;
372
+ /// Number of total probing fixings going up
373
+ double numberTimesUpTotalFixed_;
374
+ /// Number of times probing done
375
+ int numberTimesProbingTotal_;
376
+ /// Number of times infeasible when tested
377
+ /** Method -
378
+ 0 - pseudo costs
379
+ 1 - probing
380
+ */
381
+ int method_;
382
+ };
383
+ /** Simple branching object for an integer variable with pseudo costs
384
+
385
+ This object can specify a two-way branch on an integer variable. For each
386
+ arm of the branch, the upper and lower bounds on the variable can be
387
+ independently specified.
388
+
389
+ Variable_ holds the index of the integer variable in the integerVariable_
390
+ array of the model.
391
+ */
392
+
393
+ class CbcIntegerPseudoCostBranchingObject : public CbcIntegerBranchingObject {
394
+
395
+ public:
396
+
397
+ /// Default constructor
398
+ CbcIntegerPseudoCostBranchingObject ();
399
+
400
+ /** Create a standard floor/ceiling branch object
401
+
402
+ Specifies a simple two-way branch. Let \p value = x*. One arm of the
403
+ branch will be is lb <= x <= floor(x*), the other ceil(x*) <= x <= ub.
404
+ Specify way = -1 to set the object state to perform the down arm first,
405
+ way = 1 for the up arm.
406
+ */
407
+ CbcIntegerPseudoCostBranchingObject (CbcModel *model, int variable,
408
+ int way , double value) ;
409
+
410
+ /** Create a degenerate branch object
411
+
412
+ Specifies a `one-way branch'. Calling branch() for this object will
413
+ always result in lowerValue <= x <= upperValue. Used to fix a variable
414
+ when lowerValue = upperValue.
415
+ */
416
+
417
+ CbcIntegerPseudoCostBranchingObject (CbcModel *model, int variable, int way,
418
+ double lowerValue, double upperValue) ;
419
+
420
+ /// Copy constructor
421
+ CbcIntegerPseudoCostBranchingObject ( const CbcIntegerPseudoCostBranchingObject &);
422
+
423
+ /// Assignment operator
424
+ CbcIntegerPseudoCostBranchingObject & operator= (const CbcIntegerPseudoCostBranchingObject& rhs);
425
+
426
+ /// Clone
427
+ virtual CbcBranchingObject * clone() const;
428
+
429
+ /// Destructor
430
+ virtual ~CbcIntegerPseudoCostBranchingObject ();
431
+
432
+ using CbcBranchingObject::branch ;
433
+ /** \brief Sets the bounds for the variable according to the current arm
434
+ of the branch and advances the object state to the next arm.
435
+ This version also changes guessed objective value
436
+ */
437
+ virtual double branch();
438
+
439
+ /// Change in guessed
440
+ inline double changeInGuessed() const {
441
+ return changeInGuessed_;
442
+ }
443
+ /// Set change in guessed
444
+ inline void setChangeInGuessed(double value) {
445
+ changeInGuessed_ = value;
446
+ }
447
+
448
+ /** Return the type (an integer identifier) of \c this */
449
+ virtual CbcBranchObjType type() const {
450
+ return SimpleIntegerDynamicPseudoCostBranchObj;
451
+ }
452
+
453
+ /** Compare the \c this with \c brObj. \c this and \c brObj must be os the
454
+ same type and must have the same original object, but they may have
455
+ different feasible regions.
456
+ Return the appropriate CbcRangeCompare value (first argument being the
457
+ sub/superset if that's the case). In case of overlap (and if \c
458
+ replaceIfOverlap is true) replace the current branching object with one
459
+ whose feasible region is the overlap.
460
+ */
461
+ virtual CbcRangeCompare compareBranchingObject
462
+ (const CbcBranchingObject* brObj, const bool replaceIfOverlap = false);
463
+
464
+ protected:
465
+ /// Change in guessed objective value for next branch
466
+ double changeInGuessed_;
467
+ };
468
+ #ifdef SWITCH_VARIABLES
469
+ /** Define a single integer class but with associated switched variable
470
+ So Binary variable switches on/off a continuous variable
471
+ designed for badly scaled problems
472
+ */
473
+
474
+
475
+ class CbcSwitchingBinary : public CbcSimpleIntegerDynamicPseudoCost {
476
+
477
+ public:
478
+
479
+ // Default Constructor
480
+ CbcSwitchingBinary ();
481
+
482
+ // Useful constructor
483
+ CbcSwitchingBinary (CbcSimpleIntegerDynamicPseudoCost * oldObject,
484
+ int nOdd,const int * other, const int * otherRow);
485
+
486
+
487
+ // Copy constructor
488
+ CbcSwitchingBinary ( const CbcSwitchingBinary &);
489
+
490
+ /// Clone
491
+ virtual CbcObject * clone() const;
492
+
493
+ // Assignment operator
494
+ CbcSwitchingBinary & operator=( const CbcSwitchingBinary& rhs);
495
+
496
+ // Destructor
497
+ virtual ~CbcSwitchingBinary ();
498
+
499
+ /// Add in zero switches
500
+ void addZeroSwitches(int nAdd,const int * columns);
501
+ /// Infeasibility - large is 0.5
502
+ virtual double infeasibility(const OsiBranchingInformation * info,
503
+ int &preferredWay) const;
504
+
505
+ /// Same - returns true if contents match(ish)
506
+ bool same(const CbcSwitchingBinary * obj) const;
507
+ /// Set associated bounds
508
+ virtual int setAssociatedBounds(OsiSolverInterface * solver=NULL,
509
+ int cleanBasis=0) const;
510
+ /// Check associated bounds
511
+ int checkAssociatedBounds(const OsiSolverInterface * solver,const double * solution,
512
+ int printLevel, int state[3], int & nBadFixed) const;
513
+ /// Lower bound when binary zero
514
+ inline const double * zeroLowerBound() const
515
+ { return zeroLowerBound_; }
516
+ /// Lower bound when binary one
517
+ inline const double * oneLowerBound() const
518
+ { return oneLowerBound_; }
519
+ /// Upper bound when binary zero
520
+ inline const double * zeroUpperBound() const
521
+ { return zeroUpperBound_; }
522
+ /// Upper bound when binary one
523
+ inline const double * oneUpperBound() const
524
+ { return oneUpperBound_; }
525
+ /** Continuous variable -
526
+ */
527
+ inline const int * otherVariable() const
528
+ { return otherVariable_;}
529
+ /// Number of other variables
530
+ inline int numberOther() const
531
+ { return numberOther_;}
532
+ /** Type
533
+ 1 - single switch
534
+ 2 - double switch
535
+ 3 - both
536
+ */
537
+ inline int type() const
538
+ { return type_;}
539
+ protected:
540
+ /// data
541
+
542
+ /// Lower bound when binary zero
543
+ double * zeroLowerBound_;
544
+ /// Lower bound when binary one
545
+ double * oneLowerBound_;
546
+ /// Upper bound when binary zero
547
+ double * zeroUpperBound_;
548
+ /// Upper bound when binary one
549
+ double * oneUpperBound_;
550
+ /** Continuous variable -
551
+ */
552
+ int * otherVariable_;
553
+ /// Number of other variables
554
+ int numberOther_;
555
+ /** Type
556
+ 1 - single switch
557
+ 2 - double switch
558
+ 3 - both
559
+ */
560
+ int type_;
561
+ };
562
+ #endif
563
+ #endif
564
+
@@ -0,0 +1,114 @@
1
+ // $Id: CbcSimpleIntegerPseudoCost.hpp 1899 2013-04-09 18:12:08Z stefan $
2
+ // Copyright (C) 2002, International Business Machines
3
+ // Corporation and others. All Rights Reserved.
4
+ // This code is licensed under the terms of the Eclipse Public License (EPL).
5
+
6
+ // Edwin 11/10/2009-- carved out of CbcBranchActual
7
+
8
+ #ifndef CbcSimpleIntegerPseudoCost_H
9
+ #define CbcSimpleIntegerPseudoCost_H
10
+
11
+ #include "CbcSimpleInteger.hpp"
12
+ /// Define a single integer class but with pseudo costs
13
+
14
+ class CbcSimpleIntegerPseudoCost : public CbcSimpleInteger {
15
+
16
+ public:
17
+
18
+ // Default Constructor
19
+ CbcSimpleIntegerPseudoCost ();
20
+
21
+ // Useful constructor - passed model index
22
+ CbcSimpleIntegerPseudoCost (CbcModel * model, int iColumn, double breakEven = 0.5);
23
+
24
+ // Useful constructor - passed and model index and pseudo costs
25
+ CbcSimpleIntegerPseudoCost (CbcModel * model, int iColumn,
26
+ double downPseudoCost, double upPseudoCost);
27
+ // Useful constructor - passed and model index and pseudo costs
28
+ CbcSimpleIntegerPseudoCost (CbcModel * model, int dummy, int iColumn,
29
+ double downPseudoCost, double upPseudoCost);
30
+
31
+ // Copy constructor
32
+ CbcSimpleIntegerPseudoCost ( const CbcSimpleIntegerPseudoCost &);
33
+
34
+ /// Clone
35
+ virtual CbcObject * clone() const;
36
+
37
+ // Assignment operator
38
+ CbcSimpleIntegerPseudoCost & operator=( const CbcSimpleIntegerPseudoCost& rhs);
39
+
40
+ // Destructor
41
+ virtual ~CbcSimpleIntegerPseudoCost ();
42
+
43
+ /// Infeasibility - large is 0.5
44
+ virtual double infeasibility(const OsiBranchingInformation * info,
45
+ int &preferredWay) const;
46
+
47
+ /// Creates a branching object
48
+ virtual CbcBranchingObject * createCbcBranch(OsiSolverInterface * solver, const OsiBranchingInformation * info, int way) ;
49
+
50
+ /// Down pseudo cost
51
+ inline double downPseudoCost() const {
52
+ return downPseudoCost_;
53
+ }
54
+ /// Set down pseudo cost
55
+ inline void setDownPseudoCost(double value) {
56
+ downPseudoCost_ = value;
57
+ }
58
+
59
+ /// Up pseudo cost
60
+ inline double upPseudoCost() const {
61
+ return upPseudoCost_;
62
+ }
63
+ /// Set up pseudo cost
64
+ inline void setUpPseudoCost(double value) {
65
+ upPseudoCost_ = value;
66
+ }
67
+
68
+ /// Up down separator
69
+ inline double upDownSeparator() const {
70
+ return upDownSeparator_;
71
+ }
72
+ /// Set up down separator
73
+ inline void setUpDownSeparator(double value) {
74
+ upDownSeparator_ = value;
75
+ }
76
+
77
+ /// Return "up" estimate
78
+ virtual double upEstimate() const;
79
+ /// Return "down" estimate (default 1.0e-5)
80
+ virtual double downEstimate() const;
81
+
82
+ /// method - see below for details
83
+ inline int method() const {
84
+ return method_;
85
+ }
86
+ /// Set method
87
+ inline void setMethod(int value) {
88
+ method_ = value;
89
+ }
90
+
91
+ protected:
92
+ /// data
93
+
94
+ /// Down pseudo cost
95
+ double downPseudoCost_;
96
+ /// Up pseudo cost
97
+ double upPseudoCost_;
98
+ /** Up/down separator
99
+ If >0.0 then do first branch up if value-floor(value)
100
+ >= this value
101
+ */
102
+ double upDownSeparator_;
103
+ /** Method -
104
+ 0 - normal - return min (up,down)
105
+ 1 - if before any solution return CoinMax(up,down)
106
+ 2 - if before branched solution return CoinMax(up,down)
107
+ 3 - always return CoinMax(up,down)
108
+ */
109
+ int method_;
110
+ };
111
+
112
+
113
+ #endif
114
+