From 5d874814ddd86880dc854437f316e4d7197d94bb Mon Sep 17 00:00:00 2001 From: Patrick Schmitt <50843444+pat-schmitt@users.noreply.github.com> Date: Mon, 16 Sep 2024 12:31:24 +0200 Subject: [PATCH] Updating to NumPy > 2.0 (#1742) * fix tests and warnings for numpy>2.0 * fix further warnings * pep8 --- oggm/core/dynamic_spinup.py | 10 ++++------ oggm/core/flowline.py | 2 +- oggm/tests/test_models.py | 10 ++++++---- oggm/utils/_funcs.py | 16 +++++++++++++--- oggm/utils/_workflow.py | 10 ++++++++-- oggm/workflow.py | 2 +- 6 files changed, 33 insertions(+), 17 deletions(-) diff --git a/oggm/core/dynamic_spinup.py b/oggm/core/dynamic_spinup.py index aae925584..b16cdd7d8 100644 --- a/oggm/core/dynamic_spinup.py +++ b/oggm/core/dynamic_spinup.py @@ -1548,8 +1548,8 @@ def dynamic_melt_f_run( with utils.DisableLogger(): ds = utils.compile_run_output(gdir, input_filesuffix=output_filesuffix, path=False) - dmdtda_mdl = ((ds.volume.loc[yr1_ref_mb].values - - ds.volume.loc[yr0_ref_mb].values) / + dmdtda_mdl = ((ds.volume.loc[yr1_ref_mb].values[0] - + ds.volume.loc[yr0_ref_mb].values[0]) / gdir.rgi_area_m2 / (yr1_ref_mb - yr0_ref_mb) * cfg.PARAMS['ice_density']) @@ -1960,10 +1960,8 @@ def cost_fct(melt_f, model_dynamic_spinup_end): model_dynamic_spinup_end.append(copy.deepcopy(model_dynamic_spinup)) # calculate the mismatch of dmdtda - try: - cost = float(dmdtda_mdl - ref_dmdtda) - except: - t = 1 + cost = float(dmdtda_mdl - ref_dmdtda) + return cost def init_cost_fun(): diff --git a/oggm/core/flowline.py b/oggm/core/flowline.py index 1eba131a6..f84c4d433 100644 --- a/oggm/core/flowline.py +++ b/oggm/core/flowline.py @@ -1262,7 +1262,7 @@ def run_until_and_store(self, y1, # First deal with spinup (we compute volume change only) if do_fixed_spinup: - spinup_vol = monthly_time * 0 + spinup_vol = monthly_time * 0. for fl_id, fl in enumerate(self.fls): h = fl.surface_h diff --git a/oggm/tests/test_models.py b/oggm/tests/test_models.py index 6d3acd8e9..7b444a810 100644 --- a/oggm/tests/test_models.py +++ b/oggm/tests/test_models.py @@ -3858,9 +3858,9 @@ def reset_melt_f(): df_ref_dmdtda = utils.get_geodetic_mb_dataframe().loc[gdir.rgi_id] sel = df_ref_dmdtda.loc[df_ref_dmdtda['period'] == ref_period] - ref_dmdtda = float(sel['dmdtda']) + ref_dmdtda = float(sel['dmdtda'].iloc[0]) ref_dmdtda *= 1000 # kg m-2 yr-1 - err_ref_dmdtda = float(sel['err_dmdtda']) + err_ref_dmdtda = float(sel['err_dmdtda'].iloc[0]) err_ref_dmdtda *= 1000 # kg m-2 yr-1 melt_f_max = 1000 * 12 / 365 @@ -5713,8 +5713,10 @@ def test_distribute(self, hef_elev_gdir, inversion_params): fl_diag = fl_diag.isel(dis_along_flowline=slice(0, band_ids.max()+1)) for bid in band_ids: thick_band = thick.where(ds.band_index == bid) - fl_diag['volume_m3_dis'].data[:, bid] = thick_band.sum(dim=['x', 'y']) * dx2 - fl_diag['area_m2_dis'].data[:, bid] = (thick_band > 1).sum(dim=['x', 'y']) * dx2 + fl_diag['volume_m3_dis'].data[:, bid] = thick_band.sum(dim=['x', 'y'] + ).values * dx2 + fl_diag['area_m2_dis'].data[:, bid] = (thick_band > 1).sum(dim=['x', 'y'] + ).values * dx2 for yr in [2003]: # All the other years have larger errors but they somehow still look diff --git a/oggm/utils/_funcs.py b/oggm/utils/_funcs.py index 8f9447320..247bccf14 100644 --- a/oggm/utils/_funcs.py +++ b/oggm/utils/_funcs.py @@ -687,6 +687,9 @@ def floatyear_to_date(yr): The floating year """ + if isinstance(yr, xr.DataArray): + yr = yr.values + out_y, remainder = np.divmod(yr, 1) out_y = out_y.astype(int) @@ -700,9 +703,6 @@ def floatyear_to_date(yr): if (isinstance(yr, list) or isinstance(yr, np.ndarray)) and len(yr) == 1: out_y = out_y.item() out_m = out_m.item() - elif isinstance(yr, xr.DataArray): - out_y = np.array(out_y) - out_m = np.array(out_m) return out_y, out_m @@ -769,6 +769,11 @@ def calendardate_to_hydrodate(y, m, start_month=None): the first month of the hydrological year """ + if isinstance(y, xr.DataArray): + y = y.values + if isinstance(m, xr.DataArray): + m = m.values + if start_month is None: raise InvalidParamsError('In order to avoid confusion, we now force ' 'callers of this function to specify the ' @@ -793,6 +798,11 @@ def monthly_timeseries(y0, y1=None, ny=None, include_last_year=False): ---------- """ + if isinstance(y0, xr.DataArray): + y0 = y0.values + if isinstance(y1, xr.DataArray): + y1 = y1.values + if y1 is not None: years = np.arange(np.floor(y0), np.floor(y1) + 1) elif ny is not None: diff --git a/oggm/utils/_workflow.py b/oggm/utils/_workflow.py index 84db2c84c..10faeba31 100644 --- a/oggm/utils/_workflow.py +++ b/oggm/utils/_workflow.py @@ -2313,9 +2313,9 @@ def extend_past_climate_run(past_run_file=None, # Time ods['hydro_year'].data[:] = years - ods['hydro_month'].data[:] = ods['hydro_month'][-1] + ods['hydro_month'].data[:] = ods['hydro_month'][-1].item() ods['calendar_year'].data[:] = years - ods['calendar_month'].data[:] = ods['calendar_month'][-1] + ods['calendar_month'].data[:] = ods['calendar_month'][-1].item() for vn in ['hydro_year', 'hydro_month', 'calendar_year', 'calendar_month']: ods[vn] = ods[vn].astype(int) @@ -3423,6 +3423,12 @@ def write_monthly_climate_file(self, time, prcp, temp, Apply a suffix to the file """ + if isinstance(prcp, xr.DataArray): + prcp = prcp.values + if isinstance(temp, xr.DataArray): + temp = temp.values + if isinstance(temp_std, xr.DataArray): + temp_std = temp_std.values # overwrite as default fpath = self.get_filepath(file_name, filesuffix=filesuffix) if os.path.exists(fpath): diff --git a/oggm/workflow.py b/oggm/workflow.py index 8ee7a3aa7..23d2e006a 100644 --- a/oggm/workflow.py +++ b/oggm/workflow.py @@ -1068,7 +1068,7 @@ def merge_gridded_data(gdirs, output_folder=None, if slice_of_var is not None: if dim in slice_of_var: coord_val = ds_templ[coord].sel( - {dim: slice_of_var[dim]}) + {dim: slice_of_var[dim]}).values else: coord_val = ds_templ[coord].values else: