OSQP solver documentation
==========================
**Join our** `forum `_ **for any
questions related to the solver!**
The OSQP (Operator Splitting Quadratic Program) solver is a numerical
optimization package for solving convex quadratic programs in the form
.. math::
\begin{array}{ll}
\mbox{minimize} & \frac{1}{2} x^T P x + q^T x \\
\mbox{subject to} & l \leq A x \leq u
\end{array}
where :math:`x` is the optimization variable and
:math:`P \in \mathbf{S}^{n}_{+}` a positive semidefinite matrix.
**Code available on** `GitHub `_.
.. rubric:: Citing OSQP
If you are using OSQP for your work, we encourage you to
* :ref:`Cite the related papers `
* Put a star on GitHub |github-star|
.. |github-star| image:: https://img.shields.io/github/stars/oxfordcontrol/osqp.svg?style=social&label=Star
:target: https://github.com/oxfordcontrol/osqp
**We are looking forward to hearing your success stories with OSQP!** Please `share them with us `_.
.. rubric:: Features
.. glossary::
Efficient
It uses a custom ADMM-based first-order method requiring only a single matrix factorization in the setup phase. All the other operations are extremely cheap. It also implements custom sparse linear algebra routines exploiting structures in the problem data.
Robust
The algorithm is absolutely division free after the setup and it requires no assumptions on problem data (the problem only needs to be convex). It just works!
Detects primal / dual infeasible problems
When the problem is primal or dual infeasible, OSQP detects it. It is the first available QP solver based on first-order methods able to do so.
Embeddable
It has an easy interface to generate customized embeddable C code with no memory manager required.
Library-free
It requires no external library to run.
Efficiently warm started
It can be easily warm-started and the matrix factorization can be cached to solve parametrized problems extremely efficiently.
Interfaces
It can be interfaced to C, C++, Fortran (soon!), Python, Julia and Matlab.
.. rubric:: License
OSQP is distributed under the `Apache 2.0 License `_
.. rubric:: Credits
The following people have been involved in the development of OSQP:
* `Bartolomeo Stellato `_ (Princeton University): main development
* `Goran Banjac `_ (ETH Zürich): main development
* `Nicholas Moehle `_ (Stanford University): methods, maths, and code generation
* `Paul Goulart `_ (University of Oxford): methods, maths, and Matlab interface
* `Alberto Bemporad `_ (IMT Lucca): methods and maths
* `Stephen Boyd `_ (Stanford University): methods and maths
* `Ian McInerney `_ (Imperial College London): code generation, software development
* `Michel Schubiger `_ (Schindler R&D): GPU implementation
* `John Lygeros `_ (ETH Zurich): methods and maths
Interfaces development
* `Nick Gould `_ (Rutherford Appleton Laboratory): Fortran and CUTEst interfaces
* `Ed Barnard `_ (University of Oxford): Rust interface
.. rubric:: Bug reports and support
Please report any issues via the `Github issue tracker `_. All types of issues are welcome including bug reports, documentation typos, feature requests and so on.
.. rubric:: Numerical benchmarks
Numerical benchmarks against other solvers are available `here `_.
.. toctree::
:hidden:
:maxdepth: 2
:caption: User Documentation
solver/index
get_started/index
interfaces/index
parsers/index
codegen/index
examples/index
contributing/index
citing/index