- Added logger verbosity managment via environment variable
MPCXX_LOG_LEVEL_OVERRIDE
- In python bindings added the possibility to set the optimization problem parameters, to retrive the optimal sequence and to set horizon slice
- Reduced memory fooprint in the non-linear mpc
- Added python script for benchmarking the non-linear and linear mpc
- Pybind11 dependency updated to version 2.12.0 to support numpy 2
- When an element of the optimization vector from the previous iteration violates the bounds, it is overwritten with the value in the middle of the bounds
- Breaking change: The enum
Logger::log_level
has been renamed toLogger::LogLevel
- Breaking change: The enum
Logger::log_type
has been renamed toLogger::LogType
- Breaking change: The enum
constraints_type
has been renamed toConstraintsType
- Fixed
IMPC::isControlHorizonSliceValid()
andIMPC::isPredictionHorizonSliceValid()
, before was not possible to set a slice where the start+end was bigger than the horizon - Fixed possibly wrong initialization when warm start is disabled. The optimization vector was initialized with the first previous solution, which however might not respect some of the boundaries
- Fixed undefined behavior in case Tineq and/or Teq were set to zero, now the user-defined constraints are not evaluated in such a case
- The
Result
struct now contains the feasibility of the solution vector in theis_feasible
field
- Version 0.6 and 0.6.1 were affected by a bug which was preventing the proper computation of the Jacobian of the user-defined inequality constraints. This bug has been fixed in this version
- Fixed the horizon slicing for the non-linear mpc. The horizon slicing was not working properly when set via the HorizonSlice struct
- Added support for input and state bound constraints in the non-linear mpc. These constraints are actually restricing the search space of the optimization problem and are obeyed by the solver also during intermediate steps of the optimization problem
- Added warm start support in the non-linear mpc. The warm start is disabled by default and can be enabled using the parameter
enable_warm_start
- Breaking change: The stopping criterias in the non-linear mpc parameters are now disabled by default. The only enabled criteria is the maximum number of iterations
- Breaking change: The optimal sequence returned by the linear and non-linear mpc is now containing also the initial condition
- The Jacobians of the constraints in the non-linear mpc are now estimated using the trapeizoial rule
- The functions to set the bound constraints now uses a dedicated structure to define the horizon span
- Breaking change: The functions setConstraints are now split in setStateBounds, setInputBounds and setOutputBounds
- Breaking change: The fields retcode and status_msg in the result struct of the non-linear mpc are now solver_status and solver_status_msg respectively
- Python bindings for the library using pybind11 (pympcxx)
- The result struct now contains a string to describe the status of the optimization problem
- Added new parameters for the nonlinear mpc (time_limit, absolute_ftol, absolute_xtol)
- Breaking change: some of the APIs have been refactored. New APIs: setDiscretizationSamplingTime, setExogenousInputs, optimize substitute setContinuosTimeModel, setExogenuosInputs, step
- Improved error handling in the NLopt interface
- The set of the discretization sampling time was not working properly in the non-linear mpc
- Added examples to show how to use the library
- Fixed the cmake target configuration to properly target the library
- Removed coloured output for the integrated logger
- Configure script now can be used to avoid the installation of the test suite
- Fixed dockerfile to use the 0.6.3 version of the OSQP solver
- Added profiler to measure statistics of the optimization problem
- In linear mpc is now possible to override the warm start of the optimization problem
- Added support for OSQP warm start in linear mpc
- The linear mpc parameters now allows to enable the warm start of the optimization problem
- The mpc result structure now contains a status field to check if the optimization problem has been solved
- CMakelists.txt has been refactored to export the INCLUDE_DIRS variable
- The computation of the scalar multipler was not correct
- Added new api in linear mpc to add a scalar constraints
- In linear mpc the last input command is now used to initialize the optimal control problem
- The default value for the box constraints in linear mpc are now set -inf and inf
- In linear mpc optimal input sequence was erroneously the delta input sequence
- Improved performances of non-linear mpc
- Added support in non-linear for output penalization in objective function (Breaking change)
- In non-linear prediction step index is now available in the model update function (Breaking change)
## [0.1.0] - 2022-11-12
- Added support in linear mpc to define the references, weights, constraints and exogenous inputs different in each prediction step
- Added general support to the retrival of the optimal sequence (state, input and output)
- The API to set the references, weights constraints and exogenous inputs using vector now requires a span of the horizon (Breaking changes)
- Added new APIs to define the references, weights, constraints and exogenous inputs matrices to the whole horizon
- Internal structure of the library has been refactored to separate non-linear and linear classes
- Added support for multiple mpc instances in the same executable
- Minimum c++ version required updated to c++20
- Fixed issue on compilation
- Catch2 dependency updated to version 3
- Improved performances while building the optimization problem in LOptimizer
- Changelog added :)
- Fixed a memory leak in LOptimizer
- Fixed the parameters handling in LOptimizer