MPAS | ERA5| Update SST and sea-ice fraction
Generating SST and sea-ice update files
- https://www2.mmm.ucar.edu/projects/mpas/tutorial/Howard2024/index.html
- MPAS-Tutorial-NCAR-2023/mpas_tutorial | ftp
Because MPAS-Atmosphere — at least, when run as a stand-alone model — does not contain prognostic equations for the SST and sea-ice fraction, these fields would remain constant if not updated from an external source; this is, of course, not realistic, and it will generally impact the quality of longer model simulations. Consequently, for MPAS-Atmosphere simulations longer than roughly a week, it is typically necessary to periodically update the sea-surface temperature (SST) field in the model. For real-time simulations, this is generally not an option, but it is feasible for retrospective simulations, where we have observed SST analyses available to us.
Prepare intermediate files containing SST and sea-ice analyses
For ERA5
Intermediate files
- Fortran script to convert netCDF to Intermediate format
- Convert netCDF to Intermediate: netcdf-to-intermediate.f
Reading intermediate files
- WPS/util/src/rd_intermediate.F
WPS/util/rd_intermediate.exe
- USAGE:
rd_intermediate.exe <filename>
1 |
|
and, on termianl,
1 |
|
Plotting Intermediate Files: plotfmt.ncl
Plots the fields in the ungribbed intermediate files
$ ncl plotfmt.ncl 'filename="FNL:2007-09-15_00"'
See above shell script.






skintemp (skt) vs sst
Consider skt - sst
form ERA5 grib file, they are different but why?
- ERA5-0p25-SL-2022063000.grib
- ERA5 grib: skt - sst
1 |
|

Solutions
- SST input resolution and LANDMASK | Feb 2024
- SST in ERA5 only has valid values over the ocean. When metgrid conducts horizontal interpolation, it may result in some discontinuity.
- TSK is skin temperature predicted by land model (over the ocean without sst update, it remains as skintemp at the initial time. if sst_update =1, tsk is updated by SST.)
- I am suspicious that SST is somehow not continuous over the coast, which affects tsk later.
- To overcome this problem, please use skintemp as SST. You cam simply delete the line for SST in Vtable.ECMWF , then rerun ungrib and metgrid.
- I would like to confirm that in ERA5, SKINTEMP and SST over the ocean are same. This will justify that we can use SKINTEMP to replace SST.
- Metgrid SST interpolation artifacts | Nov 2023
- One quick fix of the unrealistic SST along coastal areas is to replace SST by SKINTEMP. Please delete the line below from Vtable.ECMWF, then rerun ungrib.exe.
34 | 1 | 0 | | SST | K | Sea-Surface Temperature |
- In this case SST will not be extracted from ERA5 and SKINTEMP will be used as SST. We believe this is reasonable because SST and SKINTEMP is almost the same over ocean.
- In the case you attempt to use external SST instead of ERA5 SST, you need to provide landmask specifically for the external SST data, then modify METGRID.TBL so that metgrid.exe will know what landmask is used for horizontal interpolation.
- A detailed explanation can be found at https://www2.mmm.ucar.edu/wrf/users/tutorial/presentation_pdfs/201907/duda_wps_advanced.pdf, and the slides 47-58 give an example how to process external soil data. The same approach is also applied to external SST.
- the default fill-values overland is 0K (as in -273.15ºC). If you're running in high res, the interpolation of SST leads to some wonky numbers around the landmask. Probably you can set fill_missing = 285. or some other value to remedy the problem.
- does WRF needs TSK from global data | Nov 2020
- Strong non-smooth temperature pattern over snow/ice/water land categories | Sep 2021
- I see you're using sst_update. Are you using a separate SST input data than the ERA5 data? If so, is it possible that the landsea mask for the two data types is inconsistent? Otherwise, there is a particular process necessary for processing landsea for ERA5 data.
- One suggestion is to use SKINTEMP only (instead of SST)
- Issue with ERA5 SST fields | Feb 2023
- This is an old issue. If you replace the SST by the skin temperature you will have unrealistic warm waters near the coast in summer.
- WRF regional climate simulation | Sep 2021
- This will potentially lead to problem in WRF simulation, especially for long term climate simulation with sst_update.
- To solve this issue, please use skintemp to replace SST following the steps below:
- in Vtable.ERA-I, delete the line below:
34 | 1 | 0 | | SST | K | Sea-Surface Temperature |
- rerun ungrib.exe and metgrid.exe
- run real.exe and wrf.exe
- Merge Vtable.GFS and Vtable.SST | Jan 2021
- It is perfectly fine that the SST field is derived from SKINTEMP; however, if you are not using high-resolution time-varying SST data input, there really is no need to use the sst_update option. If you are only running for 4 days, it shouldn't be necessary.
- Ungrib error: not reading SST | Dec 2022
- This means the code is not familiar with a level code of 160, and if you want to use that one, you'll need to modify the ungrib/src/rd_grib2.F file to allow it to work. You can search for that part of the code by looking for "Rd_grib2 does not know" in that file. After you make any modifications, you'll need to recompile ungrib.exe.
Summary
The ERA5.grib can be IC, LBC, FDDA and SST/Sea-Ice updated as well.
And, ERA5 corresponding interemediate file can be used.
Vtable
- Vtable.GFS
- Skin temperature (can use for SST also)
▶Vtable.GFS
1
2
3
4
5
6
7
8
9GRIB1| Level| From | To | metgrid | metgrid | metgrid |GRIB2|GRIB2|GRIB2|GRIB2|
Param| Type |Level1|Level2| Name | Units | Description |Discp|Catgy|Param|Level|
-----+------+------+------+----------+---------+-----------------------------------------+-----------------------+
91 | 1 | 0 | | SEAICE | proprtn | Ice flag | 10 | 2 | 0 | 1 |
81 | 1 | 0 | | LANDSEA | proprtn | Land/Sea flag (1=land, 0 or 2=sea) | 2 | 0 | 0 | 1 |
81 | 1 | 0 | | LANDN | proprtn | | 2 | 0 | 218 | 1 |
7 | 1 | 0 | | SOILHGT | m | Terrain field of source analysis | 0 | 3 | 5 | 1 |
11 | 1 | 0 | | SKINTEMP | K | Skin temperature | 0 | 0 | 0 | 1 |
......
- Skin temperature (can use for SST also)
Vtable.ERA-interim.pl
▶Vtable.ERA-interim.pl1
2
3
4
5
6
7GRIB | Level| Level| Level| metgrid | metgrid | metgrid |
Code | Code | 1 | 2 | Name | Units | Description |
-----+------+------+------+----------+----------+------------------------------------------+
235 | 1 | 0 | | SKINTEMP | K | Sea-Surface Temperature |
31 | 1 | 0 | | SEAICE | fraction | Sea-Ice Fraction |
34 | 1 | 0 | | SST | K | Sea-Surface Temperature |
......Vtable.SST
▶Vtable.SST1
2
3
4
5
6
7GRIB | Level| Level| Level| metgrid | metgrid | metgrid |
Code | Code | 1 | 2 | Name | Units | Description |
-----+------+------+------+----------+----------+------------------------------------------+
172 | 1 | 0 | | LANDSEA | 0/1 Flag | Land/Sea flag |
235 | 1 | 0 | | SKINTEMP | K | Sea-Surface Temperature |
31 | 1 | 0 | | SEAICE | fraction | Sea-Ice Fraction |
-----+------+------+------+----------+----------+------------------------------------------+
For sst = skintemp
Vtable.ERA-interim.pl
is modified asVtable.ERA5
- replace the SST by the skin temperature !!
- Remove the row :
34 | 1 | 0 | | SST | K | Sea-Surface Temperature |
For using ERA5 as SST source
- use ERA5's
skintemp
as SST source instead ofsst
itself - modify
Vtable.SST
with replace11
by235
try to keep three varibles (not only SST and SEAICE)
Vtable.ERA5.SST
▶Vtable.ERA5.SST1
2
3
4
5
6GRIB | Level| Level| Level| metgrid | metgrid | metgrid |
Code | Code | 1 | 2 | Name | Units | Description |
-----+------+------+------+----------+----------+------------------------------------------+
235 | 1 | 0 | | SKINTEMP | K | Sea-Surface Temperature |
31 | 1 | 0 | | SEAICE | fraction | Sea-Ice Fraction |
235 | 1 | 0 | | SST | K | Sea-Surface Temperature |
ln -sf ${TEMPLATE_DIR}/Variable_Tables/Vtable.ERA5.SST Vtable
For MPAS
code
mpas_stream_manager.F
- MPAS_stream_mgr_get_property
1 |
|
MPAS init.nc SST issue
sst = skintemp
that sst values is from skintemp.src/core_init_atmosphere/mpas_init_atm_cases.F
1 |
|
But, ERA5's skintemp and sst are different as above.
core_atmosphere
src/core_atmosphere/physics/mpas_atmphys_manager.F
- read sfc input
1
2
3type(mpas_pool_type),pointer:: sfc_input
block => domain % blocklist
call mpas_pool_get_subpool(block%structs,'sfc_input' ,sfc_input ) physics_update_sst
1
2
3
4
5
6
7!update surface boundary conditions with input sea-surface temperatures and fractional
!sea-ice coverage:
if(mpas_is_alarm_ringing(clock,sfcbdyAlarmID,ierr=ierr)) then
call mpas_reset_clock_alarm(clock,sfcbdyAlarmID,ierr=ierr)
if(config_sst_update) &
call physics_update_sst(domain%dminfo,config_frac_seaice,mesh,sfc_input,diag_physics)
endifMPAS_stream_mgr_get_property read sst.nc files
1 |
|
src/core_atmosphere/Registry.xml
1
<var_struct name="sfc_input" time_levs="1">
Update SST on MPAS time-step,
- For uptated interval = 3 hour,
- T=0, from SST(T=0) of init.nc
- T=0 to T=3, are same as SST(T=0)
- T>3 to T=6, are same as SST(T=3)
- T>6 to T=9, are same as SST(T=6)
- For uptated interval = 6 hour,
- T=0, from SST(T=0) of init.nc
- T=0 to T=6, are same as SST(T=0)
- T>6 to T=12, are same as SST(T=6)
- T>12 to T=18, are same as SST(T=12)
src/core_init_atmosphere/Registry.xml
1 |
|
namelist.init_atmosphere
The key namelist options that must be set are shown below; other options can be ignored.
Note in particular that we have set the config_init_case
variable to 8! This is the initialization case used to create surface update files, instead of real-data initial conditions files.
1 |
|
streams.init_atmosphere
We have set both the filename_template
and output_interval attributes of the "surface
" stream. The output_interval
should match the interval specified in the namelist for the config_fg_interval
variable. The other streams ("input
", "output
", and "lbc
") can remain unchanged — the input file should still be set to the name of the static file.
- Noted: can set
filename_template="sst.$Y-$M-$D_$h.$m.$s.nc"
1 |
|
results
1 |
|
Plot
- https://ftp.cptec.inpe.br/pesquisa/das/MPAS-Tutorial-NCAR-2023/mpas_tutorial/240km_uniform/plot_delta_sst.py
./plot_delta_sst.py x1.10242.static.nc x1.10242.sfc_update.nc
- In this plot, we have masked out the SST differences over land, since the values of the field over land are not representative of actual SST differences, but may represent differences in, e.g., skin temperature or 2-m air temperature, depending on the source of the SST analyses.
1 |
|
- or
$ ncdiff sst.nc init.nc diff-sst.nc
src/core_atmosphere/Registry.xml
1 |
|
streams.atmosphere
- stream_list.atmosphere.surface
1 |
|
namelist.atmosphere
1 |
|
Plot diff
For WRF
The WRF model physics do not predict sea-surface temperature, vegetation fraction, albedo or sea ice. For long simulations, the model provides an alternative to read-in the time-varying data and update these fields (the sst_update option). In order to use this option, one must have access to time-varying SST and sea ice fields. Twelve monthly values of vegetation fraction and albedo are available from the geogrid program. Once these fields are processed via WPS, one may activate the sst_update option within the namelist.input file.
You will need to input your SST data during the WPS process. Take a look at the SST Example from our WRF Online Tutorial for information on how to do this. Because your SST data are in netcdf format, however, you will need to write them to intermediate format in order for metgrid to incorporate the data. To do so, you can follow the instructions in Chapter 3 of the WRF Users' Guide. You can also find an example script for writing a netcdf file to intermediate format here. Just note that this script was provided to us from a user who wrote it specifically for their application, so you will need to make modifications for your own use.
- SST's are typically added to the model:
- Use the SST at the initial time as a constant field for all time periods (this is good for short runs, like real-time runs, where SST is not updated during the WRF model run)
- As an extra input at each model input time (this is good for long-months-model runs)
- SST:* intermediate files generated from the SST input data (if you do not have these files, first run ungrib.exe)
ln -sf ungrib/Variable_Tables/Vtable.SST Vtable
Interpolate the input data onto our model domain (metgrid.exe)
1 |
|
./metgrid.exe
- generate
met_em.d01.xxx.nc
Run model
- Run
real.exe
1 |
|
Note: Do not change the syntax "wrflowinp_d<domain>", to "wrflowinp_d01". The syntax should be left exactly as above. Input interval is in minutes.
- generate one more file as
wrflowinp_d01
that containsSST
,VEGFRA
,ALBBCK
andSEAICE
(if available) for each input time. - Run
wrf.exe
- To check if
SST
is updated in the model, look at fieldTSK
over water.
WRF&MPAS-A Support Forum
- MPAS tutorial questions about ungrid and SST data | Jun 2023
- Starting from WPSV4.3, a configure option, --nowrf, has been added to allow for configuration of the WPS without reference to a compiled WRF model. if you only need the ungrib component of the WPS, you can compile WPS with this option.
- Most of the reanalysis products like GFS, ERA5 etc include SST. When you run ungrib to extract variables from the reanalysis data, SST will be included in the intermediate file.
- SST update on the lakes | Jul 2023
- SST_UPDATE only works over water points, i.e., those grid points where landmask =0. Those points with lakemask =1 should correspond to points with landmask=0, and thus sst_update should apply to such points.
- MPAS SST update file | Feb 2020
- Updating SST not working | Sep 2018
- forrtl: severe (64): input conversion error, unit -5, file Internal List-Directed Read
- The issue seems to be that parts of the timestamp string ('xtime') that are read from input files contain garbage, which confuses the parsing code in the timekeeping module.