Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Runoff not conserved #231

Open
aekiss opened this issue Oct 1, 2024 · 26 comments
Open

Runoff not conserved #231

aekiss opened this issue Oct 1, 2024 · 26 comments
Labels
all_configurations bug Something isn't working coupler Related to the CESM coupler mediator Related to the CMEPS mediator priority:high

Comments

@aekiss
Copy link
Contributor

aekiss commented Oct 1, 2024

Runoff isn't conserved. Plots below show the RYF JRA55do input data and what is reported by MOM6 for a 1deg run (ignore "m-2" in the units).

The global integral of liquid runoff shows a significant shortfall in MOM6, especially in SH summer, but also (weirdly) excess water in late August. The step at 1 May is the RYF join.
download-2

MOM6 total_frunoff is drastically smaller than JRA55do licalvf
download-3

Plot script: https://github.com/aekiss/access-eval-recipes/blob/ef120fa/ocean/runoff_budget.ipynb

Related: #208 (comment), #217, #37, ACCESS-NRI/dev_coupling#33 (comment)

@aekiss
Copy link
Contributor Author

aekiss commented Oct 1, 2024

I'm not sure what happens when JRA55do runoff is located at land points in the model. Need to find out what routing is done (if any).

@aekiss
Copy link
Contributor Author

aekiss commented Oct 1, 2024

Also need to check whether conservative regridding is used - see #37

@aekiss
Copy link
Contributor Author

aekiss commented Oct 1, 2024

Here's log(friver) from JRA55do
download-5
and log(friver) from MOM - notice MOM is missing the Black Sea - where does this water go?
download-4

@aekiss
Copy link
Contributor Author

aekiss commented Oct 1, 2024

Here's log(licalvf) from JRA55do
download-7

and log(ficeberg) from MOM
download-6

@aekiss
Copy link
Contributor Author

aekiss commented Oct 1, 2024

Maybe we'll need to set these in nuopc.runconfig to map the runoff into the ocean?

     rof2ocn_ice_rmapname = unset
     rof2ocn_liq_rmapname = unset

@anton-seaice
Copy link
Contributor

In https://escomp.github.io/CMEPS/versions/master/html/addendum/req_attributes_cesm.html?highlight=rof2ocn_ice_rmapname#mediator-mapping-file-attributes it says CMEPS will create an "online route handle" if those values are unset.

Whats the format of a "mapping file"?

It looks like the default is to do a first-order conservative remapping:

https://github.com/ESCOMP/CMEPS/blob/f4f64c324469c33a78e0118ce1dd7944e85521d6/mediator/esmFldsExchange_cesm_mod.F90#L2399

There are options for maptype when creating the remap online:

maptype determines the mapping type and can have values of:

mapbilnr: bilinear mapping
mapconsf: first order conservative mapping with normalization type of conservative fraction.
mapconsd: first order conservative mapping with normalization type of conservative fraction.
mappatch: patch mapping
mapfcopy: redist mapping
mapnstod: nearest source to destination mapping
mapnstod_consd: nearest source to destination followed by conservative destination
mapnstod_consf: nearest source to destination followed by conservative fraction

I don't know if one of those makes more sense ?

@anton-seaice
Copy link
Contributor

ESMF seems to support remapping with masks, so maybe we need to include a mask in our mesh files ?

https://earthsystemmodeling.org/regrid/#options-for-masking-areas-unmapped-points-etc

@aekiss
Copy link
Contributor Author

aekiss commented Oct 2, 2024

Thanks @anton-seaice, these (from https://earthsystemmodeling.org/regrid/#options-for-masking-areas-unmapped-points-etc) look like they may be suitable

  • Nearest source to destination: The value of each destination point is set to the value of the closest source point.
  • Inverse distance weighted average: The value of each destination point is set to the weighted average of the values of the N closest source points. The weight is the reciprocal of the distance of the source from the destination raised to the power P. The user can choose N and P, but defaults are also provided.

or from CMEPS

mapnstod_consd: nearest source to destination followed by conservative destination

@anton-seaice
Copy link
Contributor

@gustavo-marques - We (ACCESS) are looking at options for how to make sure runoff is distributed into the ocean (and not land). Does CESM use an 'online' computation for remapping weights? Or are you using pre-computed mapping weights?

We are using this option for computing mapping weights online for liquid run-off:
mapconsd: first order conservative mapping with normalization type of conservative fraction.
but think maybe
mapnstod_consd: nearest source to destination followed by conservative destination
should ensure it gets mapped into the ocean ?

@gustavo-marques
Copy link

Hi @anton-seaice,
The runoff mapping files are still done offline in CESM. We use a combination of nearest-neighbor and smoothing mappings to distribute the runoff over a pre-defined radius and using an e-folding distance. Input parameters:

eFold = smoothing eFold distance in meters (default: 1000000)
rMax = maximum radius of effect in meters (default: 300000)

You can find out more about this procedure here.

@aekiss aekiss added bug Something isn't working coupler Related to the CESM coupler mediator Related to the CMEPS mediator all_configurations priority:high labels Oct 17, 2024
@aekiss
Copy link
Contributor Author

aekiss commented Oct 17, 2024

Thanks @gustavo-marques, it's great to have these details

@anton-seaice
Copy link
Contributor

It's possible #240 will play into this - our DROF mesh file doesn't contain any cell areas and the CDEPS is not expecting one either

However we are definitely loosing lots of runoff in the mediator. From the mediator output, this is the difference between the rof and ocean diagnostics from the mediator.

image

We gain run-off in some cells but no where near enough to equal the amount which disappears.

Similarly the frozen runoff is mostly lost

Screenshot 2024-11-07 at 4 36 26 PM

Most of the runoff is being masked out. If the runoff is masked using the landmask and compared to the amount entering the ocean, the different is very small (but non-zero!)

image

And much closer to 0 in the frozen run off case

Screenshot 2024-11-07 at 4 38 46 PM

@aekiss aekiss mentioned this issue Nov 14, 2024
@aekiss
Copy link
Contributor Author

aekiss commented Nov 14, 2024

We should prioritise fixing this, as it is blocking finalising the topography #172 (comment)

@aekiss
Copy link
Contributor Author

aekiss commented Dec 11, 2024

@anton-seaice does it look like these tools will be suitable for us? https://github.com/ESMCI/cime/blob/master/tools/mapping/gen_mapping_files/runoff_to_ocn/README

@anton-seaice
Copy link
Contributor

I am not sure, I think @kieranricardo has been trying something similar but different.

I am planning on just trying one of these mapping options in the short term:

mapnstod: nearest source to destination mapping
mapnstod_consd: nearest source to destination followed by conservative destination
mapnstod_consf: nearest source to destination followed by conservative fraction

@anton-seaice
Copy link
Contributor

I think that changing the remapping option might not have the desired effect.

All regridding methods conserve the total volume of water (at least where there is no masking), see

https://earthsystemmodeling.org/docs/release/ESMF_8_1_0/ESMF_refdoc/node5.html#SECTION05012700000000000000

So we don't need to worry about how the choice of regridding might impact overall water conservation

They are also mask aware:

https://earthsystemmodeling.org/docs/release/ESMF_8_1_0/ESMF_refdoc/node5.html#SECTION050121000000000000000

However the total volume is not mapped on to unmasked cells - its mapped to all cells and then the mask is applied ( I think). (For example, there's nothing specified differently for rain which should be mapped to all cells vs runoff which only goes to ocean cells and lakes ). So the runoff mapped to land is still lost.

It turns out there are two places to specify remapping relevant here.

  1. In the CDEPS component for drof, which specifies the remapping between the JRA mesh and the mediator mesh. This is configured in the drof "stream" file. (As an aside - the issue @aekiss highlighted above with more run-off into the ocean than in JRA55do - might be due to the time interpolation applied in this stream file - it's set to upper and maybe should be linear)
  2. in the mediator - which specifies the mapping between the mediator mesh and the ocean mesh.

Depending on the configuration - the runoff can be mapped onto land (and therefore lost) at either place. With our current set-up it's lost in the second step. When mapped in the mediator from the rof import to the ocn export.

Changing the method in the mediator to mapfcopy conserves the total volume of runoff in the mediator however doesn't help in the end as its not a mask aware redistribution (all the other options actually do some remapping).

There is no implementation [2] in CMEPS for nearest destination to source regridding which is possible in ESMF - maybe this is what we wan't. However its not clear that the "nearest destination" would only be an unmasked cells.

@anton-seaice
Copy link
Contributor

It looks like there is a few ways of generating remapping run-off forcings:

  1. generating new versions of the run-off on the new grid. e.g.

GFDL has a method for producing remapped runoff files. It looks like this would produce a new version of the runoff file, with the runoff in the correct location for the provided grid. It seems to be based on the older mosaic grid format, so would need some work to be adapted to this circumstance.

There is also this python package developed for ORA grids/models, which looks comprehensive but hasn't been updated in three years :
https://git.geomar.de/open-source/runoff_remapping

  1. access-om2 used an "online" remapping using a kdtree algorithm

Or the online remapping using a kdtree, which could be implemented in the mediator

https://github.com/ACCESS-NRI/libaccessom2/blob/f9f2d67a44554e15a477505ae1b8c5676e4c21f7/atm/src/remap_runoff_mod.F90#L5

  1. the CIME tool:
    https://github.com/ESMCI/cime/tree/master/tools/mapping/gen_mapping_files/runoff_to_ocn

which looks ok but relies on grids in the SCRIP or pop-grid formats, so might need some adapting for us

@AndyHoggANU
Copy link

Thanks Anton - all good info.
My inclination is that we would prefer to stay away from option 1 (but it might be viable for an interim solution to allow testing with RYF forcing (this is what we do, and frequently get wrong, in regional-mom6).
My suspicion is that option 3 is probably best in the long term, the only issue being that we need a workflow to update mapping files every time we change the land-sea mask ...

@anton-seaice
Copy link
Contributor

anton-seaice commented Jan 9, 2025

For run-off to reach the ocean model from the source data, there are three steps of transformation, and I'm proposing adjustments to all of them:

1. DROF to Mediator

This step maps run-off from the source data's grid to the mediator. i.e. From the meshfile in drof.streams.xml to model_meshfile in drof_in. Neither grid has a mask at this point.

We currently are using bilinear spatial averaging and 'upper' time selection. The bilinear interpolation leads to a larger overall volume of water reaching the mediator than leaves the drof component. I suggest we switch to conservative remapping and linear time interpolation.

We are also loosing some liquid runoff and lots of frozen runoff as our current 1degree grid starts at 78S, whilst the JRA product has some runoff south of this latitude. As our new grids will extend further south, I think we can ignore this.

2. Mediator to Mediator

This step maps from the runoff import to the ocn export. We use the ocean mesh in the mediator, so the only impact at this step is moving from an mesh without a mask to a mesh with a land mask. At this step, we currently loose all the runoff that is in a landcell from the previous step.

We can configure custom remapping weights in nuopc.runconfig:

     rof2ocn_ice_rmapname = unset
     rof2ocn_liq_rmapname = unset

I made some remapping weights by mapping all land cells to its nearest ocean cell.

3. Mediator to Ocean

This step basically works as is, but we should set the earths radius in MOM to be consistent with other components.

With these adjustments, run off is "close" to conserved (combined frozen + liquired runoff, blue is JRA55do, orange is MOM6):

image

The difference is explained by the runoff south of 78S not being included.

The config I ran is here

And the longer demo of the runoff budget with plots is here

@anton-seaice
Copy link
Contributor

We are also loosing some liquid runoff and lots of frozen runoff as our current 1degree grid starts at 78S, whilst the JRA product has some runoff south of this latitude. As our new grids will extend further south, I think we can ignore this.

The new 0.25 degree grids (e.g. '/g/data/tm70/ml0072/COMMON/git_repos/COSIMA_om3-scripts/expts_manager/New_grid_input_files_025deg_75zlevels/ocean_hgrid.nc') we have been experimenting with for OM3 start at -81S, so this shouldn't be an issue going forward.

@anton-seaice
Copy link
Contributor

I re-did the changes above using the "new" 0.25 degree grids and runoff is conserved:

image

as the new grid extends further south, the runoff matches exactly. The cell areas at the geographic north pole matches exactly also.

@aekiss
Copy link
Contributor Author

aekiss commented Jan 15, 2025

Awesome work, thanks @anton-seaice !

@access-hive-bot
Copy link

This issue has been mentioned on ACCESS Hive Community Forum. There might be relevant details there:

https://forum.access-hive.org.au/t/cosima-twg-meeting-minutes-2025/4067/2

@anton-seaice
Copy link
Contributor

I raised a PR for making the remapping weights:

COSIMA/om3-scripts#45

@aekiss
Copy link
Contributor Author

aekiss commented Jan 16, 2025

@anton-seaice in answer to your question in yesterday's meeting, the JRA55-do Antarctic solid and liquid runoff both come from Depoorter et al. (2013) and the Greenland solid and liquid runoff both come from Bamber et al. (2018), ie none of the solid or liquid runoff in these regions is from the JRA55 reanalysis.

Total runoff is the sum of liquid and solid. Solid (licalvf) is iceberg calving. Liquid (friver) is ice shelf basal melt in the Antarctic, total meltwater runoff in Greenland, and runoff from JRA55 (via a river-routing model) elsewhere. So only licalvf should be horizontally distributed to represent iceberg migration and melt.

Details are here - see sec 2.1 (excerpt copied below) and table 1.

JRA-55 does not directly provide the river runoff from rivers and glaciers at river mouths. JRA55-do derives them from several sources and provides liquid water flux (friver) and solid ice calving flux (licalvf) separately. The solid ice calving flux might be used as input to iceberg models. The liquid runoff fields are obtained from a river-routing model forced by runoffs from the land-surface component of JRA-55 (Suzuki et al., 2018). The runoffs from Greenland and Antarctica, which contain a significant solid runoff component, are taken from independent estimates that combine satellite observations of solid discharge with high-resolution climate models of runoff and surface processes. ... The daily runoff from Greenland for version 1.4 and later is based on the monthly runoff from 1958 to 2016 of Bamber et al. (2018). Time interpolation from monthly to daily data is linear. For the period before 1958 and after 2016, the monthly climatology from 1958 to 1962 and from 2012 to 2016 is used, respectively. The separate time series of daily liquid and solid runoff are now provided for Greenland. The runoff from Antarctica (Depoorter et al., 2013) is constant in time and the liquid water and solid ice runoffs are separated. ... See the version history presented in Appendix C.9.2 and Table 5 for details.

@aekiss
Copy link
Contributor Author

aekiss commented Jan 17, 2025

I re-did the changes above using the "new" 0.25 degree grids and runoff is conserved:

what does a timeseries of their difference look like?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
all_configurations bug Something isn't working coupler Related to the CESM coupler mediator Related to the CMEPS mediator priority:high
Projects
None yet
Development

No branches or pull requests

5 participants