From 648334489fc8b74385b88a5deab8f2a275ff9675 Mon Sep 17 00:00:00 2001 From: odow Date: Mon, 22 Mar 2021 13:26:58 +1300 Subject: [PATCH] Simplify precompile statements --- src/Containers/Containers.jl | 5 - src/Containers/precompile.jl | 93 ------------ src/_Derivatives/_Derivatives.jl | 5 - src/_Derivatives/precompile.jl | 4 - src/precompile.jl | 240 +++++++++++++------------------ 5 files changed, 97 insertions(+), 250 deletions(-) delete mode 100644 src/Containers/precompile.jl delete mode 100644 src/_Derivatives/precompile.jl diff --git a/src/Containers/Containers.jl b/src/Containers/Containers.jl index fd198bc0c98..a2927b582e9 100644 --- a/src/Containers/Containers.jl +++ b/src/Containers/Containers.jl @@ -56,9 +56,4 @@ include("no_duplicate_dict.jl") include("container.jl") include("macro.jl") -if Base.VERSION >= v"1.4.2" - include("precompile.jl") - _precompile_() -end - end diff --git a/src/Containers/precompile.jl b/src/Containers/precompile.jl deleted file mode 100644 index bfd48928c76..00000000000 --- a/src/Containers/precompile.jl +++ /dev/null @@ -1,93 +0,0 @@ -const __bodyfunction__ = Dict{Method,Any}() - -# Find keyword "body functions" (the function that contains the body -# as written by the developer, called after all missing keyword-arguments -# have been assigned values), in a manner that doesn't depend on -# gensymmed names. -# `mnokw` is the method that gets called when you invoke it without -# supplying any keywords. -function __lookup_kwbody__(mnokw::Method) - function getsym(arg) - isa(arg, Symbol) && return arg - @assert isa(arg, GlobalRef) - return arg.name - end - - f = get(__bodyfunction__, mnokw, nothing) - if f === nothing - fmod = mnokw.module - # The lowered code for `mnokw` should look like - # %1 = mkw(kwvalues..., #self#, args...) - # return %1 - # where `mkw` is the name of the "active" keyword body-function. - ast = Base.uncompressed_ast(mnokw) - if isa(ast, Core.CodeInfo) && length(ast.code) >= 2 - callexpr = ast.code[end-1] - if isa(callexpr, Expr) && callexpr.head == :call - fsym = callexpr.args[1] - if isa(fsym, Symbol) - f = getfield(fmod, fsym) - elseif isa(fsym, GlobalRef) - if fsym.mod === Core && fsym.name === :_apply - f = getfield(mnokw.module, getsym(callexpr.args[2])) - elseif fsym.mod === Core && fsym.name === :_apply_iterate - f = getfield(mnokw.module, getsym(callexpr.args[3])) - else - f = getfield(fsym.mod, fsym.name) - end - else - f = missing - end - else - f = missing - end - else - f = missing - end - __bodyfunction__[mnokw] = f - end - return f -end - -function _precompile_() - ccall(:jl_generating_output, Cint, ()) == 1 || return nothing - Base.precompile(Tuple{typeof(show),Base.TTY,DenseAxisArray{Float64, 2, Tuple{UnitRange{Int64}, Vector{Symbol}}, Tuple{Dict{Int64, Int64}, Dict{Symbol, Int64}}}}) # time: 0.06925241 - Base.precompile(Tuple{typeof(_extract_kw_args),Tuple{Symbol, Expr}}) # time: 0.02388525 - Base.precompile(Tuple{typeof(container),Function,VectorizedProductIterator{Tuple{Int64}}}) # time: 0.019638063 - Base.precompile(Tuple{typeof(_extract_kw_args),Tuple{Expr, Symbol}}) # time: 0.01300304 - Base.precompile(Tuple{typeof(container),Function,VectorizedProductIterator{Tuple{UnitRange{Int64}, Vector{Symbol}}},Type{DenseAxisArray}}) # time: 0.011042849 - Base.precompile(Tuple{typeof(_extract_kw_args),Tuple{}}) # time: 0.010988676 - Base.precompile(Tuple{typeof(container),Function,VectorizedProductIterator{Tuple{StepRange{Int64, Int64}, StepRange{Int64, Int64}, Base.OneTo{Int64}}},Type{DenseAxisArray}}) # time: 0.010785832 - Base.precompile(Tuple{typeof(container),Function,VectorizedProductIterator{Tuple{Base.OneTo{Int64}, UnitRange{Int64}, UnitRange{Int64}}},Type{DenseAxisArray}}) # time: 0.010772673 - Base.precompile(Tuple{typeof(_extract_kw_args),Tuple{Expr}}) # time: 0.010699514 - Base.precompile(Tuple{typeof(container),Function,VectorizedProductIterator{Tuple{Vector{String}}},Type{DenseAxisArray}}) # time: 0.009808394 - Base.precompile(Tuple{typeof(_extract_kw_args),Tuple{Symbol}}) # time: 0.009082955 - Base.precompile(Tuple{typeof(container),Function,VectorizedProductIterator{Tuple{UnitRange{Int64}}},Type{DenseAxisArray}}) # time: 0.008933888 - Base.precompile(Tuple{typeof(_extract_kw_args),Tuple{Symbol, Expr, Expr}}) # time: 0.007755594 - Base.precompile(Tuple{typeof(_extract_kw_args),Tuple{Expr, Expr}}) # time: 0.007691665 - Base.precompile(Tuple{typeof(_extract_kw_args),Tuple{Expr, Expr, Expr}}) # time: 0.006882744 - Base.precompile(Tuple{typeof(container_code),Vector{Any},Expr,Expr,Symbol}) # time: 0.005621142 - # TODO: isdefined(JuMP.Containers, Symbol("#37#38")) && Base.precompile(Tuple{getfield(JuMP.Containers, Symbol("#37#38")),Int64}) # time: 0.004817874 - Base.precompile(Tuple{typeof(to_index),DenseAxisArray,Any}) # time: 0.004183273 - Base.precompile(Tuple{typeof(vectorized_product),Base.OneTo{Int64},Vararg{Any, N} where N}) # time: 0.00327413 - Base.precompile(Tuple{typeof(_to_index_tuple),Tuple{Int64, Vararg{Any, N} where N},Tuple{Dict{Int64, Int64}, Dict{Symbol, Int64}}}) # time: 0.003025034 - let fbody = try __lookup_kwbody__(which(nested, (Function,Vararg{Function, N} where N,))) catch missing end - if !ismissing(fbody) - precompile(fbody, (Function,typeof(nested),Function,Vararg{Function, N} where N,)) - end - end # time: 0.002819959 - Base.precompile(Tuple{typeof(haskey),NoDuplicateDict{_A, _B} where {_A, _B},Tuple{Int64, Int64, Int64}}) # time: 0.002722087 - Base.precompile(Tuple{typeof(vectorized_product),Base.OneTo{Int64},Vararg{Base.OneTo{Int64}, N} where N}) # time: 0.002584661 - Base.precompile(Tuple{typeof(_to_index_tuple),Tuple{Int64, Function},Tuple{Dict{Int64, Int64}, Dict{Symbol, Int64}}}) # time: 0.002516737 - Base.precompile(Tuple{typeof(_to_index_tuple),Tuple{String, Int64, Int64},Tuple{Dict{String, Int64}, Dict{Int64, Int64}, Dict{Int64, Int64}}}) # time: 0.002253078 - Base.precompile(Tuple{typeof(has_dependent_sets),Vector{Any},Vector{Any}}) # time: 0.00217896 - # TODO: Base.precompile(Tuple{Type{DenseAxisArray},Core.Array{T, N},Any,Tuple{Vararg{Dict, N}} where N}) # time: 0.001977609 - Base.precompile(Tuple{typeof(_explicit_oneto),Expr}) # time: 0.001850751 - Base.precompile(Tuple{typeof(haskey),NoDuplicateDict{_A, _B} where {_A, _B},Tuple{String, String, Int64}}) # time: 0.001788105 - Base.precompile(Tuple{typeof(vectorized_product),Int64}) # time: 0.001391668 - Base.precompile(Tuple{typeof(_explicit_oneto),Any}) # time: 0.001387689 - Base.precompile(Tuple{typeof(build_lookup),Vector{Int64}}) # time: 0.001371672 - Base.precompile(Tuple{typeof(depends_on),Expr,Symbol}) # time: 0.001150738 - Base.precompile(Tuple{typeof(has_colon),Tuple{Int64, Function}}) # time: 0.001108028 - Base.precompile(Tuple{typeof(container),Function,VectorizedProductIterator{Tuple{Vector{String}, Base.OneTo{Int64}}},Type{DenseAxisArray}}) # time: 0.001101885 -end diff --git a/src/_Derivatives/_Derivatives.jl b/src/_Derivatives/_Derivatives.jl index 9331ad45608..ca060dfdade 100644 --- a/src/_Derivatives/_Derivatives.jl +++ b/src/_Derivatives/_Derivatives.jl @@ -43,9 +43,4 @@ include("forward.jl") include("reverse.jl") include("subexpressions.jl") -if Base.VERSION >= v"1.4.2" - include("precompile.jl") - _precompile_() -end - end # module diff --git a/src/_Derivatives/precompile.jl b/src/_Derivatives/precompile.jl deleted file mode 100644 index e0be17cccb0..00000000000 --- a/src/_Derivatives/precompile.jl +++ /dev/null @@ -1,4 +0,0 @@ -function _precompile_() - ccall(:jl_generating_output, Cint, ()) == 1 || return nothing - # TODO: Base.precompile(Tuple{typeof(eval_and_check_return_type),Function,Type,JuMP._UserFunctionEvaluator,Vararg{Any, N} where N}) # time: 0.003078309 -end diff --git a/src/precompile.jl b/src/precompile.jl index b1dd75afc88..be752763215 100644 --- a/src/precompile.jl +++ b/src/precompile.jl @@ -1,148 +1,102 @@ -const __bodyfunction__ = Dict{Method,Any}() - -# Find keyword "body functions" (the function that contains the body -# as written by the developer, called after all missing keyword-arguments -# have been assigned values), in a manner that doesn't depend on -# gensymmed names. -# `mnokw` is the method that gets called when you invoke it without -# supplying any keywords. -function __lookup_kwbody__(mnokw::Method) - function getsym(arg) - isa(arg, Symbol) && return arg - @assert isa(arg, GlobalRef) - return arg.name - end - - f = get(__bodyfunction__, mnokw, nothing) - if f === nothing - fmod = mnokw.module - # The lowered code for `mnokw` should look like - # %1 = mkw(kwvalues..., #self#, args...) - # return %1 - # where `mkw` is the name of the "active" keyword body-function. - ast = Base.uncompressed_ast(mnokw) - if isa(ast, Core.CodeInfo) && length(ast.code) >= 2 - callexpr = ast.code[end-1] - if isa(callexpr, Expr) && callexpr.head == :call - fsym = callexpr.args[1] - if isa(fsym, Symbol) - f = getfield(fmod, fsym) - elseif isa(fsym, GlobalRef) - if fsym.mod === Core && fsym.name === :_apply - f = getfield(mnokw.module, getsym(callexpr.args[2])) - elseif fsym.mod === Core && fsym.name === :_apply_iterate - f = getfield(mnokw.module, getsym(callexpr.args[3])) - else - f = getfield(fsym.mod, fsym.name) - end - else - f = missing - end - else - f = missing - end - else - f = missing - end - __bodyfunction__[mnokw] = f - end - return f -end +# This precompile statements are a mix of hand-generated ones (e.g., to ensure +# coverage across the breadth of common constraint types, as well as some +# SnoopCompile ones that are expensive.) function _precompile_() ccall(:jl_generating_output, Cint, ()) == 1 || return nothing - Base.precompile(Tuple{typeof(MathOptInterface.eval_hessian_lagrangian),NLPEvaluator,SubArray{Float64, 1, Vector{Float64}, Tuple{UnitRange{Int64}}, true},Vector{Float64},Float64,SubArray{Float64, 1, Vector{Float64}, Tuple{UnitRange{Int64}}, true}}) # time: 0.83568186 - Base.precompile(Tuple{typeof(MathOptInterface.eval_objective_gradient),NLPEvaluator,Vector{Float64},Vector{Float64}}) # time: 0.50052494 - Base.precompile(Tuple{typeof(MathOptInterface.initialize),NLPEvaluator,Vector{Symbol}}) # time: 0.34357876 - let fbody = try __lookup_kwbody__(which(Model, (Type,))) catch missing end - if !ismissing(fbody) - precompile(fbody, (Bool,Base.Iterators.Pairs{Union{}, Union{}, Tuple{}, NamedTuple{(), Tuple{}}},Type{Model},Type,)) - end - end # time: 0.26403505 + T = Float64 + scalar_sets = ( + MOI.LessThan{T}, + MOI.GreaterThan{T}, + MOI.EqualTo{T}, + MOI.Interval{T}, + MOI.Integer, + MOI.ZeroOne, + MOI.Semiinteger{T}, + MOI.Semicontinuous{T}, + ) + scalar_functions = ( + MOI.SingleVariable, + MOI.ScalarAffineFunction{T}, + MOI.ScalarQuadraticFunction{T}, + ) + vector_sets = ( + MOI.Nonnegatives, + MOI.Nonpositives, + MOI.Zeros, + MOI.Reals, + MOI.SecondOrderCone, + MOI.RotatedSecondOrderCone, + MOI.ExponentialCone, + MOI.DualExponentialCone, + MOI.PositiveSemidefiniteConeSquare, + MOI.PositiveSemidefiniteConeTriangle, + ) + vector_functions = ( + MOI.VectorOfVariables, + MOI.VectorAffineFunction{T}, + MOI.VectorQuadraticFunction{T}, + ) + constraints = vcat( + [(F, S) for F in scalar_functions, S in scalar_sets], + [(F, S) for F in vector_functions, S in vector_sets], + ) + for (F, S) in constraints + Base.precompile( + moi_add_constraint, + ( + MOIU.CachingOptimizer{ + MOI.AbstractOptimizer, + MOIU.UniversalFallback{MOIU.Model{Float64}}, + }, + F, + S, + ), + ) + end + Base.precompile(Tuple{typeof(model_string),Type,Model}) # time: 0.25714603 - Base.precompile(Tuple{typeof(_moi_add_variable),MathOptInterface.Utilities.CachingOptimizer{MathOptInterface.AbstractOptimizer, MathOptInterface.Utilities.UniversalFallback{MathOptInterface.Utilities.Model{Float64}}},Model,ScalarVariable{Int64, Float64, Float64, Float64},String}) # time: 0.21578874 - Base.precompile(Tuple{typeof(moi_add_constraint),MathOptInterface.Utilities.CachingOptimizer{MathOptInterface.AbstractOptimizer, MathOptInterface.Utilities.UniversalFallback{MathOptInterface.Utilities.Model{Float64}}},MathOptInterface.ScalarAffineFunction{Float64},MathOptInterface.LessThan{Float64}}) # time: 0.19299112 - Base.precompile(Tuple{typeof(moi_add_constraint),MathOptInterface.Utilities.CachingOptimizer{MathOptInterface.AbstractOptimizer, MathOptInterface.Utilities.UniversalFallback{MathOptInterface.Utilities.Model{Float64}}},MathOptInterface.ScalarQuadraticFunction{Float64},MathOptInterface.LessThan{Float64}}) # time: 0.12382254 - Base.precompile(Tuple{typeof(_hessian_slice),NLPEvaluator,_FunctionStorage,Vector{Float64},SubArray{Float64, 1, Vector{Float64}, Tuple{UnitRange{Int64}}, true},Float64,Int64,Vector{Float64},Type{Val{2}}}) # time: 0.123344906 - Base.precompile(Tuple{typeof(_process_NL_expr),Symbol,Expr}) # time: 0.08418905 - Base.precompile(Tuple{typeof(show),IOContext{IOBuffer},AffExpr}) # time: 0.058707304 - Base.precompile(Tuple{typeof(_moi_add_constrained_variables),MathOptInterface.Utilities.CachingOptimizer{MathOptInterface.AbstractOptimizer, MathOptInterface.Utilities.UniversalFallback{MathOptInterface.Utilities.Model{Float64}}},Vector{ScalarVariable{Float64, Float64, Float64, Float64}},MathOptInterface.PositiveSemidefiniteConeTriangle,Vector{String}}) # time: 0.056060467 - Base.precompile(Tuple{typeof(_constraint_macro),Tuple{Symbol, Expr},Symbol,typeof(parse_constraint_expr),LineNumberNode}) # time: 0.037720144 - Base.precompile(Tuple{typeof(dual),ConstraintRef{Model, MathOptInterface.ConstraintIndex{MathOptInterface.ScalarAffineFunction{Float64}, MathOptInterface.GreaterThan{Float64}}, ScalarShape}}) # time: 0.027809434 - isdefined(JuMP, Symbol("#108#109")) && Base.precompile(Tuple{getfield(JuMP, Symbol("#108#109")),Expr}) # time: 0.02720738 - Base.precompile(Tuple{Core.kwftype(typeof(register)),NamedTuple{(:autodiff,), Tuple{Bool}},typeof(register),Model,Symbol,Int64,Function}) # time: 0.026307618 - Base.precompile(Tuple{Core.kwftype(typeof(constraint_string)),NamedTuple{(:in_math_mode,), Tuple{Bool}},typeof(constraint_string),Type,ConstraintRef{Model, MathOptInterface.ConstraintIndex{MathOptInterface.ScalarQuadraticFunction{Float64}, MathOptInterface.LessThan{Float64}}, ScalarShape}}) # time: 0.024550961 - Base.precompile(Tuple{typeof(moi_add_constraint),MathOptInterface.Utilities.CachingOptimizer{MathOptInterface.AbstractOptimizer, MathOptInterface.Utilities.UniversalFallback{MathOptInterface.Utilities.Model{Float64}}},MathOptInterface.VectorAffineFunction{Float64},MathOptInterface.PositiveSemidefiniteConeSquare}) # time: 0.022663178 - Base.precompile(Tuple{typeof(_parse_NL_expr),Symbol,Expr,Symbol,Symbol,Symbol}) # time: 0.02125863 - Base.precompile(Tuple{Type{MathOptInterface.VectorOfVariables},Vector{VariableRef}}) # time: 0.01940772 - Base.precompile(Tuple{typeof(+),AffExpr,AffExpr}) # time: 0.017755583 - Base.precompile(Tuple{typeof(moi_add_constraint),MathOptInterface.Utilities.CachingOptimizer{MathOptInterface.AbstractOptimizer, MathOptInterface.Utilities.UniversalFallback{MathOptInterface.Utilities.Model{Float64}}},MathOptInterface.VectorAffineFunction{Float64},MathOptInterface.SecondOrderCone}) # time: 0.016445328 - Base.precompile(Tuple{typeof(moi_add_constraint),MathOptInterface.Utilities.CachingOptimizer{MathOptInterface.AbstractOptimizer, MathOptInterface.Utilities.UniversalFallback{MathOptInterface.Utilities.Model{Float64}}},MathOptInterface.ScalarAffineFunction{Float64},MathOptInterface.EqualTo{Float64}}) # time: 0.016153162 - Base.precompile(Tuple{typeof(moi_add_constraint),MathOptInterface.Utilities.CachingOptimizer{MathOptInterface.AbstractOptimizer, MathOptInterface.Utilities.UniversalFallback{MathOptInterface.Utilities.Model{Float64}}},MathOptInterface.ScalarAffineFunction{Float64},MathOptInterface.GreaterThan{Float64}}) # time: 0.015447589 - Base.precompile(Tuple{Core.kwftype(typeof(constraint_string)),NamedTuple{(:in_math_mode,), Tuple{Bool}},typeof(constraint_string),Type,ConstraintRef{Model, MathOptInterface.ConstraintIndex{MathOptInterface.ScalarAffineFunction{Float64}, MathOptInterface.EqualTo{Float64}}, ScalarShape}}) # time: 0.015426918 - Base.precompile(Tuple{typeof(add_constraint),Model,VectorConstraint{AffExpr, MathOptInterface.PositiveSemidefiniteConeSquare, SquareMatrixShape},String}) # time: 0.014703301 - Base.precompile(Tuple{typeof(MathOptInterface.features_available),NLPEvaluator}) # time: 0.014501549 - Base.precompile(Tuple{Core.kwftype(typeof(constraint_string)),NamedTuple{(:in_math_mode,), Tuple{Bool}},typeof(constraint_string),Type,ConstraintRef{Model, MathOptInterface.ConstraintIndex{MathOptInterface.SingleVariable, MathOptInterface.GreaterThan{Float64}}, ScalarShape}}) # time: 0.01252703 - Base.precompile(Tuple{Type{_FunctionStorage},Vector{NodeData},Vector{Float64},Int64,JuMP._Derivatives.Coloring.IndexedSet,Bool,Vector{_SubexpressionStorage},Vector{Int64},Vector{Linearity},Vector{Set{Tuple{Int64, Int64}}},Vector{Vector{Int64}},Dict{MathOptInterface.VariableIndex, Int64}}) # time: 0.012121839 - Base.precompile(Tuple{typeof(setindex!),Model,JuMP.Containers.DenseAxisArray{VariableRef, 3, Tuple{Vector{String}, Vector{Int64}, Base.OneTo{Int64}}, Tuple{Dict{String, Int64}, Dict{Int64, Int64}, Dict{Int64, Int64}}},Symbol}) # time: 0.009960893 - Base.precompile(Tuple{typeof(function_string),Type,AffExpr,Bool}) # time: 0.009605979 - Base.precompile(Tuple{typeof(_moi_fix),MathOptInterface.Utilities.CachingOptimizer{MathOptInterface.AbstractOptimizer, MathOptInterface.Utilities.UniversalFallback{MathOptInterface.Utilities.Model{Float64}}},VariableRef,Float64,Bool}) # time: 0.009475288 - Base.precompile(Tuple{typeof(_constraint_macro),Tuple{Symbol, Expr},Symbol,typeof(parse_SD_constraint_expr),LineNumberNode}) # time: 0.009388473 - Base.precompile(Tuple{typeof(reshape_vector),Vector{VariableRef},SymmetricMatrixShape}) # time: 0.009321982 - Base.precompile(Tuple{typeof(parse_constraint_expr),Function,Expr}) # time: 0.009186855 - Base.precompile(Tuple{Core.kwftype(typeof(constraint_string)),NamedTuple{(:in_math_mode,), Tuple{Bool}},typeof(constraint_string),Type,ConstraintRef{Model, MathOptInterface.ConstraintIndex{MathOptInterface.SingleVariable, MathOptInterface.LessThan{Float64}}, ScalarShape}}) # time: 0.009008045 - Base.precompile(Tuple{typeof(MathOptInterface.eval_constraint_jacobian),NLPEvaluator,SubArray{Float64, 1, Vector{Float64}, Tuple{UnitRange{Int64}}, true},Vector{Float64}}) # time: 0.00857948 - Base.precompile(Tuple{Core.kwftype(typeof(constraint_string)),NamedTuple{(:in_math_mode,), Tuple{Bool}},typeof(constraint_string),Type,ConstraintRef{Model, MathOptInterface.ConstraintIndex{MathOptInterface.ScalarAffineFunction{Float64}, MathOptInterface.LessThan{Float64}}, ScalarShape}}) # time: 0.007398971 - Base.precompile(Tuple{typeof(_is_info_keyword),Expr}) # time: 0.005932119 - Base.precompile(Tuple{typeof(_constraint_macro),Tuple{Symbol, Expr, Expr},Symbol,typeof(parse_constraint_expr),LineNumberNode}) # time: 0.005548552 - isdefined(JuMP, Symbol("#90#99")) && Base.precompile(Tuple{getfield(JuMP, Symbol("#90#99")),Expr}) # time: 0.00545616 - Base.precompile(Tuple{typeof(all_constraints),Model,Type{QuadExpr},Type{MathOptInterface.LessThan{Float64}}}) # time: 0.005269228 - isdefined(JuMP, Symbol("#90#99")) && Base.precompile(Tuple{getfield(JuMP, Symbol("#90#99")),Symbol}) # time: 0.005126045 - Base.precompile(Tuple{typeof(setindex!),Model,Symmetric{VariableRef, Matrix{VariableRef}},Symbol}) # time: 0.004744124 - Base.precompile(Tuple{typeof(set_integer),VariableRef}) # time: 0.004611087 - isdefined(JuMP, Symbol("#90#99")) && Base.precompile(Tuple{getfield(JuMP, Symbol("#90#99")),Any}) # time: 0.004526849 - Base.precompile(Tuple{typeof(setindex!),Model,JuMP.Containers.DenseAxisArray{ConstraintRef{Model, MathOptInterface.ConstraintIndex{MathOptInterface.ScalarAffineFunction{Float64}, MathOptInterface.EqualTo{Float64}}, ScalarShape}, 3, Tuple{StepRange{Int64, Int64}, StepRange{Int64, Int64}, Base.OneTo{Int64}}, Tuple{Dict{Int64, Int64}, Dict{Int64, Int64}, Dict{Int64, Int64}}},Symbol}) # time: 0.004247034 - Base.precompile(Tuple{typeof(all_constraints),Model,Type{VariableRef},Type{MathOptInterface.GreaterThan{Float64}}}) # time: 0.004184557 - Base.precompile(Tuple{typeof(all_constraints),Model,Type{VariableRef},Type{MathOptInterface.LessThan{Float64}}}) # time: 0.003693318 - Base.precompile(Tuple{typeof(MathOptInterface.eval_constraint),NLPEvaluator,SubArray{Float64, 1, Vector{Float64}, Tuple{UnitRange{Int64}}, true},Vector{Float64}}) # time: 0.003288632 - Base.precompile(Tuple{typeof(all_constraints),Model,Type{AffExpr},Type{MathOptInterface.EqualTo{Float64}}}) # time: 0.003248726 - Base.precompile(Tuple{typeof(parse_variable),Function,_VariableInfoExpr,Int64,Symbol,Symbol,Symbol,Float64}) # time: 0.003094496 - Base.precompile(Tuple{typeof(_moi_add_variable),MathOptInterface.Utilities.CachingOptimizer{MathOptInterface.AbstractOptimizer, MathOptInterface.Utilities.UniversalFallback{MathOptInterface.Utilities.Model{Float64}}},Model,ScalarVariable{Int64, Int64, Float64, Float64},String}) # time: 0.003087982 - Base.precompile(Tuple{typeof(set_objective_coefficient),Model,VariableRef,Float64}) # time: 0.003028207 - Base.precompile(Tuple{typeof(setindex!),Model,Vector{ConstraintRef{Model, MathOptInterface.ConstraintIndex{MathOptInterface.ScalarAffineFunction{Float64}, MathOptInterface.GreaterThan{Float64}}, ScalarShape}},Symbol}) # time: 0.002985051 - isdefined(JuMP, Symbol("#_error#101")) && Base.precompile(Tuple{getfield(JuMP, Symbol("#_error#101")),String}) # time: 0.002983753 - isdefined(JuMP, Symbol("#_error#101")) && Base.precompile(Tuple{getfield(JuMP, Symbol("#_error#101")),String}) # time: 0.002792419 - Base.precompile(Tuple{typeof(parse_variable),Function,_VariableInfoExpr,Expr,Symbol,Expr,Symbol,Expr}) # time: 0.002732017 - Base.precompile(Tuple{typeof(setindex!),Model,JuMP.Containers.SparseAxisArray{VariableRef, 3, Tuple{String, String, Int64}},Symbol}) # time: 0.002709768 - Base.precompile(Tuple{typeof(_moi_fix),MathOptInterface.Utilities.CachingOptimizer{MathOptInterface.AbstractOptimizer, MathOptInterface.Utilities.UniversalFallback{MathOptInterface.Utilities.Model{Float64}}},VariableRef,Int64,Bool}) # time: 0.002553926 - Base.precompile(Tuple{typeof(setindex!),Model,Matrix{ConstraintRef{Model, MathOptInterface.ConstraintIndex{MathOptInterface.ScalarAffineFunction{Float64}, MathOptInterface.EqualTo{Float64}}, ScalarShape}},Symbol}) # time: 0.002535749 - Base.precompile(Tuple{typeof(setindex!),Model,Matrix{ConstraintRef{Model, MathOptInterface.ConstraintIndex{MathOptInterface.ScalarAffineFunction{Float64}, MathOptInterface.LessThan{Float64}}, ScalarShape}},Symbol}) # time: 0.002429434 - Base.precompile(Tuple{typeof(all_constraints),Model,Type{AffExpr},Type{MathOptInterface.LessThan{Float64}}}) # time: 0.002425839 - Base.precompile(Tuple{typeof(setindex!),Model,Vector{ConstraintRef{Model, MathOptInterface.ConstraintIndex{MathOptInterface.ScalarAffineFunction{Float64}, MathOptInterface.LessThan{Float64}}, ScalarShape}},Symbol}) # time: 0.002409321 - Base.precompile(Tuple{typeof(_name_call),Expr,Vector{Any}}) # time: 0.002405974 - Base.precompile(Tuple{Core.kwftype(typeof(Type)),NamedTuple{(:lower_bound,), Tuple{Int64}},Type{_VariableInfoExpr}}) # time: 0.002381082 - Base.precompile(Tuple{typeof(MathOptInterface.jacobian_structure),NLPEvaluator}) # time: 0.002370995 - Base.precompile(Tuple{typeof(_name_call),String,Vector{Any}}) # time: 0.002361506 - Base.precompile(Tuple{Core.kwftype(typeof(Type)),NamedTuple{(:start,), Tuple{Float64}},Type{_VariableInfoExpr}}) # time: 0.002346172 - Base.precompile(Tuple{typeof(MathOptInterface.eval_objective),NLPEvaluator,Vector{Float64}}) # time: 0.002276394 - Base.precompile(Tuple{typeof(MutableArithmetics.mutable_operate!),typeof(MutableArithmetics.sub_mul),AffExpr,VariableRef,UInt16,Float64}) # time: 0.002249377 - Base.precompile(Tuple{typeof(build_constraint),Function,Matrix{AffExpr},PSDCone}) # time: 0.002245585 - Base.precompile(Tuple{typeof(parse_one_operator_constraint),Function,Bool,Val{:(==)},Expr,Expr}) # time: 0.00220451 - Base.precompile(Tuple{typeof(parse_one_operator_constraint),Function,Bool,Val{:>=},Expr,Expr}) # time: 0.001952178 - Base.precompile(Tuple{typeof(_moi_set_integer),MathOptInterface.Utilities.CachingOptimizer{MathOptInterface.AbstractOptimizer, MathOptInterface.Utilities.UniversalFallback{MathOptInterface.Utilities.Model{Float64}}},VariableRef}) # time: 0.001938481 - Base.precompile(Tuple{typeof(parse_one_operator_constraint),Function,Bool,Val{:<=},Expr,Int64}) # time: 0.001845112 - Base.precompile(Tuple{typeof(set_name),ConstraintRef{Model, MathOptInterface.ConstraintIndex{MathOptInterface.ScalarAffineFunction{Float64}, MathOptInterface.GreaterThan{Float64}}, ScalarShape},String}) # time: 0.001767766 - Base.precompile(Tuple{typeof(set_name),ConstraintRef{Model, MathOptInterface.ConstraintIndex{MathOptInterface.ScalarAffineFunction{Float64}, MathOptInterface.LessThan{Float64}}, ScalarShape},String}) # time: 0.001764125 - Base.precompile(Tuple{typeof(_add_kw_args),Expr,Vector{Any}}) # time: 0.001574977 - Base.precompile(Tuple{typeof(_moi_add_variable),MathOptInterface.Utilities.CachingOptimizer{MathOptInterface.AbstractOptimizer, MathOptInterface.Utilities.UniversalFallback{MathOptInterface.Utilities.Model{Float64}}},Model,ScalarVariable{Float64, Float64, Float64, Float64},String}) # time: 0.001559715 - Base.precompile(Tuple{typeof(MathOptInterface.eval_objective),_UserFunctionEvaluator,SubArray{Float64, 1, Vector{Float64}, Tuple{UnitRange{Int64}}, true}}) # time: 0.001388102 - Base.precompile(Tuple{typeof(_moi_get_result),MathOptInterface.Utilities.CachingOptimizer{MathOptInterface.AbstractOptimizer, MathOptInterface.Utilities.UniversalFallback{MathOptInterface.Utilities.Model{Float64}}},MathOptInterface.ObjectiveValue}) # time: 0.001357983 - Base.precompile(Tuple{typeof(constraint_ref_with_index),Model,MathOptInterface.ConstraintIndex{MathOptInterface.SingleVariable, MathOptInterface.LessThan{Float64}}}) # time: 0.001327407 - Base.precompile(Tuple{typeof(MutableArithmetics.sub_mul),VariableRef,Float64,AffExpr}) # time: 0.001269834 - Base.precompile(Tuple{typeof(set_name),ConstraintRef{Model, MathOptInterface.ConstraintIndex{MathOptInterface.ScalarAffineFunction{Float64}, MathOptInterface.EqualTo{Float64}}, ScalarShape},String}) # time: 0.001234877 - Base.precompile(Tuple{typeof(convert),Type{AffExpr},Union{Number, UniformScaling}}) # time: 0.00121725 - Base.precompile(Tuple{Core.kwftype(typeof(_macro_assign_and_return)),NamedTuple{(:model_for_registering,), Tuple{Expr}},typeof(_macro_assign_and_return),Expr,Symbol,Symbol}) # time: 0.001182317 - isdefined(JuMP, Symbol("#110#111")) && Base.precompile(Tuple{getfield(JuMP, Symbol("#110#111")),Tuple{Int64, MathOptInterface.VariableIndex}}) # time: 0.00111902 - Base.precompile(Tuple{typeof(set_normalized_coefficient),ConstraintRef{Model, MathOptInterface.ConstraintIndex{MathOptInterface.ScalarAffineFunction{Float64}, MathOptInterface.GreaterThan{Float64}}, ScalarShape},VariableRef,Int64}) # time: 0.00108381 - Base.precompile(Tuple{typeof(parse_constraint_head),Function,Val{:call},Symbol,Symbol,Int64}) # time: 0.001021371 + + # Nonlinear interface + Base.precompile( + Tuple{ + typeof(MOI.eval_hessian_lagrangian), + NLPEvaluator, + SubArray{Float64,1,Vector{Float64},Tuple{UnitRange{Int64}},true}, + Vector{Float64}, + Float64, + SubArray{Float64,1,Vector{Float64},Tuple{UnitRange{Int64}},true}, + }, + ) # time: 0.83568186 + Base.precompile( + Tuple{ + typeof(MOI.eval_objective_gradient), + NLPEvaluator, + Vector{Float64}, + Vector{Float64}, + }, + ) # time: 0.50052494 + Base.precompile(Tuple{typeof(MOI.initialize),NLPEvaluator,Vector{Symbol}}) # time: 0.34357876 + Base.precompile(Tuple{typeof(MOI.features_available),NLPEvaluator}) # time: 0.014501549 + Base.precompile( + Tuple{ + typeof(MOI.eval_constraint_jacobian), + NLPEvaluator, + SubArray{Float64,1,Vector{Float64},Tuple{UnitRange{Int64}},true}, + Vector{Float64}, + }, + ) # time: 0.00857948 + Base.precompile( + Tuple{ + typeof(MOI.eval_constraint), + NLPEvaluator, + SubArray{Float64,1,Vector{Float64},Tuple{UnitRange{Int64}},true}, + Vector{Float64}, + }, + ) # time: 0.003288632 + Base.precompile(Tuple{typeof(MOI.jacobian_structure),NLPEvaluator}) # time: 0.002370995 + Base.precompile( + Tuple{typeof(MOI.eval_objective),NLPEvaluator,Vector{Float64}}, + ) # time: 0.002276394 + return end