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

AMR for 1D Parabolic Eqs #1602

Closed
Closed
Show file tree
Hide file tree
Changes from 105 commits
Commits
Show all changes
108 commits
Select commit Hold shift + click to select a range
0bbe913
First try mortars for parabolic terms
DanielDoehring Jul 17, 2023
fb4efa9
Use correct interface values in calc_fstar!
DanielDoehring Jul 17, 2023
db048cb
Format parabolic 2d dgsem
DanielDoehring Jul 17, 2023
f8c3403
Remove unused function parameters
DanielDoehring Jul 18, 2023
e9d16c7
L2 Mortars for 3D DGSEM TreeMesh
DanielDoehring Jul 18, 2023
a9185a5
Format
DanielDoehring Jul 18, 2023
90ce643
Back to original example
DanielDoehring Jul 18, 2023
b37774e
Dispatch 2D DGSEm rhs_parabolic for p4est and classic tree
DanielDoehring Jul 18, 2023
2149cfd
Re-use standard prolong2mortars in gradient comp
DanielDoehring Jul 18, 2023
e0fda81
Merge branch 'main' into MortarsParabolic
ranocha Jul 18, 2023
06a8488
Merge branch 'main' into MortarsParabolic
DanielDoehring Jul 19, 2023
e3ad723
Back to original version
DanielDoehring Jul 19, 2023
b751d40
Merge branch 'MortarsParabolic' of github.com:DanielDoehring/Trixi.jl…
DanielDoehring Jul 19, 2023
567938c
Merge branch 'main' into MortarsParabolic
DanielDoehring Jul 19, 2023
7e732c7
Add tests for L2 mortars for hyp-para
DanielDoehring Jul 20, 2023
1deb7d7
Working branch for amr for parabolic
DanielDoehring Jul 20, 2023
1a26201
Merge branch 'MortarsParabolic' of github.com:DanielDoehring/Trixi.jl…
DanielDoehring Jul 20, 2023
f5b1e62
remove whitespaces
DanielDoehring Jul 20, 2023
2111a9c
remove whitespace
DanielDoehring Jul 20, 2023
caf9529
Remove some println()s
DanielDoehring Jul 20, 2023
eaf0838
add to project
DanielDoehring Jul 20, 2023
e6969cf
Use original analysis callback
DanielDoehring Jul 20, 2023
46ec996
Test Taylor-Green with different integrator
DanielDoehring Jul 20, 2023
051b2bf
Remove whitespace
DanielDoehring Jul 21, 2023
44918bf
remove blank line
DanielDoehring Jul 21, 2023
332fb85
Work in progress
DanielDoehring Jul 23, 2023
04199a4
check coverage status
DanielDoehring Jul 23, 2023
db785d9
Merge branch 'main' into MortarsParabolic
DanielDoehring Jul 23, 2023
290a41f
Stick to CK2N54 for 3D test
DanielDoehring Jul 24, 2023
05cd748
Merge branch 'MortarsParabolic' into AMR_Parabolic
DanielDoehring Jul 24, 2023
cea2100
Working version 1D parabolic AMR
DanielDoehring Jul 24, 2023
f35a398
revert elixirs
DanielDoehring Jul 24, 2023
c478942
revert elixirs
DanielDoehring Jul 24, 2023
6afed8f
revert euler
DanielDoehring Jul 24, 2023
95cd835
whitespace
DanielDoehring Jul 24, 2023
ac37b7e
Merge branch 'main' into MortarsParabolic
DanielDoehring Jul 24, 2023
69a0eaa
Add to authors
DanielDoehring Jul 24, 2023
d7a07b4
Parabolic AMR in 2D
DanielDoehring Jul 24, 2023
af9decc
3D parabolic AMR
DanielDoehring Jul 25, 2023
6dc252b
Merge branch 'main' into MortarsParabolic
DanielDoehring Jul 25, 2023
724fecb
try 3d amr
DanielDoehring Jul 25, 2023
491c923
Add more explicit dispatch
DanielDoehring Jul 25, 2023
5b5d433
Less invasive treatment for mortars and p4est
DanielDoehring Jul 25, 2023
bb68ee3
Revert "Add more explicit dispatch"
DanielDoehring Jul 25, 2023
073612e
Merge branch 'MortarsParabolicP4estCompat' into MortarsParabolic
DanielDoehring Jul 25, 2023
7f816e2
More explicit dispatch
DanielDoehring Jul 25, 2023
6cdca4a
Merge branch 'main' into MortarsParabolic
DanielDoehring Jul 25, 2023
e05d112
Remove additional end
DanielDoehring Jul 25, 2023
38e731d
Merge branch 'MortarsParabolic' of github.com:DanielDoehring/Trixi.jl…
DanielDoehring Jul 25, 2023
a17b1bd
Merge branch 'main' into MortarsParabolic
DanielDoehring Jul 26, 2023
5247b4e
Merge branch 'main' into MortarsParabolic
DanielDoehring Jul 26, 2023
d60c9f5
comment
DanielDoehring Jul 27, 2023
b17d964
Merge branch 'MortarsParabolic' into AMR_Parabolic
DanielDoehring Jul 27, 2023
14025d2
remove tabs
DanielDoehring Jul 27, 2023
6e9737b
undo whitespaces
DanielDoehring Jul 27, 2023
e539f41
Merge branch 'main' into MortarsParabolic
ranocha Jul 28, 2023
a414d7c
Merge branch 'main' into AMR_Parabolic
DanielDoehring Jul 28, 2023
ebdbbc6
Remove old stuff
DanielDoehring Jul 28, 2023
c1db7ac
Remove doubled implementations
DanielDoehring Jul 28, 2023
be3b067
kepp main updated with true main
DanielDoehring Jul 28, 2023
3a82e4a
Add comment
DanielDoehring Jul 29, 2023
83b54f8
Merge branch 'MortarsParabolic' of github.com:DanielDoehring/Trixi.jl…
DanielDoehring Jul 29, 2023
5650162
Merge branch 'main' into MortarsParabolic
DanielDoehring Jul 29, 2023
e66b831
comment parabolic 3d
DanielDoehring Jul 29, 2023
1c8efd5
Merge branch 'main' into MortarsParabolic
DanielDoehring Jul 30, 2023
b7bd74f
whitespace
DanielDoehring Jul 30, 2023
797d2d5
Merge branch 'MortarsParabolic' of github.com:DanielDoehring/Trixi.jl…
DanielDoehring Jul 30, 2023
06a4196
Avoid allocations in parabolic boundary fluxes
DanielDoehring Jul 31, 2023
7f9c752
Merge branch 'main' into main
DanielDoehring Jul 31, 2023
6ac6011
Merge branch 'main' into MortarsParabolic
DanielDoehring Aug 1, 2023
1d58857
Merge branch 'main' into AMR_Parabolic
DanielDoehring Aug 1, 2023
151fe52
Merge branch 'MortarsParabolic' into AMR_Parabolic
DanielDoehring Aug 1, 2023
c9bb0ee
Update src/solvers/dgsem_tree/dg_2d_parabolic.jl
DanielDoehring Aug 1, 2023
d7f2568
Update src/solvers/dgsem_tree/dg_3d_parabolic.jl
DanielDoehring Aug 1, 2023
a1f3e99
Update src/solvers/dgsem_tree/dg_3d_parabolic.jl
DanielDoehring Aug 1, 2023
207b253
Merge branch 'MortarsParabolic' of github.com:DanielDoehring/Trixi.jl…
DanielDoehring Aug 1, 2023
7162833
try to find allocations
DanielDoehring Aug 1, 2023
3c075d4
Increase type stability
DanielDoehring Aug 1, 2023
f3ebbdf
back to original time
DanielDoehring Aug 1, 2023
9dff7de
revert alloc BC (other PR)
DanielDoehring Aug 2, 2023
0936b3b
Revert alloc BC (other PR)
DanielDoehring Aug 2, 2023
67e064a
Name & News
DanielDoehring Aug 2, 2023
0b51b32
Update NEWS.md
DanielDoehring Aug 2, 2023
40b2796
Correct shear layer IC
DanielDoehring Aug 3, 2023
43c0b68
reset example
DanielDoehring Aug 4, 2023
e74ef9e
reset excample
DanielDoehring Aug 4, 2023
50867a4
resize now working in ODE diff eq
DanielDoehring Aug 4, 2023
5222448
splitform now working in ODE jl
DanielDoehring Aug 4, 2023
82539f7
Merge branch 'MortarsParabolic' into AMR_Parabolic
DanielDoehring Aug 4, 2023
8db068d
Update news
DanielDoehring Aug 4, 2023
80519b1
Whitespaces
DanielDoehring Aug 7, 2023
5638a01
Update examples/tree_2d_dgsem/elixir_navierstokes_convergence.jl
DanielDoehring Aug 8, 2023
034c53c
Update examples/tree_3d_dgsem/elixir_navierstokes_convergence.jl
DanielDoehring Aug 8, 2023
d1e4dad
Merge branch 'main' into main
DanielDoehring Aug 8, 2023
3c4574c
Merge branch 'trixi-framework:main' into main
DanielDoehring Aug 8, 2023
618fa21
Merge branch 'main' of github.com:DanielDoehring/Trixi.jl
DanielDoehring Aug 9, 2023
510e236
Fix typo
DanielDoehring Aug 9, 2023
5b299d6
Merge branch 'trixi-framework:main' into main
DanielDoehring Aug 9, 2023
6fbbf3a
Merge branch 'trixi-framework:main' into main
DanielDoehring Aug 11, 2023
e755ef5
Merge branch 'main' of github.com:DanielDoehring/Trixi.jl
DanielDoehring Aug 11, 2023
994974e
Merge branch 'main' into AMR_Parabolic
DanielDoehring Aug 11, 2023
a4931aa
comment
DanielDoehring Aug 11, 2023
7f57ab1
Restrict to 1D
DanielDoehring Aug 11, 2023
d28fb45
simplifications 1D
DanielDoehring Aug 11, 2023
18ef38d
Clean up
DanielDoehring Aug 11, 2023
ed1d89e
format
DanielDoehring Aug 11, 2023
deace03
format
DanielDoehring Aug 11, 2023
421fc95
format
DanielDoehring Aug 11, 2023
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
172 changes: 172 additions & 0 deletions examples/tree_1d_dgsem/elixir_navierstokes_convergence_walls_amr.jl
Original file line number Diff line number Diff line change
@@ -0,0 +1,172 @@
using OrdinaryDiffEq
using Trixi

###############################################################################
# semidiscretization of the ideal compressible Navier-Stokes equations

prandtl_number() = 0.72
mu() = 0.01

equations = CompressibleEulerEquations1D(1.4)
equations_parabolic = CompressibleNavierStokesDiffusion1D(equations, mu=mu(), Prandtl=prandtl_number(),
gradient_variables=GradientVariablesEntropy())

# Create DG solver with polynomial degree = 3 and (local) Lax-Friedrichs/Rusanov flux as surface flux
solver = DGSEM(polydeg=3, surface_flux=flux_lax_friedrichs,
volume_integral=VolumeIntegralWeakForm())

coordinates_min = -1.0
coordinates_max = 1.0

# Create a uniformly refined mesh with periodic boundaries
mesh = TreeMesh(coordinates_min, coordinates_max,
initial_refinement_level=3,
periodicity=false,
n_cells_max=30_000) # set maximum capacity of tree data structure

# Note: the initial condition cannot be specialized to `CompressibleNavierStokesDiffusion1D`
# since it is called by both the parabolic solver (which passes in `CompressibleNavierStokesDiffusion1D`)
# and by the initial condition (which passes in `CompressibleEulerEquations1D`).
# This convergence test setup was originally derived by Andrew Winters (@andrewwinters5000)
function initial_condition_navier_stokes_convergence_test(x, t, equations)
# Amplitude and shift
A = 0.5
c = 2.0

# convenience values for trig. functions
pi_x = pi * x[1]
pi_t = pi * t

rho = c + A * cos(pi_x) * cos(pi_t)
v1 = log(x[1] + 2.0) * (1.0 - exp(-A * (x[1] - 1.0)) ) * cos(pi_t)
p = rho^2

return prim2cons(SVector(rho, v1, p), equations)
end

@inline function source_terms_navier_stokes_convergence_test(u, x, t, equations)
x = x[1]

# TODO: parabolic
# we currently need to hardcode these parameters until we fix the "combined equation" issue
# see also https://github.com/trixi-framework/Trixi.jl/pull/1160
inv_gamma_minus_one = inv(equations.gamma - 1)
Pr = prandtl_number()
mu_ = mu()

# Same settings as in `initial_condition`
# Amplitude and shift
A = 0.5
c = 2.0

# convenience values for trig. functions
pi_x = pi * x
pi_t = pi * t

# compute the manufactured solution and all necessary derivatives
rho = c + A * cos(pi_x) * cos(pi_t)
rho_t = -pi * A * cos(pi_x) * sin(pi_t)
rho_x = -pi * A * sin(pi_x) * cos(pi_t)
rho_xx = -pi * pi * A * cos(pi_x) * cos(pi_t)

v1 = log(x + 2.0) * (1.0 - exp(-A * (x - 1.0))) * cos(pi_t)
v1_t = -pi * log(x + 2.0) * (1.0 - exp(-A * (x - 1.0))) * sin(pi_t)
v1_x = (A * log(x + 2.0) * exp(-A * (x - 1.0)) + (1.0 - exp(-A * (x - 1.0))) / (x + 2.0)) * cos(pi_t)
v1_xx = (( 2.0 * A * exp(-A * (x - 1.0)) / (x + 2.0)
- A * A * log(x + 2.0) * exp(-A * (x - 1.0))
- (1.0 - exp(-A * (x - 1.0))) / ((x + 2.0) * (x + 2.0))) * cos(pi_t))

p = rho * rho
p_t = 2.0 * rho * rho_t
p_x = 2.0 * rho * rho_x
p_xx = 2.0 * rho * rho_xx + 2.0 * rho_x * rho_x

# Note this simplifies slightly because the ansatz assumes that v1 = v2
E = p * inv_gamma_minus_one + 0.5 * rho * v1^2
E_t = p_t * inv_gamma_minus_one + 0.5 * rho_t * v1^2 + rho * v1 * v1_t
E_x = p_x * inv_gamma_minus_one + 0.5 * rho_x * v1^2 + rho * v1 * v1_x

# Some convenience constants
T_const = equations.gamma * inv_gamma_minus_one / Pr
inv_rho_cubed = 1.0 / (rho^3)

# compute the source terms
# density equation
du1 = rho_t + rho_x * v1 + rho * v1_x

# y-momentum equation
du2 = ( rho_t * v1 + rho * v1_t
+ p_x + rho_x * v1^2 + 2.0 * rho * v1 * v1_x
# stress tensor from y-direction
- v1_xx * mu_)

# total energy equation
du3 = ( E_t + v1_x * (E + p) + v1 * (E_x + p_x)
# stress tensor and temperature gradient terms from x-direction
- v1_xx * v1 * mu_
- v1_x * v1_x * mu_
- T_const * inv_rho_cubed * ( p_xx * rho * rho
- 2.0 * p_x * rho * rho_x
+ 2.0 * p * rho_x * rho_x
- p * rho * rho_xx ) * mu_ )

return SVector(du1, du2, du3)
end

initial_condition = initial_condition_navier_stokes_convergence_test

# BC types
velocity_bc_left_right = NoSlip((x, t, equations) -> initial_condition_navier_stokes_convergence_test(x, t, equations)[2])

heat_bc_left = Isothermal((x, t, equations) ->
Trixi.temperature(initial_condition_navier_stokes_convergence_test(x, t, equations),
equations_parabolic))
heat_bc_right = Adiabatic((x, t, equations) -> 0.0)

boundary_condition_left = BoundaryConditionNavierStokesWall(velocity_bc_left_right, heat_bc_left)
boundary_condition_right = BoundaryConditionNavierStokesWall(velocity_bc_left_right, heat_bc_right)

# define inviscid boundary conditions
boundary_conditions = (; x_neg = boundary_condition_slip_wall,
x_pos = boundary_condition_slip_wall)

# define viscous boundary conditions
boundary_conditions_parabolic = (; x_neg = boundary_condition_left,
x_pos = boundary_condition_right)

semi = SemidiscretizationHyperbolicParabolic(mesh, (equations, equations_parabolic), initial_condition, solver;
boundary_conditions=(boundary_conditions, boundary_conditions_parabolic),
source_terms=source_terms_navier_stokes_convergence_test)

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

# Create ODE problem with time span `tspan`
tspan = (0.0, 1.0)
ode = semidiscretize(semi, tspan)

summary_callback = SummaryCallback()
alive_callback = AliveCallback(alive_interval=10)
analysis_interval = 100
analysis_callback = AnalysisCallback(semi, interval=analysis_interval)

amr_controller = ControllerThreeLevel(semi,
IndicatorLöhner(semi, variable=Trixi.density),
base_level=3,
med_level=4, med_threshold=0.005,
max_level=5, max_threshold=0.01)

amr_callback = AMRCallback(semi, amr_controller,
interval=5,
adapt_initial_condition=true)

# Create a CallbackSet to collect all callbacks such that they can be passed to the ODE solver
callbacks = CallbackSet(summary_callback, analysis_callback, alive_callback, amr_callback)

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

time_int_tol = 1e-8
sol = solve(ode, RDPK3SpFSAL49(); abstol=time_int_tol, reltol=time_int_tol, dt = 1e-5,
ode_default_options()..., callback=callbacks)
summary_callback() # print the timer summary
169 changes: 169 additions & 0 deletions src/callbacks_step/amr.jl
Original file line number Diff line number Diff line change
Expand Up @@ -192,6 +192,15 @@ end
amr_callback(u_ode, mesh_equations_solver_cache(semi)..., semi, t, iter; kwargs...)
end

@inline function (amr_callback::AMRCallback)(u_ode::AbstractVector,
semi::SemidiscretizationHyperbolicParabolic,
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Special dispatch for specialized amr_callback

t, iter;
kwargs...)
# Note that we don't `wrap_array` the vector `u_ode` to be able to `resize!`
# it when doing AMR while still dispatching on the `mesh` etc.
amr_callback(u_ode, mesh_equations_solver_cache(semi)..., semi.cache_parabolic, semi, t, iter; kwargs...)
end

# `passive_args` is currently used for Euler with self-gravity to adapt the gravity solver
# passively without querying its indicator, based on the assumption that both solvers use
# the same mesh. That's a hack and should be improved in the future once we have more examples
Expand Down Expand Up @@ -346,6 +355,166 @@ function (amr_callback::AMRCallback)(u_ode::AbstractVector, mesh::TreeMesh,
return has_changed
end

# `passive_args` is currently used for Euler with self-gravity to adapt the gravity solver
# passively without querying its indicator, based on the assumption that both solvers use
# the same mesh. That's a hack and should be improved in the future once we have more examples
# and a better understanding of such a coupling.
# `passive_args` is expected to be an iterable of `Tuple`s of the form
# `(p_u_ode, p_mesh, p_equations, p_dg, p_cache)`.
function (amr_callback::AMRCallback)(u_ode::AbstractVector, mesh::TreeMesh,
equations, dg::DG,
cache, cache_parabolic,
semi::SemidiscretizationHyperbolicParabolic,
t, iter;
only_refine = false, only_coarsen = false,
passive_args = ())
@unpack controller, adaptor = amr_callback

u = wrap_array(u_ode, mesh, equations, dg, cache)
# TODO: Keep indicator based on hyperbolic variables?
lambda = @trixi_timeit timer() "indicator" controller(u, mesh, equations, dg, cache,
t = t, iter = iter)

if mpi_isparallel()
# Collect lambda for all elements
lambda_global = Vector{eltype(lambda)}(undef, nelementsglobal(dg, cache))
# Use parent because n_elements_by_rank is an OffsetArray
recvbuf = MPI.VBuffer(lambda_global, parent(cache.mpi_cache.n_elements_by_rank))
MPI.Allgatherv!(lambda, recvbuf, mpi_comm())
lambda = lambda_global
end

leaf_cell_ids = leaf_cells(mesh.tree)
@boundscheck begin
@assert axes(lambda)==axes(leaf_cell_ids) ("Indicator (axes = $(axes(lambda))) and leaf cell (axes = $(axes(leaf_cell_ids))) arrays have different axes")
end

@unpack to_refine, to_coarsen = amr_callback.amr_cache
empty!(to_refine)
empty!(to_coarsen)
for element in 1:length(lambda)
controller_value = lambda[element]
if controller_value > 0
push!(to_refine, leaf_cell_ids[element])
elseif controller_value < 0
push!(to_coarsen, leaf_cell_ids[element])
end
end

@trixi_timeit timer() "refine" if !only_coarsen && !isempty(to_refine)
# refine mesh
refined_original_cells = @trixi_timeit timer() "mesh" refine!(mesh.tree,
to_refine)

# Find all indices of elements whose cell ids are in refined_original_cells
# NOTE: This assumes same indices for hyperbolic and parabolic part!
elements_to_refine = findall(in(refined_original_cells),
cache.elements.cell_ids)

# refine solver
@trixi_timeit timer() "solver" refine!(u_ode, adaptor, mesh, equations, dg,
cache, cache_parabolic, elements_to_refine)
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Note the cache_parabolic here

for (p_u_ode, p_mesh, p_equations, p_dg, p_cache) in passive_args
@trixi_timeit timer() "passive solver" refine!(p_u_ode, adaptor, p_mesh,
p_equations, p_dg, p_cache,
elements_to_refine)
end
else
# If there is nothing to refine, create empty array for later use
refined_original_cells = Int[]
end

@trixi_timeit timer() "coarsen" if !only_refine && !isempty(to_coarsen)
# Since the cells may have been shifted due to refinement, first we need to
# translate the old cell ids to the new cell ids
if !isempty(to_coarsen)
to_coarsen = original2refined(to_coarsen, refined_original_cells, mesh)
end

# Next, determine the parent cells from which the fine cells are to be
# removed, since these are needed for the coarsen! function. However, since
# we only want to coarsen if *all* child cells are marked for coarsening,
# we count the coarsening indicators for each parent cell and only coarsen
# if all children are marked as such (i.e., where the count is 2^ndims). At
# the same time, check if a cell is marked for coarsening even though it is
# *not* a leaf cell -> this can only happen if it was refined due to 2:1
# smoothing during the preceding refinement operation.
parents_to_coarsen = zeros(Int, length(mesh.tree))
for cell_id in to_coarsen
# If cell has no parent, it cannot be coarsened
if !has_parent(mesh.tree, cell_id)
continue
end

# If cell is not leaf (anymore), it cannot be coarsened
if !is_leaf(mesh.tree, cell_id)
continue
end

# Increase count for parent cell
parent_id = mesh.tree.parent_ids[cell_id]
parents_to_coarsen[parent_id] += 1
end

# Extract only those parent cells for which all children should be coarsened
to_coarsen = collect(1:length(parents_to_coarsen))[parents_to_coarsen .== 2^ndims(mesh)]

# Finally, coarsen mesh
coarsened_original_cells = @trixi_timeit timer() "mesh" coarsen!(mesh.tree,
to_coarsen)

# Convert coarsened parent cell ids to the list of child cell ids that have
# been removed, since this is the information that is expected by the solver
removed_child_cells = zeros(Int,
n_children_per_cell(mesh.tree) *
length(coarsened_original_cells))
for (index, coarse_cell_id) in enumerate(coarsened_original_cells)
for child in 1:n_children_per_cell(mesh.tree)
removed_child_cells[n_children_per_cell(mesh.tree) * (index - 1) + child] = coarse_cell_id +
child
end
end

# Find all indices of elements whose cell ids are in removed_child_cells
# NOTE: This assumes same indices for hyperbolic and parabolic part!
elements_to_remove = findall(in(removed_child_cells), cache.elements.cell_ids)

# coarsen solver
@trixi_timeit timer() "solver" coarsen!(u_ode, adaptor, mesh, equations, dg,
cache, cache_parabolic, elements_to_remove)
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Note the cache_parabolic here


for (p_u_ode, p_mesh, p_equations, p_dg, p_cache) in passive_args
@trixi_timeit timer() "passive solver" coarsen!(p_u_ode, adaptor, p_mesh,
p_equations, p_dg, p_cache,
elements_to_remove)
end
else
# If there is nothing to coarsen, create empty array for later use
coarsened_original_cells = Int[]
end

# Store whether there were any cells coarsened or refined
has_changed = !isempty(refined_original_cells) || !isempty(coarsened_original_cells)
if has_changed # TODO: Taal decide, where shall we set this?
# don't set it to has_changed since there can be changes from earlier calls
mesh.unsaved_changes = true
end

# Dynamically balance computational load by first repartitioning the mesh and then redistributing the cells/elements
if has_changed && mpi_isparallel() && amr_callback.dynamic_load_balancing
@trixi_timeit timer() "dynamic load balancing" begin
old_mpi_ranks_per_cell = copy(mesh.tree.mpi_ranks)

partition!(mesh)

rebalance_solver!(u_ode, mesh, equations, dg, cache, old_mpi_ranks_per_cell)
end
end

# Return true if there were any cells coarsened or refined, otherwise false
return has_changed
end

# Copy controller values to quad user data storage, will be called below
function copy_to_quad_iter_volume(info, user_data)
info_pw = PointerWrapper(info)
Expand Down
Loading