Uno is a C++ library that unifies methods for solving nonlinearly constrained optimization problems of the form:
where 
Uno unifies Lagrange-Newton (essentially SQP and interior-point) methods that iteratively solve the optimality (KKT) conditions with Newton's method. It breaks them down into a set of building blocks that interact with one another. Our unification framework can be visualized in the following hypergraph (not all are implemented in Uno yet):
Thanks to Uno, you can combine these strategies in a ton of different ways. In particular, Uno implements presets, that is strategy combinations that mimic existing solvers:
- filtersqpmimics filterSQP (trust-region feasibility restoration filter SQP method with exact Hessian);
- ipoptmimics IPOPT (line-search feasibility restoration filter barrier method with exact Hessian and primal-dual inertia correction).
Note that all combinations do not necessarily result in sensible algorithms, or even convergent approaches.
For more details on our unification theory, check out the UNIFICATION page, our preprint, or my latest slides.
See the INSTALL file for instructions on how to compile Uno from source or use the precompiled libraries and executables.
To solve an AMPL model in the .nl format, move to the build directory and:
- run cmakewith the path to the ASL library:-DAMPLSOLVER=path;
- compile the executable make uno_ampl.
- run the command ./uno_ampl model.nl [-AMPL] [option=value ...]where[option=value ...]is a list of options separated by spaces. If the-AMPLflag is supplied, the solution is written to the AMPL solution filemodel.sol.
For an overview of the available strategies, type: ./uno_ampl --strategies:
A couple of CUTEst instances are available in the /examples directory.
Uno can be used from Julia in two ways:
- 
Pure Julia interface: UnoSolver.jl is the native Julia interface to Uno. It provides direct integration with the Julia optimization ecosystem through: - a thin wrapper around the full C API,
- an interface to NLPModels.jl for solving problems following the NLPModels API, such as CUTEst, ADNLPModels.jl, or ExaModels.jl,
- an interface to MathOptInterface.jl for handling JuMP models.
 Under the hood, UnoSolver.jluses precompiled shared libraries from Uno_jll.jl while exposing a high-level Julia API. More details can be found in the README ofUnoSolver.jl. This is the recommended way of using Uno in Julia.
- 
AMPL interface: Alternatively, the executable uno_amplcan be installed via Uno_jll.jl and used through AmplNLWriter.jl. An example can be found here.
Uno's Python bindings can be compiled via the command make unopy and require pybind11. For more details, see their README.md.
Uno's C interface is compiled as part of the Uno library. For more details, see its README.md. It may be modified in future minor releases.
Options can be set in three different ways (with decreasing precedence):
- passing an option file (option_file=file) that containsoption valueon each line;
- setting a preset that mimics an existing solver (preset=[filtersqp|ipopt]);
- setting individual options (see the default options).
The following ingredients are currently available:
- to pick a constraint relaxation strategy, use the argument: constraint_relaxation_strategy=[feasibility_restoration]
- to pick an inequality handling method, use the argument: inequality_handling_method=[inequality_constrained|interior_point]
- to pick a Hessian model, use the argument: hessian_model=[exact|identity|zero]
- to pick an inertia correction strategy, use the argument: inertia_correction_strategy=[primal|primal_dual|none]
- to pick a globalization strategy, use the argument: globalization_strategy=[l1_merit|fletcher_filter_method|waechter_filter_method|funnel_method]
- to pick a globalization mechanism, use the argument : globalization_mechanism=[TR|LS]
Uno presets have been tested against state-of-the-art solvers on 429 small problems of the CUTEst benchmark.
The figure below is a performance profile of Uno and state-of-the-art solvers filterSQP, IPOPT, SNOPT, MINOS, LANCELOT, LOQO and CONOPT; it shows how many problems are solved for a given budget of function evaluations (1 time, 2 times, 4 times, ..., 
All log files can be found here.
We have submitted our paper to the Mathematical Programming Computation journal. The preprint is available on ResearchGate.
Until it is published, you can use the following bibtex entry:
@unpublished{VanaretLeyffer2024,
  author = {Vanaret, Charlie and Leyffer, Sven},
  title = {Unifying nonlinearly constrained nonconvex optimization},
  year = {2024},
  note = {Submitted to Mathematical Programming Computation}
}
The theoretical abstract framework for unifying nonlinearly constrained optimization was developed by Charlie Vanaret (Argonne National Laboratory & Zuse-Institut Berlin) and Sven Leyffer (Argonne National Laboratory). Uno was designed and implemented by Charlie Vanaret. It is released under the MIT license (see the license file).
The contributors are (in alphabetical order): Oscar Dowson, Marcel Jacobse, David Kiessling, Stefano Lovato, Alexis Montoison, Rujia Liu, Manuel Schaich, Silvio Traversaro.
The Uno logo was created by Charlie Vanaret based on a saddle point icon by luimonts (CC BY 3.0).


