Skip to main content

JAX-enabled continuous-time LQR solver

Project description

logo

LQRax

LQRax is JAX-enabled continuous-time LQR solver. It is essentially a Riccati equation solver completely written in JAX:

  • It accelerates numerical simulation through JAX's scan mechanism;
  • It allows rapid prototyping of iterative LQR (iLQR) for nonlinear control by supporting auto-differentiation on the loss function and dynamics;
  • It also enables batch-based large-scale optimal control using JAX's vmap mechanism.

This repo is currently under active development.

example

Install

Follow the instructions to install JAX before installing this package.

To install: pip install lqrax

Usage

There are two modules: LQR and iLQR,

The LQR module solves the following time-varying LQR problem:

$$ \arg\min_{u(t)} \int_0^T \Big[ (x(t)-x_{ref}(t))^\top Q (x(t)-x_{ref}(t)) + u(t)^\top R u(t) \Big] dt $$ $$ \text{s.t. } \dot{x}(t) = A(t) x(t) + B(t) u(t), \quad x(0) = x_0 $$

An jupyter notebook example for the LQR module is provided here. You can open it in Google Colab here.

The iLQR module solves a different time-varying LQR problem:

$$ \arg\min_{v(t)} \int_0^T \Big[ z(t)^\top Q z(t) + v(t)^\top R v(t) + z(t)^\top a(t) + v(t)^\top b(t) \Big] dt $$ $$ \text{s.t. } \dot{z}(t) = A(t) z(t) + B(t) v(t), \quad z(0) = 0. $$

This formulation is often used as the sub-problem for iterative linear quadratic regulator (iLQR) to calculate the steepest descent direction on the control for a general nonlinear control problem:

$$ \arg\min_{u(t)} \int_0^T l(x(t), u(t)) dt, \text{ s.t. } \dot{x}(t) = f(x(t), u(t)), $$

where the $z(t)$ and $v(t)$ are perturbations on the system's state $x(t)$ and control $u(t)$, and $A(t)$ and $B(t)$ are the linearized system dynamics $f(x(t), u(t))$ on the current system trajectory with respect to the state and control.

An jupyter notebook example of using the iLQR module for a nonlinear control problem is provided here. You can open it in Google Colab here.

Copyright and License

The implementations contained herein are copyright (C) 2024 - 2025 by Max Muchen Sun, and are distributed under the terms of the GNU General Public License (GPL) version 3 (or later). Please see the LICENSE for more information.

If you use the package in your research, please cite this repository. You can see the citation information at the right side panel under "About". The BibTeX file is attached below:

@software{sun_lqrax_2025,
    author = {["Sun"], Max Muchen},
    license = {GPL-3.0},
    month = march,
    title = {{LQRax: JAX-enabled continuous-time LQR solver}},
    url = {https://github.com/MaxMSun/lqrax},
    version = {0.0.5},
    year = {2025}
}

Contact: msun@u.northwestern.edu

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

lqrax-0.0.5.tar.gz (16.7 kB view details)

Uploaded Source

Built Distribution

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

lqrax-0.0.5-py3-none-any.whl (17.8 kB view details)

Uploaded Python 3

File details

Details for the file lqrax-0.0.5.tar.gz.

File metadata

  • Download URL: lqrax-0.0.5.tar.gz
  • Upload date:
  • Size: 16.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.10.14

File hashes

Hashes for lqrax-0.0.5.tar.gz
Algorithm Hash digest
SHA256 e661f4a2ab3eeadfc208b021b1503b7d3ce73f1ce0546c84628ee289650d0552
MD5 7339d5f42afbb01574fcce57fa9b562e
BLAKE2b-256 3fbb2eacfdf7e09235cd4bc53efaea9fa66035fe2d653d066643e22cc780a303

See more details on using hashes here.

File details

Details for the file lqrax-0.0.5-py3-none-any.whl.

File metadata

  • Download URL: lqrax-0.0.5-py3-none-any.whl
  • Upload date:
  • Size: 17.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.10.14

File hashes

Hashes for lqrax-0.0.5-py3-none-any.whl
Algorithm Hash digest
SHA256 674bf0603ff28d285a5849f7d3459c84849cc70e4fff8f2a01e8030fae30991d
MD5 69a1f45b44e65e3b3447eb0b167f0fb4
BLAKE2b-256 a842e70a0e5ab217b94191b3f1cb0c77fbc46a4ca3780ae2cdfbc4e4da376627

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