Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

GLM speed calculations for coupled semidiscretizations #1835

Merged
merged 86 commits into from
May 3, 2024
Merged
Show file tree
Hide file tree
Changes from 16 commits
Commits
Show all changes
86 commits
Select commit Hold shift + click to select a range
00d1e51
Added capability to the glm speed calculations to cope
iomsn Feb 6, 2024
9191121
Merge branch 'main' into sc/glm_speed_coupled_semis
SimonCan Feb 6, 2024
00010e7
Merge branch 'main' into sc/glm_speed_coupled_semis
SimonCan Feb 7, 2024
d37ab18
Update src/callbacks_step/glm_speed.jl
SimonCan Feb 7, 2024
02afd09
Update src/callbacks_step/glm_speed.jl
SimonCan Feb 7, 2024
d00e1c7
Corrected glm_speed issue for non-coupling simulations.
iomsn Feb 7, 2024
57327d9
Merge branch 'sc/glm_speed_coupled_semis' of https://github.com/trixi…
iomsn Feb 7, 2024
19e271d
Applied autoformatter.
iomsn Feb 8, 2024
52c674f
Added comment to glm speed.
iomsn Feb 8, 2024
8136c5f
Added temptative example elixir for coupled GlmMhd equations.
iomsn Feb 12, 2024
06f3a96
Added ability to deal with both, single semidiscretizations and multi…
iomsn Feb 13, 2024
228768b
Merge branch 'main' into sc/glm_speed_coupled_semis
SimonCan Feb 15, 2024
8dea565
Added temporary fix for flux_nonconservative_powell function for
iomsn Feb 15, 2024
7f7a0ff
Fix in cumputing boundary fluxes in coupled domains
iomsn Feb 15, 2024
c098a51
Merge branch 'sc/glm_speed_coupled_semis' of https://github.com/trixi…
iomsn Feb 15, 2024
21717ba
Applied autoformatter.
iomsn Feb 15, 2024
0a346c5
Update src/callbacks_step/glm_speed.jl
SimonCan Feb 16, 2024
199106b
Update examples/structured_2d_dgsem/elixir_mhd_coupled.jl
SimonCan Feb 16, 2024
fb9b057
Merge branch 'main' into sc/glm_speed_coupled_semis
SimonCan Feb 19, 2024
739b550
Merge branch 'main' into sc/glm_speed_coupled_semis
SimonCan Feb 22, 2024
927406a
Merge branch 'main' into sc/glm_speed_coupled_semis
SimonCan Feb 26, 2024
cf51f90
Applied autoformatter.
iomsn Feb 28, 2024
5ac5bde
Added coupled 2d GLM-MHD simulations on structured grid in the tests.
iomsn Feb 28, 2024
dc81243
Added comment on adding non-conservative fluxes to the conservative f…
iomsn Feb 28, 2024
cda53ad
Changed the coupled GLM-MHD 2d example to an Alfven wave system.
iomsn Feb 28, 2024
73551c5
Removed redefined non-conservative Powell flux.
iomsn Feb 28, 2024
7a584a5
Redefined non-conservative Powell flux so it can be used with more ar…
iomsn Feb 28, 2024
28e7e7b
Debugged the extension of flux_nonconservative_powell.
iomsn Feb 28, 2024
6cce841
Merge branch 'main' into sc/glm_speed_coupled_semis
SimonCan Mar 7, 2024
1e64eca
Added explicit periodicity to the meshes.
iomsn Mar 7, 2024
55a67ac
Merge branch 'main' into sc/glm_speed_coupled_semis
SimonCan Mar 11, 2024
fd0055f
Applied autoformatter.
iomsn Mar 11, 2024
b686df7
Merge branch 'sc/glm_speed_coupled_semis' of https://github.com/trixi…
iomsn Mar 11, 2024
0ddaaae
Applied updated autoformatter.
iomsn Mar 12, 2024
8d8cfca
Fixed issue with the GlmSpeedCallback printing format.
iomsn Mar 13, 2024
7c3248c
Applied autoformatter.
iomsn Mar 13, 2024
2114a81
Update src/callbacks_step/glm_speed.jl
SimonCan Mar 14, 2024
630c91e
Clarified what we mean by semi_index.
iomsn Mar 14, 2024
55cf043
Update src/semidiscretization/semidiscretization_coupled.jl
SimonCan Mar 14, 2024
4966c4f
Merge branch 'sc/glm_speed_coupled_semis' of https://github.com/trixi…
iomsn Mar 14, 2024
e8e2aba
Applied autoformatter.
iomsn Mar 14, 2024
ecd5ec7
Merge branch 'main' into sc/glm_speed_coupled_semis
SimonCan Mar 15, 2024
8503e9b
Merge branch 'main' into sc/glm_speed_coupled_semis
SimonCan Mar 19, 2024
6bbaa32
Merge branch 'main' into sc/glm_speed_coupled_semis
SimonCan Mar 21, 2024
d2469f1
Merge branch 'main' into sc/glm_speed_coupled_semis
SimonCan Mar 22, 2024
4889cfe
Merge branch 'main' into sc/glm_speed_coupled_semis
SimonCan Mar 29, 2024
3d879d0
Merge branch 'main' into sc/glm_speed_coupled_semis
SimonCan Apr 2, 2024
5679230
Added how to to GLM speed callbacks in coupled systems.
SimonCan Apr 2, 2024
b186b8d
Added news item about the GLM speed calculation in coupled systems.
SimonCan Apr 2, 2024
2f8cd52
Merge branch 'main' into sc/glm_speed_coupled_semis
SimonCan Apr 3, 2024
7086f76
Update NEWS.md
SimonCan Apr 15, 2024
5a0f83b
Merge branch 'main' into sc/glm_speed_coupled_semis
SimonCan Apr 15, 2024
15634bc
Throw a descriptive error message if the equations of subtype Abstrac…
SimonCan Apr 15, 2024
1962b36
Merge branch 'main' into sc/glm_speed_coupled_semis
SimonCan Apr 16, 2024
28a3c06
Added checking for semi_indices in case of SemidiscretizationCoupled.
SimonCan Apr 16, 2024
07e6f38
Added index of semidiscretization for GLM speed calculation.
SimonCan Apr 16, 2024
f6a917e
Merge branch 'sc/glm_speed_coupled_semis' of https://github.com/trixi…
SimonCan Apr 16, 2024
f3b18c2
Aplplied autoformatter.
SimonCan Apr 17, 2024
c952f08
Applied autoformatter.
SimonCan Apr 17, 2024
aa79c28
Update docs/src/multi-physics_coupling.md
SimonCan Apr 24, 2024
4acb302
Update docs/src/multi-physics_coupling.md
SimonCan Apr 24, 2024
c3c7936
Update src/semidiscretization/semidiscretization_coupled.jl
SimonCan Apr 24, 2024
4715e52
Update src/callbacks_step/glm_speed.jl
SimonCan Apr 24, 2024
6cd1baf
Update src/callbacks_step/glm_speed.jl
SimonCan Apr 24, 2024
8f6c884
Update src/callbacks_step/glm_speed.jl
SimonCan Apr 24, 2024
9653bad
Update src/callbacks_step/glm_speed.jl
SimonCan Apr 24, 2024
ba3a92a
Updated semi_indices for glm speed calculations to Vector.
SimonCan Apr 24, 2024
b1e0bf5
Some refactoring of the GLM speed calculations for coupled systems.
SimonCan Apr 24, 2024
4a85672
Applied autoformatter.
SimonCan Apr 24, 2024
6bd2f87
Update examples/structured_2d_dgsem/elixir_mhd_coupled.jl
SimonCan Apr 25, 2024
9aa89a5
Update src/callbacks_step/glm_speed.jl
SimonCan Apr 25, 2024
7e004c1
Update src/callbacks_step/glm_speed.jl
SimonCan Apr 25, 2024
cfd2e47
Update src/callbacks_step/glm_speed.jl
SimonCan Apr 25, 2024
603f9fe
Update src/callbacks_step/glm_speed.jl
SimonCan Apr 25, 2024
ca011e3
Update src/callbacks_step/glm_speed.jl
SimonCan Apr 25, 2024
a432fb4
Update src/callbacks_step/glm_speed.jl
SimonCan Apr 25, 2024
01b374f
Update src/callbacks_step/glm_speed.jl
SimonCan Apr 25, 2024
c6d196d
Moved the update_cleaning_speed function for semi_coupled::Semidiscre…
SimonCan Apr 25, 2024
5984a2c
Merge branch 'main' into sc/glm_speed_coupled_semis
SimonCan Apr 26, 2024
ff3c0df
Applied autoformatter.
SimonCan Apr 29, 2024
15bad8e
Merge branch 'main' into sc/glm_speed_coupled_semis
SimonCan Apr 29, 2024
e288c54
Merge branch 'main' into sc/glm_speed_coupled_semis
SimonCan Apr 30, 2024
c77d2a4
Merge branch 'main' into sc/glm_speed_coupled_semis
SimonCan May 2, 2024
ccefbf9
Merge branch 'main' into sc/glm_speed_coupled_semis
SimonCan May 2, 2024
1469600
Update src/callbacks_step/glm_speed.jl
SimonCan May 3, 2024
d195d97
Merge branch 'main' into sc/glm_speed_coupled_semis
andrewwinters5000 May 3, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
138 changes: 138 additions & 0 deletions examples/structured_2d_dgsem/elixir_mhd_coupled.jl
Original file line number Diff line number Diff line change
@@ -0,0 +1,138 @@
using OrdinaryDiffEq
using Trixi

###############################################################################
# Coupled semidiscretization of two ideal glmMhd systems using converter functions such that
# they are also coupled across the domain boundaries to generate a periodic system.
#
# In this elixir, we have a square domain that is divided into a left and right half.
# On each half of the domain, a completely independent SemidiscretizationHyperbolic is created for the
# linear ideal glmMhd equations. The four systems are coupled in the x and y-direction.
# For a high-level overview, see also the figure below:
SimonCan marked this conversation as resolved.
Show resolved Hide resolved
#
# (-2, 2) ( 2, 2)
# ┌────────────────────┬────────────────────┐
# │ ↑ periodic ↑ │ ↑ periodic ↑ │
# │ │ │
# │ ========= │ ========= │
# │ system #1 │ system #2 │
# │ ========= │ ========= │
# │ │ │
# │<-- coupled │<-- coupled │
# │ coupled -->│ coupled -->│
# │ │ │
# │ ↓ periodic ↓ │ ↓ periodic ↓ │
# └────────────────────┴────────────────────┘
# (-2, -2) ( 2, -2)


equations = IdealGlmMhdEquations2D(1.4)

cells_per_dimension = (32, 64)

volume_flux = (flux_hindenlang_gassner, flux_nonconservative_powell)
solver = DGSEM(polydeg = 3,
surface_flux = (flux_lax_friedrichs, flux_nonconservative_powell),
volume_integral = VolumeIntegralFluxDifferencing(volume_flux))

function initial_condition_constant(x, t, equations::IdealGlmMhdEquations2D)
rho = 1.0
v1 = 0.0
v2 = 0.0
v3 = 0.0
p = rho^equations.gamma
B1 = 0.0
B2 = 0.0
B3 = 0.0
psi = 0.0
return prim2cons(SVector(rho, v1, v2, v3, p, B1, B2, B3, psi), equations)
end
SimonCan marked this conversation as resolved.
Show resolved Hide resolved

###########
# system #1
###########

initial_condition1 = initial_condition_constant
coordinates_min1 = (-2.0, -2.0)
coordinates_max1 = ( 0.0, 2.0)
mesh1 = StructuredMesh(cells_per_dimension,
coordinates_min1,
coordinates_max1)

coupling_function1 = (x, u, equations_other, equations_own) -> u
boundary_conditions1 = (
x_neg=BoundaryConditionCoupled(2, (:end, :i_forward), Float64, coupling_function1),
x_pos=BoundaryConditionCoupled(2, (:begin, :i_forward), Float64, coupling_function1),
y_neg=boundary_condition_periodic,
y_pos=boundary_condition_periodic,
)

semi1 = SemidiscretizationHyperbolic(mesh1, equations, initial_condition1, solver,
boundary_conditions=boundary_conditions1)

###########
# system #2
###########

initial_condition2 = initial_condition_constant
coordinates_min2 = ( 0.0, -2.0)
coordinates_max2 = ( 2.0, 2.0)
mesh2 = StructuredMesh(cells_per_dimension,
coordinates_min2,
coordinates_max2)

coupling_function2 = (x, u, equations_other, equations_own) -> u
boundary_conditions2 = (
x_neg=BoundaryConditionCoupled(1, (:end, :i_forward), Float64, coupling_function2),
x_pos=BoundaryConditionCoupled(1, (:begin, :i_forward), Float64, coupling_function2),
y_neg=boundary_condition_periodic,
y_pos=boundary_condition_periodic,
)

semi2 = SemidiscretizationHyperbolic(mesh2, equations, initial_condition2, solver,
boundary_conditions=boundary_conditions2)

# Create a semidiscretization that bundles all the semidiscretizations.
semi = SemidiscretizationCoupled(semi1, semi2)

###############################################################################
# ODE solvers, callbacks etc.

tspan = (0.0, 0.1)
ode = semidiscretize(semi, tspan)

summary_callback = SummaryCallback()

analysis_interval = 100

analysis_callback1 = AnalysisCallback(semi1, interval=100)
analysis_callback2 = AnalysisCallback(semi2, interval=100)
analysis_callback = AnalysisCallbackCoupled(semi, analysis_callback1, analysis_callback2)

alive_callback = AliveCallback(analysis_interval=analysis_interval)

save_solution = SaveSolutionCallback(interval=50,
save_initial_solution=true,
save_final_solution=true,
solution_variables=cons2prim)

cfl = 1.0

stepsize_callback = StepsizeCallback(cfl=cfl)

glm_speed_callback = GlmSpeedCallback(glm_scale=0.5, cfl=cfl, semi_indices=tuple(1))

callbacks = CallbackSet(summary_callback,
analysis_callback, alive_callback,
save_solution,
stepsize_callback,
glm_speed_callback)


###############################################################################
# run the simulation

sol = solve(ode, CarpenterKennedy2N54(williamson_condition=false),
dt=0.01, # solve needs some value here but it will be overwritten by the stepsize_callback
save_everystep=false, callback=callbacks);
summary_callback() # print the timer summary
44 changes: 31 additions & 13 deletions src/callbacks_step/glm_speed.jl
Original file line number Diff line number Diff line change
Expand Up @@ -6,26 +6,30 @@
#! format: noindent

"""
GlmSpeedCallback(; glm_scale=0.5, cfl)
GlmSpeedCallback(; glm_scale=0.5, cfl, semi_indices=())

Update the divergence cleaning wave speed `c_h` according to the time step
computed in [`StepsizeCallback`](@ref) for the ideal GLM-MHD equations.
The `cfl` number should be set to the same value as for the time step size calculation. The
`glm_scale` ensures that the GLM wave speed is lower than the fastest physical waves in the MHD
solution and should thus be set to a value within the interval [0,1]. Note that `glm_scale = 0`
deactivates the divergence cleaning.
In case of a couplings semidiscretization specify for which semi_index the divergence
cleaning should be applied to.
SimonCan marked this conversation as resolved.
Show resolved Hide resolved
"""
struct GlmSpeedCallback{RealT <: Real}
glm_scale::RealT
cfl::RealT
semi_indices::Tuple
SimonCan marked this conversation as resolved.
Show resolved Hide resolved
end

function Base.show(io::IO, cb::DiscreteCallback{<:Any, <:GlmSpeedCallback})
@nospecialize cb # reduce precompilation time

glm_speed_callback = cb.affect!
@unpack glm_scale, cfl = glm_speed_callback
print(io, "GlmSpeedCallback(glm_scale=", glm_scale, ", cfl=", cfl, ")")
@unpack glm_scale, cfl, semi_indices = glm_speed_callback
print(io, "GlmSpeedCallback(glm_scale=", glm_scale, ", cfl=", cfl, "semi_indices=",
semi_indices, ")")
end

function Base.show(io::IO, ::MIME"text/plain",
Expand All @@ -40,15 +44,16 @@ function Base.show(io::IO, ::MIME"text/plain",
setup = [
"GLM wave speed scaling" => glm_speed_callback.glm_scale,
"Expected CFL number" => glm_speed_callback.cfl,
# "Coupled semidiscretization indices" => glm_speed_callback.semi_indices,
SimonCan marked this conversation as resolved.
Show resolved Hide resolved
]
summary_box(io, "GlmSpeedCallback", setup)
end
end

function GlmSpeedCallback(; glm_scale = 0.5, cfl)
function GlmSpeedCallback(; glm_scale = 0.5, cfl, semi_indices = ())
@assert 0<=glm_scale<=1 "glm_scale must be between 0 and 1"

glm_speed_callback = GlmSpeedCallback(glm_scale, cfl)
glm_speed_callback = GlmSpeedCallback(glm_scale, cfl, semi_indices)

DiscreteCallback(glm_speed_callback, glm_speed_callback, # the first one is the condition, the second the affect!
save_positions = (false, false),
Expand All @@ -69,17 +74,30 @@ end
@inline function (glm_speed_callback::GlmSpeedCallback)(integrator)
dt = get_proposed_dt(integrator)
semi = integrator.p
mesh, equations, solver, cache = mesh_equations_solver_cache(semi)
@unpack glm_scale, cfl = glm_speed_callback

# compute time step for GLM linear advection equation with c_h=1 (redone due to the possible AMR)
c_h_deltat = calc_dt_for_cleaning_speed(cfl, mesh, equations, solver, cache)
@unpack glm_scale, cfl, semi_indices = glm_speed_callback

# c_h is proportional to its own time step divided by the complete MHD time step
equations.c_h = glm_scale * c_h_deltat / dt
# Make sure we can handle multiple semidiscretizationis in coupled simulations.
if length(semi_indices) == 0
semis = tuple(semi)
semi_indices = (1)
else
semis = semi.semis
end

for semi_index in semi_indices
semi = semis[semi_index]
mesh, equations, solver, cache = mesh_equations_solver_cache(semi)

# avoid re-evaluating possible FSAL stages
u_modified!(integrator, false)
# compute time step for GLM linear advection equation with c_h=1 (redone due to the possible AMR)
c_h_deltat = calc_dt_for_cleaning_speed(cfl, mesh, equations, solver, cache)

# c_h is proportional to its own time step divided by the complete MHD time step
equations.c_h = glm_scale * c_h_deltat / dt

# avoid re-evaluating possible FSAL stages
u_modified!(integrator, false)
end
SimonCan marked this conversation as resolved.
Show resolved Hide resolved

return nothing
end
Expand Down
35 changes: 35 additions & 0 deletions src/equations/ideal_glm_mhd_2d.jl
Original file line number Diff line number Diff line change
Expand Up @@ -281,6 +281,41 @@ end
return f
end

@inline function flux_nonconservative_powell(u_ll, u_rr,
normal_direction_ll::AbstractVector,
equations::IdealGlmMhdEquations2D)
SimonCan marked this conversation as resolved.
Show resolved Hide resolved
rho_ll, rho_v1_ll, rho_v2_ll, rho_v3_ll, rho_e_ll, B1_ll, B2_ll, B3_ll, psi_ll = u_ll
rho_rr, rho_v1_rr, rho_v2_rr, rho_v3_rr, rho_e_rr, B1_rr, B2_rr, B3_rr, psi_rr = u_rr

v1_ll = rho_v1_ll / rho_ll
v2_ll = rho_v2_ll / rho_ll
v3_ll = rho_v3_ll / rho_ll
v_dot_B_ll = v1_ll * B1_ll + v2_ll * B2_ll + v3_ll * B3_ll

# Note that `v_dot_n_ll` uses the `normal_direction_ll` (contravariant vector
# at the same node location) while `B_dot_n_rr` uses the averaged normal
# direction. The reason for this is that `v_dot_n_ll` depends only on the left
# state and multiplies some gradient while `B_dot_n_rr` is used to compute
# the divergence of B.
SimonCan marked this conversation as resolved.
Show resolved Hide resolved
v_dot_n_ll = v1_ll * normal_direction_ll[1] + v2_ll * normal_direction_ll[2]
B_dot_n_rr = B1_rr * normal_direction_ll[1] +
B2_rr * normal_direction_ll[2]

# Powell nonconservative term: (0, B_1, B_2, B_3, v⋅B, v_1, v_2, v_3, 0)
# Galilean nonconservative term: (0, 0, 0, 0, ψ v_{1,2}, 0, 0, 0, v_{1,2})
f = SVector(0,
B1_ll * B_dot_n_rr,
B2_ll * B_dot_n_rr,
B3_ll * B_dot_n_rr,
v_dot_B_ll * B_dot_n_rr + v_dot_n_ll * psi_ll * psi_rr,
v1_ll * B_dot_n_rr,
v2_ll * B_dot_n_rr,
v3_ll * B_dot_n_rr,
v_dot_n_ll * psi_rr)

return f
end

"""
flux_nonconservative_powell_local_symmetric(u_ll, u_rr,
orientation::Integer,
Expand Down
18 changes: 14 additions & 4 deletions src/semidiscretization/semidiscretization_coupled.jl
Original file line number Diff line number Diff line change
Expand Up @@ -435,10 +435,20 @@ function (boundary_condition::BoundaryConditionCoupled)(u_inner, orientation, di
Val(nvariables(equations))))

# Calculate boundary flux
if iseven(direction) # u_inner is "left" of boundary, u_boundary is "right" of boundary
flux = surface_flux_function(u_inner, u_boundary, orientation, equations)
else # u_boundary is "left" of boundary, u_inner is "right" of boundary
flux = surface_flux_function(u_boundary, u_inner, orientation, equations)
if surface_flux_function isa Tuple
if iseven(direction) # u_inner is "left" of boundary, u_boundary is "right" of boundary
flux = surface_flux_function[1](u_inner, u_boundary, orientation, equations) +
0.5 * surface_flux_function[2](u_inner, u_boundary, orientation, equations)
else # u_boundary is "left" of boundary, u_inner is "right" of boundary
flux = surface_flux_function[1](u_boundary, u_inner, orientation, equations) +
0.5 * surface_flux_function[2](u_boundary, u_inner, orientation, equations)
end
else
SimonCan marked this conversation as resolved.
Show resolved Hide resolved
if iseven(direction) # u_inner is "left" of boundary, u_boundary is "right" of boundary
flux = surface_flux_function(u_inner, u_boundary, orientation, equations)
else # u_boundary is "left" of boundary, u_inner is "right" of boundary
flux = surface_flux_function(u_boundary, u_inner, orientation, equations)
end
end

return flux
Expand Down
Loading