Skip to main content

A Python implementation of the adaptive Koopman model predictive control algorithm

Project description

adaptive-kmpc-py

This is a Python implementation of the adaptive Koopman model predictive control (KMPC) algorithm, proposed in https://arxiv.org/abs/2503.17902 (currently under review).

An equivalent Julia implementation can be found in the official paper repository.

Adaptive KMPC algorithm

The controller allows approximating nonlinear system dynamics from experimental data as a linear system, which is then embedded in a convex model predictive controller. This eliminates the need for determining a dynamic model via first principles. Additionally, the model is updated online from the closed-loop feedback, which enables control of systems with varying dynamic parameters.

The algorithm is explained in depth in the linked paper, and verified with real-system control experiments on a 1R and 2R robot system. To ensure understanding of the code, variable names are chosen according to the notation used in the paper.

The following process schematic may help in getting a quick overview of the algorithm and the code.

adaptive_KMPC_scheme
  • For initial model build the controller relies on availability of data that partly capture the underlying system dynamics. These data can be obtained by perturbing the system with a sequence of random controls and recording the system response, which is denoted as preceding experiment.
  • Data are then used to fill a circular buffer, operatin under first-in-first-out logic.
  • Subsequently, Extended Dynamic Mode Decomposition is carried out on the buffer data (for more detailed explanation you can consult the paper), leading to a linear model in the discrete time domain.
  • Casting the linear model in a convex quadratic program along with some reference trajectory, constraints, and feedback on the current state allows solving for an optimal control input that is applied to the system.
  • The applied controls and the measured system response are fed back into the circular buffer, such that the model adapts to the current operating point.

Installation

You can install the latest version from GitHub:

pip install git+https://github.com/adrianodelr/adaptive-kmpc-py.git

Or via the package manager:

pip install adaptive-kmpc-py

Usage

For understanding basic usage, you can have a look at the Jupyter notebooks:

Both demonstrate simulated tracking control of serial robots.

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

adaptive_kmpc_py-0.1.1.tar.gz (5.0 kB view details)

Uploaded Source

Built Distribution

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

adaptive_kmpc_py-0.1.1-py3-none-any.whl (6.0 kB view details)

Uploaded Python 3

File details

Details for the file adaptive_kmpc_py-0.1.1.tar.gz.

File metadata

  • Download URL: adaptive_kmpc_py-0.1.1.tar.gz
  • Upload date:
  • Size: 5.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.1.3 CPython/3.10.12 Linux/6.8.0-60-generic

File hashes

Hashes for adaptive_kmpc_py-0.1.1.tar.gz
Algorithm Hash digest
SHA256 33a8f113b9a648930693ebc054b332de106e32495e36d83edf34fc72c7f717b6
MD5 5b4915f82bac009211b771a9e0b38cda
BLAKE2b-256 fde61734a30d5ee5fddc2ab635371bee0123f1689d835c3526fe6dedf98ba51d

See more details on using hashes here.

File details

Details for the file adaptive_kmpc_py-0.1.1-py3-none-any.whl.

File metadata

  • Download URL: adaptive_kmpc_py-0.1.1-py3-none-any.whl
  • Upload date:
  • Size: 6.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.1.3 CPython/3.10.12 Linux/6.8.0-60-generic

File hashes

Hashes for adaptive_kmpc_py-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 e784c11695c8ae6949828b295b1ce002204aaa1e51e9d855be26fd96d04a1f0f
MD5 a54f2af8a76a32b0e8d9ea9435b75e0d
BLAKE2b-256 c205c4440c38f5a99e2d9a0428423895339261a57d937a71b2c1c8c57c7abe50

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