iit-DLSLab / Quadruped-PyMPC

A model predictive controller for quadruped robots based on the single rigid body model and written in python. Gradient-based (acados) or Sampling-based (jax).
132 stars 11 forks source link
acados jax locomotion mujoco optimization quadruped-robot

Overview

This repo contains a model predictive controller based on the single rigid body model and written in Python. It cames in two flavours: gradient-based via acados or sampling-based via jax. The controller is tested on real robots and is compatible with Mujoco.

Features gradient-based mpc:

Features sampling-based mpc:

Experiments with Aliengo
Simulations with Go2

Dependencies

Gradient-based MPC: It uses CasADI to define the model and acados to solve the optimal control problem. Sampling-based MPC: jax for both. The simulation environment is based on Mujoco.

Installation

  1. install miniforge (x86_64)

  2. create an environment using the file in the folder installation choosing between nvidia and integrated gpu, either with or without ros (to run the simulation, you don't need ros!):

    conda env create -f mamba_environment.yml

  3. clone the other submodules:

    git submodule update --init --recursive

  4. activate the conda environment

    conda activate quadruped_pympc_env

  5. go inside the folder acados and compile it pressing:

    mkdir build
    cd build
    cmake ..
    make install -j4
    pip install -e ./../interfaces/acados_template
  6. inside the file .bashrc, given your path_to_acados, put:

    export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:"/path_to_acados/lib"
    export ACADOS_SOURCE_DIR="/path_to_acados"

    Notice that if you are using Mac, you should set

    DYLD_LIBRARY_PATH=$LD_LIBRARY_PATH:"/path_to_acados/lib"
    export ACADOS_SOURCE_DIR="/path_to_acados"

The first time you run the simulation with acados, in the terminal you will be asked to install tera_render. You should accept to proceed.

  1. go inside the folder gym-quadruped and install it:

    pip install -e .

How to run

  1. activate the conda environment

    conda activate quadruped_pympc_env
  2. go in the folder simulation and press

    python3 simulation_mujoco.py

In the file config.py, you can set up the robot, the mpc type (gradient, sampling..), its proprierties (real time iteration, sampling type, foothold optimization..), and other simulation params (reference, gait type..).

  1. you can interact with the simulation with your mouse to add disturbances, or with the keyboard by pressing
    arrow up, arrow down -> add positive or negative forward velocity
    arrow left, arrow right -> add positive or negative yaw velocity
    ctrl -> set zero all velocities

Citing this work

If you find the work useful, please consider citing our work:

@INPROCEEDINGS{turrisi2024sampling,
  title={On the Benefits of GPU Sample-Based Stochastic Predictive Controllers for Legged Locomotion},
  author={Turrisi, Giulio and Modugno, Valerio and Amatucci, Lorenzo and Kanoulas, Dimitrios and Semini, Claudio},
  booktitle={2024 IEEE/RSJ International Conference on Intelligent Robots and Systems (IROS)},
  year={2024}
}

Maintainer

This repository is maintained by Giulio Turrisi and Daniel Ordonez.