Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
trixi-framework
GitHub Repository: trixi-framework/Trixi.jl
Path: blob/main/benchmark/elixir_3d_euler_source_terms_tree.jl
2055 views
1
2
using OrdinaryDiffEqLowOrderRK
3
using Trixi
4
5
###############################################################################
6
# semidiscretization of the compressible Euler equations
7
8
equations = CompressibleEulerEquations3D(1.4)
9
10
initial_condition = initial_condition_convergence_test
11
12
solver = DGSEM(polydeg = 3, surface_flux = flux_lax_friedrichs)
13
14
coordinates_min = (0.0, 0.0, 0.0)
15
coordinates_max = (2.0, 2.0, 2.0)
16
mesh = TreeMesh(coordinates_min, coordinates_max,
17
initial_refinement_level = 2,
18
n_cells_max = 10_000)
19
20
semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition, solver,
21
source_terms = source_terms_convergence_test)
22
23
###############################################################################
24
# ODE solvers, callbacks etc.
25
26
tspan = (0.0, 5.0)
27
ode = semidiscretize(semi, tspan)
28
29
summary_callback = SummaryCallback()
30
31
analysis_interval = 100
32
analysis_callback = AnalysisCallback(semi, interval = analysis_interval)
33
34
alive_callback = AliveCallback(analysis_interval = analysis_interval)
35
36
callbacks = CallbackSet(summary_callback, analysis_callback, alive_callback)
37
38
###############################################################################
39
# run the simulation
40
41
sol = solve(ode, BS3();
42
ode_default_options()..., callback = callbacks);
43
summary_callback() # print the timer summary
44
45