This repository provides a set of python scripts solving on toy optimal control problems (simple pendulum, cartpole, etc.). The goal is to familiarize with the core concepts and methods from Optimal Control theory (continous and discrete time).
In particular, the following methods are implemented
- Dynamic Programming (value iteration)
- HJB PDE numerical resolution
- Pontryagin Maximum Principle (a.k.a indirect optimal control)
- Direct Optimal Control (using SQP or DDP, based on Crocoddyl API)
The repo is still under construction (do not look into experimental/
). The scripts available in pendulum/
and cartpole/
should work, but feedback & contributions is welcome in case not.
- Crocoddyl
- mim_solvers
- matplotlib
- mim_robots
It is recommended to use conda. Install miniconda if you do not have it already by following the instructions from the anaconda webpage : https://docs.anaconda.com/miniconda/miniconda-install/
Then create a conda environment :
conda create -n mpc_tutorial
Activate the environment and install mim_solvers, matplotlib and ipython
conda activate mpc_tutorial
conda install -c conda-forge mim-solvers
conda install matplotlib
conda install ipython
Then run the script of your choice, e.g. the pendulum SQP by running :
python pendulum/pendulum_ocp.py
You may also need the mim_robots
package to run more complex examples (e.g. Kuka). Let's install this package inside your conda environment:
git clone [email protected]:machines-in-motion/mim_robots.git
cd mim_robots
pip install . --no-deps