From 5d3b295ddfb6b0e3ce064a1a21890c4a9387c278 Mon Sep 17 00:00:00 2001 From: Fredrik Bagge Carlson Date: Mon, 27 May 2024 15:18:22 +0200 Subject: [PATCH 1/2] handle units for analysis points --- src/Blocks/analysis_points.jl | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/src/Blocks/analysis_points.jl b/src/Blocks/analysis_points.jl index c5ee4b3a3..8d73e70f8 100644 --- a/src/Blocks/analysis_points.jl +++ b/src/Blocks/analysis_points.jl @@ -18,6 +18,10 @@ function Base.hash(ap::AnalysisPoint, seed::UInt) h3 ⊻ (0xd29cdc51aa6562d4 % UInt) end +function ModelingToolkit.get_unit(ap::AnalysisPoint) + ModelingToolkit.unitless +end + function ap_var(sys) if hasproperty(sys, :u) # collect to turn symbolic arrays into arrays of symbols From 35d485ea40fd33a3510e3baa69ef154b17742fe3 Mon Sep 17 00:00:00 2001 From: Fredrik Bagge Carlson Date: Mon, 27 May 2024 15:19:26 +0200 Subject: [PATCH 2/2] add test --- test/Blocks/test_analysis_points.jl | 24 ++++++++++++++++++++++++ 1 file changed, 24 insertions(+) diff --git a/test/Blocks/test_analysis_points.jl b/test/Blocks/test_analysis_points.jl index 0d3ac7122..5e245a0f1 100644 --- a/test/Blocks/test_analysis_points.jl +++ b/test/Blocks/test_analysis_points.jl @@ -374,3 +374,27 @@ L = CS.ss(matrices...) |> sminreal matrices, _ = linearize(sys_outer, [:inner_plant_input], [:inner_plant_output]) G = CS.ss(matrices...) |> sminreal @test tf(G) ≈ tf(CS.feedback(Ps, Cs)) + +## unit test +@mtkmodel SingleIntegrator begin + @parameters begin + to_mps = 1, [unit = u"m/s"] + end + @variables begin + (x(t) = 0), [unit = u"m", description = "Position"] + control(t), [unit = u"m/s", description = "Control Velocity"] + end + @components begin + uIn = RealInput() + c1 = Blocks.Constant(k = 1) + end + @equations begin + control ~ (uIn.u) * to_mps + D(x) ~ control + connect(c1.output, :test_point, uIn) + end +end +@mtkbuild single_integrator = SingleIntegrator() +prob = ODEProblem(single_integrator, [], (0, 10)) +sol = solve(prob, Tsit5()) +@test sol(10)[] ≈ 10