Misplaced Pages

MiniZinc

Article snapshot taken from Wikipedia with creative commons attribution-sharealike license. Give it a read and then ask your questions in the chat. We can research this topic together.
MiniZinc
ParadigmConstraint programming / Logic Programming
DeveloperMonash University
First appearedMay 2, 2009; 15 years ago (2009-05-02)
Stable release2.8.5 / June 3, 2024; 6 months ago (2024-06-03)
Implementation languageC++
OSLinux, MacOS, and Windows
LicenseMPLv2
Filename extensions.mzn, .dzn, .fzn
Websitewww.minizinc.org
Influenced by
Zinc

MiniZinc is a constraint modelling language (or algebraic modeling language) to describe and solve high-complexity problems using a variety of well-known solving paradigms for combinatorial problems including constraint programming, integer programming, lazy clause generation, SAT, and SMT.

Following the constraint programming paradigm, in MiniZinc a problem is specified in terms of known values (parameters), unknown values (decision variables), and the relationship (constraints) between these values. MiniZinc promotes the use of global constraints to model well-known structures in problems. These global constraints improve the clarity of the model and allow solvers to use the most effective method to exploit the structure. A MiniZinc problem instance is translated (or flattened) to a level at which it only supports constraints that are supported by the target solver and then given to the solver using its preferred format. Currently MiniZinc can communicate with solver using its own format FlatZinc or .nl files.

A big advantage of MiniZinc is the possibility to use different solvers, and even different solvers, from the same MiniZinc instance. MiniZinc supports many solvers, both open source and commercial software, including CBC, Choco, Chuffed, Gurobi, IPOPT, and OR-Tools.

MiniZinc is interoperable with other languages such as R.

Language

The following MiniZinc model can be used to solve the famous n-queens puzzle:

include "all_different.mzn"; % Include all_different global
int: n = 8; % The number of queens. (parameter)
array  of var 1..n: q; % The height of the queens on the board. (decision variable)
% No queen can be in a position where it can capture another queen. (constraints)
constraint all_different(q);
constraint all_different(i in 1..n)(q + i);
constraint all_different(i in 1..n)(q - i);

References

  1. Nethercote, Nicholas; Stuckey, Peter J.; Becket, Ralph; Brand, Sebastian; Duck, Gregory J.; Tack, Guido (2007). "MiniZinc: Towards a Standard CP Modelling Language". In Bessière, Christian (ed.). Principles and Practice of Constraint Programming – CP 2007. Lecture Notes in Computer Science. Berlin, Heidelberg: Springer. pp. 529–543. doi:10.1007/978-3-540-74970-7_38. ISBN 978-3-540-74970-7.
  2. "COIN-OR Branch-and-Cut MIP Solver". projects.coin-or.org. Retrieved 2020-09-14.
  3. "Choco-solver". Choco-solver. Retrieved 2020-09-14.
  4. "Introduction".

External links


Mathematical optimization software
Data formats
Modeling tools
Solvers
LP, MILP
QP, MIQP
QCP, MIQCP
SOCP, MISOCP
SDP, MISDP
NLP, MINLP
GO
CP
Categories: