JuMP
Programming language
From Wikipedia, the free encyclopedia
JuMP is an algebraic modeling language and a collection of supporting packages for mathematical optimization embedded in the Julia programming language.[1][2] JuMP is used by companies, government agencies, academic institutions, software projects, and individuals to formulate and submit optimization problems to third‑party solvers. JuMP has been specifically applied to problems in the field of operations research.[3]
- Miles Lubin
- Benoît Legat
- Joaquim Dias Garcia
- Joey Huchette
- Oscar Dowson
| JuMP | |
|---|---|
| Developers |
|
| First appeared | 2013 |
| Stable release | 1.26.0
/ May 21, 2025 |
| Implementation language | Julia |
| OS | Cross-platform: Linux, Mac OS X and Windows |
| License | Mozilla MPL‑2.0 (JuMP), MIT (supporting packages) |
| Website | jump |
| Influenced by | |
| AMPL, PuLP | |
Features
JuMP is a Julia package and domain-specific language that provides an API and syntax for declaring and solving optimization problems. Specialized syntax for declaring decision variables, adding constraints, and setting objective functions is facilitated by Julia's syntactic macros and metaprogramming features. JuMP supports linear programming, mixed integer programming, semidefinite programming, conic optimization, nonlinear programming, and other classes of optimization problems. JuMP provides access to over 50 solvers, including state-of-the-art commercial and open-source solvers.[4]
History
JuMP was first developed by Miles Lubin, Iain Dunning, and Joey Huchette while they were students at the Massachusetts Institute of Technology. Today, JuMP's core developers are Miles Lubin, Benoît Legat, Joaquim Dias Garcia, Joey Huchette, and Oscar Dowson. Miles Lubin additionally holds the title of BDFL.[5] JuMP is a sponsored project of NumFOCUS.[6]
Recognition
See also
- HiGHS optimization solver
- List of free and open-source optimization solvers
- Mathematical optimization
- PuLP – a similar project for Python
- Pyomo – Python packages for formulating optimization problems