diff --git a/dev/.documenter-siteinfo.json b/dev/.documenter-siteinfo.json index 0f1919d..22081d1 100644 --- a/dev/.documenter-siteinfo.json +++ b/dev/.documenter-siteinfo.json @@ -1 +1 @@ -{"documenter":{"julia_version":"1.11.2","generation_timestamp":"2024-12-03T14:49:02","documenter_version":"1.8.0"}} \ No newline at end of file +{"documenter":{"julia_version":"1.11.2","generation_timestamp":"2024-12-06T16:18:54","documenter_version":"1.8.0"}} \ No newline at end of file diff --git a/dev/index.html b/dev/index.html index f549ef7..ff7b998 100644 --- a/dev/index.html +++ b/dev/index.html @@ -1,13 +1,18 @@ -Home · TrixiAtmo.jl

TrixiAtmo

Documentation for TrixiAtmo.

TrixiAtmo.AbstractCovariantEquationsType
AbstractCovariantEquations{NDIMS, 
+Home · TrixiAtmo.jl

TrixiAtmo

Documentation for TrixiAtmo.

TrixiAtmo.AbstractCovariantEquationsType
AbstractCovariantEquations{NDIMS, 
                            NDIMS_AMBIENT, 
-                           NVARS} <: AbstractEquations{NDIMS, NVARS}

Abstract type used to dispatch on systems of equations in covariant form, in which fluxes and prognostic variables are stored and computed in terms of their contravariant components defining their expansions in terms of the local covariant tangent basis. The type parameter NDIMS denotes the dimension of the manifold on which the equations are solved, while NDIMS_AMBIENT is the dimension of the ambient space in which such a manifold is embedded. Some references on discontinuous Galerkin methods in covariant flux form are listed below:

  • M. Baldauf (2020). Discontinuous Galerkin solver for the shallow-water equations in covariant form on the sphere and the ellipsoid. Journal of Computational Physics 410:109384. DOI: 10.1016/j.jcp.2020.109384
  • M. Baldauf (2021). A horizontally explicit, vertically implicit (HEVI) discontinuous Galerkin scheme for the 2-dimensional Euler and Navier-Stokes equations using terrain-following coordinates. Journal of Computational Physics 446:110635. DOI: 10.1016/ j.jcp.2021.110635
  • L. Bao, R. D. Nair, and H. M. Tufo (2014). A mass and momentum flux-form high-order discontinuous Galerkin shallow water model on the cubed-sphere. A mass and momentum flux-form high-order discontinuous Galerkin shallow water model on the cubed-sphere. Journal of Computational Physics 271:224-243. DOI: 10.1016/j.jcp.2013.11.033

When using this equation type, functions which are evaluated pointwise, such as fluxes, source terms, and initial conditions take in the extra argument aux_vars, which contains the geometric information needed for the covariant form. To convert an initial condition given in terms of global spherical velocity or momentum components to one given in terms of local contravariant components, see transform_to_contravariant.

source
TrixiAtmo.CovariantLinearAdvectionEquation2DType
CovariantLinearAdvectionEquation2D <: AbstractCovariantEquations{2, 3, 3}

A variable-coefficient linear advection equation can be defined on a two-dimensional manifold $S \subset \mathbb{R}^3$ as

\[\partial_t h + \nabla_S \cdot (h \vec{v}) = 0,\]

where $\nabla_S \cdot$ is the horizontal divergence operator on $S$. We treat this problem as a system of equations in which the first variable is the scalar conserved quantity $h$, and the second two are the contravariant components $v^1$ and $v^2$ used in the expansion with respect to the covariant basis vectors $\vec{a}_1$ and $\vec{a}_2$ as

\[\vec{v} = v^1 \vec{a}_1 + v^2 \vec{a}_2.\]

where $\vec{a}_1 = \partial \vec{x} / \partial \xi^1$ and $\vec{a}_2 = \partial \vec{x} / \partial \xi^2$ are the so-called covariant basis vectors, and $\xi^1$ and $\xi^2$ are the local reference space coordinates. The velocity components are spatially varying but assumed to be constant in time, so we do not apply any flux or dissipation to such variables. The resulting system is then given on the reference element as

\[\sqrt{G} \frac{\partial}{\partial t}\left[\begin{array}{c} h \\ v^1 \\ v^2 \end{array}\right] + GlobalCoordinateSystem, + NVARS} <: AbstractEquations{NDIMS, NVARS}

Abstract type used to dispatch on systems of equations in covariant form, in which fluxes and prognostic variables are stored and computed in terms of their contravariant components defining their expansions in terms of the local covariant tangent basis. The type parameter NDIMS denotes the dimension of the manifold on which the equations are solved, while NDIMS_AMBIENT is the dimension of the ambient space in which such a manifold is embedded. Some references on discontinuous Galerkin methods in covariant flux form are listed below:

  • M. Baldauf (2020). Discontinuous Galerkin solver for the shallow-water equations in covariant form on the sphere and the ellipsoid. Journal of Computational Physics 410:109384. DOI: 10.1016/j.jcp.2020.109384
  • M. Baldauf (2021). A horizontally explicit, vertically implicit (HEVI) discontinuous Galerkin scheme for the 2-dimensional Euler and Navier-Stokes equations using terrain-following coordinates. Journal of Computational Physics 446:110635. DOI: 10.1016/ j.jcp.2021.110635
  • L. Bao, R. D. Nair, and H. M. Tufo (2014). A mass and momentum flux-form high-order discontinuous Galerkin shallow water model on the cubed-sphere. A mass and momentum flux-form high-order discontinuous Galerkin shallow water model on the cubed-sphere. Journal of Computational Physics 271:224-243. DOI: 10.1016/j.jcp.2013.11.033

When using this equation type, functions which are evaluated pointwise, such as fluxes, source terms, and initial conditions take in the extra argument aux_vars, which contains the geometric information needed for the covariant form. The type parameter GlobalCoordinateSystem specifies the global coordinate system used to define the covariant tangent basis, and may be either GlobalCartesianCoordinates or GlobalSphericalCoordinates. The GlobalCoordinateSystem type parameter also specifies the coordinate system with respect to which the initial condition should be prescribed.

source
TrixiAtmo.CovariantLinearAdvectionEquation2DType
CovariantLinearAdvectionEquation2D{GlobalCoordinateSystem} <:  
+    AbstractCovariantEquations{2, 3, GlobalCoordinateSystem, 3}

A variable-coefficient linear advection equation can be defined on a two-dimensional manifold $S \subset \mathbb{R}^3$ as

\[\partial_t h + \nabla_S \cdot (h \vec{v}) = 0,\]

where $\nabla_S \cdot$ is the horizontal divergence operator on $S$. We treat this problem as a system of equations in which the first variable is the scalar conserved quantity $h$, and the second two are the contravariant components $v^1$ and $v^2$ used in the expansion with respect to the covariant basis vectors $\vec{a}_1$ and $\vec{a}_2$ as

\[\vec{v} = v^1 \vec{a}_1 + v^2 \vec{a}_2,\]

where $\vec{a}_1 = \partial \vec{x} / \partial \xi^1$ and $\vec{a}_2 = \partial \vec{x} / \partial \xi^2$ are the so-called covariant basis vectors, and $\xi^1$ and $\xi^2$ are the local reference space coordinates. The velocity components are spatially varying but assumed to be constant in time, so we do not apply any flux or dissipation to such variables. The resulting system is then given on the reference element as

\[\sqrt{G} \frac{\partial}{\partial t} +\left[\begin{array}{c} h \\ v^1 \\ v^2 \end{array}\right] + -\frac{\partial}{\partial \xi^1} \left[\begin{array}{c} \sqrt{G} h v^1 \\ 0 \\ 0 \end{array}\right] +\frac{\partial}{\partial \xi^1} +\left[\begin{array}{c} \sqrt{G} h v^1 \\ 0 \\ 0 \end{array}\right] + -\frac{\partial}{\partial \xi^2} \left[\begin{array}{c} \sqrt{G} h v^2 \\ 0 \\ 0 \end{array}\right] +\frac{\partial}{\partial \xi^2} +\left[\begin{array}{c} \sqrt{G} h v^2 \\ 0 \\ 0 \end{array}\right] = -\left[\begin{array}{c} 0 \\ 0 \\ 0 \end{array}\right],\]

where $G$ is the determinant of the covariant metric tensor expressed as a matrix with entries $G_{ij} = \vec{a}_i \cdot \vec{a}_j$. Note that the variable advection velocity components could also be stored as auxiliary variables, similarly to the geometric information.

source
TrixiAtmo.MetricTermsCrossProductType
MetricTermsCrossProduct()

Struct used for multiple dispatch on functions that compute the metric terms. When the argument metric_terms is of type MetricTermsCrossProduct, the contravariant vectors are computed using the cross-product form.

source
TrixiAtmo.MetricTermsInvariantCurlType
MetricTermsInvariantCurl()

Struct used for multiple dispatch on functions that compute the metric terms. When the argument metric_terms is of type MetricTermsInvariantCurl, the contravariant vectors are computed using the invariant curl form.

References

  • Kopriva, D. A. (2006). Metric identities and the discontinuous spectral element method on curvilinear meshes. Journal of Scientific Computing 26, 301-327. DOI: 10.1007/s10915-005-9070-8
  • Vinokur, M. and Yee, H. C. (2001). Extension of efficient low dissipation high order schemes for 3-D curvilinear moving grids. In Caughey, D. A., and Hafez, M. M. (eds.), Frontiers of Computational Fluid Dynamics 2002, World Scientific, Singapore, pp. 129–164. DOI: 10.1142/9789812810793_0008
source
TrixiAtmo.ShallowWaterEquations3DType
ShallowWaterEquations3D(; gravity, H0 = 0)

Shallow water equations (SWE) in three space dimensions in conservation form (with constant bottom topography). The equations are given by

\[\begin{aligned} +\left[\begin{array}{c} 0 \\ 0 \\ 0 \end{array}\right],\]

where $G$ is the determinant of the covariant metric tensor expressed as a 2 by 2 matrix with entries $G_{ij} = \vec{a}_i \cdot \vec{a}_j$. Note that the variable advection velocity components could alternatively be stored as auxiliary variables, similarly to the geometric information.

source
TrixiAtmo.GlobalCartesianCoordinatesType
GlobalCartesianCoordinates()

Struct used for dispatch, specifying that the covariant tangent basis vectors should be defined with respect to a global Cartesian coordinate system.

source
TrixiAtmo.GlobalSphericalCoordinatesType
GlobalSphericalCoordinates()

Struct used for dispatch, specifying that the covariant tangent basis vectors should be defined with respect to a global spherical coordinate system.

source
TrixiAtmo.MetricTermsCrossProductType
MetricTermsCrossProduct()

Struct used for multiple dispatch on functions that compute the metric terms. When the argument metric_terms is of type MetricTermsCrossProduct, the contravariant vectors are computed using the cross-product form.

source
TrixiAtmo.MetricTermsInvariantCurlType
MetricTermsInvariantCurl()

Struct used for multiple dispatch on functions that compute the metric terms. When the argument metric_terms is of type MetricTermsInvariantCurl, the contravariant vectors are computed using the invariant curl form.

References

  • Kopriva, D. A. (2006). Metric identities and the discontinuous spectral element method on curvilinear meshes. Journal of Scientific Computing 26, 301-327. DOI: 10.1007/s10915-005-9070-8
  • Vinokur, M. and Yee, H. C. (2001). Extension of efficient low dissipation high order schemes for 3-D curvilinear moving grids. In Caughey, D. A., and Hafez, M. M. (eds.), Frontiers of Computational Fluid Dynamics 2002, World Scientific, Singapore, pp. 129–164. DOI: 10.1142/9789812810793_0008
source
TrixiAtmo.ShallowWaterEquations3DType
ShallowWaterEquations3D(; gravity, H0 = 0)

Shallow water equations (SWE) in three space dimensions in conservation form (with constant bottom topography). The equations are given by

\[\begin{aligned} \frac{\partial h}{\partial t} + \frac{\partial}{\partial x}(h v_1) + \frac{\partial}{\partial y}(h v_2) + \frac{\partial}{\partial z}(h v_3) &= 0 \\ \frac{\partial}{\partial t}(h v_1) + \frac{\partial}{\partial x}\left(h v_1^2 + \frac{g}{2}h^2\right) @@ -16,22 +21,16 @@ + \frac{\partial}{\partial y}\left(h v_2^2 + \frac{g}{2}h^2\right) + \frac{\partial}{\partial z}(h v_2 v_3) &= 0 \\ \frac{\partial}{\partial t}(h v_3) + \frac{\partial}{\partial x}(h v_1 v_3) + \frac{\partial}{\partial y}(h v_2 v_3) + \frac{\partial}{\partial z}\left(h v_3^2 + \frac{g}{2}h^2\right) &= 0. -\end{aligned}\]

The unknown quantities of the SWE are the water height $h$ and the velocities $\mathbf{v} = (v_1, v_2, v_3)^T$. The gravitational constant is denoted by g.

The 3D Shallow Water Equations (SWE) extend the 2D SWE to model shallow water flows on 2D manifolds embedded within 3D space. To confine the flow to the 2D manifold, a source term incorporating a Lagrange multiplier is applied. This term effectively removes momentum components that are normal to the manifold, ensuring the flow remains constrained within the 2D surface.

The additional quantity $H_0$ is also available to store a reference value for the total water height that is useful to set initial conditions or test the "lake-at-rest" well-balancedness.

In addition to the unknowns, Trixi.jl currently stores the bottom topography values at the approximation points despite being fixed in time. This is done for convenience of computing the bottom topography gradients on the fly during the approximation as well as computing auxiliary quantities like the total water height $H$ or the entropy variables. This affects the implementation and use of these equations in various ways:

  • The flux values corresponding to the bottom topography must be zero.
  • The bottom topography values must be included when defining initial conditions, boundary conditions or source terms.
  • AnalysisCallback analyzes this variable.
  • Trixi.jl's visualization tools will visualize the bottom topography by default.

References:

source
Trixi.flux_fjordholm_etalMethod
flux_fjordholm_etal(u_ll, u_rr, orientation,
-                    equations::ShallowWaterEquations1D)

Total energy conservative (mathematical entropy for shallow water equations). When the bottom topography is nonzero this should only be used as a surface flux otherwise the scheme will not be well-balanced. For well-balancedness in the volume flux use flux_wintermeyer_etal.

Details are available in Eq. (4.1) in the paper:

  • Ulrik S. Fjordholm, Siddhartha Mishr and Eitan Tadmor (2011) Well-balanced and energy stable schemes for the shallow water equations with discontinuous topography DOI: 10.1016/j.jcp.2011.03.042
source
Trixi.flux_wintermeyer_etalMethod
flux_wintermeyer_etal(u_ll, u_rr, orientation_or_normal_direction,
-                      equations::ShallowWaterEquations2D)

Total energy conservative (mathematical entropy for shallow water equations) split form. When the bottom topography is nonzero this scheme will be well-balanced when used as a volume_flux. For the surface_flux either flux_wintermeyer_etal or flux_fjordholm_etal can be used to ensure well-balancedness and entropy conservation.

Further details are available in Theorem 1 of the paper:

  • Niklas Wintermeyer, Andrew R. Winters, Gregor J. Gassner and David A. Kopriva (2017) An entropy stable nodal discontinuous Galerkin method for the two dimensional shallow water equations on unstructured curvilinear meshes with discontinuous bathymetry DOI: 10.1016/j.jcp.2017.03.036
source
TrixiAtmo.P4estMeshCubedSphere2DMethod
P4estMeshCubedSphere2D(trees_per_face_dimension, radius;
+\end{aligned}\]

The unknown quantities of the SWE are the water height $h$ and the velocities $\mathbf{v} = (v_1, v_2, v_3)^T$. The gravitational constant is denoted by g.

The 3D Shallow Water Equations (SWE) extend the 2D SWE to model shallow water flows on 2D manifolds embedded within 3D space. To confine the flow to the 2D manifold, a source term incorporating a Lagrange multiplier is applied. This term effectively removes momentum components that are normal to the manifold, ensuring the flow remains constrained within the 2D surface.

The additional quantity $H_0$ is also available to store a reference value for the total water height that is useful to set initial conditions or test the "lake-at-rest" well-balancedness.

In addition to the unknowns, Trixi.jl currently stores the bottom topography values at the approximation points despite being fixed in time. This is done for convenience of computing the bottom topography gradients on the fly during the approximation as well as computing auxiliary quantities like the total water height $H$ or the entropy variables. This affects the implementation and use of these equations in various ways:

  • The flux values corresponding to the bottom topography must be zero.
  • The bottom topography values must be included when defining initial conditions, boundary conditions or source terms.
  • AnalysisCallback analyzes this variable.
  • Trixi.jl's visualization tools will visualize the bottom topography by default.

References:

source
Trixi.flux_fjordholm_etalMethod
flux_fjordholm_etal(u_ll, u_rr, orientation,
+                    equations::ShallowWaterEquations1D)

Total energy conservative (mathematical entropy for shallow water equations). When the bottom topography is nonzero this should only be used as a surface flux otherwise the scheme will not be well-balanced. For well-balancedness in the volume flux use flux_wintermeyer_etal.

Details are available in Eq. (4.1) in the paper:

  • Ulrik S. Fjordholm, Siddhartha Mishr and Eitan Tadmor (2011) Well-balanced and energy stable schemes for the shallow water equations with discontinuous topography DOI: 10.1016/j.jcp.2011.03.042
source
Trixi.flux_wintermeyer_etalMethod
flux_wintermeyer_etal(u_ll, u_rr, orientation_or_normal_direction,
+                      equations::ShallowWaterEquations2D)

Total energy conservative (mathematical entropy for shallow water equations) split form. When the bottom topography is nonzero this scheme will be well-balanced when used as a volume_flux. For the surface_flux either flux_wintermeyer_etal or flux_fjordholm_etal can be used to ensure well-balancedness and entropy conservation.

Further details are available in Theorem 1 of the paper:

  • Niklas Wintermeyer, Andrew R. Winters, Gregor J. Gassner and David A. Kopriva (2017) An entropy stable nodal discontinuous Galerkin method for the two dimensional shallow water equations on unstructured curvilinear meshes with discontinuous bathymetry DOI: 10.1016/j.jcp.2017.03.036
source
TrixiAtmo.P4estMeshCubedSphere2DMethod
P4estMeshCubedSphere2D(trees_per_face_dimension, radius;
                         polydeg, RealT=Float64,
                         initial_refinement_level=0, unsaved_changes=true,
                         p4est_partition_allow_for_coarsening=true,
-                        element_local_mapping=false)

Build a "Cubed Sphere" mesh as a 2D P4estMesh with 6 * trees_per_face_dimension^2 trees.

The mesh will have no boundaries.

Arguments

  • trees_per_face_dimension::Integer: the number of trees in the two local dimensions of each face.
  • radius::Integer: the radius of the sphere.
  • polydeg::Integer: polynomial degree used to store the geometry of the mesh. The mapping will be approximated by an interpolation polynomial of the specified degree for each tree.
  • RealT::Type: the type that should be used for coordinates.
  • initial_refinement_level::Integer: refine the mesh uniformly to this level before the simulation starts.
  • unsaved_changes::Bool: if set to true, the mesh will be saved to a mesh file.
  • p4est_partition_allow_for_coarsening::Bool: Must be true when using AMR to make mesh adaptivity independent of domain partitioning. Should be false for static meshes to permit more fine-grained partitioning.
  • element_local_mapping::Bool: option to use the alternative element-local mapping from Appendix A of Guba et al. (2014). If set to true, the four corner vertex positions for each element will be obtained through an equiangular gnomonic projection (Ronchi et al. 1996), and the tree node coordinates within the element (i.e. the field tree_node_coordinates) will be obtained by first using a bilinear mapping based on the four corner vertices, and then projecting the bilinearly mapped nodes onto the spherical surface by normalizing the resulting Cartesian coordinates and scaling by radius. If set to false, the equiangular gnomonic projection will be used for all tree node coordinates.
Warning

Adaptivity and MPI parallelization are not yet supported for equations in covariant form, and we require initial_refinement_level = 0 for such cases. Furthermore, the calculation of the metric terms for the covariant form currently requires polydeg to be equal to the polynomial degree of the solver, and element_local_mapping = true.

!!!

source
TrixiAtmo.P4estMeshQuadIcosahedron2DMethod
P4estMeshQuadIcosahedron2D(trees_per_face_dimension, radius;
+                        element_local_mapping=false)

Build a "Cubed Sphere" mesh as a 2D P4estMesh with 6 * trees_per_face_dimension^2 trees.

The mesh will have no boundaries.

Arguments

  • trees_per_face_dimension::Integer: the number of trees in the two local dimensions of each face.
  • radius::Integer: the radius of the sphere.
  • polydeg::Integer: polynomial degree used to store the geometry of the mesh. The mapping will be approximated by an interpolation polynomial of the specified degree for each tree.
  • RealT::Type: the type that should be used for coordinates.
  • initial_refinement_level::Integer: refine the mesh uniformly to this level before the simulation starts.
  • unsaved_changes::Bool: if set to true, the mesh will be saved to a mesh file.
  • p4est_partition_allow_for_coarsening::Bool: Must be true when using AMR to make mesh adaptivity independent of domain partitioning. Should be false for static meshes to permit more fine-grained partitioning.
  • element_local_mapping::Bool: option to use the alternative element-local mapping from Appendix A of Guba et al. (2014). If set to true, the four corner vertex positions for each element will be obtained through an equiangular gnomonic projection (Ronchi et al. 1996), and the tree node coordinates within the element (i.e. the field tree_node_coordinates) will be obtained by first using a bilinear mapping based on the four corner vertices, and then projecting the bilinearly mapped nodes onto the spherical surface by normalizing the resulting Cartesian coordinates and scaling by radius. If set to false, the equiangular gnomonic projection will be used for all tree node coordinates.
Warning

Adaptivity and MPI parallelization are not yet supported for equations in covariant form, and we require initial_refinement_level = 0 for such cases. Furthermore, the calculation of the metric terms for the covariant form currently requires polydeg to be equal to the polynomial degree of the solver, and element_local_mapping = true.

source
TrixiAtmo.P4estMeshQuadIcosahedron2DMethod
P4estMeshQuadIcosahedron2D(trees_per_face_dimension, radius;
                            polydeg, RealT=Float64,
                            initial_refinement_level=0, unsaved_changes=true,
-                           p4est_partition_allow_for_coarsening=true)

Build a quad-based icosahedral mesh as a 2D P4estMesh with 60 * trees_per_face_dimension^2 trees (20 triangular faces of the icosahedron, each subdivided into 3 parent quads, each of which subdivided into trees_per_face_dimension^2 trees).

The node coordinates of the trees will be obtained using the element-local mapping from Appendix A of Guba et al. (2014). See P4estMeshCubedSphere2D for more information about the element-local mapping.

The mesh will have no boundaries.

Arguments

  • trees_per_face_dimension::Integer: the number of trees in the two local dimensions of each parent quad.
  • radius::Integer: the radius of the sphere.
  • polydeg::Integer: polynomial degree used to store the geometry of the mesh. The mapping will be approximated by an interpolation polynomial of the specified degree for each tree.
  • RealT::Type: the type that should be used for coordinates.
  • initial_refinement_level::Integer: refine the mesh uniformly to this level before the simulation starts.
  • unsaved_changes::Bool: if set to true, the mesh will be saved to a mesh file.
  • p4est_partition_allow_for_coarsening::Bool: Must be true when using AMR to make mesh adaptivity independent of domain partitioning. Should be false for static meshes to permit more fine-grained partitioning.
Warning

Adaptivity and MPI parallelization are not yet supported for equations in covariant form, and we require initial_refinement_level = 0 for such cases. Furthermore, the calculation of the metric terms for the covariant form currently requires polydeg to be equal to the polynomial degree of the solver.

!!!

source
TrixiAtmo.clean_solution_lagrange_multiplier!Method
     clean_solution_lagrange_multiplier!(u, equations::ShallowWaterEquations3D, normal_direction)

Function to apply Lagrange multiplier discretely to the solution in order to constrain the momentum to a 2D manifold.

The vector normal_direction is perpendicular to the 2D manifold. By default, this is the normal contravariant basis vector.

source
TrixiAtmo.examples_dirMethod
examples_dir()

Return the directory where the example files provided with TrixiAtmo.jl are located. If TrixiAtmo.jl is installed as a regular package (with ]add Trixi), these files are read-only and should not be modified. To find out which files are available, use, e.g., readdir:

Examples

readdir(examples_dir())
source
TrixiAtmo.have_aux_node_varsMethod
have_aux_node_vars(equations)

Trait function determining whether equations requires the use of auxiliary variables. Classical conservation laws such as the CompressibleEulerEquations2D do not require auxiliary variables. The return value will be True() or False() to allow dispatching on the return type.

source
TrixiAtmo.initial_condition_gaussianMethod
initial_condition_gaussian(x, t)

This Gaussian bell case is a smooth initial condition suitable for testing the convergence of discretizations of the linear advection equation on a spherical domain of radius $a = 6. 37122 \times 10^3\ \mathrm{m}$, representing the surface of the Earth. The height field is given in terms of the Cartesian coordinates $x$, $y$, $z$ as

\[h(x,y,z) = h_0 \exp\Big(-b_0 \big((x-x_0)^2 + (y-y_0)^2 + (z-z_0)^2\big) \Big),\]

where $h_0 = 1 \times 10^3\ \mathrm{m}$ is the height of the bell, $b_0 = 5 / a$ is the width parameter, and the Cartesian coordinates of the bell's centre at longitude $\lambda_0 = 3\pi/2$ and latitude $\theta_0 = 0$ are given by

\[\begin{aligned} -x_0 &= a\cos\theta_0\cos\lambda_0,\\ -y_0 &= a\cos\theta_0\sin\lambda_0,\\ -z_0 &= a\sin\theta_0. -\end{aligned}\]

The velocity field corresponds to a solid body rotation with a period of 12 days, at an angle of $\alpha = \pi/4$ from the polar axis. The zonal and meridional components of the velocity field are then given in terms of the longitude $\lambda$ and latitude $\theta$ as

\[\begin{aligned} -u(\lambda,\theta) &= V (\cos\theta\cos\alpha + \sin\theta\cos\lambda\sin\alpha),\\ -v(\lambda,\theta) &= -V \sin\lambda\sin\alpha, -\end{aligned}\]

where we take $V = 2\pi a / 12\ \mathrm{days}$. This test case is adapted from Case 1 of the test suite described in the following paper:

  • D. L. Williamson, J. B. Drake, J. J. Hack, R. Jakob, and P. N. Swarztrauber (1992). A standard test set for numerical approximations to the shallow water equations in spherical geometry. Journal of Computational Physics, 102(1):211-224. DOI: 10.1016/S0021-9991(05)80016-6

This function returns SVector(h, vlon, vlat, b), where the first three entries are the height, zonal velocity, and meridional velocity. The fourth entry, representing variable bottom topography, is set to zero. The functions transform_to_contravariant and transform_to_cartesian are available for converting to the prognostic variables for Cartesian and covariant formulations.

source
TrixiAtmo.source_terms_lagrange_multiplierMethod
source_terms_lagrange_multiplier(u, du, x, t,
+                           p4est_partition_allow_for_coarsening=true)

Build a quad-based icosahedral mesh as a 2D P4estMesh with 60 * trees_per_face_dimension^2 trees (20 triangular faces of the icosahedron, each subdivided into 3 parent quads, each of which subdivided into trees_per_face_dimension^2 trees).

The node coordinates of the trees will be obtained using the element-local mapping from Appendix A of Guba et al. (2014). See P4estMeshCubedSphere2D for more information about the element-local mapping.

The mesh will have no boundaries.

Arguments

  • trees_per_face_dimension::Integer: the number of trees in the two local dimensions of each parent quad.
  • radius::Integer: the radius of the sphere.
  • polydeg::Integer: polynomial degree used to store the geometry of the mesh. The mapping will be approximated by an interpolation polynomial of the specified degree for each tree.
  • RealT::Type: the type that should be used for coordinates.
  • initial_refinement_level::Integer: refine the mesh uniformly to this level before the simulation starts.
  • unsaved_changes::Bool: if set to true, the mesh will be saved to a mesh file.
  • p4est_partition_allow_for_coarsening::Bool: Must be true when using AMR to make mesh adaptivity independent of domain partitioning. Should be false for static meshes to permit more fine-grained partitioning.
Warning

Adaptivity and MPI parallelization are not yet supported for equations in covariant form, and we require initial_refinement_level = 0 for such cases. Furthermore, the calculation of the metric terms for the covariant form currently requires polydeg to be equal to the polynomial degree of the solver.

source
TrixiAtmo.clean_solution_lagrange_multiplier!Method
     clean_solution_lagrange_multiplier!(u, equations::ShallowWaterEquations3D, normal_direction)

Function to apply Lagrange multiplier discretely to the solution in order to constrain the momentum to a 2D manifold.

The vector normal_direction is perpendicular to the 2D manifold. By default, this is the normal contravariant basis vector.

source
TrixiAtmo.contravariant2globalFunction
contravariant2global(u, aux_vars, equations)

Transform the vector u of solution variables with the momentum or velocity given in terms of local contravariant components into the global coordinate system specified by the GlobalCoordinateSystem type parameter in AbstractCovariantEquations. u is a vector type of the correct length nvariables(equations). Notice the function doesn't include any error checks for the purpose of efficiency, so please make sure your input is correct. The inverse conversion is performed by global2contravariant.

source
TrixiAtmo.examples_dirMethod
examples_dir()

Return the directory where the example files provided with TrixiAtmo.jl are located. If TrixiAtmo.jl is installed as a regular package (with ]add Trixi), these files are read-only and should not be modified. To find out which files are available, use, e.g., readdir:

Examples

readdir(examples_dir())
source
TrixiAtmo.global2contravariantFunction
global2contravariant(u, aux_vars, equations)

Transform the vector u of solution variables with momentum or velocity components given with respect to the global coordinate system into local contravariant components. The global coordinate system is specified by the GlobalCoordinateSystem type parameter in AbstractCovariantEquations. u is a vector type of the correct length nvariables(equations). Notice the function doesn't include any error checks for the purpose of efficiency, so please make sure your input is correct. The inverse conversion is performed by contravariant2global.

source
TrixiAtmo.have_aux_node_varsMethod
have_aux_node_vars(equations)

Trait function determining whether equations requires the use of auxiliary variables. Classical conservation laws such as the CompressibleEulerEquations2D do not require auxiliary variables. The return value will be True() or False() to allow dispatching on the return type.

source
TrixiAtmo.initial_condition_gaussianMethod
initial_condition_gaussian(x, t, equations)

This Gaussian bell case is a smooth initial condition suitable for testing the convergence of discretizations of the linear advection equation on a spherical domain of radius $6. 37122 \times 10^3\ \mathrm{m}$, representing the surface of the Earth. Denoting the Euclidean norm as $\lVert \cdot \rVert$, the initial height field is given by

\[h(\vec{x}) = h_0 \exp +\Big(-b_0 \big(\lVert \vec{x} - \vec{x}_0 \rVert / \lVert \vec{x} \rVert\big)^2 \Big),\]

where $h_0 = 1 \times 10^3\ \mathrm{m}$ is the height of the bell, $b_0 = 5$ is the width parameter, and $\vec{x}_0$ is the position of the centre of the bell, which is initialized at a longitude of $3\pi/2$ and a latitude of zero. The velocity field corresponds to a solid body rotation with a period of 12 days at an angle of $\alpha = \pi/4$ from the polar axis. Denoting $\vec{\omega}$ as the corresponding angular velocity vector, the velocity is therefore initialized as

\[\vec{v}(\vec{x}) = \vec{\omega} \times \vec{x}.\]

This problem is adapted from Case 1 of the test suite described in the following paper:

  • D. L. Williamson, J. B. Drake, J. J. Hack, R. Jakob, and P. N. Swarztrauber (1992). A standard test set for numerical approximations to the shallow water equations in spherical geometry. Journal of Computational Physics, 102(1):211-224. DOI: 10.1016/S0021-9991(05)80016-6
source
TrixiAtmo.source_terms_lagrange_multiplierMethod
source_terms_lagrange_multiplier(u, du, x, t,
                                       equations::ShallowWaterEquations3D,
-                                      normal_direction)

Source term function to apply a Lagrange multiplier to the semi-discretization in order to constrain the momentum to a 2D manifold.

The vector normal_direction is perpendicular to the 2D manifold. By default, this is the normal contravariant basis vector.

source
TrixiAtmo.transform_to_cartesianMethod
transform_to_cartesian(initial_condition, equations)

Takes in a function with the signature initial_condition(x, t) which returns an initial condition given in terms of zonal and meridional velocity or momentum components, and returns another function with the signature initial_condition_transformed(x, t, equations) which returns the same initial condition with the velocity or momentum vector given in terms of Cartesian components.

source
TrixiAtmo.transform_to_contravariantMethod
transform_to_contravariant(initial_condition, equations)

Takes in a function with the signature initial_condition(x, t) which returns an initial condition given in terms of zonal and meridional velocity or momentum components, and returns another function with the signature initial_condition_transformed(x, t, aux_vars, equations) which returns the same initial condition with the velocity or momentum vector given in terms of contravariant components.

source
+ normal_direction)

Source term function to apply a Lagrange multiplier to the semi-discretization in order to constrain the momentum to a 2D manifold.

The vector normal_direction is perpendicular to the 2D manifold. By default, this is the normal contravariant basis vector.

source
TrixiAtmo.transform_initial_conditionMethod
transform_initial_condition(initial_condition, equations)

Takes in a function with the signature initial_condition(x, t, equations) which returns an initial condition given in terms of global Cartesian or zonal/meridional velocity components, and returns another function initial_condition_transformed(x, t, equations) or initial_condition_transformed(x, t, aux_vars, equations) which returns the same initial data, but transformed to the appropriate prognostic variables used internally by the solver. For the covariant form, this involves a transformation of the global velocity components to contravariant components using global2contravariant as well as a conversion from primitive to conservative variables. For standard Cartesian formulations, this simply involves a conversion from primitive to conservative variables. The intention here is to have a set of test cases (for example, initial_condition_gaussian) for which the initial condition is prescribed using a standardized set of primitive variables in a global Cartesian coordinates, and transformed to the specific prognostic variables required for a given model.

Note

When using the covariant formulation, the initial velocity components should be defined in the coordinate system specified by the GlobalCoordinateSystem type parameter in AbstractCovariantEquations.

source
diff --git a/dev/objects.inv b/dev/objects.inv index 1844329..9c8deae 100644 Binary files a/dev/objects.inv and b/dev/objects.inv differ diff --git a/dev/search_index.js b/dev/search_index.js index 2193772..178b0a8 100644 --- a/dev/search_index.js +++ b/dev/search_index.js @@ -1,3 +1,3 @@ var documenterSearchIndex = {"docs": -[{"location":"","page":"Home","title":"Home","text":"CurrentModule = TrixiAtmo","category":"page"},{"location":"#TrixiAtmo","page":"Home","title":"TrixiAtmo","text":"","category":"section"},{"location":"","page":"Home","title":"Home","text":"Documentation for TrixiAtmo.","category":"page"},{"location":"","page":"Home","title":"Home","text":"","category":"page"},{"location":"","page":"Home","title":"Home","text":"Modules = [TrixiAtmo]","category":"page"},{"location":"#TrixiAtmo.TrixiAtmo","page":"Home","title":"TrixiAtmo.TrixiAtmo","text":"🌍 TrixiAtmo 🌍\n\nTrixiAtmo.jl is a simulation package for atmospheric models based on Trixi.jl\n\nSee also: trixi-framework/TrixiAtmo.jl\n\n\n\n\n\n","category":"module"},{"location":"#TrixiAtmo.AbstractCovariantEquations","page":"Home","title":"TrixiAtmo.AbstractCovariantEquations","text":"AbstractCovariantEquations{NDIMS, \n NDIMS_AMBIENT, \n NVARS} <: AbstractEquations{NDIMS, NVARS}\n\nAbstract type used to dispatch on systems of equations in covariant form, in which fluxes and prognostic variables are stored and computed in terms of their contravariant components defining their expansions in terms of the local covariant tangent basis. The type parameter NDIMS denotes the dimension of the manifold on which the equations are solved, while NDIMS_AMBIENT is the dimension of the ambient space in which such a manifold is embedded. Some references on discontinuous Galerkin methods in covariant flux form are listed below:\n\nM. Baldauf (2020). Discontinuous Galerkin solver for the shallow-water equations in covariant form on the sphere and the ellipsoid. Journal of Computational Physics 410:109384. DOI: 10.1016/j.jcp.2020.109384 \nM. Baldauf (2021). A horizontally explicit, vertically implicit (HEVI) discontinuous Galerkin scheme for the 2-dimensional Euler and Navier-Stokes equations using terrain-following coordinates. Journal of Computational Physics 446:110635. DOI: 10.1016/ j.jcp.2021.110635\nL. Bao, R. D. Nair, and H. M. Tufo (2014). A mass and momentum flux-form high-order discontinuous Galerkin shallow water model on the cubed-sphere. A mass and momentum flux-form high-order discontinuous Galerkin shallow water model on the cubed-sphere. Journal of Computational Physics 271:224-243. DOI: 10.1016/j.jcp.2013.11.033\n\nWhen using this equation type, functions which are evaluated pointwise, such as fluxes, source terms, and initial conditions take in the extra argument aux_vars, which contains the geometric information needed for the covariant form. To convert an initial condition given in terms of global spherical velocity or momentum components to one given in terms of local contravariant components, see transform_to_contravariant.\n\n\n\n\n\n","category":"type"},{"location":"#TrixiAtmo.CovariantLinearAdvectionEquation2D","page":"Home","title":"TrixiAtmo.CovariantLinearAdvectionEquation2D","text":"CovariantLinearAdvectionEquation2D <: AbstractCovariantEquations{2, 3, 3}\n\nA variable-coefficient linear advection equation can be defined on a two-dimensional manifold S subset mathbbR^3 as\n\npartial_t h + nabla_S cdot (h vecv) = 0\n\nwhere nabla_S cdot is the horizontal divergence operator on S. We treat this problem as a system of equations in which the first variable is the scalar conserved quantity h, and the second two are the contravariant components v^1 and v^2 used in the expansion with respect to the covariant basis vectors veca_1 and veca_2 as\n\nvecv = v^1 veca_1 + v^2 veca_2\n\nwhere veca_1 = partial vecx partial xi^1 and veca_2 = partial vecx partial xi^2 are the so-called covariant basis vectors, and xi^1 and xi^2 are the local reference space coordinates. The velocity components are spatially varying but assumed to be constant in time, so we do not apply any flux or dissipation to such variables. The resulting system is then given on the reference element as \n\nsqrtG fracpartialpartial tleftbeginarrayc h v^1 v^2 endarrayright \n+\nfracpartialpartial xi^1 leftbeginarrayc sqrtG h v^1 0 0 endarrayright\n+ \nfracpartialpartial xi^2 leftbeginarrayc sqrtG h v^2 0 0 endarrayright \n= \nleftbeginarrayc 0 0 0 endarrayright\n\nwhere G is the determinant of the covariant metric tensor expressed as a matrix with entries G_ij = veca_i cdot veca_j. Note that the variable advection velocity components could also be stored as auxiliary variables, similarly to the geometric information.\n\n\n\n\n\n","category":"type"},{"location":"#TrixiAtmo.MetricTermsCrossProduct","page":"Home","title":"TrixiAtmo.MetricTermsCrossProduct","text":"MetricTermsCrossProduct()\n\nStruct used for multiple dispatch on functions that compute the metric terms. When the argument metric_terms is of type MetricTermsCrossProduct, the contravariant vectors are computed using the cross-product form.\n\n\n\n\n\n","category":"type"},{"location":"#TrixiAtmo.MetricTermsInvariantCurl","page":"Home","title":"TrixiAtmo.MetricTermsInvariantCurl","text":"MetricTermsInvariantCurl()\n\nStruct used for multiple dispatch on functions that compute the metric terms. When the argument metric_terms is of type MetricTermsInvariantCurl, the contravariant vectors are computed using the invariant curl form.\n\nReferences\n\nKopriva, D. A. (2006). Metric identities and the discontinuous spectral element method on curvilinear meshes. Journal of Scientific Computing 26, 301-327. DOI: 10.1007/s10915-005-9070-8\nVinokur, M. and Yee, H. C. (2001). Extension of efficient low dissipation high order schemes for 3-D curvilinear moving grids. In Caughey, D. A., and Hafez, M. M. (eds.), Frontiers of Computational Fluid Dynamics 2002, World Scientific, Singapore, pp. 129–164. DOI: 10.1142/9789812810793_0008\n\n\n\n\n\n","category":"type"},{"location":"#TrixiAtmo.ShallowWaterEquations3D","page":"Home","title":"TrixiAtmo.ShallowWaterEquations3D","text":"ShallowWaterEquations3D(; gravity, H0 = 0)\n\nShallow water equations (SWE) in three space dimensions in conservation form (with constant bottom topography). The equations are given by\n\nbeginaligned\n fracpartial hpartial t + fracpartialpartial x(h v_1)\n + fracpartialpartial y(h v_2) + fracpartialpartial z(h v_3) = 0 \n fracpartialpartial t(h v_1) + fracpartialpartial xleft(h v_1^2 + fracg2h^2right)\n + fracpartialpartial y(h v_1 v_2) + fracpartialpartial z(h v_1 v_3) = 0 \n fracpartialpartial t(h v_2) + fracpartialpartial x(h v_1 v_2)\n + fracpartialpartial yleft(h v_2^2 + fracg2h^2right) + fracpartialpartial z(h v_2 v_3) = 0 \n fracpartialpartial t(h v_3) + fracpartialpartial x(h v_1 v_3)\n + fracpartialpartial y(h v_2 v_3) + fracpartialpartial zleft(h v_3^2 + fracg2h^2right) = 0\nendaligned\n\nThe unknown quantities of the SWE are the water height h and the velocities mathbfv = (v_1 v_2 v_3)^T. The gravitational constant is denoted by g.\n\nThe 3D Shallow Water Equations (SWE) extend the 2D SWE to model shallow water flows on 2D manifolds embedded within 3D space. To confine the flow to the 2D manifold, a source term incorporating a Lagrange multiplier is applied. This term effectively removes momentum components that are normal to the manifold, ensuring the flow remains constrained within the 2D surface.\n\nThe additional quantity H_0 is also available to store a reference value for the total water height that is useful to set initial conditions or test the \"lake-at-rest\" well-balancedness.\n\nIn addition to the unknowns, Trixi.jl currently stores the bottom topography values at the approximation points despite being fixed in time. This is done for convenience of computing the bottom topography gradients on the fly during the approximation as well as computing auxiliary quantities like the total water height H or the entropy variables. This affects the implementation and use of these equations in various ways:\n\nThe flux values corresponding to the bottom topography must be zero.\nThe bottom topography values must be included when defining initial conditions, boundary conditions or source terms.\nAnalysisCallback analyzes this variable.\nTrixi.jl's visualization tools will visualize the bottom topography by default.\n\nReferences:\n\nJ. Coté (1988). \"A Lagrange multiplier approach for the metric terms of semi-Lagrangian models on the sphere\". Quarterly Journal of the Royal Meteorological Society 114, 1347-1352. DOI: 10.1002/qj.49711448310\nF. X. Giraldo (2001). \"A spectral element shallow water model on spherical geodesic grids\". DOI: 10.1002/1097-0363(20010430)35:8<869::AID-FLD116>3.0.CO;2-S\n\n\n\n\n\n","category":"type"},{"location":"#Trixi.flux_fjordholm_etal-Tuple{Any, Any, AbstractVector, ShallowWaterEquations3D}","page":"Home","title":"Trixi.flux_fjordholm_etal","text":"flux_fjordholm_etal(u_ll, u_rr, orientation,\n equations::ShallowWaterEquations1D)\n\nTotal energy conservative (mathematical entropy for shallow water equations). When the bottom topography is nonzero this should only be used as a surface flux otherwise the scheme will not be well-balanced. For well-balancedness in the volume flux use flux_wintermeyer_etal.\n\nDetails are available in Eq. (4.1) in the paper:\n\nUlrik S. Fjordholm, Siddhartha Mishr and Eitan Tadmor (2011) Well-balanced and energy stable schemes for the shallow water equations with discontinuous topography DOI: 10.1016/j.jcp.2011.03.042\n\n\n\n\n\n","category":"method"},{"location":"#Trixi.flux_wintermeyer_etal-Tuple{Any, Any, AbstractVector, ShallowWaterEquations3D}","page":"Home","title":"Trixi.flux_wintermeyer_etal","text":"flux_wintermeyer_etal(u_ll, u_rr, orientation_or_normal_direction,\n equations::ShallowWaterEquations2D)\n\nTotal energy conservative (mathematical entropy for shallow water equations) split form. When the bottom topography is nonzero this scheme will be well-balanced when used as a volume_flux. For the surface_flux either flux_wintermeyer_etal or flux_fjordholm_etal can be used to ensure well-balancedness and entropy conservation.\n\nFurther details are available in Theorem 1 of the paper:\n\nNiklas Wintermeyer, Andrew R. Winters, Gregor J. Gassner and David A. Kopriva (2017) An entropy stable nodal discontinuous Galerkin method for the two dimensional shallow water equations on unstructured curvilinear meshes with discontinuous bathymetry DOI: 10.1016/j.jcp.2017.03.036\n\n\n\n\n\n","category":"method"},{"location":"#TrixiAtmo.P4estMeshCubedSphere2D-Tuple{Any, Any}","page":"Home","title":"TrixiAtmo.P4estMeshCubedSphere2D","text":"P4estMeshCubedSphere2D(trees_per_face_dimension, radius;\n polydeg, RealT=Float64,\n initial_refinement_level=0, unsaved_changes=true,\n p4est_partition_allow_for_coarsening=true,\n element_local_mapping=false)\n\nBuild a \"Cubed Sphere\" mesh as a 2D P4estMesh with 6 * trees_per_face_dimension^2 trees.\n\nThe mesh will have no boundaries.\n\nArguments\n\ntrees_per_face_dimension::Integer: the number of trees in the two local dimensions of each face.\nradius::Integer: the radius of the sphere.\npolydeg::Integer: polynomial degree used to store the geometry of the mesh. The mapping will be approximated by an interpolation polynomial of the specified degree for each tree.\nRealT::Type: the type that should be used for coordinates.\ninitial_refinement_level::Integer: refine the mesh uniformly to this level before the simulation starts.\nunsaved_changes::Bool: if set to true, the mesh will be saved to a mesh file.\np4est_partition_allow_for_coarsening::Bool: Must be true when using AMR to make mesh adaptivity independent of domain partitioning. Should be false for static meshes to permit more fine-grained partitioning.\nelement_local_mapping::Bool: option to use the alternative element-local mapping from Appendix A of Guba et al. (2014). If set to true, the four corner vertex positions for each element will be obtained through an equiangular gnomonic projection (Ronchi et al. 1996), and the tree node coordinates within the element (i.e. the field tree_node_coordinates) will be obtained by first using a bilinear mapping based on the four corner vertices, and then projecting the bilinearly mapped nodes onto the spherical surface by normalizing the resulting Cartesian coordinates and scaling by radius. If set to false, the equiangular gnomonic projection will be used for all tree node coordinates.\n\nwarning: Warning\nAdaptivity and MPI parallelization are not yet supported for equations in covariant form, and we require initial_refinement_level = 0 for such cases. Furthermore, the calculation of the metric terms for the covariant form currently requires polydeg to be equal to the polynomial degree of the solver, and element_local_mapping = true.\n\n!!!\n\n\n\n\n\n","category":"method"},{"location":"#TrixiAtmo.P4estMeshQuadIcosahedron2D-Tuple{Any, Any}","page":"Home","title":"TrixiAtmo.P4estMeshQuadIcosahedron2D","text":"P4estMeshQuadIcosahedron2D(trees_per_face_dimension, radius;\n polydeg, RealT=Float64,\n initial_refinement_level=0, unsaved_changes=true,\n p4est_partition_allow_for_coarsening=true)\n\nBuild a quad-based icosahedral mesh as a 2D P4estMesh with 60 * trees_per_face_dimension^2 trees (20 triangular faces of the icosahedron, each subdivided into 3 parent quads, each of which subdivided into trees_per_face_dimension^2 trees).\n\nThe node coordinates of the trees will be obtained using the element-local mapping from Appendix A of Guba et al. (2014). See P4estMeshCubedSphere2D for more information about the element-local mapping.\n\nThe mesh will have no boundaries.\n\nArguments\n\ntrees_per_face_dimension::Integer: the number of trees in the two local dimensions of each parent quad.\nradius::Integer: the radius of the sphere.\npolydeg::Integer: polynomial degree used to store the geometry of the mesh. The mapping will be approximated by an interpolation polynomial of the specified degree for each tree.\nRealT::Type: the type that should be used for coordinates.\ninitial_refinement_level::Integer: refine the mesh uniformly to this level before the simulation starts.\nunsaved_changes::Bool: if set to true, the mesh will be saved to a mesh file.\np4est_partition_allow_for_coarsening::Bool: Must be true when using AMR to make mesh adaptivity independent of domain partitioning. Should be false for static meshes to permit more fine-grained partitioning.\n\nwarning: Warning\nAdaptivity and MPI parallelization are not yet supported for equations in covariant form, and we require initial_refinement_level = 0 for such cases. Furthermore, the calculation of the metric terms for the covariant form currently requires polydeg to be equal to the polynomial degree of the solver.\n\n!!!\n\n\n\n\n\n","category":"method"},{"location":"#TrixiAtmo.clean_solution_lagrange_multiplier!-Tuple{Any, ShallowWaterEquations3D, Any}","page":"Home","title":"TrixiAtmo.clean_solution_lagrange_multiplier!","text":" clean_solution_lagrange_multiplier!(u, equations::ShallowWaterEquations3D, normal_direction)\n\nFunction to apply Lagrange multiplier discretely to the solution in order to constrain the momentum to a 2D manifold.\n\nThe vector normal_direction is perpendicular to the 2D manifold. By default, this is the normal contravariant basis vector.\n\n\n\n\n\n","category":"method"},{"location":"#TrixiAtmo.examples_dir-Tuple{}","page":"Home","title":"TrixiAtmo.examples_dir","text":"examples_dir()\n\nReturn the directory where the example files provided with TrixiAtmo.jl are located. If TrixiAtmo.jl is installed as a regular package (with ]add Trixi), these files are read-only and should not be modified. To find out which files are available, use, e.g., readdir:\n\nExamples\n\nreaddir(examples_dir())\n\n\n\n\n\n","category":"method"},{"location":"#TrixiAtmo.have_aux_node_vars-Tuple{Trixi.AbstractEquations}","page":"Home","title":"TrixiAtmo.have_aux_node_vars","text":"have_aux_node_vars(equations)\n\nTrait function determining whether equations requires the use of auxiliary variables. Classical conservation laws such as the CompressibleEulerEquations2D do not require auxiliary variables. The return value will be True() or False() to allow dispatching on the return type.\n\n\n\n\n\n","category":"method"},{"location":"#TrixiAtmo.initial_condition_gaussian-Tuple{Any, Any}","page":"Home","title":"TrixiAtmo.initial_condition_gaussian","text":"initial_condition_gaussian(x, t)\n\nThis Gaussian bell case is a smooth initial condition suitable for testing the convergence of discretizations of the linear advection equation on a spherical domain of radius a = 6 37122 times 10^3 mathrmm, representing the surface of the Earth. The height field is given in terms of the Cartesian coordinates x, y, z as \n\nh(xyz) = h_0 expBig(-b_0 big((x-x_0)^2 + (y-y_0)^2 + (z-z_0)^2big) Big)\n\nwhere h_0 = 1 times 10^3 mathrmm is the height of the bell, b_0 = 5 a is the width parameter, and the Cartesian coordinates of the bell's centre at longitude lambda_0 = 3pi2 and latitude theta_0 = 0 are given by \n\nbeginaligned\nx_0 = acostheta_0coslambda_0\ny_0 = acostheta_0sinlambda_0\nz_0 = asintheta_0\nendaligned\n\nThe velocity field corresponds to a solid body rotation with a period of 12 days, at an angle of alpha = pi4 from the polar axis. The zonal and meridional components of the velocity field are then given in terms of the longitude lambda and latitude theta as \n\nbeginaligned\nu(lambdatheta) = V (costhetacosalpha + sinthetacoslambdasinalpha)\nv(lambdatheta) = -V sinlambdasinalpha\nendaligned\n\nwhere we take V = 2pi a 12 mathrmdays. This test case is adapted from Case 1 of the test suite described in the following paper:\n\nD. L. Williamson, J. B. Drake, J. J. Hack, R. Jakob, and P. N. Swarztrauber (1992). A standard test set for numerical approximations to the shallow water equations in spherical geometry. Journal of Computational Physics, 102(1):211-224. DOI: 10.1016/S0021-9991(05)80016-6\n\nThis function returns SVector(h, vlon, vlat, b), where the first three entries are the height, zonal velocity, and meridional velocity. The fourth entry, representing variable bottom topography, is set to zero. The functions transform_to_contravariant and transform_to_cartesian are available for converting to the prognostic variables for Cartesian and covariant formulations.\n\n\n\n\n\n","category":"method"},{"location":"#TrixiAtmo.source_terms_lagrange_multiplier-Tuple{Any, Any, Any, Any, ShallowWaterEquations3D, Any}","page":"Home","title":"TrixiAtmo.source_terms_lagrange_multiplier","text":"source_terms_lagrange_multiplier(u, du, x, t,\n equations::ShallowWaterEquations3D,\n normal_direction)\n\nSource term function to apply a Lagrange multiplier to the semi-discretization in order to constrain the momentum to a 2D manifold.\n\nThe vector normal_direction is perpendicular to the 2D manifold. By default, this is the normal contravariant basis vector.\n\n\n\n\n\n","category":"method"},{"location":"#TrixiAtmo.transform_to_cartesian-Tuple{Any, ShallowWaterEquations3D}","page":"Home","title":"TrixiAtmo.transform_to_cartesian","text":"transform_to_cartesian(initial_condition, equations)\n\nTakes in a function with the signature initial_condition(x, t) which returns an initial condition given in terms of zonal and meridional velocity or momentum components, and returns another function with the signature initial_condition_transformed(x, t, equations) which returns the same initial condition with the velocity or momentum vector given in terms of Cartesian components.\n\n\n\n\n\n","category":"method"},{"location":"#TrixiAtmo.transform_to_contravariant-Tuple{Any, TrixiAtmo.AbstractCovariantEquations}","page":"Home","title":"TrixiAtmo.transform_to_contravariant","text":"transform_to_contravariant(initial_condition, equations)\n\nTakes in a function with the signature initial_condition(x, t) which returns an initial condition given in terms of zonal and meridional velocity or momentum components, and returns another function with the signature initial_condition_transformed(x, t, aux_vars, equations) which returns the same initial condition with the velocity or momentum vector given in terms of contravariant components.\n\n\n\n\n\n","category":"method"}] +[{"location":"","page":"Home","title":"Home","text":"CurrentModule = TrixiAtmo","category":"page"},{"location":"#TrixiAtmo","page":"Home","title":"TrixiAtmo","text":"","category":"section"},{"location":"","page":"Home","title":"Home","text":"Documentation for TrixiAtmo.","category":"page"},{"location":"","page":"Home","title":"Home","text":"","category":"page"},{"location":"","page":"Home","title":"Home","text":"Modules = [TrixiAtmo]","category":"page"},{"location":"#TrixiAtmo.TrixiAtmo","page":"Home","title":"TrixiAtmo.TrixiAtmo","text":"🌍 TrixiAtmo 🌍\n\nTrixiAtmo.jl is a simulation package for atmospheric models based on Trixi.jl\n\nSee also: trixi-framework/TrixiAtmo.jl\n\n\n\n\n\n","category":"module"},{"location":"#TrixiAtmo.AbstractCovariantEquations","page":"Home","title":"TrixiAtmo.AbstractCovariantEquations","text":"AbstractCovariantEquations{NDIMS, \n NDIMS_AMBIENT, \n GlobalCoordinateSystem,\n NVARS} <: AbstractEquations{NDIMS, NVARS}\n\nAbstract type used to dispatch on systems of equations in covariant form, in which fluxes and prognostic variables are stored and computed in terms of their contravariant components defining their expansions in terms of the local covariant tangent basis. The type parameter NDIMS denotes the dimension of the manifold on which the equations are solved, while NDIMS_AMBIENT is the dimension of the ambient space in which such a manifold is embedded. Some references on discontinuous Galerkin methods in covariant flux form are listed below:\n\nM. Baldauf (2020). Discontinuous Galerkin solver for the shallow-water equations in covariant form on the sphere and the ellipsoid. Journal of Computational Physics 410:109384. DOI: 10.1016/j.jcp.2020.109384 \nM. Baldauf (2021). A horizontally explicit, vertically implicit (HEVI) discontinuous Galerkin scheme for the 2-dimensional Euler and Navier-Stokes equations using terrain-following coordinates. Journal of Computational Physics 446:110635. DOI: 10.1016/ j.jcp.2021.110635\nL. Bao, R. D. Nair, and H. M. Tufo (2014). A mass and momentum flux-form high-order discontinuous Galerkin shallow water model on the cubed-sphere. A mass and momentum flux-form high-order discontinuous Galerkin shallow water model on the cubed-sphere. Journal of Computational Physics 271:224-243. DOI: 10.1016/j.jcp.2013.11.033\n\nWhen using this equation type, functions which are evaluated pointwise, such as fluxes, source terms, and initial conditions take in the extra argument aux_vars, which contains the geometric information needed for the covariant form. The type parameter GlobalCoordinateSystem specifies the global coordinate system used to define the covariant tangent basis, and may be either GlobalCartesianCoordinates or GlobalSphericalCoordinates. The GlobalCoordinateSystem type parameter also specifies the coordinate system with respect to which the initial condition should be prescribed.\n\n\n\n\n\n","category":"type"},{"location":"#TrixiAtmo.CovariantLinearAdvectionEquation2D","page":"Home","title":"TrixiAtmo.CovariantLinearAdvectionEquation2D","text":"CovariantLinearAdvectionEquation2D{GlobalCoordinateSystem} <: \n AbstractCovariantEquations{2, 3, GlobalCoordinateSystem, 3}\n\nA variable-coefficient linear advection equation can be defined on a two-dimensional manifold S subset mathbbR^3 as\n\npartial_t h + nabla_S cdot (h vecv) = 0\n\nwhere nabla_S cdot is the horizontal divergence operator on S. We treat this problem as a system of equations in which the first variable is the scalar conserved quantity h, and the second two are the contravariant components v^1 and v^2 used in the expansion with respect to the covariant basis vectors veca_1 and veca_2 as\n\nvecv = v^1 veca_1 + v^2 veca_2\n\nwhere veca_1 = partial vecx partial xi^1 and veca_2 = partial vecx partial xi^2 are the so-called covariant basis vectors, and xi^1 and xi^2 are the local reference space coordinates. The velocity components are spatially varying but assumed to be constant in time, so we do not apply any flux or dissipation to such variables. The resulting system is then given on the reference element as \n\nsqrtG fracpartialpartial t\nleftbeginarrayc h v^1 v^2 endarrayright \n+\nfracpartialpartial xi^1 \nleftbeginarrayc sqrtG h v^1 0 0 endarrayright\n+ \nfracpartialpartial xi^2 \nleftbeginarrayc sqrtG h v^2 0 0 endarrayright \n= \nleftbeginarrayc 0 0 0 endarrayright\n\nwhere G is the determinant of the covariant metric tensor expressed as a 2 by 2 matrix with entries G_ij = veca_i cdot veca_j. Note that the variable advection velocity components could alternatively be stored as auxiliary variables, similarly to the geometric information.\n\n\n\n\n\n","category":"type"},{"location":"#TrixiAtmo.GlobalCartesianCoordinates","page":"Home","title":"TrixiAtmo.GlobalCartesianCoordinates","text":"GlobalCartesianCoordinates()\n\nStruct used for dispatch, specifying that the covariant tangent basis vectors should be defined with respect to a global Cartesian coordinate system.\n\n\n\n\n\n","category":"type"},{"location":"#TrixiAtmo.GlobalSphericalCoordinates","page":"Home","title":"TrixiAtmo.GlobalSphericalCoordinates","text":"GlobalSphericalCoordinates()\n\nStruct used for dispatch, specifying that the covariant tangent basis vectors should be defined with respect to a global spherical coordinate system.\n\n\n\n\n\n","category":"type"},{"location":"#TrixiAtmo.MetricTermsCrossProduct","page":"Home","title":"TrixiAtmo.MetricTermsCrossProduct","text":"MetricTermsCrossProduct()\n\nStruct used for multiple dispatch on functions that compute the metric terms. When the argument metric_terms is of type MetricTermsCrossProduct, the contravariant vectors are computed using the cross-product form.\n\n\n\n\n\n","category":"type"},{"location":"#TrixiAtmo.MetricTermsInvariantCurl","page":"Home","title":"TrixiAtmo.MetricTermsInvariantCurl","text":"MetricTermsInvariantCurl()\n\nStruct used for multiple dispatch on functions that compute the metric terms. When the argument metric_terms is of type MetricTermsInvariantCurl, the contravariant vectors are computed using the invariant curl form.\n\nReferences\n\nKopriva, D. A. (2006). Metric identities and the discontinuous spectral element method on curvilinear meshes. Journal of Scientific Computing 26, 301-327. DOI: 10.1007/s10915-005-9070-8\nVinokur, M. and Yee, H. C. (2001). Extension of efficient low dissipation high order schemes for 3-D curvilinear moving grids. In Caughey, D. A., and Hafez, M. M. (eds.), Frontiers of Computational Fluid Dynamics 2002, World Scientific, Singapore, pp. 129–164. DOI: 10.1142/9789812810793_0008\n\n\n\n\n\n","category":"type"},{"location":"#TrixiAtmo.ShallowWaterEquations3D","page":"Home","title":"TrixiAtmo.ShallowWaterEquations3D","text":"ShallowWaterEquations3D(; gravity, H0 = 0)\n\nShallow water equations (SWE) in three space dimensions in conservation form (with constant bottom topography). The equations are given by\n\nbeginaligned\n fracpartial hpartial t + fracpartialpartial x(h v_1)\n + fracpartialpartial y(h v_2) + fracpartialpartial z(h v_3) = 0 \n fracpartialpartial t(h v_1) + fracpartialpartial xleft(h v_1^2 + fracg2h^2right)\n + fracpartialpartial y(h v_1 v_2) + fracpartialpartial z(h v_1 v_3) = 0 \n fracpartialpartial t(h v_2) + fracpartialpartial x(h v_1 v_2)\n + fracpartialpartial yleft(h v_2^2 + fracg2h^2right) + fracpartialpartial z(h v_2 v_3) = 0 \n fracpartialpartial t(h v_3) + fracpartialpartial x(h v_1 v_3)\n + fracpartialpartial y(h v_2 v_3) + fracpartialpartial zleft(h v_3^2 + fracg2h^2right) = 0\nendaligned\n\nThe unknown quantities of the SWE are the water height h and the velocities mathbfv = (v_1 v_2 v_3)^T. The gravitational constant is denoted by g.\n\nThe 3D Shallow Water Equations (SWE) extend the 2D SWE to model shallow water flows on 2D manifolds embedded within 3D space. To confine the flow to the 2D manifold, a source term incorporating a Lagrange multiplier is applied. This term effectively removes momentum components that are normal to the manifold, ensuring the flow remains constrained within the 2D surface.\n\nThe additional quantity H_0 is also available to store a reference value for the total water height that is useful to set initial conditions or test the \"lake-at-rest\" well-balancedness.\n\nIn addition to the unknowns, Trixi.jl currently stores the bottom topography values at the approximation points despite being fixed in time. This is done for convenience of computing the bottom topography gradients on the fly during the approximation as well as computing auxiliary quantities like the total water height H or the entropy variables. This affects the implementation and use of these equations in various ways:\n\nThe flux values corresponding to the bottom topography must be zero.\nThe bottom topography values must be included when defining initial conditions, boundary conditions or source terms.\nAnalysisCallback analyzes this variable.\nTrixi.jl's visualization tools will visualize the bottom topography by default.\n\nReferences:\n\nJ. Coté (1988). \"A Lagrange multiplier approach for the metric terms of semi-Lagrangian models on the sphere\". Quarterly Journal of the Royal Meteorological Society 114, 1347-1352. DOI: 10.1002/qj.49711448310\nF. X. Giraldo (2001). \"A spectral element shallow water model on spherical geodesic grids\". DOI: 10.1002/1097-0363(20010430)35:8<869::AID-FLD116>3.0.CO;2-S\n\n\n\n\n\n","category":"type"},{"location":"#Trixi.flux_fjordholm_etal-Tuple{Any, Any, AbstractVector, ShallowWaterEquations3D}","page":"Home","title":"Trixi.flux_fjordholm_etal","text":"flux_fjordholm_etal(u_ll, u_rr, orientation,\n equations::ShallowWaterEquations1D)\n\nTotal energy conservative (mathematical entropy for shallow water equations). When the bottom topography is nonzero this should only be used as a surface flux otherwise the scheme will not be well-balanced. For well-balancedness in the volume flux use flux_wintermeyer_etal.\n\nDetails are available in Eq. (4.1) in the paper:\n\nUlrik S. Fjordholm, Siddhartha Mishr and Eitan Tadmor (2011) Well-balanced and energy stable schemes for the shallow water equations with discontinuous topography DOI: 10.1016/j.jcp.2011.03.042\n\n\n\n\n\n","category":"method"},{"location":"#Trixi.flux_wintermeyer_etal-Tuple{Any, Any, AbstractVector, ShallowWaterEquations3D}","page":"Home","title":"Trixi.flux_wintermeyer_etal","text":"flux_wintermeyer_etal(u_ll, u_rr, orientation_or_normal_direction,\n equations::ShallowWaterEquations2D)\n\nTotal energy conservative (mathematical entropy for shallow water equations) split form. When the bottom topography is nonzero this scheme will be well-balanced when used as a volume_flux. For the surface_flux either flux_wintermeyer_etal or flux_fjordholm_etal can be used to ensure well-balancedness and entropy conservation.\n\nFurther details are available in Theorem 1 of the paper:\n\nNiklas Wintermeyer, Andrew R. Winters, Gregor J. Gassner and David A. Kopriva (2017) An entropy stable nodal discontinuous Galerkin method for the two dimensional shallow water equations on unstructured curvilinear meshes with discontinuous bathymetry DOI: 10.1016/j.jcp.2017.03.036\n\n\n\n\n\n","category":"method"},{"location":"#TrixiAtmo.P4estMeshCubedSphere2D-Tuple{Any, Any}","page":"Home","title":"TrixiAtmo.P4estMeshCubedSphere2D","text":"P4estMeshCubedSphere2D(trees_per_face_dimension, radius;\n polydeg, RealT=Float64,\n initial_refinement_level=0, unsaved_changes=true,\n p4est_partition_allow_for_coarsening=true,\n element_local_mapping=false)\n\nBuild a \"Cubed Sphere\" mesh as a 2D P4estMesh with 6 * trees_per_face_dimension^2 trees.\n\nThe mesh will have no boundaries.\n\nArguments\n\ntrees_per_face_dimension::Integer: the number of trees in the two local dimensions of each face.\nradius::Integer: the radius of the sphere.\npolydeg::Integer: polynomial degree used to store the geometry of the mesh. The mapping will be approximated by an interpolation polynomial of the specified degree for each tree.\nRealT::Type: the type that should be used for coordinates.\ninitial_refinement_level::Integer: refine the mesh uniformly to this level before the simulation starts.\nunsaved_changes::Bool: if set to true, the mesh will be saved to a mesh file.\np4est_partition_allow_for_coarsening::Bool: Must be true when using AMR to make mesh adaptivity independent of domain partitioning. Should be false for static meshes to permit more fine-grained partitioning.\nelement_local_mapping::Bool: option to use the alternative element-local mapping from Appendix A of Guba et al. (2014). If set to true, the four corner vertex positions for each element will be obtained through an equiangular gnomonic projection (Ronchi et al. 1996), and the tree node coordinates within the element (i.e. the field tree_node_coordinates) will be obtained by first using a bilinear mapping based on the four corner vertices, and then projecting the bilinearly mapped nodes onto the spherical surface by normalizing the resulting Cartesian coordinates and scaling by radius. If set to false, the equiangular gnomonic projection will be used for all tree node coordinates.\n\nwarning: Warning\nAdaptivity and MPI parallelization are not yet supported for equations in covariant form, and we require initial_refinement_level = 0 for such cases. Furthermore, the calculation of the metric terms for the covariant form currently requires polydeg to be equal to the polynomial degree of the solver, and element_local_mapping = true.\n\n\n\n\n\n","category":"method"},{"location":"#TrixiAtmo.P4estMeshQuadIcosahedron2D-Tuple{Any, Any}","page":"Home","title":"TrixiAtmo.P4estMeshQuadIcosahedron2D","text":"P4estMeshQuadIcosahedron2D(trees_per_face_dimension, radius;\n polydeg, RealT=Float64,\n initial_refinement_level=0, unsaved_changes=true,\n p4est_partition_allow_for_coarsening=true)\n\nBuild a quad-based icosahedral mesh as a 2D P4estMesh with 60 * trees_per_face_dimension^2 trees (20 triangular faces of the icosahedron, each subdivided into 3 parent quads, each of which subdivided into trees_per_face_dimension^2 trees).\n\nThe node coordinates of the trees will be obtained using the element-local mapping from Appendix A of Guba et al. (2014). See P4estMeshCubedSphere2D for more information about the element-local mapping.\n\nThe mesh will have no boundaries.\n\nArguments\n\ntrees_per_face_dimension::Integer: the number of trees in the two local dimensions of each parent quad.\nradius::Integer: the radius of the sphere.\npolydeg::Integer: polynomial degree used to store the geometry of the mesh. The mapping will be approximated by an interpolation polynomial of the specified degree for each tree.\nRealT::Type: the type that should be used for coordinates.\ninitial_refinement_level::Integer: refine the mesh uniformly to this level before the simulation starts.\nunsaved_changes::Bool: if set to true, the mesh will be saved to a mesh file.\np4est_partition_allow_for_coarsening::Bool: Must be true when using AMR to make mesh adaptivity independent of domain partitioning. Should be false for static meshes to permit more fine-grained partitioning.\n\nwarning: Warning\nAdaptivity and MPI parallelization are not yet supported for equations in covariant form, and we require initial_refinement_level = 0 for such cases. Furthermore, the calculation of the metric terms for the covariant form currently requires polydeg to be equal to the polynomial degree of the solver.\n\n\n\n\n\n","category":"method"},{"location":"#TrixiAtmo.clean_solution_lagrange_multiplier!-Tuple{Any, ShallowWaterEquations3D, Any}","page":"Home","title":"TrixiAtmo.clean_solution_lagrange_multiplier!","text":" clean_solution_lagrange_multiplier!(u, equations::ShallowWaterEquations3D, normal_direction)\n\nFunction to apply Lagrange multiplier discretely to the solution in order to constrain the momentum to a 2D manifold.\n\nThe vector normal_direction is perpendicular to the 2D manifold. By default, this is the normal contravariant basis vector.\n\n\n\n\n\n","category":"method"},{"location":"#TrixiAtmo.contravariant2global","page":"Home","title":"TrixiAtmo.contravariant2global","text":"contravariant2global(u, aux_vars, equations)\n\nTransform the vector u of solution variables with the momentum or velocity given in terms of local contravariant components into the global coordinate system specified by the GlobalCoordinateSystem type parameter in AbstractCovariantEquations. u is a vector type of the correct length nvariables(equations). Notice the function doesn't include any error checks for the purpose of efficiency, so please make sure your input is correct. The inverse conversion is performed by global2contravariant.\n\n\n\n\n\n","category":"function"},{"location":"#TrixiAtmo.examples_dir-Tuple{}","page":"Home","title":"TrixiAtmo.examples_dir","text":"examples_dir()\n\nReturn the directory where the example files provided with TrixiAtmo.jl are located. If TrixiAtmo.jl is installed as a regular package (with ]add Trixi), these files are read-only and should not be modified. To find out which files are available, use, e.g., readdir:\n\nExamples\n\nreaddir(examples_dir())\n\n\n\n\n\n","category":"method"},{"location":"#TrixiAtmo.global2contravariant","page":"Home","title":"TrixiAtmo.global2contravariant","text":"global2contravariant(u, aux_vars, equations)\n\nTransform the vector u of solution variables with momentum or velocity components given with respect to the global coordinate system into local contravariant components. The global coordinate system is specified by the GlobalCoordinateSystem type parameter in AbstractCovariantEquations. u is a vector type of the correct length nvariables(equations). Notice the function doesn't include any error checks for the purpose of efficiency, so please make sure your input is correct. The inverse conversion is performed by contravariant2global.\n\n\n\n\n\n","category":"function"},{"location":"#TrixiAtmo.have_aux_node_vars-Tuple{Trixi.AbstractEquations}","page":"Home","title":"TrixiAtmo.have_aux_node_vars","text":"have_aux_node_vars(equations)\n\nTrait function determining whether equations requires the use of auxiliary variables. Classical conservation laws such as the CompressibleEulerEquations2D do not require auxiliary variables. The return value will be True() or False() to allow dispatching on the return type.\n\n\n\n\n\n","category":"method"},{"location":"#TrixiAtmo.initial_condition_gaussian-Tuple{Any, Any, Trixi.AbstractEquations}","page":"Home","title":"TrixiAtmo.initial_condition_gaussian","text":"initial_condition_gaussian(x, t, equations)\n\nThis Gaussian bell case is a smooth initial condition suitable for testing the convergence of discretizations of the linear advection equation on a spherical domain of radius 6 37122 times 10^3 mathrmm, representing the surface of the Earth. Denoting the Euclidean norm as lVert cdot rVert, the initial height field is given by\n\nh(vecx) = h_0 exp\nBig(-b_0 big(lVert vecx - vecx_0 rVert lVert vecx rVertbig)^2 Big)\n\nwhere h_0 = 1 times 10^3 mathrmm is the height of the bell, b_0 = 5 is the width parameter, and vecx_0 is the position of the centre of the bell, which is initialized at a longitude of 3pi2 and a latitude of zero. The velocity field corresponds to a solid body rotation with a period of 12 days at an angle of alpha = pi4 from the polar axis. Denoting vecomega as the corresponding angular velocity vector, the velocity is therefore initialized as\n\nvecv(vecx) = vecomega times vecx\n\nThis problem is adapted from Case 1 of the test suite described in the following paper:\n\nD. L. Williamson, J. B. Drake, J. J. Hack, R. Jakob, and P. N. Swarztrauber (1992). A standard test set for numerical approximations to the shallow water equations in spherical geometry. Journal of Computational Physics, 102(1):211-224. DOI: 10.1016/S0021-9991(05)80016-6\n\n\n\n\n\n","category":"method"},{"location":"#TrixiAtmo.source_terms_lagrange_multiplier-Tuple{Any, Any, Any, Any, ShallowWaterEquations3D, Any}","page":"Home","title":"TrixiAtmo.source_terms_lagrange_multiplier","text":"source_terms_lagrange_multiplier(u, du, x, t,\n equations::ShallowWaterEquations3D,\n normal_direction)\n\nSource term function to apply a Lagrange multiplier to the semi-discretization in order to constrain the momentum to a 2D manifold.\n\nThe vector normal_direction is perpendicular to the 2D manifold. By default, this is the normal contravariant basis vector.\n\n\n\n\n\n","category":"method"},{"location":"#TrixiAtmo.transform_initial_condition-Tuple{Any, TrixiAtmo.AbstractCovariantEquations}","page":"Home","title":"TrixiAtmo.transform_initial_condition","text":"transform_initial_condition(initial_condition, equations)\n\nTakes in a function with the signature initial_condition(x, t, equations) which returns an initial condition given in terms of global Cartesian or zonal/meridional velocity components, and returns another function initial_condition_transformed(x, t, equations) or initial_condition_transformed(x, t, aux_vars, equations) which returns the same initial data, but transformed to the appropriate prognostic variables used internally by the solver. For the covariant form, this involves a transformation of the global velocity components to contravariant components using global2contravariant as well as a conversion from primitive to conservative variables. For standard Cartesian formulations, this simply involves a conversion from primitive to conservative variables. The intention here is to have a set of test cases (for example, initial_condition_gaussian) for which the initial condition is prescribed using a standardized set of primitive variables in a global Cartesian coordinates, and transformed to the specific prognostic variables required for a given model.\n\nnote: Note\nWhen using the covariant formulation, the initial velocity components should be defined in the coordinate system specified by the GlobalCoordinateSystem type parameter in AbstractCovariantEquations.\n\n\n\n\n\n","category":"method"}] }