Skip to content

Commit

Permalink
Refactor and simplify src/helper.jl
Browse files Browse the repository at this point in the history
  • Loading branch information
odow committed Mar 15, 2024
1 parent 232bd38 commit eda0e4a
Show file tree
Hide file tree
Showing 5 changed files with 361 additions and 391 deletions.
90 changes: 63 additions & 27 deletions src/MOI/MOI_wrapper.jl
Original file line number Diff line number Diff line change
Expand Up @@ -1152,7 +1152,11 @@ function MOI.get(
model::Optimizer,
::MOI.ObjectiveFunction{MOI.ScalarAffineFunction{Float64}},
)
ncols = n_variables(model.inner)
ncols = @_invoke Lib.XPRSgetintattrib(
model.inner,
Lib.XPRS_ORIGINALCOLS,
_,
)::Int
first = 0
last = ncols - 1
_dobj = Vector{Float64}(undef, ncols)
Expand Down Expand Up @@ -1199,8 +1203,14 @@ function MOI.get(
::MOI.ObjectiveFunction{MOI.ScalarQuadraticFunction{Float64}},
)
dest = zeros(length(model.variable_info))
nnz = n_quadratic_elements(model.inner)
n = n_variables(model.inner)
nnz = @_invoke(
Lib.XPRSgetintattrib(model.inner, Lib.XPRS_ORIGINALQELEMS, _)::Int
)
n = @_invoke Lib.XPRSgetintattrib(
model.inner,
Lib.XPRS_ORIGINALCOLS,
_,
)::Int
nels = Ref{Cint}(nnz)
mstart = Array{Cint}(undef, n + 1)
mclind = Array{Cint}(undef, nnz)
Expand Down Expand Up @@ -2330,7 +2340,8 @@ end

function _get_affine_terms(model::Optimizer, c::MOI.ConstraintIndex)
row = _info(model, c).row
nzcnt_max = n_non_zero_elements(model.inner)
nzcnt_max =
@_invoke Lib.XPRSgetintattrib(model.inner, Lib.XPRS_ELEMS, _)::Int

_nzcnt = Ref(Cint(0))
@checked Lib.XPRSgetrows(
Expand Down Expand Up @@ -2635,10 +2646,15 @@ function MOI.add_constraint(
indices .-= 1,#Cint.(_mrwind::Vector{Int}),
coefficients,#_dmatval
)
ncons = @_invoke Lib.XPRSgetintattrib(
model.inner,
Lib.XPRS_ORIGINALROWS,
_,
)::Int
@checked Lib.XPRSsetindicators(
model.inner,
1,
Ref{Cint}(n_constraints(model.inner) - 1),
Ref{Cint}(ncons - 1),
Ref{Cint}(con_value - 1),
Ref{Cint}(indicator_activation(Val{A})),
)
Expand Down Expand Up @@ -2720,9 +2736,14 @@ function MOI.add_constraint(
V .*= 0.5 # only for constraints
I .-= 1
J .-= 1
ncons = @_invoke Lib.XPRSgetintattrib(
model.inner,
Lib.XPRS_ORIGINALROWS,
_,
)::Int
@checked Lib.XPRSaddqmatrix(
model.inner,
n_constraints(model.inner) - 1,
ncons - 1,
Cint(length(I)),
I,
J,
Expand Down Expand Up @@ -2867,9 +2888,19 @@ function MOI.delete(
end

function _get_sparse_sos(model)
nnz = n_setmembers(model.inner)
nsos = n_special_ordered_sets(model.inner)
n = n_variables(model.inner)
nnz = @_invoke(
Lib.XPRSgetintattrib(model.inner, Lib.XPRS_ORIGINALSETMEMBERS, _)::Int
)
nsos = @_invoke Lib.XPRSgetintattrib(
model.inner,
Lib.XPRS_ORIGINALSETS,
_,
)::Int
n = @_invoke Lib.XPRSgetintattrib(
model.inner,
Lib.XPRS_ORIGINALCOLS,
_,
)::Int

settypes = Array{Cchar}(undef, nsos)
setstart = Array{Cint}(undef, nsos + 1)
Expand Down Expand Up @@ -2984,22 +3015,24 @@ function MOI.optimize!(model::Optimizer)
# Initialize callbacks if necessary.
if check_moi_callback_validity(model)
if model.moi_warnings &&
getcontrol(model.inner, Lib.XPRS_HEURSTRATEGY) != 0
@warn "Callbacks in XPRESS might not work correctly with HEURSTRATEGY != 0"
getcontrol(model.inner, "XPRS_HEURSTRATEGY") != 0
@warn(
"Callbacks in XPRESS might not work correctly with HEURSTRATEGY != 0",
)
end
MOI.set(model, CallbackFunction(), default_moi_callback(model))
model.has_generic_callback = false # because it is set as true in the above
end
pre_solve_reset(model)
# cache rhs: must be done before hand because it cant be
# properly queried if the problem ends up in a presolve state
rhs = Vector{Float64}(undef, n_constraints(model.inner))
@checked Lib.XPRSgetrhs(
ncons = @_invoke Lib.XPRSgetintattrib(
model.inner,
rhs,
Cint(0),
Cint(n_constraints(model.inner) - 1),
)
Lib.XPRS_ORIGINALROWS,
_,
)::Int
rhs = Vector{Float64}(undef, ncons)
@checked Lib.XPRSgetrhs(model.inner, rhs, Cint(0), Cint(ncons - 1))
if !model.ignore_start && is_mip(model)
_set_MIP_start(model)
end
Expand Down Expand Up @@ -4205,9 +4238,14 @@ function MOI.add_constraint(
C_NULL,
C_NULL,
)
ncons = @_invoke Lib.XPRSgetintattrib(
model.inner,
Lib.XPRS_ORIGINALROWS,
_,
)::Int
@checked Lib.XPRSaddqmatrix(
model.inner,
n_constraints(model.inner) - 1,
ncons - 1,
Cint(length(I)),
I,
I,
Expand Down Expand Up @@ -4297,14 +4335,12 @@ function MOI.add_constraint(
C_NULL,
C_NULL,
)
@checked Lib.XPRSaddqmatrix(
ncons = @_invoke Lib.XPRSgetintattrib(
model.inner,
n_constraints(model.inner) - 1,
length(I),
I,
J,
V,
)
Lib.XPRS_ORIGINALROWS,
_,
)::Int
@checked Lib.XPRSaddqmatrix(model.inner, ncons - 1, length(I), I, J, V)
model.last_constraint_index += 1
model.affine_constraint_info[model.last_constraint_index] =
ConstraintInfo(length(model.affine_constraint_info) + 1, s, RSOC)
Expand Down Expand Up @@ -4904,11 +4940,11 @@ end
MOI.supports(::Optimizer, ::MOI.RelativeGapTolerance) = true

function MOI.get(model::Optimizer, ::MOI.RelativeGapTolerance)
return getcontrol(model.inner, Lib.XPRS_MIPRELSTOP)
return getcontrol(model.inner, "XPRS_MIPRELSTOP")
end

function MOI.set(model::Optimizer, ::MOI.RelativeGapTolerance, value::Float64)
setcontrol!(model.inner, Lib.XPRS_MIPRELSTOP, value)
setcontrol!(model.inner, "XPRS_MIPRELSTOP", value)
return
end

Expand Down
1 change: 0 additions & 1 deletion src/Xpress.jl
Original file line number Diff line number Diff line change
Expand Up @@ -29,7 +29,6 @@ include("Lib/Lib.jl")

include("utils.jl")
include("helper.jl")
include("attributes_controls.jl")
include("api.jl")
include("xprs_callbacks.jl")
include("license.jl")
Expand Down
165 changes: 165 additions & 0 deletions src/api.jl
Original file line number Diff line number Diff line change
Expand Up @@ -6777,3 +6777,168 @@ end
function _bo_validate(obranch, p_status)
@checked Lib.XPRS_bo_validate(obranch, p_status)
end

#=
Other methods that we have deprecated
=#

function mip_solve_complete(stat)
return stat in [Lib.XPRS_MIP_INFEAS, Lib.XPRS_MIP_OPTIMAL]

Check warning on line 6786 in src/api.jl

View check run for this annotation

Codecov / codecov/patch

src/api.jl#L6785-L6786

Added lines #L6785 - L6786 were not covered by tests
end

function mip_solve_stopped(stat)
return stat in [Lib.XPRS_MIP_INFEAS, Lib.XPRS_MIP_OPTIMAL]

Check warning on line 6790 in src/api.jl

View check run for this annotation

Codecov / codecov/patch

src/api.jl#L6789-L6790

Added lines #L6789 - L6790 were not covered by tests
end

function fixinfinity(val::Float64)
if val == Inf
return Lib.XPRS_PLUSINFINITY
elseif val == -Inf
return Lib.XPRS_MINUSINFINITY

Check warning on line 6797 in src/api.jl

View check run for this annotation

Codecov / codecov/patch

src/api.jl#L6793-L6797

Added lines #L6793 - L6797 were not covered by tests
else
return val

Check warning on line 6799 in src/api.jl

View check run for this annotation

Codecov / codecov/patch

src/api.jl#L6799

Added line #L6799 was not covered by tests
end
end

function fixinfinity!(vals::Vector{Float64})
return map!(fixinfinity, vals, vals)

Check warning on line 6804 in src/api.jl

View check run for this annotation

Codecov / codecov/patch

src/api.jl#L6803-L6804

Added lines #L6803 - L6804 were not covered by tests
end

function is_quadratic_constraints(prob::XpressProblem)
return n_quadratic_constraints(prob) > 0

Check warning on line 6808 in src/api.jl

View check run for this annotation

Codecov / codecov/patch

src/api.jl#L6807-L6808

Added lines #L6807 - L6808 were not covered by tests
end

is_quadratic_objective(prob::XpressProblem) = n_quadratic_elements(prob) > 0

Check warning on line 6811 in src/api.jl

View check run for this annotation

Codecov / codecov/patch

src/api.jl#L6811

Added line #L6811 was not covered by tests

function obj_sense(prob::XpressProblem)
@_invoke Lib.XPRSgetdblattrib(prob, Lib.XPRS_OBJSENSE, _)::Float64

Check warning on line 6814 in src/api.jl

View check run for this annotation

Codecov / codecov/patch

src/api.jl#L6813-L6814

Added lines #L6813 - L6814 were not covered by tests
end

function objective_sense(prob::XpressProblem)
return obj_sense(prob) == Lib.XPRS_OBJ_MINIMIZE ? :minimize : :maximize

Check warning on line 6818 in src/api.jl

View check run for this annotation

Codecov / codecov/patch

src/api.jl#L6817-L6818

Added lines #L6817 - L6818 were not covered by tests
end

function n_original_variables(prob::XpressProblem)
@_invoke Lib.XPRSgetintattrib(prob, Lib.XPRS_ORIGINALCOLS, _)::Int

Check warning on line 6822 in src/api.jl

View check run for this annotation

Codecov / codecov/patch

src/api.jl#L6821-L6822

Added lines #L6821 - L6822 were not covered by tests
end

function n_original_constraints(prob::XpressProblem)
@_invoke Lib.XPRSgetintattrib(prob, Lib.XPRS_ORIGINALROWS, _)::Int

Check warning on line 6826 in src/api.jl

View check run for this annotation

Codecov / codecov/patch

src/api.jl#L6825-L6826

Added lines #L6825 - L6826 were not covered by tests
end

get_version_raw() = @_invoke Lib.XPRSgetversion(_)::String

Check warning on line 6829 in src/api.jl

View check run for this annotation

Codecov / codecov/patch

src/api.jl#L6829

Added line #L6829 was not covered by tests

function problem_type(prob::XpressProblem)
if n_quadratic_constraints(prob) > 0
return :QCP
elseif n_quadratic_elements(prob) > 0
return :QP

Check warning on line 6835 in src/api.jl

View check run for this annotation

Codecov / codecov/patch

src/api.jl#L6831-L6835

Added lines #L6831 - L6835 were not covered by tests
else
return :LP

Check warning on line 6837 in src/api.jl

View check run for this annotation

Codecov / codecov/patch

src/api.jl#L6837

Added line #L6837 was not covered by tests
end
end

function n_linear_constraints(prob::XpressProblem)
return n_constraints(prob) - n_quadratic_constraints(prob)

Check warning on line 6842 in src/api.jl

View check run for this annotation

Codecov / codecov/patch

src/api.jl#L6841-L6842

Added lines #L6841 - L6842 were not covered by tests
end

function n_setmembers(prob::XpressProblem)
@_invoke Lib.XPRSgetintattrib(prob, Lib.XPRS_ORIGINALSETMEMBERS, _)::Int

Check warning on line 6846 in src/api.jl

View check run for this annotation

Codecov / codecov/patch

src/api.jl#L6845-L6846

Added lines #L6845 - L6846 were not covered by tests
end

function n_quadratic_row_coefficients(prob::XpressProblem)
@_invoke Lib.XPRSgetintattrib(prob, Lib.XPRS_ORIGINALQCELEMS, _)::Int

Check warning on line 6850 in src/api.jl

View check run for this annotation

Codecov / codecov/patch

src/api.jl#L6849-L6850

Added lines #L6849 - L6850 were not covered by tests
end

function n_quadratic_elements(prob::XpressProblem)
@_invoke Lib.XPRSgetintattrib(prob, Lib.XPRS_ORIGINALQELEMS, _)::Int

Check warning on line 6854 in src/api.jl

View check run for this annotation

Codecov / codecov/patch

src/api.jl#L6853-L6854

Added lines #L6853 - L6854 were not covered by tests
end

function n_non_zero_elements(prob::XpressProblem)
@_invoke Lib.XPRSgetintattrib(prob, Lib.XPRS_ELEMS, _)::Int

Check warning on line 6858 in src/api.jl

View check run for this annotation

Codecov / codecov/patch

src/api.jl#L6857-L6858

Added lines #L6857 - L6858 were not covered by tests
end

function n_variables(prob::XpressProblem)
@_invoke Lib.XPRSgetintattrib(prob, Lib.XPRS_ORIGINALCOLS, _)::Int

Check warning on line 6862 in src/api.jl

View check run for this annotation

Codecov / codecov/patch

src/api.jl#L6861-L6862

Added lines #L6861 - L6862 were not covered by tests
end

function n_quadratic_constraints(prob::XpressProblem)
@_invoke Lib.XPRSgetintattrib(prob, Lib.XPRS_ORIGINALQCONSTRAINTS, _)::Int

Check warning on line 6866 in src/api.jl

View check run for this annotation

Codecov / codecov/patch

src/api.jl#L6865-L6866

Added lines #L6865 - L6866 were not covered by tests
end

function n_entities(prob::XpressProblem)
@_invoke Lib.XPRSgetintattrib(prob, Lib.XPRS_ORIGINALMIPENTS, _)::Int

Check warning on line 6870 in src/api.jl

View check run for this annotation

Codecov / codecov/patch

src/api.jl#L6869-L6870

Added lines #L6869 - L6870 were not covered by tests
end

function n_special_ordered_sets(prob::XpressProblem)
@_invoke Lib.XPRSgetintattrib(prob, Lib.XPRS_ORIGINALSETS, _)::Int

Check warning on line 6874 in src/api.jl

View check run for this annotation

Codecov / codecov/patch

src/api.jl#L6873-L6874

Added lines #L6873 - L6874 were not covered by tests
end

function n_constraints(prob::XpressProblem)
@_invoke Lib.XPRSgetintattrib(prob, Lib.XPRS_ORIGINALROWS, _)::Int

Check warning on line 6878 in src/api.jl

View check run for this annotation

Codecov / codecov/patch

src/api.jl#L6877-L6878

Added lines #L6877 - L6878 were not covered by tests
end

include("attributes_controls.jl")

function get_control_or_attribute(prob::XpressProblem, control::Int32)
if control in INTEGER_CONTROLS_VALUES
return @_invoke Lib.XPRSgetintcontrol(prob, control, _)::Int

Check warning on line 6885 in src/api.jl

View check run for this annotation

Codecov / codecov/patch

src/api.jl#L6885

Added line #L6885 was not covered by tests
elseif control in DOUBLE_CONTROLS_VALUES
return @_invoke Lib.XPRSgetdblcontrol(prob, control, _)::Float64

Check warning on line 6887 in src/api.jl

View check run for this annotation

Codecov / codecov/patch

src/api.jl#L6887

Added line #L6887 was not covered by tests
elseif control in STRING_CONTROLS_VALUES
return @_invoke Lib.XPRSgetstrcontrol(prob, control, _)::String

Check warning on line 6889 in src/api.jl

View check run for this annotation

Codecov / codecov/patch

src/api.jl#L6889

Added line #L6889 was not covered by tests
elseif control in INTEGER_ATTRIBUTES_VALUES
return @_invoke Lib.XPRSgetintattrib(prob, control, _)::Int
elseif control in DOUBLE_ATTRIBUTES_VALUES
return @_invoke Lib.XPRSgetdblattrib(prob, control, _)::Float64
elseif control in STRING_ATTRIBUTES_VALUES
return @_invoke Lib.XPRSgetstrattrib(prob, control, _)::String

Check warning on line 6895 in src/api.jl

View check run for this annotation

Codecov / codecov/patch

src/api.jl#L6894-L6895

Added lines #L6894 - L6895 were not covered by tests
end
return error("Unrecognized parameter: $(control).")

Check warning on line 6897 in src/api.jl

View check run for this annotation

Codecov / codecov/patch

src/api.jl#L6897

Added line #L6897 was not covered by tests
end

function get_control_or_attribute(prob::XpressProblem, control::Integer)
return get_control_or_attribute(prob, Int32(control))
end

function getcontrol(prob::XpressProblem, control::Int32)
if control in INTEGER_CONTROLS_VALUES
return @_invoke Lib.XPRSgetintcontrol(prob, control, _)::Int

Check warning on line 6906 in src/api.jl

View check run for this annotation

Codecov / codecov/patch

src/api.jl#L6906

Added line #L6906 was not covered by tests
elseif control in DOUBLE_CONTROLS_VALUES
return @_invoke Lib.XPRSgetdblcontrol(prob, control, _)::Float64
elseif control in STRING_CONTROLS_VALUES
return @_invoke Lib.XPRSgetstrcontrol(prob, control, _)::String

Check warning on line 6910 in src/api.jl

View check run for this annotation

Codecov / codecov/patch

src/api.jl#L6909-L6910

Added lines #L6909 - L6910 were not covered by tests
end
return error("Unrecognized control: $(control).")

Check warning on line 6912 in src/api.jl

View check run for this annotation

Codecov / codecov/patch

src/api.jl#L6912

Added line #L6912 was not covered by tests
end

function getcontrol(prob::XpressProblem, control::Integer)
return getcontrol(prob, Int32(control))
end

function setcontrol!(prob::XpressProblem, control::Int32, val)
if control in INTEGER_CONTROLS_VALUES
if !isinteger(val)
error("Expected and integer and got $val")

Check warning on line 6922 in src/api.jl

View check run for this annotation

Codecov / codecov/patch

src/api.jl#L6921-L6922

Added lines #L6921 - L6922 were not covered by tests
end
Lib.XPRSsetintcontrol(prob, Cint(control), Int32(val))

Check warning on line 6924 in src/api.jl

View check run for this annotation

Codecov / codecov/patch

src/api.jl#L6924

Added line #L6924 was not covered by tests
elseif control in DOUBLE_CONTROLS_VALUES
Lib.XPRSsetdblcontrol(prob, control, Float64(val))
elseif control in STRING_CONTROLS_VALUES
Lib.XPRSsetstrcontrol(prob, control, val)

Check warning on line 6928 in src/api.jl

View check run for this annotation

Codecov / codecov/patch

src/api.jl#L6927-L6928

Added lines #L6927 - L6928 were not covered by tests
else
error("Unrecognized control parameter: $(control).")

Check warning on line 6930 in src/api.jl

View check run for this annotation

Codecov / codecov/patch

src/api.jl#L6930

Added line #L6930 was not covered by tests
end
return
end

function setcontrol!(prob::XpressProblem, control::Integer, val)
return setcontrol!(prob, Cint(control), val)
end

function setcontrols!(prob::XpressProblem; kwargs...)
for (control, val) in kwargs
setcontrol!(prob, String(control), val)
end
return

Check warning on line 6943 in src/api.jl

View check run for this annotation

Codecov / codecov/patch

src/api.jl#L6939-L6943

Added lines #L6939 - L6943 were not covered by tests
end
Loading

0 comments on commit eda0e4a

Please sign in to comment.