Rapier Python bindings

June 4, 2026 · View on GitHub

The Rapier physics engine exposed to Python via PyO3 and maturin. The bindings ship as four independent PyPI packages, one per (dimension, scalar) flavor — they share an identical API differing only in dimension and scalar type:

PyPI distimport namecrate (python/…)dimscalar
rapier2drapier2drapier-py-2d2Df32
rapier3drapier3drapier-py-3d3Df32
rapier2d-f64rapier2d_f64rapier-py-2d-f642Df64
rapier3d-f64rapier3d_f64rapier-py-3d-f643Df64

rapier-py-core holds the shared PyO3 binding macros (compiled into each package; it is not published on its own). The Panda3D visual testbed lives in the separate rapier-testbed package.

Full documentation lives in docs/; the design of this split is recorded in docs/repackaging/.

Note: these are not yet published on PyPI. The instructions below build the packages locally from this checkout. There is currently no source distribution (sdist), so building requires the full git repository plus a Rust toolchain — see docs/repackaging/05-publishing-pypi.md.

Prerequisites

  • A Rust toolchain (rustup).
  • Python ≥ 3.9 and a virtual environment (extensions are compiled per-environment).
  • maturin for building the Rust extensions.
# from the repository root
python3 -m venv .venv && source .venv/bin/activate
pip install maturin

Quick start

python/dev.sh does everything below in one command — builds all four packages, runs the test suite, builds the docs, and smoke-tests the testbed. It creates and manages a .venv at the repo root on first run:

python/dev.sh                 # build + test + docs + testbed (headless smoke)
python/dev.sh build           # just build the four packages
python/dev.sh test            # build + run the test suite
python/dev.sh docs            # build + build the docs
python/dev.sh testbed         # build + install testbed, open the picker
python/dev.sh --help          # all commands and options (e.g. PROFILE=debug)

The sections below are the manual equivalents.

1. Build the bindings

Each flavor is its own package. Build the one(s) you want, editable, with maturin develop (add --release for an optimized build — slower to compile, much faster at runtime):

maturin develop -m python/rapier-py-3d/Cargo.toml      # 3D f32 -> import rapier3d

Swap rapier-py-3d for rapier-py-2d, rapier-py-3d-f64, or rapier-py-2d-f64 to build the other flavors (see the table above for the matching import name).

python -c "import rapier3d; print(rapier3d.__version__)"   # smoke check

Run the test suite

The test suite is cross-flavor (it parametrizes over all four packages), so install every flavor first:

for c in rapier-py-2d rapier-py-2d-f64 rapier-py-3d rapier-py-3d-f64; do
  maturin develop --release -m "python/$c/Cargo.toml"
done
pip install pytest pytest-timeout hypothesis numpy matplotlib
python -m pytest python/tests        # ~708 passed

2. Build and open the docs

The docs use Sphinx autodoc, so the engine packages must be built first (step 1 — build all four to avoid import warnings). Then:

pip install sphinx furo sphinx-autodoc-typehints
cd python/docs
sphinx-build -b html . _build/html
open _build/html/index.html          # macOS; Linux: xdg-open; Windows: start

3. Run the testbed examples

rapier-testbed is a Panda3D visual gallery of ~127 examples ported from the Rust examples2d/ and examples3d/. It drives both the 2D and 3D engines.

Install

The testbed depends on rapier2d and rapier3d. Since those aren't on PyPI yet, build them first (step 1 above), then install the testbed with --no-deps so pip uses your local builds instead of trying to fetch them. Run this from the repository root (the ./python/... path is relative to it, like the build steps above):

pip install panda3d numpy
pip install --no-deps -e ./python/rapier-testbed

The -e (editable) install means edits to the testbed — examples, camera, etc. — are picked up by python -m rapier_testbed with no reinstall. (--no-deps must come before -e, or pip treats it as the install target.)

Launch

Once installed, these run from any directory (they invoke the installed rapier_testbed module, not a path), inside the virtual environment from the Prerequisites:

# Interactive picker — browse every example by category (opens a window):
python -m rapier_testbed

# Jump straight into one example. 3D examples live under `examples3`,
# 2D under `examples2`:
python -m rapier_testbed.examples3.domino3
python -m rapier_testbed.examples2.pyramid2

# Headless — run a fixed number of steps with no window (needs no display;
# this is what CI uses):
PANDA_NO_WINDOW=1 python -m rapier_testbed.examples3.domino3

To walk through every example in turn — each opens in a window, and closing it launches the next (Ctrl-C to stop):

python python/examples_tour.py          # all (2D then 3D); accepts 2d|3d|--start NAME
python/dev.sh tour                      # same, but builds + installs the testbed first

Controls (in the viewer window)

MouseActionKeyAction
left-dragrotate cameraSpacepause / resume
right-dragpanRreset the scene
wheelzoomTabnext example
Wtoggle wireframe
Escquit

The examples span 9 categories: Collisions, Dynamics, Joints, Controls, Robotics, Stress Tests, Debug, Misc, and "Inspired by Solver 2D". The picker lists them all; each example's module name (for direct launch) matches its file under python/rapier-testbed/rapier_testbed/examples{2,3}/.

License

Apache-2.0