forked from trixi-framework/Trixi.jl
-
Notifications
You must be signed in to change notification settings - Fork 1
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Save and load user_data for p4est (trixi-framework#1915)
* save and load user_data for p4est this fixes restating when using AMR * use p4est_reset_data instead * add test for p4est, restart, and AMR * adapt errors in test * 3D = p8! * return something * remove coverage_override * remove coverage_override * use ode_default_options()
- Loading branch information
Showing
7 changed files
with
98 additions
and
10 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,54 @@ | ||
|
||
using OrdinaryDiffEq | ||
using Trixi | ||
|
||
############################################################################### | ||
# create a restart file | ||
|
||
elixir_file = "elixir_advection_extended.jl" | ||
restart_file = "restart_000021.h5" | ||
|
||
trixi_include(@__MODULE__, joinpath(@__DIR__, elixir_file)) | ||
|
||
############################################################################### | ||
# adapt the parameters that have changed compared to "elixir_advection_extended.jl" | ||
|
||
# Note: If you get a restart file from somewhere else, you need to provide | ||
# appropriate setups in the elixir loading a restart file | ||
|
||
restart_filename = joinpath("out", restart_file) | ||
mesh = load_mesh(restart_filename) | ||
|
||
semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition, solver, | ||
boundary_conditions = boundary_conditions) | ||
|
||
tspan = (load_time(restart_filename), 2.0) | ||
dt = load_dt(restart_filename) | ||
ode = semidiscretize(semi, tspan, restart_filename); | ||
|
||
# Do not overwrite the initial snapshot written by elixir_advection_extended.jl. | ||
save_solution.condition.save_initial_solution = false | ||
|
||
# Add AMR callback | ||
amr_controller = ControllerThreeLevel(semi, IndicatorMax(semi, variable = first), | ||
base_level = 0, | ||
med_level = 0, med_threshold = 0.8, | ||
max_level = 1, max_threshold = 1.2) | ||
amr_callback = AMRCallback(semi, amr_controller, | ||
interval = 5, | ||
adapt_initial_condition = true, | ||
adapt_initial_condition_only_refine = true) | ||
callbacks_ext = CallbackSet(amr_callback, callbacks.discrete_callbacks...) | ||
|
||
integrator = init(ode, CarpenterKennedy2N54(williamson_condition = false), | ||
dt = dt, # solve needs some value here but it will be overwritten by the stepsize_callback | ||
save_everystep = false, callback = callbacks_ext, maxiters = 100_000); | ||
|
||
# Get the last time index and work with that. | ||
load_timestep!(integrator, restart_filename) | ||
|
||
############################################################################### | ||
# run the simulation | ||
|
||
sol = solve!(integrator) | ||
summary_callback() # print the timer summary |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters