Question & Answer
Default algorithms of Coluna do not beat the commercial solver I usually use. Is it normal ?
Yes it is.
Solvers such as Gurobi, Cplex ... are handy powerful black-box tools. They can run a very efficient presolve step to simplify the formulation, automatically apply lots of valid inequalities (such as MIR or cover cuts), choose good branching strategies, or also run heuristics. However, when your formulation reaches a certain size, commercial solvers may run for hours without finding anything. This is the point where you may want to decompose your formulation.
Coluna is a framework, not a solver. It provides algorithms to try column generation on your problem very easily. Then, you can devise your own branch-cut-and-price algorithm on top of Coluna's algorithms. to scale up and hopefully beats the commercial solver.
To start customizing Coluna for your own problem, you can separate valid inequalities or call your own algorithm that optimizes subproblems.
I'm using Gurobi as a subsolver
My license prevents me from running several environments at the same time. How can I use a single environment for the master and all subproblems?
You can use the Gurobi.Env
constructor to create a single environment and pass it to the optimizers.
const GRB_ENV = Gurobi.Env()
coluna = optimizer_with_attributes(
Coluna.Optimizer,
"params" => Coluna.Params(
solver = Coluna.Algorithm.TreeSearchAlgorithm() # default branch-cut-and-price
),
"default_optimizer" => () -> Gurobi.Optimizer(GRB_ENV)
);
If you get a Gurobi error 10002, you should wrap the Gurobi environment as a reference to initialize it during runtime instead of compile time (reference).
const GRB_ENV_REF = Ref{Gurobi.Env}()
function __init__()
GRB_ENV_REF[] = Gurobi.Env()
return nothing
end
coluna = optimizer_with_attributes(
Coluna.Optimizer,
"params" => Coluna.Params(
solver = Coluna.Algorithm.TreeSearchAlgorithm() # default branch-cut-and-price
),
"default_optimizer" => () -> Gurobi.Optimizer(GRB_ENV_REF[])
);
How to disable all outputs from Gurobi?
You can refer to the following article from Gurobi's knowledge base.
We confirm that adding the following entry in the gurobi.env
file works with Gurobi 10+:
LogToConsole 0