From 92baf329abb9956ef87b5f204d75352d54e1e617 Mon Sep 17 00:00:00 2001 From: Asli Bese Date: Mon, 7 Oct 2024 14:57:21 -0400 Subject: [PATCH 01/16] added two new variables: sst and siconc --- src/miranda/convert/data/ecmwf_cf_attrs.json | 24 ++++++++++++++++++++ 1 file changed, 24 insertions(+) diff --git a/src/miranda/convert/data/ecmwf_cf_attrs.json b/src/miranda/convert/data/ecmwf_cf_attrs.json index 1c080ac3..9fb032cb 100644 --- a/src/miranda/convert/data/ecmwf_cf_attrs.json +++ b/src/miranda/convert/data/ecmwf_cf_attrs.json @@ -501,6 +501,30 @@ "long_name": "Geopotential", "standard_name": "geopotential", "units": "m2 s-2" + }, + "sst": { + "_cf_variable_name": "tos", + "_corrected_units": false, + "_invert_sign": false, + "_offset_time": false, + "_transformation": false, + "cell_methods": "time: point", + "description": "This parameter (SST) is the temperature of sea water near the surface. In ERA5, this parameter is a foundation SST, which means there are no variations due to the daily cycle of the sun (diurnal variations).", + "long_name": "Sea surface temperature", + "standard_name": "sea_surface_temperature", + "units": "K" + }, + "siconc": { + "_cf_variable_name": "siconc", + "_corrected_units": false, + "_invert_sign": false, + "_offset_time": false, + "_transformation": false, + "cell_methods": "time: point", + "description": "This parameter is the fraction of a grid box which is covered by sea ice. Sea ice can only occur in a grid box which includes ocean or inland water according to the land-sea mask and lake cover, at the resolution being used.", + "long_name": "Sea ice area fraction", + "standard_name": "sea_ice_area_fraction", + "units": "(0 - 1)" } } } From d7c1b4756a4d3dabe879bbcfcb47e94b55b62852 Mon Sep 17 00:00:00 2001 From: Asli Bese Date: Tue, 8 Oct 2024 11:05:57 -0400 Subject: [PATCH 02/16] updated siconc units --- src/miranda/convert/data/ecmwf_cf_attrs.json | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/miranda/convert/data/ecmwf_cf_attrs.json b/src/miranda/convert/data/ecmwf_cf_attrs.json index 9fb032cb..6436678b 100644 --- a/src/miranda/convert/data/ecmwf_cf_attrs.json +++ b/src/miranda/convert/data/ecmwf_cf_attrs.json @@ -516,7 +516,7 @@ }, "siconc": { "_cf_variable_name": "siconc", - "_corrected_units": false, + "_corrected_units": "1", "_invert_sign": false, "_offset_time": false, "_transformation": false, @@ -524,7 +524,7 @@ "description": "This parameter is the fraction of a grid box which is covered by sea ice. Sea ice can only occur in a grid box which includes ocean or inland water according to the land-sea mask and lake cover, at the resolution being used.", "long_name": "Sea ice area fraction", "standard_name": "sea_ice_area_fraction", - "units": "(0 - 1)" + "units": "1" } } } From 3f3e778c6d6cf9d403fdc1e67e737c28485454f1 Mon Sep 17 00:00:00 2001 From: Asli Bese <164702046+aslibese@users.noreply.github.com> Date: Tue, 8 Oct 2024 14:38:15 -0400 Subject: [PATCH 03/16] Update AUTHORS.rst --- AUTHORS.rst | 1 + 1 file changed, 1 insertion(+) diff --git a/AUTHORS.rst b/AUTHORS.rst index a5fa30c1..35e3486e 100644 --- a/AUTHORS.rst +++ b/AUTHORS.rst @@ -17,3 +17,4 @@ Contributors * Sébastien Biner `@sbiner `_ * David Huard `@huard `_ * Gabriel Rondeau-Genesse `@RondeauG `_ +* Asli Bese `@aslibese `_ From f58d9dab7e4b819d707539ae6ff28a7a0dfbe5b1 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Asl=C4=B1=20Be=C5=9Fe?= <164702046+aslibese@users.noreply.github.com> Date: Tue, 8 Oct 2024 14:44:54 -0400 Subject: [PATCH 04/16] Update AUTHORS.rst --- AUTHORS.rst | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/AUTHORS.rst b/AUTHORS.rst index 35e3486e..2bd4eca4 100644 --- a/AUTHORS.rst +++ b/AUTHORS.rst @@ -17,4 +17,4 @@ Contributors * Sébastien Biner `@sbiner `_ * David Huard `@huard `_ * Gabriel Rondeau-Genesse `@RondeauG `_ -* Asli Bese `@aslibese `_ +* Aslı Beşe `@aslibese `_ From 556cbc69af875fbc5ee5c6e6238f895bcfd6c93d Mon Sep 17 00:00:00 2001 From: tlogan2000 Date: Tue, 8 Oct 2024 15:13:51 -0400 Subject: [PATCH 05/16] add standard_name to raw to allow units conversion --- src/miranda/convert/_data_corrections.py | 9 +++++++++ src/miranda/convert/data/ecmwf_cf_attrs.json | 3 +++ 2 files changed, 12 insertions(+) diff --git a/src/miranda/convert/_data_corrections.py b/src/miranda/convert/_data_corrections.py index 0ef24be9..1b328676 100644 --- a/src/miranda/convert/_data_corrections.py +++ b/src/miranda/convert/_data_corrections.py @@ -342,6 +342,14 @@ def _preprocess_correct(d: xr.Dataset, *, ops: list[partial]) -> xr.Dataset: return ds +def _correct_standard_names(d: xr.Dataset, p: str, m: dict) -> xr.Dataset: + key = "_corrected_standard_name" + for var, val in _iter_entry_key(d, m, "variables", key, p): + if val: + d[var].attrs["standard_name"] = val + return d + + def _correct_units_names(d: xr.Dataset, p: str, m: dict) -> xr.Dataset: key = "_corrected_units" for var, val in _iter_entry_key(d, m, "variables", key, p): @@ -888,6 +896,7 @@ def dataset_corrections(ds: xr.Dataset, project: str) -> xr.Dataset: metadata_definition = load_json_data_mappings(project) ds = _correct_units_names(ds, project, metadata_definition) + ds = _correct_standard_names(ds, project, metadata_definition) ds = _transform(ds, project, metadata_definition) ds = _invert_sign(ds, project, metadata_definition) ds = _units_cf_conversion(ds, metadata_definition) diff --git a/src/miranda/convert/data/ecmwf_cf_attrs.json b/src/miranda/convert/data/ecmwf_cf_attrs.json index 1c080ac3..27418338 100644 --- a/src/miranda/convert/data/ecmwf_cf_attrs.json +++ b/src/miranda/convert/data/ecmwf_cf_attrs.json @@ -103,6 +103,7 @@ "pev": { "_cf_variable_name": "evspsblpot", "_corrected_units": false, + "_corrected_standard_name": "lwe_thickness_of_water_evaporation_amount", "_invert_sign": { "era5-land": true, "era5-single-levels": true, @@ -208,6 +209,7 @@ } }, "_corrected_units": "m", + "_corrected_standard_name": "lwe_thickness_of_precipitation_amount", "_invert_sign": false, "_offset_time": { "era5-land": true, @@ -449,6 +451,7 @@ } }, "_corrected_units": false, + "_corrected_standard_name": "lwe_thickness_of_precipitation_amount", "_invert_sign": false, "_offset_time": true, "_transformation": { From 882b469dec391dc954baaeac2c2d73ac78a3e7f1 Mon Sep 17 00:00:00 2001 From: Asli Bese Date: Tue, 8 Oct 2024 16:07:11 -0400 Subject: [PATCH 06/16] updated the units of tos and siconc to cmip6 standards --- src/miranda/convert/data/ecmwf_cf_attrs.json | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/src/miranda/convert/data/ecmwf_cf_attrs.json b/src/miranda/convert/data/ecmwf_cf_attrs.json index afbf7fd8..26af79b9 100644 --- a/src/miranda/convert/data/ecmwf_cf_attrs.json +++ b/src/miranda/convert/data/ecmwf_cf_attrs.json @@ -515,7 +515,7 @@ "description": "This parameter (SST) is the temperature of sea water near the surface. In ERA5, this parameter is a foundation SST, which means there are no variations due to the daily cycle of the sun (diurnal variations).", "long_name": "Sea surface temperature", "standard_name": "sea_surface_temperature", - "units": "K" + "units": "degC" }, "siconc": { "_cf_variable_name": "siconc", @@ -524,10 +524,10 @@ "_offset_time": false, "_transformation": false, "cell_methods": "time: point", - "description": "This parameter is the fraction of a grid box which is covered by sea ice. Sea ice can only occur in a grid box which includes ocean or inland water according to the land-sea mask and lake cover, at the resolution being used.", - "long_name": "Sea ice area fraction", + "description": "This parameter is the percentage of a grid box which is covered by sea ice. Sea ice can only occur in a grid box which includes ocean or inland water according to the land-sea mask and lake cover, at the resolution being used.", + "long_name": "Sea ice area percentage", "standard_name": "sea_ice_area_fraction", - "units": "1" + "units": "%" } } } From 3239cc86feef0fa5379af548aeee3f8f865ad2b9 Mon Sep 17 00:00:00 2001 From: tlogan2000 Date: Wed, 9 Oct 2024 09:08:09 -0400 Subject: [PATCH 07/16] use pr standard_name for now --- src/miranda/convert/data/ecmwf_cf_attrs.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/miranda/convert/data/ecmwf_cf_attrs.json b/src/miranda/convert/data/ecmwf_cf_attrs.json index 26af79b9..4f13b93c 100644 --- a/src/miranda/convert/data/ecmwf_cf_attrs.json +++ b/src/miranda/convert/data/ecmwf_cf_attrs.json @@ -103,7 +103,7 @@ "pev": { "_cf_variable_name": "evspsblpot", "_corrected_units": false, - "_corrected_standard_name": "lwe_thickness_of_water_evaporation_amount", + "_corrected_standard_name": "lwe_thickness_of_precipitation_amount", "_invert_sign": { "era5-land": true, "era5-single-levels": true, From 70d1e9a793a3f246380bc621bb5cdf9bae0649d2 Mon Sep 17 00:00:00 2001 From: tlogan2000 Date: Wed, 9 Oct 2024 09:10:31 -0400 Subject: [PATCH 08/16] rollback --- src/miranda/convert/data/ecmwf_cf_attrs.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/miranda/convert/data/ecmwf_cf_attrs.json b/src/miranda/convert/data/ecmwf_cf_attrs.json index 4f13b93c..26af79b9 100644 --- a/src/miranda/convert/data/ecmwf_cf_attrs.json +++ b/src/miranda/convert/data/ecmwf_cf_attrs.json @@ -103,7 +103,7 @@ "pev": { "_cf_variable_name": "evspsblpot", "_corrected_units": false, - "_corrected_standard_name": "lwe_thickness_of_precipitation_amount", + "_corrected_standard_name": "lwe_thickness_of_water_evaporation_amount", "_invert_sign": { "era5-land": true, "era5-single-levels": true, From 1058d6cfabff0664b1eec120ea080a1cf6ee1e90 Mon Sep 17 00:00:00 2001 From: tlogan2000 Date: Thu, 10 Oct 2024 13:41:47 -0400 Subject: [PATCH 09/16] comment out _offset_time (not doing anything ... potentially could remove?) --- src/miranda/convert/_data_corrections.py | 103 ++++++++++++----------- 1 file changed, 52 insertions(+), 51 deletions(-) diff --git a/src/miranda/convert/_data_corrections.py b/src/miranda/convert/_data_corrections.py index 1b328676..53f2bac0 100644 --- a/src/miranda/convert/_data_corrections.py +++ b/src/miranda/convert/_data_corrections.py @@ -458,53 +458,55 @@ def _transform(d: xr.Dataset, p: str, m: dict) -> xr.Dataset: return d_out -def _offset_time(d: xr.Dataset, p: str, m: dict) -> xr.Dataset: - key = "_offset_time" - d_out = xr.Dataset(coords=d.coords, attrs=d.attrs) - converted = [] - offset, offset_meaning = None, None - - time_freq = dict() - expected_period = _get_section_entry_key( - m, "dimensions", "time", "_ensure_correct_time", p - ) - if isinstance(expected_period, str): - time_freq["expected_period"] = expected_period - - for vv, offs in _iter_entry_key(d, m, "dimensions", key, p): - if offs: - # Offset time by value of one time-step - if offset is None and offset_meaning is None: - try: - offset, offset_meaning = get_time_frequency(d, **time_freq) - except TypeError: - logging.error( - "Unable to parse the time frequency. Verify data integrity before retrying." - ) - raise - - msg = f"Offsetting data for `{vv}` by `{offset[0]} {offset_meaning}(s)`." - - logging.info(msg) - with xr.set_options(keep_attrs=True): - out = d[vv] - out["time"] = out.time - np.timedelta64(offset[0], offset[1]) - d_out[vv] = out - converted.append(vv) - prev_history = d.attrs.get("history", "") - history = f"Offset variable `{vv}` values by `{offset[0]} {offset_meaning}(s). {prev_history}" - d_out.attrs.update(dict(history=history)) - elif offs is False: - msg = f"No time offsetting needed for `{vv}` in `{p}` (Explicitly set to False)." - - logging.info(msg) - continue - - # Copy unconverted variables - for vv in d.data_vars: - if vv not in converted: - d_out[vv] = d[vv] - return d_out +# TODO: Determine if this function is still needed + +# def _offset_time(d: xr.Dataset, p: str, m: dict) -> xr.Dataset: +# key = "_offset_time" +# d_out = xr.Dataset(coords=d.coords, attrs=d.attrs) +# converted = [] +# offset, offset_meaning = None, None +# +# time_freq = dict() +# expected_period = _get_section_entry_key( +# m, "dimensions", "time", "_ensure_correct_time", p +# ) +# if isinstance(expected_period, str): +# time_freq["expected_period"] = expected_period +# +# for vv, offs in _iter_entry_key(d, m, "dimensions", key, p): +# if offs: +# # Offset time by value of one time-step +# if offset is None and offset_meaning is None: +# try: +# offset, offset_meaning = get_time_frequency(d, **time_freq) +# except TypeError: +# logging.error( +# "Unable to parse the time frequency. Verify data integrity before retrying." +# ) +# raise +# +# msg = f"Offsetting data for `{vv}` by `{offset[0]} {offset_meaning}(s)`." +# +# logging.info(msg) +# with xr.set_options(keep_attrs=True): +# out = d[vv] +# out["time"] = out.time - np.timedelta64(offset[0], offset[1]) +# d_out[vv] = out +# converted.append(vv) +# prev_history = d.attrs.get("history", "") +# history = f"Offset variable `{vv}` values by `{offset[0]} {offset_meaning}(s). {prev_history}" +# d_out.attrs.update(dict(history=history)) +# elif offs is False: +# msg = f"No time offsetting needed for `{vv}` in `{p}` (Explicitly set to False)." +# +# logging.info(msg) +# continue +# +# # Copy unconverted variables +# for vv in d.data_vars: +# if vv not in converted: +# d_out[vv] = d[vv] +# return d_out def _invert_sign(d: xr.Dataset, p: str, m: dict) -> xr.Dataset: @@ -544,7 +546,7 @@ def _units_cf_conversion(d: xr.Dataset, m: dict) -> xr.Dataset: for vv, unit in _iter_entry_key(d, m, "variables", "units", None): if unit: with xr.set_options(keep_attrs=True): - d[vv] = units.convert_units_to(d[vv], unit, context="hydro") + d[vv] = units.convert_units_to(d[vv], unit) prev_history = d.attrs.get("history", "") history = f"Converted variable `{vv}` to CF-compliant units (`{unit}`). {prev_history}" d.attrs.update(dict(history=history)) @@ -904,10 +906,9 @@ def dataset_corrections(ds: xr.Dataset, project: str) -> xr.Dataset: ds = dims_conversion(ds, project, metadata_definition) ds = _ensure_correct_time(ds, project, metadata_definition) - ds = _offset_time(ds, project, metadata_definition) - + # TODO validate this is needed + # ds = _offset_time(ds, project, metadata_definition) ds = variable_conversion(ds, project, metadata_definition) - ds = metadata_conversion(ds, project, metadata_definition) ds.attrs["history"] = ( From e4857dab89fc59c425e3e50f77c3bd154209b596 Mon Sep 17 00:00:00 2001 From: tlogan2000 Date: Thu, 10 Oct 2024 13:44:50 -0400 Subject: [PATCH 10/16] remove _offset_time from ecmwf config; add "era5-single-levels-monthly-means" project to _transformation and _invert_sign --- src/miranda/convert/data/ecmwf_cf_attrs.json | 60 ++------------------ 1 file changed, 4 insertions(+), 56 deletions(-) diff --git a/src/miranda/convert/data/ecmwf_cf_attrs.json b/src/miranda/convert/data/ecmwf_cf_attrs.json index 26af79b9..c8aa133a 100644 --- a/src/miranda/convert/data/ecmwf_cf_attrs.json +++ b/src/miranda/convert/data/ecmwf_cf_attrs.json @@ -80,7 +80,6 @@ "_cf_variable_name": "tdps", "_corrected_units": false, "_invert_sign": false, - "_offset_time": false, "_transformation": false, "cell_methods": "time: point", "description": "This parameter is the temperature to which the air, at 2 metres above the surface of the Earth, would have to be cooled for saturation to occur. It is a measure of the humidity of the air. Combined with temperature and pressure, it can be used to calculate the relative humidity. 2m dew point temperature is calculated by interpolating between the lowest model level and the Earth's surface, taking account of the atmospheric conditions.", @@ -92,7 +91,6 @@ "_cf_variable_name": "psl", "_corrected_units": false, "_invert_sign": false, - "_offset_time": false, "_transformation": false, "cell_methods": "time: mean (interval: 1 hour)", "description": "This parameter is the pressure (force per unit area) of the atmosphere adjusted to the height of mean sea level. It is a measure of the weight that all the air in a column vertically above the area of Earth's surface would have at that point, if the point were located at the mean sea level. It is calculated over all surfaces - land, sea and in-land water.", @@ -107,16 +105,13 @@ "_invert_sign": { "era5-land": true, "era5-single-levels": true, - "era5-single-levels-preliminary-back-extension": true - }, - "_offset_time": { - "era5-land": true, - "era5-single-levels": true, + "era5-single-levels-monthly-means": true, "era5-single-levels-preliminary-back-extension": true }, "_transformation": { "era5-land": "deaccumulate", "era5-single-levels": "amount2rate", + "era5-single-levels-monthly-means": "amount2rate", "era5-single-levels-preliminary-back-extension": "amount2rate" }, "cell_methods": "time: mean (interval: 1 hour)", @@ -129,7 +124,6 @@ "ptype": { "_cf_variable_name": "prtype", "_invert_sign": false, - "_offset_time": false, "_transformation": false, "cell_methods": "time: point", "description": "This parameter describes the type of precipitation at the surface, at the specified time. A precipitation type is assigned wherever there is a non-zero value of precipitation. In the ECMWF Integrated Forecasting System (IFS) there are only two predicted precipitation variables: rain and snow. Precipitation type is derived from these two predicted variables in combination with atmospheric conditions, such as temperature. Values of precipitation type defined in the IFS: 0: No precipitation, 1: Rain, 3: Freezing rain (i.e. supercooled raindrops which freeze on contact with the ground and other surfaces), 5: Snow, 6: Wet snow (i.e. snow particles which are starting to melt); 7: Mixture of rain and snow, 8: Ice pellets. These precipitation types are consistent with WMO Code Table 4.201. Other types in this WMO table are not defined in the IFS.", @@ -141,7 +135,6 @@ "_cf_variable_name": "hus", "_corrected_units": 1, "_invert_sign": false, - "_offset_time": false, "_transformation": false, "cell_methods": "time: point", "description": "The total mass of moist air is the sum of the dry air, water vapour, cloud liquid, cloud ice, rain and falling snow.", @@ -152,7 +145,6 @@ "r": { "_cf_variable_name": "hur", "_invert_sign": false, - "_offset_time": false, "_transformation": false, "cell_methods": "time: point", "description": "This parameter is the water vapour pressure as a percentage of the value at which the air becomes saturated (the point at which water vapour begins to condense into liquid water or deposition into ice). For temperatures over 0°C (273.15 K) it is calculated for saturation over water. At temperatures below -23°C it is calculated for saturation over ice. Between -23°C and 0°C this parameter is calculated by interpolating between the ice and water values using a quadratic function.", @@ -164,7 +156,6 @@ "_cf_variable_name": "snr", "_corrected_units": "kg m-3", "_invert_sign": false, - "_offset_time": false, "_transformation": false, "cell_methods": "time: point", "description": "The ECMWF Integrated Forecasting System (IFS) represents snow as a single additional layer over the uppermost soil level. The snow may cover all or part of the grid box.", @@ -177,7 +168,6 @@ "_cf_variable_name": "snw", "_corrected_units": "Mg m-2", "_invert_sign": false, - "_offset_time": false, "_transformation": false, "cell_methods": "time: point", "comment": "Liquid water equivalent of snow converted to snow amount using a water density of 1000 kg/m³.", @@ -192,7 +182,6 @@ "era5-land": "m" }, "_invert_sign": false, - "_offset_time": false, "_transformation": false, "cell_methods": "time: point", "description": "Snow thickness in m of liquid water equivalent converted to snow thickness using a water density of 1000 kg/m³ and a snow density of 300 kg/m³.", @@ -211,14 +200,10 @@ "_corrected_units": "m", "_corrected_standard_name": "lwe_thickness_of_precipitation_amount", "_invert_sign": false, - "_offset_time": { - "era5-land": true, - "era5-single-levels": true, - "era5-single-levels-preliminary-back-extension": true - }, "_transformation": { "era5-land": "deaccumulate", "era5-single-levels": "amount2rate", + "era5-single-levels-monthly-means": "amount2rate", "era5-single-levels-preliminary-back-extension": "amount2rate" }, "cell_methods": "time: mean (interval: 1 hour)", @@ -236,11 +221,6 @@ "era5-single-levels": true, "era5-single-levels-preliminary-back-extension": true }, - "_offset_time": { - "era5-land": true, - "era5-single-levels": true, - "era5-single-levels-preliminary-back-extension": true - }, "_transformation": { "era5-land": "deaccumulate", "era5-single-levels": "amount2rate", @@ -257,7 +237,6 @@ "_cf_variable_name": "ps", "_corrected_units": false, "_invert_sign": false, - "_offset_time": false, "_transformation": false, "cell_methods": "time: point", "description": "This parameter is the pressure (force per unit area) of the atmosphere on the surface of land, sea and in-land water. It is a measure of the weight of all the air in a column vertically above the area of the Earth's surface represented at a fixed point.", @@ -273,11 +252,6 @@ "era5-single-levels": true, "era5-single-levels-preliminary-back-extension": true }, - "_offset_time": { - "era5-land": true, - "era5-single-levels": true, - "era5-single-levels-preliminary-back-extension": true - }, "_transformation": { "era5-land": "deaccumulate", "era5-single-levels": "amount2rate", @@ -294,11 +268,6 @@ "_cf_variable_name": "rss", "_corrected_units": "J m-2", "_invert_sign": false, - "_offset_time": { - "era5-land": true, - "era5-single-levels": true, - "era5-single-levels-preliminary-back-extension": true - }, "_transformation": { "era5-land": "deaccumulate", "era5-single-levels": "amount2rate", @@ -321,11 +290,6 @@ }, "_corrected_units": "J m-2", "_invert_sign": false, - "_offset_time": { - "era5-land": true, - "era5-single-levels": true, - "era5-single-levels-preliminary-back-extension": true - }, "_transformation": { "era5-land": "deaccumulate", "era5-single-levels": "amount2rate", @@ -342,7 +306,6 @@ "_cf_variable_name": "rls", "_corrected_units": "J m-2", "_invert_sign": false, - "_offset_time": true, "_transformation": { "era5-land": "deaccumulate", "era5-single-levels": "amount2rate", @@ -365,11 +328,6 @@ }, "_corrected_units": "J m-2", "_invert_sign": false, - "_offset_time": { - "era5-land": true, - "era5-single-levels": true, - "era5-single-levels-preliminary-back-extension": true - }, "_transformation": { "era5-land": "deaccumulate", "era5-single-levels": "amount2rate", @@ -386,7 +344,6 @@ "_cf_variable_name": "mrsolv1", "_corrected_units": "1", "_invert_sign": false, - "_offset_time": false, "_transformation": false, "cell_methods": "time: point", "description": "This parameter is the volume of water in soil layer 1 (0 - 7cm, the surface is at 0cm).", @@ -398,7 +355,6 @@ "_cf_variable_name": "mrsolv2", "_corrected_units": "1", "_invert_sign": false, - "_offset_time": false, "_transformation": false, "cell_methods": "time: point", "description": "This parameter is the volume of water in soil layer 2 (7 - 28cm, the surface is at 0cm).", @@ -410,7 +366,6 @@ "_cf_variable_name": "mrsolv3", "_corrected_units": "1", "_invert_sign": false, - "_offset_time": false, "_transformation": false, "cell_methods": "time: point", "description": "This parameter is the volume of water in soil layer 3 (28 - 100cm, the surface is at 0cm).", @@ -422,7 +377,6 @@ "_cf_variable_name": "mrsolv4", "_corrected_units": "1", "_invert_sign": false, - "_offset_time": false, "_transformation": false, "cell_methods": "time: point", "description": "This parameter is the volume of water in soil layer 4 (100 - 289cm, the surface is at 0cm).", @@ -434,7 +388,6 @@ "_cf_variable_name": "tas", "_corrected_units": false, "_invert_sign": false, - "_offset_time": false, "_transformation": false, "cell_methods": "time: point", "description": "This parameter is the temperature of air at 2m above the surface of land, sea or in-land waters. 2m temperature is calculated by interpolating between the lowest model level and the Earth's surface, taking account of the atmospheric conditions.", @@ -453,10 +406,10 @@ "_corrected_units": false, "_corrected_standard_name": "lwe_thickness_of_precipitation_amount", "_invert_sign": false, - "_offset_time": true, "_transformation": { "era5-land": "deaccumulate", "era5-single-levels": "amount2rate", + "era5-single-levels-monthly-means": "amount2rate", "era5-single-levels-preliminary-back-extension": "amount2rate" }, "cell_methods": "time: mean (interval: 1 hour)", @@ -470,7 +423,6 @@ "_cf_variable_name": "uas", "_corrected_units": false, "_invert_sign": false, - "_offset_time": false, "_transformation": false, "cell_methods": "time: point", "comments": "Care should be taken when comparing this parameter with observations, because wind observations vary on small space and time scales and are affected by the local terrain, vegetation and buildings that are represented only on average in the ECMWF Integrated Forecasting System.", @@ -483,7 +435,6 @@ "_cf_variable_name": "vas", "_corrected_units": false, "_invert_sign": false, - "_offset_time": false, "_transformation": false, "cell_methods": "time: point", "comments": "Care should be taken when comparing this parameter with observations, because wind observations vary on small space and time scales and are affected by the local terrain, vegetation and buildings that are represented only on average in the ECMWF Integrated Forecasting System.", @@ -496,7 +447,6 @@ "_cf_variable_name": "z", "_corrected_units": "m2 s-2", "_invert_sign": false, - "_offset_time": false, "_transformation": false, "cell_methods": "time: point", "comment": "The geopotential height can be calculated by dividing the geopotential by the Earth's gravitational acceleration, g (=9.80665 m s-2).", @@ -509,7 +459,6 @@ "_cf_variable_name": "tos", "_corrected_units": false, "_invert_sign": false, - "_offset_time": false, "_transformation": false, "cell_methods": "time: point", "description": "This parameter (SST) is the temperature of sea water near the surface. In ERA5, this parameter is a foundation SST, which means there are no variations due to the daily cycle of the sun (diurnal variations).", @@ -521,7 +470,6 @@ "_cf_variable_name": "siconc", "_corrected_units": "1", "_invert_sign": false, - "_offset_time": false, "_transformation": false, "cell_methods": "time: point", "description": "This parameter is the percentage of a grid box which is covered by sea ice. Sea ice can only occur in a grid box which includes ocean or inland water according to the land-sea mask and lake cover, at the resolution being used.", From eb12f5ca47c898b694009d1358830c161521800c Mon Sep 17 00:00:00 2001 From: Asli Bese Date: Tue, 22 Oct 2024 11:22:11 -0400 Subject: [PATCH 11/16] added the new variable 'land-sea mask (lsm)' --- src/miranda/convert/data/ecmwf_cf_attrs.json | 12 ++++++++++++ 1 file changed, 12 insertions(+) diff --git a/src/miranda/convert/data/ecmwf_cf_attrs.json b/src/miranda/convert/data/ecmwf_cf_attrs.json index 26af79b9..a8ec2fba 100644 --- a/src/miranda/convert/data/ecmwf_cf_attrs.json +++ b/src/miranda/convert/data/ecmwf_cf_attrs.json @@ -528,6 +528,18 @@ "long_name": "Sea ice area percentage", "standard_name": "sea_ice_area_fraction", "units": "%" + }, + "lsm": { + "_cf_variable_name": "sftlf", + "_corrected_units": "1", + "_invert_sign": false, + "_offset_time": false, + "_transformation": false, + "cell_methods": "time: point", + "description": "This parameter is the proportion of land, as opposed to ocean or inland waters (lakes, reservoirs, rivers and coastal waters), in a grid box.", + "long_name": "Land Area Fraction", + "standard_name": "land_area_fraction", + "units": "%" } } } From edadd0764317b3527c4ca1d02b7c56caa6f534d9 Mon Sep 17 00:00:00 2001 From: tlogan2000 Date: Wed, 27 Nov 2024 11:18:58 -0500 Subject: [PATCH 12/16] add units correction for raw ERA5 tp data --- src/miranda/convert/data/ecmwf_cf_attrs.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/miranda/convert/data/ecmwf_cf_attrs.json b/src/miranda/convert/data/ecmwf_cf_attrs.json index 38fd5356..3c6142cc 100644 --- a/src/miranda/convert/data/ecmwf_cf_attrs.json +++ b/src/miranda/convert/data/ecmwf_cf_attrs.json @@ -403,7 +403,7 @@ "min": "0 kg m-2 s-1" } }, - "_corrected_units": false, + "_corrected_units": {"era5-single-levels-monthly-means":"m d-1"}, "_corrected_standard_name": "lwe_thickness_of_precipitation_amount", "_invert_sign": false, "_transformation": { From 6b1b7a34f16d137c7dc51ba77c5b26050698cd95 Mon Sep 17 00:00:00 2001 From: "pre-commit-ci[bot]" <66853113+pre-commit-ci[bot]@users.noreply.github.com> Date: Wed, 27 Nov 2024 16:19:40 +0000 Subject: [PATCH 13/16] [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci --- src/miranda/convert/data/ecmwf_cf_attrs.json | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/src/miranda/convert/data/ecmwf_cf_attrs.json b/src/miranda/convert/data/ecmwf_cf_attrs.json index 3c6142cc..cde4f064 100644 --- a/src/miranda/convert/data/ecmwf_cf_attrs.json +++ b/src/miranda/convert/data/ecmwf_cf_attrs.json @@ -403,7 +403,9 @@ "min": "0 kg m-2 s-1" } }, - "_corrected_units": {"era5-single-levels-monthly-means":"m d-1"}, + "_corrected_units": { + "era5-single-levels-monthly-means": "m d-1" + }, "_corrected_standard_name": "lwe_thickness_of_precipitation_amount", "_invert_sign": false, "_transformation": { From 3d857ca0fe588674baef578954905b67c5a3ffac Mon Sep 17 00:00:00 2001 From: tlogan2000 Date: Wed, 27 Nov 2024 12:07:07 -0500 Subject: [PATCH 14/16] remove transformation unit correction is a rate for monthly --- src/miranda/convert/data/ecmwf_cf_attrs.json | 1 - 1 file changed, 1 deletion(-) diff --git a/src/miranda/convert/data/ecmwf_cf_attrs.json b/src/miranda/convert/data/ecmwf_cf_attrs.json index cde4f064..c06a2ca1 100644 --- a/src/miranda/convert/data/ecmwf_cf_attrs.json +++ b/src/miranda/convert/data/ecmwf_cf_attrs.json @@ -411,7 +411,6 @@ "_transformation": { "era5-land": "deaccumulate", "era5-single-levels": "amount2rate", - "era5-single-levels-monthly-means": "amount2rate", "era5-single-levels-preliminary-back-extension": "amount2rate" }, "cell_methods": "time: mean (interval: 1 hour)", From 762bcf5d6300d1678dcf35eb980c9ab47a96bd4b Mon Sep 17 00:00:00 2001 From: Asli Bese Date: Thu, 19 Dec 2024 16:45:57 -0500 Subject: [PATCH 15/16] added four new variables cp, cape, u, v. removed stlf --- src/miranda/convert/data/ecmwf_cf_attrs.json | 65 +++++++++++++++++--- 1 file changed, 57 insertions(+), 8 deletions(-) diff --git a/src/miranda/convert/data/ecmwf_cf_attrs.json b/src/miranda/convert/data/ecmwf_cf_attrs.json index c06a2ca1..67332b6b 100644 --- a/src/miranda/convert/data/ecmwf_cf_attrs.json +++ b/src/miranda/convert/data/ecmwf_cf_attrs.json @@ -478,17 +478,66 @@ "standard_name": "sea_ice_area_fraction", "units": "%" }, - "lsm": { - "_cf_variable_name": "sftlf", - "_corrected_units": "1", + "cp": { + "_cf_variable_name": "prc", + "_clip_values": { + "all": { + "context": "hydro", + "min": "0 kg m-2 s-1" + } + }, + "_corrected_units": { + "era5-single-levels-monthly-means": "m d-1" + }, + "_corrected_standard_name": "lwe_thickness_of_convective_precipitation_amount", + "_invert_sign": false, + "_transformation": { + "era5-land": "deaccumulate", + "era5-single-levels": "amount2rate", + "era5-single-levels-preliminary-back-extension": "amount2rate" + }, + "cell_methods": "time: mean (interval: 1 hour)", + "description": "Convective precipitation thickness converted to mass flux using a water density of 1000 kg/m³.", + "long_name": "Convective precipitation", + "standard_name": "convective_precipitation_flux", + "units": "kg m-2 s-1" + }, + "cape": { + "_cf_variable_name": "CAPE", + "_corrected_units": false, "_invert_sign": false, - "_offset_time": false, "_transformation": false, "cell_methods": "time: point", - "description": "This parameter is the proportion of land, as opposed to ocean or inland waters (lakes, reservoirs, rivers and coastal waters), in a grid box.", - "long_name": "Land Area Fraction", - "standard_name": "land_area_fraction", - "units": "%" + "description": "This is an indication of the instability (or stability) of the atmosphere and can be used to assess the potential for the development of convection, which can lead to heavy rainfall, thunderstorms and other severe weather. ", + "long_name": "Convective available potential energy", + "standard_name": "atmosphere_convective_available_potential_energy_wrt_surface", + "units": "J kg-1" + }, + "u": { + "_cf_variable_name": "ua", + "_corrected_units": false, + "_invert_sign": false, + "_transformation": false, + "cell_methods": "time: point", + "comments": "Care should be taken when comparing model parameters with observations, because observations are often local to a particular point in space and time, rather than representing averages over a model grid box.", + "description": "This parameter is the eastward component of the wind at specified pressure levels. It is the horizontal speed of air moving towards the east, in metres per second.", + "long_name": "Eastward wind", + "original_long_name": "U component of wind", + "standard_name": "eastward_wind", + "units": "m s-1" + }, + "v": { + "_cf_variable_name": "va", + "_corrected_units": false, + "_invert_sign": false, + "_transformation": false, + "cell_methods": "time: point", + "comments": "Care should be taken when comparing model parameters with observations, because observations are often local to a particular point in space and time, rather than representing averages over a model grid box.", + "description": "This parameter is the northward component of the wind at specified pressure levels. It is the horizontal speed of air moving towards the north, in metres per second.", + "long_name": "Northward wind", + "original_long_name": "V component of wind", + "standard_name": "northward_wind", + "units": "m s-1" } } } From 02807b83a4a67cff793c338e01b97fb7c9f68018 Mon Sep 17 00:00:00 2001 From: "pre-commit-ci[bot]" <66853113+pre-commit-ci[bot]@users.noreply.github.com> Date: Thu, 19 Dec 2024 21:47:20 +0000 Subject: [PATCH 16/16] [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci --- src/miranda/convert/data/ecmwf_cf_attrs.json | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/src/miranda/convert/data/ecmwf_cf_attrs.json b/src/miranda/convert/data/ecmwf_cf_attrs.json index 67332b6b..6d685430 100644 --- a/src/miranda/convert/data/ecmwf_cf_attrs.json +++ b/src/miranda/convert/data/ecmwf_cf_attrs.json @@ -497,11 +497,11 @@ "era5-single-levels-preliminary-back-extension": "amount2rate" }, "cell_methods": "time: mean (interval: 1 hour)", - "description": "Convective precipitation thickness converted to mass flux using a water density of 1000 kg/m³.", + "description": "Convective precipitation thickness converted to mass flux using a water density of 1000 kg/m³.", "long_name": "Convective precipitation", "standard_name": "convective_precipitation_flux", "units": "kg m-2 s-1" - }, + }, "cape": { "_cf_variable_name": "CAPE", "_corrected_units": false, @@ -512,7 +512,7 @@ "long_name": "Convective available potential energy", "standard_name": "atmosphere_convective_available_potential_energy_wrt_surface", "units": "J kg-1" - }, + }, "u": { "_cf_variable_name": "ua", "_corrected_units": false,