casadi 3.6.3__cp35-none-manylinux2010_x86_64.whl → 3.6.5__cp35-none-manylinux2010_x86_64.whl

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 (571) hide show
  1. casadi/_casadi.so +0 -0
  2. casadi/casadi.py +415 -260
  3. casadi/cbc +0 -0
  4. casadi/clp +0 -0
  5. casadi/cmake/casadi-config-version.cmake +1 -1
  6. casadi/include/casadi/casadi.i +43 -18
  7. casadi/include/casadi/config.h +6 -6
  8. casadi/include/casadi/core/calculus.hpp +1 -1
  9. casadi/include/casadi/core/code_generator.hpp +29 -1
  10. casadi/include/casadi/core/core.hpp +1 -0
  11. casadi/include/casadi/core/fmu.hpp +29 -1
  12. casadi/include/casadi/core/generic_expression.hpp +1 -1
  13. casadi/include/casadi/core/generic_type.hpp +25 -1
  14. casadi/include/casadi/core/matrix_decl.hpp +15 -0
  15. casadi/include/casadi/core/nlpsol.hpp +0 -2
  16. casadi/include/casadi/core/runtime/casadi_nlp.hpp +131 -6
  17. casadi/include/casadi/core/runtime/casadi_sqpmethod.hpp +11 -1
  18. casadi/include/casadi/core/serializing_stream.hpp +12 -0
  19. casadi/include/casadi/core/sparsity.hpp +5 -3
  20. casadi/include/casadi/core/tools.hpp +67 -0
  21. casadi/include/casadi/doc.i +1457 -825
  22. casadi/include/casadi/doc_merged.i +1089 -570
  23. casadi/include/coin/BonArraysHelpers.hpp +52 -0
  24. casadi/include/coin/BonAuxInfos.hpp +110 -0
  25. casadi/include/coin/BonBabInfos.hpp +57 -0
  26. casadi/include/coin/BonBabSetupBase.hpp +386 -0
  27. casadi/include/coin/BonBonminSetup.hpp +95 -0
  28. casadi/include/coin/BonBranchingTQP.hpp +197 -0
  29. casadi/include/coin/BonCbc.hpp +127 -0
  30. casadi/include/coin/BonCbcLpStrategy.hpp +45 -0
  31. casadi/include/coin/BonCbcNlpStrategy.hpp +98 -0
  32. casadi/include/coin/BonCbcNode.hpp +133 -0
  33. casadi/include/coin/BonChooseVariable.hpp +345 -0
  34. casadi/include/coin/BonCurvBranchingSolver.hpp +77 -0
  35. casadi/include/coin/BonCutStrengthener.hpp +244 -0
  36. casadi/include/coin/BonDiver.hpp +424 -0
  37. casadi/include/coin/BonDummyHeuristic.hpp +53 -0
  38. casadi/include/coin/BonDummyPump.hpp +43 -0
  39. casadi/include/coin/BonEcpCuts.hpp +97 -0
  40. casadi/include/coin/BonExitCodes.hpp +12 -0
  41. casadi/include/coin/BonFixAndSolveHeuristic.hpp +43 -0
  42. casadi/include/coin/BonGuessHeuristic.hpp +46 -0
  43. casadi/include/coin/BonHeuristicDive.hpp +88 -0
  44. casadi/include/coin/BonHeuristicDiveFractional.hpp +67 -0
  45. casadi/include/coin/BonHeuristicDiveMIP.hpp +83 -0
  46. casadi/include/coin/BonHeuristicDiveMIPFractional.hpp +67 -0
  47. casadi/include/coin/BonHeuristicDiveMIPVectorLength.hpp +74 -0
  48. casadi/include/coin/BonHeuristicDiveVectorLength.hpp +74 -0
  49. casadi/include/coin/BonHeuristicFPump.hpp +111 -0
  50. casadi/include/coin/BonHeuristicLocalBranching.hpp +59 -0
  51. casadi/include/coin/BonHeuristicRINS.hpp +55 -0
  52. casadi/include/coin/BonIpoptInteriorWarmStarter.hpp +103 -0
  53. casadi/include/coin/BonIpoptSolver.hpp +188 -0
  54. casadi/include/coin/BonIpoptWarmStart.hpp +148 -0
  55. casadi/include/coin/BonLinearCutsGenerator.hpp +75 -0
  56. casadi/include/coin/BonLocalSolverBasedHeuristic.hpp +102 -0
  57. casadi/include/coin/BonLpBranchingSolver.hpp +80 -0
  58. casadi/include/coin/BonMilpRounding.hpp +74 -0
  59. casadi/include/coin/BonOACutGenerator2.hpp +56 -0
  60. casadi/include/coin/BonOAMessages.hpp +44 -0
  61. casadi/include/coin/BonOaDecBase.hpp +297 -0
  62. casadi/include/coin/BonOaFeasChecker.hpp +73 -0
  63. casadi/include/coin/BonOaNlpOptim.hpp +116 -0
  64. casadi/include/coin/BonOsiTMINLPInterface.hpp +1342 -0
  65. casadi/include/coin/BonOuterApprox.hpp +123 -0
  66. casadi/include/coin/BonPseudoCosts.hpp +91 -0
  67. casadi/include/coin/BonPumpForMinlp.hpp +45 -0
  68. casadi/include/coin/BonQuadCut.hpp +217 -0
  69. casadi/include/coin/BonQuadRow.hpp +122 -0
  70. casadi/include/coin/BonRegisteredOptions.hpp +225 -0
  71. casadi/include/coin/BonStrongBranchingSolver.hpp +69 -0
  72. casadi/include/coin/BonSubMipSolver.hpp +143 -0
  73. casadi/include/coin/BonTMINLP.hpp +420 -0
  74. casadi/include/coin/BonTMINLP2OsiLP.hpp +164 -0
  75. casadi/include/coin/BonTMINLP2Quad.hpp +191 -0
  76. casadi/include/coin/BonTMINLP2TNLP.hpp +509 -0
  77. casadi/include/coin/BonTMINLPLinObj.hpp +216 -0
  78. casadi/include/coin/BonTMatrix.hpp +167 -0
  79. casadi/include/coin/BonTNLP2FPNLP.hpp +264 -0
  80. casadi/include/coin/BonTNLPSolver.hpp +241 -0
  81. casadi/include/coin/BonTypes.hpp +95 -0
  82. casadi/include/coin/BonminConfig.h +19 -0
  83. casadi/include/coin/CbcBranchActual.hpp +26 -0
  84. casadi/include/coin/CbcBranchAllDifferent.hpp +61 -0
  85. casadi/include/coin/CbcBranchBase.hpp +79 -0
  86. casadi/include/coin/CbcBranchCut.hpp +182 -0
  87. casadi/include/coin/CbcBranchDecision.hpp +135 -0
  88. casadi/include/coin/CbcBranchDefaultDecision.hpp +101 -0
  89. casadi/include/coin/CbcBranchDynamic.hpp +210 -0
  90. casadi/include/coin/CbcBranchLotsize.hpp +249 -0
  91. casadi/include/coin/CbcBranchToFixLots.hpp +94 -0
  92. casadi/include/coin/CbcBranchingObject.hpp +245 -0
  93. casadi/include/coin/CbcClique.hpp +309 -0
  94. casadi/include/coin/CbcCompare.hpp +46 -0
  95. casadi/include/coin/CbcCompareActual.hpp +16 -0
  96. casadi/include/coin/CbcCompareBase.hpp +155 -0
  97. casadi/include/coin/CbcCompareDefault.hpp +129 -0
  98. casadi/include/coin/CbcCompareDepth.hpp +48 -0
  99. casadi/include/coin/CbcCompareEstimate.hpp +48 -0
  100. casadi/include/coin/CbcCompareObjective.hpp +50 -0
  101. casadi/include/coin/CbcConfig.h +18 -0
  102. casadi/include/coin/CbcConsequence.hpp +50 -0
  103. casadi/include/coin/CbcCountRowCut.hpp +176 -0
  104. casadi/include/coin/CbcCutGenerator.hpp +550 -0
  105. casadi/include/coin/CbcCutModifier.hpp +59 -0
  106. casadi/include/coin/CbcCutSubsetModifier.hpp +69 -0
  107. casadi/include/coin/CbcDummyBranchingObject.hpp +83 -0
  108. casadi/include/coin/CbcEventHandler.hpp +250 -0
  109. casadi/include/coin/CbcFathom.hpp +136 -0
  110. casadi/include/coin/CbcFathomDynamicProgramming.hpp +177 -0
  111. casadi/include/coin/CbcFeasibilityBase.hpp +60 -0
  112. casadi/include/coin/CbcFixVariable.hpp +68 -0
  113. casadi/include/coin/CbcFollowOn.hpp +207 -0
  114. casadi/include/coin/CbcFullNodeInfo.hpp +171 -0
  115. casadi/include/coin/CbcGeneral.hpp +60 -0
  116. casadi/include/coin/CbcGeneralDepth.hpp +289 -0
  117. casadi/include/coin/CbcHeuristic.hpp +735 -0
  118. casadi/include/coin/CbcHeuristicDINS.hpp +98 -0
  119. casadi/include/coin/CbcHeuristicDW.hpp +374 -0
  120. casadi/include/coin/CbcHeuristicDive.hpp +198 -0
  121. casadi/include/coin/CbcHeuristicDiveCoefficient.hpp +52 -0
  122. casadi/include/coin/CbcHeuristicDiveFractional.hpp +52 -0
  123. casadi/include/coin/CbcHeuristicDiveGuided.hpp +55 -0
  124. casadi/include/coin/CbcHeuristicDiveLineSearch.hpp +52 -0
  125. casadi/include/coin/CbcHeuristicDivePseudoCost.hpp +60 -0
  126. casadi/include/coin/CbcHeuristicDiveVectorLength.hpp +52 -0
  127. casadi/include/coin/CbcHeuristicFPump.hpp +375 -0
  128. casadi/include/coin/CbcHeuristicGreedy.hpp +289 -0
  129. casadi/include/coin/CbcHeuristicLocal.hpp +276 -0
  130. casadi/include/coin/CbcHeuristicPivotAndFix.hpp +58 -0
  131. casadi/include/coin/CbcHeuristicRENS.hpp +79 -0
  132. casadi/include/coin/CbcHeuristicRINS.hpp +106 -0
  133. casadi/include/coin/CbcHeuristicRandRound.hpp +58 -0
  134. casadi/include/coin/CbcHeuristicVND.hpp +95 -0
  135. casadi/include/coin/CbcLinked.hpp +1443 -0
  136. casadi/include/coin/CbcMessage.hpp +94 -0
  137. casadi/include/coin/CbcMipStartIO.hpp +29 -0
  138. casadi/include/coin/CbcModel.hpp +3296 -0
  139. casadi/include/coin/CbcNWay.hpp +171 -0
  140. casadi/include/coin/CbcNode.hpp +380 -0
  141. casadi/include/coin/CbcNodeInfo.hpp +377 -0
  142. casadi/include/coin/CbcObject.hpp +288 -0
  143. casadi/include/coin/CbcObjectUpdateData.hpp +63 -0
  144. casadi/include/coin/CbcOrClpParam.cpp +4321 -0
  145. casadi/include/coin/CbcOrClpParam.hpp +585 -0
  146. casadi/include/coin/CbcParam.hpp +338 -0
  147. casadi/include/coin/CbcPartialNodeInfo.hpp +116 -0
  148. casadi/include/coin/CbcSOS.hpp +290 -0
  149. casadi/include/coin/CbcSimpleInteger.hpp +299 -0
  150. casadi/include/coin/CbcSimpleIntegerDynamicPseudoCost.hpp +619 -0
  151. casadi/include/coin/CbcSimpleIntegerPseudoCost.hpp +122 -0
  152. casadi/include/coin/CbcSolver.hpp +460 -0
  153. casadi/include/coin/CbcStrategy.hpp +269 -0
  154. casadi/include/coin/CbcSubProblem.hpp +84 -0
  155. casadi/include/coin/CbcTree.hpp +493 -0
  156. casadi/include/coin/CbcTreeLocal.hpp +393 -0
  157. casadi/include/coin/Cbc_C_Interface.h +904 -0
  158. casadi/include/coin/Cgl012cut.hpp +464 -0
  159. casadi/include/coin/CglAllDifferent.hpp +115 -0
  160. casadi/include/coin/CglClique.hpp +312 -0
  161. casadi/include/coin/CglConfig.h +19 -0
  162. casadi/include/coin/CglCutGenerator.hpp +133 -0
  163. casadi/include/coin/CglDuplicateRow.hpp +189 -0
  164. casadi/include/coin/CglFlowCover.hpp +371 -0
  165. casadi/include/coin/CglGMI.hpp +364 -0
  166. casadi/include/coin/CglGMIParam.hpp +313 -0
  167. casadi/include/coin/CglGomory.hpp +204 -0
  168. casadi/include/coin/CglKnapsackCover.hpp +310 -0
  169. casadi/include/coin/CglLandP.hpp +306 -0
  170. casadi/include/coin/CglLandPValidator.hpp +130 -0
  171. casadi/include/coin/CglLiftAndProject.hpp +104 -0
  172. casadi/include/coin/CglMessage.hpp +49 -0
  173. casadi/include/coin/CglMixedIntegerRounding.hpp +429 -0
  174. casadi/include/coin/CglMixedIntegerRounding2.hpp +427 -0
  175. casadi/include/coin/CglOddHole.hpp +160 -0
  176. casadi/include/coin/CglParam.hpp +93 -0
  177. casadi/include/coin/CglPreProcess.hpp +600 -0
  178. casadi/include/coin/CglProbing.hpp +543 -0
  179. casadi/include/coin/CglRedSplit.hpp +448 -0
  180. casadi/include/coin/CglRedSplit2.hpp +494 -0
  181. casadi/include/coin/CglRedSplit2Param.hpp +495 -0
  182. casadi/include/coin/CglRedSplitParam.hpp +272 -0
  183. casadi/include/coin/CglResidualCapacity.hpp +240 -0
  184. casadi/include/coin/CglSimpleRounding.hpp +174 -0
  185. casadi/include/coin/CglStored.hpp +140 -0
  186. casadi/include/coin/CglTreeInfo.hpp +216 -0
  187. casadi/include/coin/CglTwomir.hpp +562 -0
  188. casadi/include/coin/CglZeroHalf.hpp +133 -0
  189. casadi/include/coin/ClpAmplObjective.hpp +113 -0
  190. casadi/include/coin/ClpCholeskyBase.hpp +321 -0
  191. casadi/include/coin/ClpCholeskyDense.hpp +157 -0
  192. casadi/include/coin/ClpCholeskyMumps.hpp +65 -0
  193. casadi/include/coin/ClpCholeskyPardiso.hpp +67 -0
  194. casadi/include/coin/ClpConfig.h +17 -0
  195. casadi/include/coin/ClpConstraint.hpp +129 -0
  196. casadi/include/coin/ClpConstraintAmpl.hpp +109 -0
  197. casadi/include/coin/ClpConstraintLinear.hpp +113 -0
  198. casadi/include/coin/ClpConstraintQuadratic.hpp +123 -0
  199. casadi/include/coin/ClpDualRowDantzig.hpp +72 -0
  200. casadi/include/coin/ClpDualRowPivot.hpp +136 -0
  201. casadi/include/coin/ClpDualRowSteepest.hpp +160 -0
  202. casadi/include/coin/ClpDummyMatrix.hpp +186 -0
  203. casadi/include/coin/ClpDynamicExampleMatrix.hpp +199 -0
  204. casadi/include/coin/ClpDynamicMatrix.hpp +420 -0
  205. casadi/include/coin/ClpEventHandler.hpp +193 -0
  206. casadi/include/coin/ClpFactorization.hpp +556 -0
  207. casadi/include/coin/ClpGubDynamicMatrix.hpp +270 -0
  208. casadi/include/coin/ClpGubMatrix.hpp +373 -0
  209. casadi/include/coin/ClpInterior.hpp +622 -0
  210. casadi/include/coin/ClpLinearObjective.hpp +104 -0
  211. casadi/include/coin/ClpMatrixBase.hpp +561 -0
  212. casadi/include/coin/ClpMessage.hpp +131 -0
  213. casadi/include/coin/ClpModel.hpp +1442 -0
  214. casadi/include/coin/ClpNetworkMatrix.hpp +235 -0
  215. casadi/include/coin/ClpNode.hpp +364 -0
  216. casadi/include/coin/ClpNonLinearCost.hpp +432 -0
  217. casadi/include/coin/ClpObjective.hpp +142 -0
  218. casadi/include/coin/ClpPEDualRowDantzig.hpp +84 -0
  219. casadi/include/coin/ClpPEDualRowSteepest.hpp +100 -0
  220. casadi/include/coin/ClpPEPrimalColumnDantzig.hpp +71 -0
  221. casadi/include/coin/ClpPEPrimalColumnSteepest.hpp +107 -0
  222. casadi/include/coin/ClpPESimplex.hpp +231 -0
  223. casadi/include/coin/ClpPackedMatrix.hpp +778 -0
  224. casadi/include/coin/ClpParameters.hpp +132 -0
  225. casadi/include/coin/ClpPdcoBase.hpp +110 -0
  226. casadi/include/coin/ClpPlusMinusOneMatrix.hpp +565 -0
  227. casadi/include/coin/ClpPresolve.hpp +379 -0
  228. casadi/include/coin/ClpPrimalColumnDantzig.hpp +74 -0
  229. casadi/include/coin/ClpPrimalColumnPivot.hpp +163 -0
  230. casadi/include/coin/ClpPrimalColumnSteepest.hpp +281 -0
  231. casadi/include/coin/ClpQuadraticObjective.hpp +161 -0
  232. casadi/include/coin/ClpSimplex.hpp +2137 -0
  233. casadi/include/coin/ClpSimplexDual.hpp +304 -0
  234. casadi/include/coin/ClpSimplexNonlinear.hpp +117 -0
  235. casadi/include/coin/ClpSimplexOther.hpp +282 -0
  236. casadi/include/coin/ClpSimplexPrimal.hpp +244 -0
  237. casadi/include/coin/ClpSolve.hpp +505 -0
  238. casadi/include/coin/Clp_C_Interface.h +554 -0
  239. casadi/include/coin/CoinAlloc.hpp +179 -0
  240. casadi/include/coin/CoinBuild.hpp +159 -0
  241. casadi/include/coin/CoinDenseFactorization.hpp +452 -0
  242. casadi/include/coin/CoinDenseVector.hpp +401 -0
  243. casadi/include/coin/CoinDistance.hpp +51 -0
  244. casadi/include/coin/CoinError.hpp +274 -0
  245. casadi/include/coin/CoinFactorization.hpp +2178 -0
  246. casadi/include/coin/CoinFileIO.hpp +185 -0
  247. casadi/include/coin/CoinFinite.hpp +37 -0
  248. casadi/include/coin/CoinFloatEqual.hpp +204 -0
  249. casadi/include/coin/CoinHelperFunctions.hpp +1270 -0
  250. casadi/include/coin/CoinIndexedVector.hpp +1437 -0
  251. casadi/include/coin/CoinLpIO.hpp +836 -0
  252. casadi/include/coin/CoinMessage.hpp +95 -0
  253. casadi/include/coin/CoinMessageHandler.hpp +717 -0
  254. casadi/include/coin/CoinModel.hpp +1214 -0
  255. casadi/include/coin/CoinModelUseful.hpp +518 -0
  256. casadi/include/coin/CoinMpsIO.hpp +1142 -0
  257. casadi/include/coin/CoinOslFactorization.hpp +287 -0
  258. casadi/include/coin/CoinPackedMatrix.hpp +956 -0
  259. casadi/include/coin/CoinPackedVector.hpp +670 -0
  260. casadi/include/coin/CoinPackedVectorBase.hpp +274 -0
  261. casadi/include/coin/CoinParam.hpp +644 -0
  262. casadi/include/coin/CoinPragma.hpp +29 -0
  263. casadi/include/coin/CoinPresolveDoubleton.hpp +76 -0
  264. casadi/include/coin/CoinPresolveDual.hpp +84 -0
  265. casadi/include/coin/CoinPresolveDupcol.hpp +259 -0
  266. casadi/include/coin/CoinPresolveEmpty.hpp +120 -0
  267. casadi/include/coin/CoinPresolveFixed.hpp +185 -0
  268. casadi/include/coin/CoinPresolveForcing.hpp +69 -0
  269. casadi/include/coin/CoinPresolveImpliedFree.hpp +66 -0
  270. casadi/include/coin/CoinPresolveIsolated.hpp +59 -0
  271. casadi/include/coin/CoinPresolveMatrix.hpp +1996 -0
  272. casadi/include/coin/CoinPresolveMonitor.hpp +105 -0
  273. casadi/include/coin/CoinPresolvePsdebug.hpp +169 -0
  274. casadi/include/coin/CoinPresolveSingleton.hpp +115 -0
  275. casadi/include/coin/CoinPresolveSubst.hpp +103 -0
  276. casadi/include/coin/CoinPresolveTighten.hpp +58 -0
  277. casadi/include/coin/CoinPresolveTripleton.hpp +69 -0
  278. casadi/include/coin/CoinPresolveUseless.hpp +63 -0
  279. casadi/include/coin/CoinPresolveZeros.hpp +65 -0
  280. casadi/include/coin/CoinRational.hpp +43 -0
  281. casadi/include/coin/CoinSearchTree.hpp +523 -0
  282. casadi/include/coin/CoinShallowPackedVector.hpp +149 -0
  283. casadi/include/coin/CoinSignal.hpp +127 -0
  284. casadi/include/coin/CoinSimpFactorization.hpp +432 -0
  285. casadi/include/coin/CoinSmartPtr.hpp +548 -0
  286. casadi/include/coin/CoinSnapshot.hpp +572 -0
  287. casadi/include/coin/CoinSort.hpp +753 -0
  288. casadi/include/coin/CoinStructuredModel.hpp +270 -0
  289. casadi/include/coin/CoinTime.hpp +350 -0
  290. casadi/include/coin/CoinTypes.hpp +67 -0
  291. casadi/include/coin/CoinUtility.hpp +26 -0
  292. casadi/include/coin/CoinUtilsConfig.h +34 -0
  293. casadi/include/coin/CoinWarmStart.hpp +56 -0
  294. casadi/include/coin/CoinWarmStartBasis.hpp +468 -0
  295. casadi/include/coin/CoinWarmStartDual.hpp +180 -0
  296. casadi/include/coin/CoinWarmStartPrimalDual.hpp +233 -0
  297. casadi/include/coin/CoinWarmStartVector.hpp +523 -0
  298. casadi/include/coin/Coin_C_defines.h +149 -0
  299. casadi/include/coin/Idiot.hpp +327 -0
  300. casadi/include/coin/OsiAuxInfo.hpp +261 -0
  301. casadi/include/coin/OsiBranchingObject.hpp +1097 -0
  302. casadi/include/coin/OsiCbcSolverInterface.hpp +791 -0
  303. casadi/include/coin/OsiChooseVariable.hpp +645 -0
  304. casadi/include/coin/OsiClpSolverInterface.hpp +1604 -0
  305. casadi/include/coin/OsiColCut.hpp +322 -0
  306. casadi/include/coin/OsiCollections.hpp +34 -0
  307. casadi/include/coin/OsiConfig.h +19 -0
  308. casadi/include/coin/OsiCut.hpp +251 -0
  309. casadi/include/coin/OsiCuts.hpp +505 -0
  310. casadi/include/coin/OsiPresolve.hpp +272 -0
  311. casadi/include/coin/OsiRowCut.hpp +345 -0
  312. casadi/include/coin/OsiRowCutDebugger.hpp +190 -0
  313. casadi/include/coin/OsiSolverBranch.hpp +169 -0
  314. casadi/include/coin/OsiSolverInterface.hpp +2221 -0
  315. casadi/include/coin/OsiSolverParameters.hpp +144 -0
  316. casadi/include/coin/OsiUnitTests.hpp +390 -0
  317. casadi/include/coin-or/IpAlgBuilder.hpp +417 -0
  318. casadi/include/coin-or/IpAlgStrategy.hpp +201 -0
  319. casadi/include/coin-or/IpAlgTypes.hpp +64 -0
  320. casadi/include/coin-or/IpAugSystemSolver.hpp +212 -0
  321. casadi/include/coin-or/IpBlas.hpp +426 -0
  322. casadi/include/coin-or/IpCachedResults.hpp +897 -0
  323. casadi/include/coin-or/IpCompoundMatrix.hpp +423 -0
  324. casadi/include/coin-or/IpCompoundSymMatrix.hpp +348 -0
  325. casadi/include/coin-or/IpCompoundVector.hpp +395 -0
  326. casadi/include/coin-or/IpConvCheck.hpp +97 -0
  327. casadi/include/coin-or/IpDebug.hpp +167 -0
  328. casadi/include/coin-or/IpDenseVector.hpp +626 -0
  329. casadi/include/coin-or/IpDiagMatrix.hpp +158 -0
  330. casadi/include/coin-or/IpEqMultCalculator.hpp +76 -0
  331. casadi/include/coin-or/IpException.hpp +156 -0
  332. casadi/include/coin-or/IpExpansionMatrix.hpp +245 -0
  333. casadi/include/coin-or/IpGenTMatrix.hpp +290 -0
  334. casadi/include/coin-or/IpHessianUpdater.hpp +73 -0
  335. casadi/include/coin-or/IpIdentityMatrix.hpp +167 -0
  336. casadi/include/coin-or/IpIpoptAlg.hpp +257 -0
  337. casadi/include/coin-or/IpIpoptApplication.hpp +367 -0
  338. casadi/include/coin-or/IpIpoptCalculatedQuantities.hpp +1009 -0
  339. casadi/include/coin-or/IpIpoptData.hpp +966 -0
  340. casadi/include/coin-or/IpIpoptNLP.hpp +328 -0
  341. casadi/include/coin-or/IpIterateInitializer.hpp +68 -0
  342. casadi/include/coin-or/IpIteratesVector.hpp +840 -0
  343. casadi/include/coin-or/IpIterationOutput.hpp +78 -0
  344. casadi/include/coin-or/IpJournalist.hpp +573 -0
  345. casadi/include/coin-or/IpLapack.hpp +227 -0
  346. casadi/include/coin-or/IpLibraryLoader.hpp +76 -0
  347. casadi/include/coin-or/IpLineSearch.hpp +106 -0
  348. casadi/include/coin-or/IpLinearSolvers.h +46 -0
  349. casadi/include/coin-or/IpMatrix.hpp +434 -0
  350. casadi/include/coin-or/IpMuUpdate.hpp +77 -0
  351. casadi/include/coin-or/IpNLP.hpp +306 -0
  352. casadi/include/coin-or/IpNLPScaling.hpp +582 -0
  353. casadi/include/coin-or/IpObserver.hpp +422 -0
  354. casadi/include/coin-or/IpOptionsList.hpp +412 -0
  355. casadi/include/coin-or/IpOrigIpoptNLP.hpp +603 -0
  356. casadi/include/coin-or/IpPDSystemSolver.hpp +137 -0
  357. casadi/include/coin-or/IpReferenced.hpp +262 -0
  358. casadi/include/coin-or/IpRegOptions.hpp +1152 -0
  359. casadi/include/coin-or/IpReturnCodes.h +23 -0
  360. casadi/include/coin-or/IpReturnCodes.hpp +18 -0
  361. casadi/include/coin-or/IpReturnCodes.inc +71 -0
  362. casadi/include/coin-or/IpReturnCodes_inc.h +45 -0
  363. casadi/include/coin-or/IpScaledMatrix.hpp +291 -0
  364. casadi/include/coin-or/IpSearchDirCalculator.hpp +72 -0
  365. casadi/include/coin-or/IpSmartPtr.hpp +865 -0
  366. casadi/include/coin-or/IpSolveStatistics.hpp +210 -0
  367. casadi/include/coin-or/IpSparseSymLinearSolverInterface.hpp +260 -0
  368. casadi/include/coin-or/IpStdAugSystemSolver.cpp +555 -0
  369. casadi/include/coin-or/IpStdCInterface.h +428 -0
  370. casadi/include/coin-or/IpSumSymMatrix.hpp +186 -0
  371. casadi/include/coin-or/IpSymLinearSolver.hpp +141 -0
  372. casadi/include/coin-or/IpSymMatrix.hpp +167 -0
  373. casadi/include/coin-or/IpSymScaledMatrix.hpp +255 -0
  374. casadi/include/coin-or/IpSymTMatrix.hpp +275 -0
  375. casadi/include/coin-or/IpTNLP.hpp +820 -0
  376. casadi/include/coin-or/IpTNLPAdapter.hpp +648 -0
  377. casadi/include/coin-or/IpTNLPReducer.hpp +274 -0
  378. casadi/include/coin-or/IpTaggedObject.hpp +128 -0
  379. casadi/include/coin-or/IpTimedTask.hpp +218 -0
  380. casadi/include/coin-or/IpTimingStatistics.hpp +323 -0
  381. casadi/include/coin-or/IpTripletHelper.hpp +308 -0
  382. casadi/include/coin-or/IpTypes.h +81 -0
  383. casadi/include/coin-or/IpTypes.hpp +30 -0
  384. casadi/include/coin-or/IpUtils.hpp +166 -0
  385. casadi/include/coin-or/IpVector.hpp +892 -0
  386. casadi/include/coin-or/IpZeroSymMatrix.hpp +155 -0
  387. casadi/include/coin-or/IpoptConfig.h +45 -0
  388. casadi/include/coin-or/SensAlgorithm.hpp +114 -0
  389. casadi/include/coin-or/SensApplication.hpp +188 -0
  390. casadi/include/coin-or/SensBacksolver.hpp +36 -0
  391. casadi/include/coin-or/SensMeasurement.hpp +56 -0
  392. casadi/include/coin-or/SensPCalculator.hpp +137 -0
  393. casadi/include/coin-or/SensRegOp.hpp +21 -0
  394. casadi/include/coin-or/SensSchurData.hpp +182 -0
  395. casadi/include/coin-or/SensSchurDriver.hpp +118 -0
  396. casadi/include/coin-or/SensSimpleBacksolver.hpp +49 -0
  397. casadi/include/coin-or/SensStepCalc.hpp +85 -0
  398. casadi/include/coin-or/SensUtils.hpp +63 -0
  399. casadi/include/coin-or/metis/defs.h +161 -0
  400. casadi/include/coin-or/metis/macros.h +143 -0
  401. casadi/include/coin-or/metis/metis.h +37 -0
  402. casadi/include/coin-or/metis/proto.h +505 -0
  403. casadi/include/coin-or/metis/rename.h +418 -0
  404. casadi/include/coin-or/metis/struct.h +251 -0
  405. casadi/include/coin-or/mumps/dmumps_c.h +142 -0
  406. casadi/include/coin-or/mumps/mumps_c_types.h +72 -0
  407. casadi/include/coin-or/mumps/mumps_compat.h +27 -0
  408. casadi/include/coin-or/mumps/mumps_int_def.h +11 -0
  409. casadi/include/coin-or/mumps/mumps_mpi.h +67 -0
  410. casadi/include/d_blas.h +78 -0
  411. casadi/include/d_blas_64.h +73 -0
  412. casadi/include/openblas/cblas.h +411 -0
  413. casadi/include/openblas/f77blas.h +796 -0
  414. casadi/include/openblas/lapack.h +22997 -0
  415. casadi/include/openblas/lapacke.h +12665 -0
  416. casadi/include/openblas/lapacke_config.h +119 -0
  417. casadi/include/openblas/lapacke_example_aux.h +9 -0
  418. casadi/include/openblas/lapacke_mangling.h +17 -0
  419. casadi/include/openblas/lapacke_utils.h +582 -0
  420. casadi/include/openblas/openblas/lapacke_mangling.h +17 -0
  421. casadi/include/openblas/openblas_config.h +139 -0
  422. casadi/include/qdldl/qdldl.h +169 -0
  423. casadi/include/qdldl/qdldl_types.h +23 -0
  424. casadi/include/s_blas.h +78 -0
  425. casadi/include/s_blas_64.h +73 -0
  426. casadi/lib64/libtinyxml2.a +0 -0
  427. casadi/libCbc.la +3 -3
  428. casadi/libCbc.so +0 -0
  429. casadi/libCbc.so.3 +0 -0
  430. casadi/libCbc.so.3.10.11 +0 -0
  431. casadi/libCbcSolver.la +3 -3
  432. casadi/libCbcSolver.so +0 -0
  433. casadi/libCbcSolver.so.3 +0 -0
  434. casadi/libCbcSolver.so.3.10.11 +0 -0
  435. casadi/libCgl.la +2 -2
  436. casadi/libCgl.so +0 -0
  437. casadi/libCgl.so.1 +0 -0
  438. casadi/libCgl.so.1.10.8 +0 -0
  439. casadi/libClp.la +2 -2
  440. casadi/libClp.so +0 -0
  441. casadi/libClp.so.1 +0 -0
  442. casadi/libClp.so.1.14.9 +0 -0
  443. casadi/libClpSolver.la +2 -2
  444. casadi/libClpSolver.so +0 -0
  445. casadi/libClpSolver.so.1 +0 -0
  446. casadi/{libClpSolver.so.1.14.7 → libClpSolver.so.1.14.9} +0 -0
  447. casadi/libCoinUtils.la +2 -2
  448. casadi/libCoinUtils.so +0 -0
  449. casadi/libCoinUtils.so.3 +0 -0
  450. casadi/libCoinUtils.so.3.11.10 +0 -0
  451. casadi/libOsi.la +2 -2
  452. casadi/libOsiCbc.la +3 -3
  453. casadi/libOsiCbc.so +0 -0
  454. casadi/libOsiCbc.so.3 +0 -0
  455. casadi/{libOsiCbc.so.3.10.6 → libOsiCbc.so.3.10.11} +0 -0
  456. casadi/libOsiClp.la +2 -2
  457. casadi/libOsiClp.so +0 -0
  458. casadi/libOsiClp.so.1 +0 -0
  459. casadi/libOsiClp.so.1.14.9 +0 -0
  460. casadi/libOsiCommonTests.la +2 -2
  461. casadi/libOsiCommonTests.so +0 -0
  462. casadi/libOsiCommonTests.so.1 +0 -0
  463. casadi/{libOsiCommonTests.so.1.13.7 → libOsiCommonTests.so.1.13.9} +0 -0
  464. casadi/libbonmin.la +3 -3
  465. casadi/libbonmin.so +0 -0
  466. casadi/libbonmin.so.4 +0 -0
  467. casadi/libbonmin.so.4.8.9 +0 -0
  468. casadi/libcasadi.so +0 -0
  469. casadi/libcasadi.so.3.7 +0 -0
  470. casadi/libcasadi_conic_cbc.so +0 -0
  471. casadi/libcasadi_conic_cbc.so.3.7 +0 -0
  472. casadi/libcasadi_conic_clp.so +0 -0
  473. casadi/libcasadi_conic_clp.so.3.7 +0 -0
  474. casadi/libcasadi_conic_cplex.so +0 -0
  475. casadi/libcasadi_conic_cplex.so.3.7 +0 -0
  476. casadi/libcasadi_conic_gurobi.so +0 -0
  477. casadi/libcasadi_conic_gurobi.so.3.7 +0 -0
  478. casadi/libcasadi_conic_hpipm.so +0 -0
  479. casadi/libcasadi_conic_hpipm.so.3.7 +0 -0
  480. casadi/libcasadi_conic_ipqp.so +0 -0
  481. casadi/libcasadi_conic_ipqp.so.3.7 +0 -0
  482. casadi/libcasadi_conic_nlpsol.so +0 -0
  483. casadi/libcasadi_conic_nlpsol.so.3.7 +0 -0
  484. casadi/libcasadi_conic_osqp.so +0 -0
  485. casadi/libcasadi_conic_osqp.so.3.7 +0 -0
  486. casadi/libcasadi_conic_qpoases.so +0 -0
  487. casadi/libcasadi_conic_qpoases.so.3.7 +0 -0
  488. casadi/libcasadi_conic_qrqp.so +0 -0
  489. casadi/libcasadi_conic_qrqp.so.3.7 +0 -0
  490. casadi/libcasadi_conic_superscs.so +0 -0
  491. casadi/libcasadi_conic_superscs.so.3.7 +0 -0
  492. casadi/libcasadi_integrator_collocation.so +0 -0
  493. casadi/libcasadi_integrator_collocation.so.3.7 +0 -0
  494. casadi/libcasadi_integrator_cvodes.so +0 -0
  495. casadi/libcasadi_integrator_cvodes.so.3.7 +0 -0
  496. casadi/libcasadi_integrator_idas.so +0 -0
  497. casadi/libcasadi_integrator_idas.so.3.7 +0 -0
  498. casadi/libcasadi_interpolant_bspline.so +0 -0
  499. casadi/libcasadi_interpolant_bspline.so.3.7 +0 -0
  500. casadi/libcasadi_interpolant_linear.so +0 -0
  501. casadi/libcasadi_interpolant_linear.so.3.7 +0 -0
  502. casadi/libcasadi_linsol_lapacklu.so +0 -0
  503. casadi/libcasadi_linsol_lapacklu.so.3.7 +0 -0
  504. casadi/libcasadi_linsol_lapackqr.so +0 -0
  505. casadi/libcasadi_linsol_lapackqr.so.3.7 +0 -0
  506. casadi/libcasadi_linsol_ldl.so +0 -0
  507. casadi/libcasadi_linsol_ldl.so.3.7 +0 -0
  508. casadi/libcasadi_linsol_mumps.so +0 -0
  509. casadi/libcasadi_linsol_mumps.so.3.7 +0 -0
  510. casadi/libcasadi_linsol_qr.so +0 -0
  511. casadi/libcasadi_linsol_qr.so.3.7 +0 -0
  512. casadi/libcasadi_linsol_symbolicqr.so +0 -0
  513. casadi/libcasadi_linsol_symbolicqr.so.3.7 +0 -0
  514. casadi/libcasadi_nlpsol_ampl.so +0 -0
  515. casadi/libcasadi_nlpsol_ampl.so.3.7 +0 -0
  516. casadi/libcasadi_nlpsol_blocksqp.so +0 -0
  517. casadi/libcasadi_nlpsol_blocksqp.so.3.7 +0 -0
  518. casadi/libcasadi_nlpsol_bonmin.so +0 -0
  519. casadi/libcasadi_nlpsol_bonmin.so.3.7 +0 -0
  520. casadi/libcasadi_nlpsol_feasiblesqpmethod.so +0 -0
  521. casadi/libcasadi_nlpsol_feasiblesqpmethod.so.3.7 +0 -0
  522. casadi/libcasadi_nlpsol_ipopt.so +0 -0
  523. casadi/libcasadi_nlpsol_ipopt.so.3.7 +0 -0
  524. casadi/libcasadi_nlpsol_knitro.so +0 -0
  525. casadi/libcasadi_nlpsol_knitro.so.3.7 +0 -0
  526. casadi/libcasadi_nlpsol_qrsqp.so +0 -0
  527. casadi/libcasadi_nlpsol_qrsqp.so.3.7 +0 -0
  528. casadi/libcasadi_nlpsol_scpgen.so +0 -0
  529. casadi/libcasadi_nlpsol_scpgen.so.3.7 +0 -0
  530. casadi/libcasadi_nlpsol_snopt.so +0 -0
  531. casadi/libcasadi_nlpsol_snopt.so.3.7 +0 -0
  532. casadi/libcasadi_nlpsol_sqpmethod.so +0 -0
  533. casadi/libcasadi_nlpsol_sqpmethod.so.3.7 +0 -0
  534. casadi/libcasadi_nlpsol_worhp.so +0 -0
  535. casadi/libcasadi_nlpsol_worhp.so.3.7 +0 -0
  536. casadi/libcasadi_rootfinder_fast_newton.so +0 -0
  537. casadi/libcasadi_rootfinder_fast_newton.so.3.7 +0 -0
  538. casadi/libcasadi_rootfinder_newton.so +0 -0
  539. casadi/libcasadi_rootfinder_newton.so.3.7 +0 -0
  540. casadi/libcasadi_sundials_common.so +0 -0
  541. casadi/libcasadi_sundials_common.so.3.7 +0 -0
  542. casadi/libindirect.a +0 -0
  543. casadi/liblinsys.a +0 -0
  544. casadi/libosqp.a +0 -0
  545. casadi/libqdldl.a +0 -0
  546. casadi/libsuperscs.a +0 -0
  547. casadi/pkgconfig/blas.pc +11 -0
  548. casadi/pkgconfig/bonmin.pc +1 -1
  549. casadi/pkgconfig/casadi.pc +1 -1
  550. casadi/pkgconfig/cbc.pc +2 -2
  551. casadi/pkgconfig/cgl.pc +2 -2
  552. casadi/pkgconfig/clp.pc +1 -1
  553. casadi/pkgconfig/coinutils.pc +1 -1
  554. casadi/pkgconfig/lapack.pc +11 -0
  555. casadi/pkgconfig/openblas.pc +1 -1
  556. casadi/pkgconfig/osi-cbc.pc +1 -1
  557. casadi/pkgconfig/osi-clp.pc +1 -1
  558. casadi/pkgconfig/osi-unittests.pc +1 -1
  559. casadi/pkgconfig/osi.pc +1 -1
  560. {casadi-3.6.3.dist-info → casadi-3.6.5.dist-info}/METADATA +11 -3
  561. casadi-3.6.5.dist-info/RECORD +987 -0
  562. casadi/libCbc.so.3.10.6 +0 -0
  563. casadi/libCbcSolver.so.3.10.6 +0 -0
  564. casadi/libCgl.so.1.10.4 +0 -0
  565. casadi/libClp.so.1.14.7 +0 -0
  566. casadi/libCoinUtils.so.3.11.6 +0 -0
  567. casadi/libOsiClp.so.1.14.7 +0 -0
  568. casadi/libbonmin.so.4.8.8 +0 -0
  569. casadi-3.6.3.dist-info/RECORD +0 -581
  570. /casadi/{libOsi.so.1.13.7 → libOsi.so.1.13.9} +0 -0
  571. {casadi-3.6.3.dist-info → casadi-3.6.5.dist-info}/WHEEL +0 -0
@@ -0,0 +1,140 @@
1
+ // $Id$
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
+ #ifndef CglStored_H
7
+ #define CglStored_H
8
+
9
+ #include <string>
10
+
11
+ #include "CglCutGenerator.hpp"
12
+
13
+ class CoinWarmStartBasis;
14
+ class CglTreeProbingInfo;
15
+ /** Stored Cut Generator Class */
16
+ class CglStored : public CglCutGenerator {
17
+
18
+ public:
19
+ /**@name Generate Cuts */
20
+ //@{
21
+ /** Generate Mixed Integer Stored cuts for the model of the
22
+ solver interface, si.
23
+
24
+ Insert the generated cuts into OsiCut, cs.
25
+
26
+ This generator just looks at previously stored cuts
27
+ and inserts any that are violated by enough
28
+ */
29
+ virtual void generateCuts(const OsiSolverInterface &si, OsiCuts &cs,
30
+ const CglTreeInfo info = CglTreeInfo());
31
+ //@}
32
+
33
+ /**@name Change criterion on whether to include cut.
34
+ Violations of more than this will be added to current cut list
35
+ (default 1.0e-5) */
36
+ //@{
37
+ /// Set
38
+ inline void setRequiredViolation(double value)
39
+ {
40
+ requiredViolation_ = value;
41
+ }
42
+ /// Get
43
+ inline double getRequiredViolation() const
44
+ {
45
+ return requiredViolation_;
46
+ }
47
+ /// Takes over ownership of probing info
48
+ inline void setProbingInfo(CglTreeProbingInfo *info)
49
+ {
50
+ probingInfo_ = info;
51
+ }
52
+ //@}
53
+
54
+ /**@name Cut stuff */
55
+ //@{
56
+ /// Add cuts
57
+ void addCut(const OsiCuts &cs);
58
+ /// Add a row cut
59
+ void addCut(const OsiRowCut &cut);
60
+ /// Add a row cut from a packed vector
61
+ void addCut(double lb, double ub, const CoinPackedVector &vector);
62
+ /// Add a row cut from elements
63
+ void addCut(double lb, double ub, int size, const int *colIndices, const double *elements);
64
+ inline int sizeRowCuts() const
65
+ {
66
+ return cuts_.sizeRowCuts();
67
+ }
68
+ const OsiRowCut *rowCutPointer(int index) const
69
+ {
70
+ return cuts_.rowCutPtr(index);
71
+ }
72
+ /// Save stuff
73
+ void saveStuff(double bestObjective, const double *bestSolution,
74
+ const double *lower, const double *upper);
75
+ /// Best solution (or NULL)
76
+ inline const double *bestSolution() const
77
+ {
78
+ return bestSolution_;
79
+ }
80
+ /// Best objective
81
+ double bestObjective() const;
82
+ /// Tight lower bounds
83
+ const double *tightLower() const
84
+ {
85
+ return bounds_;
86
+ }
87
+ /// Tight upper bounds
88
+ const double *tightUpper() const
89
+ {
90
+ return bounds_ + numberColumns_;
91
+ }
92
+ //@}
93
+
94
+ /**@name Constructors and destructors */
95
+ //@{
96
+ /// Default constructor
97
+ CglStored(int numberColumns = 0);
98
+
99
+ /// Copy constructor
100
+ CglStored(const CglStored &rhs);
101
+
102
+ /// Constructor from file
103
+ CglStored(const char *fileName);
104
+
105
+ /// Clone
106
+ virtual CglCutGenerator *clone() const;
107
+
108
+ /// Assignment operator
109
+ CglStored &
110
+ operator=(const CglStored &rhs);
111
+
112
+ /// Destructor
113
+ virtual ~CglStored();
114
+ //@}
115
+
116
+ protected:
117
+ // Protected member methods
118
+
119
+ // Protected member data
120
+
121
+ /**@name Protected member data */
122
+ //@{
123
+ /// Only add if more than this requiredViolation
124
+ double requiredViolation_;
125
+ /// Pointer to probing information
126
+ CglTreeProbingInfo *probingInfo_;
127
+ /// Cuts
128
+ OsiCuts cuts_;
129
+ /// Number of columns in model
130
+ int numberColumns_;
131
+ /// Best solution (objective at end)
132
+ double *bestSolution_;
133
+ /// Tight bounds
134
+ double *bounds_;
135
+ //@}
136
+ };
137
+ #endif
138
+
139
+ /* vi: softtabstop=2 shiftwidth=2 expandtab tabstop=2
140
+ */
@@ -0,0 +1,216 @@
1
+ // $Id$
2
+ // Copyright (C) 2000, 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
+ #ifndef CglTreeInfo_H
7
+ #define CglTreeInfo_H
8
+
9
+ #include "OsiCuts.hpp"
10
+ #include "OsiSolverInterface.hpp"
11
+ #include "CoinHelperFunctions.hpp"
12
+ class CglStored;
13
+ /** Information about where the cut generator is invoked from. */
14
+
15
+ class CglTreeInfo {
16
+ public:
17
+ /// The level of the search tree node
18
+ int level;
19
+ /** How many times the cut generator was already invoked in this search tree
20
+ node */
21
+ int pass;
22
+ /** The number of rows in the original formulation. Some generators may not
23
+ want to consider already generated rows when generating new ones. */
24
+ int formulation_rows;
25
+ /** Options
26
+ 1 - treat costed integers as important
27
+ 2 - switch off some stuff as variables semi-integer
28
+ 4 - set global cut flag if at root node
29
+ 8 - set global cut flag if at root node and first pass
30
+ 16 - set global cut flag and make cuts globally valid
31
+ 32 - last round of cuts did nothing - maybe be more aggressive
32
+ 64 - in preprocessing stage
33
+ 128 - looks like solution
34
+ 256 - want alternate cuts
35
+ 512 - in sub tree (i.e. parent model)
36
+ 1024 - in must call again mode or after everything mode
37
+ */
38
+ int options;
39
+ /// Set true if in tree (to avoid ambiguity at first branch)
40
+ bool inTree;
41
+ /** nonzero if called from child of main model
42
+ 1 if heuristic run
43
+ 2 if doing full search
44
+ */
45
+ int hasParent;
46
+ /// parent solver
47
+ OsiSolverInterface *parentSolver;
48
+ /// Original columns (if preprocessed)
49
+ int *originalColumns;
50
+ /** Replacement array. Before Branch and Cut it may be beneficial to strengthen rows
51
+ rather than adding cuts. If this array is not NULL then the cut generator can
52
+ place a pointer to the stronger cut in this array which is number of rows in size.
53
+
54
+ A null (i.e. zero elements and free rhs) cut indicates that the row is useless
55
+ and can be removed.
56
+
57
+ The calling function can then replace those rows.
58
+ */
59
+ OsiRowCut **strengthenRow;
60
+ /// Optional pointer to thread specific random number generator
61
+ CoinThreadRandom *randomNumberGenerator;
62
+ /// Default constructor
63
+ CglTreeInfo();
64
+
65
+ /// Copy constructor
66
+ CglTreeInfo(
67
+ const CglTreeInfo &);
68
+ /// Clone
69
+ virtual CglTreeInfo *clone() const;
70
+
71
+ /// Assignment operator
72
+ CglTreeInfo &
73
+ operator=(
74
+ const CglTreeInfo &rhs);
75
+
76
+ /// Destructor
77
+ virtual ~CglTreeInfo();
78
+ /// Take action if cut generator can fix a variable (toValue -1 for down, +1 for up)
79
+ virtual bool fixes(int, int, int, bool) { return false; }
80
+ /** Initalizes fixing arrays etc - returns >0 if we want to save info
81
+ 0 if we don't and -1 if is to be used */
82
+ virtual int initializeFixing(const OsiSolverInterface *) { return 0; }
83
+ };
84
+
85
+ /** Derived class to pick up probing info. */
86
+ typedef struct {
87
+ //unsigned int oneFixed:1; // nonzero if variable to 1 fixes all
88
+ //unsigned int sequence:31; // variable (in matrix) (but also see cliqueRow_)
89
+ unsigned int fixes;
90
+ } CliqueEntry;
91
+
92
+ class CglTreeProbingInfo : public CglTreeInfo {
93
+ public:
94
+ /// Default constructor
95
+ CglTreeProbingInfo();
96
+ /// Constructor from model
97
+ CglTreeProbingInfo(const OsiSolverInterface *model);
98
+
99
+ /// Copy constructor
100
+ CglTreeProbingInfo(
101
+ const CglTreeProbingInfo &);
102
+ /// Clone
103
+ virtual CglTreeInfo *clone() const;
104
+
105
+ /// Assignment operator
106
+ CglTreeProbingInfo &
107
+ operator=(
108
+ const CglTreeProbingInfo &rhs);
109
+
110
+ /// Destructor
111
+ virtual ~CglTreeProbingInfo();
112
+ OsiSolverInterface *analyze(const OsiSolverInterface &si, int createSolver = 0,
113
+ int numberExtraCliques = 0, const CoinBigIndex *starts = NULL,
114
+ const CliqueEntry *entries = NULL, const char *type = NULL);
115
+ /** Take action if cut generator can fix a variable
116
+ (toValue -1 for down, +1 for up)
117
+ Returns true if still room, false if not */
118
+ virtual bool fixes(int variable, int toValue, int fixedVariable, bool fixedToLower);
119
+ /** Initalizes fixing arrays etc - returns >0 if we want to save info
120
+ 0 if we don't and -1 if is to be used */
121
+ virtual int initializeFixing(const OsiSolverInterface *model);
122
+ /// Fix entries in a solver using implications
123
+ int fixColumns(OsiSolverInterface &si) const;
124
+ /// Fix entries in a solver using implications for one variable
125
+ int fixColumns(int iColumn, int value, OsiSolverInterface &si) const;
126
+ /// Packs down entries
127
+ int packDown();
128
+ /// Generate cuts from implications
129
+ void generateCuts(const OsiSolverInterface &si, OsiCuts &cs,
130
+ const CglTreeInfo info) const;
131
+ /// Entries for fixing variables
132
+ inline CliqueEntry *fixEntries()
133
+ {
134
+ convert();
135
+ return fixEntry_;
136
+ }
137
+ /// Starts of integer variable going to zero
138
+ inline int *toZero()
139
+ {
140
+ convert();
141
+ return toZero_;
142
+ }
143
+ /// Starts of integer variable going to one
144
+ inline int *toOne()
145
+ {
146
+ convert();
147
+ return toOne_;
148
+ }
149
+ /// List of 0-1 integer variables
150
+ inline int *integerVariable() const
151
+ {
152
+ return integerVariable_;
153
+ }
154
+ /// Backward look up
155
+ inline int *backward() const
156
+ {
157
+ return backward_;
158
+ }
159
+ /// Number of variables
160
+ inline int numberVariables() const
161
+ {
162
+ return numberVariables_;
163
+ }
164
+ /// Number of 0-1 variables
165
+ inline int numberIntegers() const
166
+ {
167
+ return numberIntegers_;
168
+ }
169
+
170
+ private:
171
+ /// Converts to ordered
172
+ void convert();
173
+
174
+ protected:
175
+ /// Entries for fixing variables
176
+ CliqueEntry *fixEntry_;
177
+ /// Starts of integer variable going to zero
178
+ int *toZero_;
179
+ /// Starts of integer variable going to one
180
+ int *toOne_;
181
+ /// List of 0-1 integer variables
182
+ int *integerVariable_;
183
+ /// Backward look up
184
+ int *backward_;
185
+ /// Entries for fixing variable when collecting
186
+ int *fixingEntry_;
187
+ /// Number of variables
188
+ int numberVariables_;
189
+ /// Number of 0-1 variables
190
+ int numberIntegers_;
191
+ /// Maximum number in fixEntry_
192
+ int maximumEntries_;
193
+ /// Number entries in fixingEntry_ (and fixEntry_) or -2 if correct style
194
+ int numberEntries_;
195
+ };
196
+ inline int sequenceInCliqueEntry(const CliqueEntry &cEntry)
197
+ {
198
+ return cEntry.fixes & 0x7fffffff;
199
+ }
200
+ inline void setSequenceInCliqueEntry(CliqueEntry &cEntry, int sequence)
201
+ {
202
+ cEntry.fixes = sequence | (cEntry.fixes & 0x80000000);
203
+ }
204
+ inline bool oneFixesInCliqueEntry(const CliqueEntry &cEntry)
205
+ {
206
+ return (cEntry.fixes & 0x80000000) != 0;
207
+ }
208
+ inline void setOneFixesInCliqueEntry(CliqueEntry &cEntry, bool oneFixes)
209
+ {
210
+ cEntry.fixes = (oneFixes ? 0x80000000 : 0) | (cEntry.fixes & 0x7fffffff);
211
+ }
212
+
213
+ #endif
214
+
215
+ /* vi: softtabstop=2 shiftwidth=2 expandtab tabstop=2
216
+ */