Skip to main content

HILO-MPC is a toolbox for easy, flexible and fast development of machine-learning-supported optimal control and estimation problems

Project description

HILO-MPC

python Documentation Status tests CodeQL

doi Github license Github release

HILO-MPC is a Python toolbox for easy, flexible and fast realization of machine-learning-supported optimal control, and estimation problems developed mainly at the Control and Cyber-Physical Systems Laboratory, TU Darmstadt, and the Laboratory for Systems Theory and Control, Otto von Guericke University. It can be used for model predictive control, moving horizon estimation, Kalman filters, solving optimal control problems and has interfaces to embedded model predictive control tools.

HILO-MPC can interface directly to TensorFlow and PyTorch to create machine learning models and the CasADi framework to efficiently build control and estimation problems. The machine learning models can be used (almost) everywhere in the setup of these problems.

plot

Currently the following machine learning models are supported:

  • Feedforward neural networks
  • Gaussian processes

The following machine learning models are currently under development:

  • Bayesian neural network
  • Recurrent neural network

At the moment the following MPC and optimal control problems can be solved:

  • Reference tracking nonlinear MPC
  • Trajectory tracking nonlinear MPC
  • Path following nonlinear MPC
  • Economic nonlinear MPC
  • Linear MPC
  • Traditional optimal control problems

All the nonlinear MPCs support soft constraints, time-variant systems, time-varying parameters and can be used to solve minimum-time problems. They work for continuous-time and discrete-time models, in DAE or ODE form. Linear MPC is currently limited towards discrete-time models.

A rich set of examples is available, spanning:

  • NMPC for bioreactors using hybrid first principle and learned models
  • Trajectory tracking and path following model predictive control with learning and obstacle avoidance
  • Output feedback MPC of a continuous stirred tank reactor with a Gaussian process prediction model
  • Learning NMPC control using a neural network
  • Simple LQR, PID
  • Moving horizon estimation, extended Kalman filter, unscented Kalman filter, and particle filter for a continuous stirred tank reactor

Installation

Using Poetry (recommended):

poetry install

Optional extras:

  • Plotting backends: poetry install -E viz
  • Data utilities: poetry install -E ml

From PyPI using pip:

pip install hilo-mpc

Python support: 3.10–3.12 (aligned to current CasADi wheels). Newer versions may work once CasADi adds support.

Optional Dependencies

HILO-MPC uses a minimal core installation by default. Additional features require optional dependencies, which are kept optional to avoid forcing users to install heavy packages they may not need.

Installation with Extras

Install specific feature sets using Poetry extras:

# Machine learning utilities (scikit-learn, pandas)
poetry install -E ml

# Plotting backends (Bokeh, Matplotlib)
poetry install -E viz

# TensorFlow backend for neural networks
poetry install -E tensorflow

# PyTorch backend for neural networks
poetry install -E pytorch

# Install multiple extras
poetry install -E ml -E viz -E tensorflow

Or with pip:

pip install hilo-mpc[ml,viz,tensorflow]

Optional Package Versions

Extra Packages Version Constraints Purpose
ml scikit-learn ≥0.19.2 Data preprocessing and normalization
pandas ≥2.0.0 Data handling for training
viz Bokeh ≥2.3.0 Interactive plotting
Matplotlib ≥3.0.0 Static plotting
tensorflow TensorFlow ≥2.8.0 Neural network training (TensorFlow backend)
TensorBoard ≥2.8.0 Training visualization
pytorch PyTorch ≥1.2.0 Neural network training (PyTorch backend)
TorchVision ≥0.4.0 PyTorch utilities

Note: The package will raise informative errors if you try to use features that require uninstalled optional dependencies. This design keeps the core installation lightweight while allowing users to install only what they need.

Documentation

The documentation can be found here. Note that this documentation is not complete and will be updated over time.

Citing HILO-MPC

If you use HILO-MPC for your research, please cite the following publication:

@misc{pohlodek2022hilompc,
    title = {Flexible development and evaluation of machine-learning-supported optimal control and estimation methods via {HILO-MPC}},
    author = {Pohlodek, Johannes and Morabito, Bruno and Schlauch, Christian and Zometa, Pablo and Findeisen, Rolf},
    publisher = {arXiv},
    year = {2022},
    doi = {10.48550/ARXIV.2203.13671}
}

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

hilo_mpc-2.0.0.tar.gz (211.9 kB view details)

Uploaded Source

Built Distribution

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

hilo_mpc-2.0.0-py3-none-any.whl (262.9 kB view details)

Uploaded Python 3

File details

Details for the file hilo_mpc-2.0.0.tar.gz.

File metadata

  • Download URL: hilo_mpc-2.0.0.tar.gz
  • Upload date:
  • Size: 211.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for hilo_mpc-2.0.0.tar.gz
Algorithm Hash digest
SHA256 2c6bfd8a5775b8b789547bd64ae9276f32725cb923f43a2044f1fcae5461874d
MD5 68b3feb5529b7fbd4b6bde3253eaade6
BLAKE2b-256 4661548505f9165c6465e53e607be1ce953c6fe79a0f2827de5a4b029b2ae98c

See more details on using hashes here.

Provenance

The following attestation bundles were made for hilo_mpc-2.0.0.tar.gz:

Publisher: python-publish.yml on hilo-mpc/hilo-mpc

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file hilo_mpc-2.0.0-py3-none-any.whl.

File metadata

  • Download URL: hilo_mpc-2.0.0-py3-none-any.whl
  • Upload date:
  • Size: 262.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for hilo_mpc-2.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 b1077811c67288583ecf7fa0f949cda33231970981a6a4767ad9394f52af18f7
MD5 b4fe00e221222c75f72b4d4869500cea
BLAKE2b-256 cec20bd7ee817fe0688d7c13cb5e19ea4e18e720193e2fa40eceb43491b51717

See more details on using hashes here.

Provenance

The following attestation bundles were made for hilo_mpc-2.0.0-py3-none-any.whl:

Publisher: python-publish.yml on hilo-mpc/hilo-mpc

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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