Skip to content

Commit 924169b

Browse files
fix: fix conversion of solved array parameters to variables in initialization
1 parent ec4c32e commit 924169b

File tree

1 file changed

+9
-0
lines changed

1 file changed

+9
-0
lines changed

src/systems/nonlinear/initializesystem.jl

Lines changed: 9 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -193,6 +193,15 @@ function generate_initializesystem(sys::AbstractSystem;
193193
append!(eqs_ics, trueobs)
194194
end
195195

196+
# even if `p => tovar(p)` is in `paramsubs`, `isparameter(p[1]) === true` after substitution
197+
# so add scalarized versions as well
198+
for k in collect(keys(paramsubs))
199+
symbolic_type(k) == ArraySymbolic() || continue
200+
for i in eachindex(k)
201+
paramsubs[k[i]] = paramsubs[k][i]
202+
end
203+
end
204+
196205
eqs_ics = Symbolics.substitute.(eqs_ics, (paramsubs,))
197206
if is_time_dependent(sys)
198207
vars = [vars; collect(values(paramsubs))]

0 commit comments

Comments
 (0)