diff --git a/Project.toml b/Project.toml index 5ea33a264..8b16ec3aa 100644 --- a/Project.toml +++ b/Project.toml @@ -2,7 +2,7 @@ name = "PowerModelsDistribution" uuid = "d7431456-977f-11e9-2de3-97ff7677985e" authors = ["David M Fobes ", "Carleton Coffrin"] repo = "https://github.com/lanl-ansi/PowerModelsDistribution.jl.git" -version = "0.15.2" +version = "0.16.0" [deps] CSV = "336ed68f-0bac-5ca0-87d4-7b16caf5d00b" @@ -23,22 +23,24 @@ Statistics = "10745b16-79ce-11e8-11f9-7d13ad32a3b2" [compat] CSV = "0.8.5, 0.9, 0.10" +Dates = "1.6" FilePaths = "0.8.3" Glob = "1.3" Graphs = "1" InfrastructureModels = "0.7.3, 0.7.5" -Ipopt = "0.9, 1.0.2, 1.1" +Ipopt = "1" JSON = "0.18, 0.19, 0.20, 0.21" -JuMP = "0.22, 0.23, 1" +JuMP = "1.23.2" LoggingExtras = "0.4.7, 1" PolyhedralRelaxations = "0.3.5" SCS = "0.9, 1.0, 1.1" +SparseArrays = "1.6" SpecialFunctions = "2" +Test = "1.6" julia = "1.6" [extras] Ipopt = "b6b21f68-93f8-5de0-b562-5493be1d77c9" -JSON = "682c06a0-de6a-54ab-a142-c8b1cf79cde6" SCS = "c946c3f1-0d1f-5ce8-9dea-7daa1f7e2d13" Test = "8dfed614-e22c-5e08-85e1-65c5234f0b40" diff --git a/docs/src/reference/base.md b/docs/src/reference/base.md index f443600a3..76f9d9645 100644 --- a/docs/src/reference/base.md +++ b/docs/src/reference/base.md @@ -13,7 +13,6 @@ nw_ids ## Helper functions ```@docs -@smart_constraint set_lower_bound set_upper_bound comp_start_value diff --git a/examples/Extension Tutorial.jl b/examples/Extension Tutorial.jl index d9a3e696e..dd5187e3f 100644 --- a/examples/Extension Tutorial.jl +++ b/examples/Extension Tutorial.jl @@ -410,10 +410,10 @@ end; # ╔═╡ f7b500a6-7dbf-44cb-9433-3b534f13cd6b begin # link charge to generator models - JuMP.@NLconstraint(nc_model, [e in EVs, k in K], + JuMP.@constraint(nc_model, [e in EVs, k in K], nc_Pg_ek[e,k] == -nc_P_ek[e,k] ) - JuMP.@NLconstraint(nc_model, [e in EVs, k in K], + JuMP.@constraint(nc_model, [e in EVs, k in K], nc_Qg_ek[e,k] == 0.0 ) end; diff --git a/src/core/base.jl b/src/core/base.jl index 5f33c2a90..9d5c0f3d7 100644 --- a/src/core/base.jl +++ b/src/core/base.jl @@ -69,22 +69,6 @@ function _check_var_keys(vars, keys, var_name, comp_name) end -""" - @smart_constraint model::JuMP.Model vars::Vector expr::JuMP.Expression - -Detection of whether a constraint should be NL or not" -""" -macro smart_constraint(model, vars, expr) - esc(quote - if _has_nl_expression($vars) - JuMP.@NLconstraint($model, $expr) - else - JuMP.@constraint($model, $expr) - end - end) -end - - """ function set_lower_bound( x::JuMP.VariableRef, diff --git a/src/core/data.jl b/src/core/data.jl index 8309af410..3e568b516 100644 --- a/src/core/data.jl +++ b/src/core/data.jl @@ -811,31 +811,6 @@ function _make_full_matrix_variable(diag::Vector{T}, lowertriangle::Vector{T}, u return matrix end -# TODO refactor into several functions -"helper to determine if expession has any Nonlinear terms" -function _has_nl_expression(x)::Bool - if isa(x, JuMP.NonlinearExpression) - return true - elseif isa(x, Array) - if any(_has_nl_expression.(x)) - return true - end - elseif isa(x, Dict) - for i in values(x) - if _has_nl_expression(i) - return true - end - end - elseif isa(x, JuMP.Containers.DenseAxisArray) - for i in values(x.data) - if _has_nl_expression(i) - return true - end - end - end - return false -end - """ correct_mc_voltage_angle_differences!(data::Dict{String,<:Any}, default_pad::Real=deg2rad(10.0)) diff --git a/src/core/objective.jl b/src/core/objective.jl index 126299e52..233dbc6a2 100644 --- a/src/core/objective.jl +++ b/src/core/objective.jl @@ -247,59 +247,29 @@ end "gen connections adaptation of min fuel cost polynomial linquad objective" function _objective_mc_min_fuel_cost_polynomial_linquad(pm::AbstractUnbalancedPowerModel; report::Bool=true) - pg_contains_nl_exp = any(x<:JuMP.NonlinearExpression for x in vcat([typeof.(isa(pg, JuMP.Containers.DenseAxisArray) ? pg.data : pg) for nw in nw_ids(pm) for (id,pg) in var(pm, nw, :pg)]...)) gen_cost = Dict() - if !pg_contains_nl_exp - for (n, nw_ref) in nws(pm) - for (i,gen) in nw_ref[:gen] - pg = sum(var(pm, n, :pg, i)) - - if length(gen["cost"]) == 1 - gen_cost[(n,i)] = gen["cost"][1] - elseif length(gen["cost"]) == 2 - gen_cost[(n,i)] = gen["cost"][1]*pg + gen["cost"][2] - elseif length(gen["cost"]) == 3 - gen_cost[(n,i)] = gen["cost"][1]*pg^2 + gen["cost"][2]*pg + gen["cost"][3] - else - gen_cost[(n,i)] = 0.0 - end - end - end + for (n, nw_ref) in nws(pm) + for (i,gen) in nw_ref[:gen] + pg = sum(var(pm, n, :pg, i)) - return JuMP.@objective(pm.model, Min, - sum( - sum( gen_cost[(n,i)] for (i,gen) in nw_ref[:gen] ) - for (n, nw_ref) in nws(pm)) - ) - else - for (n, nw_ref) in nws(pm) - for (i,gen) in nw_ref[:gen] - bus = gen["gen_bus"] - - #to avoid function calls inside of @NLconstraint: - pg = var(pm, n, :pg, i) - pg = isa(pg, JuMP.Containers.DenseAxisArray) ? pg.data : pg - - int_dim = length(pg) - if length(gen["cost"]) == 1 - gen_cost[(n,i)] = gen["cost"][1] - elseif length(gen["cost"]) == 2 - gen_cost[(n,i)] = JuMP.@NLexpression(pm.model, gen["cost"][1]*sum(pg[i] for i in 1:int_dim) + gen["cost"][2]) - elseif length(gen["cost"]) == 3 - gen_cost[(n,i)] = JuMP.@NLexpression(pm.model, gen["cost"][1]*sum(pg[i] for i in 1:int_dim)^2 + gen["cost"][2]*sum(pg[i] for i in 1:int_dim) + gen["cost"][3]) - else - gen_cost[(n,i)] = 0.0 - end + if length(gen["cost"]) == 1 + gen_cost[(n,i)] = gen["cost"][1] + elseif length(gen["cost"]) == 2 + gen_cost[(n,i)] = gen["cost"][1]*pg + gen["cost"][2] + elseif length(gen["cost"]) == 3 + gen_cost[(n,i)] = gen["cost"][1]*pg^2 + gen["cost"][2]*pg + gen["cost"][3] + else + gen_cost[(n,i)] = 0.0 end end - - return JuMP.@NLobjective(pm.model, Min, - sum( - sum( gen_cost[(n,i)] for (i,gen) in nw_ref[:gen] ) - for (n, nw_ref) in nws(pm)) - ) end + + return JuMP.@objective(pm.model, Min, + sum( + sum( gen_cost[(n,i)] for (i,gen) in nw_ref[:gen] ) + for (n, nw_ref) in nws(pm)) + ) end @@ -375,21 +345,21 @@ function _objective_mc_min_fuel_cost_polynomial_nl(pm::AbstractUnbalancedPowerMo cost_rev = reverse(gen["cost"]) if length(cost_rev) == 1 - gen_cost[(n,i)] = JuMP.@NLexpression(pm.model, cost_rev[1]) + gen_cost[(n,i)] = JuMP.@expression(pm.model, cost_rev[1]) elseif length(cost_rev) == 2 - gen_cost[(n,i)] = JuMP.@NLexpression(pm.model, cost_rev[1] + cost_rev[2]*pg) + gen_cost[(n,i)] = JuMP.@expression(pm.model, cost_rev[1] + cost_rev[2]*pg) elseif length(cost_rev) == 3 - gen_cost[(n,i)] = JuMP.@NLexpression(pm.model, cost_rev[1] + cost_rev[2]*pg + cost_rev[3]*pg^2) + gen_cost[(n,i)] = JuMP.@expression(pm.model, cost_rev[1] + cost_rev[2]*pg + cost_rev[3]*pg^2) elseif length(cost_rev) >= 4 cost_rev_nl = cost_rev[4:end] - gen_cost[(n,i)] = JuMP.@NLexpression(pm.model, cost_rev[1] + cost_rev[2]*pg + cost_rev[3]*pg^2 + sum( v*pg^(d+2) for (d,v) in enumerate(cost_rev_nl)) ) + gen_cost[(n,i)] = JuMP.@expression(pm.model, cost_rev[1] + cost_rev[2]*pg + cost_rev[3]*pg^2 + sum( v*pg^(d+2) for (d,v) in enumerate(cost_rev_nl)) ) else - gen_cost[(n,i)] = JuMP.@NLexpression(pm.model, 0.0) + gen_cost[(n,i)] = JuMP.@expression(pm.model, 0.0) end end end - return JuMP.@NLobjective(pm.model, Min, + return JuMP.@objective(pm.model, Min, sum( sum( gen_cost[(n,i)] for (i,gen) in nw_ref[:gen] ) for (n, nw_ref) in nws(pm)) @@ -406,21 +376,21 @@ function _objective_mc_min_fuel_cost_polynomial_nl_switch(pm::AbstractUnbalanced cost_rev = reverse(gen["cost"]) if length(cost_rev) == 1 - gen_cost[(n,i)] = JuMP.@NLexpression(pm.model, cost_rev[1]) + gen_cost[(n,i)] = JuMP.@expression(pm.model, cost_rev[1]) elseif length(cost_rev) == 2 - gen_cost[(n,i)] = JuMP.@NLexpression(pm.model, cost_rev[1] + cost_rev[2]*pg) + gen_cost[(n,i)] = JuMP.@expression(pm.model, cost_rev[1] + cost_rev[2]*pg) elseif length(cost_rev) == 3 - gen_cost[(n,i)] = JuMP.@NLexpression(pm.model, cost_rev[1] + cost_rev[2]*pg + cost_rev[3]*pg^2) + gen_cost[(n,i)] = JuMP.@expression(pm.model, cost_rev[1] + cost_rev[2]*pg + cost_rev[3]*pg^2) elseif length(cost_rev) >= 4 cost_rev_nl = cost_rev[4:end] - gen_cost[(n,i)] = JuMP.@NLexpression(pm.model, cost_rev[1] + cost_rev[2]*pg + cost_rev[3]*pg^2 + sum( v*pg^(d+2) for (d,v) in enumerate(cost_rev_nl)) ) + gen_cost[(n,i)] = JuMP.@expression(pm.model, cost_rev[1] + cost_rev[2]*pg + cost_rev[3]*pg^2 + sum( v*pg^(d+2) for (d,v) in enumerate(cost_rev_nl)) ) else - gen_cost[(n,i)] = JuMP.@NLexpression(pm.model, 0.0) + gen_cost[(n,i)] = JuMP.@expression(pm.model, 0.0) end end end - return JuMP.@NLobjective(pm.model, Min, + return JuMP.@objective(pm.model, Min, sum( sum( gen_cost[(n,i)] for (i,gen) in nw_ref[:gen] ) + sum( var(pm, n, :switch_state, l) for l in ids(pm, n, :switch_dispatchable)) @@ -448,7 +418,7 @@ function objective_variable_pg_cost(pm::AbstractUnbalancedIVRModel; report::Bool for (i, gen) in nw_ref[:gen] pg = var(pm, n, :pg, i) for line in gen_lines[i] - JuMP.@NLconstraint(pm.model, pg_cost[i] >= line.slope*sum(pg[c] for c in gen["connections"]) + line.intercept) + JuMP.@constraint(pm.model, pg_cost[i] >= line.slope*sum(pg[c] for c in gen["connections"]) + line.intercept) end end end diff --git a/src/core/solution.jl b/src/core/solution.jl index de41154e2..d39b51661 100644 --- a/src/core/solution.jl +++ b/src/core/solution.jl @@ -11,21 +11,9 @@ function _IM.solution_preprocessor(pm::AbstractUnbalancedPowerModel, solution::D end -"custom `build_solution_values` for multiconductor (vector) variables" -function _IM.build_solution_values(var::JuMP.Containers.DenseAxisArray{<:JuMP.VariableRef,1}) - return JuMP.value.(var.data) -end - - -"custom `build_solution_values` for multiconductor (vector) nonlinear expressions" -function _IM.build_solution_values(var::JuMP.Containers.DenseAxisArray{<:JuMP.NonlinearExpression,1}) - return JuMP.value.(var.data) -end - - -"custom `build_solution_values` for multiconductor (vector) generic affine expressions" -function _IM.build_solution_values(var::JuMP.Containers.DenseAxisArray{<:JuMP.GenericAffExpr,1}) - return JuMP.value.(var.data) +"custom `build_solution_values` for multiconductor (vector) JuMP expressions" +function _IM.build_solution_values(var::JuMP.AbstractJuMPScalar) + return JuMP.value(var) end diff --git a/src/form/acp.jl b/src/form/acp.jl index b70d5aaef..b5f6b8f02 100644 --- a/src/form/acp.jl +++ b/src/form/acp.jl @@ -149,7 +149,7 @@ function constraint_mc_power_balance_slack(pm::AbstractUnbalancedACPModel, nw::I ungrounded_terminals = [(idx,t) for (idx,t) in enumerate(terminals) if !grounded[idx]] for (idx,t) in ungrounded_terminals - cp = JuMP.@NLconstraint(pm.model, + cp = JuMP.@constraint(pm.model, sum( p[a][t] for (a, conns) in bus_arcs if t in conns) + sum(psw[a][t] for (a, conns) in bus_arcs_sw if t in conns) + sum( pt[a][t] for (a, conns) in bus_arcs_trans if t in conns) @@ -167,7 +167,7 @@ function constraint_mc_power_balance_slack(pm::AbstractUnbalancedACPModel, nw::I ) push!(cstr_p, cp) - cq = JuMP.@NLconstraint(pm.model, + cq = JuMP.@constraint(pm.model, sum( q[a][t] for (a, conns) in bus_arcs if t in conns) + sum(qsw[a][t] for (a, conns) in bus_arcs_sw if t in conns) + sum( qt[a][t] for (a, conns) in bus_arcs_trans if t in conns) @@ -223,7 +223,7 @@ function constraint_mc_power_balance_shed(pm::AbstractUnbalancedACPModel, nw::In ungrounded_terminals = [(idx,t) for (idx,t) in enumerate(terminals) if !grounded[idx]] for (idx,t) in ungrounded_terminals - cp = JuMP.@NLconstraint(pm.model, + cp = JuMP.@constraint(pm.model, sum( p[a][t] for (a, conns) in bus_arcs if t in conns) + sum(psw[a_sw][t] for (a_sw, conns) in bus_arcs_sw if t in conns) + sum( pt[a_t][t] for (a_t, conns) in bus_arcs_trans if t in conns) @@ -241,7 +241,7 @@ function constraint_mc_power_balance_shed(pm::AbstractUnbalancedACPModel, nw::In ) push!(cstr_p, cp) - cq = JuMP.@NLconstraint(pm.model, + cq = JuMP.@constraint(pm.model, sum( q[a][t] for (a, conns) in bus_arcs if t in conns) + sum(qsw[a_sw][t] for (a_sw, conns) in bus_arcs_sw if t in conns) + sum( qt[a_t][t] for (a_t, conns) in bus_arcs_trans if t in conns) @@ -304,7 +304,7 @@ function constraint_mc_power_balance_simple(pm::AbstractUnbalancedACPModel, nw:: ungrounded_terminals = [(idx,t) for (idx,t) in enumerate(terminals) if !grounded[idx]] for (idx,t) in ungrounded_terminals - cp = JuMP.@NLconstraint(pm.model, + cp = JuMP.@constraint(pm.model, sum( p[a][t] for (a, conns) in bus_arcs if t in conns) + sum(psw[a][t] for (a, conns) in bus_arcs_sw if t in conns) + sum( pt[a][t] for (a, conns) in bus_arcs_trans if t in conns) @@ -321,7 +321,7 @@ function constraint_mc_power_balance_simple(pm::AbstractUnbalancedACPModel, nw:: ) push!(cstr_p, cp) - cq = JuMP.@NLconstraint(pm.model, + cq = JuMP.@constraint(pm.model, sum(q[a][c] for a in bus_arcs) + sum(qsw[a_sw][c] for a_sw in bus_arcs_sw) + sum(qt[a_trans][c] for a_trans in bus_arcs_trans) @@ -374,7 +374,7 @@ function constraint_mc_power_balance(pm::AbstractUnbalancedACPModel, nw::Int, i: for (idx,t) in ungrounded_terminals if any(Bs[idx,jdx] != 0 for (jdx, u) in ungrounded_terminals if idx != jdx) || any(Gs[idx,jdx] != 0 for (jdx, u) in ungrounded_terminals if idx != jdx) - cp = JuMP.@NLconstraint(pm.model, + cp = JuMP.@constraint(pm.model, sum( p[a][t] for (a, conns) in bus_arcs if t in conns) + sum(psw[a][t] for (a, conns) in bus_arcs_sw if t in conns) + sum( pt[a][t] for (a, conns) in bus_arcs_trans if t in conns) @@ -392,7 +392,7 @@ function constraint_mc_power_balance(pm::AbstractUnbalancedACPModel, nw::Int, i: ) push!(cstr_p, cp) - cq = JuMP.@NLconstraint(pm.model, + cq = JuMP.@constraint(pm.model, sum( q[a][t] for (a, conns) in bus_arcs if t in conns) + sum(qsw[a][t] for (a, conns) in bus_arcs_sw if t in conns) + sum( qt[a][t] for (a, conns) in bus_arcs_trans if t in conns) @@ -410,7 +410,7 @@ function constraint_mc_power_balance(pm::AbstractUnbalancedACPModel, nw::Int, i: ) push!(cstr_q, cq) else - cp = @smart_constraint(pm.model, [p, pg, ps, psw, pt, pd, vm], + cp = JuMP.@constraint(pm.model, sum( p[a][t] for (a, conns) in bus_arcs if t in conns) + sum(psw[a][t] for (a, conns) in bus_arcs_sw if t in conns) + sum( pt[a][t] for (a, conns) in bus_arcs_trans if t in conns) @@ -423,7 +423,7 @@ function constraint_mc_power_balance(pm::AbstractUnbalancedACPModel, nw::Int, i: ) push!(cstr_p, cp) - cq = @smart_constraint(pm.model, [q, qg, qs, qsw, qt, qd, vm], + cq = JuMP.@constraint(pm.model, sum( q[a][t] for (a, conns) in bus_arcs if t in conns) + sum(qsw[a][t] for (a, conns) in bus_arcs_sw if t in conns) + sum( qt[a][t] for (a, conns) in bus_arcs_trans if t in conns) @@ -486,7 +486,7 @@ function constraint_mc_power_balance_capc(pm::AbstractUnbalancedACPModel, nw::In cap_state = 1.0 ncnds = length(terminals) Gs = fill(0.0, ncnds, ncnds) - Bs = convert(Matrix{JuMP.NonlinearExpression}, JuMP.@NLexpression(pm.model, [idx=1:ncnds, jdx=1:ncnds], 0.0)) + Bs = Any[0.0 for idx in 1:ncnds, jdx in 1:ncnds] for (val, connections) in bus_shunts shunt = ref(pm,nw,:shunt,val) for (idx,c) in enumerate(connections) @@ -495,7 +495,7 @@ function constraint_mc_power_balance_capc(pm::AbstractUnbalancedACPModel, nw::In end for (jdx,d) in enumerate(connections) Gs[findfirst(isequal(c), terminals),findfirst(isequal(d), terminals)] += shunt["gs"][idx,jdx] - Bs[findfirst(isequal(c), terminals),findfirst(isequal(d), terminals)] = JuMP.@NLexpression(pm.model, Bs[findfirst(isequal(c), terminals),findfirst(isequal(d), terminals)] + shunt["bs"][idx,jdx]*cap_state) + Bs[findfirst(isequal(c), terminals),findfirst(isequal(d), terminals)] = JuMP.@expression(pm.model, Bs[findfirst(isequal(c), terminals),findfirst(isequal(d), terminals)] + shunt["bs"][idx,jdx]*cap_state) end end end @@ -506,7 +506,7 @@ function constraint_mc_power_balance_capc(pm::AbstractUnbalancedACPModel, nw::In for (idx,t) in ungrounded_terminals if any(Bs[idx,jdx] != 0 for (jdx, u) in ungrounded_terminals if idx != jdx) || any(Gs[idx,jdx] != 0 for (jdx, u) in ungrounded_terminals if idx != jdx) - cp = JuMP.@NLconstraint(pm.model, + cp = JuMP.@constraint(pm.model, sum( p[a][t] for (a, conns) in bus_arcs if t in conns) + sum(psw[a][t] for (a, conns) in bus_arcs_sw if t in conns) + sum( pt[a][t] for (a, conns) in bus_arcs_trans if t in conns) @@ -524,7 +524,7 @@ function constraint_mc_power_balance_capc(pm::AbstractUnbalancedACPModel, nw::In ) push!(cstr_p, cp) - cq = JuMP.@NLconstraint(pm.model, + cq = JuMP.@constraint(pm.model, sum( q[a][t] for (a, conns) in bus_arcs if t in conns) + sum(qsw[a][t] for (a, conns) in bus_arcs_sw if t in conns) + sum( qt[a][t] for (a, conns) in bus_arcs_trans if t in conns) @@ -542,7 +542,7 @@ function constraint_mc_power_balance_capc(pm::AbstractUnbalancedACPModel, nw::In ) push!(cstr_q, cq) else - cp = @smart_constraint(pm.model, [p, pg, ps, psw, pt, pd, vm], + cp = JuMP.@constraint(pm.model, sum( p[a][t] for (a, conns) in bus_arcs if t in conns) + sum(psw[a][t] for (a, conns) in bus_arcs_sw if t in conns) + sum( pt[a][t] for (a, conns) in bus_arcs_trans if t in conns) @@ -555,7 +555,7 @@ function constraint_mc_power_balance_capc(pm::AbstractUnbalancedACPModel, nw::In ) push!(cstr_p, cp) - cq = @smart_constraint(pm.model, [q, qg, qs, qsw, qt, qd, vm, Bs], + cq = JuMP.@constraint(pm.model, sum( q[a][t] for (a, conns) in bus_arcs if t in conns) + sum(qsw[a][t] for (a, conns) in bus_arcs_sw if t in conns) + sum( qt[a][t] for (a, conns) in bus_arcs_trans if t in conns) @@ -670,7 +670,7 @@ function constraint_mc_ohms_yt_from(pm::AbstractUnbalancedACPModel, nw::Int, f_b ohms_yt_p = JuMP.ConstraintRef[] ohms_yt_q = JuMP.ConstraintRef[] for (idx, (fc,tc)) in enumerate(zip(f_connections,t_connections)) - push!(ohms_yt_p, JuMP.@NLconstraint(pm.model, p_fr[fc] == (G[idx,idx]+G_fr[idx,idx])*vm_fr[fc]^2 + push!(ohms_yt_p, JuMP.@constraint(pm.model, p_fr[fc] == (G[idx,idx]+G_fr[idx,idx])*vm_fr[fc]^2 +sum( (G[idx,jdx]+G_fr[idx,jdx]) * vm_fr[fc]*vm_fr[fd]*cos(va_fr[fc]-va_fr[fd]) +(B[idx,jdx]+B_fr[idx,jdx]) * vm_fr[fc]*vm_fr[fd]*sin(va_fr[fc]-va_fr[fd]) for (jdx, (fd,td)) in enumerate(zip(f_connections,t_connections)) if idx != jdx) @@ -680,7 +680,7 @@ function constraint_mc_ohms_yt_from(pm::AbstractUnbalancedACPModel, nw::Int, f_b ) ) - push!(ohms_yt_q, JuMP.@NLconstraint(pm.model, q_fr[fc] == -(B[idx,idx]+B_fr[idx,idx])*vm_fr[fc]^2 + push!(ohms_yt_q, JuMP.@constraint(pm.model, q_fr[fc] == -(B[idx,idx]+B_fr[idx,idx])*vm_fr[fc]^2 -sum( (B[idx,jdx]+B_fr[idx,jdx])*vm_fr[fc]*vm_fr[fd]*cos(va_fr[fc]-va_fr[fd]) -(G[idx,jdx]+G_fr[idx,jdx])*vm_fr[fc]*vm_fr[fd]*sin(va_fr[fc]-va_fr[fd]) for (jdx, (fd,td)) in enumerate(zip(f_connections,t_connections)) if idx != jdx) @@ -739,16 +739,16 @@ function constraint_mc_transformer_power_yy(pm::AbstractUnbalancedACPModel, nw:: x = transformer["controls"]["x"][idx] # (cr+jci) = (p-jq)/(vm⋅cos(va)-jvm⋅sin(va)) - cr = JuMP.@NLexpression(pm.model, ( p_to[idx]*vm_to[tc]*cos(va_to[tc]) + q_to[idx]*vm_to[tc]*sin(va_to[tc]))/vm_to[tc]^2) - ci = JuMP.@NLexpression(pm.model, (-q_to[idx]*vm_to[tc]*cos(va_to[tc]) + p_to[idx]*vm_to[tc]*sin(va_to[tc]))/vm_to[tc]^2) + cr = JuMP.@expression(pm.model, ( p_to[idx]*vm_to[tc]*cos(va_to[tc]) + q_to[idx]*vm_to[tc]*sin(va_to[tc]))/vm_to[tc]^2) + ci = JuMP.@expression(pm.model, (-q_to[idx]*vm_to[tc]*cos(va_to[tc]) + p_to[idx]*vm_to[tc]*sin(va_to[tc]))/vm_to[tc]^2) # v_drop = (cr+jci)⋅(r+jx) - vr_drop = JuMP.@NLexpression(pm.model, r*cr-x*ci) - vi_drop = JuMP.@NLexpression(pm.model, r*ci+x*cr) + vr_drop = JuMP.@expression(pm.model, r*cr-x*ci) + vi_drop = JuMP.@expression(pm.model, r*ci+x*cr) # v_ref-δ ≤ vm_fr-(cr+jci)⋅(r+jx)≤ v_ref+δ # vm_fr/1.1 ≤ vm_to ≤ vm_fr/0.9 - JuMP.@NLconstraint(pm.model, (vm_fr[fc]*cos(va_fr[fc])-vr_drop)^2 + (vm_fr[fc]*sin(va_fr[fc])-vi_drop)^2 ≥ (v_ref - δ)^2) - JuMP.@NLconstraint(pm.model, (vm_fr[fc]*cos(va_fr[fc])-vr_drop)^2 + (vm_fr[fc]*sin(va_fr[fc])-vi_drop)^2 ≤ (v_ref + δ)^2) + JuMP.@constraint(pm.model, (vm_fr[fc]*cos(va_fr[fc])-vr_drop)^2 + (vm_fr[fc]*sin(va_fr[fc])-vi_drop)^2 ≥ (v_ref - δ)^2) + JuMP.@constraint(pm.model, (vm_fr[fc]*cos(va_fr[fc])-vr_drop)^2 + (vm_fr[fc]*sin(va_fr[fc])-vi_drop)^2 ≤ (v_ref + δ)^2) JuMP.@constraint(pm.model, vm_fr[fc]/1.1 ≤ vm_to[tc]) JuMP.@constraint(pm.model, vm_fr[fc]/0.9 ≥ vm_to[tc]) end @@ -782,10 +782,10 @@ function constraint_mc_transformer_power_dy(pm::AbstractUnbalancedACPModel, nw:: # e.g., for nph=3: 1->3, 2->1, 3->2 jdx = (idx-1+1)%nph+1 fd = f_connections[jdx] - vd_re[idx] = JuMP.@NLexpression(pm.model, vm_fr[fc]*cos(va_fr[fc])-vm_fr[fd]*cos(va_fr[fd])) - vd_im[idx] = JuMP.@NLexpression(pm.model, vm_fr[fc]*sin(va_fr[fc])-vm_fr[fd]*sin(va_fr[fd])) - JuMP.@NLconstraint(pm.model, vd_re[idx] == pol*tm_scale*tm[idx]*vm_to[tc]*cos(va_to[tc])) - JuMP.@NLconstraint(pm.model, vd_im[idx] == pol*tm_scale*tm[idx]*vm_to[tc]*sin(va_to[tc])) + vd_re[idx] = JuMP.@expression(pm.model, vm_fr[fc]*cos(va_fr[fc])-vm_fr[fd]*cos(va_fr[fd])) + vd_im[idx] = JuMP.@expression(pm.model, vm_fr[fc]*sin(va_fr[fc])-vm_fr[fd]*sin(va_fr[fd])) + JuMP.@constraint(pm.model, vd_re[idx] == pol*tm_scale*tm[idx]*vm_to[tc]*cos(va_to[tc])) + JuMP.@constraint(pm.model, vd_im[idx] == pol*tm_scale*tm[idx]*vm_to[tc]*sin(va_to[tc])) end p_fr = var(pm, nw, :pt, f_idx) @@ -801,8 +801,8 @@ function constraint_mc_transformer_power_dy(pm::AbstractUnbalancedACPModel, nw:: # -Im(s/v) = -(q*cos(va)-p*sin(va))/|v| for (idx,(fc,tc)) in enumerate(zip(f_connections,t_connections)) # id = conj(s_to/v_to)./tm - id_re[idx] = JuMP.@NLexpression(pm.model, (p_to[tc]*cos(va_to[tc])+q_to[tc]*sin(va_to[tc]))/vm_to[tc]/(tm_scale*tm[idx])/pol) - id_im[idx] = JuMP.@NLexpression(pm.model, -(q_to[tc]*cos(va_to[tc])-p_to[tc]*sin(va_to[tc]))/vm_to[tc]/(tm_scale*tm[idx])/pol) + id_re[idx] = JuMP.@expression(pm.model, (p_to[tc]*cos(va_to[tc])+q_to[tc]*sin(va_to[tc]))/vm_to[tc]/(tm_scale*tm[idx])/pol) + id_im[idx] = JuMP.@expression(pm.model, -(q_to[tc]*cos(va_to[tc])-p_to[tc]*sin(va_to[tc]))/vm_to[tc]/(tm_scale*tm[idx])/pol) end for (idx, (fc,tc)) in enumerate(zip(f_connections,t_connections)) # rotate by nph-1 to get 'previous' phase @@ -811,11 +811,11 @@ function constraint_mc_transformer_power_dy(pm::AbstractUnbalancedACPModel, nw:: # s_fr = v_fr*conj(i_fr) # = v_fr*conj(id[q]-id[p]) # = v_fr*(id_re[q]-j*id_im[q]-id_re[p]+j*id_im[p]) - JuMP.@NLconstraint(pm.model, p_fr[fc] == + JuMP.@constraint(pm.model, p_fr[fc] == vm_fr[fc]*cos(va_fr[fc])*( id_re[jdx]-id_re[idx]) -vm_fr[fc]*sin(va_fr[fc])*(-id_im[jdx]+id_im[idx]) ) - JuMP.@NLconstraint(pm.model, q_fr[fc] == + JuMP.@constraint(pm.model, q_fr[fc] == vm_fr[fc]*cos(va_fr[fc])*(-id_im[jdx]+id_im[idx]) +vm_fr[fc]*sin(va_fr[fc])*( id_re[jdx]-id_re[idx]) ) @@ -845,25 +845,25 @@ function constraint_mc_bus_voltage_magnitude_vuf(pm::AbstractUnbalancedACPModel, a2re = real(a^2) a2im = imag(a^2) # real and imaginary components of U+ - vrepos = JuMP.@NLexpression(pm.model, + vrepos = JuMP.@expression(pm.model, (vm_a*cos(va_a) + are*vm_b*cos(va_b) - aim*vm_b*sin(va_b) + a2re*vm_c*cos(va_c) - a2im*vm_c*sin(va_c))/3 ) - vimpos = JuMP.@NLexpression(pm.model, + vimpos = JuMP.@expression(pm.model, (vm_a*sin(va_a) + are*vm_b*sin(va_b) + aim*vm_b*cos(va_b) + a2re*vm_c*sin(va_c) + a2im*vm_c*cos(va_c))/3 ) # square of magnitude of U+, |U+|^2 - vmpossqr = JuMP.@NLexpression(pm.model, vrepos^2+vimpos^2) + vmpossqr = JuMP.@expression(pm.model, vrepos^2+vimpos^2) # real and imaginary components of U- - vreneg = JuMP.@NLexpression(pm.model, + vreneg = JuMP.@expression(pm.model, (vm_a*cos(va_a) + a2re*vm_b*cos(va_b) - a2im*vm_b*sin(va_b) + are*vm_c*cos(va_c) - aim*vm_c*sin(va_c))/3 ) - vimneg = JuMP.@NLexpression(pm.model, + vimneg = JuMP.@expression(pm.model, (vm_a*sin(va_a) + a2re*vm_b*sin(va_b) + a2im*vm_b*cos(va_b) + are*vm_c*sin(va_c) + aim*vm_c*cos(va_c))/3 ) # square of magnitude of U-, |U-|^2 - vmnegsqr = JuMP.@NLexpression(pm.model, vreneg^2+vimneg^2) + vmnegsqr = JuMP.@expression(pm.model, vreneg^2+vimneg^2) # finally, apply constraint - JuMP.@NLconstraint(pm.model, vmnegsqr <= vufmax^2*vmpossqr) + JuMP.@constraint(pm.model, vmnegsqr <= vufmax^2*vmpossqr) # DEBUGGING: save references for post check #var(pm, nw_id_default, :vmpossqr)[bus_id] = vmpossqr #var(pm, nw_id_default, :vmnegsqr)[bus_id] = vmnegsqr @@ -892,16 +892,16 @@ function constraint_mc_bus_voltage_magnitude_negative_sequence(pm::AbstractUnbal a2re = real(a^2) a2im = imag(a^2) # real and imaginary components of U- - vreneg = JuMP.@NLexpression(pm.model, + vreneg = JuMP.@expression(pm.model, (vm_a*cos(va_a) + a2re*vm_b*cos(va_b) - a2im*vm_b*sin(va_b) + are*vm_c*cos(va_c) - aim*vm_c*sin(va_c))/3 ) - vimneg = JuMP.@NLexpression(pm.model, + vimneg = JuMP.@expression(pm.model, (vm_a*sin(va_a) + a2re*vm_b*sin(va_b) + a2im*vm_b*cos(va_b) + are*vm_c*sin(va_c) + aim*vm_c*cos(va_c))/3 ) # square of magnitude of U-, |U-|^2 - vmnegsqr = JuMP.@NLexpression(pm.model, vreneg^2+vimneg^2) + vmnegsqr = JuMP.@expression(pm.model, vreneg^2+vimneg^2) # finally, apply constraint - JuMP.@NLconstraint(pm.model, vmnegsqr <= vmnegmax^2) + JuMP.@constraint(pm.model, vmnegsqr <= vmnegmax^2) end @@ -927,16 +927,16 @@ function constraint_mc_bus_voltage_magnitude_positive_sequence(pm::AbstractUnbal a2re = real(a^2) a2im = imag(a^2) # real and imaginary components of U+ - vrepos = JuMP.@NLexpression(pm.model, + vrepos = JuMP.@expression(pm.model, (vm_a*cos(va_a) + are*vm_b*cos(va_b) - aim*vm_b*sin(va_b) + a2re*vm_c*cos(va_c) - a2im*vm_c*sin(va_c))/3 ) - vimpos = JuMP.@NLexpression(pm.model, + vimpos = JuMP.@expression(pm.model, (vm_a*sin(va_a) + are*vm_b*sin(va_b) + aim*vm_b*cos(va_b) + a2re*vm_c*sin(va_c) + a2im*vm_c*cos(va_c))/3 ) # square of magnitude of U+, |U+|^2 - vmpossqr = JuMP.@NLexpression(pm.model, vrepos^2+vimpos^2) + vmpossqr = JuMP.@expression(pm.model, vrepos^2+vimpos^2) # finally, apply constraint - JuMP.@NLconstraint(pm.model, vmpossqr <= vmposmax^2) + JuMP.@constraint(pm.model, vmpossqr <= vmposmax^2) end @@ -956,16 +956,16 @@ function constraint_mc_bus_voltage_magnitude_zero_sequence(pm::AbstractUnbalance (vm_a, vm_b, vm_c) = [var(pm, nw, :vm, bus_id)[i] for i in 1:3] (va_a, va_b, va_c) = [var(pm, nw, :va, bus_id)[i] for i in 1:3] # real and imaginary components of U+ - vrezero = JuMP.@NLexpression(pm.model, + vrezero = JuMP.@expression(pm.model, (vm_a*cos(va_a) + vm_b*cos(va_b) + vm_c*cos(va_c))/3 ) - vimzero = JuMP.@NLexpression(pm.model, + vimzero = JuMP.@expression(pm.model, (vm_a*sin(va_a) + vm_b*sin(va_b) + vm_c*sin(va_c))/3 ) # square of magnitude of U+, |U+|^2 - vmzerosqr = JuMP.@NLexpression(pm.model, vrezero^2+vimzero^2) + vmzerosqr = JuMP.@expression(pm.model, vrezero^2+vimzero^2) # finally, apply constraint - JuMP.@NLconstraint(pm.model, vmzerosqr <= vmzeromax^2) + JuMP.@constraint(pm.model, vmzerosqr <= vmzeromax^2) end @@ -984,8 +984,8 @@ function constraint_mc_load_current_delta(pm::AbstractUnbalancedACPModel, nw::In vm_a, vm_b, vm_c = var(pm, nw, :vm, load_bus_id) va_a, va_b, va_c = var(pm, nw, :va, load_bus_id) # v_xy = v_x - v_y - vre_xy(vm_x, va_x, vm_y, va_y) = JuMP.@NLexpression(pm.model, vm_x*cos(va_x)-vm_y*cos(va_y)) - vim_xy(vm_x, va_x, vm_y, va_y) = JuMP.@NLexpression(pm.model, vm_x*sin(va_x)-vm_y*sin(va_y)) + vre_xy(vm_x, va_x, vm_y, va_y) = JuMP.@expression(pm.model, vm_x*cos(va_x)-vm_y*cos(va_y)) + vim_xy(vm_x, va_x, vm_y, va_y) = JuMP.@expression(pm.model, vm_x*sin(va_x)-vm_y*sin(va_y)) vre_ab = vre_xy(vm_a, va_a, vm_b, va_b) vim_ab = vim_xy(vm_a, va_a, vm_b, va_b) vre_bc = vre_xy(vm_b, va_b, vm_c, va_c) @@ -993,8 +993,8 @@ function constraint_mc_load_current_delta(pm::AbstractUnbalancedACPModel, nw::In vre_ca = vre_xy(vm_c, va_c, vm_a, va_a) vim_ca = vim_xy(vm_c, va_c, vm_a, va_a) # i_xy = conj(s_xy/v_xy) - ire_xy(cp_xy, cq_xy, vre_xy, vim_xy) = JuMP.@NLexpression(pm.model, 1/sqrt(vre_xy^2+vim_xy^2)*(cp_xy*vre_xy+cq_xy*vim_xy)) - iim_xy(cp_xy, cq_xy, vre_xy, vim_xy) = JuMP.@NLexpression(pm.model, 1/sqrt(vre_xy^2+vim_xy^2)*(cp_xy*vim_xy-cq_xy*vre_xy)) + ire_xy(cp_xy, cq_xy, vre_xy, vim_xy) = JuMP.@expression(pm.model, 1/sqrt(vre_xy^2+vim_xy^2)*(cp_xy*vre_xy+cq_xy*vim_xy)) + iim_xy(cp_xy, cq_xy, vre_xy, vim_xy) = JuMP.@expression(pm.model, 1/sqrt(vre_xy^2+vim_xy^2)*(cp_xy*vim_xy-cq_xy*vre_xy)) ire_ab = ire_xy(cp_ab, cq_ab, vre_ab, vim_ab) iim_ab = iim_xy(cp_ab, cq_ab, vre_ab, vim_ab) ire_bc = ire_xy(cp_bc, cq_bc, vre_bc, vim_bc) @@ -1004,8 +1004,8 @@ function constraint_mc_load_current_delta(pm::AbstractUnbalancedACPModel, nw::In # s_x = v_x*conj(i_xy-i_zx) # p_x = vm_x*cos(va_x)*(ire_xy-ire_zx) + vm_x*sin(va_x)*(iim_xy-iim_zx) # q_x = vm_x*sin(va_x)*(ire_xy-ire_zx) - vm_x*cos(va_x)*(iim_xy-iim_zx) - p_x(vm_x, va_x, ire_xy, iim_xy, ire_zx, iim_zx) = JuMP.@NLexpression(pm.model, vm_x*cos(va_x)*(ire_xy-ire_zx) + vm_x*sin(va_x)*(iim_xy-iim_zx)) - q_x(vm_x, va_x, ire_xy, iim_xy, ire_zx, iim_zx) = JuMP.@NLexpression(pm.model, vm_x*sin(va_x)*(ire_xy-ire_zx) - vm_x*cos(va_x)*(iim_xy-iim_zx)) + p_x(vm_x, va_x, ire_xy, iim_xy, ire_zx, iim_zx) = JuMP.@expression(pm.model, vm_x*cos(va_x)*(ire_xy-ire_zx) + vm_x*sin(va_x)*(iim_xy-iim_zx)) + q_x(vm_x, va_x, ire_xy, iim_xy, ire_zx, iim_zx) = JuMP.@expression(pm.model, vm_x*sin(va_x)*(ire_xy-ire_zx) - vm_x*cos(va_x)*(iim_xy-iim_zx)) # s_x = s_x,ref var(pm, nw, :pd_bus)[load_id] = [ p_x(vm_a, va_a, ire_ab, iim_ab, ire_ca, iim_ca), @@ -1023,20 +1023,20 @@ function constraint_mc_bus_voltage_magnitude_ll(pm::AbstractUnbalancedACPModel, # 3 conductors asserted in template already vm_ln = [var(pm, nw, :vm, bus_id)[i] for i in 1:3] va_ln = [var(pm, nw, :va, bus_id)[i] for i in 1:3] - vr_ll = JuMP.@NLexpression(pm.model, [i in 1:3], + vr_ll = JuMP.@expression(pm.model, [i in 1:3], vm_ln[i]*cos(va_ln[i]) - vm_ln[i%3+1]*cos(va_ln[i%3+1]) ) - vi_ll = JuMP.@NLexpression(pm.model, [i in 1:3], + vi_ll = JuMP.@expression(pm.model, [i in 1:3], vm_ln[i]*sin(va_ln[i]) - vm_ln[i%3+1]*sin(va_ln[i%3+1]) ) for c in 1:3 # factor of 3 is needed because vm_ll bounds are with respect to the # LL base, not the LN base if vm_ll_min[c] > 0 - JuMP.@NLconstraint(pm.model, vr_ll[c]^2+vi_ll[c]^2 >= vm_ll_min[c]^2*3) + JuMP.@constraint(pm.model, vr_ll[c]^2+vi_ll[c]^2 >= vm_ll_min[c]^2*3) end if vm_ll_max[c] < Inf - JuMP.@NLconstraint(pm.model, vr_ll[c]^2+vi_ll[c]^2 <= vm_ll_max[c]^2*3) + JuMP.@constraint(pm.model, vr_ll[c]^2+vi_ll[c]^2 <= vm_ll_max[c]^2*3) end end end @@ -1083,21 +1083,21 @@ function constraint_mc_load_power_wye(pm::AbstractUnbalancedACPModel, nw::Int, i pd_bus = a qd_bus = b else - pd_bus = Vector{JuMP.NonlinearExpression}([]) - qd_bus = Vector{JuMP.NonlinearExpression}([]) + pd_bus = JuMP.NonlinearExpr[] + qd_bus = JuMP.NonlinearExpr[] for (idx, c) in enumerate(connections) - crd = JuMP.@NLexpression(pm.model, + crd = JuMP.@expression(pm.model, a[idx]*vm[c]*cos(va[c])*(vm[c]^2)^(alpha[idx]/2-1) +b[idx]*vm[c]*sin(va[c])*(vm[c]^2)^( beta[idx]/2-1) ) - cid = JuMP.@NLexpression(pm.model, + cid = JuMP.@expression(pm.model, a[idx]*vm[c]*sin(va[c])*(vm[c]^2)^(alpha[idx]/2-1) -b[idx]*vm[c]*cos(va[c])*(vm[c]^2)^( beta[idx]/2-1) ) - push!(pd_bus, JuMP.@NLexpression(pm.model, vm[c]*cos(va[c])*crd+vm[c]*sin(va[c])*cid)) - push!(qd_bus, JuMP.@NLexpression(pm.model, -vm[c]*cos(va[c])*cid+vm[c]*sin(va[c])*crd)) + push!(pd_bus, JuMP.@expression(pm.model, vm[c]*cos(va[c])*crd+vm[c]*sin(va[c])*cid)) + push!(qd_bus, JuMP.@expression(pm.model, -vm[c]*cos(va[c])*cid+vm[c]*sin(va[c])*crd)) end end @@ -1111,12 +1111,12 @@ function constraint_mc_load_power_wye(pm::AbstractUnbalancedACPModel, nw::Int, i sol(pm, nw, :load, id)[:pd_bus] = pd_bus sol(pm, nw, :load, id)[:qd_bus] = qd_bus - pd = Vector{JuMP.NonlinearExpression}([]) - qd = Vector{JuMP.NonlinearExpression}([]) + pd = JuMP.NonlinearExpr[] + qd = JuMP.NonlinearExpr[] for (idx,c) in enumerate(connections) - push!(pd, JuMP.@NLexpression(pm.model, a[idx]*vm[c]^alpha[idx] )) - push!(qd, JuMP.@NLexpression(pm.model, b[idx]*vm[c]^beta[idx] )) + push!(pd, JuMP.@expression(pm.model, a[idx]*vm[c]^alpha[idx] )) + push!(qd, JuMP.@expression(pm.model, b[idx]*vm[c]^beta[idx] )) end sol(pm, nw, :load, id)[:pd] = JuMP.Containers.DenseAxisArray(pd, connections) sol(pm, nw, :load, id)[:qd] = JuMP.Containers.DenseAxisArray(qd, connections) @@ -1139,18 +1139,18 @@ function constraint_mc_load_power_delta(pm::AbstractUnbalancedACPModel, nw::Int, vrd = Dict() vid = Dict() for (idx, c) in enumerate(connections) - vrd[c] = JuMP.@NLexpression(pm.model, vm[c]*cos(va[c])-vm[next[c]]*cos(va[next[c]])) - vid[c] = JuMP.@NLexpression(pm.model, vm[c]*sin(va[c])-vm[next[c]]*sin(va[next[c]])) + vrd[c] = JuMP.@expression(pm.model, vm[c]*cos(va[c])-vm[next[c]]*cos(va[next[c]])) + vid[c] = JuMP.@expression(pm.model, vm[c]*sin(va[c])-vm[next[c]]*sin(va[next[c]])) end crd = Dict() cid = Dict() for (idx, c) in enumerate(connections) - crd[c] = JuMP.@NLexpression(pm.model, + crd[c] = JuMP.@expression(pm.model, a[idx]*vrd[c]*(vrd[c]^2+vid[c]^2)^(alpha[idx]/2-1) +b[idx]*vid[c]*(vrd[c]^2+vid[c]^2)^(beta[idx]/2 -1) ) - cid[c] = JuMP.@NLexpression(pm.model, + cid[c] = JuMP.@expression(pm.model, a[idx]*vid[c]*(vrd[c]^2+vid[c]^2)^(alpha[idx]/2-1) -b[idx]*vrd[c]*(vrd[c]^2+vid[c]^2)^(beta[idx]/2 -1) ) @@ -1160,19 +1160,19 @@ function constraint_mc_load_power_delta(pm::AbstractUnbalancedACPModel, nw::Int, cid_bus = Dict() for (idx, c) in enumerate(conn_bus) if is_triplex - crd_bus[c] = JuMP.@NLexpression(pm.model, (-1.0)^(c-1)*crd[1]) - cid_bus[c] = JuMP.@NLexpression(pm.model, (-1.0)^(c-1)*cid[1]) + crd_bus[c] = JuMP.@expression(pm.model, (-1.0)^(c-1)*crd[1]) + cid_bus[c] = JuMP.@expression(pm.model, (-1.0)^(c-1)*cid[1]) else - crd_bus[c] = JuMP.@NLexpression(pm.model, crd[c]-crd[prev[c]]) - cid_bus[c] = JuMP.@NLexpression(pm.model, cid[c]-cid[prev[c]]) + crd_bus[c] = JuMP.@expression(pm.model, crd[c]-crd[prev[c]]) + cid_bus[c] = JuMP.@expression(pm.model, cid[c]-cid[prev[c]]) end end - pd_bus = Vector{JuMP.NonlinearExpression}([]) - qd_bus = Vector{JuMP.NonlinearExpression}([]) + pd_bus = JuMP.NonlinearExpr[] + qd_bus = JuMP.NonlinearExpr[] for (idx,c) in enumerate(conn_bus) - push!(pd_bus, JuMP.@NLexpression(pm.model, vm[c]*cos(va[c])*crd_bus[c]+vm[c]*sin(va[c])*cid_bus[c])) - push!(qd_bus, JuMP.@NLexpression(pm.model, -vm[c]*cos(va[c])*cid_bus[c]+vm[c]*sin(va[c])*crd_bus[c])) + push!(pd_bus, JuMP.@expression(pm.model, vm[c]*cos(va[c])*crd_bus[c]+vm[c]*sin(va[c])*cid_bus[c])) + push!(qd_bus, JuMP.@expression(pm.model, -vm[c]*cos(va[c])*cid_bus[c]+vm[c]*sin(va[c])*crd_bus[c])) end pd_bus = JuMP.Containers.DenseAxisArray(pd_bus, conn_bus) @@ -1188,8 +1188,8 @@ function constraint_mc_load_power_delta(pm::AbstractUnbalancedACPModel, nw::Int, pd = [] qd = [] for (idx,c) in enumerate(connections) - push!(pd, JuMP.@NLexpression(pm.model, a[idx]*(vrd[c]^2+vid[c]^2)^(alpha[idx]/2) )) - push!(qd, JuMP.@NLexpression(pm.model, b[idx]*(vrd[c]^2+vid[c]^2)^(beta[idx]/2) )) + push!(pd, JuMP.@expression(pm.model, a[idx]*(vrd[c]^2+vid[c]^2)^(alpha[idx]/2) )) + push!(qd, JuMP.@expression(pm.model, b[idx]*(vrd[c]^2+vid[c]^2)^(beta[idx]/2) )) end sol(pm, nw, :load, id)[:pd] = pd sol(pm, nw, :load, id)[:qd] = qd @@ -1214,34 +1214,34 @@ function constraint_mc_generator_power_delta(pm::AbstractUnbalancedACPModel, nw: vrg = Dict() vig = Dict() for c in connections - vrg[c] = JuMP.@NLexpression(pm.model, vm[c]*cos(va[c])-vm[next[c]]*cos(va[next[c]])) - vig[c] = JuMP.@NLexpression(pm.model, vm[c]*sin(va[c])-vm[next[c]]*sin(va[next[c]])) + vrg[c] = JuMP.@expression(pm.model, vm[c]*cos(va[c])-vm[next[c]]*cos(va[next[c]])) + vig[c] = JuMP.@expression(pm.model, vm[c]*sin(va[c])-vm[next[c]]*sin(va[next[c]])) end crg = Dict() cig = Dict() for c in connections - crg[c] = JuMP.@NLexpression(pm.model, (pg[c]*vrg[c]+qg[c]*vig[c])/(vrg[c]^2+vig[c]^2) ) - cig[c] = JuMP.@NLexpression(pm.model, (pg[c]*vig[c]-qg[c]*vrg[c])/(vrg[c]^2+vig[c]^2) ) + crg[c] = JuMP.@expression(pm.model, (pg[c]*vrg[c]+qg[c]*vig[c])/(vrg[c]^2+vig[c]^2) ) + cig[c] = JuMP.@expression(pm.model, (pg[c]*vig[c]-qg[c]*vrg[c])/(vrg[c]^2+vig[c]^2) ) end crg_bus = Dict() cig_bus = Dict() for c in conn_bus if is_triplex - crg_bus[c] = JuMP.@NLexpression(pm.model, (-1.0)^(c-1)*crg[1]) - cig_bus[c] = JuMP.@NLexpression(pm.model, (-1.0)^(c-1)*cig[1]) + crg_bus[c] = JuMP.@expression(pm.model, (-1.0)^(c-1)*crg[1]) + cig_bus[c] = JuMP.@expression(pm.model, (-1.0)^(c-1)*cig[1]) else - crg_bus[c] = JuMP.@NLexpression(pm.model, crg[c]-crg[prev[c]]) - cig_bus[c] = JuMP.@NLexpression(pm.model, cig[c]-cig[prev[c]]) + crg_bus[c] = JuMP.@expression(pm.model, crg[c]-crg[prev[c]]) + cig_bus[c] = JuMP.@expression(pm.model, cig[c]-cig[prev[c]]) end end - pg_bus = Vector{JuMP.NonlinearExpression}([]) - qg_bus = Vector{JuMP.NonlinearExpression}([]) + pg_bus = JuMP.NonlinearExpr[] + qg_bus = JuMP.NonlinearExpr[] for c in conn_bus - push!(pg_bus, JuMP.@NLexpression(pm.model, vm[c]*cos(va[c])*crg_bus[c]+vm[c]*sin(va[c])*cig_bus[c])) - push!(qg_bus, JuMP.@NLexpression(pm.model, -vm[c]*cos(va[c])*cig_bus[c]+vm[c]*sin(va[c])*crg_bus[c])) + push!(pg_bus, JuMP.@expression(pm.model, vm[c]*cos(va[c])*crg_bus[c]+vm[c]*sin(va[c])*cig_bus[c])) + push!(qg_bus, JuMP.@expression(pm.model, -vm[c]*cos(va[c])*cig_bus[c]+vm[c]*sin(va[c])*crg_bus[c])) end pg_bus = JuMP.Containers.DenseAxisArray(pg_bus, conn_bus) qg_bus = JuMP.Containers.DenseAxisArray(qg_bus, conn_bus) @@ -1265,13 +1265,13 @@ function constraint_mc_storage_losses(pm::AbstractUnbalancedACPModel, n::Int, i: sd = var(pm, n, :sd, i) qsc = var(pm, n, :qsc, i) - JuMP.@NLconstraint(pm.model, + JuMP.@constraint(pm.model, sum(ps[c] for c in connections) + (sd - sc) == p_loss + r * sum((ps[c]^2 + qs[c]^2)/vm[c]^2 for c in connections) ) - JuMP.@NLconstraint(pm.model, + JuMP.@constraint(pm.model, sum(qs[c] for c in connections) == qsc + q_loss + x * sum((ps[c]^2 + qs[c]^2)/vm[c]^2 for c in connections) diff --git a/src/form/acr.jl b/src/form/acr.jl index fccc68ebe..3e55c9c01 100644 --- a/src/form/acr.jl +++ b/src/form/acr.jl @@ -463,7 +463,7 @@ function constraint_mc_power_balance(pm::AbstractUnbalancedACRModel, nw::Int, i: # pd/qd can be NLexpressions, so cannot be vectorized for (idx, t) in ungrounded_terminals - cp = @smart_constraint(pm.model, [p, q, pg, qg, ps, qs, psw, qsw, pt, qt, pd, qd, vr, vi], + cp = JuMP.@constraint(pm.model, sum( p[arc][t] for (arc, conns) in bus_arcs if t in conns) + sum(psw[arc][t] for (arc, conns) in bus_arcs_sw if t in conns) + sum( pt[arc][t] for (arc, conns) in bus_arcs_trans if t in conns) @@ -477,7 +477,7 @@ function constraint_mc_power_balance(pm::AbstractUnbalancedACRModel, nw::Int, i: ) push!(cstr_p, cp) - cq = @smart_constraint(pm.model, [p, q, pg, qg, ps, qs, psw, qsw, pt, qt, pd, qd, vr, vi], + cq = JuMP.@constraint(pm.model, sum( q[arc][t] for (arc, conns) in bus_arcs if t in conns) + sum(qsw[arc][t] for (arc, conns) in bus_arcs_sw if t in conns) + sum( qt[arc][t] for (arc, conns) in bus_arcs_trans if t in conns) @@ -538,14 +538,14 @@ function constraint_mc_power_balance_capc(pm::AbstractUnbalancedACRModel, nw::In # calculate Gs, Bs ncnds = length(terminals) Gt = fill(0.0, ncnds, ncnds) - Bt = convert(Matrix{JuMP.NonlinearExpression}, JuMP.@NLexpression(pm.model, [idx=1:ncnds, jdx=1:ncnds], 0.0)) + Bt = Any[0.0 for idx in 1:ncnds, jdx in 1:ncnds] for (val, connections) in bus_shunts shunt = ref(pm,nw,:shunt,val) for (idx,c) in enumerate(connections) cap_state = haskey(shunt,"controls") ? var(pm, nw, :capacitor_state, val)[c] : 1.0 for (jdx,d) in enumerate(connections) Gt[findfirst(isequal(c), terminals),findfirst(isequal(d), terminals)] += shunt["gs"][idx,jdx] - Bt[findfirst(isequal(c), terminals),findfirst(isequal(d), terminals)] = JuMP.@NLexpression(pm.model, Bt[findfirst(isequal(c), terminals),findfirst(isequal(d), terminals)] + shunt["bs"][idx,jdx]*cap_state) + Bt[findfirst(isequal(c), terminals),findfirst(isequal(d), terminals)] = JuMP.@expression(pm.model, Bt[findfirst(isequal(c), terminals),findfirst(isequal(d), terminals)] + shunt["bs"][idx,jdx]*cap_state) end end end @@ -557,7 +557,7 @@ function constraint_mc_power_balance_capc(pm::AbstractUnbalancedACRModel, nw::In # pd/qd can be NLexpressions, so cannot be vectorized for (idx, t) in ungrounded_terminals - cp = JuMP.@NLconstraint(pm.model, + cp = JuMP.@constraint(pm.model, sum( p[arc][t] for (arc, conns) in bus_arcs if t in conns) + sum(psw[arc][t] for (arc, conns) in bus_arcs_sw if t in conns) + sum( pt[arc][t] for (arc, conns) in bus_arcs_trans if t in conns) @@ -571,7 +571,7 @@ function constraint_mc_power_balance_capc(pm::AbstractUnbalancedACRModel, nw::In ) push!(cstr_p, cp) - cq = JuMP.@NLconstraint(pm.model, + cq = JuMP.@constraint(pm.model, sum( q[arc][t] for (arc, conns) in bus_arcs if t in conns) + sum(qsw[arc][t] for (arc, conns) in bus_arcs_sw if t in conns) + sum( qt[arc][t] for (arc, conns) in bus_arcs_trans if t in conns) @@ -684,7 +684,7 @@ function constraint_mc_power_balance_shed(pm::AbstractUnbalancedACRModel, nw::In # pd/qd can be NLexpressions, so cannot be vectorized for (idx, t) in ungrounded_terminals - cp = @smart_constraint(pm.model, [p, pg, ps, psw, pt], + cp = JuMP.@constraint(pm.model, sum( p[a][t] for (a, conns) in bus_arcs if t in conns) + sum(psw[a][t] for (a, conns) in bus_arcs_sw if t in conns) + sum( pt[a][t] for (a, conns) in bus_arcs_trans if t in conns) @@ -698,7 +698,7 @@ function constraint_mc_power_balance_shed(pm::AbstractUnbalancedACRModel, nw::In ) push!(cstr_p, cp) - cq = @smart_constraint(pm.model, [q, qg, qs, qsw, qt], + cq = JuMP.@constraint(pm.model, sum( q[a][t] for (a, conns) in bus_arcs if t in conns) + sum(qsw[a][t] for (a, conns) in bus_arcs_sw if t in conns) + sum( qt[a][t] for (a, conns) in bus_arcs_trans if t in conns) @@ -780,15 +780,15 @@ function constraint_mc_load_power_wye(pm::AbstractUnbalancedACRModel, nw::Int, i pd_bus = a qd_bus = b else - pd_bus = Vector{JuMP.NonlinearExpression}([]) - qd_bus = Vector{JuMP.NonlinearExpression}([]) + pd_bus = JuMP.NonlinearExpr[] + qd_bus = JuMP.NonlinearExpr[] for (idx,c) in enumerate(connections) - crd = JuMP.@NLexpression(pm.model, a[idx]*vr[c]*(vr[c]^2+vi[c]^2)^(alpha[idx]/2-1)+b[idx]*vi[c]*(vr[c]^2+vi[c]^2)^(beta[idx]/2 -1)) - cid = JuMP.@NLexpression(pm.model, a[idx]*vi[c]*(vr[c]^2+vi[c]^2)^(alpha[idx]/2-1)-b[idx]*vr[c]*(vr[c]^2+vi[c]^2)^(beta[idx]/2 -1)) + crd = JuMP.@expression(pm.model, a[idx]*vr[c]*(vr[c]^2+vi[c]^2)^(alpha[idx]/2-1)+b[idx]*vi[c]*(vr[c]^2+vi[c]^2)^(beta[idx]/2 -1)) + cid = JuMP.@expression(pm.model, a[idx]*vi[c]*(vr[c]^2+vi[c]^2)^(alpha[idx]/2-1)-b[idx]*vr[c]*(vr[c]^2+vi[c]^2)^(beta[idx]/2 -1)) - push!(pd_bus, JuMP.@NLexpression(pm.model, vr[c]*crd+vi[c]*cid)) - push!(qd_bus, JuMP.@NLexpression(pm.model, -vr[c]*cid+vi[c]*crd)) + push!(pd_bus, JuMP.@expression(pm.model, vr[c]*crd+vi[c]*cid)) + push!(qd_bus, JuMP.@expression(pm.model, -vr[c]*cid+vi[c]*crd)) end end @@ -802,12 +802,12 @@ function constraint_mc_load_power_wye(pm::AbstractUnbalancedACRModel, nw::Int, i sol(pm, nw, :load, id)[:pd_bus] = pd_bus sol(pm, nw, :load, id)[:qd_bus] = qd_bus - pd = Vector{JuMP.NonlinearExpression}([]) - qd = Vector{JuMP.NonlinearExpression}([]) + pd = JuMP.NonlinearExpr[] + qd = JuMP.NonlinearExpr[] for (idx,c) in enumerate(connections) - push!(pd, JuMP.@NLexpression(pm.model, a[idx]*(vr[c]^2+vi[c]^2)^(alpha[idx]/2) )) - push!(qd, JuMP.@NLexpression(pm.model, b[idx]*(vr[c]^2+vi[c]^2)^(beta[idx]/2) )) + push!(pd, JuMP.@expression(pm.model, a[idx]*(vr[c]^2+vi[c]^2)^(alpha[idx]/2) )) + push!(qd, JuMP.@expression(pm.model, b[idx]*(vr[c]^2+vi[c]^2)^(beta[idx]/2) )) end sol(pm, nw, :load, id)[:pd] = JuMP.Containers.DenseAxisArray(pd, connections) sol(pm, nw, :load, id)[:qd] = JuMP.Containers.DenseAxisArray(qd, connections) @@ -830,34 +830,34 @@ function constraint_mc_load_power_delta(pm::AbstractUnbalancedACRModel, nw::Int, vrd = Dict() vid = Dict() for (idx, c) in enumerate(connections) - vrd[c] = JuMP.@NLexpression(pm.model, vr[c]-vr[next[c]]) - vid[c] = JuMP.@NLexpression(pm.model, vi[c]-vi[next[c]]) + vrd[c] = JuMP.@expression(pm.model, vr[c]-vr[next[c]]) + vid[c] = JuMP.@expression(pm.model, vi[c]-vi[next[c]]) end crd = Dict() cid = Dict() for (idx, c) in enumerate(connections) - crd[c] = JuMP.@NLexpression(pm.model, a[idx]*vrd[c]*(vrd[c]^2+vid[c]^2)^(alpha[idx]/2-1)+b[idx]*vid[c]*(vrd[c]^2+vid[c]^2)^(beta[idx]/2 -1)) - cid[c] = JuMP.@NLexpression(pm.model, a[idx]*vid[c]*(vrd[c]^2+vid[c]^2)^(alpha[idx]/2-1)-b[idx]*vrd[c]*(vrd[c]^2+vid[c]^2)^(beta[idx]/2 -1)) + crd[c] = JuMP.@expression(pm.model, a[idx]*vrd[c]*(vrd[c]^2+vid[c]^2)^(alpha[idx]/2-1)+b[idx]*vid[c]*(vrd[c]^2+vid[c]^2)^(beta[idx]/2 -1)) + cid[c] = JuMP.@expression(pm.model, a[idx]*vid[c]*(vrd[c]^2+vid[c]^2)^(alpha[idx]/2-1)-b[idx]*vrd[c]*(vrd[c]^2+vid[c]^2)^(beta[idx]/2 -1)) end crd_bus = Dict() cid_bus = Dict() for (idx, c) in enumerate(conn_bus) if is_triplex - crd_bus[c] = JuMP.@NLexpression(pm.model, (-1.0)^(c-1)*crd[1]) - cid_bus[c] = JuMP.@NLexpression(pm.model, (-1.0)^(c-1)*cid[1]) + crd_bus[c] = JuMP.@expression(pm.model, (-1.0)^(c-1)*crd[1]) + cid_bus[c] = JuMP.@expression(pm.model, (-1.0)^(c-1)*cid[1]) else - crd_bus[c] = JuMP.@NLexpression(pm.model, crd[c]-crd[prev[c]]) - cid_bus[c] = JuMP.@NLexpression(pm.model, cid[c]-cid[prev[c]]) + crd_bus[c] = JuMP.@expression(pm.model, crd[c]-crd[prev[c]]) + cid_bus[c] = JuMP.@expression(pm.model, cid[c]-cid[prev[c]]) end end - pd_bus = Vector{JuMP.NonlinearExpression}([]) - qd_bus = Vector{JuMP.NonlinearExpression}([]) + pd_bus = JuMP.NonlinearExpr[] + qd_bus = JuMP.NonlinearExpr[] for (idx,c) in enumerate(conn_bus) - push!(pd_bus, JuMP.@NLexpression(pm.model, vr[c]*crd_bus[c]+vi[c]*cid_bus[c])) - push!(qd_bus, JuMP.@NLexpression(pm.model, -vr[c]*cid_bus[c]+vi[c]*crd_bus[c])) + push!(pd_bus, JuMP.@expression(pm.model, vr[c]*crd_bus[c]+vi[c]*cid_bus[c])) + push!(qd_bus, JuMP.@expression(pm.model, -vr[c]*cid_bus[c]+vi[c]*crd_bus[c])) end pd_bus = JuMP.Containers.DenseAxisArray(pd_bus, conn_bus) @@ -870,11 +870,11 @@ function constraint_mc_load_power_delta(pm::AbstractUnbalancedACRModel, nw::Int, sol(pm, nw, :load, id)[:pd_bus] = pd_bus sol(pm, nw, :load, id)[:qd_bus] = qd_bus - pd = Vector{JuMP.NonlinearExpression}([]) - qd = Vector{JuMP.NonlinearExpression}([]) + pd = JuMP.NonlinearExpr[] + qd = JuMP.NonlinearExpr[] for (idx,c) in enumerate(connections) - push!(pd, JuMP.@NLexpression(pm.model, a[idx]*(vrd[c]^2+vid[c]^2)^(alpha[idx]/2) )) - push!(qd, JuMP.@NLexpression(pm.model, b[idx]*(vrd[c]^2+vid[c]^2)^(beta[idx]/2) )) + push!(pd, JuMP.@expression(pm.model, a[idx]*(vrd[c]^2+vid[c]^2)^(alpha[idx]/2) )) + push!(qd, JuMP.@expression(pm.model, b[idx]*(vrd[c]^2+vid[c]^2)^(beta[idx]/2) )) end sol(pm, nw, :load, id)[:pd] = JuMP.Containers.DenseAxisArray(pd, connections) sol(pm, nw, :load, id)[:qd] = JuMP.Containers.DenseAxisArray(qd, connections) @@ -908,34 +908,34 @@ function constraint_mc_generator_power_delta(pm::AbstractUnbalancedACRModel, nw: vrg = Dict() vig = Dict() for c in connections - vrg[c] = JuMP.@NLexpression(pm.model, vr[c]-vr[next[c]]) - vig[c] = JuMP.@NLexpression(pm.model, vi[c]-vi[next[c]]) + vrg[c] = JuMP.@expression(pm.model, vr[c]-vr[next[c]]) + vig[c] = JuMP.@expression(pm.model, vi[c]-vi[next[c]]) end crg = Dict() cig = Dict() for c in connections - crg[c] = JuMP.@NLexpression(pm.model, (pg[c]*vrg[c]+qg[c]*vig[c])/(vrg[c]^2+vig[c]^2) ) - cig[c] = JuMP.@NLexpression(pm.model, (pg[c]*vig[c]-qg[c]*vrg[c])/(vrg[c]^2+vig[c]^2) ) + crg[c] = JuMP.@expression(pm.model, (pg[c]*vrg[c]+qg[c]*vig[c])/(vrg[c]^2+vig[c]^2) ) + cig[c] = JuMP.@expression(pm.model, (pg[c]*vig[c]-qg[c]*vrg[c])/(vrg[c]^2+vig[c]^2) ) end crg_bus = Dict() cig_bus = Dict() for c in conn_bus if is_triplex - crg_bus[c] = JuMP.@NLexpression(pm.model, (-1.0)^(c-1)*crg[1]) - cig_bus[c] = JuMP.@NLexpression(pm.model, (-1.0)^(c-1)*cig[1]) + crg_bus[c] = JuMP.@expression(pm.model, (-1.0)^(c-1)*crg[1]) + cig_bus[c] = JuMP.@expression(pm.model, (-1.0)^(c-1)*cig[1]) else - crg_bus[c] = JuMP.@NLexpression(pm.model, crg[c]-crg[prev[c]]) - cig_bus[c] = JuMP.@NLexpression(pm.model, cig[c]-cig[prev[c]]) + crg_bus[c] = JuMP.@expression(pm.model, crg[c]-crg[prev[c]]) + cig_bus[c] = JuMP.@expression(pm.model, cig[c]-cig[prev[c]]) end end - pg_bus = Vector{JuMP.NonlinearExpression}([]) - qg_bus = Vector{JuMP.NonlinearExpression}([]) + pg_bus = JuMP.NonlinearExpr[] + qg_bus = JuMP.NonlinearExpr[] for (idx,c) in enumerate(conn_bus) - push!(pg_bus, JuMP.@NLexpression(pm.model, vr[c]*crg_bus[c]+vi[c]*cig_bus[c])) - push!(qg_bus, JuMP.@NLexpression(pm.model, -vr[c]*cig_bus[c]+vi[c]*crg_bus[c])) + push!(pg_bus, JuMP.@expression(pm.model, vr[c]*crg_bus[c]+vi[c]*cig_bus[c])) + push!(qg_bus, JuMP.@expression(pm.model, -vr[c]*cig_bus[c]+vi[c]*crg_bus[c])) end pg_bus = JuMP.Containers.DenseAxisArray(pg_bus, conn_bus) @@ -985,16 +985,16 @@ function constraint_mc_transformer_power_yy(pm::AbstractUnbalancedACRModel, nw:: x = transformer["controls"]["x"][idx] # (cr+jci) = (p-jq)/(vr-j⋅vi) - cr = JuMP.@NLexpression(pm.model, ( p_to[idx]*vr_to[tc] + q_to[idx]*vi_to[tc])/(vr_to[tc]^2+vi_to[tc]^2)) - ci = JuMP.@NLexpression(pm.model, (-q_to[idx]*vr_to[tc] + p_to[idx]*vi_to[tc])/(vr_to[tc]^2+vi_to[tc]^2)) + cr = JuMP.@expression(pm.model, ( p_to[idx]*vr_to[tc] + q_to[idx]*vi_to[tc])/(vr_to[tc]^2+vi_to[tc]^2)) + ci = JuMP.@expression(pm.model, (-q_to[idx]*vr_to[tc] + p_to[idx]*vi_to[tc])/(vr_to[tc]^2+vi_to[tc]^2)) # v_drop = (cr+jci)⋅(r+jx) - vr_drop = JuMP.@NLexpression(pm.model, r*cr-x*ci) - vi_drop = JuMP.@NLexpression(pm.model, r*ci+x*cr) + vr_drop = JuMP.@expression(pm.model, r*cr-x*ci) + vi_drop = JuMP.@expression(pm.model, r*ci+x*cr) # (v_ref-δ)^2 ≤ (vr_fr-vr_drop)^2 + (vi_fr-vi_drop)^2 ≤ (v_ref+δ)^2 # (vr_fr^2 + vi_fr^2)/1.1^2 ≤ (vr_to^2 + vi_to^2) ≤ (vr_fr^2 + vi_fr^2)/0.9^2 - JuMP.@NLconstraint(pm.model, (vr_fr[fc]-vr_drop)^2 + (vi_fr[fc]-vi_drop)^2 ≥ (v_ref - δ)^2) - JuMP.@NLconstraint(pm.model, (vr_fr[fc]-vr_drop)^2 + (vi_fr[fc]-vi_drop)^2 ≤ (v_ref + δ)^2) + JuMP.@constraint(pm.model, (vr_fr[fc]-vr_drop)^2 + (vi_fr[fc]-vi_drop)^2 ≥ (v_ref - δ)^2) + JuMP.@constraint(pm.model, (vr_fr[fc]-vr_drop)^2 + (vi_fr[fc]-vi_drop)^2 ≤ (v_ref + δ)^2) JuMP.@constraint(pm.model, (vr_fr[fc]^2 + vi_fr[fc]^2)/1.1^2 ≤ vr_to[tc]^2 + vi_to[tc]^2) JuMP.@constraint(pm.model, (vr_fr[fc]^2 + vi_fr[fc]^2)/0.9^2 ≥ vr_to[tc]^2 + vi_to[tc]^2) end @@ -1041,19 +1041,19 @@ function constraint_mc_transformer_power_dy(pm::AbstractUnbalancedACRModel, nw:: # -Im(s/v) = -(q*cos(va)-p*sin(va))/|v| for (idx, (fc,tc)) in enumerate(zip(f_connections,t_connections)) # id = conj(s_to/v_to)./tm - id_re[idx] = JuMP.@NLexpression(pm.model, (p_to[tc]*vr_p_to[idx]+q_to[tc]*vi_p_to[idx])/(tm_scale*tm[idx]*pol)/(vr_p_to[idx]^2+vi_p_to[idx]^2)) - id_im[idx] = JuMP.@NLexpression(pm.model, (p_to[tc]*vi_p_to[idx]-q_to[tc]*vr_p_to[idx])/(tm_scale*tm[idx]*pol)/(vr_p_to[idx]^2+vi_p_to[idx]^2)) + id_re[idx] = JuMP.@expression(pm.model, (p_to[tc]*vr_p_to[idx]+q_to[tc]*vi_p_to[idx])/(tm_scale*tm[idx]*pol)/(vr_p_to[idx]^2+vi_p_to[idx]^2)) + id_im[idx] = JuMP.@expression(pm.model, (p_to[tc]*vi_p_to[idx]-q_to[tc]*vr_p_to[idx])/(tm_scale*tm[idx]*pol)/(vr_p_to[idx]^2+vi_p_to[idx]^2)) end for (idx,(fc,tc)) in enumerate(zip(f_connections, t_connections)) jdx = (idx-1+nph-1)%nph+1 # s_fr = v_fr*conj(i_fr) # = v_fr*conj(id[q]-id[p]) # = v_fr*(id_re[q]-j*id_im[q]-id_re[p]+j*id_im[p]) - JuMP.@NLconstraint(pm.model, p_fr[fc] == + JuMP.@constraint(pm.model, p_fr[fc] == vr_p_fr[idx]*( id_re[jdx]-id_re[idx]) -vi_p_fr[idx]*(-id_im[jdx]+id_im[idx]) ) - JuMP.@NLconstraint(pm.model, q_fr[fc] == + JuMP.@constraint(pm.model, q_fr[fc] == vr_p_fr[idx]*(-id_im[jdx]+id_im[idx]) +vi_p_fr[idx]*( id_re[jdx]-id_re[idx]) ) @@ -1078,13 +1078,13 @@ function constraint_mc_storage_losses(pm::AbstractUnbalancedACRModel, i::Int; nw r = storage["r"] x = storage["x"] - JuMP.@NLconstraint(pm.model, + JuMP.@constraint(pm.model, sum(ps[c] for c in storage["connections"]) + (sd - sc) == p_loss + r * sum((ps[c]^2 + qs[c]^2)/(vr[c]^2 + vi[c]^2) for (idx,c) in enumerate(storage["connections"])) ) - JuMP.@NLconstraint(pm.model, + JuMP.@constraint(pm.model, sum(qs[c] for c in storage["connections"]) == qsc + q_loss + x * sum((ps[c]^2 + qs[c]^2)/(vr[c]^2 + vi[c]^2) for (idx,c) in enumerate(storage["connections"])) @@ -1102,13 +1102,13 @@ function constraint_mc_storage_losses(pm::AbstractUnbalancedACRModel, n::Int, i: sd = var(pm, n, :sd, i) qsc = var(pm, n, :qsc, i) - JuMP.@NLconstraint(pm.model, + JuMP.@constraint(pm.model, sum(ps[c] for c in connections) + (sd - sc) == p_loss + r * sum((ps[c]^2 + qs[c]^2)/(vr[c]^2 + vi[c]^2) for c in connections) ) - JuMP.@NLconstraint(pm.model, + JuMP.@constraint(pm.model, sum(qs[c] for c in connections) == qsc + q_loss + x * sum((ps[c]^2 + qs[c]^2)/(vr[c]^2 + vi[c]^2) for c in connections) diff --git a/src/form/bf_fbs.jl b/src/form/bf_fbs.jl index c0aa6ff58..0942717fc 100644 --- a/src/form/bf_fbs.jl +++ b/src/form/bf_fbs.jl @@ -827,8 +827,8 @@ function constraint_mc_generator_power_delta(pm::FBSUBFPowerModel, nw::Int, id:: crg_bus[c] = JuMP.@expression(pm.model, (-1.0)^(c-1)*crg[1]) cig_bus[c] = JuMP.@expression(pm.model, (-1.0)^(c-1)*cig[1]) else - crg_bus[c] = JuMP.@NLexpression(pm.model, crg[c]-crg[prev[c]]) - cig_bus[c] = JuMP.@NLexpression(pm.model, cig[c]-cig[prev[c]]) + crg_bus[c] = JuMP.@expression(pm.model, crg[c]-crg[prev[c]]) + cig_bus[c] = JuMP.@expression(pm.model, cig[c]-cig[prev[c]]) end end diff --git a/src/form/en_acr.jl b/src/form/en_acr.jl index bd5e446d1..5051b4e97 100644 --- a/src/form/en_acr.jl +++ b/src/form/en_acr.jl @@ -57,19 +57,19 @@ function constraint_mc_generator_power_wye(pm::AbstractExplicitNeutralACRModel, vr_pn = [vr[p]-vr[n] for p in phases] vi_pn = [vi[p]-vi[n] for p in phases] - crg = JuMP.@NLexpression(pm.model, [idx in 1:P], + crg = JuMP.@expression(pm.model, [idx in 1:P], ( pg[idx]*vr_pn[idx] + qg[idx]*vi_pn[idx] )/( vr_pn[idx]^2 + vi_pn[idx]^2 ) ) - cig = JuMP.@NLexpression(pm.model, [idx in 1:P], + cig = JuMP.@expression(pm.model, [idx in 1:P], ( pg[idx]*vi_pn[idx] - qg[idx]*vr_pn[idx] )/( vr_pn[idx]^2 + vi_pn[idx]^2 ) ) pg_bus_unmerged = [ - [JuMP.@NLexpression(pm.model, vr[p]*crg[idx]+vi[p]*cig[idx]) for (idx,p) in enumerate(phases)]..., - JuMP.@NLexpression(pm.model, vr[n]*sum(-crg[idx] for idx in 1:P)+vi[n]*sum(-cig[idx] for idx in 1:P)) + [JuMP.@expression(pm.model, vr[p]*crg[idx]+vi[p]*cig[idx]) for (idx,p) in enumerate(phases)]..., + JuMP.@expression(pm.model, vr[n]*sum(-crg[idx] for idx in 1:P)+vi[n]*sum(-cig[idx] for idx in 1:P)) ] qg_bus_unmerged = [ - [JuMP.@NLexpression(pm.model, -vr[p]*cig[idx]+vi[p]*crg[idx]) for (idx,p) in enumerate(phases)]..., - JuMP.@NLexpression(pm.model, -vr[n]*sum(-cig[idx] for idx in 1:P)+vi[n]*sum(-crg[idx] for idx in 1:P)) + [JuMP.@expression(pm.model, -vr[p]*cig[idx]+vi[p]*crg[idx]) for (idx,p) in enumerate(phases)]..., + JuMP.@expression(pm.model, -vr[n]*sum(-cig[idx] for idx in 1:P)+vi[n]*sum(-crg[idx] for idx in 1:P)) ] end var(pm, nw, :pg_bus)[id] = pg_bus = _merge_bus_flows(pm, pg_bus_unmerged, connections) @@ -115,17 +115,17 @@ function constraint_mc_generator_power_delta(pm::AbstractExplicitNeutralACRModel vr_pp = [vr[c]-vr[d] for (c,d) in zip(ph,ph_next)] vi_pp = [vi[c]-vi[d] for (c,d) in zip(ph,ph_next)] - crg = JuMP.@NLexpression(pm.model, [idx in 1:P], + crg = JuMP.@expression(pm.model, [idx in 1:P], ( pg[idx]*vr_pp[idx] + qg[idx]*vi_pp[idx] )/( vr_pp[idx]^2 + vi_pp[idx]^2 ) ) - cig = JuMP.@NLexpression(pm.model, [idx in 1:P], + cig = JuMP.@expression(pm.model, [idx in 1:P], ( pg[idx]*vi_pp[idx] - qg[idx]*vr_pp[idx] )/( vr_pp[idx]^2 + vi_pp[idx]^2 ) ) - crg_bus = JuMP.@NLexpression(pm.model, [idx in 1:P], crg[idx] - crg[idxs_prev[idx]]) - cig_bus = JuMP.@NLexpression(pm.model, [idx in 1:P], cig[idx] - cig[idxs_prev[idx]]) + crg_bus = JuMP.@expression(pm.model, [idx in 1:P], crg[idx] - crg[idxs_prev[idx]]) + cig_bus = JuMP.@expression(pm.model, [idx in 1:P], cig[idx] - cig[idxs_prev[idx]]) - pg_bus_unmerged = [JuMP.@NLexpression(pm.model, vr[p]*crg_bus[idx]+vi[p]*cig_bus[idx]) for (idx,p) in enumerate(ph)] - qg_bus_unmerged = [JuMP.@NLexpression(pm.model, -vr[p]*cig_bus[idx]+vi[p]*crg_bus[idx]) for (idx,p) in enumerate(ph)] + pg_bus_unmerged = [JuMP.@expression(pm.model, vr[p]*crg_bus[idx]+vi[p]*cig_bus[idx]) for (idx,p) in enumerate(ph)] + qg_bus_unmerged = [JuMP.@expression(pm.model, -vr[p]*cig_bus[idx]+vi[p]*crg_bus[idx]) for (idx,p) in enumerate(ph)] var(pm, nw, :pg_bus)[id] = pg_bus = _merge_bus_flows(pm, pg_bus_unmerged, connections) var(pm, nw, :qg_bus)[id] = qg_bus = _merge_bus_flows(pm, qg_bus_unmerged, connections) @@ -190,8 +190,8 @@ function constraint_mc_load_power_wye(pm::AbstractExplicitNeutralACRModel, nw::I vr_pn = [vr[p]-vr[n] for p in phases] vi_pn = [vi[p]-vi[n] for p in phases] - crd = JuMP.@NLexpression(pm.model, [idx in 1:P], a[idx]*vr_pn[idx]*(vr_pn[idx]^2+vi_pn[idx]^2)^(alpha[idx]/2-1)+b[idx]*vi_pn[idx]*(vr_pn[idx]^2+vi_pn[idx]^2)^(beta[idx]/2 -1)) - cid = JuMP.@NLexpression(pm.model, [idx in 1:P], a[idx]*vi_pn[idx]*(vr_pn[idx]^2+vi_pn[idx]^2)^(alpha[idx]/2-1)-b[idx]*vr_pn[idx]*(vr_pn[idx]^2+vi_pn[idx]^2)^(beta[idx]/2 -1)) + crd = JuMP.@expression(pm.model, [idx in 1:P], a[idx]*vr_pn[idx]*(vr_pn[idx]^2+vi_pn[idx]^2)^(alpha[idx]/2-1)+b[idx]*vi_pn[idx]*(vr_pn[idx]^2+vi_pn[idx]^2)^(beta[idx]/2 -1)) + cid = JuMP.@expression(pm.model, [idx in 1:P], a[idx]*vi_pn[idx]*(vr_pn[idx]^2+vi_pn[idx]^2)^(alpha[idx]/2-1)-b[idx]*vr_pn[idx]*(vr_pn[idx]^2+vi_pn[idx]^2)^(beta[idx]/2 -1)) # if constant power load @@ -199,8 +199,8 @@ function constraint_mc_load_power_wye(pm::AbstractExplicitNeutralACRModel, nw::I pd = a qd = b else - pd = JuMP.@NLexpression(pm.model, [idx in 1:P], vr_pn[idx]*crd[idx]+vi_pn[idx]*cid[idx]) - qd = JuMP.@NLexpression(pm.model, [idx in 1:P], -vr_pn[idx]*cid[idx]+vi_pn[idx]*crd[idx]) + pd = JuMP.@expression(pm.model, [idx in 1:P], vr_pn[idx]*crd[idx]+vi_pn[idx]*cid[idx]) + qd = JuMP.@expression(pm.model, [idx in 1:P], -vr_pn[idx]*cid[idx]+vi_pn[idx]*crd[idx]) end if iszero(vr[n]) && iszero(vi[n]) @@ -208,12 +208,12 @@ function constraint_mc_load_power_wye(pm::AbstractExplicitNeutralACRModel, nw::I qd_bus_unmerged = [qd..., 0.0] else pd_bus_unmerged = [ - [JuMP.@NLexpression(pm.model, vr[p]*crd[idx]+vi[p]*cid[idx]) for (idx,p) in enumerate(phases)]..., - JuMP.@NLexpression(pm.model, vr[n]*sum(-crd[idx] for idx in 1:P)+vi[n]*sum(-cid[idx] for idx in 1:P)) + [JuMP.@expression(pm.model, vr[p]*crd[idx]+vi[p]*cid[idx]) for (idx,p) in enumerate(phases)]..., + JuMP.@expression(pm.model, vr[n]*sum(-crd[idx] for idx in 1:P)+vi[n]*sum(-cid[idx] for idx in 1:P)) ] qd_bus_unmerged = [ - [JuMP.@NLexpression(pm.model, -vr[p]*cid[idx]+vi[p]*crd[idx]) for (idx,p) in enumerate(phases)]..., - JuMP.@NLexpression(pm.model, -vr[n]*sum(-cid[idx] for idx in 1:P)+vi[n]*sum(-crd[idx] for idx in 1:P)) + [JuMP.@expression(pm.model, -vr[p]*cid[idx]+vi[p]*crd[idx]) for (idx,p) in enumerate(phases)]..., + JuMP.@expression(pm.model, -vr[n]*sum(-cid[idx] for idx in 1:P)+vi[n]*sum(-crd[idx] for idx in 1:P)) ] end var(pm, nw, :pd_bus)[id] = pd_bus = _merge_bus_flows(pm, pd_bus_unmerged, connections) @@ -258,14 +258,14 @@ function constraint_mc_load_power_delta(pm::AbstractExplicitNeutralACRModel, nw: vrd = [vr[t]-vr[connections[next(idx)]] for (idx,t) in enumerate(connections)] vid = [vi[t]-vi[connections[next(idx)]] for (idx,t) in enumerate(connections)] - crd = JuMP.@NLexpression(pm.model, [idx in 1:nph], a[idx]*vrd[idx]*(vrd[idx]^2+vid[idx]^2)^(alpha[idx]/2-1)+b[idx]*vid[idx]*(vrd[idx]^2+vid[idx]^2)^(beta[idx]/2 -1)) - cid = JuMP.@NLexpression(pm.model, [idx in 1:nph], a[idx]*vid[idx]*(vrd[idx]^2+vid[idx]^2)^(alpha[idx]/2-1)-b[idx]*vrd[idx]*(vrd[idx]^2+vid[idx]^2)^(beta[idx]/2 -1)) + crd = JuMP.@expression(pm.model, [idx in 1:nph], a[idx]*vrd[idx]*(vrd[idx]^2+vid[idx]^2)^(alpha[idx]/2-1)+b[idx]*vid[idx]*(vrd[idx]^2+vid[idx]^2)^(beta[idx]/2 -1)) + cid = JuMP.@expression(pm.model, [idx in 1:nph], a[idx]*vid[idx]*(vrd[idx]^2+vid[idx]^2)^(alpha[idx]/2-1)-b[idx]*vrd[idx]*(vrd[idx]^2+vid[idx]^2)^(beta[idx]/2 -1)) - crd_bus_unmerged = JuMP.@NLexpression(pm.model, [idx in 1:nph], crd[idx]-crd[prev(idx)]) - cid_bus_unmerged = JuMP.@NLexpression(pm.model, [idx in 1:nph], cid[idx]-cid[prev(idx)]) + crd_bus_unmerged = JuMP.@expression(pm.model, [idx in 1:nph], crd[idx]-crd[prev(idx)]) + cid_bus_unmerged = JuMP.@expression(pm.model, [idx in 1:nph], cid[idx]-cid[prev(idx)]) - pd_bus_unmerged = [JuMP.@NLexpression(pm.model, vr[p]*crd_bus_unmerged[idx]+vi[p]*cid_bus_unmerged[idx]) for (idx,p) in enumerate(connections)] - qd_bus_unmerged = [JuMP.@NLexpression(pm.model, -vr[p]*cid_bus_unmerged[idx]+vi[p]*crd_bus_unmerged[idx]) for (idx,p) in enumerate(connections)] + pd_bus_unmerged = [JuMP.@expression(pm.model, vr[p]*crd_bus_unmerged[idx]+vi[p]*cid_bus_unmerged[idx]) for (idx,p) in enumerate(connections)] + qd_bus_unmerged = [JuMP.@expression(pm.model, -vr[p]*cid_bus_unmerged[idx]+vi[p]*crd_bus_unmerged[idx]) for (idx,p) in enumerate(connections)] var(pm, nw, :pd_bus)[id] = pd_bus = _merge_bus_flows(pm, pd_bus_unmerged, connections) var(pm, nw, :qd_bus)[id] = qd_bus = _merge_bus_flows(pm, qd_bus_unmerged, connections) @@ -274,11 +274,11 @@ function constraint_mc_load_power_delta(pm::AbstractExplicitNeutralACRModel, nw: sol(pm, nw, :load, id)[:pd_bus] = pd_bus sol(pm, nw, :load, id)[:qd_bus] = qd_bus - pd = Vector{JuMP.NonlinearExpression}([]) - qd = Vector{JuMP.NonlinearExpression}([]) + pd = JuMP.NonlinearExpr[] + qd = JuMP.NonlinearExpr[] for idx in 1:nph - push!(pd, JuMP.@NLexpression(pm.model, a[idx]*(vrd[idx]^2+vid[idx]^2)^(alpha[idx]/2) )) - push!(qd, JuMP.@NLexpression(pm.model, b[idx]*(vrd[idx]^2+vid[idx]^2)^(beta[idx]/2) )) + push!(pd, JuMP.@expression(pm.model, a[idx]*(vrd[idx]^2+vid[idx]^2)^(alpha[idx]/2) )) + push!(qd, JuMP.@expression(pm.model, b[idx]*(vrd[idx]^2+vid[idx]^2)^(beta[idx]/2) )) end sol(pm, nw, :load, id)[:pd] = JuMP.Containers.DenseAxisArray(pd, connections) sol(pm, nw, :load, id)[:qd] = JuMP.Containers.DenseAxisArray(qd, connections) @@ -357,16 +357,16 @@ function constraint_mc_transformer_power_yy(pm::AbstractExplicitNeutralACRModel, vr_fr_pn = [vr_fr[p]-vr_fr[f_n] for p in f_phases] vi_fr_pn = [vi_fr[p]-vi_fr[f_n] for p in f_phases] - crt_fr = [JuMP.@NLexpression(pm.model, ( pt_fr[idx]*vr_fr_pn[idx]+qt_fr[idx]*vi_fr_pn[idx])/(vr_fr_pn[idx]^2+vi_fr_pn[idx]^2)) for idx in 1:P] - cit_fr = [JuMP.@NLexpression(pm.model, (-pt_fr[idx]*vi_fr_pn[idx]+qt_fr[idx]*vr_fr_pn[idx])/(vr_fr_pn[idx]^2+vi_fr_pn[idx]^2)) for idx in 1:P] + crt_fr = [JuMP.@expression(pm.model, ( pt_fr[idx]*vr_fr_pn[idx]+qt_fr[idx]*vi_fr_pn[idx])/(vr_fr_pn[idx]^2+vi_fr_pn[idx]^2)) for idx in 1:P] + cit_fr = [JuMP.@expression(pm.model, (-pt_fr[idx]*vi_fr_pn[idx]+qt_fr[idx]*vr_fr_pn[idx])/(vr_fr_pn[idx]^2+vi_fr_pn[idx]^2)) for idx in 1:P] pt_bus_fr_unmerged = [ - [JuMP.@NLexpression(pm.model, vr_fr[p]*crt_fr[idx]+vi_fr[p]*cit_fr[idx]) for (idx,p) in enumerate(f_phases)]..., - JuMP.@NLexpression(pm.model, vr_fr[f_n]*sum(-crt_fr[idx] for idx in 1:P)+vi_fr[f_n]*sum(-cit_fr[idx] for idx in 1:P)) + [JuMP.@expression(pm.model, vr_fr[p]*crt_fr[idx]+vi_fr[p]*cit_fr[idx]) for (idx,p) in enumerate(f_phases)]..., + JuMP.@expression(pm.model, vr_fr[f_n]*sum(-crt_fr[idx] for idx in 1:P)+vi_fr[f_n]*sum(-cit_fr[idx] for idx in 1:P)) ] qt_bus_fr_unmerged = [ - [JuMP.@NLexpression(pm.model, -vr_fr[p]*cit_fr[idx]+vi_fr[p]*crt_fr[idx]) for (idx,p) in enumerate(f_phases)]..., - JuMP.@NLexpression(pm.model, -vr_fr[f_n]*sum(-cit_fr[idx] for idx in 1:P)+vi_fr[f_n]*sum(-crt_fr[idx] for idx in 1:P)) + [JuMP.@expression(pm.model, -vr_fr[p]*cit_fr[idx]+vi_fr[p]*crt_fr[idx]) for (idx,p) in enumerate(f_phases)]..., + JuMP.@expression(pm.model, -vr_fr[f_n]*sum(-cit_fr[idx] for idx in 1:P)+vi_fr[f_n]*sum(-crt_fr[idx] for idx in 1:P)) ] end var(pm, nw, :pt_bus)[f_idx] = pt_bus_fr = _merge_bus_flows(pm, pt_bus_fr_unmerged, f_connections) @@ -380,16 +380,16 @@ function constraint_mc_transformer_power_yy(pm::AbstractExplicitNeutralACRModel, vr_to_pn = [vr_to[p]-vr_to[t_n] for p in t_phases] vi_to_pn = [vi_to[p]-vi_to[t_n] for p in t_phases] - crt_to = [JuMP.@NLexpression(pm.model, ( pt_to[idx]*vr_to_pn[idx]+qt_to[idx]*vi_to_pn[idx])/(vr_to_pn[idx]^2+vi_to_pn[idx]^2)) for idx in 1:P] - cit_to = [JuMP.@NLexpression(pm.model, (-pt_to[idx]*vi_to_pn[idx]+qt_to[idx]*vr_to_pn[idx])/(vr_to_pn[idx]^2+vi_to_pn[idx]^2)) for idx in 1:P] + crt_to = [JuMP.@expression(pm.model, ( pt_to[idx]*vr_to_pn[idx]+qt_to[idx]*vi_to_pn[idx])/(vr_to_pn[idx]^2+vi_to_pn[idx]^2)) for idx in 1:P] + cit_to = [JuMP.@expression(pm.model, (-pt_to[idx]*vi_to_pn[idx]+qt_to[idx]*vr_to_pn[idx])/(vr_to_pn[idx]^2+vi_to_pn[idx]^2)) for idx in 1:P] pt_bus_to_unmerged = [ - [JuMP.@NLexpression(pm.model, vr_to[p]*crt_to[idx]+vi_to[p]*cit_to[idx]) for (idx,p) in enumerate(t_phases)]..., - JuMP.@NLexpression(pm.model, vr_to[t_n]*sum(-crt_to[idx] for idx in 1:P)+vi_to[t_n]*sum(-cit_to[idx] for idx in 1:P)) + [JuMP.@expression(pm.model, vr_to[p]*crt_to[idx]+vi_to[p]*cit_to[idx]) for (idx,p) in enumerate(t_phases)]..., + JuMP.@expression(pm.model, vr_to[t_n]*sum(-crt_to[idx] for idx in 1:P)+vi_to[t_n]*sum(-cit_to[idx] for idx in 1:P)) ] qt_bus_to_unmerged = [ - [JuMP.@NLexpression(pm.model, -vr_to[p]*cit_to[idx]+vi_to[p]*crt_to[idx]) for (idx,p) in enumerate(t_phases)]..., - JuMP.@NLexpression(pm.model, -vr_to[t_n]*sum(-cit_to[idx] for idx in 1:P)+vi_to[t_n]*sum(-crt_to[idx] for idx in 1:P)) + [JuMP.@expression(pm.model, -vr_to[p]*cit_to[idx]+vi_to[p]*crt_to[idx]) for (idx,p) in enumerate(t_phases)]..., + JuMP.@expression(pm.model, -vr_to[t_n]*sum(-cit_to[idx] for idx in 1:P)+vi_to[t_n]*sum(-crt_to[idx] for idx in 1:P)) ] end var(pm, nw, :pt_bus)[t_idx] = pt_bus_to = _merge_bus_flows(pm, pt_bus_to_unmerged, t_connections) @@ -440,14 +440,14 @@ function constraint_mc_transformer_power_dy(pm::AbstractExplicitNeutralACRModel, vrg_fr = [vr_fr[p]-vr_fr[f_connections[next(idx)]] for (idx,p) in enumerate(f_connections)] vig_fr = [vi_fr[p]-vi_fr[f_connections[next(idx)]] for (idx,p) in enumerate(f_connections)] - crt_fr = JuMP.@NLexpression(pm.model, [idx in 1:P], (pt_fr[idx]*vrg_fr[idx]+qt_fr[idx]*vig_fr[idx])/(vrg_fr[idx]^2+vig_fr[idx]^2)) - cit_fr = JuMP.@NLexpression(pm.model, [idx in 1:P], (pt_fr[idx]*vig_fr[idx]-qt_fr[idx]*vrg_fr[idx])/(vrg_fr[idx]^2+vig_fr[idx]^2)) + crt_fr = JuMP.@expression(pm.model, [idx in 1:P], (pt_fr[idx]*vrg_fr[idx]+qt_fr[idx]*vig_fr[idx])/(vrg_fr[idx]^2+vig_fr[idx]^2)) + cit_fr = JuMP.@expression(pm.model, [idx in 1:P], (pt_fr[idx]*vig_fr[idx]-qt_fr[idx]*vrg_fr[idx])/(vrg_fr[idx]^2+vig_fr[idx]^2)) - crt_bus_fr_unmerged = JuMP.@NLexpression(pm.model, [idx in 1:P], crt_fr[idx]-crt_fr[prev(idx)]) - cit_bus_fr_unmerged = JuMP.@NLexpression(pm.model, [idx in 1:P], cit_fr[idx]-cit_fr[prev(idx)]) + crt_bus_fr_unmerged = JuMP.@expression(pm.model, [idx in 1:P], crt_fr[idx]-crt_fr[prev(idx)]) + cit_bus_fr_unmerged = JuMP.@expression(pm.model, [idx in 1:P], cit_fr[idx]-cit_fr[prev(idx)]) - pt_bus_fr_unmerged = [JuMP.@NLexpression(pm.model, vr_fr[p]*crt_bus_fr_unmerged[idx]+vi_fr[p]*cit_bus_fr_unmerged[idx]) for (idx,p) in enumerate(f_connections)] - qt_bus_fr_unmerged = [JuMP.@NLexpression(pm.model, -vr_fr[p]*cit_bus_fr_unmerged[idx]+vi_fr[p]*crt_bus_fr_unmerged[idx]) for (idx,p) in enumerate(f_connections)] + pt_bus_fr_unmerged = [JuMP.@expression(pm.model, vr_fr[p]*crt_bus_fr_unmerged[idx]+vi_fr[p]*cit_bus_fr_unmerged[idx]) for (idx,p) in enumerate(f_connections)] + qt_bus_fr_unmerged = [JuMP.@expression(pm.model, -vr_fr[p]*cit_bus_fr_unmerged[idx]+vi_fr[p]*crt_bus_fr_unmerged[idx]) for (idx,p) in enumerate(f_connections)] var(pm, nw, :pt_bus)[f_idx] = pt_bus_fr = _merge_bus_flows(pm, pt_bus_fr_unmerged, f_connections) var(pm, nw, :qt_bus)[f_idx] = qt_bus_fr = _merge_bus_flows(pm, qt_bus_fr_unmerged, f_connections) @@ -460,16 +460,16 @@ function constraint_mc_transformer_power_dy(pm::AbstractExplicitNeutralACRModel, vr_to_pn = [vr_to[p]-vr_to[t_n] for p in t_phases] vi_to_pn = [vi_to[p]-vi_to[t_n] for p in t_phases] - crt_to = [JuMP.@NLexpression(pm.model, ( pt_to[idx]*vr_to_pn[idx]+qt_to[idx]*vi_to_pn[idx])/(vr_to_pn[idx]^2+vi_to_pn[idx]^2)) for idx in 1:P] - cit_to = [JuMP.@NLexpression(pm.model, (-pt_to[idx]*vi_to_pn[idx]+qt_to[idx]*vr_to_pn[idx])/(vr_to_pn[idx]^2+vi_to_pn[idx]^2)) for idx in 1:P] + crt_to = [JuMP.@expression(pm.model, ( pt_to[idx]*vr_to_pn[idx]+qt_to[idx]*vi_to_pn[idx])/(vr_to_pn[idx]^2+vi_to_pn[idx]^2)) for idx in 1:P] + cit_to = [JuMP.@expression(pm.model, (-pt_to[idx]*vi_to_pn[idx]+qt_to[idx]*vr_to_pn[idx])/(vr_to_pn[idx]^2+vi_to_pn[idx]^2)) for idx in 1:P] pt_bus_to_unmerged = [ - [JuMP.@NLexpression(pm.model, vr_to[p]*crt_to[idx]+vi_to[p]*cit_to[idx]) for (idx,p) in enumerate(phases)]..., - JuMP.@NLexpression(pm.model, vr_to[n]*sum(-crt_to[idx] for idx in 1:P)+vi_to[n]*sum(-cit_to[idx] for idx in 1:P)) + [JuMP.@expression(pm.model, vr_to[p]*crt_to[idx]+vi_to[p]*cit_to[idx]) for (idx,p) in enumerate(phases)]..., + JuMP.@expression(pm.model, vr_to[n]*sum(-crt_to[idx] for idx in 1:P)+vi_to[n]*sum(-cit_to[idx] for idx in 1:P)) ] qt_bus_to_unmerged = [ - [JuMP.@NLexpression(pm.model, -vr_to[p]*cit_to[idx]+vi_to[p]*crt_to[idx]) for (idx,p) in enumerate(phases)]..., - JuMP.@NLexpression(pm.model, -vr_to[n]*sum(-cit_to[idx] for idx in 1:P)+vi_to[n]*sum(-crt_to[idx] for idx in 1:P)) + [JuMP.@expression(pm.model, -vr_to[p]*cit_to[idx]+vi_to[p]*crt_to[idx]) for (idx,p) in enumerate(phases)]..., + JuMP.@expression(pm.model, -vr_to[n]*sum(-cit_to[idx] for idx in 1:P)+vi_to[n]*sum(-crt_to[idx] for idx in 1:P)) ] end var(pm, nw, :pt_bus)[t_idx] = pt_bus_to = _merge_bus_flows(pm, pt_bus_to_unmerged, t_connections) @@ -680,7 +680,7 @@ function constraint_mc_thermal_limit_from(pm::AbstractExplicitNeutralACRModel, n if rate_a[idx]= pg[i]) - JuMP.@NLconstraint(pm.model, [i in 1:nph], qmin[i] <= qg[i]) - JuMP.@NLconstraint(pm.model, [i in 1:nph], qmax[i] >= qg[i]) + # TODO(odow): refactor as pmin[i] <= pg[i] <= pmax[i] + JuMP.@constraint(pm.model, [i in 1:nph], pmin[i] <= pg[i]) + JuMP.@constraint(pm.model, [i in 1:nph], pmax[i] >= pg[i]) + JuMP.@constraint(pm.model, [i in 1:nph], qmin[i] <= qg[i]) + JuMP.@constraint(pm.model, [i in 1:nph], qmax[i] >= qg[i]) var(pm, nw, :pg)[id] = JuMP.Containers.DenseAxisArray(pg, connections) var(pm, nw, :qg)[id] = JuMP.Containers.DenseAxisArray(qg, connections) @@ -499,18 +500,18 @@ function constraint_mc_load_current_wye(pm::AbstractExplicitNeutralIVRModel, nw: vr = var(pm, nw, :vr, bus_id) vi = var(pm, nw, :vi, bus_id) - crd = Vector{JuMP.NonlinearExpression}([]) - cid = Vector{JuMP.NonlinearExpression}([]) + crd = JuMP.NonlinearExpr[] + cid = JuMP.NonlinearExpr[] phases = connections[1:end-1] n = connections[end] for (idx, p) in enumerate(phases) - push!(crd, JuMP.@NLexpression(pm.model, + push!(crd, JuMP.@expression(pm.model, a[idx]*(vr[p]-vr[n])*((vr[p]-vr[n])^2+(vi[p]-vi[n])^2)^(alpha[idx]/2-1) +b[idx]*(vi[p]-vi[n])*((vr[p]-vr[n])^2+(vi[p]-vi[n])^2)^(beta[idx]/2 -1) )) - push!(cid, JuMP.@NLexpression(pm.model, + push!(cid, JuMP.@expression(pm.model, a[idx]*(vi[p]-vi[n])*((vr[p]-vr[n])^2+(vi[p]-vi[n])^2)^(alpha[idx]/2-1) -b[idx]*(vr[p]-vr[n])*((vr[p]-vr[n])^2+(vi[p]-vi[n])^2)^(beta[idx]/2 -1) )) @@ -519,18 +520,18 @@ function constraint_mc_load_current_wye(pm::AbstractExplicitNeutralIVRModel, nw: var(pm, nw, :crd)[id] = crd var(pm, nw, :cid)[id] = cid - crd_bus_n = JuMP.@NLexpression(pm.model, -sum(crd[i] for i in 1:length(phases))) - cid_bus_n = JuMP.@NLexpression(pm.model, -sum(cid[i] for i in 1:length(phases))) + crd_bus_n = JuMP.@expression(pm.model, -sum(crd[i] for i in 1:length(phases))) + cid_bus_n = JuMP.@expression(pm.model, -sum(cid[i] for i in 1:length(phases))) var(pm, nw, :crd_bus)[id] = crd_bus = _merge_bus_flows(pm, [crd..., crd_bus_n], connections) var(pm, nw, :cid_bus)[id] = cid_bus = _merge_bus_flows(pm, [cid..., cid_bus_n], connections) if report - pd_bus = Vector{JuMP.NonlinearExpression}([]) - qd_bus = Vector{JuMP.NonlinearExpression}([]) + pd_bus = JuMP.NonlinearExpr[] + qd_bus = JuMP.NonlinearExpr[] for (idx,c) in enumerate(connections) - push!(pd_bus, JuMP.@NLexpression(pm.model, vr[c]*crd_bus[c]+vi[c]*cid_bus[c])) - push!(qd_bus, JuMP.@NLexpression(pm.model, -vr[c]*cid_bus[c]+vi[c]*crd_bus[c])) + push!(pd_bus, JuMP.@expression(pm.model, vr[c]*crd_bus[c]+vi[c]*cid_bus[c])) + push!(qd_bus, JuMP.@expression(pm.model, -vr[c]*cid_bus[c]+vi[c]*crd_bus[c])) end sol(pm, nw, :load, id)[:pd_bus] = JuMP.Containers.DenseAxisArray(pd_bus, connections) @@ -542,11 +543,11 @@ function constraint_mc_load_current_wye(pm::AbstractExplicitNeutralIVRModel, nw: sol(pm, nw, :load, id)[:crd_bus] = crd_bus sol(pm, nw, :load, id)[:cid_bus] = cid_bus - pd = Vector{JuMP.NonlinearExpression}([]) - qd = Vector{JuMP.NonlinearExpression}([]) + pd = JuMP.NonlinearExpr[] + qd = JuMP.NonlinearExpr[] for (idx, p) in enumerate(phases) - push!(pd, JuMP.@NLexpression(pm.model, a[idx]*(vr[p]^2+vi[p]^2)^(alpha[idx]/2) )) - push!(qd, JuMP.@NLexpression(pm.model, b[idx]*(vr[p]^2+vi[p]^2)^(beta[idx]/2) )) + push!(pd, JuMP.@expression(pm.model, a[idx]*(vr[p]^2+vi[p]^2)^(alpha[idx]/2) )) + push!(qd, JuMP.@expression(pm.model, b[idx]*(vr[p]^2+vi[p]^2)^(beta[idx]/2) )) end sol(pm, nw, :load, id)[:pd] = JuMP.Containers.DenseAxisArray(pd, connections) sol(pm, nw, :load, id)[:qd] = JuMP.Containers.DenseAxisArray(qd, connections) @@ -586,30 +587,30 @@ function constraint_mc_load_current_delta(pm::AbstractExplicitNeutralIVRModel, n vrd = [vr[c]-vr[d] for (c,d) in zip(ph,ph_next)] vid = [vi[c]-vi[d] for (c,d) in zip(ph,ph_next)] - crd = JuMP.@NLexpression(pm.model, [i in 1:P], + crd = JuMP.@expression(pm.model, [i in 1:P], a[i]*vrd[i]*(vrd[i]^2+vid[i]^2)^(alpha[i]/2-1) +b[i]*vid[i]*(vrd[i]^2+vid[i]^2)^(beta[i]/2 -1) ) - cid = JuMP.@NLexpression(pm.model, [i in 1:P], + cid = JuMP.@expression(pm.model, [i in 1:P], a[i]*vid[i]*(vrd[i]^2+vid[i]^2)^(alpha[i]/2-1) -b[i]*vrd[i]*(vrd[i]^2+vid[i]^2)^(beta[i]/2 -1) ) - crd_bus = JuMP.@NLexpression(pm.model, [i in 1:P], crd[i]-crd[idxs_prev[i]]) - cid_bus = JuMP.@NLexpression(pm.model, [i in 1:P], cid[i]-cid[idxs_prev[i]]) + crd_bus = JuMP.@expression(pm.model, [i in 1:P], crd[i]-crd[idxs_prev[i]]) + cid_bus = JuMP.@expression(pm.model, [i in 1:P], cid[i]-cid[idxs_prev[i]]) var(pm, nw, :crd_bus)[id] = _merge_bus_flows(pm, crd_bus, connections) var(pm, nw, :cid_bus)[id] = _merge_bus_flows(pm, cid_bus, connections) if report - pd_bus = JuMP.@NLexpression(pm.model, [i in 1:P], vr[i]*crd_bus[i]+vi[i]*cid_bus[i]) - qd_bus = JuMP.@NLexpression(pm.model, [i in 1:P], -vr[i]*cid_bus[i]+vi[i]*crd_bus[i]) + pd_bus = JuMP.@expression(pm.model, [i in 1:P], vr[i]*crd_bus[i]+vi[i]*cid_bus[i]) + qd_bus = JuMP.@expression(pm.model, [i in 1:P], -vr[i]*cid_bus[i]+vi[i]*crd_bus[i]) sol(pm, nw, :load, id)[:pd_bus] = pd_bus sol(pm, nw, :load, id)[:qd_bus] = qd_bus - pd = JuMP.@NLexpression(pm.model, [i in 1:P], a[i]*(vrd[i]^2+vid[i]^2)^(alpha[i]/2) ) - qd = JuMP.@NLexpression(pm.model, [i in 1:P], b[i]*(vrd[i]^2+vid[i]^2)^(beta[i]/2) ) + pd = JuMP.@expression(pm.model, [i in 1:P], a[i]*(vrd[i]^2+vid[i]^2)^(alpha[i]/2) ) + qd = JuMP.@expression(pm.model, [i in 1:P], b[i]*(vrd[i]^2+vid[i]^2)^(beta[i]/2) ) sol(pm, nw, :load, id)[:pd] = pd sol(pm, nw, :load, id)[:qd] = qd end @@ -1101,14 +1102,14 @@ function constraint_mc_transformer_thermal_limit(pm::AbstractNLExplicitNeutralIV vit_to = [vi_to[p]-vi_to[n_to] for p in P_to] idxs = [1:length(vrt_fr)...] - pt_fr = JuMP.@NLexpression(pm.model, [i in idxs], vrt_fr[i]*crt_fr[i] + vit_fr[i]*cit_fr[i]) - qt_fr = JuMP.@NLexpression(pm.model, [i in idxs], -vrt_fr[i]*cit_fr[i] + vit_fr[i]*crt_fr[i]) - pt_to = JuMP.@NLexpression(pm.model, [i in idxs], vrt_to[i]*crt_to[i] + vit_to[i]*cit_to[i]) - qt_to = JuMP.@NLexpression(pm.model, [i in idxs], -vrt_to[i]*cit_to[i] + vit_to[i]*crt_to[i]) + pt_fr = JuMP.@expression(pm.model, [i in idxs], vrt_fr[i]*crt_fr[i] + vit_fr[i]*cit_fr[i]) + qt_fr = JuMP.@expression(pm.model, [i in idxs], -vrt_fr[i]*cit_fr[i] + vit_fr[i]*crt_fr[i]) + pt_to = JuMP.@expression(pm.model, [i in idxs], vrt_to[i]*crt_to[i] + vit_to[i]*cit_to[i]) + qt_to = JuMP.@expression(pm.model, [i in idxs], -vrt_to[i]*cit_to[i] + vit_to[i]*crt_to[i]) if sm_ub(i+nph-2)%nph+1 for i in 1:nph) next = is_triplex ? conn_bus[2] : Dict(i=>i%nph+1 for i in 1:nph) - vrd = JuMP.@NLexpression(pm.model, [i in 1:nph], vr[i]-vr[next[i]]) - vid = JuMP.@NLexpression(pm.model, [i in 1:nph], vi[i]-vi[next[i]]) + vrd = JuMP.@expression(pm.model, [i in 1:nph], vr[i]-vr[next[i]]) + vid = JuMP.@expression(pm.model, [i in 1:nph], vi[i]-vi[next[i]]) - crd = JuMP.@NLexpression(pm.model, [i in 1:nph], + crd = JuMP.@expression(pm.model, [i in 1:nph], a[i]*vrd[i]*(vrd[i]^2+vid[i]^2)^(alpha[i]/2-1) +b[i]*vid[i]*(vrd[i]^2+vid[i]^2)^(beta[i]/2 -1) ) - cid = JuMP.@NLexpression(pm.model, [i in 1:nph], + cid = JuMP.@expression(pm.model, [i in 1:nph], a[i]*vid[i]*(vrd[i]^2+vid[i]^2)^(alpha[i]/2-1) -b[i]*vrd[i]*(vrd[i]^2+vid[i]^2)^(beta[i]/2 -1) ) @@ -686,11 +686,11 @@ function constraint_mc_load_power_delta(pm::IVRUPowerModel, nw::Int, id::Int, bu cid_bus = Dict() for (idx, c) in enumerate(conn_bus) if is_triplex - crd_bus[c] = JuMP.@NLexpression(pm.model, (-1.0)^(c-1)*crd[1]) - cid_bus[c] = JuMP.@NLexpression(pm.model, (-1.0)^(c-1)*cid[1]) + crd_bus[c] = JuMP.@expression(pm.model, (-1.0)^(c-1)*crd[1]) + cid_bus[c] = JuMP.@expression(pm.model, (-1.0)^(c-1)*cid[1]) else - crd_bus[c] = JuMP.@NLexpression(pm.model, crd[c]-crd[prev[c]]) - cid_bus[c] = JuMP.@NLexpression(pm.model, cid[c]-cid[prev[c]]) + crd_bus[c] = JuMP.@expression(pm.model, crd[c]-crd[prev[c]]) + cid_bus[c] = JuMP.@expression(pm.model, cid[c]-cid[prev[c]]) end end @@ -698,13 +698,13 @@ function constraint_mc_load_power_delta(pm::IVRUPowerModel, nw::Int, id::Int, bu var(pm, nw, :cid_bus)[id] = cid_bus if report - pd_bus = JuMP.@NLexpression(pm.model, [c in conn_bus], vr[c]*crd_bus[c]+vi[c]*cid_bus[c]) - qd_bus = JuMP.@NLexpression(pm.model, [c in conn_bus], -vr[c]*cid_bus[c]+vi[c]*crd_bus[c]) + pd_bus = JuMP.@expression(pm.model, [c in conn_bus], vr[c]*crd_bus[c]+vi[c]*cid_bus[c]) + qd_bus = JuMP.@expression(pm.model, [c in conn_bus], -vr[c]*cid_bus[c]+vi[c]*crd_bus[c]) sol(pm, nw, :load, id)[:pd_bus] = pd_bus sol(pm, nw, :load, id)[:qd_bus] = qd_bus - pd = JuMP.@NLexpression(pm.model, [i in 1:nph], a[i]*(vrd[i]^2+vid[i]^2)^(alpha[i]/2) ) - qd = JuMP.@NLexpression(pm.model, [i in 1:nph], b[i]*(vrd[i]^2+vid[i]^2)^(beta[i]/2) ) + pd = JuMP.@expression(pm.model, [i in 1:nph], a[i]*(vrd[i]^2+vid[i]^2)^(alpha[i]/2) ) + qd = JuMP.@expression(pm.model, [i in 1:nph], b[i]*(vrd[i]^2+vid[i]^2)^(beta[i]/2) ) sol(pm, nw, :load, id)[:pd] = pd sol(pm, nw, :load, id)[:qd] = qd end @@ -718,12 +718,12 @@ function constraint_mc_generator_power_wye(pm::IVRUPowerModel, nw::Int, id::Int, crg = var(pm, nw, :crg, id) cig = var(pm, nw, :cig, id) - pg = Vector{JuMP.NonlinearExpression}([]) - qg = Vector{JuMP.NonlinearExpression}([]) + pg = JuMP.NonlinearExpr[] + qg = JuMP.NonlinearExpr[] for (idx, c) in enumerate(connections) - push!(pg, JuMP.@NLexpression(pm.model, vr[c]*crg[c]+vi[c]*cig[c])) - push!(qg, JuMP.@NLexpression(pm.model, -vr[c]*cig[c]+vi[c]*crg[c])) + push!(pg, JuMP.@expression(pm.model, vr[c]*crg[c]+vi[c]*cig[c])) + push!(qg, JuMP.@expression(pm.model, -vr[c]*cig[c]+vi[c]*crg[c])) end if bounded @@ -775,41 +775,42 @@ function constraint_mc_generator_power_delta(pm::IVRUPowerModel, nw::Int, id::In vrg = Dict() vig = Dict() for c in connections - vrg[c] = JuMP.@NLexpression(pm.model, vr[c]-vr[next[c]]) - vig[c] = JuMP.@NLexpression(pm.model, vi[c]-vi[next[c]]) + vrg[c] = JuMP.@expression(pm.model, vr[c]-vr[next[c]]) + vig[c] = JuMP.@expression(pm.model, vi[c]-vi[next[c]]) end - pg = Vector{JuMP.NonlinearExpression}([]) - qg = Vector{JuMP.NonlinearExpression}([]) + pg = JuMP.NonlinearExpr[] + qg = JuMP.NonlinearExpr[] for c in connections - push!(pg, JuMP.@NLexpression(pm.model, vrg[c]*crg[c]+vig[c]*cig[c])) - push!(qg, JuMP.@NLexpression(pm.model, -vrg[c]*cig[c]+vig[c]*crg[c])) + push!(pg, JuMP.@expression(pm.model, vrg[c]*crg[c]+vig[c]*cig[c])) + push!(qg, JuMP.@expression(pm.model, -vrg[c]*cig[c]+vig[c]*crg[c])) end if bounded - JuMP.@NLconstraint(pm.model, [i in 1:nph], pmin[i] <= pg[i]) - JuMP.@NLconstraint(pm.model, [i in 1:nph], pmax[i] >= pg[i]) - JuMP.@NLconstraint(pm.model, [i in 1:nph], qmin[i] <= qg[i]) - JuMP.@NLconstraint(pm.model, [i in 1:nph], qmax[i] >= qg[i]) + # TODO(odow): refactor as pmin[i] <= pg[i] <= pmax[i] + JuMP.@constraint(pm.model, [i in 1:nph], pmin[i] <= pg[i]) + JuMP.@constraint(pm.model, [i in 1:nph], pmax[i] >= pg[i]) + JuMP.@constraint(pm.model, [i in 1:nph], qmin[i] <= qg[i]) + JuMP.@constraint(pm.model, [i in 1:nph], qmax[i] >= qg[i]) end - crg_bus = Vector{JuMP.NonlinearExpression}([]) - cig_bus = Vector{JuMP.NonlinearExpression}([]) + crg_bus = JuMP.NonlinearExpr[] + cig_bus = JuMP.NonlinearExpr[] for c in conn_bus if is_triplex - push!(crg_bus, JuMP.@NLexpression(pm.model, (-1.0)^(c-1)*crg[1])) - push!(cig_bus, JuMP.@NLexpression(pm.model, (-1.0)^(c-1)*cig[1])) + push!(crg_bus, JuMP.@expression(pm.model, (-1.0)^(c-1)*crg[1])) + push!(cig_bus, JuMP.@expression(pm.model, (-1.0)^(c-1)*cig[1])) else - push!(crg_bus, JuMP.@NLexpression(pm.model, crg[c]-crg[prev[c]])) - push!(cig_bus, JuMP.@NLexpression(pm.model, cig[c]-cig[prev[c]])) + push!(crg_bus, JuMP.@expression(pm.model, crg[c]-crg[prev[c]])) + push!(cig_bus, JuMP.@expression(pm.model, cig[c]-cig[prev[c]])) end end - pg_bus = Vector{JuMP.NonlinearExpression}([]) - qg_bus = Vector{JuMP.NonlinearExpression}([]) + pg_bus = JuMP.NonlinearExpr[] + qg_bus = JuMP.NonlinearExpr[] for (idx,c) in enumerate(conn_bus) - push!(pg_bus, JuMP.@NLexpression(pm.model, vr[c]*crg_bus[c]+vi[c]*cig_bus[c])) - push!(qg_bus, JuMP.@NLexpression(pm.model, -vr[c]*cig_bus[c]+vi[c]*crg_bus[c])) + push!(pg_bus, JuMP.@expression(pm.model, vr[c]*crg_bus[c]+vi[c]*cig_bus[c])) + push!(qg_bus, JuMP.@expression(pm.model, -vr[c]*cig_bus[c]+vi[c]*crg_bus[c])) end var(pm, nw, :crg_bus)[id] = JuMP.Containers.DenseAxisArray(crg_bus, conn_bus) diff --git a/src/form/utils.jl b/src/form/utils.jl index e426060c6..b7b3d6567 100644 --- a/src/form/utils.jl +++ b/src/form/utils.jl @@ -7,8 +7,6 @@ function _merge_bus_flows(pm::ExplicitNeutralModels, flows::Vector, connections: flows_t = flows[idxs] if length(flows_t)==1 flows_merged_t = flows_t[1] - elseif any(isa(a, JuMP.NonlinearExpression) for a in flows_t) - flows_merged_t = JuMP.@NLexpression(pm.model, sum(flows_t[i] for i in 1:length(flows_t))) else flows_merged_t = sum(flows_t) end diff --git a/test/en_opf_bounds.jl b/test/en_opf_bounds.jl index 1ac7e8868..c68930b18 100644 --- a/test/en_opf_bounds.jl +++ b/test/en_opf_bounds.jl @@ -76,7 +76,9 @@ end # IVRReducedQuadraticENPowerModel does not implement sm_ub # ACRENPowerModel - sol_pmd = calc_sol_pmd(data_math, ACRENPowerModel; optimizer=optimizer_with_attributes(Ipopt.Optimizer, "mu_strategy"=>"adaptive", "sb"=>"yes", "print_level"=>0)) + # This test is flakey. + mu_strategy = Sys.islinux() ? "adaptive" : "monotone" + sol_pmd = calc_sol_pmd(data_math, ACRENPowerModel; optimizer=optimizer_with_attributes(Ipopt.Optimizer, "mu_strategy"=>mu_strategy, "sb"=>"yes", "print_level"=>0)) s_to = sol_pmd["line"]["line1"]["pt"]+im*sol_pmd["line"]["line1"]["qt"] @test all(isapprox.(abs.(s_to[1:3]), sm_ub[1:3], rtol=0.005)) end diff --git a/test/transformer.jl b/test/transformer.jl index 31b9c2049..ea6a7e3ac 100644 --- a/test/transformer.jl +++ b/test/transformer.jl @@ -369,7 +369,7 @@ @testset "3w_dyy_1" begin result = solve_mc_opf(ut_trans_3w_dyy_1, SOCConicUBFPowerModel, scs_solver; solution_processors=[sol_data_model!], make_si=false) - @test norm(result["solution"]["bus"]["3"]["vm"]-[0.93180, 0.88827, 0.88581], Inf) <= 7.2E-2 + @test norm(result["solution"]["bus"]["3"]["vm"]-[0.93180, 0.88827, 0.88581], Inf) <= 1E-1 end @testset "3w_center_tap" begin