Path: blob/main/examples/unstructured_2d_dgsem/elixir_euler_ec.jl
5586 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;28boundary_conditions = boundary_condition_periodic)2930###############################################################################31# ODE solvers, callbacks etc.3233tspan = (0.0, 2.0)34ode = semidiscretize(semi, tspan)3536summary_callback = SummaryCallback()3738analysis_interval = 10039analysis_callback = AnalysisCallback(semi, interval = analysis_interval)4041alive_callback = AliveCallback(analysis_interval = analysis_interval)4243save_solution = SaveSolutionCallback(interval = 100,44save_initial_solution = true,45save_final_solution = true)4647stepsize_callback = StepsizeCallback(cfl = 1.0)4849callbacks = CallbackSet(summary_callback,50analysis_callback,51alive_callback,52save_solution,53stepsize_callback)5455###############################################################################56# run the simulation5758sol = solve(ode, CarpenterKennedy2N54(williamson_condition = false);59dt = 1.0, # solve needs some value here but it will be overwritten by the stepsize_callback60ode_default_options()..., callback = callbacks);616263