CVXlab - Open-source Python laboratory for convex algebraic modeling
Project description
Beta Release - CVXlab is currently in beta (v1.0.0b1). The API may change before the stable 1.0.0 release. Documentation is under active development.
CVXlab is an open-source Python laboratory for modeling and solving convex optimization problems. It extends cvxpy with user-friendly interfaces, integrated data management and support for multiple, interconnected optimization models.
Table of Contents
Installation
From PyPI (once published):
pip install cvxlab
From source (for development):
git clone https://github.com/cvxlab/cvxlab.git
cd cvxlab
pip install -e .[docs]
See the Installation Guide for detailed instructions.
Quick Overview
CVXlab allows you to define optimization problems using:
- General-purpose model generator: Model problems as you would mathematically, without restrictive solver forms.
- Almost no-code required: Build models using Excel or YAML—no coding required.
- Centralized data management: Centralized data input/output via SQLite database.
- Multi-Model Support: Generate and solve multiple integrated or decomposed optimization problems.
- Powerful engine embedded: Built on cvxpy package, leveraging its extensive solver support.
Typical workflow:
The figure below provides a synthetic and simplified overview of the CVXlab modeling process.
In generating and handling a CVXlab model, the user must follow the five fundamental activities summarized below:
- The user defines the model settings and the related structure: model scope, structure of variables, and list of mathematical expressions, including equalities, inequalities and (eventually) objective function. This activity requires almost no coding, as model definition can be performed via Excel files or YAML configuration files.
- The user proceeds by generating a CVXlab Model object, consisting in a Python class instance embedding all the model settings and the methods useful to manage the model. At the same time, other items are generated, including the SQLite database file (to store all model data), and the Excel files serving as blank templates for collecting exogenous data from the user.
- The user feeds input data to SQLite database through blank Excel template files. Specifically, user defines the data input required to characterize exogenous model variables.
- The numerical problem is generated, exogenous data fetched from the database, and the problem is solved through CVXPY engine.
- If problem is successfuly solved, results are finally exported to the database. Due to the structure of the relational database, it can be easily linked and inspected via Excel or SQL queries, or imported into Business Intelligence tools (such as PowerBI or Tableau) for more elaborated data visualization and analysis.
Documentation
Full documentation is available at cvxlab.readthedocs.io. You can also browse the source documentation in the docs/source directory.
Changelog
See CHANGELOG.md for a detailed history of changes.
Contributing
We welcome contributions from the community! Please see CONTRIBUTING.md for guidelines.
Community & Support
Submit issues and ideas for improvements in GitHub GitHub Issues
License
Licensed under the Apache License 2.0. See LICENSE for details.
Citing
If you use CVXlab in academic work, please cite our papers. For industry use, we'd love to hear your feedback—reach out via email (matteovincenzo.rocco@polimi.it).
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file cvxlab-1.0.1b1.tar.gz.
File metadata
- Download URL: cvxlab-1.0.1b1.tar.gz
- Upload date:
- Size: 123.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.10.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
08190647a9f80ec702128c661ed95619ab064d60dd3a0764286934b024e46d6d
|
|
| MD5 |
a297ca8ff28c8d071aa68f9991a9b893
|
|
| BLAKE2b-256 |
f818a6bac2e765df7b2fdb6c5e11525b9602a935b7b85f3dde1b2bd67103a241
|
File details
Details for the file cvxlab-1.0.1b1-py3-none-any.whl.
File metadata
- Download URL: cvxlab-1.0.1b1-py3-none-any.whl
- Upload date:
- Size: 132.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.10.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
8706e7cbc167582d50d43bd677f218d72b22f5e78a920edc971069825ecb1878
|
|
| MD5 |
850c93ef347c5a4ac74ddaca9159c7fc
|
|
| BLAKE2b-256 |
e8ba058ef9e9d9de53dfcaab801921f2e35c9fbedffb6f864b43011af2047d8f
|