From b37f74760727b5d3d79a5c6f8c2dbae6571275e1 Mon Sep 17 00:00:00 2001 From: huiyuxie Date: Tue, 23 Jul 2024 19:14:47 -1000 Subject: [PATCH 1/3] start --- src/equations/traffic_flow_lwr_1d.jl | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/equations/traffic_flow_lwr_1d.jl b/src/equations/traffic_flow_lwr_1d.jl index a4d2613a5c8..914dbaa4c35 100644 --- a/src/equations/traffic_flow_lwr_1d.jl +++ b/src/equations/traffic_flow_lwr_1d.jl @@ -106,11 +106,11 @@ end @inline cons2entropy(u, equations::TrafficFlowLWREquations1D) = u # Calculate entropy for a conservative state `cons` -@inline entropy(u::Real, ::TrafficFlowLWREquations1D) = 0.5 * u^2 +@inline entropy(u::Real, ::TrafficFlowLWREquations1D) = 0.5f0 * u^2 @inline entropy(u, equations::TrafficFlowLWREquations1D) = entropy(u[1], equations) # Calculate total energy for a conservative state `cons` -@inline energy_total(u::Real, ::TrafficFlowLWREquations1D) = 0.5 * u^2 +@inline energy_total(u::Real, ::TrafficFlowLWREquations1D) = 0.5f0 * u^2 @inline energy_total(u, equations::TrafficFlowLWREquations1D) = energy_total(u[1], equations) end # @muladd From b2c7fe1489632191d0849dc8db2afe6a5ef6efe2 Mon Sep 17 00:00:00 2001 From: huiyuxie Date: Thu, 25 Jul 2024 17:18:38 -1000 Subject: [PATCH 2/3] complete equation --- src/equations/traffic_flow_lwr_1d.jl | 26 ++++++++++++++------------ 1 file changed, 14 insertions(+), 12 deletions(-) diff --git a/src/equations/traffic_flow_lwr_1d.jl b/src/equations/traffic_flow_lwr_1d.jl index 914dbaa4c35..948b9da716f 100644 --- a/src/equations/traffic_flow_lwr_1d.jl +++ b/src/equations/traffic_flow_lwr_1d.jl @@ -36,11 +36,12 @@ varnames(::typeof(cons2prim), ::TrafficFlowLWREquations1D) = ("car-density",) A smooth initial condition used for convergence tests. """ function initial_condition_convergence_test(x, t, equations::TrafficFlowLWREquations1D) - c = 2.0 - A = 1.0 + RealT = eltype(x) + c = 2 + A = 1 L = 1 f = 1 / L - omega = 2 * pi * f + omega = 2 * convert(RealT, pi) * f scalar = c + A * sin(omega * (x[1] - t)) return SVector(scalar) @@ -55,11 +56,12 @@ Source terms used for convergence tests in combination with @inline function source_terms_convergence_test(u, x, t, equations::TrafficFlowLWREquations1D) # Same settings as in `initial_condition` - c = 2.0 - A = 1.0 + RealT = eltype(x) + c = 2 + A = 1 L = 1 f = 1 / L - omega = 2 * pi * f + omega = 2 * convert(RealT, pi) * f du = omega * cos(omega * (x[1] - t)) * (-1 - equations.v_max * (2 * sin(omega * (x[1] - t)) + 3)) @@ -68,21 +70,21 @@ end # Calculate 1D flux in for a single point @inline function flux(u, orientation::Integer, equations::TrafficFlowLWREquations1D) - return SVector(equations.v_max * u[1] * (1.0 - u[1])) + return SVector(equations.v_max * u[1] * (1 - u[1])) end # Calculate maximum wave speed for local Lax-Friedrichs-type dissipation @inline function max_abs_speed_naive(u_ll, u_rr, orientation::Integer, equations::TrafficFlowLWREquations1D) - λ_max = max(abs(equations.v_max * (1.0 - 2 * u_ll[1])), - abs(equations.v_max * (1.0 - 2 * u_rr[1]))) + λ_max = max(abs(equations.v_max * (1 - 2 * u_ll[1])), + abs(equations.v_max * (1 - 2 * u_rr[1]))) end # Calculate minimum and maximum wave speeds for HLL-type fluxes @inline function min_max_speed_naive(u_ll, u_rr, orientation::Integer, equations::TrafficFlowLWREquations1D) - jac_L = equations.v_max * (1.0 - 2 * u_ll[1]) - jac_R = equations.v_max * (1.0 - 2 * u_rr[1]) + jac_L = equations.v_max * (1 - 2 * u_ll[1]) + jac_R = equations.v_max * (1 - 2 * u_rr[1]) λ_min = min(jac_L, jac_R) λ_max = max(jac_L, jac_R) @@ -96,7 +98,7 @@ end end @inline function max_abs_speeds(u, equations::TrafficFlowLWREquations1D) - return (abs(equations.v_max * (1.0 - 2 * u[1])),) + return (abs(equations.v_max * (1 - 2 * u[1])),) end # Convert conservative variables to primitive From d171dec8c9e7ee8d058c02db40d2b634a5459518 Mon Sep 17 00:00:00 2001 From: huiyuxie Date: Thu, 25 Jul 2024 21:36:07 -1000 Subject: [PATCH 3/3] complete test --- src/equations/traffic_flow_lwr_1d.jl | 4 ++-- test/test_type.jl | 33 ++++++++++++++++++++++++++++ 2 files changed, 35 insertions(+), 2 deletions(-) diff --git a/src/equations/traffic_flow_lwr_1d.jl b/src/equations/traffic_flow_lwr_1d.jl index 948b9da716f..c41fbb2809e 100644 --- a/src/equations/traffic_flow_lwr_1d.jl +++ b/src/equations/traffic_flow_lwr_1d.jl @@ -40,7 +40,7 @@ function initial_condition_convergence_test(x, t, equations::TrafficFlowLWREquat c = 2 A = 1 L = 1 - f = 1 / L + f = 1.0f0 / L omega = 2 * convert(RealT, pi) * f scalar = c + A * sin(omega * (x[1] - t)) @@ -60,7 +60,7 @@ Source terms used for convergence tests in combination with c = 2 A = 1 L = 1 - f = 1 / L + f = 1.0f0 / L omega = 2 * convert(RealT, pi) * f du = omega * cos(omega * (x[1] - t)) * (-1 - equations.v_max * (2 * sin(omega * (x[1] - t)) + 3)) diff --git a/test/test_type.jl b/test/test_type.jl index 34fef14fee3..6c51460e6d9 100644 --- a/test/test_type.jl +++ b/test/test_type.jl @@ -2194,6 +2194,39 @@ isdir(outdir) && rm(outdir, recursive = true) @test typeof(@inferred lake_at_rest_error(u, equations)) == RealT end end + + @timed_testset "Traffic Flow LWR 1D" begin + for RealT in (Float32, Float64) + equations = @inferred TrafficFlowLWREquations1D(RealT(1)) + + x = SVector(zero(RealT)) + t = zero(RealT) + u = u_ll = u_rr = SVector(one(RealT)) + orientation = 1 + c = one(RealT) + + @test eltype(@inferred initial_condition_convergence_test(x, t, equations)) == + RealT + @test eltype(@inferred source_terms_convergence_test(u, x, t, equations)) == + RealT + + @test eltype(@inferred flux(u, orientation, equations)) == RealT + + @test typeof(@inferred max_abs_speed_naive(u_ll, u_rr, orientation, equations)) == + RealT + @test eltype(@inferred min_max_speed_naive(u_ll, u_rr, orientation, equations)) == + RealT + @test eltype(@inferred min_max_speed_davis(u_ll, u_rr, orientation, equations)) == + RealT + @test eltype(@inferred Trixi.max_abs_speeds(u, equations)) == RealT + @test eltype(@inferred cons2prim(u, equations)) == RealT + @test eltype(@inferred cons2entropy(u, equations)) == RealT + @test typeof(@inferred entropy(c, equations)) == RealT + @test typeof(@inferred entropy(u, equations)) == RealT + @test typeof(@inferred energy_total(c, equations)) == RealT + @test typeof(@inferred energy_total(u, equations)) == RealT + end + end end end # module