Skip to content

Latest commit

 

History

History
137 lines (101 loc) · 4.96 KB

README.md

File metadata and controls

137 lines (101 loc) · 4.96 KB

MAPLWrapper

A wrapper to make MAPL components NUOPC-compliant. This wrapper offers several unique features that unavailable through MAPL. It can run multiple MAPL components concurrently on separate sets of processors, it can run MAPL components on different grids and use ESMF re-gridding, and it gives the ability to take an existing MAPL component or subtree and run it in a NUOPC system.

Motivation

The motivation behind this wrapper is to make MAPL and NUOPC more interopable. Despite both being based on ESMF there was no way for a MAPL component to be run within NUOPC or vice-versa. A previous approach attempted to manually convert the MAPL ExtData component into a NUOPC component by replacing the MAPL code with NUOPC code, but this approach was time-consuming and difficult due to the many implicit assumptions that MAPL makes.

The approach taken in this wrapper is different: it wraps an entire MAPL application or subtree at the Cap level with NUOPC. Through this approach MAPL components can run as they are with no changes to existing code. The NUOPC wrapper simply drives MAPL through a MAPL_Cap object.

Implementation

The wrapper is a NUOPC Model component that encapsulates a MAPL_Cap object which contains the entire MAPL hierarchy with three children: History, ExtData, and a root component provided by the user, which may have its own children. By wrapping at the cap level MAPL retains all of its functionality and has no knowledge of the NUOPC environment in which it is run.

The NUOPC wrapper merely acts as a container for the MAPL_CAP and maps its initilization and run routines onto the cap by querying it for necessary information such as fields, grids, states, imports, exports, etc, or by performing actions on it such as stepping the model.

The advantage to this approach is its simplicity and that no changes are needed at the MAPL level. The downside is that the wrapper is fairly heavy and that it is not suitable for wrapping many individual components since each instance of the wraper contains an entire MAPL hierarchy with History and ExtData.

Therefore, this wrapper is best suited for wrapping entire MAPL models or large pieces of it.

How the wrapper is used to couple two different MAPL components:

Diagram

Obtaining and Building

The wrapper requires MAPL and NUOPC to build and is included within the latest version of MAPL included in the GEOS develop branch.

MAPL is currently only distributed with GEOS and is not publicly available at this time.

Contact [email protected] if you would like to obtain a copy.

Usage

All that's needed to make a MAPL component NUOPC-compatible using this wrapper is a build of the wrapper and the root component's SetService routine. Then, the wrapper is initialized as a NUOPC model component using NUOPC_DriverAddComp or similar routine, and the resulting ESMF_GridComp is initialized with a MAPL CAP.rc file, the MAPL component's SetServices, and a name with a call to "init_wrapper".

call NUOPC_DriverAddComp(driver, "agcm", wrapper_ss, comp = agcm,
petlist = agcm_petlist, rc = rc)

call init_wrapper(wrapper_gc = agcm, name = "agcm", cap_rc_file =
"AGCM_CAP.rc", root_set_services = gcs_set_services, rc = rc)

Then, in the MAPL CAP.rc file given to the wrapper imports and exports from the MAPL side can be listed which will automatically advertise and realize them in the wrapper's import/export states just like a regular NUOPC component.

For imports add a line called "CAP_IMPORTS:" followed by a list of MAPL import names and terminated by a double colon "::".

For exports it is "CAP_EXPORTS:", and the export name must also be followed by a comma and the MAPL component from which the export can be found.

For example,

CAP_IMPORTS:
	U
	V
	T
	Q
::

CAP_EXPORTS:
	U,DYN
	V,DYN
	Q,MOIST
::

In MAPL unsatisfied imports are usually sent to ExtData to be fulfilled by a file, however, the cap intercepts the fields listed in the CAP_IMPORTS list, and instead adds them to the MAPL_Cap's import state which is then traversed by the NUOPC wrapper and advertised to its import state.

For exports, MAPL's top-level export state is recursively searched for fields from the given field name and component name listed in the CAP_EXPORTS list. Then, the fields are added to the cap's export state, and are used to advertise to the wrapper's export state.

This will automatically advertise and realize the imports and exports for the NUOPC model component that is the wrapper, and can be connected with other components using standard NUOPC connectors.

Limitations and Future Work

The wrapper currently only supports a fairly limited number of NUOPC features and some options are hardcoded. For example, there is no option to enable field mirroring within the wrapper, and TransferActionGeomObject is always on. However, it is well suited for simply running a component and connecting fields.

In the future the wrapper could be made more generic and support for more NUOPC options could be toggled.