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 84 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
1 change: 1 addition & 0 deletions NEWS.md
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@ for human readability.
to 1D and 3D on `TreeMesh`.
- Implementation of 1D Linearized Euler Equations.
- New analysis callback for 2D `P4estMesh` to compute integrated quantities along a boundary surface, e.g., pressure lift and drag coefficients.
- Optional tuple parameter for `GlmSpeedCallback` called `semi_indices` to specify for which semidiscretization of a `SemidiscretizationCoupled` we need to update the GLM speed.

## Changes when updating to v0.7 from v0.6.x

Expand Down
11 changes: 11 additions & 0 deletions docs/src/multi-physics_coupling.md
Original file line number Diff line number Diff line change
Expand Up @@ -36,6 +36,17 @@ By passing the equations we can make use of their parameters, if they are requir
Examples can be seen in `examples/structured_2d_dgsem/elixir_advection_coupled.jl`.


## GlmSpeedCallback for coupled MHD simulations

When simulating an MHD system and the [`GlmSpeedCallback`](@ref) is required,
we need to specify for which semidiscretization we need the GLM speed updated.
This can be done with an additional parameter called `semi_indices`, which
is a tuple containing the semidiscretization indices for all systems
that require the GLM speed updated.

An example elixir can be found at [`examples/structured_2d_dgsem/elixir_mhd_coupled.jl`](https://github.com/trixi-framework/Trixi.jl/blob/main/examples/structured_2d_dgsem/elixir_mhd_coupled.jl).


## Warning about binary compatibility
Currently the coordinate values on the nodes can differ by machine precision when
simulating the mesh and when splitting the mesh in multiple domains.
Expand Down
136 changes: 136 additions & 0 deletions examples/structured_2d_dgsem/elixir_mhd_coupled.jl
Original file line number Diff line number Diff line change
@@ -0,0 +1,136 @@
using OrdinaryDiffEq
using Trixi

###############################################################################
# Two semidiscretizations of the ideal GLM-MHD systems using converter functions such that
# they are 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, an independent SemidiscretizationHyperbolic is created for
# each set of ideal GLM-MHD equations. The two systems are coupled in the x-direction
# and are periodic in the y-direction.
# For a high-level overview, see also the figure below:
#
# (-2, 2) ( 2, 2)
# ┌────────────────────┬────────────────────┐
# │ ↑ periodic ↑ │ ↑ periodic ↑ │
# │ │ │
# │ ========= │ ========= │
# │ system #1 │ system #2 │
# │ ========= │ ========= │
# │ │ │
# │<-- coupled │<-- coupled │
# │ coupled -->│ coupled -->│
# │ │ │
# │ ↓ periodic ↓ │ ↓ periodic ↓ │
# └────────────────────┴────────────────────┘
# (-2, -2) ( 2, -2)

gamma = 5 / 3
equations = IdealGlmMhdEquations2D(gamma)

cells_per_dimension = (32, 64)

# Extend the definition of the non-conservative Powell flux functions.
import Trixi.flux_nonconservative_powell
function flux_nonconservative_powell(u_ll, u_rr,
normal_direction_ll::AbstractVector,
equations::IdealGlmMhdEquations2D)
flux_nonconservative_powell(u_ll, u_rr, normal_direction_ll, normal_direction_ll,
equations)
end
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))

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

initial_condition1 = initial_condition_convergence_test
coordinates_min1 = (-1 / sin(pi / 4), -1 / sin(pi / 4))
coordinates_max1 = (0.0, 1 / sin(pi / 4))
mesh1 = StructuredMesh(cells_per_dimension,
coordinates_min1,
coordinates_max1,
periodicity = (false, true))

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_convergence_test
coordinates_min2 = (0.0, -1 / sin(pi / 4))
coordinates_max2 = (1 / sin(pi / 4), 1 / sin(pi / 4))
mesh2 = StructuredMesh(cells_per_dimension,
coordinates_min2,
coordinates_max2,
periodicity = (false, true))

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 = [1, 2])

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
69 changes: 59 additions & 10 deletions src/callbacks_step/glm_speed.jl
Original file line number Diff line number Diff line change
Expand Up @@ -6,26 +6,34 @@
#! 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 coupled semidiscretizations, specify for which `semi_index`, i.e. index of the
semidiscretization, the divergence cleaning should be applied. See also
[`SemidiscretizationCoupled`](@ref).
Note: `SemidiscretizationCoupled` and all related features are considered experimental and
may change at any time.
"""
struct GlmSpeedCallback{RealT <: Real}
glm_scale::RealT
cfl::RealT
semi_indices::Vector{Int}
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 +48,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,
"Selected semidiscretizations" => glm_speed_callback.semi_indices,
]
summary_box(io, "GlmSpeedCallback", setup)
end
end

function GlmSpeedCallback(; glm_scale = 0.5, cfl)
function GlmSpeedCallback(; glm_scale = 0.5, cfl, semi_indices = Int[])
@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 @@ -65,19 +74,59 @@ function (glm_speed_callback::GlmSpeedCallback)(u, t, integrator)
return true
end

# This method is called as callback after the StepsizeCallback during the time integration.
@inline function (glm_speed_callback::GlmSpeedCallback)(integrator)
dt = get_proposed_dt(integrator)
semi = integrator.p
mesh, equations, solver, cache = mesh_equations_solver_cache(semi)
function update_cleaning_speed!(semi, glm_speed_callback, dt)
@unpack glm_scale, cfl = glm_speed_callback

mesh, equations, solver, cache = mesh_equations_solver_cache(semi)

# 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

return semi
end

function update_cleaning_speed!(semi_coupled::SemidiscretizationCoupled,
glm_speed_callback, dt)
@unpack glm_scale, cfl, semi_indices = glm_speed_callback

if length(semi_indices) == 0
throw("Since you have more than one semidiscretization you need to specify the 'semi_indices' for which the GLM speed needs to be calculated.")
end
SimonCan marked this conversation as resolved.
Show resolved Hide resolved

# Check that all MHD semidiscretizations received a GLM cleaning speed update.
for (semi_index, semi) in enumerate(semi_coupled.semis)
if (typeof(semi.equations) <: AbstractIdealGlmMhdEquations &&
!(semi_index in semi_indices))
error("Equation of semidiscretization $semi_index needs to be included in 'semi_indices' of 'GlmSpeedCallback'.")
end
end

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

# 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
end

return semi_coupled
end
SimonCan marked this conversation as resolved.
Show resolved Hide resolved

# This method is called as callback after the StepsizeCallback during the time integration.
@inline function (glm_speed_callback::GlmSpeedCallback)(integrator)
dt = get_proposed_dt(integrator)
semi = integrator.p

# Call the appropriate update function (this indirection allows to specialize on,
# e.g., the semidiscretization type)
update_cleaning_speed!(semi, glm_speed_callback, dt)
SimonCan marked this conversation as resolved.
Show resolved Hide resolved

# avoid re-evaluating possible FSAL stages
u_modified!(integrator, false)

Expand Down
56 changes: 52 additions & 4 deletions src/semidiscretization/semidiscretization_coupled.jl
Original file line number Diff line number Diff line change
Expand Up @@ -348,6 +348,36 @@ function calculate_dt(u_ode, t, cfl_number, semi::SemidiscretizationCoupled)
return dt
end

function update_cleaning_speed!(semi_coupled::SemidiscretizationCoupled,
glm_speed_callback, dt)
@unpack glm_scale, cfl, semi_indices = glm_speed_callback

if length(semi_indices) == 0
throw("Since you have more than one semidiscretization you need to specify the 'semi_indices' for which the GLM speed needs to be calculated.")
end

# Check that all MHD semidiscretizations received a GLM cleaning speed update.
for (semi_index, semi) in enumerate(semi_coupled.semis)
if (typeof(semi.equations) <: AbstractIdealGlmMhdEquations &&
!(semi_index in semi_indices))
error("Equation of semidiscretization $semi_index needs to be included in 'semi_indices' of 'GlmSpeedCallback'.")
end
end

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

# 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
end

return semi_coupled
end

################################################################################
### Equations
################################################################################
Expand Down Expand Up @@ -435,10 +465,28 @@ 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
# In case of conservative (index 1) and non-conservative (index 2) fluxes,
# add the non-conservative one with a factor of 1/2.
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
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
Loading