Benchmark repository for optimization
=====================================

|Test Status| |Python 3.6+| |codecov|

BenchOpt is a benchmarking suite for optimization algorithms.
It is built for simplicity, transparency, and reproducibility.

Benchopt is implemented in Python, and can run algorithms
written in **many programming languages**.
So far, Benchopt has been tested with `Python <https://www.python.org/>`_,
`R <https://www.r-project.org/>`_, `Julia <https://julialang.org/>`_
and `C/C++ <https://isocpp.org/>`_ (compiled binaries with a command line interface).
Programs available via
`conda <https://docs.conda.io/en/latest/>`_ should be compatible.

BenchOpt is run through a command line interface as described
in the `API Documentation`_.
Replicating an optimization benchmark should
be **as simple as doing**:

.. code-block::

   conda create -n benchopt python
   conda activate benchopt
   pip install -e .
   cd benchmarks/ridge
   benchopt install --config config_example.yml
   benchopt run --config config_example.yml

Running this command will give you a benchmark plot on Ridge Regression.

Learn how to `create a new benchmark`_ or using the `benchmark template`_.

Install
--------

The command line tool to run the benchmarks can be installed through `pip`. In order to allow `benchopt`
to automatically install solvers dependencies, the install needs to be done in a `conda` environment.


.. code-block::

    conda create -n benchopt python
    conda activate benchopt
    pip install -e .

Then, existing benchmarks can be retrieved from git or created locally.

Command line interface
----------------------

The preferred way to run the benchmarks is through the command line interface.
To run the Lasso benchmark on all datasets and with all solvers, run:

.. code-block::

    benchopt run ./benchmarks/lasso

To get more details about the different options, run:

.. code-block::

    benchopt run -h

Benchopt also provides a Python API described in the
`API documentation`_.

.. |Python 3.6+| image:: https://img.shields.io/badge/python-3.6%2B-blue
   :target: https://www.python.org/downloads/release/python-360/

