casadi 3.6.5__cp39-none-manylinux2014_i686.whl → 3.6.7__cp39-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 +739 -308
- 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 +3 -0
- 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 +52 -0
- casadi/include/casadi/core/casadi_types.hpp +3 -2
- casadi/include/casadi/core/code_generator.hpp +30 -1
- casadi/include/casadi/core/global_options.hpp +2 -0
- casadi/include/casadi/core/mx.hpp +18 -3
- casadi/include/casadi/core/optistack.hpp +23 -0
- casadi/include/casadi/core/runtime/casadi_nlp.hpp +19 -4
- 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/serializing_stream.hpp +2 -2
- casadi/include/casadi/core/sparsity.hpp +7 -0
- casadi/include/casadi/doc.i +1513 -1016
- casadi/include/casadi/doc_merged.i +965 -719
- casadi/include/casadi/mem.h +1 -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/libCbcSolver.so +0 -0
- casadi/libCbcSolver.so.3 +0 -0
- casadi/libCbcSolver.so.3.10.11 +0 -0
- casadi/libClpSolver.so +0 -0
- casadi/libClpSolver.so.1 +0 -0
- casadi/libClpSolver.so.1.14.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/libcoinmetis.la +1 -1
- casadi/libcoinmetis.so +0 -0
- casadi/libcoinmetis.so.2 +0 -0
- casadi/libcoinmetis.so.2.0.0 +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/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/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.5.dist-info → casadi-3.6.7.dist-info}/METADATA +2 -2
- {casadi-3.6.5.dist-info → casadi-3.6.7.dist-info}/RECORD +365 -250
- 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.5.dist-info → casadi-3.6.7.dist-info}/WHEEL +0 -0
casadi/cbc
CHANGED
Binary file
|
casadi/clp
CHANGED
Binary file
|
@@ -2,23 +2,16 @@
|
|
2
2
|
|
3
3
|
set(HIGHS_DIR "")
|
4
4
|
|
5
|
-
if
|
6
|
-
|
7
|
-
|
8
|
-
endif()
|
5
|
+
if(NOT TARGET highs)
|
6
|
+
include("${CMAKE_CURRENT_LIST_DIR}/highs-targets.cmake")
|
7
|
+
endif()
|
9
8
|
|
10
|
-
|
11
|
-
else()
|
12
|
-
if(NOT TARGET libhighs)
|
13
|
-
include("${CMAKE_CURRENT_LIST_DIR}/highs-targets.cmake")
|
14
|
-
endif()
|
9
|
+
set(HIGHS_LIBRARIES highs)
|
15
10
|
|
16
|
-
|
17
|
-
endif()
|
18
|
-
|
19
|
-
set(HIGHS_INCLUDE_DIRS "${CMAKE_CURRENT_LIST_DIR}/../../../include/highs")
|
11
|
+
set(HIGHS_INCLUDE_DIRS "${CMAKE_CURRENT_LIST_DIR}/../../../include")
|
20
12
|
|
21
13
|
set(HIGHS_FOUND TRUE)
|
22
14
|
|
23
15
|
include(CMakeFindDependencyMacro)
|
16
|
+
find_dependency(Threads)
|
24
17
|
find_dependency(ZLIB)
|
@@ -5,24 +5,24 @@
|
|
5
5
|
# Commands may need to know the format version.
|
6
6
|
set(CMAKE_IMPORT_FILE_VERSION 1)
|
7
7
|
|
8
|
-
# Import target "highs" for configuration "Release"
|
9
|
-
set_property(TARGET highs APPEND PROPERTY IMPORTED_CONFIGURATIONS RELEASE)
|
10
|
-
set_target_properties(highs PROPERTIES
|
11
|
-
IMPORTED_LOCATION_RELEASE "${_IMPORT_PREFIX}/
|
8
|
+
# Import target "highs::highs" for configuration "Release"
|
9
|
+
set_property(TARGET highs::highs APPEND PROPERTY IMPORTED_CONFIGURATIONS RELEASE)
|
10
|
+
set_target_properties(highs::highs PROPERTIES
|
11
|
+
IMPORTED_LOCATION_RELEASE "${_IMPORT_PREFIX}/lib/libhighs.so.1.7.2"
|
12
|
+
IMPORTED_SONAME_RELEASE "libhighs.so.1"
|
12
13
|
)
|
13
14
|
|
14
|
-
list(APPEND _cmake_import_check_targets highs )
|
15
|
-
list(APPEND _cmake_import_check_files_for_highs "${_IMPORT_PREFIX}/
|
15
|
+
list(APPEND _cmake_import_check_targets highs::highs )
|
16
|
+
list(APPEND _cmake_import_check_files_for_highs::highs "${_IMPORT_PREFIX}/lib/libhighs.so.1.7.2" )
|
16
17
|
|
17
|
-
# Import target "
|
18
|
-
set_property(TARGET
|
19
|
-
set_target_properties(
|
20
|
-
IMPORTED_LOCATION_RELEASE "${_IMPORT_PREFIX}/
|
21
|
-
IMPORTED_SONAME_RELEASE "libhighs.so.1.6"
|
18
|
+
# Import target "highs::highs-bin" for configuration "Release"
|
19
|
+
set_property(TARGET highs::highs-bin APPEND PROPERTY IMPORTED_CONFIGURATIONS RELEASE)
|
20
|
+
set_target_properties(highs::highs-bin PROPERTIES
|
21
|
+
IMPORTED_LOCATION_RELEASE "${_IMPORT_PREFIX}/bin/highs"
|
22
22
|
)
|
23
23
|
|
24
|
-
list(APPEND _cmake_import_check_targets
|
25
|
-
list(APPEND
|
24
|
+
list(APPEND _cmake_import_check_targets highs::highs-bin )
|
25
|
+
list(APPEND _cmake_import_check_files_for_highs::highs-bin "${_IMPORT_PREFIX}/bin/highs" )
|
26
26
|
|
27
27
|
# Commands beyond this point should not need to know the version.
|
28
28
|
set(CMAKE_IMPORT_FILE_VERSION)
|
@@ -19,7 +19,7 @@ set(CMAKE_IMPORT_FILE_VERSION 1)
|
|
19
19
|
set(_cmake_targets_defined "")
|
20
20
|
set(_cmake_targets_not_defined "")
|
21
21
|
set(_cmake_expected_targets "")
|
22
|
-
foreach(_cmake_expected_target IN ITEMS highs
|
22
|
+
foreach(_cmake_expected_target IN ITEMS highs::highs highs::highs-bin)
|
23
23
|
list(APPEND _cmake_expected_targets "${_cmake_expected_target}")
|
24
24
|
if(TARGET "${_cmake_expected_target}")
|
25
25
|
list(APPEND _cmake_targets_defined "${_cmake_expected_target}")
|
@@ -55,19 +55,22 @@ if(_IMPORT_PREFIX STREQUAL "/")
|
|
55
55
|
set(_IMPORT_PREFIX "")
|
56
56
|
endif()
|
57
57
|
|
58
|
-
# Create imported target highs
|
59
|
-
|
58
|
+
# Create imported target highs::highs
|
59
|
+
add_library(highs::highs SHARED IMPORTED)
|
60
60
|
|
61
|
-
set_target_properties(highs PROPERTIES
|
62
|
-
|
61
|
+
set_target_properties(highs::highs PROPERTIES
|
62
|
+
COMPATIBLE_INTERFACE_STRING "HIGHS_MAJOR_VERSION"
|
63
|
+
INTERFACE_HIGHS_MAJOR_VERSION "1"
|
64
|
+
INTERFACE_INCLUDE_DIRECTORIES "${_IMPORT_PREFIX}/include;${_IMPORT_PREFIX}/include/highs"
|
65
|
+
INTERFACE_LINK_LIBRARIES "ZLIB::ZLIB;Threads::Threads"
|
66
|
+
INTERFACE_POSITION_INDEPENDENT_CODE "ON"
|
63
67
|
)
|
64
68
|
|
65
|
-
# Create imported target
|
66
|
-
|
69
|
+
# Create imported target highs::highs-bin
|
70
|
+
add_executable(highs::highs-bin IMPORTED)
|
67
71
|
|
68
|
-
set_target_properties(
|
69
|
-
|
70
|
-
INTERFACE_LINK_LIBRARIES "ZLIB::ZLIB;Threads::Threads"
|
72
|
+
set_target_properties(highs::highs-bin PROPERTIES
|
73
|
+
INTERFACE_COMPILE_OPTIONS "-Wno-unused-variable;-Wno-unused-const-variable"
|
71
74
|
)
|
72
75
|
|
73
76
|
if(CMAKE_VERSION VERSION_LESS 2.8.12)
|
casadi/highs
CHANGED
Binary file
|
casadi/include/casadi/casadi.i
CHANGED
@@ -3694,6 +3694,9 @@ DECL M casadi_stop_diff(const M& expr, casadi_int order) {
|
|
3694
3694
|
DECL M casadi_stop_diff(const M& expr, const M& var, casadi_int order) {
|
3695
3695
|
return stop_diff(expr, var, order);
|
3696
3696
|
}
|
3697
|
+
DECL std::vector< M > casadi_difference(const std::vector< M >& a, const std::vector< M >& b) {
|
3698
|
+
return difference(a, b);
|
3699
|
+
}
|
3697
3700
|
DECL M casadi_no_hess(const M& expr) {
|
3698
3701
|
return no_hess(expr);
|
3699
3702
|
}
|
casadi/include/casadi/casadi_c.h
CHANGED
@@ -128,6 +128,8 @@ CASADI_EXPORT int casadi_c_work_id(int id, casadi_int *sz_arg, casadi_int* sz_re
|
|
128
128
|
CASADI_EXPORT int casadi_c_eval_id(int id, const double** arg, double** res,
|
129
129
|
casadi_int* iw, double* w, int mem);
|
130
130
|
|
131
|
+
CASADI_EXPORT void casadi_c_logger_write(const char* msg, int num);
|
132
|
+
CASADI_EXPORT void casadi_c_logger_flush(void);
|
131
133
|
|
132
134
|
#ifdef __cplusplus
|
133
135
|
}
|
casadi/include/casadi/config.h
CHANGED
@@ -26,18 +26,18 @@
|
|
26
26
|
|
27
27
|
#define CASADI_MAJOR_VERSION 3
|
28
28
|
#define CASADI_MINOR_VERSION 6
|
29
|
-
#define CASADI_PATCH_VERSION
|
29
|
+
#define CASADI_PATCH_VERSION 7
|
30
30
|
#define CASADI_IS_RELEASE 1
|
31
|
-
#define CASADI_VERSION_STRING "3.6.
|
32
|
-
#define CASADI_GIT_REVISION "
|
33
|
-
#define CASADI_GIT_DESCRIBE "3.6.3-
|
34
|
-
#define CASADI_FEATURE_LIST "\n * dynamic-loading, Support for import of FMI 2.0 binaries\n * sundials-interface, Interface to the ODE/DAE integrator suite SUNDIALS.\n * csparse-interface, Interface to the sparse direct linear solver CSparse.\n * superscs-interface, Interface to QP solver SUPERSCS.\n * osqp-interface, Interface to QP solver OSQP.\n * tinyxml-interface, Interface to the XML parser TinyXML.\n * qpoases-interface, Interface to the active-set QP solver qpOASES.\n * blocksqp-interface, Interface to the NLP solver blockSQP.\n * snopt-mockup-build, Use mockup SNOPT (BUILD_MOCKUPS_VERSION=
|
31
|
+
#define CASADI_VERSION_STRING "3.6.7"
|
32
|
+
#define CASADI_GIT_REVISION "a2d71bf95dbd3fa5f6725504bcba67dd52869d91" // NOLINT(whitespace/line_length)
|
33
|
+
#define CASADI_GIT_DESCRIBE "3.6.3-327.a2d71bf95" // NOLINT(whitespace/line_length)
|
34
|
+
#define CASADI_FEATURE_LIST "\n * dynamic-loading, Support for import of FMI 2.0 binaries\n * sundials-interface, Interface to the ODE/DAE integrator suite SUNDIALS.\n * csparse-interface, Interface to the sparse direct linear solver CSparse.\n * superscs-interface, Interface to QP solver SUPERSCS.\n * osqp-interface, Interface to QP solver OSQP.\n * tinyxml-interface, Interface to the XML parser TinyXML.\n * qpoases-interface, Interface to the active-set QP solver qpOASES.\n * blocksqp-interface, Interface to the NLP solver blockSQP.\n * snopt-mockup-build, Use mockup SNOPT (BUILD_MOCKUPS_VERSION=master) from downloaded source (BUILD_MOCKUPS_GIT_REPO=https://github.com/casadi/mockups.git).\n * knitro-mockup-build, Use mockup KNITRO (BUILD_MOCKUPS_VERSION=master) from downloaded source (BUILD_MOCKUPS_GIT_REPO=https://github.com/casadi/mockups.git).\n * gurobi-mockup-build, Use mockup GUROBI (BUILD_MOCKUPS_VERSION=master) from downloaded source (BUILD_MOCKUPS_GIT_REPO=https://github.com/casadi/mockups.git).\n * worhp-mockup-build, Use mockup WORHP (BUILD_MOCKUPS_VERSION=master) from downloaded source (BUILD_MOCKUPS_GIT_REPO=https://github.com/casadi/mockups.git).\n * hsl-mockup-build, Use mockup WORHP (BUILD_MOCKUPS_VERSION=master) from downloaded source (BUILD_MOCKUPS_GIT_REPO=https://github.com/casadi/mockups.git).\n * madnlp-mockup-build, Use mockup MadNLP (BUILD_MOCKUPS_VERSION=master) from downloaded source (BUILD_MOCKUPS_GIT_REPO=https://github.com/casadi/mockups.git).\n * alpaqa-sourcebuild, Build Alpaqa (BUILD_ALPAQA_VERSION=develop) from downloaded source (BUILD_ALPAQA_GIT_REPO=https://github.com/jgillis/alpaqa).\n * highs-sourcebuild, Build HiGHS (BUILD_HIGHS_VERSION=v1.7.2) from downloaded source (BUILD_HIGHS_GIT_REPO=https://github.com/ERGO-Code/HiGHS).\n * daqp-sourcebuild, Build DAQP (BUILD_DAQP_VERSION=master) from downloaded source (BUILD_DAQP_GIT_REPO=https://github.com/jgillis/daqp.git).\n * proxqp-sourcebuild, Build PROXQP (BUILD_PROXQP_VERSION=v0.3.2) from downloaded source (BUILD_PROXQP_GIT_REPO=https://github.com/Simple-Robotics/proxsuite.git).\n * osqp-sourcebuild, Build OSQP (BUILD_OSQP_VERSION=v0.6.3) from downloaded source (BUILD_OSQP_GIT_REPO=https://github.com/osqp/osqp.git).\n * superscs-sourcebuild, Build SuperSCS (BUILD_SUPERSCS_VERSION=4d2d1bd03ed4cf93e684a880b233760ce34ca69c) from downloaded source (BUILD_SUPERSCS_GIT_REPO=https://github.com/jgillis/scs.git).\n * sleqp-sourcebuild, Build SLEQP (BUILD_SLEQP_VERSION=patch-1) from downloaded source (BUILD_SLEQP_GIT_REPO=https://github.com/jgillis/sleqp.git).\n * bonmin-sourcebuild, Build BONMIN (BUILD_BONMIN_VERSION=releases/1.8.9) from downloaded source (BUILD_BONMIN_GIT_REPO=https://github.com/coin-or/Bonmin.git).\n * ipopt-sourcebuild, Build IPOPT (BUILD_IPOPT_VERSION=3.14.11.mod) from downloaded source (BUILD_IPOPT_GIT_REPO=https://github.com/jgillis/Ipopt-1.git).\n * cbc-sourcebuild, Build CBC (BUILD_CBC_VERSION=releases/2.10.11) from downloaded source.\n * clp-sourcebuild, Build CLP (BUILD_CLP_VERSION=releases/1.17.9) from downloaded source (BUILD_CLP_GIT_REPO=https://github.com/coin-or/Clp.git).\n * mumps-sourcebuild, Build MUMPS (BUILD_MUMPS_TP_VERSION=releases/3.0.2) from downloaded source (BUILD_MUMPS_TP_GIT_REPO=https://github.com/coin-or-tools/ThirdParty-Mumps.git).\n * spral-sourcebuild, Build SPRAL (BUILD_SPRAL_VERSION=d385d2c9e858366d257cafaaf05760ffa6543e26) from downloaded source (BUILD_SPRAL_GIT_REPO=https://github.com/ralna/spral.git).\n * metis-sourcebuild, Build METIS (BUILD_METIS_TP_VERSION=6997f64) from downloaded source.\n * trlib-sourcebuild, Build TRLIB (BUILD_TRLIB_VERSION=c7632b8b14152e78bc21721a3bd1a2432586b824) from downloaded source (BUILD_TRLIB_GIT_REPO=https://github.com/jgillis/trlib.git).\n * lapack-sourcebuild, Download and install OpenBLAS for LAPACK+BLAS\n * eigen3-sourcebuild, Build Eigen (BUILD_EIGEN3_VERSION=3.4.0) from downloaded source (BUILD_EIGEN3_GIT_REPO=https://gitlab.com/libeigen/eigen.git).\n * simde-sourcebuild, Build Simde (BUILD_SIMDE_VERSION=v0.7.2) from downloaded source (BUILD_SIMDE_GIT_REPO=https://github.com/simd-everywhere/simde.git).\n * gurobi-interface, Interface to the (mixed-integer) QP solver GUROBI\n * knitro-interface, Interface to the NLP solver KNITRO.\n * madnlp-interface, Interface to the NLP solver MadNLP.\n * snopt-interface, Interface to the NLP solver KNITRO.\n * worhp-interface, Interface to the NLP solver Worhp (requires gfortran, gomp).\n * lapack-interface, Interface to LAPACK.\n * mumps-interface, Interface to MUMPS.\n * spral-interface, Interface to SPRAL.\n * coinutils-sourcebuild, Build COINUTILS (BUILD_COINUTILS_VERSION=releases/2.11.10) from downloaded source.\n * osi-sourcebuild, Build OSI (BUILD_OSI_VERSION=releases/0.108.9) from downloaded source.\n * clp-interface, Interface to the LP solver CLP.\n * cgl-sourcebuild, Build CGL (BUILD_CGL_VERSION=releases/0.60.8) from downloaded source.\n * cbc-interface, Interface to the LP solver CBC.\n * ipopt-interface, Interface to the NLP solver Ipopt.\n * bonmin-interface, Interface to the MINLP framework Bonmin.\n * highs-interface, Interface to the MILP / QP solver HiGHS.\n * daqp-interface, Interface to the MILP / QP solver HiGHS.\n * sleqp-interface, Interface to the NLP solver SLEQP.\n * alpaqa-interface, Interface to the NLP solver Alpaqa.\n * proxqp-interface, Interface to QP solver PROXQP.\n * ampl-interface, Interface to the AMPL solver library.\n" // NOLINT(whitespace/line_length)
|
35
35
|
#define CASADI_BUILD_TYPE "Release" // NOLINT(whitespace/line_length)
|
36
36
|
#define CASADI_COMPILER_ID "GNU" // NOLINT(whitespace/line_length)
|
37
37
|
#define CASADI_COMPILER "/opt/rh/devtoolset-10/root/usr/bin/g++" // NOLINT(whitespace/line_length)
|
38
|
-
#define CASADI_COMPILER_FLAGS " -pthread -DUSE_CXX11 -DHAVE_MKSTEMPS -DCASADI_WITH_THREAD -DWITH_DEEPBIND -DCASADI_MAJOR_VERSION=3 -DCASADI_MINOR_VERSION=6 -DCASADI_PATCH_VERSION=
|
39
|
-
#define CASADI_MODULES "casadi;casadi_linsol_lapacklu;casadi_linsol_lapackqr;casadi_sundials_common;casadi_integrator_cvodes;casadi_integrator_idas;casadi_rootfinder_kinsol;casadi_nlpsol_sleqp;casadi_nlpsol_ipopt;casadi_nlpsol_bonmin;casadi_conic_qpoases;casadi_nlpsol_knitro;casadi_conic_clp;casadi_conic_cbc;casadi_linsol_csparse;casadi_linsol_csparsecholesky;casadi_conic_highs;casadi_linsol_ma27;casadi_linsol_mumps;casadi_conic_gurobi;casadi_nlpsol_worhp;casadi_nlpsol_snopt;casadi_xmlfile_tinyxml;casadi_nlpsol_blocksqp;casadi_conic_superscs;casadi_nlpsol_ampl;casadi_conic_proxqp;casadi_conic_osqp;casadi_nlpsol_alpaqa;casadi_conic_nlpsol;casadi_conic_qrqp;casadi_conic_ipqp;casadi_nlpsol_qrsqp;casadi_importer_shell;casadi_integrator_rk;casadi_integrator_collocation;casadi_interpolant_linear;casadi_interpolant_bspline;casadi_linsol_symbolicqr;casadi_linsol_qr;casadi_linsol_ldl;casadi_linsol_tridiag;casadi_linsol_lsqr;casadi_nlpsol_sqpmethod;casadi_nlpsol_feasiblesqpmethod;casadi_nlpsol_scpgen;casadi_rootfinder_newton;casadi_rootfinder_fast_newton;casadi_rootfinder_nlpsol" // NOLINT(whitespace/line_length)
|
40
|
-
#define CASADI_PLUGINS "Linsol::lapacklu;Linsol::lapackqr;Integrator::cvodes;Integrator::idas;Rootfinder::kinsol;Nlpsol::sleqp;Nlpsol::ipopt;Nlpsol::bonmin;Conic::qpoases;Nlpsol::knitro;Conic::clp;Conic::cbc;Linsol::csparse;Linsol::csparsecholesky;Conic::highs;Linsol::ma27;Linsol::mumps;Conic::gurobi;Nlpsol::worhp;Nlpsol::snopt;XmlFile::tinyxml;Nlpsol::blocksqp;Conic::superscs;Nlpsol::ampl;Conic::proxqp;Conic::osqp;Nlpsol::alpaqa;Conic::nlpsol;Conic::qrqp;Conic::ipqp;Nlpsol::qrsqp;Importer::shell;Integrator::rk;Integrator::collocation;Interpolant::linear;Interpolant::bspline;Linsol::symbolicqr;Linsol::qr;Linsol::ldl;Linsol::tridiag;Linsol::lsqr;Nlpsol::sqpmethod;Nlpsol::feasiblesqpmethod;Nlpsol::scpgen;Rootfinder::newton;Rootfinder::fast_newton;Rootfinder::nlpsol" // NOLINT(whitespace/line_length)
|
38
|
+
#define CASADI_COMPILER_FLAGS " -pthread -DUSE_CXX11 -DHAVE_MKSTEMPS -DCASADI_WITH_THREAD -DWITH_DEEPBIND -DCASADI_MAJOR_VERSION=3 -DCASADI_MINOR_VERSION=6 -DCASADI_PATCH_VERSION=7 -DCASADI_IS_RELEASE=1 -DCASADI_VERSION=31 -D_USE_MATH_DEFINES -D_SCL_SECURE_NO_WARNINGS -DWITH_DL -DWITH_DEPRECATED_FEATURES -DCASADI_DEFAULT_COMPILER_PLUGIN=shell" // NOLINT(whitespace/line_length)
|
39
|
+
#define CASADI_MODULES "casadi;casadi_linsol_lapacklu;casadi_linsol_lapackqr;casadi_sundials_common;casadi_integrator_cvodes;casadi_integrator_idas;casadi_rootfinder_kinsol;casadi_nlpsol_sleqp;casadi_nlpsol_ipopt;casadi_nlpsol_madnlp;casadi_nlpsol_bonmin;casadi_conic_qpoases;casadi_nlpsol_knitro;casadi_conic_clp;casadi_conic_cbc;casadi_linsol_csparse;casadi_linsol_csparsecholesky;casadi_conic_highs;casadi_conic_daqp;casadi_linsol_ma27;casadi_linsol_mumps;casadi_conic_gurobi;casadi_nlpsol_worhp;casadi_nlpsol_snopt;casadi_xmlfile_tinyxml;casadi_nlpsol_blocksqp;casadi_conic_superscs;casadi_nlpsol_ampl;casadi_conic_proxqp;casadi_conic_osqp;casadi_nlpsol_alpaqa;casadi_conic_nlpsol;casadi_conic_qrqp;casadi_conic_ipqp;casadi_nlpsol_qrsqp;casadi_importer_shell;casadi_integrator_rk;casadi_integrator_collocation;casadi_interpolant_linear;casadi_interpolant_bspline;casadi_linsol_symbolicqr;casadi_linsol_qr;casadi_linsol_ldl;casadi_linsol_tridiag;casadi_linsol_lsqr;casadi_nlpsol_sqpmethod;casadi_nlpsol_feasiblesqpmethod;casadi_nlpsol_scpgen;casadi_rootfinder_newton;casadi_rootfinder_fast_newton;casadi_rootfinder_nlpsol" // NOLINT(whitespace/line_length)
|
40
|
+
#define CASADI_PLUGINS "Linsol::lapacklu;Linsol::lapackqr;Integrator::cvodes;Integrator::idas;Rootfinder::kinsol;Nlpsol::sleqp;Nlpsol::ipopt;Nlpsol::madnlp;Nlpsol::bonmin;Conic::qpoases;Nlpsol::knitro;Conic::clp;Conic::cbc;Linsol::csparse;Linsol::csparsecholesky;Conic::highs;Conic::daqp;Linsol::ma27;Linsol::mumps;Conic::gurobi;Nlpsol::worhp;Nlpsol::snopt;XmlFile::tinyxml;Nlpsol::blocksqp;Conic::superscs;Nlpsol::ampl;Conic::proxqp;Conic::osqp;Nlpsol::alpaqa;Conic::nlpsol;Conic::qrqp;Conic::ipqp;Nlpsol::qrsqp;Importer::shell;Integrator::rk;Integrator::collocation;Interpolant::linear;Interpolant::bspline;Linsol::symbolicqr;Linsol::qr;Linsol::ldl;Linsol::tridiag;Linsol::lsqr;Nlpsol::sqpmethod;Nlpsol::feasiblesqpmethod;Nlpsol::scpgen;Rootfinder::newton;Rootfinder::fast_newton;Rootfinder::nlpsol" // NOLINT(whitespace/line_length)
|
41
41
|
#define CASADI_INSTALL_PREFIX "/usr/local" // NOLINT(whitespace/line_length)
|
42
42
|
#define CASADI_SHARED_LIBRARY_PREFIX "lib" // NOLINT(whitespace/line_length)
|
43
43
|
#define CASADI_SHARED_LIBRARY_SUFFIX ".so" // NOLINT(whitespace/line_length)
|
@@ -135,6 +135,7 @@ namespace casadi {
|
|
135
135
|
/** \brief Function pointer types for the C API
|
136
136
|
|
137
137
|
\identifier{7j} */
|
138
|
+
typedef int (*config_t)(int, const char**);
|
138
139
|
typedef void (*signal_t)(void);
|
139
140
|
typedef casadi_int (*getint_t)(void);
|
140
141
|
typedef double (*default_t)(casadi_int i);
|
@@ -144,6 +144,28 @@ private:
|
|
144
144
|
template<typename T>
|
145
145
|
std::vector<T> vector_slice(const std::vector<T> &v, const std::vector<casadi_int> &i);
|
146
146
|
|
147
|
+
/** \brief Select subset of vector
|
148
|
+
|
149
|
+
* \param v Vector to slice
|
150
|
+
* \param s Select?
|
151
|
+
|
152
|
+
\identifier{286} */
|
153
|
+
template<typename T>
|
154
|
+
std::vector<T> vector_select(const std::vector<T> &v, const std::vector<bool> &s,
|
155
|
+
bool invert=false);
|
156
|
+
|
157
|
+
/** \brief Return all but the first element of a vector
|
158
|
+
|
159
|
+
\identifier{27y} */
|
160
|
+
template<typename T>
|
161
|
+
std::vector<T> vector_tail(const std::vector<T> &v);
|
162
|
+
|
163
|
+
/** \brief Return all but the last element of a vector
|
164
|
+
|
165
|
+
\identifier{285} */
|
166
|
+
template<typename T>
|
167
|
+
std::vector<T> vector_init(const std::vector<T> &v);
|
168
|
+
|
147
169
|
/** \brief Reverse a list
|
148
170
|
|
149
171
|
\identifier{1la} */
|
@@ -526,6 +548,36 @@ namespace casadi {
|
|
526
548
|
return ret;
|
527
549
|
}
|
528
550
|
|
551
|
+
template<typename T>
|
552
|
+
std::vector<T> vector_select(const std::vector<T> &v, const std::vector<bool> &s, bool invert) {
|
553
|
+
std::vector<T> ret;
|
554
|
+
casadi_assert(v.size()==s.size(), "Dimension mismatch.");
|
555
|
+
if (invert) {
|
556
|
+
for (casadi_int k=0;k<s.size();++k) {
|
557
|
+
if (!s[k]) ret.push_back(v[k]);
|
558
|
+
}
|
559
|
+
} else {
|
560
|
+
for (casadi_int k=0;k<s.size();++k) {
|
561
|
+
if (s[k]) ret.push_back(v[k]);
|
562
|
+
}
|
563
|
+
}
|
564
|
+
return ret;
|
565
|
+
}
|
566
|
+
|
567
|
+
template<typename T>
|
568
|
+
std::vector<T> vector_tail(const std::vector<T> &v) {
|
569
|
+
std::vector<T> ret;
|
570
|
+
ret.insert(ret.begin(), v.begin()+1, v.end());
|
571
|
+
return ret;
|
572
|
+
}
|
573
|
+
|
574
|
+
template<typename T>
|
575
|
+
std::vector<T> vector_init(const std::vector<T> &v) {
|
576
|
+
std::vector<T> ret;
|
577
|
+
ret.insert(ret.begin(), v.begin(), v.begin()+v.size()-1);
|
578
|
+
return ret;
|
579
|
+
}
|
580
|
+
|
529
581
|
template<typename T>
|
530
582
|
std::vector<T> reverse(const std::vector<T> &v) {
|
531
583
|
std::vector<T> ret(v.size());
|
@@ -108,6 +108,11 @@ namespace casadi {
|
|
108
108
|
\identifier{27l} */
|
109
109
|
casadi_int get_constant(const std::vector<char>& v, bool allow_adding=false);
|
110
110
|
|
111
|
+
/** \brief Get or add a vector<string> constant
|
112
|
+
|
113
|
+
\identifier{27z} */
|
114
|
+
casadi_int get_constant(const std::vector<std::string>& v, bool allow_adding=false);
|
115
|
+
|
111
116
|
/** \brief Represent an array constant; adding it when new
|
112
117
|
|
113
118
|
\identifier{rz} */
|
@@ -138,6 +143,11 @@ namespace casadi {
|
|
138
143
|
\identifier{27m} */
|
139
144
|
std::string constant(const std::vector<char>& v);
|
140
145
|
|
146
|
+
/** \brief Represent an array constant; adding it when new
|
147
|
+
|
148
|
+
\identifier{280} */
|
149
|
+
std::string constant(const std::vector<std::string>& v);
|
150
|
+
|
141
151
|
/** \brief Allocate file scope double read-only memory
|
142
152
|
|
143
153
|
\identifier{s2} */
|
@@ -153,6 +163,10 @@ namespace casadi {
|
|
153
163
|
\identifier{s4} */
|
154
164
|
void define_rom_integer(const void* id, casadi_int size);
|
155
165
|
|
166
|
+
/** \brief Setup a callback
|
167
|
+
|
168
|
+
\identifier{27s} */
|
169
|
+
void setup_callback(const std::string& s, const Function& f);
|
156
170
|
/** \brief Access file scope integer read-only memory
|
157
171
|
|
158
172
|
\identifier{s5} */
|
@@ -243,6 +257,7 @@ namespace casadi {
|
|
243
257
|
std::string initializer(const std::vector<double>& v);
|
244
258
|
std::string initializer(const std::vector<casadi_int>& v);
|
245
259
|
std::string initializer(const std::vector<char>& v);
|
260
|
+
std::string initializer(const std::vector<std::string>& v);
|
246
261
|
|
247
262
|
/** \brief Sanitize source files for codegen
|
248
263
|
|
@@ -614,7 +629,12 @@ namespace casadi {
|
|
614
629
|
AUX_MMIN,
|
615
630
|
AUX_MMAX,
|
616
631
|
AUX_LOGSUMEXP,
|
617
|
-
AUX_SPARSITY
|
632
|
+
AUX_SPARSITY,
|
633
|
+
AUX_BFGS,
|
634
|
+
AUX_ORACLE_CALLBACK,
|
635
|
+
AUX_OCP_BLOCK,
|
636
|
+
AUX_ORACLE,
|
637
|
+
AUX_SCALED_COPY
|
618
638
|
};
|
619
639
|
|
620
640
|
/** \brief Add a built-in auxiliary function
|
@@ -657,6 +677,12 @@ namespace casadi {
|
|
657
677
|
void print_vector(std::ostream &s, const std::string& name,
|
658
678
|
const std::vector<double>& v);
|
659
679
|
|
680
|
+
/** \brief Print string vector to a c file
|
681
|
+
|
682
|
+
\identifier{281} */
|
683
|
+
void print_vector(std::ostream &s, const std::string& name,
|
684
|
+
const std::vector<std::string>& v);
|
685
|
+
|
660
686
|
/** \brief Create a copy operation
|
661
687
|
|
662
688
|
\identifier{tt} */
|
@@ -895,6 +921,7 @@ namespace casadi {
|
|
895
921
|
std::multimap<size_t, size_t> added_double_constants_;
|
896
922
|
std::multimap<size_t, size_t> added_integer_constants_;
|
897
923
|
std::multimap<size_t, size_t> added_char_constants_;
|
924
|
+
std::multimap<size_t, size_t> added_string_constants_;
|
898
925
|
std::map<std::string, std::pair<std::string, std::string> > local_variables_;
|
899
926
|
std::map<std::string, std::string> local_default_;
|
900
927
|
std::map<const void *, casadi_int> file_scope_double_;
|
@@ -916,6 +943,7 @@ namespace casadi {
|
|
916
943
|
std::vector<std::vector<double> > double_constants_;
|
917
944
|
std::vector<std::vector<casadi_int> > integer_constants_;
|
918
945
|
std::vector<std::vector<char> > char_constants_;
|
946
|
+
std::vector<std::vector<std::string> > string_constants_;
|
919
947
|
|
920
948
|
// Does any function need thread-local memory?
|
921
949
|
bool needs_mem_;
|
@@ -924,6 +952,7 @@ namespace casadi {
|
|
924
952
|
static size_t hash(const std::vector<double>& v);
|
925
953
|
static size_t hash(const std::vector<casadi_int>& v);
|
926
954
|
static size_t hash(const std::vector<char>& v);
|
955
|
+
static size_t hash(const std::vector<std::string>& v);
|
927
956
|
|
928
957
|
std::string wrapper(const Function& base, const std::string& name);
|
929
958
|
|
@@ -274,6 +274,11 @@ namespace casadi {
|
|
274
274
|
/// Check if evaluation output
|
275
275
|
bool is_output() const;
|
276
276
|
|
277
|
+
/** \brief Check if a multiple output node
|
278
|
+
|
279
|
+
\identifier{284} */
|
280
|
+
bool has_output() const;
|
281
|
+
|
277
282
|
/// Get the index of evaluation output - only valid when is_output() is true
|
278
283
|
casadi_int which_output() const;
|
279
284
|
|
@@ -306,15 +311,23 @@ namespace casadi {
|
|
306
311
|
\identifier{qp} */
|
307
312
|
std::vector<MX> primitives() const;
|
308
313
|
|
314
|
+
/// @{
|
309
315
|
/** \brief Split up an expression along symbolic primitives
|
310
316
|
|
311
317
|
\identifier{qq} */
|
312
318
|
std::vector<MX> split_primitives(const MX& x) const;
|
319
|
+
std::vector<SX> split_primitives(const SX& x) const;
|
320
|
+
std::vector<DM> split_primitives(const DM& x) const;
|
321
|
+
/// @}
|
313
322
|
|
323
|
+
/// @{
|
314
324
|
/** \brief Join an expression along symbolic primitives
|
315
325
|
|
316
326
|
\identifier{qr} */
|
317
327
|
MX join_primitives(const std::vector<MX>& v) const;
|
328
|
+
SX join_primitives(const std::vector<SX>& v) const;
|
329
|
+
DM join_primitives(const std::vector<DM>& v) const;
|
330
|
+
/// @}
|
318
331
|
|
319
332
|
/// \cond INTERNAL
|
320
333
|
/** \brief Detect duplicate symbolic expressions
|
@@ -655,6 +668,7 @@ namespace casadi {
|
|
655
668
|
static MX convexify(const MX& H, const Dict& opts = Dict());
|
656
669
|
static MX stop_diff(const MX& expr, casadi_int order);
|
657
670
|
static MX stop_diff(const MX& expr, const MX& var, casadi_int order);
|
671
|
+
static std::vector<MX> difference(const std::vector<MX>& a, const std::vector<MX>& b);
|
658
672
|
///@}
|
659
673
|
/// \endcond
|
660
674
|
|
@@ -836,13 +850,14 @@ namespace casadi {
|
|
836
850
|
return MX::stop_diff(expr, var, order);
|
837
851
|
}
|
838
852
|
|
853
|
+
/** \bried Return all elements of a that do not occur in b, preserving order */
|
854
|
+
inline friend std::vector<MX> difference(const std::vector<MX>& a, const std::vector<MX>& b) {
|
855
|
+
return MX::difference(a, b);
|
856
|
+
}
|
839
857
|
|
840
858
|
/** @} */
|
841
859
|
#endif // SWIG
|
842
860
|
|
843
|
-
/** \bried Return all elements of a that do not occur in b, preserving order */
|
844
|
-
friend std::vector<MX> difference(const std::vector<MX>& a, const std::vector<MX>& b);
|
845
|
-
|
846
861
|
/** \brief returns itself, but with an assertion attached
|
847
862
|
*
|
848
863
|
* If y does not evaluate to 1, a runtime error is raised
|
@@ -200,6 +200,23 @@ public:
|
|
200
200
|
void set_value(const std::vector<MX>& assignments);
|
201
201
|
/// @}
|
202
202
|
|
203
|
+
/// @{
|
204
|
+
/** \brief Set domain of a decision variable
|
205
|
+
*
|
206
|
+
* \param[in] x decision variable
|
207
|
+
* \param[in] type 'real', 'integer' (default: real)
|
208
|
+
*
|
209
|
+
* \verbatim
|
210
|
+
* opti.set_domain(x, "real")
|
211
|
+
* opti.set_domain(x, "integer")
|
212
|
+
* \endverbatim
|
213
|
+
|
214
|
+
\identifier{27t} */
|
215
|
+
void set_domain(const MX& x, const std::string& domain);
|
216
|
+
|
217
|
+
/// @}
|
218
|
+
|
219
|
+
|
203
220
|
/// Crunch the numbers; solve the problem
|
204
221
|
OptiSol solve();
|
205
222
|
|
@@ -451,6 +468,11 @@ public:
|
|
451
468
|
OPTI_PAR, // parameter
|
452
469
|
OPTI_DUAL_G // dual
|
453
470
|
};
|
471
|
+
enum DomainType {
|
472
|
+
OPTI_DOMAIN_REAL,
|
473
|
+
OPTI_DOMAIN_INTEGER
|
474
|
+
};
|
475
|
+
|
454
476
|
|
455
477
|
struct IndexAbstraction {
|
456
478
|
IndexAbstraction() : start(0), stop(0) {}
|
@@ -475,6 +497,7 @@ public:
|
|
475
497
|
casadi_int n;
|
476
498
|
casadi_int m;
|
477
499
|
VariableType type;
|
500
|
+
DomainType domain;
|
478
501
|
casadi_int count;
|
479
502
|
casadi_int i;
|
480
503
|
casadi_int active_i;
|
@@ -66,12 +66,14 @@ struct casadi_nlpsol_detect_bounds_data {
|
|
66
66
|
T1* lam_xu;
|
67
67
|
};
|
68
68
|
// C-REPLACE "casadi_nlpsol_detect_bounds_data<T1>" "struct casadi_nlpsol_detect_bounds_data"
|
69
|
+
// C-REPLACE "casadi_oracle_data<T1>" "struct casadi_oracle_data"
|
69
70
|
|
70
71
|
// SYMBOL "nlpsol_data"
|
71
72
|
template<typename T1>
|
72
73
|
struct casadi_nlpsol_data {
|
73
74
|
// Problem structure
|
74
75
|
const casadi_nlpsol_prob<T1>* prob;
|
76
|
+
casadi_oracle_data<T1>* oracle;
|
75
77
|
// Variable bounds
|
76
78
|
T1 *lbz, *ubz;
|
77
79
|
// Current primal solution
|
@@ -151,8 +153,6 @@ void casadi_nlpsol_init(casadi_nlpsol_data<T1>* d, const T1*** arg, T1*** res,
|
|
151
153
|
|
152
154
|
}
|
153
155
|
|
154
|
-
// C-REPLACE "fabs" "casadi_fabs"
|
155
|
-
|
156
156
|
// SYMBOL "nlpsol_detect_bounds_before"
|
157
157
|
template<typename T1>
|
158
158
|
int casadi_detect_bounds_before(casadi_nlpsol_data<T1>* d_nlp) {
|
@@ -194,8 +194,14 @@ int casadi_detect_bounds_before(casadi_nlpsol_data<T1>* d_nlp) {
|
|
194
194
|
for (casadi_int i=0;i<p_bounds->ng;++i) {
|
195
195
|
if (p_bounds->is_simple[i]) {
|
196
196
|
// Update lbz/ubz
|
197
|
-
|
198
|
-
T1
|
197
|
+
|
198
|
+
T1 lb = (d_nlp->lbg[i]-d_bounds->b[k])/d_bounds->a[k];
|
199
|
+
T1 ub = (d_nlp->ubg[i]-d_bounds->b[k])/d_bounds->a[k];
|
200
|
+
if (d_bounds->a[k]<0) {
|
201
|
+
T1 tmp = lb;
|
202
|
+
lb = ub;
|
203
|
+
ub = tmp;
|
204
|
+
}
|
199
205
|
casadi_int j = p_bounds->target_x[k];
|
200
206
|
|
201
207
|
if (lb==d_nlp->lbz[j]) {
|
@@ -270,5 +276,14 @@ int casadi_detect_bounds_after(casadi_nlpsol_data<T1>* d_nlp) {
|
|
270
276
|
d_nlp->lam_g[d_bounds->target_u[i]-nx] += (d_nlp->lam[i]>0)*d_nlp->lam[i];
|
271
277
|
}
|
272
278
|
}
|
279
|
+
|
280
|
+
k = 0;
|
281
|
+
for (casadi_int i=0;i<p_bounds->ng;++i) {
|
282
|
+
if (p_bounds->is_simple[i]) {
|
283
|
+
if (d_nlp->lam_g) d_nlp->lam_g[i] /= d_bounds->a[k];
|
284
|
+
k++;
|
285
|
+
}
|
286
|
+
}
|
287
|
+
|
273
288
|
return 0;
|
274
289
|
}
|
@@ -0,0 +1,55 @@
|
|
1
|
+
//
|
2
|
+
// MIT No Attribution
|
3
|
+
//
|
4
|
+
// Copyright (C) 2010-2023 Joel Andersson, Joris Gillis, Moritz Diehl, KU Leuven.
|
5
|
+
//
|
6
|
+
// Permission is hereby granted, free of charge, to any person obtaining a copy of this
|
7
|
+
// software and associated documentation files (the "Software"), to deal in the Software
|
8
|
+
// without restriction, including without limitation the rights to use, copy, modify,
|
9
|
+
// merge, publish, distribute, sublicense, and/or sell copies of the Software, and to
|
10
|
+
// permit persons to whom the Software is furnished to do so.
|
11
|
+
//
|
12
|
+
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED,
|
13
|
+
// INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A
|
14
|
+
// PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
|
15
|
+
// HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
16
|
+
// OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
|
17
|
+
// SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
18
|
+
//
|
19
|
+
|
20
|
+
|
21
|
+
// SYMBOL "ocp_block"
|
22
|
+
struct casadi_ocp_block {
|
23
|
+
casadi_int offset_r;
|
24
|
+
casadi_int offset_c;
|
25
|
+
casadi_int rows;
|
26
|
+
casadi_int cols;
|
27
|
+
};
|
28
|
+
// C-REPLACE "casadi_ocp_block" "struct casadi_ocp_block"
|
29
|
+
|
30
|
+
// SYMBOL "unpack_ocp_blocks"
|
31
|
+
template<typename T1>
|
32
|
+
void casadi_unpack_ocp_blocks(casadi_ocp_block* blocks, const casadi_int* packed) {
|
33
|
+
casadi_int i;
|
34
|
+
casadi_int N = *packed++;
|
35
|
+
for (i=0;i<N;++i) {
|
36
|
+
blocks[i].offset_r = *packed++;
|
37
|
+
blocks[i].offset_c = *packed++;
|
38
|
+
blocks[i].rows = *packed++;
|
39
|
+
blocks[i].cols = *packed++;
|
40
|
+
}
|
41
|
+
}
|
42
|
+
|
43
|
+
// SYMBOL "ptr_ocp_block"
|
44
|
+
template<typename T1>
|
45
|
+
void casadi_ptr_ocp_block(casadi_int N, T1** vs, T1* v, const casadi_ocp_block* blocks, int eye) {
|
46
|
+
casadi_int k, offset = 0;
|
47
|
+
for (k=0;k<N;++k) {
|
48
|
+
vs[k] = v+offset;
|
49
|
+
if (eye) {
|
50
|
+
offset += blocks[k].rows;
|
51
|
+
} else {
|
52
|
+
offset += blocks[k].rows*blocks[k].cols;
|
53
|
+
}
|
54
|
+
}
|
55
|
+
}
|
@@ -0,0 +1,44 @@
|
|
1
|
+
//
|
2
|
+
// MIT No Attribution
|
3
|
+
//
|
4
|
+
// Copyright (C) 2010-2023 Joel Andersson, Joris Gillis, Moritz Diehl, KU Leuven.
|
5
|
+
//
|
6
|
+
// Permission is hereby granted, free of charge, to any person obtaining a copy of this
|
7
|
+
// software and associated documentation files (the "Software"), to deal in the Software
|
8
|
+
// without restriction, including without limitation the rights to use, copy, modify,
|
9
|
+
// merge, publish, distribute, sublicense, and/or sell copies of the Software, and to
|
10
|
+
// permit persons to whom the Software is furnished to do so.
|
11
|
+
//
|
12
|
+
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED,
|
13
|
+
// INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A
|
14
|
+
// PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
|
15
|
+
// HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
16
|
+
// OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
|
17
|
+
// SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
18
|
+
//
|
19
|
+
|
20
|
+
// C-REPLACE "OracleMemory* m;" ""
|
21
|
+
|
22
|
+
|
23
|
+
// SYMBOL "oracle_data"
|
24
|
+
template<typename T1>
|
25
|
+
struct casadi_oracle_data {
|
26
|
+
const T1** arg;
|
27
|
+
T1** res;
|
28
|
+
casadi_int* iw;
|
29
|
+
T1* w;
|
30
|
+
|
31
|
+
void* m;
|
32
|
+
};
|
33
|
+
|
34
|
+
// C-REPLACE "casadi_oracle_data<T1>" "struct casadi_oracle_data"
|
35
|
+
|
36
|
+
// SYMBOL "oracle_init"
|
37
|
+
template<typename T1>
|
38
|
+
void casadi_oracle_init(casadi_oracle_data<T1>* d, const T1*** arg, T1*** res,
|
39
|
+
casadi_int** iw, T1** w) {
|
40
|
+
d->arg = *arg;
|
41
|
+
d->res = *res;
|
42
|
+
d->iw = *iw;
|
43
|
+
d->w = *w;
|
44
|
+
}
|