Skip to content

Commit

Permalink
fix more
Browse files Browse the repository at this point in the history
  • Loading branch information
exaexa committed Jun 10, 2024
1 parent b69c29f commit 9cdbb11
Showing 1 changed file with 7 additions and 5 deletions.
12 changes: 7 additions & 5 deletions src/interface.jl
Original file line number Diff line number Diff line change
Expand Up @@ -48,28 +48,30 @@ inefficient. Use `coupling` instead.
function A.coupling_weights(m::MATFBCModel, cid::String)
startswith(cid, "mat_coupling_") || throw(DomainError(cid, "unknown coupling"))
cidx = parse(Int, cid[14:end])
return Dict(r => w for (r, w) in zip(A.reactions(m), A.coupling(m)[cidx, :]) if w != 0)
return Dict{String,Float64}(
r => w for (r, w) in zip(A.reactions(m), A.coupling(m)[cidx, :]) if w != 0
)
end


function A.coupling_bounds(m::MATFBCModel)
nc = n_coupling_constraints(m)
nc = A.n_couplings(m)
if looks_like_squashed_coupling(m.mat)
c = reshape(m.mat["b"], length(m.mat["b"]))[A.n_reactions(m)+1:end]
csense = reshape(m.mat["csense"], length(m.mat["csense"]))[A.n_reactions(m)+1:end],
(
return (
[sense in ["G", "E"] ? val : -Inf for (val, sense) in zip(c, csense)],
[sense in ["L", "E"] ? val : Inf for (val, sense) in zip(c, csense)],
)
elseif haskey(m.mat, "d") && haskey(m.mat, "dsense")
d = reshape(m.mat["d"], nc)
dsense = reshape(m.mat["dsense"], nc)
(
return (
[sense in ["G", "E"] ? val : -Inf for (val, sense) in zip(d, dsense)],
[sense in ["L", "E"] ? val : Inf for (val, sense) in zip(d, dsense)],
)
else
(
return (
reshape(get(m.mat, "cl", fill(-Inf, nc, 1)), nc),
reshape(get(m.mat, "cu", fill(Inf, nc, 1)), nc),
)
Expand Down

0 comments on commit 9cdbb11

Please sign in to comment.