Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
trixi-framework
GitHub Repository: trixi-framework/Trixi.jl
Path: blob/main/examples/structured_2d_dgsem/elixir_mhdmultiion_ec.jl
5586 views
1
using OrdinaryDiffEqLowStorageRK
2
using Trixi
3
4
###############################################################################
5
# semidiscretization of the ideal multi-ion MHD equations
6
equations = IdealGlmMhdMultiIonEquations2D(gammas = (1.4, 1.667),
7
charge_to_mass = (1.0, 2.0))
8
9
initial_condition = initial_condition_weak_blast_wave
10
11
# Entropy conservative numerical fluxes
12
volume_flux = (flux_ruedaramirez_etal, flux_nonconservative_ruedaramirez_etal)
13
surface_flux = (flux_ruedaramirez_etal, flux_nonconservative_ruedaramirez_etal)
14
15
solver = DGSEM(polydeg = 3, surface_flux = surface_flux,
16
volume_integral = VolumeIntegralFluxDifferencing(volume_flux))
17
18
coordinates_min = (-2.0, -2.0)
19
coordinates_max = (2.0, 2.0)
20
cells_per_dimension = (100, 100)
21
mesh = StructuredMesh(cells_per_dimension, coordinates_min,
22
coordinates_max, periodicity = true)
23
24
# The multi-ion GLM-MHD equations require the inclusion of source_terms_lorentz
25
# whenever multiple ion species are present
26
semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition, solver,
27
source_terms = source_terms_lorentz,
28
boundary_conditions = boundary_condition_periodic)
29
30
###############################################################################
31
# ODE solvers, callbacks etc.
32
33
tspan = (0.0, 0.4)
34
ode = semidiscretize(semi, tspan)
35
36
summary_callback = SummaryCallback()
37
38
analysis_interval = 10
39
analysis_callback = AnalysisCallback(semi, interval = analysis_interval)
40
alive_callback = AliveCallback(analysis_interval = analysis_interval)
41
42
save_solution = SaveSolutionCallback(dt = 0.1, # interval=100,
43
save_initial_solution = true,
44
save_final_solution = true,
45
solution_variables = cons2prim)
46
47
cfl = 0.5
48
49
stepsize_callback = StepsizeCallback(cfl = cfl)
50
51
glm_speed_callback = GlmSpeedCallback(glm_scale = 0.5, cfl = cfl)
52
53
callbacks = CallbackSet(summary_callback,
54
analysis_callback, alive_callback,
55
save_solution,
56
stepsize_callback,
57
glm_speed_callback)
58
59
###############################################################################
60
# run the simulation
61
62
sol = solve(ode, CarpenterKennedy2N54(williamson_condition = false);
63
dt = 1.0, # solve needs some value here but it will be overwritten by the stepsize_callback
64
ode_default_options()..., callback = callbacks);
65
66