From 511088d814ebf27b8dcbdac57598924933698b2e Mon Sep 17 00:00:00 2001 From: Jesse Chan Date: Wed, 24 Aug 2022 22:22:03 -0500 Subject: [PATCH 1/3] adding literate docs for advection-diffusion --- .../src/files/adding_parabolic_terms.jl | 88 +++++++++++++++++++ docs/make.jl | 1 + 2 files changed, 89 insertions(+) create mode 100644 docs/literate/src/files/adding_parabolic_terms.jl diff --git a/docs/literate/src/files/adding_parabolic_terms.jl b/docs/literate/src/files/adding_parabolic_terms.jl new file mode 100644 index 00000000000..381c5c969b1 --- /dev/null +++ b/docs/literate/src/files/adding_parabolic_terms.jl @@ -0,0 +1,88 @@ +#src # Adding parabolic terms (advection-diffusion). + +# Experimental support for parabolic diffusion terms is available in Trixi.jl. +# This demo illustrates parabolic terms for the advection-diffusion equation. + +using OrdinaryDiffEq +using Trixi + +# ## Splitting a system into hyperbolic and parabolic parts. + +# For a mixed hyperbolic-parabolic system, we represent the hyperbolic and parabolic +# parts of the system separately. We first define the hyperbolic (advection) part of +# the advection-diffusion equation. + +advection_velocity = (1.5, 1.0) +equations_hyperbolic = LinearScalarAdvectionEquation2D(advection_velocity); + +# Next, we define the parabolic diffusion term. The constructor requires knowledge of +# `equations_hyperbolic` to be passed in because the `LaplaceDiffusion2D` applies +# diffusion to every variable of the hyperbolic system. + +diffusivity = 5.0e-2 +equations_parabolic = LaplaceDiffusion2D(diffusivity, equations_hyperbolic); + +# ## Boundary conditions + +# As with the equations, we define boundary conditions separately for the hyperbolic and +# parabolic part of the system. For this example, we impose inflow BCs for the hyperbolic +# system (no condition is imposed on the outflow), and we impose Dirichlet boundary conditions +# for the parabolic equations. Both `BoundaryConditionDirichlet` and `BoundaryConditionNeumann` +# are defined for `LaplaceDiffusion2D`. +# +# The hyperbolic and parabolic boundary conditions are assumed to be consistent with each other. + +boundary_condition_zero_dirichlet = BoundaryConditionDirichlet((x, t, equations) -> SVector(0.0)) + +boundary_conditions_hyperbolic = (; x_neg = BoundaryConditionDirichlet((x, t, equations) -> SVector(1 + 0.5 * x[2])), + y_neg = boundary_condition_zero_dirichlet, + y_pos = boundary_condition_zero_dirichlet, + x_pos = boundary_condition_do_nothing) + +boundary_conditions_parabolic = (; x_neg = BoundaryConditionDirichlet((x, t, equations) -> SVector(1 + 0.5 * x[2])), + y_neg = boundary_condition_zero_dirichlet, + y_pos = boundary_condition_zero_dirichlet, + x_pos = boundary_condition_zero_dirichlet); + +# ## Defining the solver and mesh + +# The process of creating the DG solver and mesh is the same as for a purely +# hyperbolic system of equations. + +solver = DGSEM(polydeg=3, surface_flux=flux_lax_friedrichs) +coordinates_min = (-1.0, -1.0) # minimum coordinates (min(x), min(y)) +coordinates_max = ( 1.0, 1.0) # maximum coordinates (max(x), max(y)) +mesh = TreeMesh(coordinates_min, coordinates_max, + initial_refinement_level=4, + periodicity=false, n_cells_max=30_000) # set maximum capacity of tree data structure + +initial_condition = (x, t, equations) -> SVector(0.0); + +# ## Semidiscretizing and solving + +# To semidiscretize a hyperbolic-parabolic system, we create a `SemidiscretizationHyperbolicParabolic`. +# This differs from a `SemidiscretizationHyperbolic` in that we pass in a `Tuple` containing both the +# hyperbolic and parabolic equation, as well as a `Tuple` containing the hyperbolic and parabolic +# boundary conditions. + +semi = SemidiscretizationHyperbolicParabolic(mesh, + (equations_hyperbolic, equations_parabolic), + initial_condition, solver; + boundary_conditions=(boundary_conditions_hyperbolic, + boundary_conditions_parabolic)) + +# The rest of the code is identical to the hyperbolic case. We create a system of ODEs through +# `semidiscretize`, defining callbacks, and then passing the system to OrdinaryDiffEq.jl. + +tspan = (0.0, 1.5) +ode = semidiscretize(semi, tspan) +callbacks = CallbackSet(SummaryCallback()) +time_int_tol = 1.0e-6 +sol = solve(ode, RDPK3SpFSAL49(), abstol=time_int_tol, reltol=time_int_tol, + save_everystep=false, callback=callbacks); + +# We can now visualize the solution, which develops a boundary layer at the outflow boundaries. + +using Plots +plot(sol) + diff --git a/docs/make.jl b/docs/make.jl index 57321677480..0f2deb19386 100644 --- a/docs/make.jl +++ b/docs/make.jl @@ -39,6 +39,7 @@ files = [ # Topic: equations "Adding a new scalar conservation law" => "adding_new_scalar_equations.jl", "Adding a non-conservative equation" => "adding_nonconservative_equation.jl", + "Adding parabolic terms" => "adding_parabolic_terms.jl", # Topic: meshes "Adaptive mesh refinement" => "adaptive_mesh_refinement.jl", "Structured mesh with curvilinear mapping" => "structured_mesh_mapping.jl", From bc1735faf222e1d32d0a4a2da2ebfa7938cdaef3 Mon Sep 17 00:00:00 2001 From: Jesse Chan <1156048+jlchan@users.noreply.github.com> Date: Thu, 25 Aug 2022 06:59:16 -0500 Subject: [PATCH 2/3] Apply suggestions from code review Co-authored-by: Hendrik Ranocha --- docs/literate/src/files/adding_parabolic_terms.jl | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/docs/literate/src/files/adding_parabolic_terms.jl b/docs/literate/src/files/adding_parabolic_terms.jl index 381c5c969b1..ff972fc75fe 100644 --- a/docs/literate/src/files/adding_parabolic_terms.jl +++ b/docs/literate/src/files/adding_parabolic_terms.jl @@ -16,7 +16,7 @@ advection_velocity = (1.5, 1.0) equations_hyperbolic = LinearScalarAdvectionEquation2D(advection_velocity); # Next, we define the parabolic diffusion term. The constructor requires knowledge of -# `equations_hyperbolic` to be passed in because the `LaplaceDiffusion2D` applies +# `equations_hyperbolic` to be passed in because the [`LaplaceDiffusion2D`](@ref) applies # diffusion to every variable of the hyperbolic system. diffusivity = 5.0e-2 @@ -60,8 +60,8 @@ initial_condition = (x, t, equations) -> SVector(0.0); # ## Semidiscretizing and solving -# To semidiscretize a hyperbolic-parabolic system, we create a `SemidiscretizationHyperbolicParabolic`. -# This differs from a `SemidiscretizationHyperbolic` in that we pass in a `Tuple` containing both the +# To semidiscretize a hyperbolic-parabolic system, we create a [`SemidiscretizationHyperbolicParabolic`](@ref). +# This differs from a [`SemidiscretizationHyperbolic`](@ref) in that we pass in a `Tuple` containing both the # hyperbolic and parabolic equation, as well as a `Tuple` containing the hyperbolic and parabolic # boundary conditions. From 3c4efb5576e2808fbcfe03142d5afbc8d43d9277 Mon Sep 17 00:00:00 2001 From: Jesse Chan Date: Thu, 25 Aug 2022 06:59:48 -0500 Subject: [PATCH 3/3] rename "adding parabolic terms" -> "parabolic terms" --- .../src/files/{adding_parabolic_terms.jl => parabolic_terms.jl} | 0 docs/make.jl | 2 +- 2 files changed, 1 insertion(+), 1 deletion(-) rename docs/literate/src/files/{adding_parabolic_terms.jl => parabolic_terms.jl} (100%) diff --git a/docs/literate/src/files/adding_parabolic_terms.jl b/docs/literate/src/files/parabolic_terms.jl similarity index 100% rename from docs/literate/src/files/adding_parabolic_terms.jl rename to docs/literate/src/files/parabolic_terms.jl diff --git a/docs/make.jl b/docs/make.jl index 0f2deb19386..1f2791d7054 100644 --- a/docs/make.jl +++ b/docs/make.jl @@ -39,7 +39,7 @@ files = [ # Topic: equations "Adding a new scalar conservation law" => "adding_new_scalar_equations.jl", "Adding a non-conservative equation" => "adding_nonconservative_equation.jl", - "Adding parabolic terms" => "adding_parabolic_terms.jl", + "Parabolic terms" => "parabolic_terms.jl", # Topic: meshes "Adaptive mesh refinement" => "adaptive_mesh_refinement.jl", "Structured mesh with curvilinear mapping" => "structured_mesh_mapping.jl",