Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add support for hyperbolic-parabolic systems to TreeMesh2D #1156

Merged
merged 161 commits into from
Aug 9, 2022
Merged
Show file tree
Hide file tree
Changes from 154 commits
Commits
Show all changes
161 commits
Select commit Hold shift + click to select a range
1f42e4f
Add prototype for advection-diffusion elixir for TreeMesh2D
sloede Jun 2, 2022
d5fba2a
Merge branch 'dev' into parabolic-treemesh
sloede Jun 2, 2022
586f8e1
Merge branch 'dev' into parabolic-treemesh
sloede Jun 3, 2022
2cc327b
Initial implementation of `calc_gradient!` for TreeMesh{2}
sloede Jun 3, 2022
ed13d72
First complete implementation of the parabolic rhs operator for TreeMesh
sloede Jun 3, 2022
f83374e
Make it work
sloede Jun 3, 2022
12c59eb
Add first elixir that works
sloede Jun 3, 2022
03a1a60
Clean up elixir
sloede Jun 3, 2022
60cce54
first draft of container for Navier-Stokes constants and fluxes
andrewwinters5000 Jun 7, 2022
46ae5fb
remove unneeded temperature computation
andrewwinters5000 Jun 7, 2022
4f6558f
draft of elixir with possible boundary condition structure
andrewwinters5000 Jun 7, 2022
dde54d3
added manufactured solution and source term
andrewwinters5000 Jun 7, 2022
daaeac3
fix typo in function name for MMS
andrewwinters5000 Jun 7, 2022
4a39883
update variable names for consistency. improve comments
andrewwinters5000 Jun 8, 2022
84d8454
Merge branch 'main' into nav_stokes_2d
andrewwinters5000 Jun 8, 2022
3879a3f
fix dumb typos in new equation system name
andrewwinters5000 Jun 8, 2022
435e081
actually export new equations
andrewwinters5000 Jun 8, 2022
7b59fef
add comment near variable_mapping declaration.
andrewwinters5000 Jun 8, 2022
b33570f
Merge branch 'dev' into parabolic-treemesh
ranocha Jun 8, 2022
d3b7870
Merge branch 'parabolic-treemesh' into nav_stokes_2d
ranocha Jun 8, 2022
5dc8301
Apply suggestions from code review
andrewwinters5000 Jun 9, 2022
f316684
parabolic equations now exported separately
andrewwinters5000 Jun 9, 2022
02c14e1
change name to CompressibleNavierStokesEquations2D
andrewwinters5000 Jun 9, 2022
dd733bb
export NS with proper name
andrewwinters5000 Jun 9, 2022
a1a48fe
explicitly require compressible Euler in the type parameter
andrewwinters5000 Jun 10, 2022
d8db203
name kinematic viscosity nu for consistency with Lattice-Boltzmann
andrewwinters5000 Jun 10, 2022
06e69b8
add promotion in constructor
andrewwinters5000 Jun 10, 2022
eda9737
make Reynolds, Prandtl, Mach, and kappa keyword arguments
andrewwinters5000 Jun 10, 2022
b469bce
update constructor call in elixir
andrewwinters5000 Jun 10, 2022
fb646b0
reduce computation by exploiting stress tensor symmetry
andrewwinters5000 Jun 10, 2022
f32ef8c
Merge remote-tracking branch 'origin/main' into nav_stokes_2d
jlchan Jun 14, 2022
f6bca76
fix unpacking of flux
jlchan Jun 14, 2022
9b5dd35
modifying parabolic cache creation
jlchan Jun 14, 2022
21e1c99
comments
jlchan Jun 15, 2022
19f004e
comments
jlchan Jun 15, 2022
de442bf
formatting and renaming equations to equations_hyperbolic
jlchan Jun 15, 2022
298b726
fix unpacking of gradients in flux
jlchan Jun 15, 2022
01f8325
adding CNS BCs
jlchan Jun 15, 2022
3f04e71
adding lid-driven cavity elixir
jlchan Jun 15, 2022
36e3b68
adding variable transform, editing cons2prim for CNS
jlchan Jun 15, 2022
6bf91eb
add prim2cons for NS (inconsistent right now)
jlchan Jun 15, 2022
a0ea3f0
add draft of DGMulti Navier Stokes convergence elixir
jlchan Jun 15, 2022
c103e2e
converging solution using elixir for TreeMesh with BCs
jlchan Jun 27, 2022
845c133
Merge branch 'main' into nav_stokes_2d
jlchan Jun 27, 2022
3d717a6
fixing DGMulti advection diffusion elixir convergence
jlchan Jun 27, 2022
8471273
naming equations as parabolic/hyperbolic
jlchan Jun 27, 2022
96667e6
generalizing transform_variables
jlchan Jun 27, 2022
73e4740
add TODO
jlchan Jun 27, 2022
2c05f66
additional checks on get_unsigned_normal
jlchan Jun 27, 2022
d5e7f9e
adding isothermal BC
jlchan Jun 27, 2022
89acae8
commenting out unused CNS functions for now
jlchan Jun 27, 2022
f503b85
fix call to transform_variables
jlchan Jun 27, 2022
41b41a9
comments and cleanup
jlchan Jun 27, 2022
1107def
changing default solver and Re for cavity
jlchan Jun 27, 2022
f90afb9
adding more advection diffusion tests
jlchan Jun 27, 2022
2e7019f
label tests
jlchan Jun 28, 2022
063b602
add gradient_variables field to SemidiscretizationHyperbolicParabolic
jlchan Jun 28, 2022
50d76df
Revert "add gradient_variables field to SemidiscretizationHyperbolicP…
jlchan Jun 28, 2022
5b112e9
Merge branch 'main' into nav_stokes_2d
jlchan Jul 11, 2022
549793c
allowing for specialization in transform_variables
jlchan Jul 12, 2022
3e3e41f
formatting and comments
jlchan Jul 13, 2022
6347151
reverting elixir
jlchan Jul 13, 2022
eb98568
comments
jlchan Jul 13, 2022
766cdc5
standardizing time tol
jlchan Jul 13, 2022
c865fb7
minor fix to CNS boundary flux for convenience
jlchan Jul 13, 2022
08768a7
formatting + comments
jlchan Jul 13, 2022
6c38bdb
using primitive variables in viscous flux instead of conservative
jlchan Jul 13, 2022
0f67dd0
minor formatting
jlchan Jul 13, 2022
6a1d908
add CNS tests
jlchan Jul 13, 2022
6d5be6c
fix test
jlchan Jul 13, 2022
bc58754
testing if scoping issues fix TreeMesh tests
jlchan Jul 13, 2022
f13045a
decreasing timestep tol for TreeMesh parabolic test
jlchan Jul 13, 2022
d29d583
enabling periodic BCs for TreeMesh + more tests
jlchan Jul 13, 2022
abd020b
fix density BC flux (unused, but could be useful)
jlchan Jul 13, 2022
663f465
adding non-working TreeMesh elixirs
jlchan Jul 15, 2022
5ae580b
adding AD checks
jlchan Jul 15, 2022
e0c3b84
Merge remote-tracking branch 'origin/main' into nav_stokes_2d
jlchan Jul 28, 2022
bfffc00
standardizing parameters in convergence elixirs
jlchan Jul 28, 2022
17eafbb
minor cleanup
jlchan Jul 28, 2022
0c4e098
revert DGMulti CNS elixir setup back to the one used in tests
jlchan Jul 28, 2022
b70bbc0
adding TreeMesh CNS convergence test
jlchan Jul 28, 2022
13e0c8f
removing redundant elixir
jlchan Jul 28, 2022
8cecb5f
add more tests
jlchan Jul 28, 2022
adb8eca
add more test
jlchan Jul 28, 2022
3281b49
Apply suggestions from code review
andrewwinters5000 Jul 29, 2022
d643679
set version to v0.4.43
ranocha Jul 29, 2022
a6244c2
set development version to v0.4.44-pre
ranocha Jul 29, 2022
d6ab952
add YouTube links to JuliaCon presentations (#1192)
ranocha Jul 29, 2022
689fe59
improved readability of equation docstrings in compressible Euler files
andrewwinters5000 Jul 29, 2022
e8a24a7
Merge branch 'dev' into parabolic-treemesh
ranocha Jul 29, 2022
6002ba6
Navier-Stokes in 2D on DGMulti and TreeMesh (#1165)
andrewwinters5000 Jul 29, 2022
24f2d82
Merge branch 'nav_stokes_2d' into parabolic-treemesh
andrewwinters5000 Jul 29, 2022
5f48588
add docstring for CNS equations
andrewwinters5000 Jul 29, 2022
baea3ec
removing some addressed TODOs
jlchan Jul 29, 2022
8b0e5d3
Merge branch 'parabolic-treemesh' of github.com:trixi-framework/Trixi…
andrewwinters5000 Jul 29, 2022
0b17ec6
adjust definition of the kappa constant
andrewwinters5000 Jul 29, 2022
ba49eef
avoid overwriting u_grad with viscous_flux results
jlchan Jul 29, 2022
a8897aa
remove old TODOs
jlchan Jul 29, 2022
e0fddfa
clarify TODOs for later
jlchan Jul 29, 2022
baec967
removing let statements
jlchan Jul 29, 2022
f6fd1f8
rearrange main docstring. Fix typos in math environment causing it to…
andrewwinters5000 Aug 3, 2022
7a4106f
Merge branch 'dev' into parabolic-treemesh
ranocha Aug 8, 2022
0b63e58
update TODO notes
ranocha Aug 8, 2022
8bd0e1d
Apply suggestions from code review
ranocha Aug 8, 2022
dcdbe07
update TODO notes
ranocha Aug 8, 2022
5eae2b0
Apply suggestions from code review
ranocha Aug 8, 2022
8177678
update TODO notes
ranocha Aug 8, 2022
ada3fb9
changing diffusivity names
jlchan Aug 8, 2022
c547b1c
Reynolds/Prandtl number name changes for consistency
jlchan Aug 8, 2022
d0848b5
Apply suggestions from code review
jlchan Aug 8, 2022
b2f0621
fixing bug introduced by GH code review
jlchan Aug 8, 2022
e3fdde8
moving manufactured solution into the CNS equations file
jlchan Aug 8, 2022
a8ed40e
fix allocation issue
jlchan Aug 8, 2022
9bf3726
get_diffusivity -> diffusivity
ranocha Aug 8, 2022
a6b6d91
removing cruft code, adding comment on messy prim2cons routine
jlchan Aug 8, 2022
ff77812
Merge remote-tracking branch 'origin/parabolic-treemesh' into parabol…
jlchan Aug 8, 2022
69880c4
moving manufactured solution back into elixirs
jlchan Aug 8, 2022
133be3e
Update examples/dgmulti_2d/elixir_advection_diffusion_nonperiodic.jl
jlchan Aug 8, 2022
928347b
TODO -> Todo, and .6 -> 0.6
jlchan Aug 8, 2022
1060898
Update src/solvers/dgsem_tree/dg_2d_parabolic.jl
jlchan Aug 8, 2022
0d358de
adding note to Adiabatic/Isothermal BCs
jlchan Aug 8, 2022
4f757d3
replacing CompressibleNavierStokesEquations with ...Diffusion
jlchan Aug 8, 2022
7382a28
Merge remote-tracking branch 'origin/parabolic-treemesh' into parabol…
jlchan Aug 8, 2022
65f491b
Update src/solvers/dgsem_tree/dg_2d_parabolic.jl
jlchan Aug 8, 2022
d2facb0
Update src/solvers/dgsem_tree/dg_2d_parabolic.jl
jlchan Aug 8, 2022
299f04e
documenting Jacobian sign flip
jlchan Aug 8, 2022
d4843bf
Merge remote-tracking branch 'origin/parabolic-treemesh' into parabol…
jlchan Aug 8, 2022
9ff5f4c
viscous_flux -> flux_viscous
jlchan Aug 8, 2022
144fc59
remove extra arg to `gradient_variable_transformation`
jlchan Aug 8, 2022
ce7a045
Update src/solvers/dgsem_tree/dg_2d_parabolic.jl
jlchan Aug 8, 2022
5bf23e5
change warning to error
jlchan Aug 8, 2022
9f4a8b1
fix bug introduced by search/replace
jlchan Aug 8, 2022
1159377
dg_parabolic -> parabolic_scheme
jlchan Aug 8, 2022
bf42a66
BoundaryConditionViscousWall -> BoundaryConditionNavierStokesWall
jlchan Aug 8, 2022
020fb15
u_grad -> gradients
jlchan Aug 8, 2022
76a8563
fix test
jlchan Aug 8, 2022
0fc9828
renaming
jlchan Aug 8, 2022
3b46afd
update comment
jlchan Aug 8, 2022
8e94965
converting to signature `flux(u, gradients, orientation, equations)`
jlchan Aug 8, 2022
f5f48fc
using prolong2interfaces/boundaries
jlchan Aug 8, 2022
da319b9
unpacking `gradients` and `flux_viscous`
jlchan Aug 8, 2022
4b9b04f
using calc_surface_integral!
jlchan Aug 9, 2022
7b74f19
adding @muladd
jlchan Aug 9, 2022
9b05185
Apply suggestions from code review
ranocha Aug 9, 2022
1ff6b87
update comments
jlchan Aug 9, 2022
5caf63c
Merge remote-tracking branch 'origin/parabolic-treemesh' into parabol…
jlchan Aug 9, 2022
e8bccba
Rename grad_u -> gradients
sloede Aug 9, 2022
f05bc7d
Update src/equations/compressible_navier_stokes_2d.jl
jlchan Aug 9, 2022
5692189
Rename remaining grad_u/u_grad -> gradients
sloede Aug 9, 2022
5437f7b
Refactor into prolong2interfaces!
sloede Aug 9, 2022
be8a5e0
Refactor calc_volume_integral!
sloede Aug 9, 2022
cbadcb8
Refactor calc_interface_flux
sloede Aug 9, 2022
3400e83
Refactor prolong2boundaries!
sloede Aug 9, 2022
cb82c8f
Refactor calc_divergence!
sloede Aug 9, 2022
5c7becc
Formatting consistency
sloede Aug 9, 2022
9510dc8
Remove dispatch on volume integral type
sloede Aug 9, 2022
831f878
Add comment on why surface_integral is passed to prolong2interfaces!
sloede Aug 9, 2022
23015ea
Explicitly use weak form volume integral to allow easy overriding in …
sloede Aug 9, 2022
d1ea1be
Add flux differencing test for CNS test
sloede Aug 9, 2022
9976085
Remove erroneous P4estMesh{2} dispatch
sloede Aug 9, 2022
b06f927
Remove non-cons terms from parabolic solver
sloede Aug 9, 2022
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion examples/dgmulti_2d/elixir_advection_diffusion.jl
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@ dg = DGMulti(polydeg = 3, element_type = Tri(), approximation_type = Polynomial(
volume_integral = VolumeIntegralWeakForm())

equations = LinearScalarAdvectionEquation2D(1.5, 1.0)
equations_parabolic = LaplaceDiffusion2D(5e-2, equations)
equations_parabolic = LaplaceDiffusion2D(5.0e-2, equations)

initial_condition_zero(x, t, equations::LinearScalarAdvectionEquation2D) = SVector(0.0)
initial_condition = initial_condition_zero
Expand Down
72 changes: 72 additions & 0 deletions examples/dgmulti_2d/elixir_advection_diffusion_nonperiodic.jl
Original file line number Diff line number Diff line change
@@ -0,0 +1,72 @@
using Trixi, OrdinaryDiffEq

dg = DGMulti(polydeg = 3, element_type = Quad(), approximation_type = Polynomial(),
surface_integral = SurfaceIntegralWeakForm(flux_lax_friedrichs),
volume_integral = VolumeIntegralWeakForm())

diffusivity() = 5.0e-2

equations = LinearScalarAdvectionEquation2D(1.0, 0.0)
equations_parabolic = LaplaceDiffusion2D(diffusivity(), equations)

# Example setup taken from
# - Truman Ellis, Jesse Chan, and Leszek Demkowicz (2016).
# Robust DPG methods for transient convection-diffusion.
# In: Building bridges: connections and challenges in modern approaches
# to numerical partial differential equations.
# [DOI](https://doi.org/10.1007/978-3-319-41640-3_6).
function initial_condition_erikkson_johnson(x, t, equations)
l = 4
epsilon = diffusivity() # Note: this requires epsilon < 0.6 due to the sqrt
lambda_1 = (-1 + sqrt(1 - 4 * epsilon * l)) / (-2 * epsilon)
lambda_2 = (-1 - sqrt(1 - 4 * epsilon * l)) / (-2 * epsilon)
r1 = (1 + sqrt(1 + 4 * pi^2 * epsilon^2)) / (2 * epsilon)
s1 = (1 - sqrt(1 + 4 * pi^2 * epsilon^2)) / (2 * epsilon)
u = exp(-l * t) * (exp(lambda_1 * x[1]) - exp(lambda_2 * x[1])) +
cos(pi * x[2]) * (exp(s1 * x[1]) - exp(r1 * x[1])) / (exp(-s1) - exp(-r1))
return SVector{1}(u)
end
initial_condition = initial_condition_erikkson_johnson

# tag different boundary segments
left(x, tol=50*eps()) = abs(x[1] + 1) < tol
right(x, tol=50*eps()) = abs(x[1]) < tol
bottom(x, tol=50*eps()) = abs(x[2] + .5) < tol
top(x, tol=50*eps()) = abs(x[2] - .5) < tol
entire_boundary(x, tol=50*eps()) = true
is_on_boundary = Dict(:left => left, :right => right, :top => top, :bottom => bottom,
:entire_boundary => entire_boundary)
mesh = DGMultiMesh(dg; coordinates_min=(-1.0, -0.5), coordinates_max=(0.0, 0.5),
cells_per_dimension=(16, 16), is_on_boundary)

# BC types
boundary_condition = BoundaryConditionDirichlet(initial_condition)

# define inviscid boundary conditions, enforce "do nothing" boundary condition at the outflow
boundary_conditions = (; :left => boundary_condition,
:top => boundary_condition,
:bottom => boundary_condition,
:right => boundary_condition_do_nothing)

# define viscous boundary conditions
boundary_conditions_parabolic = (; :entire_boundary => boundary_condition)

semi = SemidiscretizationHyperbolicParabolic(mesh, (equations, equations_parabolic), initial_condition, dg;
boundary_conditions=(boundary_conditions, boundary_conditions_parabolic))

tspan = (0.0, 1.5)
ode = semidiscretize(semi, tspan)

summary_callback = SummaryCallback()
alive_callback = AliveCallback(alive_interval=10)
analysis_interval = 100
analysis_callback = AnalysisCallback(semi, interval=analysis_interval, uEltype=real(dg))
callbacks = CallbackSet(summary_callback, alive_callback)

###############################################################################
# run the simulation

time_int_tol = 1e-8
sol = solve(ode, RDPK3SpFSAL49(), abstol=time_int_tol, reltol=time_int_tol,
save_everystep=false, callback=callbacks)
summary_callback() # print the timer summary
206 changes: 206 additions & 0 deletions examples/dgmulti_2d/elixir_navier_stokes_convergence.jl
Original file line number Diff line number Diff line change
@@ -0,0 +1,206 @@
using OrdinaryDiffEq
using Trixi

###############################################################################
# semidiscretization of the ideal compressible Navier-Stokes equations

reynolds_number() = 100
prandtl_number() = 0.72

equations = CompressibleEulerEquations2D(1.4)
# Note: If you change the Navier-Stokes parameters here, also change them in the initial condition
# I really do not like this structure but it should work for now
ranocha marked this conversation as resolved.
Show resolved Hide resolved
equations_parabolic = CompressibleNavierStokesDiffusion2D(equations, Reynolds=reynolds_number(), Prandtl=prandtl_number(),
Mach_freestream=0.5)

# Create DG solver with polynomial degree = 3 and (local) Lax-Friedrichs/Rusanov flux as surface flux
dg = DGMulti(polydeg = 3, element_type = Tri(), approximation_type = Polynomial(),
surface_integral = SurfaceIntegralWeakForm(flux_lax_friedrichs),
volume_integral = VolumeIntegralWeakForm())

top_bottom(x, tol=50*eps()) = abs(abs(x[2]) - 1) < tol
is_on_boundary = Dict(:top_bottom => top_bottom)
mesh = DGMultiMesh(dg, cells_per_dimension=(16, 16); periodicity=(true, false), is_on_boundary)

# Note: the initial condition cannot be specialized to `CompressibleNavierStokesDiffusion2D`
# since it is called by both the parabolic solver (which passes in `CompressibleNavierStokesDiffusion2D`)
# and by the initial condition (which passes in `CompressibleEulerEquations2D`).
# This convergence test setup was originally derived by Andrew Winters (@andrewwinters5000)
function initial_condition_navier_stokes_convergence_test(x, t, equations)
jlchan marked this conversation as resolved.
Show resolved Hide resolved
jlchan marked this conversation as resolved.
Show resolved Hide resolved
# Amplitude and shift
A = 0.5
c = 2.0

# convenience values for trig. functions
pi_x = pi * x[1]
pi_y = pi * x[2]
pi_t = pi * t

rho = c + A * sin(pi_x) * cos(pi_y) * cos(pi_t)
v1 = sin(pi_x) * log(x[2] + 2.0) * (1.0 - exp(-A * (x[2] - 1.0)) ) * cos(pi_t)
v2 = v1
p = rho^2

return prim2cons(SVector(rho, v1, v2, p), equations)
end

@inline function source_terms_navier_stokes_convergence_test(u, x, t, equations)
y = x[2]

# TODO: parabolic
# we currently need to hardcode these parameters until we fix the "combined equation" issue
# see also https://github.com/trixi-framework/Trixi.jl/pull/1160
inv_gamma_minus_one = inv(equations.gamma - 1)
Pr = prandtl_number()
Re = reynolds_number()

# Same settings as in `initial_condition`
# Amplitude and shift
A = 0.5
c = 2.0

# convenience values for trig. functions
pi_x = pi * x[1]
pi_y = pi * x[2]
pi_t = pi * t

# compute the manufactured solution and all necessary derivatives
rho = c + A * sin(pi_x) * cos(pi_y) * cos(pi_t)
rho_t = -pi * A * sin(pi_x) * cos(pi_y) * sin(pi_t)
rho_x = pi * A * cos(pi_x) * cos(pi_y) * cos(pi_t)
rho_y = -pi * A * sin(pi_x) * sin(pi_y) * cos(pi_t)
rho_xx = -pi * pi * A * sin(pi_x) * cos(pi_y) * cos(pi_t)
rho_yy = -pi * pi * A * sin(pi_x) * cos(pi_y) * cos(pi_t)

v1 = sin(pi_x) * log(y + 2.0) * (1.0 - exp(-A * (y - 1.0))) * cos(pi_t)
v1_t = -pi * sin(pi_x) * log(y + 2.0) * (1.0 - exp(-A * (y - 1.0))) * sin(pi_t)
v1_x = pi * cos(pi_x) * log(y + 2.0) * (1.0 - exp(-A * (y - 1.0))) * cos(pi_t)
v1_y = sin(pi_x) * (A * log(y + 2.0) * exp(-A * (y - 1.0)) + (1.0 - exp(-A * (y - 1.0))) / (y + 2.0)) * cos(pi_t)
v1_xx = -pi * pi * sin(pi_x) * log(y + 2.0) * (1.0 - exp(-A * (y - 1.0))) * cos(pi_t)
v1_xy = pi * cos(pi_x) * (A * log(y + 2.0) * exp(-A * (y - 1.0)) + (1.0 - exp(-A * (y - 1.0))) / (y + 2.0)) * cos(pi_t)
v1_yy = (sin(pi_x) * ( 2.0 * A * exp(-A * (y - 1.0)) / (y + 2.0)
- A * A * log(y + 2.0) * exp(-A * (y - 1.0))
- (1.0 - exp(-A * (y - 1.0))) / ((y + 2.0) * (y + 2.0))) * cos(pi_t))
v2 = v1
v2_t = v1_t
v2_x = v1_x
v2_y = v1_y
v2_xx = v1_xx
v2_xy = v1_xy
v2_yy = v1_yy

p = rho * rho
p_t = 2.0 * rho * rho_t
p_x = 2.0 * rho * rho_x
p_y = 2.0 * rho * rho_y
p_xx = 2.0 * rho * rho_xx + 2.0 * rho_x * rho_x
p_yy = 2.0 * rho * rho_yy + 2.0 * rho_y * rho_y

# Note this simplifies slightly because the ansatz assumes that v1 = v2
E = p * inv_gamma_minus_one + 0.5 * rho * (v1^2 + v2^2)
E_t = p_t * inv_gamma_minus_one + rho_t * v1^2 + 2.0 * rho * v1 * v1_t
E_x = p_x * inv_gamma_minus_one + rho_x * v1^2 + 2.0 * rho * v1 * v1_x
E_y = p_y * inv_gamma_minus_one + rho_y * v1^2 + 2.0 * rho * v1 * v1_y

# Some convenience constants
T_const = equations.gamma * inv_gamma_minus_one / Pr
inv_Re = 1.0 / Re
inv_rho_cubed = 1.0 / (rho^3)

# compute the source terms
# density equation
du1 = rho_t + rho_x * v1 + rho * v1_x + rho_y * v2 + rho * v2_y

# x-momentum equation
du2 = ( rho_t * v1 + rho * v1_t + p_x + rho_x * v1^2
+ 2.0 * rho * v1 * v1_x
+ rho_y * v1 * v2
+ rho * v1_y * v2
+ rho * v1 * v2_y
# stress tensor from x-direction
- 4.0 / 3.0 * v1_xx * inv_Re
+ 2.0 / 3.0 * v2_xy * inv_Re
- v1_yy * inv_Re
- v2_xy * inv_Re )
# y-momentum equation
du3 = ( rho_t * v2 + rho * v2_t + p_y + rho_x * v1 * v2
+ rho * v1_x * v2
+ rho * v1 * v2_x
+ rho_y * v2^2
+ 2.0 * rho * v2 * v2_y
# stress tensor from y-direction
- v1_xy * inv_Re
- v2_xx * inv_Re
- 4.0 / 3.0 * v2_yy * inv_Re
+ 2.0 / 3.0 * v1_xy * inv_Re )
# total energy equation
du4 = ( E_t + v1_x * (E + p) + v1 * (E_x + p_x)
+ v2_y * (E + p) + v2 * (E_y + p_y)
# stress tensor and temperature gradient terms from x-direction
- 4.0 / 3.0 * v1_xx * v1 * inv_Re
+ 2.0 / 3.0 * v2_xy * v1 * inv_Re
- 4.0 / 3.0 * v1_x * v1_x * inv_Re
+ 2.0 / 3.0 * v2_y * v1_x * inv_Re
- v1_xy * v2 * inv_Re
- v2_xx * v2 * inv_Re
- v1_y * v2_x * inv_Re
- v2_x * v2_x * inv_Re
- T_const * inv_rho_cubed * ( p_xx * rho * rho
- 2.0 * p_x * rho * rho_x
+ 2.0 * p * rho_x * rho_x
- p * rho * rho_xx ) * inv_Re
# stress tensor and temperature gradient terms from y-direction
- v1_yy * v1 * inv_Re
- v2_xy * v1 * inv_Re
- v1_y * v1_y * inv_Re
- v2_x * v1_y * inv_Re
- 4.0 / 3.0 * v2_yy * v2 * inv_Re
+ 2.0 / 3.0 * v1_xy * v2 * inv_Re
- 4.0 / 3.0 * v2_y * v2_y * inv_Re
+ 2.0 / 3.0 * v1_x * v2_y * inv_Re
- T_const * inv_rho_cubed * ( p_yy * rho * rho
- 2.0 * p_y * rho * rho_y
+ 2.0 * p * rho_y * rho_y
- p * rho * rho_yy ) * inv_Re )

return SVector(du1, du2, du3, du4)
end

initial_condition = initial_condition_navier_stokes_convergence_test

# BC types
velocity_bc_top_bottom = NoSlip((x, t, equations) -> initial_condition_navier_stokes_convergence_test(x, t, equations)[2:3])
heat_bc_top_bottom = Adiabatic((x, t, equations) -> 0.0)
boundary_condition_top_bottom = BoundaryConditionNavierStokesWall(velocity_bc_top_bottom, heat_bc_top_bottom)
ranocha marked this conversation as resolved.
Show resolved Hide resolved

# define inviscid boundary conditions
boundary_conditions = (; :top_bottom => boundary_condition_slip_wall)

# define viscous boundary conditions
boundary_conditions_parabolic = (; :top_bottom => boundary_condition_top_bottom)

semi = SemidiscretizationHyperbolicParabolic(mesh, (equations, equations_parabolic), initial_condition, dg;
boundary_conditions=(boundary_conditions, boundary_conditions_parabolic),
source_terms=source_terms_navier_stokes_convergence_test)


###############################################################################
# ODE solvers, callbacks etc.

# Create ODE problem with time span `tspan`
tspan = (0.0, 0.5)
ode = semidiscretize(semi, tspan)

summary_callback = SummaryCallback()
alive_callback = AliveCallback(alive_interval=10)
analysis_interval = 100
analysis_callback = AnalysisCallback(semi, interval=analysis_interval, uEltype=real(dg))
callbacks = CallbackSet(summary_callback, alive_callback)

###############################################################################
# run the simulation

time_int_tol = 1e-8
sol = solve(ode, RDPK3SpFSAL49(), abstol=time_int_tol, reltol=time_int_tol,
save_everystep=false, callback=callbacks)
summary_callback() # print the timer summary
74 changes: 74 additions & 0 deletions examples/dgmulti_2d/elixir_navier_stokes_lid_driven_cavity.jl
Original file line number Diff line number Diff line change
@@ -0,0 +1,74 @@
using OrdinaryDiffEq
using Trixi

###############################################################################
# semidiscretization of the ideal compressible Navier-Stokes equations

# TODO: parabolic; unify names of these accessor functions
jlchan marked this conversation as resolved.
Show resolved Hide resolved
reynolds_number() = 1000.0
prandtl_number() = 0.72
mach_number() = 0.1

equations = CompressibleEulerEquations2D(1.4)
equations_parabolic = CompressibleNavierStokesDiffusion2D(equations, Reynolds=reynolds_number(),
Prandtl=prandtl_number(),
Mach_freestream=mach_number())

# Create DG solver with polynomial degree = 3 and (local) Lax-Friedrichs/Rusanov flux as surface flux
dg = DGMulti(polydeg = 3, element_type = Quad(), approximation_type = GaussSBP(),
surface_integral = SurfaceIntegralWeakForm(flux_lax_friedrichs),
volume_integral = VolumeIntegralFluxDifferencing(flux_ranocha))

top(x, tol=50*eps()) = abs(x[2] - 1) < tol
rest_of_boundary(x, tol=50*eps()) = !top(x, tol)
is_on_boundary = Dict(:top => top, :rest_of_boundary => rest_of_boundary)
mesh = DGMultiMesh(dg, cells_per_dimension=(16, 16); is_on_boundary)

function initial_condition_cavity(x, t, equations::CompressibleEulerEquations2D)
Ma = mach_number()
rho = 1.0
u, v = 0, 0
p = 1.0 / (Ma^2 * equations.gamma)
return prim2cons(SVector(rho, u, v, p), equations)
end
initial_condition = initial_condition_cavity

# BC types
velocity_bc_lid = NoSlip((x, t, equations) -> SVector(1.0, 0.0))
velocity_bc_cavity = NoSlip((x, t, equations) -> SVector(0.0, 0.0))
heat_bc = Adiabatic((x, t, equations) -> 0.0)
boundary_condition_lid = BoundaryConditionNavierStokesWall(velocity_bc_lid, heat_bc)
boundary_condition_cavity = BoundaryConditionNavierStokesWall(velocity_bc_cavity, heat_bc)

# define inviscid boundary conditions
boundary_conditions = (; :top => boundary_condition_slip_wall,
:rest_of_boundary => boundary_condition_slip_wall)

# define viscous boundary conditions
boundary_conditions_parabolic = (; :top => boundary_condition_lid,
:rest_of_boundary => boundary_condition_cavity)

semi = SemidiscretizationHyperbolicParabolic(mesh, (equations, equations_parabolic), initial_condition, dg;
boundary_conditions=(boundary_conditions, boundary_conditions_parabolic))


###############################################################################
# ODE solvers, callbacks etc.

# Create ODE problem with time span `tspan`
tspan = (0.0, 10.0)
ode = semidiscretize(semi, tspan);

summary_callback = SummaryCallback()
alive_callback = AliveCallback(alive_interval=10)
analysis_interval = 100
analysis_callback = AnalysisCallback(semi, interval=analysis_interval, uEltype=real(dg))
callbacks = CallbackSet(summary_callback, alive_callback)

###############################################################################
# run the simulation

time_int_tol = 1e-8
sol = solve(ode, RDPK3SpFSAL49(), abstol=time_int_tol, reltol=time_int_tol,
save_everystep=false, callback=callbacks)
summary_callback() # print the timer summary
Loading