python_simple_mppi
python_simple_mppi copied to clipboard
Python implementation of MPPI (Model Predictive Path-Integral) controller to understand the basic idea. Mandatory dependencies are numpy and matplotlib only.
Simple MPPI Implementation with Python
Model Predictive Path-Integral (MPPI) Control [G. Williams et al., 2018] is a promising sampling-based optimal control algorithm.
This repository is for understanding the basic idea of the algorithm.
data:image/s3,"s3://crabby-images/5056c/5056c73dd2e4461b141388339fd1830d7ef4a9e0" alt="pathtracking and obstacle avoidance demonstraion"
data:image/s3,"s3://crabby-images/025c8/025c83d92070ec1523386d94bfc1b334d4a08ec7" alt="pathtracking demonstraion"
data:image/s3,"s3://crabby-images/2abe5/2abe5f54f7b64d138b8d89d90212eec25231fce5" alt="swinging up pendulum demonstraion"
data:image/s3,"s3://crabby-images/1a9e9/1a9e9e98dc0f20a0baf6d9c4fbff25ed568bb8e8" alt="swinging up pendulum demonstraion"
Dependency
-
- version 3.10 or higher is recommended.
-
- seting up python environment easily and safely.
- only
numpy
,matplotlib
,notebook
are needed to run all scripts in this repository.
-
-
mp4 movie writer
-
Setup
git clone https://github.com/MizuhoAOKI/python_simple_mppi.git
cd python_simple_mppi
poetry install
Usage
Path Tracking
data:image/s3,"s3://crabby-images/f8d56/f8d567feb7b92c8778020a0ea219322179404f87" alt="pendulum"
Simple Path Tracking
-
Run simulation
cd python_simple_mppi poetry run python scripts/mppi_pathtracking.py
-
Run jupyter notebook if you would like to check mathematical explanations on the algorithm.
cd python_simple_mppi poetry run jupyter notebook notebooks/mppi_pathtracking.ipynb
Path Tracking with Obstacle Avoidance
-
Run simulation
cd python_simple_mppi poetry run python scripts/mppi_pathtracking_obav.py
-
Run jupyter notebook if you would like to check mathematical explanations on the algorithm.
cd python_simple_mppi poetry run jupyter notebook notebooks/mppi_pathtracking_obav.ipynb
Pendulum
data:image/s3,"s3://crabby-images/74e2f/74e2f06489fe49a8e7f512c48d5b6840c4e1c036" alt="pendulum"
-
Run simulation to swing up a pendulum.
cd python_simple_mppi poetry run python scripts/mppi_pendulum.py
-
Run jupyter notebook if you would like to check mathematical explanations on the algorithm.
cd python_simple_mppi poetry run jupyter notebook notebooks/mppi_pendulum.ipynb
CartPole
data:image/s3,"s3://crabby-images/805f9/805f9b1d51c4dc05de43fed005b7e8cd60338223" alt="cartpole"
-
Run simulation of cartpole
cd python_simple_mppi poetry run python scripts/mppi_cartpole.py
-
Run jupyter notebook if you would like to check mathematical explanations on the algorithm.
cd python_simple_mppi poetry run jupyter notebook notebooks/mppi_cartpole.ipynb
References
- G. Williams et al. "Information-Theoretic Model Predictive Control: Theory and Applications to Autonomous Driving"
- URL : https://ieeexplore.ieee.org/document/8558663
- PDF : https://arxiv.org/pdf/1707.02342.pdf