From 1f012e9f4cab0a32370a06b7c7c5751f20330b7f Mon Sep 17 00:00:00 2001 From: Ann Almgren Date: Wed, 20 Nov 2024 11:34:52 -0800 Subject: [PATCH] updating docs --- Docs/sphinx_doc/AMReX.rst | 28 +++++++++++++++++++++++ Docs/sphinx_doc/Checkpoint.rst | 4 ++++ Docs/sphinx_doc/Inputs.rst | 2 +- Docs/sphinx_doc/LinearSolvers.rst | 12 ++++++++++ Docs/sphinx_doc/Plotfiles.rst | 10 ++++++-- Docs/sphinx_doc/index.rst | 2 ++ Docs/sphinx_doc/theory/Initialization.rst | 2 +- 7 files changed, 56 insertions(+), 4 deletions(-) create mode 100644 Docs/sphinx_doc/AMReX.rst create mode 100644 Docs/sphinx_doc/LinearSolvers.rst diff --git a/Docs/sphinx_doc/AMReX.rst b/Docs/sphinx_doc/AMReX.rst new file mode 100644 index 000000000..1b6e4fdab --- /dev/null +++ b/Docs/sphinx_doc/AMReX.rst @@ -0,0 +1,28 @@ + + .. role:: cpp(code) + :language: c++ + +.. _subsec:AMReX: + +AMReX +============== + +ERF is built on AMReX, a C++--based software framework that supports the development of structured mesh algorithms for solving systems of partial differential equations, with options for adaptive mesh refinement, on machines from laptops to exascale architectures. AMReX was developed in the U.S. Department of Energy’s Exascale Computing Project and is now a member project of the High Performance Software Foundation under the umbrella of the Linux Foundation. + +AMReX uses an MPI+X model of hierarchical parallelism where blocks of data are distributed across MPI ranks (typically across multiple nodes). Fine-grained parallelism at the node level (X) is achieved using +OpenMP for CPU-only machines, or CUDA, HIP or SYCL for NVIDIA, AMD or Intel GPUs, respectively. AMReX provides extensive support for kernel launching on GPU accelerators (using ParallelFor looping constructs and C++ lambda functions) and the effective use of various memory types, including managed, device, and pinned. Architecture-specific aspects of the software for GPUs are highly localized within the code, and essentially hidden from the application developer or user. + +In addition to portability across architectures, AMReX provides data structures and iterators that define, allocate and efficiently operate on distributed multi-dimensional arrays. +Data is defined on disjoint logically rectangular regions of the domain known as patches (or grids or boxes); we note that unlike WRF, AMReX (and therefore ERF) does not require one patch per MPI rank, thus allowing much more general domain decomposition. Common operations, such as parallel communication and reduction operations, as well as interpolation and averaging operators between levels of refinement, are provided by the AMReX framework. + +Finally, ERF currently leverages, or plans to leverage, AMReX capabilities for effective load balancing, adaptive mesh refinement, memory management, asynchronous I/O, Lagrangian particles with particle-mesh interactions, and linear solvers. + +We note that ERF supports both a cmake and a gmake build system. + + +Linear Solvers +============== + +Evolving the anelastic equation set requires solution of a Poisson equation in which we solve for the update to the perturbational pressure at cell centers. AMReX provides several solver options: geometric multigrid, Fast Fourier Transforms (FFTs) and preconditioned GMRES. For simulations with no terrain or grid stretching, one of the FFT options is generally the fastest solver, followed by multigrid. We note that the multigrid solver has the option to ``ignore'' a coordinate direction if the domain is only one cell wide in that direction; this allows for efficient solution of effectively 2D problems. Multigrid can also be used when the union of grids at a level is not in itself rectangular; the FFT solvers do not work in that general case. + +For simulations using grid stretching in the vertical but flat terrain, we must use the hybrid FFT solver in which we perform 2D transforms only in the lateral directions and couple the solution in the vertical direction with a tridiagonal solve. In both these cases we use a 7-point stencil. To solve the Poisson equation on terrain-fitted coordinates with general terrain, we rely on the preconditioned GMRES solver since the stencil effectively has variable coefficients and requires 19 points. diff --git a/Docs/sphinx_doc/Checkpoint.rst b/Docs/sphinx_doc/Checkpoint.rst index 3b90849b7..0ce3baf8a 100644 --- a/Docs/sphinx_doc/Checkpoint.rst +++ b/Docs/sphinx_doc/Checkpoint.rst @@ -14,6 +14,10 @@ uses the native AMReX format for reading and writing checkpoints. In the inputs file, the following options control the generation of checkpoint files (which are really directories): +The computational cost associated with reading and writing checkpoint files is +typically negligible relative to the overall cost of the simulation; in a recent performance +study the cost of writing a checkpoint file was roughly a percent of the cost of a single timestep. + Writing the Checkpoint "Files" ============================== diff --git a/Docs/sphinx_doc/Inputs.rst b/Docs/sphinx_doc/Inputs.rst index 93172351f..20b31d201 100644 --- a/Docs/sphinx_doc/Inputs.rst +++ b/Docs/sphinx_doc/Inputs.rst @@ -1165,7 +1165,7 @@ Users have the option to define a dry or moist background state. The initialization strategy is determined at runtime by ``init_type``, which has six possible values. -For more details on the hydrostatic initialization, see the ref:`Initialization section`. +For more details on the hydrostatic initialization, see :ref:`sec:Initialization`. In addition, there is a run-time option to project the initial velocity field to make it divergence-free. diff --git a/Docs/sphinx_doc/LinearSolvers.rst b/Docs/sphinx_doc/LinearSolvers.rst new file mode 100644 index 000000000..9ac62c56c --- /dev/null +++ b/Docs/sphinx_doc/LinearSolvers.rst @@ -0,0 +1,12 @@ + + .. role:: cpp(code) + :language: c++ + +.. _subsec:LinearSolvers: + +Linear Solvers +============== + +Evolving the anelastic equation set requires solution of a Poisson equation in which we solve for the update to the perturbational pressure at cell centers. AMReX provides several solver options: geometric multigrid, Fast Fourier Transforms (FFTs) and preconditioned GMRES. For simulations with no terrain or grid stretching, one of the FFT options is generally the fastest solver, followed by multigrid. We note that the multigrid solver has the option to ``ignore'' a coordinate direction if the domain is only one cell wide in that direction; this allows for efficient solution of effectively 2D problems. Multigrid can also be used when the union of grids at a level is not in itself rectangular; the FFT solvers do not work in that general case. + +For simulations using grid stretching in the vertical but flat terrain, we must use the hybrid FFT solver in which we perform 2D transforms only in the lateral directions and couple the solution in the vertical direction with a tridiagonal solve. In both these cases we use a 7-point stencil. To solve the Poisson equation on terrain-fitted coordinates with general terrain, we rely on the preconditioned GMRES solver since the stencil effectively has variable coefficients and requires 19 points. diff --git a/Docs/sphinx_doc/Plotfiles.rst b/Docs/sphinx_doc/Plotfiles.rst index a13332a1d..105b757f9 100644 --- a/Docs/sphinx_doc/Plotfiles.rst +++ b/Docs/sphinx_doc/Plotfiles.rst @@ -12,8 +12,14 @@ Plotfiles Controlling PlotFile Generation =============================== -"Plotfiles" can be written very efficiently in parallel in a native AMReX format -or in HDF5. They can also be written in NetCDF. +Plotfiles can be written very efficiently in parallel in a native AMReX format. +They can also be written in NetCDF. It is possible to output plotfiles in the +same or separate formats at two distinct frequencies. + +The computational cost associated with reading and writing checkpoint files +in the AMReX native format is typically negligible relative to the overall cost of the simulation; +in a recent performance study the cost of writing a plotfile was roughly a percent or two +of the cost of a single timestep. The following options in the inputs file control the generation of plotfiles. Note that plotfiles can be written at two different frequencies; the names, diff --git a/Docs/sphinx_doc/index.rst b/Docs/sphinx_doc/index.rst index 61db8e425..f15f931ee 100644 --- a/Docs/sphinx_doc/index.rst +++ b/Docs/sphinx_doc/index.rst @@ -62,10 +62,12 @@ In addition to this documentation, there is API documentation for ERF generated :caption: IMPLEMENTATION :maxdepth: 1 + AMReX.rst ArakawaCGrid.rst MapFactors.rst TimeAdvance.rst Discretizations.rst + LinearSolvers.rst MeshRefinement.rst BoundaryConditions.rst MOST.rst diff --git a/Docs/sphinx_doc/theory/Initialization.rst b/Docs/sphinx_doc/theory/Initialization.rst index 68cc64af6..fbe8245b5 100644 --- a/Docs/sphinx_doc/theory/Initialization.rst +++ b/Docs/sphinx_doc/theory/Initialization.rst @@ -5,7 +5,7 @@ .. role:: f(code) :language: fortran -.. _Initialization: +.. _sec:Initialization: Initialization ==================