Skip to content

Commit

Permalink
Allow PureJuMP problems in generate meta (#329)
Browse files Browse the repository at this point in the history
  • Loading branch information
tmigot authored May 28, 2024
1 parent f30adec commit 025e88f
Showing 1 changed file with 11 additions and 3 deletions.
14 changes: 11 additions & 3 deletions test/utils.jl
Original file line number Diff line number Diff line change
Expand Up @@ -131,13 +131,21 @@ function is_feasible(nlp::AbstractNLPModel; x = nlp.meta.x0)
end

function var_size(name::String, get_field::Function, default_nvar)
nlp_eval = if name != "hs61" && name in string.(names(PureJuMP))
n -> eval(Meta.parse("MathOptNLPModel(PureJuMP." * name * "(n = $n))"))
elseif name in string.(names(ADNLPProblems))
n -> eval(Meta.parse("ADNLPProblems." * name * "(n = $n)"))
end
return var_size(nlp_eval, name, get_field, default_nvar)
end

function var_size(nlp_eval::Function, name::String, get_field::Function, default_nvar)
n1 = default_nvar
n2 = div(default_nvar, 2)

prefix = name in string.(names(ADNLPProblems)) ? "ADNLPProblems." : ""
nlp1 = eval(Meta.parse(prefix * name))(n = n1)
nlp1 = nlp_eval(n1)
nvar1 = get_field(nlp1)
nlp2 = eval(Meta.parse(prefix * name))(n = n2)
nlp2 = nlp_eval(n2)
nvar2 = get_field(nlp2)
variable_nvar = nvar1 != nvar2
#Assuming the scale is linear in n
Expand Down

0 comments on commit 025e88f

Please sign in to comment.