casadi 3.6.4__cp310-none-manylinux2014_i686.whl → 3.6.6__cp310-none-manylinux2014_i686.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.
- casadi/_casadi.so +0 -0
- casadi/casadi.py +984 -500
- casadi/cbc +0 -0
- casadi/clp +0 -0
- casadi/cmake/casadi-config-version.cmake +1 -1
- casadi/cmake/highs/highs-config.cmake +6 -13
- casadi/cmake/highs/highs-targets-release.cmake +13 -13
- casadi/cmake/highs/highs-targets.cmake +13 -10
- casadi/highs +0 -0
- casadi/include/casadi/casadi.i +33 -15
- casadi/include/casadi/casadi_c.h +2 -0
- casadi/include/casadi/config.h +8 -8
- casadi/include/casadi/core/casadi_common.hpp +1 -0
- casadi/include/casadi/core/casadi_misc.hpp +13 -0
- casadi/include/casadi/core/casadi_types.hpp +3 -2
- casadi/include/casadi/core/code_generator.hpp +59 -2
- casadi/include/casadi/core/core.hpp +1 -0
- casadi/include/casadi/core/generic_expression.hpp +1 -1
- casadi/include/casadi/core/generic_type.hpp +25 -1
- casadi/include/casadi/core/global_options.hpp +2 -0
- casadi/include/casadi/core/matrix_decl.hpp +15 -0
- casadi/include/casadi/core/mx.hpp +13 -3
- casadi/include/casadi/core/optistack.hpp +23 -0
- casadi/include/casadi/core/runtime/casadi_nlp.hpp +133 -6
- casadi/include/casadi/core/runtime/casadi_ocp_block.hpp +55 -0
- casadi/include/casadi/core/runtime/casadi_oracle.hpp +44 -0
- casadi/include/casadi/core/runtime/casadi_oracle_callback.hpp +39 -0
- casadi/include/casadi/core/runtime/casadi_runtime.hpp +4 -1
- casadi/include/casadi/core/runtime/casadi_scaled_copy.hpp +31 -0
- casadi/include/casadi/core/runtime/casadi_sqpmethod.hpp +11 -1
- casadi/include/casadi/core/serializing_stream.hpp +2 -2
- casadi/include/casadi/core/sparsity.hpp +12 -3
- casadi/include/casadi/core/tools.hpp +67 -0
- casadi/include/casadi/doc.i +2283 -1491
- casadi/include/casadi/doc_merged.i +1522 -1065
- casadi/include/casadi/mem.h +1 -0
- casadi/include/coin-or/IpAlgBuilder.hpp +417 -0
- casadi/include/coin-or/IpAlgStrategy.hpp +201 -0
- casadi/include/coin-or/IpAlgTypes.hpp +64 -0
- casadi/include/coin-or/IpAugSystemSolver.hpp +212 -0
- casadi/include/coin-or/IpBlas.hpp +426 -0
- casadi/include/coin-or/IpCachedResults.hpp +897 -0
- casadi/include/coin-or/IpCompoundMatrix.hpp +423 -0
- casadi/include/coin-or/IpCompoundSymMatrix.hpp +348 -0
- casadi/include/coin-or/IpCompoundVector.hpp +395 -0
- casadi/include/coin-or/IpConvCheck.hpp +97 -0
- casadi/include/coin-or/IpDebug.hpp +167 -0
- casadi/include/coin-or/IpDenseVector.hpp +626 -0
- casadi/include/coin-or/IpDiagMatrix.hpp +158 -0
- casadi/include/coin-or/IpEqMultCalculator.hpp +76 -0
- casadi/include/coin-or/IpException.hpp +156 -0
- casadi/include/coin-or/IpExpansionMatrix.hpp +245 -0
- casadi/include/coin-or/IpGenTMatrix.hpp +290 -0
- casadi/include/coin-or/IpHessianUpdater.hpp +73 -0
- casadi/include/coin-or/IpIdentityMatrix.hpp +167 -0
- casadi/include/coin-or/IpIpoptAlg.hpp +257 -0
- casadi/include/coin-or/IpIpoptApplication.hpp +367 -0
- casadi/include/coin-or/IpIpoptCalculatedQuantities.hpp +1009 -0
- casadi/include/coin-or/IpIpoptData.hpp +966 -0
- casadi/include/coin-or/IpIpoptNLP.hpp +328 -0
- casadi/include/coin-or/IpIterateInitializer.hpp +68 -0
- casadi/include/coin-or/IpIteratesVector.hpp +840 -0
- casadi/include/coin-or/IpIterationOutput.hpp +78 -0
- casadi/include/coin-or/IpJournalist.hpp +573 -0
- casadi/include/coin-or/IpLapack.hpp +227 -0
- casadi/include/coin-or/IpLibraryLoader.hpp +76 -0
- casadi/include/coin-or/IpLineSearch.hpp +106 -0
- casadi/include/coin-or/IpLinearSolvers.h +46 -0
- casadi/include/coin-or/IpMatrix.hpp +434 -0
- casadi/include/coin-or/IpMuUpdate.hpp +77 -0
- casadi/include/coin-or/IpNLP.hpp +306 -0
- casadi/include/coin-or/IpNLPScaling.hpp +582 -0
- casadi/include/coin-or/IpObserver.hpp +422 -0
- casadi/include/coin-or/IpOptionsList.hpp +412 -0
- casadi/include/coin-or/IpOrigIpoptNLP.hpp +603 -0
- casadi/include/coin-or/IpPDSystemSolver.hpp +137 -0
- casadi/include/coin-or/IpReferenced.hpp +262 -0
- casadi/include/coin-or/IpRegOptions.hpp +1152 -0
- casadi/include/coin-or/IpReturnCodes.h +23 -0
- casadi/include/coin-or/IpReturnCodes.hpp +18 -0
- casadi/include/coin-or/IpReturnCodes.inc +71 -0
- casadi/include/coin-or/IpReturnCodes_inc.h +45 -0
- casadi/include/coin-or/IpScaledMatrix.hpp +291 -0
- casadi/include/coin-or/IpSearchDirCalculator.hpp +72 -0
- casadi/include/coin-or/IpSmartPtr.hpp +865 -0
- casadi/include/coin-or/IpSolveStatistics.hpp +210 -0
- casadi/include/coin-or/IpSparseSymLinearSolverInterface.hpp +260 -0
- casadi/include/coin-or/IpStdAugSystemSolver.cpp +555 -0
- casadi/include/coin-or/IpStdCInterface.h +428 -0
- casadi/include/coin-or/IpSumSymMatrix.hpp +186 -0
- casadi/include/coin-or/IpSymLinearSolver.hpp +141 -0
- casadi/include/coin-or/IpSymMatrix.hpp +167 -0
- casadi/include/coin-or/IpSymScaledMatrix.hpp +255 -0
- casadi/include/coin-or/IpSymTMatrix.hpp +275 -0
- casadi/include/coin-or/IpTNLP.hpp +820 -0
- casadi/include/coin-or/IpTNLPAdapter.hpp +648 -0
- casadi/include/coin-or/IpTNLPReducer.hpp +274 -0
- casadi/include/coin-or/IpTaggedObject.hpp +128 -0
- casadi/include/coin-or/IpTimedTask.hpp +218 -0
- casadi/include/coin-or/IpTimingStatistics.hpp +323 -0
- casadi/include/coin-or/IpTripletHelper.hpp +308 -0
- casadi/include/coin-or/IpTypes.h +81 -0
- casadi/include/coin-or/IpTypes.hpp +30 -0
- casadi/include/coin-or/IpUtils.hpp +166 -0
- casadi/include/coin-or/IpVector.hpp +892 -0
- casadi/include/coin-or/IpZeroSymMatrix.hpp +155 -0
- casadi/include/coin-or/IpoptConfig.h +45 -0
- casadi/include/coin-or/SensAlgorithm.hpp +114 -0
- casadi/include/coin-or/SensApplication.hpp +188 -0
- casadi/include/coin-or/SensBacksolver.hpp +36 -0
- casadi/include/coin-or/SensMeasurement.hpp +56 -0
- casadi/include/coin-or/SensPCalculator.hpp +137 -0
- casadi/include/coin-or/SensRegOp.hpp +21 -0
- casadi/include/coin-or/SensSchurData.hpp +182 -0
- casadi/include/coin-or/SensSchurDriver.hpp +118 -0
- casadi/include/coin-or/SensSimpleBacksolver.hpp +49 -0
- casadi/include/coin-or/SensStepCalc.hpp +85 -0
- casadi/include/coin-or/SensUtils.hpp +63 -0
- casadi/include/coin-or/metis/defs.h +161 -0
- casadi/include/coin-or/metis/macros.h +143 -0
- casadi/include/coin-or/metis/metis.h +37 -0
- casadi/include/coin-or/metis/proto.h +505 -0
- casadi/include/coin-or/metis/rename.h +418 -0
- casadi/include/coin-or/metis/struct.h +251 -0
- casadi/include/coin-or/mumps/dmumps_c.h +142 -0
- casadi/include/coin-or/mumps/mumps_c_types.h +72 -0
- casadi/include/coin-or/mumps/mumps_compat.h +27 -0
- casadi/include/coin-or/mumps/mumps_int_def.h +11 -0
- casadi/include/coin-or/mumps/mumps_mpi.h +67 -0
- casadi/include/daqp/api.h +46 -0
- casadi/include/daqp/auxiliary.h +29 -0
- casadi/include/daqp/bnb.h +32 -0
- casadi/include/daqp/codegen.h +18 -0
- casadi/include/daqp/constants.h +92 -0
- casadi/include/daqp/daqp.h +22 -0
- casadi/include/daqp/daqp_prox.h +18 -0
- casadi/include/daqp/factorization.h +18 -0
- casadi/include/daqp/types.h +161 -0
- casadi/include/daqp/utils.h +44 -0
- casadi/include/highs/HConfig.h +6 -5
- casadi/include/highs/Highs.h +93 -23
- casadi/include/highs/filereaderlp/def.hpp +19 -0
- casadi/include/highs/interfaces/highs_c_api.h +200 -24
- casadi/include/highs/io/Filereader.h +1 -1
- casadi/include/highs/io/FilereaderEms.h +1 -1
- casadi/include/highs/io/FilereaderLp.h +1 -1
- casadi/include/highs/io/FilereaderMps.h +1 -1
- casadi/include/highs/io/HMPSIO.h +1 -1
- casadi/include/highs/io/HMpsFF.h +5 -3
- casadi/include/highs/io/HighsIO.h +18 -8
- casadi/include/highs/io/LoadOptions.h +1 -1
- casadi/include/highs/ipm/IpxSolution.h +35 -0
- casadi/include/highs/ipm/IpxWrapper.h +1 -1
- casadi/include/highs/ipm/basiclu/basiclu.h +161 -0
- casadi/include/highs/ipm/basiclu/basiclu_factorize.h +247 -0
- casadi/include/highs/ipm/basiclu/basiclu_get_factors.h +108 -0
- casadi/include/highs/ipm/basiclu/basiclu_initialize.h +119 -0
- casadi/include/highs/ipm/basiclu/basiclu_obj_factorize.h +34 -0
- casadi/include/highs/ipm/basiclu/basiclu_obj_free.h +19 -0
- casadi/include/highs/ipm/basiclu/basiclu_obj_get_factors.h +34 -0
- casadi/include/highs/ipm/basiclu/basiclu_obj_initialize.h +46 -0
- casadi/include/highs/ipm/basiclu/basiclu_obj_solve_dense.h +29 -0
- casadi/include/highs/ipm/basiclu/basiclu_obj_solve_for_update.h +42 -0
- casadi/include/highs/ipm/basiclu/basiclu_obj_solve_sparse.h +32 -0
- casadi/include/highs/ipm/basiclu/basiclu_obj_update.h +31 -0
- casadi/include/highs/ipm/basiclu/basiclu_object.h +30 -0
- casadi/include/highs/ipm/basiclu/basiclu_solve_dense.h +75 -0
- casadi/include/highs/ipm/basiclu/basiclu_solve_for_update.h +169 -0
- casadi/include/highs/ipm/basiclu/basiclu_solve_sparse.h +112 -0
- casadi/include/highs/ipm/basiclu/basiclu_update.h +125 -0
- casadi/include/highs/ipm/basiclu/lu_def.h +39 -0
- casadi/include/highs/ipm/basiclu/lu_file.h +21 -0
- casadi/include/highs/ipm/basiclu/lu_internal.h +220 -0
- casadi/include/highs/ipm/basiclu/lu_list.h +168 -0
- casadi/include/highs/ipm/ipx/basiclu_kernel.h +20 -0
- casadi/include/highs/ipm/ipx/basiclu_wrapper.h +47 -0
- casadi/include/highs/ipm/ipx/basis.h +351 -0
- casadi/include/highs/ipm/ipx/conjugate_residuals.h +74 -0
- casadi/include/highs/ipm/ipx/control.h +163 -0
- casadi/include/highs/ipm/ipx/crossover.h +157 -0
- casadi/include/highs/ipm/ipx/diagonal_precond.h +45 -0
- casadi/include/highs/ipm/ipx/forrest_tomlin.h +102 -0
- casadi/include/highs/ipm/ipx/guess_basis.h +21 -0
- casadi/include/highs/ipm/ipx/indexed_vector.h +113 -0
- casadi/include/highs/ipm/ipx/info.h +27 -0
- casadi/include/highs/ipm/ipx/ipm.h +94 -0
- casadi/include/highs/ipm/ipx/ipx_c.h +47 -0
- casadi/include/highs/ipm/ipx/ipx_config.h +9 -0
- casadi/include/highs/ipm/ipx/ipx_info.h +111 -0
- casadi/include/highs/ipm/ipx/ipx_internal.h +88 -0
- casadi/include/highs/ipm/ipx/ipx_parameters.h +75 -0
- casadi/include/highs/ipm/ipx/ipx_status.h +57 -0
- casadi/include/highs/ipm/ipx/iterate.h +328 -0
- casadi/include/highs/ipm/ipx/kkt_solver.h +70 -0
- casadi/include/highs/ipm/ipx/kkt_solver_basis.h +66 -0
- casadi/include/highs/ipm/ipx/kkt_solver_diag.h +48 -0
- casadi/include/highs/ipm/ipx/linear_operator.h +26 -0
- casadi/include/highs/ipm/ipx/lp_solver.h +201 -0
- casadi/include/highs/ipm/ipx/lu_factorization.h +79 -0
- casadi/include/highs/ipm/ipx/lu_update.h +129 -0
- casadi/include/highs/ipm/ipx/maxvolume.h +54 -0
- casadi/include/highs/ipm/ipx/model.h +409 -0
- casadi/include/highs/ipm/ipx/multistream.h +52 -0
- casadi/include/highs/ipm/ipx/normal_matrix.h +44 -0
- casadi/include/highs/ipm/ipx/power_method.h +44 -0
- casadi/include/highs/ipm/ipx/sparse_matrix.h +195 -0
- casadi/include/highs/ipm/ipx/sparse_utils.h +58 -0
- casadi/include/highs/ipm/ipx/splitted_normal_matrix.h +63 -0
- casadi/include/highs/ipm/ipx/starting_basis.h +39 -0
- casadi/include/highs/ipm/ipx/symbolic_invert.h +29 -0
- casadi/include/highs/ipm/ipx/timer.h +24 -0
- casadi/include/highs/ipm/ipx/utils.h +39 -0
- casadi/include/highs/lp_data/HConst.h +20 -10
- casadi/include/highs/lp_data/HStruct.h +23 -1
- casadi/include/highs/lp_data/HighsAnalysis.h +1 -1
- casadi/include/highs/lp_data/HighsCallback.h +10 -3
- casadi/include/highs/lp_data/HighsCallbackStruct.h +31 -5
- casadi/include/highs/lp_data/HighsDebug.h +1 -1
- casadi/include/highs/lp_data/HighsInfo.h +20 -2
- casadi/include/highs/lp_data/HighsInfoDebug.h +1 -1
- casadi/include/highs/lp_data/HighsLp.h +17 -1
- casadi/include/highs/lp_data/HighsLpSolverObject.h +1 -1
- casadi/include/highs/lp_data/HighsLpUtils.h +19 -19
- casadi/include/highs/lp_data/HighsModelUtils.h +1 -1
- casadi/include/highs/lp_data/HighsOptions.h +237 -10
- casadi/include/highs/lp_data/HighsRanging.h +1 -1
- casadi/include/highs/lp_data/HighsRuntimeOptions.h +2 -2
- casadi/include/highs/lp_data/HighsSolution.h +2 -2
- casadi/include/highs/lp_data/HighsSolutionDebug.h +1 -1
- casadi/include/highs/lp_data/HighsSolve.h +3 -1
- casadi/include/highs/lp_data/HighsStatus.h +1 -1
- casadi/include/highs/mip/HighsCliqueTable.h +4 -4
- casadi/include/highs/mip/HighsConflictPool.h +1 -1
- casadi/include/highs/mip/HighsCutGeneration.h +1 -1
- casadi/include/highs/mip/HighsCutPool.h +2 -2
- casadi/include/highs/mip/HighsDebugSol.h +22 -29
- casadi/include/highs/mip/HighsDomain.h +10 -2
- casadi/include/highs/mip/HighsDomainChange.h +1 -1
- casadi/include/highs/mip/HighsDynamicRowMatrix.h +5 -3
- casadi/include/highs/mip/HighsGFkSolve.h +3 -3
- casadi/include/highs/mip/HighsImplications.h +3 -3
- casadi/include/highs/mip/HighsLpAggregator.h +1 -1
- casadi/include/highs/mip/HighsLpRelaxation.h +6 -1
- casadi/include/highs/mip/HighsMipSolver.h +4 -2
- casadi/include/highs/mip/HighsMipSolverData.h +47 -4
- casadi/include/highs/mip/HighsModkSeparator.h +2 -2
- casadi/include/highs/mip/HighsNodeQueue.h +5 -3
- casadi/include/highs/mip/HighsObjectiveFunction.h +1 -1
- casadi/include/highs/mip/HighsPathSeparator.h +2 -2
- casadi/include/highs/mip/HighsPrimalHeuristics.h +1 -1
- casadi/include/highs/mip/HighsPseudocost.h +35 -23
- casadi/include/highs/mip/HighsRedcostFixing.h +1 -1
- casadi/include/highs/mip/HighsSearch.h +2 -1
- casadi/include/highs/mip/HighsSeparation.h +1 -1
- casadi/include/highs/mip/HighsSeparator.h +1 -1
- casadi/include/highs/mip/HighsTableauSeparator.h +1 -1
- casadi/include/highs/mip/HighsTransformedLp.h +1 -1
- casadi/include/highs/model/HighsHessian.h +5 -0
- casadi/include/highs/model/HighsHessianUtils.h +2 -0
- casadi/include/highs/model/HighsModel.h +10 -1
- casadi/include/highs/parallel/HighsMutex.h +2 -1
- casadi/include/highs/parallel/HighsParallel.h +7 -2
- casadi/include/highs/parallel/HighsTask.h +1 -2
- casadi/include/highs/pdlp/CupdlpWrapper.h +93 -0
- casadi/include/highs/pdlp/cupdlp/cupdlp_cs.h +41 -0
- casadi/include/highs/pdlp/cupdlp/cupdlp_defs.h +423 -0
- casadi/include/highs/pdlp/cupdlp/cupdlp_linalg.h +183 -0
- casadi/include/highs/pdlp/cupdlp/cupdlp_proj.h +19 -0
- casadi/include/highs/pdlp/cupdlp/cupdlp_restart.h +31 -0
- casadi/include/highs/pdlp/cupdlp/cupdlp_scaling_cuda.h +28 -0
- casadi/include/highs/pdlp/cupdlp/cupdlp_solver.h +98 -0
- casadi/include/highs/pdlp/cupdlp/cupdlp_step.h +33 -0
- casadi/include/highs/pdlp/cupdlp/cupdlp_utils.c +1726 -0
- casadi/include/highs/pdqsort/pdqsort.h +532 -0
- casadi/include/highs/presolve/HPresolve.h +27 -14
- casadi/include/highs/presolve/HPresolveAnalysis.h +1 -1
- casadi/include/highs/presolve/HighsPostsolveStack.h +92 -68
- casadi/include/highs/presolve/HighsSymmetry.h +6 -5
- casadi/include/highs/presolve/ICrash.h +8 -2
- casadi/include/highs/presolve/ICrashUtil.h +1 -1
- casadi/include/highs/presolve/ICrashX.h +1 -1
- casadi/include/highs/presolve/PresolveComponent.h +1 -1
- casadi/include/highs/qpsolver/a_asm.hpp +23 -12
- casadi/include/highs/qpsolver/a_quass.hpp +8 -1
- casadi/include/highs/qpsolver/basis.hpp +150 -0
- casadi/include/highs/qpsolver/crashsolution.hpp +12 -0
- casadi/include/highs/qpsolver/dantzigpricing.hpp +72 -0
- casadi/include/highs/qpsolver/devexpricing.hpp +99 -0
- casadi/include/highs/qpsolver/eventhandler.hpp +23 -0
- casadi/include/highs/qpsolver/factor.hpp +400 -0
- casadi/include/highs/qpsolver/feasibility_bounded.hpp +105 -0
- casadi/include/highs/qpsolver/feasibility_highs.hpp +270 -0
- casadi/include/highs/qpsolver/gradient.hpp +39 -0
- casadi/include/highs/qpsolver/instance.hpp +63 -0
- casadi/include/highs/qpsolver/matrix.hpp +335 -0
- casadi/include/highs/qpsolver/pricing.hpp +15 -0
- casadi/include/highs/qpsolver/qpconst.hpp +27 -0
- casadi/include/highs/qpsolver/{vector.hpp → qpvector.hpp} +25 -25
- casadi/include/highs/qpsolver/quass.hpp +1 -1
- casadi/include/highs/qpsolver/ratiotest.hpp +19 -0
- casadi/include/highs/qpsolver/runtime.hpp +38 -0
- casadi/include/highs/qpsolver/settings.hpp +57 -0
- casadi/include/highs/qpsolver/snippets.hpp +29 -0
- casadi/include/highs/qpsolver/statistics.hpp +23 -0
- casadi/include/highs/qpsolver/steepestedgepricing.hpp +167 -0
- casadi/include/highs/simplex/HApp.h +1 -1
- casadi/include/highs/simplex/HEkk.h +52 -18
- casadi/include/highs/simplex/HEkkDual.h +1 -1
- casadi/include/highs/simplex/HEkkDualRHS.h +6 -7
- casadi/include/highs/simplex/HEkkDualRow.h +2 -2
- casadi/include/highs/simplex/HEkkPrimal.h +6 -1
- casadi/include/highs/simplex/HSimplex.h +1 -3
- casadi/include/highs/simplex/HSimplexDebug.h +1 -1
- casadi/include/highs/simplex/HSimplexNla.h +1 -1
- casadi/include/highs/simplex/HSimplexReport.h +1 -1
- casadi/include/highs/simplex/HighsSimplexAnalysis.h +228 -100
- casadi/include/highs/simplex/SimplexConst.h +1 -1
- casadi/include/highs/simplex/SimplexStruct.h +2 -2
- casadi/include/highs/simplex/SimplexTimer.h +1 -1
- casadi/include/highs/test/DevKkt.h +1 -1
- casadi/include/highs/test/KktCh2.h +1 -1
- casadi/include/highs/util/FactorTimer.h +1 -1
- casadi/include/highs/util/HFactor.h +35 -6
- casadi/include/highs/util/HFactorConst.h +1 -1
- casadi/include/highs/util/HFactorDebug.h +1 -1
- casadi/include/highs/util/HSet.h +1 -1
- casadi/include/highs/util/HVector.h +1 -1
- casadi/include/highs/util/HVectorBase.h +1 -1
- casadi/include/highs/util/HighsCDouble.h +3 -3
- casadi/include/highs/util/HighsComponent.h +1 -1
- casadi/include/highs/util/HighsDataStack.h +4 -4
- casadi/include/highs/util/HighsDisjointSets.h +1 -1
- casadi/include/highs/util/HighsHash.h +28 -21
- casadi/include/highs/util/HighsHashTree.h +63 -63
- casadi/include/highs/util/HighsInt.h +1 -1
- casadi/include/highs/util/HighsIntegers.h +8 -9
- casadi/include/highs/util/HighsLinearSumBounds.h +1 -1
- casadi/include/highs/util/HighsMatrixPic.h +1 -1
- casadi/include/highs/util/HighsMatrixSlice.h +9 -6
- casadi/include/highs/util/HighsMatrixUtils.h +1 -1
- casadi/include/highs/util/HighsMemoryAllocation.h +55 -0
- casadi/include/highs/util/HighsRandom.h +27 -15
- casadi/include/highs/util/HighsRbTree.h +2 -2
- casadi/include/highs/util/HighsSort.h +7 -7
- casadi/include/highs/util/HighsSparseMatrix.h +5 -2
- casadi/include/highs/util/HighsSparseVectorSum.h +2 -2
- casadi/include/highs/util/HighsSplay.h +1 -1
- casadi/include/highs/util/HighsTimer.h +18 -9
- casadi/include/highs/util/HighsUtils.h +15 -8
- casadi/include/highs/util/stringutil.h +9 -4
- casadi/include/highs/zstr/strict_fstream.hpp +237 -0
- casadi/include/highs/zstr/zstr.hpp +472 -0
- casadi/include/licenses/daqp-external/LICENSE +21 -0
- casadi/include/licenses/highs-external/{LICENSE → LICENSE.txt} +1 -1
- casadi/include/osqp/constants.h +2 -3
- casadi/include/osqp/version.h +9 -0
- casadi/lib/libtinyxml2.a +0 -0
- casadi/libCbc.so +0 -0
- casadi/libCbc.so.3 +0 -0
- casadi/libCbc.so.3.10.11 +0 -0
- casadi/libCbcSolver.so +0 -0
- casadi/libCbcSolver.so.3 +0 -0
- casadi/libCbcSolver.so.3.10.11 +0 -0
- casadi/libCgl.so +0 -0
- casadi/libCgl.so.1 +0 -0
- casadi/libCgl.so.1.10.8 +0 -0
- casadi/libClp.so +0 -0
- casadi/libClp.so.1 +0 -0
- casadi/libClp.so.1.14.9 +0 -0
- casadi/libClpSolver.so +0 -0
- casadi/libClpSolver.so.1 +0 -0
- casadi/libClpSolver.so.1.14.9 +0 -0
- casadi/libCoinUtils.so +0 -0
- casadi/libCoinUtils.so.3 +0 -0
- casadi/libCoinUtils.so.3.11.10 +0 -0
- casadi/libOsi.so +0 -0
- casadi/libOsi.so.1 +0 -0
- casadi/libOsi.so.1.13.9 +0 -0
- casadi/libOsiCbc.so +0 -0
- casadi/libOsiCbc.so.3 +0 -0
- casadi/libOsiCbc.so.3.10.11 +0 -0
- casadi/libOsiClp.so +0 -0
- casadi/libOsiClp.so.1 +0 -0
- casadi/libOsiClp.so.1.14.9 +0 -0
- casadi/libOsiCommonTests.so +0 -0
- casadi/libOsiCommonTests.so.1 +0 -0
- casadi/libOsiCommonTests.so.1.13.9 +0 -0
- casadi/libbonmin.so +0 -0
- casadi/libbonmin.so.4 +0 -0
- casadi/libbonmin.so.4.8.9 +0 -0
- casadi/libcasadi.so +0 -0
- casadi/libcasadi.so.3.7 +0 -0
- casadi/libcasadi_conic_cbc.so +0 -0
- casadi/libcasadi_conic_cbc.so.3.7 +0 -0
- casadi/libcasadi_conic_clp.so +0 -0
- casadi/libcasadi_conic_clp.so.3.7 +0 -0
- casadi/libcasadi_conic_daqp.so +0 -0
- casadi/libcasadi_conic_daqp.so.3.7 +0 -0
- casadi/libcasadi_conic_gurobi.so +0 -0
- casadi/libcasadi_conic_gurobi.so.3.7 +0 -0
- casadi/libcasadi_conic_highs.so +0 -0
- casadi/libcasadi_conic_highs.so.3.7 +0 -0
- casadi/libcasadi_conic_ipqp.so +0 -0
- casadi/libcasadi_conic_ipqp.so.3.7 +0 -0
- casadi/libcasadi_conic_nlpsol.so +0 -0
- casadi/libcasadi_conic_nlpsol.so.3.7 +0 -0
- casadi/libcasadi_conic_osqp.so +0 -0
- casadi/libcasadi_conic_osqp.so.3.7 +0 -0
- casadi/libcasadi_conic_proxqp.so +0 -0
- casadi/libcasadi_conic_proxqp.so.3.7 +0 -0
- casadi/libcasadi_conic_qpoases.so +0 -0
- casadi/libcasadi_conic_qpoases.so.3.7 +0 -0
- casadi/libcasadi_conic_qrqp.so +0 -0
- casadi/libcasadi_conic_qrqp.so.3.7 +0 -0
- casadi/libcasadi_conic_superscs.so +0 -0
- casadi/libcasadi_conic_superscs.so.3.7 +0 -0
- casadi/libcasadi_integrator_collocation.so +0 -0
- casadi/libcasadi_integrator_collocation.so.3.7 +0 -0
- casadi/libcasadi_integrator_cvodes.so +0 -0
- casadi/libcasadi_integrator_cvodes.so.3.7 +0 -0
- casadi/libcasadi_integrator_idas.so +0 -0
- casadi/libcasadi_integrator_idas.so.3.7 +0 -0
- casadi/libcasadi_integrator_rk.so +0 -0
- casadi/libcasadi_integrator_rk.so.3.7 +0 -0
- casadi/libcasadi_nlpsol_alpaqa.so +0 -0
- casadi/libcasadi_nlpsol_alpaqa.so.3.7 +0 -0
- casadi/libcasadi_nlpsol_ampl.so +0 -0
- casadi/libcasadi_nlpsol_ampl.so.3.7 +0 -0
- casadi/libcasadi_nlpsol_blocksqp.so +0 -0
- casadi/libcasadi_nlpsol_blocksqp.so.3.7 +0 -0
- casadi/libcasadi_nlpsol_bonmin.so +0 -0
- casadi/libcasadi_nlpsol_bonmin.so.3.7 +0 -0
- casadi/libcasadi_nlpsol_feasiblesqpmethod.so +0 -0
- casadi/libcasadi_nlpsol_feasiblesqpmethod.so.3.7 +0 -0
- casadi/libcasadi_nlpsol_ipopt.so +0 -0
- casadi/libcasadi_nlpsol_ipopt.so.3.7 +0 -0
- casadi/libcasadi_nlpsol_knitro.so +0 -0
- casadi/libcasadi_nlpsol_knitro.so.3.7 +0 -0
- casadi/libcasadi_nlpsol_madnlp.so +0 -0
- casadi/libcasadi_nlpsol_madnlp.so.3.7 +0 -0
- casadi/libcasadi_nlpsol_qrsqp.so +0 -0
- casadi/libcasadi_nlpsol_qrsqp.so.3.7 +0 -0
- casadi/libcasadi_nlpsol_scpgen.so +0 -0
- casadi/libcasadi_nlpsol_scpgen.so.3.7 +0 -0
- casadi/libcasadi_nlpsol_sleqp.so +0 -0
- casadi/libcasadi_nlpsol_sleqp.so.3.7 +0 -0
- casadi/libcasadi_nlpsol_snopt.so +0 -0
- casadi/libcasadi_nlpsol_snopt.so.3.7 +0 -0
- casadi/libcasadi_nlpsol_sqpmethod.so +0 -0
- casadi/libcasadi_nlpsol_sqpmethod.so.3.7 +0 -0
- casadi/libcasadi_nlpsol_worhp.so +0 -0
- casadi/libcasadi_nlpsol_worhp.so.3.7 +0 -0
- casadi/libcasadi_rootfinder_fast_newton.so +0 -0
- casadi/libcasadi_rootfinder_fast_newton.so.3.7 +0 -0
- casadi/libcasadi_rootfinder_kinsol.so +0 -0
- casadi/libcasadi_rootfinder_kinsol.so.3.7 +0 -0
- casadi/libcasadi_rootfinder_newton.so +0 -0
- casadi/libcasadi_rootfinder_newton.so.3.7 +0 -0
- casadi/libcasadi_rootfinder_nlpsol.so +0 -0
- casadi/libcasadi_rootfinder_nlpsol.so.3.7 +0 -0
- casadi/libcasadi_sundials_common.so +0 -0
- casadi/libcasadi_sundials_common.so.3.7 +0 -0
- casadi/libdaqp.so +0 -0
- casadi/libdaqpstat.a +0 -0
- casadi/libhighs.so +0 -0
- casadi/libhighs.so.1 +0 -0
- casadi/libhighs.so.1.7.2 +0 -0
- casadi/libindirect.a +0 -0
- casadi/libipopt.so +0 -0
- casadi/libipopt.so.3 +0 -0
- casadi/libipopt.so.3.14.11 +0 -0
- casadi/liblinsys.a +0 -0
- casadi/libmatlab_ipc.so +0 -0
- casadi/libosqp.a +0 -0
- casadi/libosqp.so +0 -0
- casadi/libqdldl.a +0 -0
- casadi/libsipopt.so +0 -0
- casadi/libsipopt.so.3 +0 -0
- casadi/libsipopt.so.3.14.11 +0 -0
- casadi/libsleqp.so +0 -0
- casadi/libsleqp.so.1.0.1 +0 -0
- casadi/libspral.a +0 -0
- casadi/libsuperscs.a +0 -0
- casadi/pkgconfig/casadi.pc +1 -1
- casadi/pkgconfig/highs.pc +1 -1
- casadi/tools/__init__.py +4 -0
- casadi/tools/bounds.py +3 -3
- {casadi-3.6.4.dist-info → casadi-3.6.6.dist-info}/METADATA +12 -4
- {casadi-3.6.4.dist-info → casadi-3.6.6.dist-info}/RECORD +490 -281
- casadi/include/highs/fortran/highs_fortran_api.mod +0 -0
- casadi/libFortranHighs.so +0 -0
- casadi/libhighs.so.1.6 +0 -0
- casadi/libhighs.so.1.6.0 +0 -0
- {casadi-3.6.4.dist-info → casadi-3.6.6.dist-info}/WHEEL +0 -0
@@ -0,0 +1,23 @@
|
|
1
|
+
/* Copyright (C) 2004, 2006 International Business Machines and others.
|
2
|
+
* All Rights Reserved.
|
3
|
+
* This code is published under the Eclipse Public License.
|
4
|
+
*
|
5
|
+
* Authors: Carl Laird, Andreas Waechter IBM 2004-08-13
|
6
|
+
*/
|
7
|
+
|
8
|
+
#ifndef __IPRETURNCODES_H__
|
9
|
+
#define __IPRETURNCODES_H__
|
10
|
+
|
11
|
+
/* include from a common include file */
|
12
|
+
#ifdef __cplusplus
|
13
|
+
extern "C"
|
14
|
+
{
|
15
|
+
#endif
|
16
|
+
|
17
|
+
#include "IpReturnCodes_inc.h"
|
18
|
+
|
19
|
+
#ifdef __cplusplus
|
20
|
+
}
|
21
|
+
#endif
|
22
|
+
|
23
|
+
#endif
|
@@ -0,0 +1,18 @@
|
|
1
|
+
/* Copyright (C) 2006 International Business Machines and others.
|
2
|
+
* All Rights Reserved.
|
3
|
+
* This code is published under the Eclipse Public License.
|
4
|
+
*
|
5
|
+
* Authors: Andreas Waechter IBM 2006-03-01
|
6
|
+
*/
|
7
|
+
|
8
|
+
#ifndef __IPRETURNCODES_HPP__
|
9
|
+
#define __IPRETURNCODES_HPP__
|
10
|
+
|
11
|
+
/* include from a common include file */
|
12
|
+
|
13
|
+
namespace Ipopt
|
14
|
+
{
|
15
|
+
#include "IpReturnCodes_inc.h"
|
16
|
+
}
|
17
|
+
|
18
|
+
#endif
|
@@ -0,0 +1,71 @@
|
|
1
|
+
C Copyright (C) 2005, 2009 International Business Machines and others.
|
2
|
+
C All Rights Reserved.
|
3
|
+
C This code is published under the Eclipse Public License.
|
4
|
+
C
|
5
|
+
C Author: Andreas Waechter IBM 2005-08-11
|
6
|
+
C
|
7
|
+
INTEGER IP_SOLVE_SUCCEEDED
|
8
|
+
PARAMETER( IP_SOLVE_SUCCEEDED = 0 )
|
9
|
+
|
10
|
+
INTEGER IP_ACCEPTABLE_LEVEL
|
11
|
+
PARAMETER( IP_ACCEPTABLE_LEVEL = 1 )
|
12
|
+
|
13
|
+
INTEGER IP_INFEASIBLE_PROBLEM
|
14
|
+
PARAMETER( IP_INFEASIBLE_PROBLEM = 2 )
|
15
|
+
|
16
|
+
INTEGER IP_SEARCH_DIRECTION_TOO_SMALL
|
17
|
+
PARAMETER( IP_SEARCH_DIRECTION_TOO_SMALL = 3 )
|
18
|
+
|
19
|
+
INTEGER IP_DIVERGING_ITERATES
|
20
|
+
PARAMETER( IP_DIVERGING_ITERATES = 4 )
|
21
|
+
|
22
|
+
INTEGER IP_USER_REQUESTED_STOP
|
23
|
+
PARAMETER( IP_USER_REQUESTED_STOP = 5 )
|
24
|
+
|
25
|
+
INTEGER IP_FEASIBLE_POINT_FOUND
|
26
|
+
PARAMETER( IP_FEASIBLE_POINT_FOUND = 6 )
|
27
|
+
|
28
|
+
INTEGER IP_ITERATION_EXCEEDED
|
29
|
+
PARAMETER( IP_ITERATION_EXCEEDED = -1 )
|
30
|
+
|
31
|
+
INTEGER IP_RESTORATION_FAILED
|
32
|
+
PARAMETER( IP_RESTORATION_FAILED = -2 )
|
33
|
+
|
34
|
+
INTEGER IP_ERROR_IN_STEP_COMPUTATION
|
35
|
+
PARAMETER( IP_ERROR_IN_STEP_COMPUTATION = -3 )
|
36
|
+
|
37
|
+
INTEGER IP_CPUTIME_EXCEEDED
|
38
|
+
PARAMETER( IP_CPUTIME_EXCEEDED = -4 )
|
39
|
+
|
40
|
+
INTEGER IP_WALLTIME_EXCEEDED
|
41
|
+
PARAMETER( IP_WALLTIME_EXCEEDED = -5 )
|
42
|
+
|
43
|
+
INTEGER IP_NOT_ENOUGH_DEGREES_OF_FRE
|
44
|
+
PARAMETER( IP_NOT_ENOUGH_DEGREES_OF_FRE = -10 )
|
45
|
+
|
46
|
+
INTEGER IP_INVALID_PROBLEM_DEFINITION
|
47
|
+
PARAMETER( IP_INVALID_PROBLEM_DEFINITION = -11)
|
48
|
+
|
49
|
+
INTEGER IP_INVALID_OPTION
|
50
|
+
PARAMETER( IP_INVALID_OPTION = -12 )
|
51
|
+
|
52
|
+
INTEGER IP_INVALID_NUMBER_DETECTED
|
53
|
+
PARAMETER( IP_INVALID_NUMBER_DETECTED = -13 )
|
54
|
+
|
55
|
+
INTEGER IP_UNRECOVERABLE_EXCEPTION
|
56
|
+
PARAMETER( IP_UNRECOVERABLE_EXCEPTION = -100 )
|
57
|
+
|
58
|
+
INTEGER IP_NON_IPOPT_EXCEPTION
|
59
|
+
PARAMETER( IP_NON_IPOPT_EXCEPTION = -101 )
|
60
|
+
|
61
|
+
INTEGER IP_INSUFFICIENT_MEMORY
|
62
|
+
PARAMETER( IP_INSUFFICIENT_MEMORY = -102 )
|
63
|
+
|
64
|
+
INTEGER IP_INTERNAL_ERROR
|
65
|
+
PARAMETER( IP_INTERNAL_ERROR = -199 )
|
66
|
+
|
67
|
+
INTEGER IP_REGULAR_MODE
|
68
|
+
PARAMETER( IP_REGULAR_MODE = 0 )
|
69
|
+
|
70
|
+
INTEGER IP_RESTORATION_PHASE_MODE
|
71
|
+
PARAMETER( IP_RESTORATION_PHASE_MODE = 1 )
|
@@ -0,0 +1,45 @@
|
|
1
|
+
/* Copyright (C) 2004, 2009 International Business Machines and others.
|
2
|
+
* All Rights Reserved.
|
3
|
+
* This code is published under the Eclipse Public License.
|
4
|
+
*
|
5
|
+
* Authors: Carl Laird, Andreas Waechter IBM 2004-08-13
|
6
|
+
*/
|
7
|
+
|
8
|
+
/* !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! */
|
9
|
+
/* !!!!!!!!! REMEMBER TO UPDATE IpReturnCodes.inc and Ipopt.java !!!!!!!! */
|
10
|
+
/* !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! */
|
11
|
+
|
12
|
+
/** Return codes for the Optimize call for an application */
|
13
|
+
enum ApplicationReturnStatus
|
14
|
+
{
|
15
|
+
Solve_Succeeded = 0,
|
16
|
+
Solved_To_Acceptable_Level = 1,
|
17
|
+
Infeasible_Problem_Detected = 2,
|
18
|
+
Search_Direction_Becomes_Too_Small = 3,
|
19
|
+
Diverging_Iterates = 4,
|
20
|
+
User_Requested_Stop = 5,
|
21
|
+
Feasible_Point_Found = 6,
|
22
|
+
|
23
|
+
Maximum_Iterations_Exceeded = -1,
|
24
|
+
Restoration_Failed = -2,
|
25
|
+
Error_In_Step_Computation = -3,
|
26
|
+
Maximum_CpuTime_Exceeded = -4,
|
27
|
+
Maximum_WallTime_Exceeded = -5, ///< @since 3.14.0
|
28
|
+
|
29
|
+
Not_Enough_Degrees_Of_Freedom = -10,
|
30
|
+
Invalid_Problem_Definition = -11,
|
31
|
+
Invalid_Option = -12,
|
32
|
+
Invalid_Number_Detected = -13,
|
33
|
+
|
34
|
+
Unrecoverable_Exception = -100,
|
35
|
+
NonIpopt_Exception_Thrown = -101,
|
36
|
+
Insufficient_Memory = -102,
|
37
|
+
Internal_Error = -199
|
38
|
+
};
|
39
|
+
|
40
|
+
/** enum to indicate the mode in which the algorithm is */
|
41
|
+
enum AlgorithmMode
|
42
|
+
{
|
43
|
+
RegularMode = 0,
|
44
|
+
RestorationPhaseMode = 1
|
45
|
+
};
|
@@ -0,0 +1,291 @@
|
|
1
|
+
// Copyright (C) 2004, 2008 International Business Machines and others.
|
2
|
+
// All Rights Reserved.
|
3
|
+
// This code is published under the Eclipse Public License.
|
4
|
+
//
|
5
|
+
// Authors: Carl Laird, Andreas Waechter IBM 2004-08-13
|
6
|
+
|
7
|
+
#ifndef __IPSCALEDMATRIX_HPP__
|
8
|
+
#define __IPSCALEDMATRIX_HPP__
|
9
|
+
|
10
|
+
#include "IpUtils.hpp"
|
11
|
+
#include "IpMatrix.hpp"
|
12
|
+
|
13
|
+
namespace Ipopt
|
14
|
+
{
|
15
|
+
|
16
|
+
/* forward declarations */
|
17
|
+
class ScaledMatrixSpace;
|
18
|
+
|
19
|
+
/** Class for a Matrix in conjunction with its scaling factors for
|
20
|
+
* row and column scaling.
|
21
|
+
*
|
22
|
+
* Operations on the matrix are performed using
|
23
|
+
* the scaled matrix. You can pull out the pointer to the
|
24
|
+
* unscaled matrix for unscaled calculations.
|
25
|
+
*/
|
26
|
+
class IPOPTLIB_EXPORT ScaledMatrix: public Matrix
|
27
|
+
{
|
28
|
+
public:
|
29
|
+
/**@name Constructors / Destructors */
|
30
|
+
///@{
|
31
|
+
/** Constructor, taking the owner_space.
|
32
|
+
*/
|
33
|
+
ScaledMatrix(
|
34
|
+
const ScaledMatrixSpace* owner_space
|
35
|
+
);
|
36
|
+
|
37
|
+
/** Destructor */
|
38
|
+
~ScaledMatrix();
|
39
|
+
///@}
|
40
|
+
|
41
|
+
/** Set the unscaled matrix */
|
42
|
+
void SetUnscaledMatrix(
|
43
|
+
const SmartPtr<const Matrix> unscaled_matrix
|
44
|
+
);
|
45
|
+
|
46
|
+
/** Set the unscaled matrix in a non-const version */
|
47
|
+
void SetUnscaledMatrixNonConst(
|
48
|
+
const SmartPtr<Matrix>& unscaled_matrix
|
49
|
+
);
|
50
|
+
|
51
|
+
/** Return the unscaled matrix in const form */
|
52
|
+
SmartPtr<const Matrix> GetUnscaledMatrix() const;
|
53
|
+
|
54
|
+
/** Return the unscaled matrix in non-const form */
|
55
|
+
SmartPtr<Matrix> GetUnscaledMatrixNonConst();
|
56
|
+
|
57
|
+
/** return the vector for the row scaling */
|
58
|
+
SmartPtr<const Vector> RowScaling() const;
|
59
|
+
|
60
|
+
/** return the vector for the column scaling */
|
61
|
+
SmartPtr<const Vector> ColumnScaling() const;
|
62
|
+
|
63
|
+
protected:
|
64
|
+
/**@name Methods overloaded from Matrix */
|
65
|
+
///@{
|
66
|
+
virtual void MultVectorImpl(
|
67
|
+
Number alpha,
|
68
|
+
const Vector& x,
|
69
|
+
Number beta,
|
70
|
+
Vector& y
|
71
|
+
) const;
|
72
|
+
|
73
|
+
virtual void TransMultVectorImpl(
|
74
|
+
Number alpha,
|
75
|
+
const Vector& x,
|
76
|
+
Number beta,
|
77
|
+
Vector& y
|
78
|
+
) const;
|
79
|
+
|
80
|
+
virtual bool HasValidNumbersImpl() const;
|
81
|
+
|
82
|
+
virtual void ComputeRowAMaxImpl(
|
83
|
+
Vector& rows_norms,
|
84
|
+
bool init
|
85
|
+
) const;
|
86
|
+
|
87
|
+
virtual void ComputeColAMaxImpl(
|
88
|
+
Vector& cols_norms,
|
89
|
+
bool init
|
90
|
+
) const;
|
91
|
+
|
92
|
+
virtual void PrintImpl(
|
93
|
+
const Journalist& jnlst,
|
94
|
+
EJournalLevel level,
|
95
|
+
EJournalCategory category,
|
96
|
+
const std::string& name,
|
97
|
+
Index indent,
|
98
|
+
const std::string& prefix
|
99
|
+
) const;
|
100
|
+
|
101
|
+
/** X = beta*X + alpha*(Matrix S^{-1} Z). */
|
102
|
+
// ToDo Specialized implementation missing so far!
|
103
|
+
virtual void AddMSinvZImpl(
|
104
|
+
Number alpha,
|
105
|
+
const Vector& S,
|
106
|
+
const Vector& Z,
|
107
|
+
Vector& X
|
108
|
+
) const;
|
109
|
+
|
110
|
+
/** X = S^{-1} (r + alpha*Z*M^Td). */
|
111
|
+
// ToDo Specialized implementation missing so far!
|
112
|
+
virtual void SinvBlrmZMTdBrImpl(
|
113
|
+
Number alpha,
|
114
|
+
const Vector& S,
|
115
|
+
const Vector& R,
|
116
|
+
const Vector& Z,
|
117
|
+
const Vector& D,
|
118
|
+
Vector& X
|
119
|
+
) const;
|
120
|
+
///@}
|
121
|
+
|
122
|
+
private:
|
123
|
+
/**@name Default Compiler Generated Methods
|
124
|
+
* (Hidden to avoid implicit creation/calling).
|
125
|
+
* These methods are not implemented and
|
126
|
+
* we do not want the compiler to implement
|
127
|
+
* them for us, so we declare them private
|
128
|
+
* and do not define them. This ensures that
|
129
|
+
* they will not be implicitly created/called.
|
130
|
+
*/
|
131
|
+
///@{
|
132
|
+
/** Default Constructor */
|
133
|
+
ScaledMatrix();
|
134
|
+
|
135
|
+
/** Copy Constructor */
|
136
|
+
ScaledMatrix(
|
137
|
+
const ScaledMatrix&
|
138
|
+
);
|
139
|
+
|
140
|
+
/** Default Assignment Operator */
|
141
|
+
void operator=(
|
142
|
+
const ScaledMatrix&
|
143
|
+
);
|
144
|
+
///@}
|
145
|
+
|
146
|
+
/** const version of the unscaled matrix */
|
147
|
+
SmartPtr<const Matrix> matrix_;
|
148
|
+
|
149
|
+
/** non-const version of the unscaled matrix */
|
150
|
+
SmartPtr<Matrix> nonconst_matrix_;
|
151
|
+
|
152
|
+
/** Matrix space stored as a ScaledMatrixSpace */
|
153
|
+
SmartPtr<const ScaledMatrixSpace> owner_space_;
|
154
|
+
};
|
155
|
+
|
156
|
+
/** This is the matrix space for ScaledMatrix. */
|
157
|
+
class IPOPTLIB_EXPORT ScaledMatrixSpace: public MatrixSpace
|
158
|
+
{
|
159
|
+
public:
|
160
|
+
/** @name Constructors / Destructors */
|
161
|
+
///@{
|
162
|
+
/** Constructor, given the number of row and columns blocks, as
|
163
|
+
* well as the totel number of rows and columns.
|
164
|
+
*/
|
165
|
+
ScaledMatrixSpace(
|
166
|
+
const SmartPtr<const Vector>& row_scaling,
|
167
|
+
bool row_scaling_reciprocal,
|
168
|
+
const SmartPtr<const MatrixSpace>& unscaled_matrix_space,
|
169
|
+
const SmartPtr<const Vector>& column_scaling,
|
170
|
+
bool column_scaling_reciprocal
|
171
|
+
);
|
172
|
+
|
173
|
+
/** Destructor */
|
174
|
+
~ScaledMatrixSpace()
|
175
|
+
{ }
|
176
|
+
///@}
|
177
|
+
|
178
|
+
/** Method for creating a new matrix of this specific type. */
|
179
|
+
ScaledMatrix* MakeNewScaledMatrix(
|
180
|
+
bool allocate_unscaled_matrix = false
|
181
|
+
) const
|
182
|
+
{
|
183
|
+
ScaledMatrix* ret = new ScaledMatrix(this);
|
184
|
+
if( allocate_unscaled_matrix )
|
185
|
+
{
|
186
|
+
SmartPtr<Matrix> unscaled_matrix = unscaled_matrix_space_->MakeNew();
|
187
|
+
ret->SetUnscaledMatrixNonConst(unscaled_matrix);
|
188
|
+
}
|
189
|
+
return ret;
|
190
|
+
}
|
191
|
+
|
192
|
+
virtual Matrix* MakeNew() const
|
193
|
+
{
|
194
|
+
return MakeNewScaledMatrix();
|
195
|
+
}
|
196
|
+
|
197
|
+
/** return the vector for the row scaling */
|
198
|
+
SmartPtr<const Vector> RowScaling() const
|
199
|
+
{
|
200
|
+
return ConstPtr(row_scaling_);
|
201
|
+
}
|
202
|
+
|
203
|
+
/** return the matrix space for the unscaled matrix */
|
204
|
+
SmartPtr<const MatrixSpace> UnscaledMatrixSpace() const
|
205
|
+
{
|
206
|
+
return unscaled_matrix_space_;
|
207
|
+
}
|
208
|
+
|
209
|
+
/** return the vector for the column scaling */
|
210
|
+
SmartPtr<const Vector> ColumnScaling() const
|
211
|
+
{
|
212
|
+
return ConstPtr(column_scaling_);
|
213
|
+
}
|
214
|
+
|
215
|
+
private:
|
216
|
+
/**@name Default Compiler Generated Methods
|
217
|
+
* (Hidden to avoid implicit creation/calling).
|
218
|
+
* These methods are not implemented and
|
219
|
+
* we do not want the compiler to implement
|
220
|
+
* them for us, so we declare them private
|
221
|
+
* and do not define them. This ensures that
|
222
|
+
* they will not be implicitly created/called.
|
223
|
+
*/
|
224
|
+
///@{
|
225
|
+
/** Default constructor */
|
226
|
+
ScaledMatrixSpace();
|
227
|
+
|
228
|
+
/** Copy Constructor */
|
229
|
+
ScaledMatrixSpace(
|
230
|
+
const ScaledMatrixSpace&
|
231
|
+
);
|
232
|
+
|
233
|
+
/** Default Assignment Operator */
|
234
|
+
ScaledMatrixSpace& operator=(
|
235
|
+
const ScaledMatrixSpace&
|
236
|
+
);
|
237
|
+
///@}
|
238
|
+
|
239
|
+
/** Row scaling vector */
|
240
|
+
SmartPtr<Vector> row_scaling_;
|
241
|
+
|
242
|
+
/** unscaled matrix space */
|
243
|
+
SmartPtr<const MatrixSpace> unscaled_matrix_space_;
|
244
|
+
|
245
|
+
/** column scaling vector */
|
246
|
+
SmartPtr<Vector> column_scaling_;
|
247
|
+
};
|
248
|
+
|
249
|
+
inline void ScaledMatrix::SetUnscaledMatrix(
|
250
|
+
const SmartPtr<const Matrix> unscaled_matrix
|
251
|
+
)
|
252
|
+
{
|
253
|
+
matrix_ = unscaled_matrix;
|
254
|
+
nonconst_matrix_ = NULL;
|
255
|
+
ObjectChanged();
|
256
|
+
}
|
257
|
+
|
258
|
+
inline void ScaledMatrix::SetUnscaledMatrixNonConst(
|
259
|
+
const SmartPtr<Matrix>& unscaled_matrix
|
260
|
+
)
|
261
|
+
{
|
262
|
+
nonconst_matrix_ = unscaled_matrix;
|
263
|
+
matrix_ = GetRawPtr(unscaled_matrix);
|
264
|
+
ObjectChanged();
|
265
|
+
}
|
266
|
+
|
267
|
+
inline SmartPtr<const Matrix> ScaledMatrix::GetUnscaledMatrix() const
|
268
|
+
{
|
269
|
+
return matrix_;
|
270
|
+
}
|
271
|
+
|
272
|
+
inline SmartPtr<Matrix> ScaledMatrix::GetUnscaledMatrixNonConst()
|
273
|
+
{
|
274
|
+
DBG_ASSERT(IsValid(nonconst_matrix_));
|
275
|
+
ObjectChanged();
|
276
|
+
return nonconst_matrix_;
|
277
|
+
}
|
278
|
+
|
279
|
+
inline SmartPtr<const Vector> ScaledMatrix::RowScaling() const
|
280
|
+
{
|
281
|
+
return ConstPtr(owner_space_->RowScaling());
|
282
|
+
}
|
283
|
+
|
284
|
+
inline SmartPtr<const Vector> ScaledMatrix::ColumnScaling() const
|
285
|
+
{
|
286
|
+
return ConstPtr(owner_space_->ColumnScaling());
|
287
|
+
}
|
288
|
+
|
289
|
+
} // namespace Ipopt
|
290
|
+
|
291
|
+
#endif
|
@@ -0,0 +1,72 @@
|
|
1
|
+
// Copyright (C) 2005, 2007 International Business Machines and others.
|
2
|
+
// All Rights Reserved.
|
3
|
+
// This code is published under the Eclipse Public License.
|
4
|
+
//
|
5
|
+
// Authors: Andreas Waechter IBM 2005-10-13
|
6
|
+
|
7
|
+
#ifndef __IPSEARCHDIRCALCULATOR_HPP__
|
8
|
+
#define __IPSEARCHDIRCALCULATOR_HPP__
|
9
|
+
|
10
|
+
#include "IpAlgStrategy.hpp"
|
11
|
+
|
12
|
+
namespace Ipopt
|
13
|
+
{
|
14
|
+
|
15
|
+
/** Base class for computing the search direction for the line
|
16
|
+
* search.
|
17
|
+
*/
|
18
|
+
class IPOPTLIB_EXPORT SearchDirectionCalculator: public AlgorithmStrategyObject
|
19
|
+
{
|
20
|
+
public:
|
21
|
+
/**@name Constructors/Destructors */
|
22
|
+
///@{
|
23
|
+
/** Constructor */
|
24
|
+
SearchDirectionCalculator()
|
25
|
+
{ }
|
26
|
+
|
27
|
+
/** Destructor */
|
28
|
+
virtual ~SearchDirectionCalculator()
|
29
|
+
{ }
|
30
|
+
///@}
|
31
|
+
|
32
|
+
virtual bool InitializeImpl(
|
33
|
+
const OptionsList& options,
|
34
|
+
const std::string& prefix
|
35
|
+
) = 0;
|
36
|
+
|
37
|
+
/** Pure virtual method for computing the search direction.
|
38
|
+
*
|
39
|
+
* The computed direction is stored in IpData().delta().
|
40
|
+
*/
|
41
|
+
virtual bool ComputeSearchDirection() = 0;
|
42
|
+
|
43
|
+
private:
|
44
|
+
/**@name Default Compiler Generated Methods
|
45
|
+
* (Hidden to avoid implicit creation/calling).
|
46
|
+
*
|
47
|
+
* These methods are not implemented and
|
48
|
+
* we do not want the compiler to implement
|
49
|
+
* them for us, so we declare them private
|
50
|
+
* and do not define them. This ensures that
|
51
|
+
* they will not be implicitly created/called.
|
52
|
+
*/
|
53
|
+
///@{
|
54
|
+
/** Default Constructor */
|
55
|
+
// SearchDirectionCalculator();
|
56
|
+
|
57
|
+
/** Copy Constructor */
|
58
|
+
SearchDirectionCalculator(
|
59
|
+
const SearchDirectionCalculator&
|
60
|
+
);
|
61
|
+
|
62
|
+
/** Default Assignment Operator */
|
63
|
+
void operator=(
|
64
|
+
const SearchDirectionCalculator&
|
65
|
+
);
|
66
|
+
///@}
|
67
|
+
|
68
|
+
};
|
69
|
+
|
70
|
+
} // namespace Ipopt
|
71
|
+
|
72
|
+
#endif
|