From b928cb24444f8c7e7d5c0a7ab1e969e3106f0eda Mon Sep 17 00:00:00 2001 From: Akash Dhruv Date: Tue, 17 Dec 2024 12:25:50 -0600 Subject: [PATCH] Add documentation for NoahMP --- Docs/sphinx_doc/CouplingToNoahMP.rst | 99 ++++++++++++++++++++++++++++ Docs/sphinx_doc/index.rst | 1 + 2 files changed, 100 insertions(+) create mode 100644 Docs/sphinx_doc/CouplingToNoahMP.rst diff --git a/Docs/sphinx_doc/CouplingToNoahMP.rst b/Docs/sphinx_doc/CouplingToNoahMP.rst new file mode 100644 index 000000000..f6699e022 --- /dev/null +++ b/Docs/sphinx_doc/CouplingToNoahMP.rst @@ -0,0 +1,99 @@ + .. role:: cpp(code) + :language: c++ + +Coupling to Noah-MP +=================== + +Overview +-------- + +The NOAH Land Surface Model (LSM) is integrated with ERF to facilitate +interaction with the Noah-MP (Multi-Physics) land surface processes. + +This documentation covers key components of this interface and its +associated data structures and routines, which are implemented in C++ +and Fortran, and provides details on initialization and management of +data structures necessary for these processes. + +Files Overview +-------------- + +- **Source/LandSurfaceModel/NOAH/ERF_NOAH.H**: Contains the declaration + of the NOAH class, which extends the NullSurf. + +- **Source/LandSurfaceModel/NOAH/ERF_NOAH.cpp**: Implements the + initialization routine for the NOAH class. + +- **Submodules/NOAH-MP/drivers/hrldas/NoahmpIO.H**: Defines the C++ + `NoahmpIO_type` that is used to interface with Noah-MP implementations + following similar structure as the underlying Fortran interface + (https://dx.doi.org/10.5065/ew8g-yr95). + +- **Submodules/NOAH-MP/drivers/hrldas/NoahmpIO.cpp**: Contains the + implementation of C++ routines interfacing with Fortran. + +- **Submodules/NOAH-MP/drivers/hrldas/NoahmpIO_fi.F90**: Fortran module + responsible for managing mapping data between C++ and Fortran. + +NOAH Class +---------- + +The NOAH class serves as the handler for initializing and managing the +data structures required for NOAH-MP operations. It inherits from the +`NullSurf` class. This class declares private variable `NoahmpIO_type +noahmpio`, that is passed to NoahMP routines similar to the Fortran +interface in the Noah-MP documentation +(https://dx.doi.org/10.5065/ew8g-yr95) + +NoahmpIO_type Structure +----------------------- + +This structure is key for handling the input and output operations for +NOAH-MP through C++ and Fortran interoperation. Contains various +variables for domain, memory, and tile configuration. Also, contains +arrays for geographic variables. At present this type exposes only a +select set of variables. More variables should be exposed as needed by +applications in ERF. The process of adding new variables is as follows: + +#. In **Submodules/NOAH-MP/drivers/hrldas/NoahmpIO.H** add pointers to + the desired variable and set their initialization for + `NoahmpIO_type_fi` similar to implementation of `WSLAKEXY` and + `XLAT`. + +#. In **Submodules/NOAH-MP/drivers/hrldas/NoahmpIO.H** declare objects + for Fortran-style multidimensional arrays for the same variables in + `NoahmpIO_type` similar to implemnation of `NoahArray2D XLAT` + and `NoahArray2D WSLAKEXY`. + +#. In **Submodules/NOAH-MP/drivers/hrldas/NoahmpIO.cpp** cast the + pointers from `NoahmpIO_type_fi` to multidimensional arrays in + `NoahmpIO_type` within the implementation of `void + NoahmpIOVarInitDefault(NoahmpIO_type* noahmpio)`. + +Fortran Interoperability +------------------------ + +The connection between C++ and Fortran is managed through `NoahmpIO_fi`. +This module contains a mirroring of the C++ structure for NOAH-MP +input-output operations. + +The following functions are used to operate on the `NoahmpIO_type` and +interface with thier respective Fortran implementations: + +- `void NoahmpIOVarInitDefault(NoahmpIO_type* noahmpio)`: Initializes + default variables of `NoahmpIO_type`. Create C pointer for Fortran + data. + +- `void NoahmpInitMain(NoahmpIO_type* noahmpio)`: Main initialization + function for the NOAH-MP operations in C++. + +Usage +----- + +To use the NOAH class and associated functions, ensure the correct +initialization sequence is followed within the simulation setup. The +interplay between C++ and Fortran necessitates careful memory and data +handling, which is crucial for ensuring performance and correctness in +simulations. The interface is designed to mimic the Fortran interface +from documentation(https://dx.doi.org/10.5065/ew8g-yr95), therefore +similar practices should be followed. diff --git a/Docs/sphinx_doc/index.rst b/Docs/sphinx_doc/index.rst index 2bf6db61d..58da0f419 100644 --- a/Docs/sphinx_doc/index.rst +++ b/Docs/sphinx_doc/index.rst @@ -88,6 +88,7 @@ In addition to this documentation, there is API documentation for ERF generated CouplingToAMRWind.rst CouplingToWW3.rst + CouplingToNoahMP.rst .. toctree:: :caption: ERF vs WRF