From ab917a41042397dc25732e4b7dfad976d7fa7e93 Mon Sep 17 00:00:00 2001 From: "pre-commit-ci[bot]" <66853113+pre-commit-ci[bot]@users.noreply.github.com> Date: Mon, 3 Jun 2024 21:41:01 +0000 Subject: [PATCH 1/6] [pre-commit.ci] pre-commit autoupdate MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit updates: - [github.com/psf/black-pre-commit-mirror: 24.4.1 → 24.4.2](https://github.com/psf/black-pre-commit-mirror/compare/24.4.1...24.4.2) - [github.com/astral-sh/ruff-pre-commit: v0.3.7 → v0.4.7](https://github.com/astral-sh/ruff-pre-commit/compare/v0.3.7...v0.4.7) - [github.com/pylint-dev/pylint: v3.1.0 → v3.2.2](https://github.com/pylint-dev/pylint/compare/v3.1.0...v3.2.2) - [github.com/codespell-project/codespell: v2.2.6 → v2.3.0](https://github.com/codespell-project/codespell/compare/v2.2.6...v2.3.0) - [github.com/gitleaks/gitleaks: v8.18.2 → v8.18.3](https://github.com/gitleaks/gitleaks/compare/v8.18.2...v8.18.3) - [github.com/python-jsonschema/check-jsonschema: 0.28.2 → 0.28.4](https://github.com/python-jsonschema/check-jsonschema/compare/0.28.2...0.28.4) --- .pre-commit-config.yaml | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/.pre-commit-config.yaml b/.pre-commit-config.yaml index 6d9f2ce7d..4f4ed1db7 100644 --- a/.pre-commit-config.yaml +++ b/.pre-commit-config.yaml @@ -33,7 +33,7 @@ repos: - id: yamllint args: [ '--config-file=.yamllint.yaml' ] - repo: https://github.com/psf/black-pre-commit-mirror - rev: 24.4.1 + rev: 24.4.2 hooks: - id: black - repo: https://github.com/PyCQA/isort @@ -41,11 +41,11 @@ repos: hooks: - id: isort - repo: https://github.com/astral-sh/ruff-pre-commit - rev: v0.3.7 + rev: v0.4.7 hooks: - id: ruff - repo: https://github.com/pylint-dev/pylint - rev: v3.1.0 + rev: v3.2.2 hooks: - id: pylint args: [ '--rcfile=.pylintrc.toml', '--errors-only', '--jobs=0', '--disable=import-error' ] @@ -82,16 +82,16 @@ repos: additional_dependencies: [ 'black==24.4.1' ] exclude: '(xclim/indices/__init__.py|docs/installation.rst)' - repo: https://github.com/codespell-project/codespell - rev: v2.2.6 + rev: v2.3.0 hooks: - id: codespell additional_dependencies: [ 'tomli' ] - repo: https://github.com/gitleaks/gitleaks - rev: v8.18.2 + rev: v8.18.3 hooks: - id: gitleaks - repo: https://github.com/python-jsonschema/check-jsonschema - rev: 0.28.2 + rev: 0.28.4 hooks: - id: check-github-workflows - id: check-readthedocs From 768b8c6c59955833d94d81f489eee87525550e26 Mon Sep 17 00:00:00 2001 From: Trevor James Smith <10819524+Zeitsperre@users.noreply.github.com> Date: Fri, 7 Jun 2024 14:37:11 -0400 Subject: [PATCH 2/6] Update .pre-commit-config.yaml --- .pre-commit-config.yaml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/.pre-commit-config.yaml b/.pre-commit-config.yaml index 4f4ed1db7..5cb38c26e 100644 --- a/.pre-commit-config.yaml +++ b/.pre-commit-config.yaml @@ -66,7 +66,7 @@ repos: args: [ '--py39-plus' ] additional_dependencies: [ 'pyupgrade==3.15.2' ] - id: nbqa-black - additional_dependencies: [ 'black==24.4.1' ] + additional_dependencies: [ 'black==24.4.2' ] - id: nbqa-isort additional_dependencies: [ 'isort==5.13.2' ] - repo: https://github.com/kynan/nbstripout @@ -79,7 +79,7 @@ repos: rev: v0.3.9 hooks: - id: blackdoc - additional_dependencies: [ 'black==24.4.1' ] + additional_dependencies: [ 'black==24.4.2' ] exclude: '(xclim/indices/__init__.py|docs/installation.rst)' - repo: https://github.com/codespell-project/codespell rev: v2.3.0 From 9f4d4c0a6b1acd7917dfb455f8c62af36485d45f Mon Sep 17 00:00:00 2001 From: Zeitsperre <10819524+Zeitsperre@users.noreply.github.com> Date: Fri, 7 Jun 2024 16:37:38 -0400 Subject: [PATCH 3/6] fix linting issues raised from new pylint and codespell versions --- pyproject.toml | 2 +- tests/test_calendar.py | 2 ++ tests/test_indices.py | 2 ++ xclim/indices/fire/_cffwis.py | 8 ++++++++ xclim/indices/fire/_ffdi.py | 2 +- xclim/sdba/adjustment.py | 6 +++++- xclim/sdba/loess.py | 21 +++++++++++---------- xclim/sdba/processing.py | 15 ++++++++------- 8 files changed, 38 insertions(+), 20 deletions(-) diff --git a/pyproject.toml b/pyproject.toml index 6ba54f844..3b424f129 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -156,7 +156,7 @@ values = [ [tool.codespell] skip = 'xclim/data/*.json,docs/_build,docs/notebooks/xclim_training/*.ipynb,docs/references.bib,__pycache__,*.gz,*.nc,*.png,*.svg,*.whl' -ignore-words-list = "absolue,astroid,bloc,bui,callendar,degreee,environnement,hanel,inferrable,lond,nam,nd,ressources,sie,vas" +ignore-words-list = "absolue,astroid,bloc,bui,callendar,degreee,environnement,hanel,inferrable,lond,nam,nd,ressources,socio-economic,sie,vas" [tool.coverage.run] relative_files = true diff --git a/tests/test_calendar.py b/tests/test_calendar.py index 2d37f0348..9e9af5630 100644 --- a/tests/test_calendar.py +++ b/tests/test_calendar.py @@ -90,6 +90,8 @@ def test_time_bnds_irregular(typ): elif typ == "pd": start = pd.date_range("1990-01-01", periods=24, freq="MS") end = pd.date_range("1990-01-01 23:59:59.999999999", periods=24, freq="ME") + else: + raise ValueError("`typ` must be 'pd' or 'xr'") time = start + (end - start) / 2 diff --git a/tests/test_indices.py b/tests/test_indices.py index e2a8ccc47..ad4483cd7 100644 --- a/tests/test_indices.py +++ b/tests/test_indices.py @@ -2971,6 +2971,8 @@ def test_rain_season(pr_series, result_type, method_dry_start): elif result_type == "end_cond_fails": pr[{"time": 99 + 20 - 1}] = 5 out_exp = [3, np.NaN, 363] + else: + raise ValueError(f"Unknown result_type: {result_type}") out = {} out["start"], out["end"], out["length"] = xci.rain_season( diff --git a/xclim/indices/fire/_cffwis.py b/xclim/indices/fire/_cffwis.py index 7d1e99db5..1a58b8448 100644 --- a/xclim/indices/fire/_cffwis.py +++ b/xclim/indices/fire/_cffwis.py @@ -597,6 +597,8 @@ def _fire_season( elif method in ["LA08", "GFWED"]: # In LA08, the check INCLUDES the current day, start_index = max(temp_condition_days, snow_condition_days) + else: + raise ValueError("`method` must be one of 'WF93', 'LA08' or 'GFWED'.") for it in range(start_index, tas.shape[-1]): if method == "WF93": @@ -627,6 +629,8 @@ def _fire_season( # Shut down when mean snow OR mean temp are over/under threshold shut_down = (msnow >= snow_thresh) | (mtemp < temp_end_thresh) + else: + raise ValueError("`method` must be one of 'WF93', 'LA08' or 'GFWED'.") # Mask is on if the previous days was on OR is there is a start-up, AND if it's not a shut-down, # Aka is off if either the previous day was or it is a shut-down. @@ -687,6 +691,10 @@ def _fire_weather_calc( # noqa: C901 overwintering = params["overwintering"] dry_start = params["dry_start"] + + ow_DC = dc0.copy() if dc0 is not None else None + ow_DMC = dmc0.copy() if dmc0 is not None else None + if overwintering and "DC" in ind_prevs: # In overwintering, dc0 is understood as the previous season's last DC code. ow_DC = dc0.copy() diff --git a/xclim/indices/fire/_ffdi.py b/xclim/indices/fire/_ffdi.py index 847652f31..be14f16d1 100644 --- a/xclim/indices/fire/_ffdi.py +++ b/xclim/indices/fire/_ffdi.py @@ -144,7 +144,7 @@ def _griffiths_drought_factor(p, smd, lim, df): # pragma: no cover # N = 0 defines a rainfall event since 9am today, # so doesn't apply here, where p is the rainfall # over previous 24 hours. - x_ = N**1.3 / (N**1.3 + P - 2.0) + x_ = N**1.3 / (N**1.3 + P - 2.0) # pylint: disable=E0601 x = min(x_, x) conseq = 0 diff --git a/xclim/sdba/adjustment.py b/xclim/sdba/adjustment.py index 113f8acb0..d9bdbf225 100644 --- a/xclim/sdba/adjustment.py +++ b/xclim/sdba/adjustment.py @@ -959,7 +959,7 @@ def _compute_transform_matrix(reference, historical): # This step needs vectorize with dask, but vectorize doesn't work with dask, argh. # Invert to get transformation matrix from hist to PC coords. Hinv = np.linalg.inv(H) - # Fancy tricks to choose best orientation on each axes + # Fancy tricks to choose the best orientation on each axis. # (using eigenvectors, the output axes orientation is undefined) if best_orientation == "simple": orient = best_pc_orientation_simple(R, Hinv) @@ -967,6 +967,10 @@ def _compute_transform_matrix(reference, historical): orient = best_pc_orientation_full( R, Hinv, reference.mean(axis=1), historical.mean(axis=1), historical ) + else: + raise ValueError( + f"Unknown `best_orientation` method: {best_orientation}." + ) # Get transformation matrix return (R * orient) @ Hinv diff --git a/xclim/sdba/loess.py b/xclim/sdba/loess.py index 2a527d993..abb15480e 100644 --- a/xclim/sdba/loess.py +++ b/xclim/sdba/loess.py @@ -68,21 +68,21 @@ def _loess_nb( Parameters ---------- x : np.ndarray - X-coordinates of the points. + X-coordinates of the points. y : np.ndarray - Y-coordinates of the points. + Y-coordinates of the points. f : float - Parameter controlling the shape of the weight curve. Behavior depends on the weighting function. + Parameter controlling the shape of the weight curve. Behavior depends on the weighting function. niter : int - Number of robustness iterations to execute. + Number of robustness iterations to execute. weight_func : numba func - Numba function giving the weights when passed abs(x - xi) / hi + Numba function giving the weights when passed abs(x - xi) / hi dx : float - The spacing of the x coordinates. If above 0, this enables the optimization for equally spaced x coordinates. - Must be 0 if spacing is unequal (default). + The spacing of the x coordinates. If above 0, this enables the optimization for equally spaced x coordinates. + Must be 0 if spacing is unequal (default). skipna : bool - If True (default), remove NaN values before computing the loess. The output has the - same missing values as the input. + If True (default), remove NaN values before computing the loess. The output has the + same missing values as the input. References ---------- @@ -150,7 +150,8 @@ def _loess_nb( else: h = (hw + 1) * dx wi = weight_func(diffs / h) - w = di * wi + # Is it expected that `wi` always be assigned before first being called? + w = di * wi # pylint: disable=E0606 else: # The weights computation is repeated niter times # The distance of points from the current centre point. diff --git a/xclim/sdba/processing.py b/xclim/sdba/processing.py index 359d95eee..ce9a6e70a 100644 --- a/xclim/sdba/processing.py +++ b/xclim/sdba/processing.py @@ -7,6 +7,7 @@ import types from collections.abc import Sequence +from typing import cast import dask.array as dsk import numpy as np @@ -584,14 +585,12 @@ def to_additive_space( float ) - from typing import cast - with xr.set_options(keep_attrs=True), np.errstate(divide="ignore"): if trans == "log": out = cast(xr.DataArray, np.log(data - lower_bound_array)) - elif trans == "logit": + elif trans == "logit" and upper_bound is not None: data_prime = (data - lower_bound_array) / ( - upper_bound_array - lower_bound_array + upper_bound_array - lower_bound_array # pylint: disable=E0606 ) out = cast(xr.DataArray, np.log(data_prime / (1 - data_prime))) else: @@ -684,7 +683,7 @@ def from_additive_space( lower_bound_array = np.array(data.attrs["sdba_transform_lower"]).astype( float ) - if trans == "logit": + if trans == "logit" and upper_bound is not None: upper_bound_array = np.array(data.attrs["sdba_transform_upper"]).astype( float ) @@ -714,10 +713,12 @@ def from_additive_space( with xr.set_options(keep_attrs=True): if trans == "log": out = np.exp(data) + lower_bound_array - elif trans == "logit": + elif trans == "logit" and upper_bound is not None: out_prime = 1 / (1 + np.exp(-data)) out = ( - out_prime * (upper_bound_array - lower_bound_array) + lower_bound_array + out_prime + * (upper_bound_array - lower_bound_array) # pylint: disable=E0606 + + lower_bound_array ) else: raise NotImplementedError("`trans` must be one of 'log' or 'logit'.") From c5b1f9ce369ac78e99cfa427a712375f26dd63ac Mon Sep 17 00:00:00 2001 From: Zeitsperre <10819524+Zeitsperre@users.noreply.github.com> Date: Mon, 10 Jun 2024 13:59:17 -0400 Subject: [PATCH 4/6] undo regression --- xclim/sdba/processing.py | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/xclim/sdba/processing.py b/xclim/sdba/processing.py index ce9a6e70a..ecd2128f6 100644 --- a/xclim/sdba/processing.py +++ b/xclim/sdba/processing.py @@ -683,7 +683,7 @@ def from_additive_space( lower_bound_array = np.array(data.attrs["sdba_transform_lower"]).astype( float ) - if trans == "logit" and upper_bound is not None: + if trans == "logit": upper_bound_array = np.array(data.attrs["sdba_transform_upper"]).astype( float ) @@ -713,7 +713,7 @@ def from_additive_space( with xr.set_options(keep_attrs=True): if trans == "log": out = np.exp(data) + lower_bound_array - elif trans == "logit" and upper_bound is not None: + elif trans == "logit": out_prime = 1 / (1 + np.exp(-data)) out = ( out_prime From 97875978b6dc0020d14a2a583cea4ee54541de15 Mon Sep 17 00:00:00 2001 From: Zeitsperre <10819524+Zeitsperre@users.noreply.github.com> Date: Mon, 10 Jun 2024 14:07:48 -0400 Subject: [PATCH 5/6] safer doctests --- xclim/indices/_agro.py | 4 ++-- xclim/indices/_anuclim.py | 8 ++++---- xclim/indices/_multivariate.py | 26 +++++++++++++------------- xclim/indices/_simple.py | 14 +++++++------- xclim/indices/_threshold.py | 16 ++++++++-------- 5 files changed, 34 insertions(+), 34 deletions(-) diff --git a/xclim/indices/_agro.py b/xclim/indices/_agro.py index 2c3c8855c..9bfcb0cb4 100644 --- a/xclim/indices/_agro.py +++ b/xclim/indices/_agro.py @@ -506,7 +506,7 @@ def cool_night_index( Examples -------- >>> from xclim.indices import cool_night_index - >>> tasmin = xr.open_dataset(path_to_tasmin_file).tasmin + >>> tasmin = open_dataset(path_to_tasmin_file).tasmin >>> cni = cool_night_index(tasmin) References @@ -1170,7 +1170,7 @@ def standardized_precipitation_index( ------- >>> from datetime import datetime >>> from xclim.indices import standardized_precipitation_index - >>> ds = xr.open_dataset(path_to_pr_file) + >>> ds = open_dataset(path_to_pr_file) >>> pr = ds.pr >>> cal_start, cal_end = "1990-05-01", "1990-08-31" >>> spi_3 = standardized_precipitation_index( diff --git a/xclim/indices/_anuclim.py b/xclim/indices/_anuclim.py index 76256c984..8702bc5af 100644 --- a/xclim/indices/_anuclim.py +++ b/xclim/indices/_anuclim.py @@ -128,7 +128,7 @@ def temperature_seasonality( The following would compute for each grid cell of file `tas.day.nc` the annual temperature seasonality: >>> import xclim.indices as xci - >>> t = xr.open_dataset(path_to_tas_file).tas + >>> t = open_dataset(path_to_tas_file).tas >>> tday_seasonality = xci.temperature_seasonality(t) >>> t_weekly = xci.tg_mean(t, freq="7D") >>> tweek_seasonality = xci.temperature_seasonality(t_weekly) @@ -179,7 +179,7 @@ def precip_seasonality(pr: xarray.DataArray, freq: str = "YS") -> xarray.DataArr The following would compute for each grid cell of file `pr.day.nc` the annual precipitation seasonality: >>> import xclim.indices as xci - >>> p = xr.open_dataset(path_to_pr_file).pr + >>> p = open_dataset(path_to_pr_file).pr >>> pday_seasonality = xci.precip_seasonality(p) >>> p_weekly = xci.precip_accumulation(p, freq="7D") @@ -242,7 +242,7 @@ def tg_mean_warmcold_quarter( warmest quarter mean temperature: >>> from xclim.indices import tg_mean_warmcold_quarter - >>> t = xr.open_dataset(path_to_tas_file) + >>> t = open_dataset(path_to_tas_file) >>> t_warm_qrt = tg_mean_warmcold_quarter(tas=t.tas, op="warmest") Notes @@ -353,7 +353,7 @@ def prcptot_wetdry_quarter( The following would compute for each grid cell of file `pr.day.nc` the annual wettest quarter total precipitation: >>> from xclim.indices import prcptot_wetdry_quarter - >>> p = xr.open_dataset(path_to_pr_file) + >>> p = open_dataset(path_to_pr_file) >>> pr_warm_qrt = prcptot_wetdry_quarter(pr=p.pr, op="wettest") Notes diff --git a/xclim/indices/_multivariate.py b/xclim/indices/_multivariate.py index 6785f2d3c..be5cf71da 100644 --- a/xclim/indices/_multivariate.py +++ b/xclim/indices/_multivariate.py @@ -127,7 +127,7 @@ def cold_spell_duration_index( -------- >>> from xclim.core.calendar import percentile_doy >>> from xclim.indices import cold_spell_duration_index - >>> tasmin = xr.open_dataset(path_to_tasmin_file).tasmin.isel(lat=0, lon=0) + >>> tasmin = open_dataset(path_to_tasmin_file).tasmin.isel(lat=0, lon=0) >>> tn10 = percentile_doy(tasmin, per=10).sel(percentiles=10) >>> cold_spell_duration_index(tasmin, tn10) @@ -971,7 +971,7 @@ def precip_accumulation( precipitation at the seasonal frequency, ie DJF, MAM, JJA, SON, DJF, etc.: >>> from xclim.indices import precip_accumulation - >>> pr_day = xr.open_dataset(path_to_pr_file).pr + >>> pr_day = open_dataset(path_to_pr_file).pr >>> prcp_tot_seasonal = precip_accumulation(pr_day, freq="QS-DEC") """ if phase == "liquid": @@ -1034,7 +1034,7 @@ def precip_average( precipitation at the seasonal frequency, ie DJF, MAM, JJA, SON, DJF, etc.: >>> from xclim.indices import precip_average - >>> pr_day = xr.open_dataset(path_to_pr_file).pr + >>> pr_day = open_dataset(path_to_pr_file).pr >>> prcp_tot_seasonal = precip_average(pr_day, freq="QS-DEC") """ if phase == "liquid": @@ -1146,8 +1146,8 @@ def high_precip_low_temp( Example ------- To compute the number of days with intense rainfall while minimum temperatures dip below -0.2C: - >>> pr = xr.open_dataset(path_to_pr_file).pr - >>> tasmin = xr.open_dataset(path_to_tasmin_file).tasmin + >>> pr = open_dataset(path_to_pr_file).pr + >>> tasmin = open_dataset(path_to_tasmin_file).tasmin >>> high_precip_low_temp( ... pr, tas=tasmin, pr_thresh="10 mm/d", tas_thresh="-0.2 degC" ... ) @@ -1204,7 +1204,7 @@ def days_over_precip_thresh( Examples -------- >>> from xclim.indices import days_over_precip_thresh - >>> pr = xr.open_dataset(path_to_pr_file).pr + >>> pr = open_dataset(path_to_pr_file).pr >>> p75 = pr.quantile(0.75, dim="time", keep_attrs=True) >>> r75p = days_over_precip_thresh(pr, p75) """ @@ -1333,7 +1333,7 @@ def tg90p( -------- >>> from xclim.core.calendar import percentile_doy >>> from xclim.indices import tg90p - >>> tas = xr.open_dataset(path_to_tas_file).tas + >>> tas = open_dataset(path_to_tas_file).tas >>> tas_per = percentile_doy(tas, per=90).sel(percentiles=90) >>> hot_days = tg90p(tas, tas_per) """ @@ -1391,7 +1391,7 @@ def tg10p( -------- >>> from xclim.core.calendar import percentile_doy >>> from xclim.indices import tg10p - >>> tas = xr.open_dataset(path_to_tas_file).tas + >>> tas = open_dataset(path_to_tas_file).tas >>> tas_per = percentile_doy(tas, per=10).sel(percentiles=10) >>> cold_days = tg10p(tas, tas_per) """ @@ -1449,7 +1449,7 @@ def tn90p( -------- >>> from xclim.core.calendar import percentile_doy >>> from xclim.indices import tn90p - >>> tas = xr.open_dataset(path_to_tas_file).tas + >>> tas = open_dataset(path_to_tas_file).tas >>> tas_per = percentile_doy(tas, per=90).sel(percentiles=90) >>> hot_days = tn90p(tas, tas_per) """ @@ -1507,7 +1507,7 @@ def tn10p( -------- >>> from xclim.core.calendar import percentile_doy >>> from xclim.indices import tn10p - >>> tas = xr.open_dataset(path_to_tas_file).tas + >>> tas = open_dataset(path_to_tas_file).tas >>> tas_per = percentile_doy(tas, per=10).sel(percentiles=10) >>> cold_days = tn10p(tas, tas_per) """ @@ -1565,7 +1565,7 @@ def tx90p( -------- >>> from xclim.core.calendar import percentile_doy >>> from xclim.indices import tx90p - >>> tas = xr.open_dataset(path_to_tas_file).tas + >>> tas = open_dataset(path_to_tas_file).tas >>> tasmax_per = percentile_doy(tas, per=90).sel(percentiles=90) >>> hot_days = tx90p(tas, tasmax_per) """ @@ -1623,7 +1623,7 @@ def tx10p( -------- >>> from xclim.core.calendar import percentile_doy >>> from xclim.indices import tx10p - >>> tas = xr.open_dataset(path_to_tas_file).tas + >>> tas = open_dataset(path_to_tas_file).tas >>> tasmax_per = percentile_doy(tas, per=10).sel(percentiles=10) >>> cold_days = tx10p(tas, tasmax_per) """ @@ -1762,7 +1762,7 @@ def warm_spell_duration_index( >>> from xclim.core.calendar import percentile_doy >>> from xclim.indices import warm_spell_duration_index - >>> tasmax = xr.open_dataset(path_to_tasmax_file).tasmax.isel(lat=0, lon=0) + >>> tasmax = open_dataset(path_to_tasmax_file).tasmax.isel(lat=0, lon=0) >>> tasmax_per = percentile_doy(tasmax, per=90).sel(percentiles=90) >>> warm_spell_duration_index(tasmax, tasmax_per) """ diff --git a/xclim/indices/_simple.py b/xclim/indices/_simple.py index c97d714a4..f93ae5cc4 100644 --- a/xclim/indices/_simple.py +++ b/xclim/indices/_simple.py @@ -103,7 +103,7 @@ def tg_mean(tas: xarray.DataArray, freq: str = "YS") -> xarray.DataArray: at the seasonal frequency, i.e. DJF, MAM, JJA, SON, DJF, etc.: >>> from xclim.indices import tg_mean - >>> t = xr.open_dataset(path_to_tas_file).tas + >>> t = open_dataset(path_to_tas_file).tas >>> tg = tg_mean(t, freq="QS-DEC") """ return select_resample_op(tas, op="mean", freq=freq) @@ -428,7 +428,7 @@ def max_1day_precipitation_amount( The following would compute for each grid cell the highest 1-day total at an annual frequency: >>> from xclim.indices import max_1day_precipitation_amount - >>> pr = xr.open_dataset(path_to_pr_file).pr + >>> pr = open_dataset(path_to_pr_file).pr >>> rx1day = max_1day_precipitation_amount(pr, freq="YS") """ return select_resample_op(pr, op="max", freq=freq) @@ -462,7 +462,7 @@ def max_n_day_precipitation_amount( The following would compute for each grid cell the highest 5-day total precipitation at an annual frequency: >>> from xclim.indices import max_n_day_precipitation_amount - >>> pr = xr.open_dataset(path_to_pr_file).pr + >>> pr = open_dataset(path_to_pr_file).pr >>> out = max_n_day_precipitation_amount(pr, window=5, freq="YS") """ # Rolling sum of the values @@ -499,7 +499,7 @@ def max_pr_intensity( The following would compute the maximum 6-hour precipitation intensity at an annual frequency: >>> from xclim.indices import max_pr_intensity - >>> pr = xr.open_dataset(path_to_pr_file).pr + >>> pr = open_dataset(path_to_pr_file).pr >>> out = max_pr_intensity(pr, window=5, freq="YS") """ # Rolling sum of the values @@ -569,7 +569,7 @@ def sfcWind_max( # noqa: N802 at the seasonal frequency, i.e. DJF, MAM, JJA, SON, DJF, etc.: >>> from xclim.indices import sfcWind_max - >>> fg = xr.open_dataset(path_to_sfcWind_file).sfcWind + >>> fg = open_dataset(path_to_sfcWind_file).sfcWind >>> fg_max = sfcWind_max(fg, freq="QS-DEC") """ return sfcWind.resample(time=freq).max(dim="time").assign_attrs(units=sfcWind.units) @@ -610,7 +610,7 @@ def sfcWind_mean( # noqa: N802 at the seasonal frequency, i.e. DJF, MAM, JJA, SON, DJF, etc.: >>> from xclim.indices import sfcWind_mean - >>> fg = xr.open_dataset(path_to_sfcWind_file).sfcWind + >>> fg = open_dataset(path_to_sfcWind_file).sfcWind >>> fg_mean = sfcWind_mean(fg, freq="QS-DEC") """ return ( @@ -653,7 +653,7 @@ def sfcWind_min( # noqa: N802 at the seasonal frequency, i.e. DJF, MAM, JJA, SON, DJF, etc.: >>> from xclim.indices import sfcWind_min - >>> fg = xr.open_dataset(path_to_sfcWind_file).sfcWind + >>> fg = open_dataset(path_to_sfcWind_file).sfcWind >>> fg_min = sfcWind_min(fg, freq="QS-DEC") """ return sfcWind.resample(time=freq).min(dim="time").assign_attrs(units=sfcWind.units) diff --git a/xclim/indices/_threshold.py b/xclim/indices/_threshold.py index 150c55b04..3916dbc8c 100644 --- a/xclim/indices/_threshold.py +++ b/xclim/indices/_threshold.py @@ -773,7 +773,7 @@ def daily_pr_intensity( precipitation >= 5 mm at seasonal frequency, i.e. DJF, MAM, JJA, SON, DJF, etc.: >>> from xclim.indices import daily_pr_intensity - >>> pr = xr.open_dataset(path_to_pr_file).pr + >>> pr = open_dataset(path_to_pr_file).pr >>> daily_int = daily_pr_intensity(pr, thresh="5 mm/day", freq="QS-DEC") """ t = convert_units_to(thresh, pr, "hydro") @@ -1142,7 +1142,7 @@ def growing_season_length( Examples -------- >>> from xclim.indices import growing_season_length - >>> tas = xr.open_dataset(path_to_tas_file).tas + >>> tas = open_dataset(path_to_tas_file).tas For the Northern Hemisphere: @@ -1228,7 +1228,7 @@ def frost_season_length( Examples -------- >>> from xclim.indices import frost_season_length - >>> tasmin = xr.open_dataset(path_to_tasmin_file).tasmin + >>> tasmin = open_dataset(path_to_tasmin_file).tasmin For the Northern Hemisphere: @@ -1411,7 +1411,7 @@ def frost_free_season_length( Examples -------- >>> from xclim.indices import frost_season_length - >>> tasmin = xr.open_dataset(path_to_tasmin_file).tasmin + >>> tasmin = open_dataset(path_to_tasmin_file).tasmin For the Northern Hemisphere: @@ -2604,7 +2604,7 @@ def wetdays( at the seasonal frequency, i.e. DJF, MAM, JJA, SON, DJF, etc.: >>> from xclim.indices import wetdays - >>> pr = xr.open_dataset(path_to_pr_file).pr + >>> pr = open_dataset(path_to_pr_file).pr >>> wd = wetdays(pr, thresh="5 mm/day", freq="QS-DEC") """ thresh = convert_units_to(thresh, pr, "hydro") @@ -2646,7 +2646,7 @@ def wetdays_prop( 5 mm at the seasonal frequency, i.e. DJF, MAM, JJA, SON, DJF, etc.: >>> from xclim.indices import wetdays_prop - >>> pr = xr.open_dataset(path_to_pr_file).pr + >>> pr = open_dataset(path_to_pr_file).pr >>> wd = wetdays_prop(pr, thresh="5 mm/day", freq="QS-DEC") """ thresh = convert_units_to(thresh, pr, "hydro") @@ -3179,7 +3179,7 @@ def dry_spell_frequency( Examples -------- >>> from xclim.indices import dry_spell_frequency - >>> pr = xr.open_dataset(path_to_pr_file).pr + >>> pr = open_dataset(path_to_pr_file).pr >>> dsf = dry_spell_frequency(pr=pr, op="sum") >>> dsf = dry_spell_frequency(pr=pr, op="max") """ @@ -3372,7 +3372,7 @@ def wet_spell_frequency( Examples -------- >>> from xclim.indices import wet_spell_frequency - >>> pr = xr.open_dataset(path_to_pr_file).pr + >>> pr = open_dataset(path_to_pr_file).pr >>> dsf = wet_spell_frequency(pr=pr, op="sum") >>> dsf = wet_spell_frequency(pr=pr, op="max") """ From b67e51e3c08d4cb6b9e2371e73e5ec5cb498395d Mon Sep 17 00:00:00 2001 From: Zeitsperre <10819524+Zeitsperre@users.noreply.github.com> Date: Mon, 10 Jun 2024 14:11:09 -0400 Subject: [PATCH 6/6] update CHANGES.rst --- CHANGES.rst | 2 ++ 1 file changed, 2 insertions(+) diff --git a/CHANGES.rst b/CHANGES.rst index d13c48519..1b252b8ff 100644 --- a/CHANGES.rst +++ b/CHANGES.rst @@ -15,6 +15,8 @@ Internal changes * Synchronized tooling versions across ``pyproject.toml`` and ``tox.ini`` and pinned them to the latest stable releases in GitHub Workflows. (:pull:`1744`). * Fixed a few small spelling and grammar issues that were causing errors with `codespell`. Now ignoring `SVG` files. (:pull:`1769`). * Temporarily skipping the ``test_hawkins_sutton_smoke`` test due to strange behaviour with `xarray`. (:pull:`1769`). +* Fixed some previously uncaught errors raised from recent versions of `pylint` and `codespell`. (:pull:`1772`). +* Set the `doctest` examples to all use `h5netcdf` with worker-separated caches to load datasets. (:pull:`1772`). v0.49.0 (2024-05-02) --------------------