Path: blob/main/examples/unstructured_2d_dgsem/elixir_euler_ec.jl
2055 views
using OrdinaryDiffEqLowStorageRK1using Trixi23###############################################################################4# semidiscretization of the compressible Euler equations56equations = CompressibleEulerEquations2D(5 / 3)78initial_condition = initial_condition_weak_blast_wave910###############################################################################11# Get the DG approximation space1213volume_flux = flux_ranocha14solver = DGSEM(polydeg = 6, surface_flux = flux_ranocha,15volume_integral = VolumeIntegralFluxDifferencing(volume_flux))1617###############################################################################18# Get the curved quad mesh from a file19mesh_file = Trixi.download("https://gist.githubusercontent.com/andrewwinters5000/12ce661d7c354c3d94c74b964b0f1c96/raw/8275b9a60c6e7ebbdea5fc4b4f091c47af3d5273/mesh_periodic_square_with_twist.mesh",20joinpath(@__DIR__, "mesh_periodic_square_with_twist.mesh"))2122mesh = UnstructuredMesh2D(mesh_file, periodicity = true)2324###############################################################################25# create the semi discretization object2627semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition, solver)2829###############################################################################30# ODE solvers, callbacks etc.3132tspan = (0.0, 2.0)33ode = semidiscretize(semi, tspan)3435summary_callback = SummaryCallback()3637analysis_interval = 10038analysis_callback = AnalysisCallback(semi, interval = analysis_interval)3940alive_callback = AliveCallback(analysis_interval = analysis_interval)4142save_solution = SaveSolutionCallback(interval = 100,43save_initial_solution = true,44save_final_solution = true)4546stepsize_callback = StepsizeCallback(cfl = 1.0)4748callbacks = CallbackSet(summary_callback,49analysis_callback,50alive_callback,51save_solution,52stepsize_callback)5354###############################################################################55# run the simulation5657sol = solve(ode, CarpenterKennedy2N54(williamson_condition = false);58dt = 1.0, # solve needs some value here but it will be overwritten by the stepsize_callback59ode_default_options()..., callback = callbacks);606162