id,node_id,number,title,user,state,locked,assignee,milestone,comments,created_at,updated_at,closed_at,author_association,active_lock_reason,draft,pull_request,body,reactions,performed_via_github_app,state_reason,repo,type 1320562401,I_kwDOAMm_X85Oti7h,6844,module 'xarray.core' has no attribute 'rolling',4711805,closed,0,,,2,2022-07-28T08:13:41Z,2022-07-28T08:26:13Z,2022-07-28T08:26:12Z,CONTRIBUTOR,,,,"### What happened? There used to be a `xarray.core.rolling`, and the documentation suggests it still [exists](https://docs.xarray.dev/en/v2022.06.0/generated/xarray.core.rolling.DataArrayCoarsen.html#xarray-core-rolling-dataarraycoarsen), but with `xarray-2022.6.0` I get: module `xarray.core` has no attribute `rolling`. It works with `xarray-2022.3.0`. ### What did you expect to happen? Shouldn't we be able to access `xarray.core.rolling`? ### Minimal Complete Verifiable Example ```Python import xarray as xr xr.core.rolling # Traceback (most recent call last): # File """", line 1, in # AttributeError: module 'xarray.core' has no attribute 'rolling' ``` ### MVCE confirmation - [X] Minimal example — the example is as focused as reasonably possible to demonstrate the underlying issue in xarray. - [X] Complete example — the example is self-contained, including all data and the text of any traceback. - [X] Verifiable example — the example copy & pastes into an IPython prompt or [Binder notebook](https://mybinder.org/v2/gh/pydata/xarray/main?urlpath=lab/tree/doc/examples/blank_template.ipynb), returning the result. - [X] New issue — a search of GitHub Issues suggests this is not a duplicate. ### Relevant log output _No response_ ### Anything else we need to know? _No response_ ### Environment
/home/david/mambaforge/envs/xarray_leaflet/lib/python3.10/site-packages/_distutils_hack/__init__.py:33: UserWarning: Setuptools is replacing distutils. warnings.warn(""Setuptools is replacing distutils."") INSTALLED VERSIONS ------------------ commit: None python: 3.10.5 | packaged by conda-forge | (main, Jun 14 2022, 07:06:46) [GCC 10.3.0] python-bits: 64 OS: Linux OS-release: 5.15.0-41-generic machine: x86_64 processor: x86_64 byteorder: little LC_ALL: None LANG: en_US.UTF-8 LOCALE: ('en_US', 'UTF-8') libhdf5: None libnetcdf: None xarray: 2022.6.0 pandas: 1.4.3 numpy: 1.23.1 scipy: None netCDF4: None pydap: None h5netcdf: None h5py: None Nio: None zarr: None cftime: None nc_time_axis: None PseudoNetCDF: None rasterio: 1.3.0 cfgrib: None iris: None bottleneck: None dask: 2022.7.1 distributed: None matplotlib: 3.5.2 cartopy: None seaborn: None numbagg: None fsspec: 2022.7.0 cupy: None pint: None sparse: None flox: None numpy_groupies: None setuptools: 63.2.0 pip: 22.2.1 conda: None pytest: None IPython: 8.4.0 sphinx: None
","{""url"": ""https://api.github.com/repos/pydata/xarray/issues/6844/reactions"", ""total_count"": 0, ""+1"": 0, ""-1"": 0, ""laugh"": 0, ""hooray"": 0, ""confused"": 0, ""heart"": 0, ""rocket"": 0, ""eyes"": 0}",,completed,13221727,issue 636480145,MDU6SXNzdWU2MzY0ODAxNDU=,4141,xarray.where() drops attributes,4711805,closed,0,,,3,2020-06-10T19:06:32Z,2022-01-19T19:35:41Z,2022-01-19T19:35:41Z,CONTRIBUTOR,,,," #### MCVE Code Sample ```python import xarray as xr da = xr.DataArray(1) da.attrs['foo'] = 'bar' xr.where(da==0, -1, da).attrs # shows: {} ``` #### Expected Output `{'foo': 'bar'}` #### Problem Description I would expect the attributes to remain in the data array. #### Versions
Output of xr.show_versions() INSTALLED VERSIONS ------------------ commit: None python: 3.8.2 | packaged by conda-forge | (default, Apr 24 2020, 08:20:52) [GCC 7.3.0] python-bits: 64 OS: Linux OS-release: 5.4.0-33-generic machine: x86_64 processor: x86_64 byteorder: little LC_ALL: None LANG: en_US.UTF-8 LOCALE: en_US.UTF-8 libhdf5: None libnetcdf: None xarray: 0.15.1 pandas: 1.0.4 numpy: 1.18.4 scipy: 1.4.1 netCDF4: None pydap: None h5netcdf: None h5py: None Nio: None zarr: None cftime: None nc_time_axis: None PseudoNetCDF: None rasterio: 1.1.4 cfgrib: None iris: None bottleneck: None dask: 2.16.0 distributed: None matplotlib: 3.2.1 cartopy: None seaborn: None numbagg: None setuptools: 46.2.0 pip: 20.1 conda: None pytest: None IPython: 7.14.0 sphinx: 3.0.4
","{""url"": ""https://api.github.com/repos/pydata/xarray/issues/4141/reactions"", ""total_count"": 0, ""+1"": 0, ""-1"": 0, ""laugh"": 0, ""hooray"": 0, ""confused"": 0, ""heart"": 0, ""rocket"": 0, ""eyes"": 0}",,completed,13221727,issue 393742068,MDU6SXNzdWUzOTM3NDIwNjg=,2628,Empty plot with pcolormesh in the notebook,4711805,closed,0,,,3,2018-12-23T11:21:48Z,2020-12-05T05:06:36Z,2020-12-05T05:06:36Z,CONTRIBUTOR,,,,"#### Code Sample ```python import numpy as np import xarray as xr import matplotlib.pyplot as plt %matplotlib inline a = np.ones((4000, 4000), dtype=np.uint8) a[:1000, :1000] = 0 lat = np.array([0-i for i in range(a.shape[0])]) lon = np.array([0+i for i in range(a.shape[1])]) da = xr.DataArray(a, coords=[lat, lon], dims=['lat', 'lon']) da.plot.pcolormesh() ``` #### Problem description The code above shows an empty plot **in a notebook** (but not in the console). #### Expected Output If I replace `da.plot.pcolormesh()` with `da.plot.imshow()` or `plt.pcolormesh(a)`, it works fine. Also, if I decrease the size of the array, it works. #### Output of ``xr.show_versions()``
INSTALLED VERSIONS ------------------ commit: None python: 3.6.6.final.0 python-bits: 64 OS: Linux OS-release: 4.10.0-42-generic machine: x86_64 processor: x86_64 byteorder: little LC_ALL: None LANG: en_US.UTF-8 LOCALE: en_US.UTF-8 xarray: 0.10.7 pandas: 0.23.4 numpy: 1.15.4 scipy: 1.1.0 netCDF4: 1.4.1 h5netcdf: 0.6.2 h5py: 2.8.0 Nio: 1.5.4 zarr: 2.2.0 bottleneck: 1.2.1 cyordereddict: None dask: 0.20.2 distributed: 1.24.2 matplotlib: 3.0.2 cartopy: None seaborn: None setuptools: 40.6.2 pip: 18.1 conda: 4.5.12 pytest: None IPython: 7.1.1 sphinx: None
","{""url"": ""https://api.github.com/repos/pydata/xarray/issues/2628/reactions"", ""total_count"": 0, ""+1"": 0, ""-1"": 0, ""laugh"": 0, ""hooray"": 0, ""confused"": 0, ""heart"": 0, ""rocket"": 0, ""eyes"": 0}",,completed,13221727,issue 736092268,MDExOlB1bGxSZXF1ZXN0NTE1MzY2NzA3,4564,Add xtrude project to documentation,4711805,closed,0,,,1,2020-11-04T12:54:20Z,2020-11-04T16:00:34Z,2020-11-04T15:57:11Z,CONTRIBUTOR,,0,pydata/xarray/pulls/4564,,"{""url"": ""https://api.github.com/repos/pydata/xarray/issues/4564/reactions"", ""total_count"": 0, ""+1"": 0, ""-1"": 0, ""laugh"": 0, ""hooray"": 0, ""confused"": 0, ""heart"": 0, ""rocket"": 0, ""eyes"": 0}",,,13221727,pull 649683292,MDExOlB1bGxSZXF1ZXN0NDQzMzEzNDMz,4192,Fix typo,4711805,closed,0,,,1,2020-07-02T06:51:56Z,2020-07-02T12:15:07Z,2020-07-02T12:09:38Z,CONTRIBUTOR,,0,pydata/xarray/pulls/4192,,"{""url"": ""https://api.github.com/repos/pydata/xarray/issues/4192/reactions"", ""total_count"": 0, ""+1"": 0, ""-1"": 0, ""laugh"": 0, ""hooray"": 0, ""confused"": 0, ""heart"": 0, ""rocket"": 0, ""eyes"": 0}",,,13221727,pull 615837634,MDExOlB1bGxSZXF1ZXN0NDE2MDY2MTEz,4051,Add xarray-leaflet to the visualization projects,4711805,closed,0,,,3,2020-05-11T12:13:53Z,2020-05-11T20:01:30Z,2020-05-11T14:54:28Z,CONTRIBUTOR,,0,pydata/xarray/pulls/4051,,"{""url"": ""https://api.github.com/repos/pydata/xarray/issues/4051/reactions"", ""total_count"": 0, ""+1"": 0, ""-1"": 0, ""laugh"": 0, ""hooray"": 0, ""confused"": 0, ""heart"": 0, ""rocket"": 0, ""eyes"": 0}",,,13221727,pull 395384938,MDU6SXNzdWUzOTUzODQ5Mzg=,2644,DataArray concat with tolerance,4711805,closed,0,,,3,2019-01-02T21:23:21Z,2019-08-15T15:15:26Z,2019-08-15T15:15:26Z,CONTRIBUTOR,,,,"I would like to concatenate many `DataArray` whose dimension coordinates are almost aligned, allowing for some offset in the coordinates: ```python import xarray as xr da1 = xr.DataArray([[0, 1], [2, 3]], coords=[[0, 1], [0, 1]], dims=['x', 'y']) da2 = xr.DataArray([[4, 5], [6, 7]], coords=[[1.1, 2.1], [1.1, 2.1]], dims=['x', 'y']) da = xr.concat([da1, da2], 'z', method='nearest', tolerance=0.2) # doesn't exist yet da ``` And I would get: ``` array([[[ 0., 1., nan], [ 2., 3., nan], [nan, nan, nan]], [[nan, nan, nan], [nan, 4., 5.], [nan, 6., 7.]]]) Coordinates: * x (x) float64 0 1 2.1 * y (y) float64 0 1 2.1 Dimensions without coordinates: z ``` @jhamman suggested to use `reindex_like` in this [StackOverflow question](https://stackoverflow.com/questions/54007495/concatenating-dataarray-with-tolerance-in-xarray/54010432#54010432), but it doesn't produce the union of coordinates, so I cannot chain them like this: ```python da2 = da2.reindex_like(da1, method='nearest', tolerance=0.2) ``` Is there another work around? Do you think it would be worth having this feature in `concat`?","{""url"": ""https://api.github.com/repos/pydata/xarray/issues/2644/reactions"", ""total_count"": 1, ""+1"": 1, ""-1"": 0, ""laugh"": 0, ""hooray"": 0, ""confused"": 0, ""heart"": 0, ""rocket"": 0, ""eyes"": 0}",,completed,13221727,issue 467805570,MDExOlB1bGxSZXF1ZXN0Mjk3Mzc0NDIw,3123,to_zarr(append_dim='dim0') doesn't need mode='a',4711805,closed,0,,,4,2019-07-14T07:36:11Z,2019-07-29T18:49:12Z,2019-07-29T15:54:45Z,CONTRIBUTOR,,0,pydata/xarray/pulls/3123," - [x] Closes #3100 - [x] Tests updated - [x] Fully documented, including `whats-new.rst` for all changes and `api.rst` for new API ","{""url"": ""https://api.github.com/repos/pydata/xarray/issues/3123/reactions"", ""total_count"": 0, ""+1"": 0, ""-1"": 0, ""laugh"": 0, ""hooray"": 0, ""confused"": 0, ""heart"": 0, ""rocket"": 0, ""eyes"": 0}",,,13221727,pull 467338176,MDU6SXNzdWU0NjczMzgxNzY=,3100,Append to zarr redundant with mode='a',4711805,closed,0,,,3,2019-07-12T10:21:04Z,2019-07-29T15:54:45Z,2019-07-29T15:54:45Z,CONTRIBUTOR,,,,"When appending to a zarr store, we need to set `append_dim=dim_name` but also `mode='a'`. Any reason to also specify the writing mode? I think it should automatically be set to `'a'` if `append_dim is not None`.","{""url"": ""https://api.github.com/repos/pydata/xarray/issues/3100/reactions"", ""total_count"": 0, ""+1"": 0, ""-1"": 0, ""laugh"": 0, ""hooray"": 0, ""confused"": 0, ""heart"": 0, ""rocket"": 0, ""eyes"": 0}",,completed,13221727,issue 385155383,MDExOlB1bGxSZXF1ZXN0MjM0MTg4NTUx,2578,Fix typo,4711805,closed,0,,,1,2018-11-28T08:34:40Z,2019-07-14T07:25:01Z,2018-11-28T19:26:55Z,CONTRIBUTOR,,0,pydata/xarray/pulls/2578,,"{""url"": ""https://api.github.com/repos/pydata/xarray/issues/2578/reactions"", ""total_count"": 0, ""+1"": 0, ""-1"": 0, ""laugh"": 0, ""hooray"": 0, ""confused"": 0, ""heart"": 0, ""rocket"": 0, ""eyes"": 0}",,,13221727,pull 463430234,MDExOlB1bGxSZXF1ZXN0MjkzOTExNDgw,3076,Fix error message,4711805,closed,0,,,1,2019-07-02T20:52:11Z,2019-07-14T07:24:50Z,2019-07-02T21:27:41Z,CONTRIBUTOR,,0,pydata/xarray/pulls/3076,"`rechunk` is not a methode of DataArray or Dataset, `chunk` does rechunk.","{""url"": ""https://api.github.com/repos/pydata/xarray/issues/3076/reactions"", ""total_count"": 0, ""+1"": 0, ""-1"": 0, ""laugh"": 0, ""hooray"": 0, ""confused"": 0, ""heart"": 0, ""rocket"": 0, ""eyes"": 0}",,,13221727,pull 467267153,MDU6SXNzdWU0NjcyNjcxNTM=,3099,Interpolation doesn't apply on time coordinate,4711805,closed,0,,,1,2019-07-12T07:37:18Z,2019-07-13T15:05:39Z,2019-07-13T15:05:39Z,CONTRIBUTOR,,,,"#### MCVE Code Sample ```python In [1]: import numpy as np ...: import pandas as pd ...: import xarray as xr In [2]: da = xr.DataArray([1, 2], [('time', pd.date_range('2000-01-01', '2000-01-02', periods=2))]) ...: da Out[2]: array([1, 2]) Coordinates: * time (time) datetime64[ns] 2000-01-01 2000-01-02 In [3]: da.interp(time=da.time-np.timedelta64(1, 'D')) Out[3]: array([nan, 1.]) Coordinates: * time (time) datetime64[ns] 2000-01-01 2000-01-02 ``` #### Problem Description The data has been interpolated, but not the time coordinate. #### Expected Output When we explicitly get the values of the time coordinate, it works fine: ```python In [4]: da.interp(time=da.time.values-np.timedelta64(1, 'D')) Out[4]: array([nan, 1.]) Coordinates: * time (time) datetime64[ns] 1999-12-31 2000-01-01 ``` #### Output of ``xr.show_versions()``
INSTALLED VERSIONS ------------------ commit: None python: 3.7.3 (default, Mar 27 2019, 22:11:17) [GCC 7.3.0] python-bits: 64 OS: Linux OS-release: 4.10.0-42-generic machine: x86_64 processor: x86_64 byteorder: little LC_ALL: None LANG: en_US.UTF-8 LOCALE: en_US.UTF-8 libhdf5: None libnetcdf: None xarray: 0.12.2 pandas: 0.24.2 numpy: 1.16.4 scipy: 1.2.1 netCDF4: None pydap: None h5netcdf: None h5py: None Nio: None zarr: 2.3.2 cftime: None nc_time_axis: None PseudonetCDF: None rasterio: None cfgrib: None iris: None bottleneck: None dask: 2.0.0 distributed: 2.0.1 matplotlib: 3.1.0 cartopy: None seaborn: None numbagg: None setuptools: 41.0.0 pip: 19.0.3 conda: 4.7.5 pytest: None IPython: 7.7.0.dev sphinx: None
","{""url"": ""https://api.github.com/repos/pydata/xarray/issues/3099/reactions"", ""total_count"": 0, ""+1"": 0, ""-1"": 0, ""laugh"": 0, ""hooray"": 0, ""confused"": 0, ""heart"": 0, ""rocket"": 0, ""eyes"": 0}",,completed,13221727,issue 463928027,MDU6SXNzdWU0NjM5MjgwMjc=,3078,Auto-generated API documentation,4711805,closed,0,,,2,2019-07-03T19:57:51Z,2019-07-03T20:02:11Z,2019-07-03T20:00:35Z,CONTRIBUTOR,,,,"For instance in http://xarray.pydata.org/en/stable/generated/xarray.apply_ufunc.html, there is no space between the parameters and their type description, e.g. `funccallable` instead of `func : callable`.","{""url"": ""https://api.github.com/repos/pydata/xarray/issues/3078/reactions"", ""total_count"": 0, ""+1"": 0, ""-1"": 0, ""laugh"": 0, ""hooray"": 0, ""confused"": 0, ""heart"": 0, ""rocket"": 0, ""eyes"": 0}",,completed,13221727,issue