Skip to main content

A general Python-based successive convexification implementation which uses a JAX backend.

Project description

License: Apache 2.0


Getting Started

Installation

Stable

To grab the latest stable release simply run

pip install openscvx

to install OpenSCVx in your python environment.

Or using uv:

uv pip install openscvx

For optional dependencies:

pip install openscvx[gui,cvxpygen]
# or with uv
uv pip install openscvx[gui,cvxpygen]
Nightly

To install the latest development version (nightly):

pip install --pre openscvx

With optional dependencies:

pip install --pre openscvx[gui,cvxpygen]

Or using uv:

uv pip install --pre openscvx
# With optional dependencies
uv pip install --pre openscvx[gui,cvxpygen]

Note: The --pre flag tells pip/uv to install pre-release versions (e.g., 1.2.4.dev3) from PyPI.

Alternatively, for local development with the latest source:

# Clone the repo
git clone https://github.com/OpenSCvx/OpenSCvx.git
cd OpenSCvx

# Install in editable/development mode
pip install -e .
# or with uv
uv pip install -e .

Dependencies

The main packages are:

  • cvxpy - is used to formulate and solve the convex subproblems
  • jax - is used for determining the Jacobians using automatic differentiation, vectorization, and ahead-of-time (AOT) compilation of the dynamics and their Jacobians
  • numpy - is used for numerical operations
  • diffrax - is used for the numerical integration of the dynamics
  • termcolor - is used for pretty command line output
  • plotly - is used for all visualizations

These will be installed automatically, but can be installed via conda or pip if you are building from source.

GUI Dependencies (Optional)

For interactive 3D plotting and real-time visualization, additional packages are required:

  • pyqtgraph - is used for interactive 3D plotting and real-time visualization
  • PyQt5 - provides the Qt5 GUI framework for pyqtgraph
  • scipy - is used for spatial transformations in plotting functions
  • PyOpenGL - provides OpenGL bindings for Python, required for 3D plotting
  • PyOpenGL_accelerate - (optional) speeds up PyOpenGL

For local development:

pip install -e ".[gui]"

CVXPYGen Dependencies (Optional)

For code generation and faster solver performance, CVXPYGen can be installed:

  • cvxpygen - enables code generation for faster solver performance
  • qocogen - custom solver backend for CVXPYGen (included with cvxpygen extras)

To install with CVXPYGen support:

pip install openscvx[cvxpygen]

Or for both GUI and CVXPYGen:

pip install openscvx[gui,cvxpygen]

CVXPYGen features include:

  • Automatic C++ code generation for optimization problems
  • Faster solver performance through compiled code
  • Support for custom solver backends like QOCOGen

Local Development

This git repository can be installed using https

git clone https://github.com/OpenSCvx/OpenSCvx.git

or ssh

git clone git@github.com:OpenSCvx/OpenSCvx.git

Dependencies can then be installed using Conda or Pip

Via Conda
  1. Clone the repo using https or ssh

  2. Create a conda environment with Python:

    conda create -n openscvx python>=3.9
    
  3. Activate the environment:

    conda activate openscvx
    
  4. Install the package with dependencies:

    pip install -e .
    

    Or install with optional dependencies:

    pip install -e ".[gui,cvxpygen]"
    
Via uv
  1. Prerequisites

    • Install uv
  2. Clone the repo using https or ssh

  3. Create virtual environment and install the package:

    uv venv
    source .venv/bin/activate  # On Windows: .venv\Scripts\activate
    uv pip install -e .
    

    Or install with optional dependencies:

    uv pip install -e ".[gui,cvxpygen]"
    
Via pip
  1. Prerequisites Python >= 3.9

  2. Clone the repo using https or ssh

  3. Create virtual environment (called venv here) and source it

    python3 -m venv venv
    source venv/bin/activate
    
  4. Install the package with dependencies:

    pip install -e .
    

    Or install with optional dependencies:

    pip install -e ".[gui,cvxpygen]"
    

Running Trajectory Optimization

See examples/ folder for several example trajectory optimization problems grouped by application. To run a problem simply run any of the examples directly, for example:

python3 examples/abstract/brachistochrone.py

Note: To run the examples, you'll need to clone this repository and install OpenSCvx in editable mode (pip install -e .). See the Local Development section above for detailed installation instructions.

and adjust the plotting as needed.

Check out the problem definitions inside examples/ to see how to define your own problems.

Code Structure

ToDos

  • Standardized Vehicle and Constraint classes
  • Implement QOCOGen with CVPYGEN
  • Non-Dilated Time Propagation
  • Save and reload the compiled JAX code
  • Unified Mathematical Interface
  • Auto-SCvx Weight Tuning
  • Compiled at the subproblem level with JAX
  • Single Shot propagation

What is implemented

This repo has the following features:

  1. Free Final Time
  2. Fully adaptive time dilation (s is appended to the control vector)
  3. Continuous-Time Constraint Satisfaction
  4. FOH and ZOH exact discretization (t is a state so you can bring your own scheme)
  5. Vectorized and Ahead-of-Time (AOT) Compiled Multishooting Discretization
  6. JAX Autodiff for Jacobians

(back to top)

Acknowledgements

This work was supported by a NASA Space Technology Graduate Research Opportunity and the Office of Naval Research under grant N00014-17-1-2433. The authors would like to acknowledge Natalia Pavlasek, Samuel Buckner, Abhi Kamath, Govind Chari, and Purnanand Elango as well as the other Autonomous Controls Laboratory members, for their many helpful discussions and support throughout this work.

Citation

Please cite the following works if you use the repository,

@ARTICLE{hayner2025los,
        author={Hayner, Christopher R. and Carson III, John M. and Açıkmeşe, Behçet and Leung, Karen},
        journal={IEEE Robotics and Automation Letters}, 
        title={Continuous-Time Line-of-Sight Constrained Trajectory Planning for 6-Degree of Freedom Systems}, 
        year={2025},
        volume={},
        number={},
        pages={1-8},
        keywords={Robot sensing systems;Vectors;Vehicle dynamics;Line-of-sight propagation;Trajectory planning;Trajectory optimization;Quadrotors;Nonlinear dynamical systems;Heuristic algorithms;Convergence;Constrained Motion Planning;Optimization and Optimal Control;Aerial Systems: Perception and Autonomy},
        doi={10.1109/LRA.2025.3545299}}
@misc{elango2024ctscvx,
      title={Successive Convexification for Trajectory Optimization with Continuous-Time Constraint Satisfaction}, 
      author={Purnanand Elango and Dayou Luo and Abhinav G. Kamath and Samet Uzun and Taewan Kim and Behçet Açıkmeşe},
      year={2024},
      eprint={2404.16826},
      archivePrefix={arXiv},
      primaryClass={math.OC},
      url={https://arxiv.org/abs/2404.16826}, 
}
@misc{chari2025qoco,
  title = {QOCO: A Quadratic Objective Conic Optimizer with Custom Solver Generation},
  author = {Chari, Govind M and A{\c{c}}{\i}kme{\c{s}}e, Beh{\c{c}}et},
  year = {2025},
  eprint = {2503.12658},
  archiveprefix = {arXiv},
  primaryclass = {math.OC},
}

Project details


Release history Release notifications | RSS feed

Download files

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

Source Distribution

openscvx-0.3.2.dev295.tar.gz (32.9 MB view details)

Uploaded Source

Built Distribution

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

openscvx-0.3.2.dev295-py3-none-any.whl (252.3 kB view details)

Uploaded Python 3

File details

Details for the file openscvx-0.3.2.dev295.tar.gz.

File metadata

  • Download URL: openscvx-0.3.2.dev295.tar.gz
  • Upload date:
  • Size: 32.9 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.26 {"installer":{"name":"uv","version":"0.9.26","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for openscvx-0.3.2.dev295.tar.gz
Algorithm Hash digest
SHA256 04e8ac0ae447967c641db6cabe6474359083a959f9741af0f7c289dfce1a7cf3
MD5 3a0eeee4d4f7c8700e9cd289f8cfe05f
BLAKE2b-256 98537ac4eba9fef4d7a6126d5b505a55842c789057902091369b8d1b05b3f0e9

See more details on using hashes here.

File details

Details for the file openscvx-0.3.2.dev295-py3-none-any.whl.

File metadata

  • Download URL: openscvx-0.3.2.dev295-py3-none-any.whl
  • Upload date:
  • Size: 252.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.26 {"installer":{"name":"uv","version":"0.9.26","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for openscvx-0.3.2.dev295-py3-none-any.whl
Algorithm Hash digest
SHA256 6342edc1e6478ed96fe457a5111841f149699cc01f4aad894d95da49076580e1
MD5 27b54731e7fa38346d83bd849dca1d9a
BLAKE2b-256 7389e94857c30f13e6852745665cd8de60529fc20eae57975dcaa066a488c940

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