Skip to main content

Benchmark toolkit for optimization

Project description

https://raw.githubusercontent.com/benchopt/communication_materials/main/posters/images/logo_benchopt.png

—A framework for reproducible, comparable benchmarks—


Test Status codecov Documentation Python 3.6+ install-per-months discord SWH

Benchopt is a benchmarking suite tailored for machine learning workflows. It is built for simplicity, transparency, and reproducibility. It is implemented in Python but can run algorithms written in many programming languages.

So far, benchopt has been tested with Python, R, Julia and C/C++ (compiled binaries with a command line interface). Programs available via conda should be compatible as well. See for instance an example of usage with R.

Install

It is recommended to use benchopt within a conda environment to fully-benefit from benchopt Command Line Interface (CLI).

To install benchopt, start by creating a new conda environment and then activate it

conda create -n benchopt python
conda activate benchopt

Then run the following command to install the latest release of benchopt

pip install -U benchopt

It is also possible to use the latest development version. To do so, run instead

pip install git+https://github.com/benchopt/benchopt.git

Getting started

After installing benchopt, you can

  • replicate/modify an existing benchmark

  • create your own benchmark

Using an existing benchmark

Replicating an existing benchmark is simple. Here is how to do so for the L2-logistic Regression benchmark.

  1. Clone the benchmark repository and cd to it

git clone https://github.com/benchopt/benchmark_logreg_l2
cd benchmark_logreg_l2
  1. Install the desired solvers automatically with benchopt

benchopt install . -s lightning -s sklearn
  1. Run the benchmark to get the figure below

benchopt run . --config ./example_config.yml
https://benchopt.github.io/_images/sphx_glr_plot_run_benchmark_001.png

These steps illustrate how to reproduce the L2-logistic Regression benchmark. Find the complete list of the Available benchmarks. Also, refer to the documentation to learn more about benchopt CLI and its features. You can also easily extend this benchmark by adding a dataset, solver or metric. Learn that and more in the Benchmark workflow.

Creating a benchmark

The section Write a benchmark of the documentation provides a tutorial for creating a benchmark. The benchopt community also maintains a template benchmark to quickly and easily start a new benchmark.

Finding help

Join benchopt discord server and get in touch with the community! Feel free to drop us a message to get help with running/constructing benchmarks or (why not) discuss new features to be added and future development directions that benchopt should take.

Citing Benchopt

Benchopt is a continuous effort to make reproducible and transparent ML and optimization benchmarks. Join us in this endeavor! If you use benchopt in a scientific publication, please cite

@inproceedings{benchopt,
   author    = {Moreau, Thomas and Massias, Mathurin and Gramfort, Alexandre
                and Ablin, Pierre and Bannier, Pierre-Antoine
                and Charlier, Benjamin and Dagréou, Mathieu and Dupré la Tour, Tom
                and Durif, Ghislain and F. Dantas, Cassio and Klopfenstein, Quentin
                and Larsson, Johan and Lai, En and Lefort, Tanguy
                and Malézieux, Benoit and Moufad, Badr and T. Nguyen, Binh and Rakotomamonjy,
                Alain and Ramzi, Zaccharie and Salmon, Joseph and Vaiter, Samuel},
   title     = {Benchopt: Reproducible, efficient and collaborative optimization benchmarks},
   year      = {2022},
   booktitle = {NeurIPS},
   url       = {https://arxiv.org/abs/2206.13424}
}

Available benchmarks

Problem

Results

Build Status

Ordinary Least Squares (OLS)

Results

Build Status OLS

Non-Negative Least Squares (NNLS)

Results

Build Status NNLS

LASSO: L1-Regularized Least Squares

Results

Build Status Lasso

LASSO Path

Results

Build Status Lasso Path

Elastic Net

Build Status ElasticNet

MCP

Results

Build Status MCP

L2-Regularized Logistic Regression

Results

Build Status LogRegL2

L1-Regularized Logistic Regression

Results

Build Status LogRegL1

L2-regularized Huber regression

Results

Build Status HuberL2

L1-Regularized Quantile Regression

Results

Build Status QuantileRegL1

Linear SVM for Binary Classification

Results

Build Status LinearSVM

Linear ICA

Build Status LinearICA

Approximate Joint Diagonalization (AJD)

Build Status JointDiag

1D Total Variation Denoising

Results

Build Status TV1D

2D Total Variation Denoising

Build Status TV2D

ResNet Classification

Results

Build Status ResNetClassif

Bilevel Optimization

Results

Build Status Bilevel

Sorted L-One Penalized Estimation (SLOPE)

Build Status SLOPE

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

benchopt-1.9.0.tar.gz (1.2 MB view details)

Uploaded Source

Built Distribution

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

benchopt-1.9.0-py3-none-any.whl (213.5 kB view details)

Uploaded Python 3

File details

Details for the file benchopt-1.9.0.tar.gz.

File metadata

  • Download URL: benchopt-1.9.0.tar.gz
  • Upload date:
  • Size: 1.2 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for benchopt-1.9.0.tar.gz
Algorithm Hash digest
SHA256 1b4871e5c28cf9db2c049e72ccde6cd727f765d293238ecee5a55d7bce5f98d3
MD5 41f7a21c973888dc426100967cd6b6f9
BLAKE2b-256 76f92dedfd820c93a1425cde3e7d179b05fd24b5bc1ad560b0e69f4d97769b2a

See more details on using hashes here.

Provenance

The following attestation bundles were made for benchopt-1.9.0.tar.gz:

Publisher: release.yml on benchopt/benchopt

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

File details

Details for the file benchopt-1.9.0-py3-none-any.whl.

File metadata

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

File hashes

Hashes for benchopt-1.9.0-py3-none-any.whl
Algorithm Hash digest
SHA256 e50c1da7333fcced84ea3a7c4fea53e33004f8f82807e6593d4b60f73ac8c0d3
MD5 7f6b074f5f3609b7d1d3ed3afc9ef0f2
BLAKE2b-256 0fe8c87f3c08231845326689e90e475862fdb20237906721005ca357442eec2b

See more details on using hashes here.

Provenance

The following attestation bundles were made for benchopt-1.9.0-py3-none-any.whl:

Publisher: release.yml on benchopt/benchopt

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