Path: blob/main/examples/unstructured_2d_fdsbp/elixir_euler_free_stream.jl
2055 views
using OrdinaryDiffEqSSPRK1using Trixi23###############################################################################4# semidiscretization of the compressible Euler equations56equations = CompressibleEulerEquations2D(1.4)78# Free-stream initial condition9initial_condition = initial_condition_constant1011# Boundary conditions for free-stream testing12boundary_condition_free_stream = BoundaryConditionDirichlet(initial_condition)13boundary_conditions = Dict(:Body => boundary_condition_free_stream,14:Button1 => boundary_condition_free_stream,15:Button2 => boundary_condition_free_stream,16:Eye1 => boundary_condition_free_stream,17:Eye2 => boundary_condition_free_stream,18:Smile => boundary_condition_free_stream,19:Bowtie => boundary_condition_free_stream)2021###############################################################################22# Get the FDSBP approximation space2324D_SBP = derivative_operator(SummationByPartsOperators.MattssonAlmquistVanDerWeide2018Accurate(),25derivative_order = 1, accuracy_order = 4,26xmin = -1.0, xmax = 1.0, N = 12)27solver = FDSBP(D_SBP,28surface_integral = SurfaceIntegralStrongForm(flux_hll),29volume_integral = VolumeIntegralStrongForm())3031###############################################################################32# Get the curved quad mesh from a file (downloads the file if not available locally)33mesh_file = Trixi.download("https://gist.githubusercontent.com/andrewwinters5000/2c6440b5f8a57db131061ad7aa78ee2b/raw/1f89fdf2c874ff678c78afb6fe8dc784bdfd421f/mesh_gingerbread_man.mesh",34joinpath(@__DIR__, "mesh_gingerbread_man.mesh"))3536mesh = UnstructuredMesh2D(mesh_file)3738###############################################################################39# create the semi discretization object4041semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition, solver,42boundary_conditions = boundary_conditions)4344###############################################################################45# ODE solvers, callbacks etc.4647tspan = (0.0, 5.0)48ode = semidiscretize(semi, tspan)4950summary_callback = SummaryCallback()5152analysis_interval = 10053analysis_callback = AnalysisCallback(semi, interval = analysis_interval)5455alive_callback = AliveCallback(analysis_interval = analysis_interval)5657save_solution = SaveSolutionCallback(interval = 100,58save_initial_solution = true,59save_final_solution = true)6061callbacks = CallbackSet(summary_callback, analysis_callback,62alive_callback, save_solution)6364###############################################################################65# run the simulation6667# set small tolerances for the free-stream preservation test68sol = solve(ode, SSPRK43(), abstol = 1.0e-12, reltol = 1.0e-12;69ode_default_options()..., callback = callbacks)707172