You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
When building models with large (>10^5) numbers of variables and constraints, these dictionaries contain a large number of strings. Each String is a GC-tracked object, and it is long-lived, because we maintain these dictionaries throughout the lifetime of a Model. If CachingOptimizer is involved, there can also be multiple copies of the strings, for example, if we have a setup like Cache(Model, Bridge(Cache(Model, Solver))).
Lots of long-lived GC-tracked objects are bad for Julia's garbage collector.
Workaround
The main workaround at present is JuMP.set_string_names_on_creation(model, false), which does not pass string names from JuMP to the solver.
The downside of this workaround is that solvers and file writers cannot print or display useful names to the user.
To ensure backwards compatibility, we should make sure that getting and setting these strings uses the original String type, so that the internal storage is hidden from the user.
It is okay to convert between string types, and to generate extra allocations if these new strings are short-lived objects. The real performance problem is long-lived GC-tracked objects.
Solvers
Many solver packages also store String names. If the changes to MOI are an improvement, we should investigate was to simplify name handling in the different solver wrappers.
The text was updated successfully, but these errors were encountered:
A common source of performance problems in JuMP and MathOptInterface are dealing with the
String
names of variables and constraints.As a recent example, see #2426 and related issues/PRs.
The main place that
String
s are stored is:MathOptInterface.jl/src/Utilities/model.jl
Lines 27 to 31 in dcfb033
When building models with large (>10^5) numbers of variables and constraints, these dictionaries contain a large number of strings. Each
String
is a GC-tracked object, and it is long-lived, because we maintain these dictionaries throughout the lifetime of aModel
. IfCachingOptimizer
is involved, there can also be multiple copies of the strings, for example, if we have a setup likeCache(Model, Bridge(Cache(Model, Solver)))
.Lots of long-lived GC-tracked objects are bad for Julia's garbage collector.
Workaround
The main workaround at present is
JuMP.set_string_names_on_creation(model, false)
, which does not pass string names from JuMP to the solver.The downside of this workaround is that solvers and file writers cannot print or display useful names to the user.
Potential approaches
We should try replacing the
String
storage with an alternative string type. Candidates are:To ensure backwards compatibility, we should make sure that getting and setting these strings uses the original
String
type, so that the internal storage is hidden from the user.It is okay to convert between string types, and to generate extra allocations if these new strings are short-lived objects. The real performance problem is long-lived GC-tracked objects.
Solvers
Many solver packages also store
String
names. If the changes to MOI are an improvement, we should investigate was to simplify name handling in the different solver wrappers.The text was updated successfully, but these errors were encountered: