This repo contains starter code and examples for running simulations in MuJoCo with its Python bindings. This repo is inspired by the C code developed for Prof.Pranav Bhounsule's MuJoCo Bootcamp.
First, install the Python bindings for MuJoCo (newly tested on v2.3.0)
python3 -m pip install mujoco
Then, run the following commands to install PyMuJoCoBase
git clone https://github.com/BolunDai0216/PyMuJoCoBase.git
cd PyMuJoCoBase
python3 -m pip install .
The main purpose of this repo is providing the starter code required to run a MuJoCo simulation with keyboard and mouse callbacks using its Python bindings. The base class is in mujoco_base.py
. To create your own MuJoCo simulation, you can create a new class that inherits mujoco_base.MuJoCoBase
. An example of this usage is provided in example_projectile.py
, the new class should implement the functions
- reset() # Initializes the enviroment and control callback
- controller() # Adds control actions
- simulate() # Copy the simulate() function from
# mujoco_base.MuJoCoBase and add your own twist
The sole purpose of the controller()
function is to change the values of the data.ctrl
which corresponds to the actuator control values. There are two ways to achieve this, one is to set controller()
as the control callback function
mj.set_mjcb_control(self.controller)
in reset()
, an example usage is shown in example_manipulator_drawing.py
. This tells MuJoCo to run the controller automatically. Another way to is to run controller()
directly in simulate()
, i.e., add
while (self.data.time - simstart < 1.0/60.0):
self.controller(self.model, self.data)
mj.mj_step(self.model, self.data)
to simulate()
, please refer to example_manipulator_ik.py
for this usage. This is a more manual approach, which applies the new control action at each time step.
All of the examples in the MuJoCo Bootcamp are translated into Python. The examples include:
- Projectile with drag (pymjbase-projectile-example)
- Control a simple pendulum (pymjbase-pendulum-example)
- Control a double pendulum (pymjbase-dbpendulum-example)
- Leg swing (pymjbase-leg-swing-example)
- Manipulator drawing (pymjbase-manipulator-drawing-example)
- Control an underactuated pendulum (pymjbase-underactuated-pendulum-example)
- Gymnast swing/release on a bar (pymjbase-gymnast-example)
- 2D Hopper (pymjbase-hopper-example)
- Initial Value Problem (pymjbase-ivp-example)
- Inverse Kinematics (pymjbase-manipulator-ik-example)
- 2D Biped (pymjbase-biped-example)
Run the command in the parenthesis to see the example, for example, to run the inverse kinematics example we can use the command:
pymjbase-manipulator-ik-example
I could not get the Python bindings for NLOPT to work on an M1 Mac, its only tested on Ubuntu 20.04 LTS.
If you like this repo please consider giving it a star! If you have any questions or suggestions regarding this repo you can contact me at bd1555 at nyu dot edu
.