Skip to main content

Python module to control Upkie wheeled biped robots.

Project description

Upkie wheeled biped robots

CI Documentation Coverage Conda version PyPI version

Upkies are open-source wheeled biped robots featuring wheels for balance and legs to negotiate uneven terrains. They are designed to be buildable with off-the-shelf tools and components, such as mjbots actuators. You can develop in Python or C++, on Linux or macOS, then deploy your behaviors directly to the robot's Raspberry Pi. There are videos showing the robots in action on the Upkies' YouTube channel.

This repository contains all the materials needed to build and control an Upkie. Questions are welcome in the discussions forum or in the chat room.

Building your own

Upkies come with step by step build instructions.

Getting started

Upkies come out-of-the-box with balancing and locomotion capabilities. You can try them out in simulation using pixi:

pixi run example-follow-joystick

Or using uv:

uv run examples/follow_joystick.py

Once the agent is running, you can direct your Upkie using a gamepad 🎮

  • Left joystick ⬆️ ⬇️: go forward or backward
  • Left joystick ⬅️ ➡️: turn left or right
  • Right button: (B on an Xbox controller, red circle on a PS4 controller) emergency stop 🚨

Click on the robot in the simulator window to apply external forces and see how the robot reacts.

Creating your own behaviors

Software for Upkies comes is packaged in an upkie Python library that you can install from conda or pip:

pip install upkie

This library provides Gymnasium environments to control real and simulation robots with the same code. For instance, the following example balances the robot like a wheeled inverted pendulum in PyBullet:

import gymnasium as gym
import numpy as np
import upkie.envs

upkie.envs.register()

with gym.make("Upkie-PyBullet-Pendulum", frequency=200.0) as env:
    observation, _ = env.reset()
    gain = np.array([10.0, 1.0, 0.0, 0.1])
    for step in range(1_000_000):
        action = gain.dot(observation).reshape((1,))
        observation, reward, terminated, truncated, _ = env.step(action)
        if terminated or truncated:
            observation, _ = env.reset()

To switch to the real robot, replace "PyBullet" by "Spine" in the environment name.

Examples

There are smaller standalone examples in the examples directory. For instance:

  • Domain randomization: shows how to add domain-randomization wrappers to an Upkie environment.
  • Lying genuflection: genuflect while lying on a horizontal floor.
  • Model predictive control: a self-contained MPC balancer
  • PD balancer: balance by proportional-derivative feedback to wheel velocities.

Contributing

Contributions are welcome to both the hardware and software of Upkies! Check out the contribution guidelines.

Citation

If you built an Upkie or use parts of this project in your works, please cite the project and its contributors:

@software{upkie,
  title = {{Upkie open source wheeled biped robot}},
  author = {Caron, St\'{e}phane and Perrin-Gilbert, Nicolas and Ledoux, Viviane and G\"{o}kbakan, \"{U}mit Bora and Raverdy, Pierre-Guillaume and Raffin, Antonin and Tordjman{-}{-}Levavasseur, Valentin and Arlaud, Etienne and Duclusaud, Marc},
  url = {https://github.com/upkie/upkie},
  license = {Apache-2.0},
  version = {11.0.0},
  year = {2026}
}

Don't forget to add yourself to the BibTeX above and to CITATION.cff if you contribute to the project.

See also

Reinforcement learning playgrounds for Upkies

  • MjLab Upkie: GPU-accelerated playground based on MjLab and MuJoCo Warp (requires an Nvidia GPU). Can train whole-body policies such as the one depicted to the right.
  • RLB3 upkie: new CPU playground to train policies for Upkie-Pendulum environments via RL Baselines3 Zoo
  • PPO balancer: legacy CPU playground to train policies for Upkie-Pendulum environments using Stable-Baselines3 (video)

Open-source robotics

  • Awesome Open Source Robots: Upkies are one among many open-source open-hardware robot initiative: check out the others!
  • mjbots: The company that manufactures the brushless servos used in Upkies, that are open source in firmware, hardware and software.
  • Open Dynamic Robot Initiative: An open torque-controlled modular robot architecture for legged locomotion research.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

upkie-11.0.0.tar.gz (74.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

upkie-11.0.0-py3-none-any.whl (83.7 kB view details)

Uploaded Python 3

File details

Details for the file upkie-11.0.0.tar.gz.

File metadata

  • Download URL: upkie-11.0.0.tar.gz
  • Upload date:
  • Size: 74.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: python-requests/2.32.4

File hashes

Hashes for upkie-11.0.0.tar.gz
Algorithm Hash digest
SHA256 0118f34d024162fad5a2350ac5bc855bfec04ab341c36700084bbe89081b6097
MD5 0d36d28f64ac0f73c392177dc15ba706
BLAKE2b-256 2162ec4d44c36e7b22e3f77b8a79c402e6302a2c4a394c4e7b638ba6d8546ae6

See more details on using hashes here.

File details

Details for the file upkie-11.0.0-py3-none-any.whl.

File metadata

  • Download URL: upkie-11.0.0-py3-none-any.whl
  • Upload date:
  • Size: 83.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: python-requests/2.32.4

File hashes

Hashes for upkie-11.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 c07f94221333fd8de80fdbad99c06eb73c23427c21d882c28d30fefcd9c83240
MD5 376ae03543ea8cb0c2c58f961701c7ca
BLAKE2b-256 f4353a9da82282cf4506ac9bdab9b2f54302320573241e805b75342ef44691cd

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page