From aa1df089add2fce8b669dc4ecbc5e91b24065ecf Mon Sep 17 00:00:00 2001 From: Andrew Leonard Date: Sun, 28 Jul 2024 12:48:24 -0400 Subject: [PATCH 1/2] generate_control_function test and fix --- src/inputoutput.jl | 1 + test/input_output_handling.jl | 10 ++++++++++ 2 files changed, 11 insertions(+) diff --git a/src/inputoutput.jl b/src/inputoutput.jl index e07d2ed976..6ef36cddcc 100644 --- a/src/inputoutput.jl +++ b/src/inputoutput.jl @@ -218,6 +218,7 @@ function generate_control_function(sys::AbstractODESystem, inputs = unbound_inpu inputs = map(x -> time_varying_as_func(value(x), sys), inputs) eqs = [eq for eq in full_equations(sys)] + eqs = map(subs_constants, eqs) if disturbance_inputs !== nothing # Set all disturbance *inputs* to zero (we just want to keep the disturbance state) subs = Dict(disturbance_inputs .=> 0) diff --git a/test/input_output_handling.jl b/test/input_output_handling.jl index 778e02db0a..d5179c2296 100644 --- a/test/input_output_handling.jl +++ b/test/input_output_handling.jl @@ -171,6 +171,16 @@ x = [rand()] u = [rand()] @test f[1](x, u, p, 1) == -x + u +@testset "Constants substitution" begin + @constants c = 2.0 + @variables x(t) + eqs = [D(x) ~ c * x] + @named sys = ODESystem(eqs, t, [x], []) + + f, dvs, ps = ModelingToolkit.generate_control_function(sys, simplify = true) + @test f[1]([0.5], nothing, nothing, 0.0) == [1.0] +end + # more complicated system @variables u(t) [input = true] From 7a93c8d10f455058a0c3162962b673c316b15efb Mon Sep 17 00:00:00 2001 From: Andrew Leonard Date: Sun, 28 Jul 2024 20:45:38 -0400 Subject: [PATCH 2/2] move test --- test/input_output_handling.jl | 21 +++++++++++---------- 1 file changed, 11 insertions(+), 10 deletions(-) diff --git a/test/input_output_handling.jl b/test/input_output_handling.jl index d5179c2296..19078bc98c 100644 --- a/test/input_output_handling.jl +++ b/test/input_output_handling.jl @@ -171,16 +171,6 @@ x = [rand()] u = [rand()] @test f[1](x, u, p, 1) == -x + u -@testset "Constants substitution" begin - @constants c = 2.0 - @variables x(t) - eqs = [D(x) ~ c * x] - @named sys = ODESystem(eqs, t, [x], []) - - f, dvs, ps = ModelingToolkit.generate_control_function(sys, simplify = true) - @test f[1]([0.5], nothing, nothing, 0.0) == [1.0] -end - # more complicated system @variables u(t) [input = true] @@ -401,3 +391,14 @@ matrices, ssys = linearize(augmented_sys, io_sys, [x + u * t]; inputs = [u]) @test obsfn([1.0], [2.0], nothing, 3.0) == [7.0] end + +# https://github.com/SciML/ModelingToolkit.jl/issues/2896 +@testset "Constants substitution" begin + @constants c = 2.0 + @variables x(t) + eqs = [D(x) ~ c * x] + @named sys = ODESystem(eqs, t, [x], []) + + f, dvs, ps = ModelingToolkit.generate_control_function(sys, simplify = true) + @test f[1]([0.5], nothing, nothing, 0.0) == [1.0] +end