{"diffoscope-json-version": 1, "source1": "/srv/reproducible-results/rbuild-debian/r-b-build.7Ww0J1yU/b1/python-xarray_2025.01.2-1_amd64.changes", "source2": "/srv/reproducible-results/rbuild-debian/r-b-build.7Ww0J1yU/b2/python-xarray_2025.01.2-1_amd64.changes", "unified_diff": null, "details": [{"source1": "Files", "source2": "Files", "unified_diff": "@@ -1,3 +1,3 @@\n \n- 0498ec7f50853bbeffc8d052b694ab7f 2751776 doc optional python-xarray-doc_2025.01.2-1_all.deb\n+ c3c727b28c2d2ac9cfbdf090b7f86954 2751900 doc optional python-xarray-doc_2025.01.2-1_all.deb\n 4644c3352e568f782718f7d018211ae7 799852 python optional python3-xarray_2025.01.2-1_all.deb\n"}, {"source1": "python-xarray-doc_2025.01.2-1_all.deb", "source2": "python-xarray-doc_2025.01.2-1_all.deb", "unified_diff": null, "details": [{"source1": "file list", "source2": "file list", "unified_diff": "@@ -1,3 +1,3 @@\n -rw-r--r-- 0 0 0 4 2025-02-02 11:36:57.000000 debian-binary\n--rw-r--r-- 0 0 0 6364 2025-02-02 11:36:57.000000 control.tar.xz\n--rw-r--r-- 0 0 0 2745220 2025-02-02 11:36:57.000000 data.tar.xz\n+-rw-r--r-- 0 0 0 6368 2025-02-02 11:36:57.000000 control.tar.xz\n+-rw-r--r-- 0 0 0 2745340 2025-02-02 11:36:57.000000 data.tar.xz\n"}, {"source1": "control.tar.xz", "source2": "control.tar.xz", "unified_diff": null, "details": [{"source1": "control.tar", "source2": "control.tar", "unified_diff": null, "details": [{"source1": "./control", "source2": "./control", "unified_diff": "@@ -1,13 +1,13 @@\n Package: python-xarray-doc\n Source: python-xarray\n Version: 2025.01.2-1\n Architecture: all\n Maintainer: Debian Science Maintainers \n-Installed-Size: 8991\n+Installed-Size: 8992\n Depends: libjs-sphinxdoc (>= 8.1), libjs-mathjax, libjs-requirejs\n Built-Using: alabaster (= 0.7.16-0.1), sphinx (= 8.1.3-5)\n Section: doc\n Priority: optional\n Multi-Arch: foreign\n Homepage: https://xarray.pydata.org/\n Description: documentation for xarray\n"}, {"source1": "./md5sums", "source2": "./md5sums", "unified_diff": null, "details": [{"source1": "./md5sums", "source2": "./md5sums", "comments": ["Files differ"], "unified_diff": null}]}]}]}, {"source1": "data.tar.xz", "source2": "data.tar.xz", "unified_diff": null, "details": [{"source1": "data.tar", "source2": "data.tar", "unified_diff": null, "details": [{"source1": "file list", "source2": "file list", "unified_diff": "@@ -160,32 +160,32 @@\n -rw-r--r-- 0 root (0) root (0) 101581 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/contributing.html\n -rw-r--r-- 0 root (0) root (0) 461 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/dask.html\n -rw-r--r-- 0 root (0) root (0) 494 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/data-structures.html\n -rw-r--r-- 0 root (0) root (0) 8448 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/developers-meeting.html\n -rw-r--r-- 0 root (0) root (0) 479 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/duckarrays.html\n -rw-r--r-- 0 root (0) root (0) 22666 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/ecosystem.html\n drwxr-xr-x 0 root (0) root (0) 0 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/examples/\n--rw-r--r-- 0 root (0) root (0) 151021 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/examples/ERA5-GRIB-example.html\n--rw-r--r-- 0 root (0) root (0) 10281 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/examples/ERA5-GRIB-example.ipynb.gz\n--rw-r--r-- 0 root (0) root (0) 51050 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/examples/ROMS_ocean_model.html\n--rw-r--r-- 0 root (0) root (0) 24967 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/examples/ROMS_ocean_model.ipynb.gz\n--rw-r--r-- 0 root (0) root (0) 134137 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/examples/apply_ufunc_vectorize_1d.html\n--rw-r--r-- 0 root (0) root (0) 10477 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/examples/apply_ufunc_vectorize_1d.ipynb.gz\n--rw-r--r-- 0 root (0) root (0) 42089 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/examples/area_weighted_temperature.html\n--rw-r--r-- 0 root (0) root (0) 22654 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/examples/area_weighted_temperature.ipynb.gz\n--rw-r--r-- 0 root (0) root (0) 27905 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/examples/blank_template.html\n+-rw-r--r-- 0 root (0) root (0) 151036 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/examples/ERA5-GRIB-example.html\n+-rw-r--r-- 0 root (0) root (0) 10287 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/examples/ERA5-GRIB-example.ipynb.gz\n+-rw-r--r-- 0 root (0) root (0) 51051 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/examples/ROMS_ocean_model.html\n+-rw-r--r-- 0 root (0) root (0) 24994 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/examples/ROMS_ocean_model.ipynb.gz\n+-rw-r--r-- 0 root (0) root (0) 134138 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/examples/apply_ufunc_vectorize_1d.html\n+-rw-r--r-- 0 root (0) root (0) 10511 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/examples/apply_ufunc_vectorize_1d.ipynb.gz\n+-rw-r--r-- 0 root (0) root (0) 42090 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/examples/area_weighted_temperature.html\n+-rw-r--r-- 0 root (0) root (0) 22670 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/examples/area_weighted_temperature.ipynb.gz\n+-rw-r--r-- 0 root (0) root (0) 27906 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/examples/blank_template.html\n -rw-r--r-- 0 root (0) root (0) 2568 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/examples/blank_template.ipynb.gz\n--rw-r--r-- 0 root (0) root (0) 50959 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/examples/monthly-means.html\n--rw-r--r-- 0 root (0) root (0) 4540 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/examples/monthly-means.ipynb.gz\n--rw-r--r-- 0 root (0) root (0) 43740 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/examples/multidimensional-coords.html\n--rw-r--r-- 0 root (0) root (0) 12221 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/examples/multidimensional-coords.ipynb.gz\n--rw-r--r-- 0 root (0) root (0) 50844 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/examples/visualization_gallery.html\n--rw-r--r-- 0 root (0) root (0) 4373 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/examples/visualization_gallery.ipynb.gz\n+-rw-r--r-- 0 root (0) root (0) 50960 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/examples/monthly-means.html\n+-rw-r--r-- 0 root (0) root (0) 4568 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/examples/monthly-means.ipynb.gz\n+-rw-r--r-- 0 root (0) root (0) 43741 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/examples/multidimensional-coords.html\n+-rw-r--r-- 0 root (0) root (0) 12239 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/examples/multidimensional-coords.ipynb.gz\n+-rw-r--r-- 0 root (0) root (0) 50845 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/examples/visualization_gallery.html\n+-rw-r--r-- 0 root (0) root (0) 4396 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/examples/visualization_gallery.ipynb.gz\n -rw-r--r-- 0 root (0) root (0) 87944 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/examples/weather-data.html\n--rw-r--r-- 0 root (0) root (0) 367986 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/examples/weather-data.ipynb.gz\n+-rw-r--r-- 0 root (0) root (0) 368004 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/examples/weather-data.ipynb.gz\n -rw-r--r-- 0 root (0) root (0) 491 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/faq.html\n -rw-r--r-- 0 root (0) root (0) 15073 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/gallery.html\n -rw-r--r-- 0 root (0) root (0) 16306 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/genindex.html\n drwxr-xr-x 0 root (0) root (0) 0 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/getting-started-guide/\n -rw-r--r-- 0 root (0) root (0) 50398 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/getting-started-guide/faq.html\n -rw-r--r-- 0 root (0) root (0) 7741 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/getting-started-guide/index.html\n -rw-r--r-- 0 root (0) root (0) 23857 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/getting-started-guide/installing.html\n@@ -200,50 +200,50 @@\n drwxr-xr-x 0 root (0) root (0) 0 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/internals/\n -rw-r--r-- 0 root (0) root (0) 81178 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/internals/chunked-arrays.html\n -rw-r--r-- 0 root (0) root (0) 19678 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/internals/duck-arrays-integration.html\n -rw-r--r-- 0 root (0) root (0) 22842 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/internals/extending-xarray.html\n -rw-r--r-- 0 root (0) root (0) 53506 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/internals/how-to-add-new-backend.html\n -rw-r--r-- 0 root (0) root (0) 30758 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/internals/how-to-create-custom-index.html\n -rw-r--r-- 0 root (0) root (0) 9035 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/internals/index.html\n--rw-r--r-- 0 root (0) root (0) 60255 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/internals/internal-design.html\n+-rw-r--r-- 0 root (0) root (0) 60257 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/internals/internal-design.html\n -rw-r--r-- 0 root (0) root (0) 13589 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/internals/interoperability.html\n--rw-r--r-- 0 root (0) root (0) 27075 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/internals/zarr-encoding-spec.html\n+-rw-r--r-- 0 root (0) root (0) 27076 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/internals/zarr-encoding-spec.html\n -rw-r--r-- 0 root (0) root (0) 488 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/interpolation.html\n -rw-r--r-- 0 root (0) root (0) 455 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/io.html\n -rw-r--r-- 0 root (0) root (0) 22249 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/objects.inv\n -rw-r--r-- 0 root (0) root (0) 467 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/pandas.html\n -rw-r--r-- 0 root (0) root (0) 473 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/plotting.html\n -rw-r--r-- 0 root (0) root (0) 6546 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/py-modindex.html\n -rw-r--r-- 0 root (0) root (0) 524 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/quick-overview.html\n -rw-r--r-- 0 root (0) root (0) 443 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/related-projects.html\n -rw-r--r-- 0 root (0) root (0) 476 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/reshaping.html\n -rw-r--r-- 0 root (0) root (0) 24474 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/roadmap.html\n -rw-r--r-- 0 root (0) root (0) 6341 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/search.html\n--rw-r--r-- 0 root (0) root (0) 250422 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/searchindex.js\n+-rw-r--r-- 0 root (0) root (0) 250520 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/searchindex.js\n -rw-r--r-- 0 root (0) root (0) 482 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/terminology.html\n -rw-r--r-- 0 root (0) root (0) 482 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/time-series.html\n -rw-r--r-- 0 root (0) root (0) 13358 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/tutorials-and-videos.html\n drwxr-xr-x 0 root (0) root (0) 0 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/user-guide/\n -rw-r--r-- 0 root (0) root (0) 58676 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/user-guide/combining.html\n -rw-r--r-- 0 root (0) root (0) 140284 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/user-guide/computation.html\n -rw-r--r-- 0 root (0) root (0) 71358 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/user-guide/dask.html\n -rw-r--r-- 0 root (0) root (0) 150185 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/user-guide/data-structures.html\n -rw-r--r-- 0 root (0) root (0) 35119 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/user-guide/duckarrays.html\n -rw-r--r-- 0 root (0) root (0) 50924 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/user-guide/groupby.html\n--rw-r--r-- 0 root (0) root (0) 120196 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/user-guide/hierarchical-data.html\n+-rw-r--r-- 0 root (0) root (0) 120197 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/user-guide/hierarchical-data.html\n -rw-r--r-- 0 root (0) root (0) 9025 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/user-guide/index.html\n--rw-r--r-- 0 root (0) root (0) 140275 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/user-guide/indexing.html\n--rw-r--r-- 0 root (0) root (0) 68719 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/user-guide/interpolation.html\n--rw-r--r-- 0 root (0) root (0) 144483 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/user-guide/io.html\n+-rw-r--r-- 0 root (0) root (0) 140278 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/user-guide/indexing.html\n+-rw-r--r-- 0 root (0) root (0) 68720 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/user-guide/interpolation.html\n+-rw-r--r-- 0 root (0) root (0) 144485 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/user-guide/io.html\n -rw-r--r-- 0 root (0) root (0) 11704 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/user-guide/options.html\n -rw-r--r-- 0 root (0) root (0) 42224 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/user-guide/pandas.html\n--rw-r--r-- 0 root (0) root (0) 136281 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/user-guide/plotting.html\n--rw-r--r-- 0 root (0) root (0) 62916 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/user-guide/reshaping.html\n+-rw-r--r-- 0 root (0) root (0) 136283 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/user-guide/plotting.html\n+-rw-r--r-- 0 root (0) root (0) 62917 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/user-guide/reshaping.html\n -rw-r--r-- 0 root (0) root (0) 46815 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/user-guide/terminology.html\n--rw-r--r-- 0 root (0) root (0) 47383 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/user-guide/testing.html\n+-rw-r--r-- 0 root (0) root (0) 48185 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/user-guide/testing.html\n -rw-r--r-- 0 root (0) root (0) 45787 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/user-guide/time-series.html\n -rw-r--r-- 0 root (0) root (0) 45368 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/user-guide/weather-climate.html\n -rw-r--r-- 0 root (0) root (0) 494 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/weather-climate.html\n -rw-r--r-- 0 root (0) root (0) 1017523 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/whats-new.html\n -rw-r--r-- 0 root (0) root (0) 512 2025-02-02 11:36:57.000000 ./usr/share/doc/python-xarray-doc/html/why-xarray.html\n drwxr-xr-x 0 root (0) root (0) 0 2025-02-02 11:36:57.000000 ./usr/share/doc-base/\n -rw-r--r-- 0 root (0) root (0) 290 2025-02-02 11:36:57.000000 ./usr/share/doc-base/python-xarray-doc.python-xarray-doc\n"}, {"source1": "./usr/share/doc/python-xarray-doc/html/examples/ERA5-GRIB-example.html", "source2": "./usr/share/doc/python-xarray-doc/html/examples/ERA5-GRIB-example.html", "unified_diff": "@@ -170,15 +170,15 @@\n File /usr/lib/python3/dist-packages/pooch/utils.py:276, in make_local_storage(path, env)\n 272 if env is not None:\n 273 message.append(\n 274 f"Use environment variable '{env}' to specify a different location."\n 275 )\n --> 276 raise PermissionError(" ".join(message)) from error\n \n-PermissionError: [Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/first-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\n+PermissionError: [Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/second-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\n \n \n

Let\u2019s create a simple plot of 2-m air temperature in degrees Celsius:

\n
\n
[3]:\n 
\n
\n@@ -238,90 +238,90 @@\n
\n \n
\n
\n
\n
\n
\n-Error in callback <function _draw_all_if_interactive at 0x7f0d1cd74fe0> (for post_execute), with arguments args (),kwargs {}:\n+Error in callback <function _draw_all_if_interactive at 0x7f3fcd2ecfe0> (for post_execute), with arguments args (),kwargs {}:\n 
\n
\n
\n
\n
\n
\n
\n ---------------------------------------------------------------------------\n FileNotFoundError                         Traceback (most recent call last)\n File /usr/lib/python3.13/pathlib/_local.py:724, in Path.mkdir(self, mode, parents, exist_ok)\n     723 try:\n --> 724     os.mkdir(self, mode)\n     725 except FileNotFoundError:\n \n-FileNotFoundError: [Errno 2] No such file or directory: '/nonexistent/first-build/.local/share/cartopy/shapefiles/natural_earth/physical'\n+FileNotFoundError: [Errno 2] No such file or directory: '/nonexistent/second-build/.local/share/cartopy/shapefiles/natural_earth/physical'\n \n During handling of the above exception, another exception occurred:\n \n FileNotFoundError                         Traceback (most recent call last)\n File /usr/lib/python3.13/pathlib/_local.py:724, in Path.mkdir(self, mode, parents, exist_ok)\n     723 try:\n --> 724     os.mkdir(self, mode)\n     725 except FileNotFoundError:\n \n-FileNotFoundError: [Errno 2] No such file or directory: '/nonexistent/first-build/.local/share/cartopy/shapefiles/natural_earth'\n+FileNotFoundError: [Errno 2] No such file or directory: '/nonexistent/second-build/.local/share/cartopy/shapefiles/natural_earth'\n \n During handling of the above exception, another exception occurred:\n \n FileNotFoundError                         Traceback (most recent call last)\n File /usr/lib/python3.13/pathlib/_local.py:724, in Path.mkdir(self, mode, parents, exist_ok)\n     723 try:\n --> 724     os.mkdir(self, mode)\n     725 except FileNotFoundError:\n \n-FileNotFoundError: [Errno 2] No such file or directory: '/nonexistent/first-build/.local/share/cartopy/shapefiles'\n+FileNotFoundError: [Errno 2] No such file or directory: '/nonexistent/second-build/.local/share/cartopy/shapefiles'\n \n During handling of the above exception, another exception occurred:\n \n FileNotFoundError                         Traceback (most recent call last)\n File /usr/lib/python3.13/pathlib/_local.py:724, in Path.mkdir(self, mode, parents, exist_ok)\n     723 try:\n --> 724     os.mkdir(self, mode)\n     725 except FileNotFoundError:\n \n-FileNotFoundError: [Errno 2] No such file or directory: '/nonexistent/first-build/.local/share/cartopy'\n+FileNotFoundError: [Errno 2] No such file or directory: '/nonexistent/second-build/.local/share/cartopy'\n \n During handling of the above exception, another exception occurred:\n \n FileNotFoundError                         Traceback (most recent call last)\n File /usr/lib/python3.13/pathlib/_local.py:724, in Path.mkdir(self, mode, parents, exist_ok)\n     723 try:\n --> 724     os.mkdir(self, mode)\n     725 except FileNotFoundError:\n \n-FileNotFoundError: [Errno 2] No such file or directory: '/nonexistent/first-build/.local/share'\n+FileNotFoundError: [Errno 2] No such file or directory: '/nonexistent/second-build/.local/share'\n \n During handling of the above exception, another exception occurred:\n \n FileNotFoundError                         Traceback (most recent call last)\n File /usr/lib/python3.13/pathlib/_local.py:724, in Path.mkdir(self, mode, parents, exist_ok)\n     723 try:\n --> 724     os.mkdir(self, mode)\n     725 except FileNotFoundError:\n \n-FileNotFoundError: [Errno 2] No such file or directory: '/nonexistent/first-build/.local'\n+FileNotFoundError: [Errno 2] No such file or directory: '/nonexistent/second-build/.local'\n \n During handling of the above exception, another exception occurred:\n \n FileNotFoundError                         Traceback (most recent call last)\n File /usr/lib/python3.13/pathlib/_local.py:724, in Path.mkdir(self, mode, parents, exist_ok)\n     723 try:\n --> 724     os.mkdir(self, mode)\n     725 except FileNotFoundError:\n \n-FileNotFoundError: [Errno 2] No such file or directory: '/nonexistent/first-build'\n+FileNotFoundError: [Errno 2] No such file or directory: '/nonexistent/second-build'\n \n During handling of the above exception, another exception occurred:\n \n PermissionError                           Traceback (most recent call last)\n File /usr/lib/python3/dist-packages/matplotlib/pyplot.py:197, in _draw_all_if_interactive()\n     195 def _draw_all_if_interactive() -> None:\n     196     if matplotlib.is_interactive():\n@@ -530,75 +530,75 @@\n ---------------------------------------------------------------------------\n FileNotFoundError                         Traceback (most recent call last)\n File /usr/lib/python3.13/pathlib/_local.py:724, in Path.mkdir(self, mode, parents, exist_ok)\n     723 try:\n --> 724     os.mkdir(self, mode)\n     725 except FileNotFoundError:\n \n-FileNotFoundError: [Errno 2] No such file or directory: '/nonexistent/first-build/.local/share/cartopy/shapefiles/natural_earth/physical'\n+FileNotFoundError: [Errno 2] No such file or directory: '/nonexistent/second-build/.local/share/cartopy/shapefiles/natural_earth/physical'\n \n During handling of the above exception, another exception occurred:\n \n FileNotFoundError                         Traceback (most recent call last)\n File /usr/lib/python3.13/pathlib/_local.py:724, in Path.mkdir(self, mode, parents, exist_ok)\n     723 try:\n --> 724     os.mkdir(self, mode)\n     725 except FileNotFoundError:\n \n-FileNotFoundError: [Errno 2] No such file or directory: '/nonexistent/first-build/.local/share/cartopy/shapefiles/natural_earth'\n+FileNotFoundError: [Errno 2] No such file or directory: '/nonexistent/second-build/.local/share/cartopy/shapefiles/natural_earth'\n \n During handling of the above exception, another exception occurred:\n \n FileNotFoundError                         Traceback (most recent call last)\n File /usr/lib/python3.13/pathlib/_local.py:724, in Path.mkdir(self, mode, parents, exist_ok)\n     723 try:\n --> 724     os.mkdir(self, mode)\n     725 except FileNotFoundError:\n \n-FileNotFoundError: [Errno 2] No such file or directory: '/nonexistent/first-build/.local/share/cartopy/shapefiles'\n+FileNotFoundError: [Errno 2] No such file or directory: '/nonexistent/second-build/.local/share/cartopy/shapefiles'\n \n During handling of the above exception, another exception occurred:\n \n FileNotFoundError                         Traceback (most recent call last)\n File /usr/lib/python3.13/pathlib/_local.py:724, in Path.mkdir(self, mode, parents, exist_ok)\n     723 try:\n --> 724     os.mkdir(self, mode)\n     725 except FileNotFoundError:\n \n-FileNotFoundError: [Errno 2] No such file or directory: '/nonexistent/first-build/.local/share/cartopy'\n+FileNotFoundError: [Errno 2] No such file or directory: '/nonexistent/second-build/.local/share/cartopy'\n \n During handling of the above exception, another exception occurred:\n \n FileNotFoundError                         Traceback (most recent call last)\n File /usr/lib/python3.13/pathlib/_local.py:724, in Path.mkdir(self, mode, parents, exist_ok)\n     723 try:\n --> 724     os.mkdir(self, mode)\n     725 except FileNotFoundError:\n \n-FileNotFoundError: [Errno 2] No such file or directory: '/nonexistent/first-build/.local/share'\n+FileNotFoundError: [Errno 2] No such file or directory: '/nonexistent/second-build/.local/share'\n \n During handling of the above exception, another exception occurred:\n \n FileNotFoundError                         Traceback (most recent call last)\n File /usr/lib/python3.13/pathlib/_local.py:724, in Path.mkdir(self, mode, parents, exist_ok)\n     723 try:\n --> 724     os.mkdir(self, mode)\n     725 except FileNotFoundError:\n \n-FileNotFoundError: [Errno 2] No such file or directory: '/nonexistent/first-build/.local'\n+FileNotFoundError: [Errno 2] No such file or directory: '/nonexistent/second-build/.local'\n \n During handling of the above exception, another exception occurred:\n \n FileNotFoundError                         Traceback (most recent call last)\n File /usr/lib/python3.13/pathlib/_local.py:724, in Path.mkdir(self, mode, parents, exist_ok)\n     723 try:\n --> 724     os.mkdir(self, mode)\n     725 except FileNotFoundError:\n \n-FileNotFoundError: [Errno 2] No such file or directory: '/nonexistent/first-build'\n+FileNotFoundError: [Errno 2] No such file or directory: '/nonexistent/second-build'\n \n During handling of the above exception, another exception occurred:\n \n PermissionError                           Traceback (most recent call last)\n File /usr/lib/python3/dist-packages/IPython/core/formatters.py:402, in BaseFormatter.__call__(self, obj)\n     400     pass\n     401 else:\n", "details": [{"source1": "html2text {}", "source2": "html2text {}", "unified_diff": "@@ -99,15 +99,15 @@\n     273     message.append(\n     274         f\"Use environment variable '{env}' to specify a different\n location.\"\n     275     )\n --> 276 raise PermissionError(\" \".join(message)) from error\n \n PermissionError: [Errno 13] Permission denied: '/nonexistent' | Pooch could not\n-create data cache folder '/nonexistent/first-build/.cache/\n+create data cache folder '/nonexistent/second-build/.cache/\n xarray_tutorial_data'. Will not be able to download data files.\n Let\u2019s create a simple plot of 2-m air temperature in degrees Celsius:\n [3]:\n ds = ds - 273.15\n ds.t2m[0].plot(cmap=plt.cm.coolwarm)\n ---------------------------------------------------------------------------\n NameError                                 Traceback (most recent call last)\n@@ -138,97 +138,97 @@\n ----> 7 plot = ds.t2m[0].plot(\n       8     cmap=plt.cm.coolwarm, transform=ccrs.PlateCarree(), cbar_kwargs=\n {\"shrink\": 0.6}\n       9 )\n      10 plt.title(\"ERA5 - 2m temperature British Isles March 2019\")\n \n NameError: name 'ds' is not defined\n-Error in callback  (for\n+Error in callback  (for\n post_execute), with arguments args (),kwargs {}:\n ---------------------------------------------------------------------------\n FileNotFoundError                         Traceback (most recent call last)\n File /usr/lib/python3.13/pathlib/_local.py:724, in Path.mkdir(self, mode,\n parents, exist_ok)\n     723 try:\n --> 724     os.mkdir(self, mode)\n     725 except FileNotFoundError:\n \n-FileNotFoundError: [Errno 2] No such file or directory: '/nonexistent/first-\n+FileNotFoundError: [Errno 2] No such file or directory: '/nonexistent/second-\n build/.local/share/cartopy/shapefiles/natural_earth/physical'\n \n During handling of the above exception, another exception occurred:\n \n FileNotFoundError                         Traceback (most recent call last)\n File /usr/lib/python3.13/pathlib/_local.py:724, in Path.mkdir(self, mode,\n parents, exist_ok)\n     723 try:\n --> 724     os.mkdir(self, mode)\n     725 except FileNotFoundError:\n \n-FileNotFoundError: [Errno 2] No such file or directory: '/nonexistent/first-\n+FileNotFoundError: [Errno 2] No such file or directory: '/nonexistent/second-\n build/.local/share/cartopy/shapefiles/natural_earth'\n \n During handling of the above exception, another exception occurred:\n \n FileNotFoundError                         Traceback (most recent call last)\n File /usr/lib/python3.13/pathlib/_local.py:724, in Path.mkdir(self, mode,\n parents, exist_ok)\n     723 try:\n --> 724     os.mkdir(self, mode)\n     725 except FileNotFoundError:\n \n-FileNotFoundError: [Errno 2] No such file or directory: '/nonexistent/first-\n+FileNotFoundError: [Errno 2] No such file or directory: '/nonexistent/second-\n build/.local/share/cartopy/shapefiles'\n \n During handling of the above exception, another exception occurred:\n \n FileNotFoundError                         Traceback (most recent call last)\n File /usr/lib/python3.13/pathlib/_local.py:724, in Path.mkdir(self, mode,\n parents, exist_ok)\n     723 try:\n --> 724     os.mkdir(self, mode)\n     725 except FileNotFoundError:\n \n-FileNotFoundError: [Errno 2] No such file or directory: '/nonexistent/first-\n+FileNotFoundError: [Errno 2] No such file or directory: '/nonexistent/second-\n build/.local/share/cartopy'\n \n During handling of the above exception, another exception occurred:\n \n FileNotFoundError                         Traceback (most recent call last)\n File /usr/lib/python3.13/pathlib/_local.py:724, in Path.mkdir(self, mode,\n parents, exist_ok)\n     723 try:\n --> 724     os.mkdir(self, mode)\n     725 except FileNotFoundError:\n \n-FileNotFoundError: [Errno 2] No such file or directory: '/nonexistent/first-\n+FileNotFoundError: [Errno 2] No such file or directory: '/nonexistent/second-\n build/.local/share'\n \n During handling of the above exception, another exception occurred:\n \n FileNotFoundError                         Traceback (most recent call last)\n File /usr/lib/python3.13/pathlib/_local.py:724, in Path.mkdir(self, mode,\n parents, exist_ok)\n     723 try:\n --> 724     os.mkdir(self, mode)\n     725 except FileNotFoundError:\n \n-FileNotFoundError: [Errno 2] No such file or directory: '/nonexistent/first-\n+FileNotFoundError: [Errno 2] No such file or directory: '/nonexistent/second-\n build/.local'\n \n During handling of the above exception, another exception occurred:\n \n FileNotFoundError                         Traceback (most recent call last)\n File /usr/lib/python3.13/pathlib/_local.py:724, in Path.mkdir(self, mode,\n parents, exist_ok)\n     723 try:\n --> 724     os.mkdir(self, mode)\n     725 except FileNotFoundError:\n \n-FileNotFoundError: [Errno 2] No such file or directory: '/nonexistent/first-\n+FileNotFoundError: [Errno 2] No such file or directory: '/nonexistent/second-\n build'\n \n During handling of the above exception, another exception occurred:\n \n PermissionError                           Traceback (most recent call last)\n File /usr/lib/python3/dist-packages/matplotlib/pyplot.py:197, in\n _draw_all_if_interactive()\n@@ -458,87 +458,87 @@\n FileNotFoundError                         Traceback (most recent call last)\n File /usr/lib/python3.13/pathlib/_local.py:724, in Path.mkdir(self, mode,\n parents, exist_ok)\n     723 try:\n --> 724     os.mkdir(self, mode)\n     725 except FileNotFoundError:\n \n-FileNotFoundError: [Errno 2] No such file or directory: '/nonexistent/first-\n+FileNotFoundError: [Errno 2] No such file or directory: '/nonexistent/second-\n build/.local/share/cartopy/shapefiles/natural_earth/physical'\n \n During handling of the above exception, another exception occurred:\n \n FileNotFoundError                         Traceback (most recent call last)\n File /usr/lib/python3.13/pathlib/_local.py:724, in Path.mkdir(self, mode,\n parents, exist_ok)\n     723 try:\n --> 724     os.mkdir(self, mode)\n     725 except FileNotFoundError:\n \n-FileNotFoundError: [Errno 2] No such file or directory: '/nonexistent/first-\n+FileNotFoundError: [Errno 2] No such file or directory: '/nonexistent/second-\n build/.local/share/cartopy/shapefiles/natural_earth'\n \n During handling of the above exception, another exception occurred:\n \n FileNotFoundError                         Traceback (most recent call last)\n File /usr/lib/python3.13/pathlib/_local.py:724, in Path.mkdir(self, mode,\n parents, exist_ok)\n     723 try:\n --> 724     os.mkdir(self, mode)\n     725 except FileNotFoundError:\n \n-FileNotFoundError: [Errno 2] No such file or directory: '/nonexistent/first-\n+FileNotFoundError: [Errno 2] No such file or directory: '/nonexistent/second-\n build/.local/share/cartopy/shapefiles'\n \n During handling of the above exception, another exception occurred:\n \n FileNotFoundError                         Traceback (most recent call last)\n File /usr/lib/python3.13/pathlib/_local.py:724, in Path.mkdir(self, mode,\n parents, exist_ok)\n     723 try:\n --> 724     os.mkdir(self, mode)\n     725 except FileNotFoundError:\n \n-FileNotFoundError: [Errno 2] No such file or directory: '/nonexistent/first-\n+FileNotFoundError: [Errno 2] No such file or directory: '/nonexistent/second-\n build/.local/share/cartopy'\n \n During handling of the above exception, another exception occurred:\n \n FileNotFoundError                         Traceback (most recent call last)\n File /usr/lib/python3.13/pathlib/_local.py:724, in Path.mkdir(self, mode,\n parents, exist_ok)\n     723 try:\n --> 724     os.mkdir(self, mode)\n     725 except FileNotFoundError:\n \n-FileNotFoundError: [Errno 2] No such file or directory: '/nonexistent/first-\n+FileNotFoundError: [Errno 2] No such file or directory: '/nonexistent/second-\n build/.local/share'\n \n During handling of the above exception, another exception occurred:\n \n FileNotFoundError                         Traceback (most recent call last)\n File /usr/lib/python3.13/pathlib/_local.py:724, in Path.mkdir(self, mode,\n parents, exist_ok)\n     723 try:\n --> 724     os.mkdir(self, mode)\n     725 except FileNotFoundError:\n \n-FileNotFoundError: [Errno 2] No such file or directory: '/nonexistent/first-\n+FileNotFoundError: [Errno 2] No such file or directory: '/nonexistent/second-\n build/.local'\n \n During handling of the above exception, another exception occurred:\n \n FileNotFoundError                         Traceback (most recent call last)\n File /usr/lib/python3.13/pathlib/_local.py:724, in Path.mkdir(self, mode,\n parents, exist_ok)\n     723 try:\n --> 724     os.mkdir(self, mode)\n     725 except FileNotFoundError:\n \n-FileNotFoundError: [Errno 2] No such file or directory: '/nonexistent/first-\n+FileNotFoundError: [Errno 2] No such file or directory: '/nonexistent/second-\n build'\n \n During handling of the above exception, another exception occurred:\n \n PermissionError                           Traceback (most recent call last)\n File /usr/lib/python3/dist-packages/IPython/core/formatters.py:402, in\n BaseFormatter.__call__(self, obj)\n"}]}, {"source1": "./usr/share/doc/python-xarray-doc/html/examples/ERA5-GRIB-example.ipynb.gz", "source2": "./usr/share/doc/python-xarray-doc/html/examples/ERA5-GRIB-example.ipynb.gz", "unified_diff": null, "details": [{"source1": "ERA5-GRIB-example.ipynb", "source2": "ERA5-GRIB-example.ipynb", "unified_diff": null, "details": [{"source1": "Pretty-printed", "source2": "Pretty-printed", "comments": ["Similarity: 0.9983703823622252%", "Differences: {\"'cells'\": \"{2: {'metadata': {'execution': {'iopub.execute_input': '2025-03-05T03:35:30.498292Z', \"", "            \"'iopub.status.busy': '2025-03-05T03:35:30.497745Z', 'iopub.status.idle': \"", "            \"'2025-03-05T03:35:38.250746Z', 'shell.execute_reply': \"", "            \"'2025-03-05T03:35:38.249250Z'}}}, 4: {'metadata': {'execution': \"", "            \"{'iopub.execute_input': '2025-03-05T03:35:38.265644Z', 'iopub.status.busy': \"", "            \"'2025-03-05T03:35:38.264742Z', 'iopub.status.idle': '2025-03-05T03:35:3 [\u2026]"], "unified_diff": "@@ -15,18 +15,18 @@\n             ]\n         },\n         {\n             \"cell_type\": \"code\",\n             \"execution_count\": 1,\n             \"metadata\": {\n                 \"execution\": {\n-                    \"iopub.execute_input\": \"2026-04-07T09:26:51.347688Z\",\n-                    \"iopub.status.busy\": \"2026-04-07T09:26:51.347439Z\",\n-                    \"iopub.status.idle\": \"2026-04-07T09:26:53.310417Z\",\n-                    \"shell.execute_reply\": \"2026-04-07T09:26:53.309745Z\"\n+                    \"iopub.execute_input\": \"2025-03-05T03:35:30.498292Z\",\n+                    \"iopub.status.busy\": \"2025-03-05T03:35:30.497745Z\",\n+                    \"iopub.status.idle\": \"2025-03-05T03:35:38.250746Z\",\n+                    \"shell.execute_reply\": \"2025-03-05T03:35:38.249250Z\"\n                 }\n             },\n             \"outputs\": [\n                 {\n                     \"name\": \"stderr\",\n                     \"output_type\": \"stream\",\n                     \"text\": [\n@@ -47,24 +47,24 @@\n             ]\n         },\n         {\n             \"cell_type\": \"code\",\n             \"execution_count\": 2,\n             \"metadata\": {\n                 \"execution\": {\n-                    \"iopub.execute_input\": \"2026-04-07T09:26:53.313557Z\",\n-                    \"iopub.status.busy\": \"2026-04-07T09:26:53.312881Z\",\n-                    \"iopub.status.idle\": \"2026-04-07T09:26:53.590580Z\",\n-                    \"shell.execute_reply\": \"2026-04-07T09:26:53.589909Z\"\n+                    \"iopub.execute_input\": \"2025-03-05T03:35:38.265644Z\",\n+                    \"iopub.status.busy\": \"2025-03-05T03:35:38.264742Z\",\n+                    \"iopub.status.idle\": \"2025-03-05T03:35:39.420986Z\",\n+                    \"shell.execute_reply\": \"2025-03-05T03:35:39.419683Z\"\n                 }\n             },\n             \"outputs\": [\n                 {\n                     \"ename\": \"PermissionError\",\n-                    \"evalue\": \"[Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/first-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\",\n+                    \"evalue\": \"[Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/second-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\",\n                     \"output_type\": \"error\",\n                     \"traceback\": [\n                         \"\\u001b[0;31m---------------------------------------------------------------------------\\u001b[0m\",\n                         \"\\u001b[0;31mPermissionError\\u001b[0m                           Traceback (most recent call last)\",\n                         \"File \\u001b[0;32m/usr/lib/python3/dist-packages/pooch/utils.py:262\\u001b[0m, in \\u001b[0;36mmake_local_storage\\u001b[0;34m(path, env)\\u001b[0m\\n\\u001b[1;32m    258\\u001b[0m \\u001b[38;5;28;01mif\\u001b[39;00m action \\u001b[38;5;241m==\\u001b[39m \\u001b[38;5;124m\\\"\\u001b[39m\\u001b[38;5;124mcreate\\u001b[39m\\u001b[38;5;124m\\\"\\u001b[39m:\\n\\u001b[1;32m    259\\u001b[0m     \\u001b[38;5;66;03m# When running in parallel, it's possible that multiple jobs will\\u001b[39;00m\\n\\u001b[1;32m    260\\u001b[0m     \\u001b[38;5;66;03m# try to create the path at the same time. Use exist_ok to avoid\\u001b[39;00m\\n\\u001b[1;32m    261\\u001b[0m     \\u001b[38;5;66;03m# raising an error.\\u001b[39;00m\\n\\u001b[0;32m--> 262\\u001b[0m     \\u001b[43mos\\u001b[49m\\u001b[38;5;241;43m.\\u001b[39;49m\\u001b[43mmakedirs\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[43mpath\\u001b[49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[43mexist_ok\\u001b[49m\\u001b[38;5;241;43m=\\u001b[39;49m\\u001b[38;5;28;43;01mTrue\\u001b[39;49;00m\\u001b[43m)\\u001b[49m\\n\\u001b[1;32m    263\\u001b[0m \\u001b[38;5;28;01melse\\u001b[39;00m:\\n\",\n                         \"File \\u001b[0;32m/usr/lib/python3.13/os.py:217\\u001b[0m, in \\u001b[0;36mmakedirs\\u001b[0;34m(name, mode, exist_ok)\\u001b[0m\\n\\u001b[1;32m    216\\u001b[0m \\u001b[38;5;28;01mtry\\u001b[39;00m:\\n\\u001b[0;32m--> 217\\u001b[0m     \\u001b[43mmakedirs\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[43mhead\\u001b[49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[43mexist_ok\\u001b[49m\\u001b[38;5;241;43m=\\u001b[39;49m\\u001b[43mexist_ok\\u001b[49m\\u001b[43m)\\u001b[49m\\n\\u001b[1;32m    218\\u001b[0m \\u001b[38;5;28;01mexcept\\u001b[39;00m \\u001b[38;5;167;01mFileExistsError\\u001b[39;00m:\\n\\u001b[1;32m    219\\u001b[0m     \\u001b[38;5;66;03m# Defeats race condition when another thread created the path\\u001b[39;00m\\n\",\n                         \"File \\u001b[0;32m/usr/lib/python3.13/os.py:217\\u001b[0m, in \\u001b[0;36mmakedirs\\u001b[0;34m(name, mode, exist_ok)\\u001b[0m\\n\\u001b[1;32m    216\\u001b[0m \\u001b[38;5;28;01mtry\\u001b[39;00m:\\n\\u001b[0;32m--> 217\\u001b[0m     \\u001b[43mmakedirs\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[43mhead\\u001b[49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[43mexist_ok\\u001b[49m\\u001b[38;5;241;43m=\\u001b[39;49m\\u001b[43mexist_ok\\u001b[49m\\u001b[43m)\\u001b[49m\\n\\u001b[1;32m    218\\u001b[0m \\u001b[38;5;28;01mexcept\\u001b[39;00m \\u001b[38;5;167;01mFileExistsError\\u001b[39;00m:\\n\\u001b[1;32m    219\\u001b[0m     \\u001b[38;5;66;03m# Defeats race condition when another thread created the path\\u001b[39;00m\\n\",\n@@ -74,15 +74,15 @@\n                         \"\\nThe above exception was the direct cause of the following exception:\\n\",\n                         \"\\u001b[0;31mPermissionError\\u001b[0m                           Traceback (most recent call last)\",\n                         \"Cell \\u001b[0;32mIn[2], line 1\\u001b[0m\\n\\u001b[0;32m----> 1\\u001b[0m ds \\u001b[38;5;241m=\\u001b[39m \\u001b[43mxr\\u001b[49m\\u001b[38;5;241;43m.\\u001b[39;49m\\u001b[43mtutorial\\u001b[49m\\u001b[38;5;241;43m.\\u001b[39;49m\\u001b[43mload_dataset\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[38;5;124;43m\\\"\\u001b[39;49m\\u001b[38;5;124;43mera5-2mt-2019-03-uk.grib\\u001b[39;49m\\u001b[38;5;124;43m\\\"\\u001b[39;49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[43mengine\\u001b[49m\\u001b[38;5;241;43m=\\u001b[39;49m\\u001b[38;5;124;43m\\\"\\u001b[39;49m\\u001b[38;5;124;43mcfgrib\\u001b[39;49m\\u001b[38;5;124;43m\\\"\\u001b[39;49m\\u001b[43m)\\u001b[49m\\n\",\n                         \"File \\u001b[0;32m/usr/lib/python3/dist-packages/xarray/tutorial.py:213\\u001b[0m, in \\u001b[0;36mload_dataset\\u001b[0;34m(*args, **kwargs)\\u001b[0m\\n\\u001b[1;32m    176\\u001b[0m \\u001b[38;5;28;01mdef\\u001b[39;00m \\u001b[38;5;21mload_dataset\\u001b[39m(\\u001b[38;5;241m*\\u001b[39margs, \\u001b[38;5;241m*\\u001b[39m\\u001b[38;5;241m*\\u001b[39mkwargs) \\u001b[38;5;241m-\\u001b[39m\\u001b[38;5;241m>\\u001b[39m Dataset:\\n\\u001b[1;32m    177\\u001b[0m \\u001b[38;5;250m    \\u001b[39m\\u001b[38;5;124;03m\\\"\\\"\\\"\\u001b[39;00m\\n\\u001b[1;32m    178\\u001b[0m \\u001b[38;5;124;03m    Open, load into memory, and close a dataset from the online repository\\u001b[39;00m\\n\\u001b[1;32m    179\\u001b[0m \\u001b[38;5;124;03m    (requires internet).\\u001b[39;00m\\n\\u001b[0;32m   (...)\\u001b[0m\\n\\u001b[1;32m    211\\u001b[0m \\u001b[38;5;124;03m    load_dataset\\u001b[39;00m\\n\\u001b[1;32m    212\\u001b[0m \\u001b[38;5;124;03m    \\\"\\\"\\\"\\u001b[39;00m\\n\\u001b[0;32m--> 213\\u001b[0m     \\u001b[38;5;28;01mwith\\u001b[39;00m \\u001b[43mopen_dataset\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[38;5;241;43m*\\u001b[39;49m\\u001b[43margs\\u001b[49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[38;5;241;43m*\\u001b[39;49m\\u001b[38;5;241;43m*\\u001b[39;49m\\u001b[43mkwargs\\u001b[49m\\u001b[43m)\\u001b[49m \\u001b[38;5;28;01mas\\u001b[39;00m ds:\\n\\u001b[1;32m    214\\u001b[0m         \\u001b[38;5;28;01mreturn\\u001b[39;00m ds\\u001b[38;5;241m.\\u001b[39mload()\\n\",\n                         \"File \\u001b[0;32m/usr/lib/python3/dist-packages/xarray/tutorial.py:165\\u001b[0m, in \\u001b[0;36mopen_dataset\\u001b[0;34m(name, cache, cache_dir, engine, **kws)\\u001b[0m\\n\\u001b[1;32m    162\\u001b[0m downloader \\u001b[38;5;241m=\\u001b[39m pooch\\u001b[38;5;241m.\\u001b[39mHTTPDownloader(headers\\u001b[38;5;241m=\\u001b[39mheaders)\\n\\u001b[1;32m    164\\u001b[0m \\u001b[38;5;66;03m# retrieve the file\\u001b[39;00m\\n\\u001b[0;32m--> 165\\u001b[0m filepath \\u001b[38;5;241m=\\u001b[39m \\u001b[43mpooch\\u001b[49m\\u001b[38;5;241;43m.\\u001b[39;49m\\u001b[43mretrieve\\u001b[49m\\u001b[43m(\\u001b[49m\\n\\u001b[1;32m    166\\u001b[0m \\u001b[43m    \\u001b[49m\\u001b[43murl\\u001b[49m\\u001b[38;5;241;43m=\\u001b[39;49m\\u001b[43murl\\u001b[49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[43mknown_hash\\u001b[49m\\u001b[38;5;241;43m=\\u001b[39;49m\\u001b[38;5;28;43;01mNone\\u001b[39;49;00m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[43mpath\\u001b[49m\\u001b[38;5;241;43m=\\u001b[39;49m\\u001b[43mcache_dir\\u001b[49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[43mdownloader\\u001b[49m\\u001b[38;5;241;43m=\\u001b[39;49m\\u001b[43mdownloader\\u001b[49m\\n\\u001b[1;32m    167\\u001b[0m \\u001b[43m\\u001b[49m\\u001b[43m)\\u001b[49m\\n\\u001b[1;32m    168\\u001b[0m ds \\u001b[38;5;241m=\\u001b[39m _open_dataset(filepath, engine\\u001b[38;5;241m=\\u001b[39mengine, \\u001b[38;5;241m*\\u001b[39m\\u001b[38;5;241m*\\u001b[39mkws)\\n\\u001b[1;32m    169\\u001b[0m \\u001b[38;5;28;01mif\\u001b[39;00m \\u001b[38;5;129;01mnot\\u001b[39;00m cache:\\n\",\n                         \"File \\u001b[0;32m/usr/lib/python3/dist-packages/pooch/core.py:227\\u001b[0m, in \\u001b[0;36mretrieve\\u001b[0;34m(url, known_hash, fname, path, processor, downloader, progressbar)\\u001b[0m\\n\\u001b[1;32m    222\\u001b[0m action, verb \\u001b[38;5;241m=\\u001b[39m download_action(full_path, known_hash)\\n\\u001b[1;32m    224\\u001b[0m \\u001b[38;5;28;01mif\\u001b[39;00m action \\u001b[38;5;129;01min\\u001b[39;00m (\\u001b[38;5;124m\\\"\\u001b[39m\\u001b[38;5;124mdownload\\u001b[39m\\u001b[38;5;124m\\\"\\u001b[39m, \\u001b[38;5;124m\\\"\\u001b[39m\\u001b[38;5;124mupdate\\u001b[39m\\u001b[38;5;124m\\\"\\u001b[39m):\\n\\u001b[1;32m    225\\u001b[0m     \\u001b[38;5;66;03m# We need to write data, so create the local data directory if it\\u001b[39;00m\\n\\u001b[1;32m    226\\u001b[0m     \\u001b[38;5;66;03m# doesn't already exist.\\u001b[39;00m\\n\\u001b[0;32m--> 227\\u001b[0m     \\u001b[43mmake_local_storage\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[43mpath\\u001b[49m\\u001b[43m)\\u001b[49m\\n\\u001b[1;32m    229\\u001b[0m     get_logger()\\u001b[38;5;241m.\\u001b[39minfo(\\n\\u001b[1;32m    230\\u001b[0m         \\u001b[38;5;124m\\\"\\u001b[39m\\u001b[38;5;132;01m%s\\u001b[39;00m\\u001b[38;5;124m data from \\u001b[39m\\u001b[38;5;124m'\\u001b[39m\\u001b[38;5;132;01m%s\\u001b[39;00m\\u001b[38;5;124m'\\u001b[39m\\u001b[38;5;124m to file \\u001b[39m\\u001b[38;5;124m'\\u001b[39m\\u001b[38;5;132;01m%s\\u001b[39;00m\\u001b[38;5;124m'\\u001b[39m\\u001b[38;5;124m.\\u001b[39m\\u001b[38;5;124m\\\"\\u001b[39m,\\n\\u001b[1;32m    231\\u001b[0m         verb,\\n\\u001b[1;32m    232\\u001b[0m         url,\\n\\u001b[1;32m    233\\u001b[0m         \\u001b[38;5;28mstr\\u001b[39m(full_path),\\n\\u001b[1;32m    234\\u001b[0m     )\\n\\u001b[1;32m    236\\u001b[0m     \\u001b[38;5;28;01mif\\u001b[39;00m downloader \\u001b[38;5;129;01mis\\u001b[39;00m \\u001b[38;5;28;01mNone\\u001b[39;00m:\\n\",\n                         \"File \\u001b[0;32m/usr/lib/python3/dist-packages/pooch/utils.py:276\\u001b[0m, in \\u001b[0;36mmake_local_storage\\u001b[0;34m(path, env)\\u001b[0m\\n\\u001b[1;32m    272\\u001b[0m \\u001b[38;5;28;01mif\\u001b[39;00m env \\u001b[38;5;129;01mis\\u001b[39;00m \\u001b[38;5;129;01mnot\\u001b[39;00m \\u001b[38;5;28;01mNone\\u001b[39;00m:\\n\\u001b[1;32m    273\\u001b[0m     message\\u001b[38;5;241m.\\u001b[39mappend(\\n\\u001b[1;32m    274\\u001b[0m         \\u001b[38;5;124mf\\u001b[39m\\u001b[38;5;124m\\\"\\u001b[39m\\u001b[38;5;124mUse environment variable \\u001b[39m\\u001b[38;5;124m'\\u001b[39m\\u001b[38;5;132;01m{\\u001b[39;00menv\\u001b[38;5;132;01m}\\u001b[39;00m\\u001b[38;5;124m'\\u001b[39m\\u001b[38;5;124m to specify a different location.\\u001b[39m\\u001b[38;5;124m\\\"\\u001b[39m\\n\\u001b[1;32m    275\\u001b[0m     )\\n\\u001b[0;32m--> 276\\u001b[0m \\u001b[38;5;28;01mraise\\u001b[39;00m \\u001b[38;5;167;01mPermissionError\\u001b[39;00m(\\u001b[38;5;124m\\\"\\u001b[39m\\u001b[38;5;124m \\u001b[39m\\u001b[38;5;124m\\\"\\u001b[39m\\u001b[38;5;241m.\\u001b[39mjoin(message)) \\u001b[38;5;28;01mfrom\\u001b[39;00m \\u001b[38;5;21;01merror\\u001b[39;00m\\n\",\n-                        \"\\u001b[0;31mPermissionError\\u001b[0m: [Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/first-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\"\n+                        \"\\u001b[0;31mPermissionError\\u001b[0m: [Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/second-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\"\n                     ]\n                 }\n             ],\n             \"source\": [\n                 \"ds = xr.tutorial.load_dataset(\\\"era5-2mt-2019-03-uk.grib\\\", engine=\\\"cfgrib\\\")\"\n             ]\n         },\n@@ -94,18 +94,18 @@\n             ]\n         },\n         {\n             \"cell_type\": \"code\",\n             \"execution_count\": 3,\n             \"metadata\": {\n                 \"execution\": {\n-                    \"iopub.execute_input\": \"2026-04-07T09:26:53.592977Z\",\n-                    \"iopub.status.busy\": \"2026-04-07T09:26:53.592733Z\",\n-                    \"iopub.status.idle\": \"2026-04-07T09:26:53.606030Z\",\n-                    \"shell.execute_reply\": \"2026-04-07T09:26:53.605488Z\"\n+                    \"iopub.execute_input\": \"2025-03-05T03:35:39.433958Z\",\n+                    \"iopub.status.busy\": \"2025-03-05T03:35:39.433394Z\",\n+                    \"iopub.status.idle\": \"2025-03-05T03:35:39.470701Z\",\n+                    \"shell.execute_reply\": \"2025-03-05T03:35:39.469661Z\"\n                 }\n             },\n             \"outputs\": [\n                 {\n                     \"ename\": \"NameError\",\n                     \"evalue\": \"name 'ds' is not defined\",\n                     \"output_type\": \"error\",\n@@ -130,18 +130,18 @@\n             ]\n         },\n         {\n             \"cell_type\": \"code\",\n             \"execution_count\": 4,\n             \"metadata\": {\n                 \"execution\": {\n-                    \"iopub.execute_input\": \"2026-04-07T09:26:53.608013Z\",\n-                    \"iopub.status.busy\": \"2026-04-07T09:26:53.607779Z\",\n-                    \"iopub.status.idle\": \"2026-04-07T09:26:55.002750Z\",\n-                    \"shell.execute_reply\": \"2026-04-07T09:26:55.001878Z\"\n+                    \"iopub.execute_input\": \"2025-03-05T03:35:39.481734Z\",\n+                    \"iopub.status.busy\": \"2025-03-05T03:35:39.481190Z\",\n+                    \"iopub.status.idle\": \"2025-03-05T03:35:44.564022Z\",\n+                    \"shell.execute_reply\": \"2025-03-05T03:35:44.547891Z\"\n                 }\n             },\n             \"outputs\": [\n                 {\n                     \"ename\": \"NameError\",\n                     \"evalue\": \"name 'ds' is not defined\",\n                     \"output_type\": \"error\",\n@@ -152,50 +152,50 @@\n                         \"\\u001b[0;31mNameError\\u001b[0m: name 'ds' is not defined\"\n                     ]\n                 },\n                 {\n                     \"name\": \"stdout\",\n                     \"output_type\": \"stream\",\n                     \"text\": [\n-                        \"Error in callback  (for post_execute), with arguments args (),kwargs {}:\\n\"\n+                        \"Error in callback  (for post_execute), with arguments args (),kwargs {}:\\n\"\n                     ]\n                 },\n                 {\n                     \"ename\": \"PermissionError\",\n                     \"evalue\": \"[Errno 13] Permission denied: '/nonexistent'\",\n                     \"output_type\": \"error\",\n                     \"traceback\": [\n                         \"\\u001b[0;31m---------------------------------------------------------------------------\\u001b[0m\",\n                         \"\\u001b[0;31mFileNotFoundError\\u001b[0m                         Traceback (most recent call last)\",\n                         \"File \\u001b[0;32m/usr/lib/python3.13/pathlib/_local.py:724\\u001b[0m, in \\u001b[0;36mPath.mkdir\\u001b[0;34m(self, mode, parents, exist_ok)\\u001b[0m\\n\\u001b[1;32m    723\\u001b[0m \\u001b[38;5;28;01mtry\\u001b[39;00m:\\n\\u001b[0;32m--> 724\\u001b[0m     \\u001b[43mos\\u001b[49m\\u001b[38;5;241;43m.\\u001b[39;49m\\u001b[43mmkdir\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[38;5;28;43mself\\u001b[39;49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[43mmode\\u001b[49m\\u001b[43m)\\u001b[49m\\n\\u001b[1;32m    725\\u001b[0m \\u001b[38;5;28;01mexcept\\u001b[39;00m \\u001b[38;5;167;01mFileNotFoundError\\u001b[39;00m:\\n\",\n-                        \"\\u001b[0;31mFileNotFoundError\\u001b[0m: [Errno 2] No such file or directory: '/nonexistent/first-build/.local/share/cartopy/shapefiles/natural_earth/physical'\",\n+                        \"\\u001b[0;31mFileNotFoundError\\u001b[0m: [Errno 2] No such file or directory: '/nonexistent/second-build/.local/share/cartopy/shapefiles/natural_earth/physical'\",\n                         \"\\nDuring handling of the above exception, another exception occurred:\\n\",\n                         \"\\u001b[0;31mFileNotFoundError\\u001b[0m                         Traceback (most recent call last)\",\n                         \"File \\u001b[0;32m/usr/lib/python3.13/pathlib/_local.py:724\\u001b[0m, in \\u001b[0;36mPath.mkdir\\u001b[0;34m(self, mode, parents, exist_ok)\\u001b[0m\\n\\u001b[1;32m    723\\u001b[0m \\u001b[38;5;28;01mtry\\u001b[39;00m:\\n\\u001b[0;32m--> 724\\u001b[0m     \\u001b[43mos\\u001b[49m\\u001b[38;5;241;43m.\\u001b[39;49m\\u001b[43mmkdir\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[38;5;28;43mself\\u001b[39;49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[43mmode\\u001b[49m\\u001b[43m)\\u001b[49m\\n\\u001b[1;32m    725\\u001b[0m \\u001b[38;5;28;01mexcept\\u001b[39;00m \\u001b[38;5;167;01mFileNotFoundError\\u001b[39;00m:\\n\",\n-                        \"\\u001b[0;31mFileNotFoundError\\u001b[0m: [Errno 2] No such file or directory: '/nonexistent/first-build/.local/share/cartopy/shapefiles/natural_earth'\",\n+                        \"\\u001b[0;31mFileNotFoundError\\u001b[0m: [Errno 2] No such file or directory: '/nonexistent/second-build/.local/share/cartopy/shapefiles/natural_earth'\",\n                         \"\\nDuring handling of the above exception, another exception occurred:\\n\",\n                         \"\\u001b[0;31mFileNotFoundError\\u001b[0m                         Traceback (most recent call last)\",\n                         \"File \\u001b[0;32m/usr/lib/python3.13/pathlib/_local.py:724\\u001b[0m, in \\u001b[0;36mPath.mkdir\\u001b[0;34m(self, mode, parents, exist_ok)\\u001b[0m\\n\\u001b[1;32m    723\\u001b[0m \\u001b[38;5;28;01mtry\\u001b[39;00m:\\n\\u001b[0;32m--> 724\\u001b[0m     \\u001b[43mos\\u001b[49m\\u001b[38;5;241;43m.\\u001b[39;49m\\u001b[43mmkdir\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[38;5;28;43mself\\u001b[39;49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[43mmode\\u001b[49m\\u001b[43m)\\u001b[49m\\n\\u001b[1;32m    725\\u001b[0m \\u001b[38;5;28;01mexcept\\u001b[39;00m \\u001b[38;5;167;01mFileNotFoundError\\u001b[39;00m:\\n\",\n-                        \"\\u001b[0;31mFileNotFoundError\\u001b[0m: [Errno 2] No such file or directory: '/nonexistent/first-build/.local/share/cartopy/shapefiles'\",\n+                        \"\\u001b[0;31mFileNotFoundError\\u001b[0m: [Errno 2] No such file or directory: '/nonexistent/second-build/.local/share/cartopy/shapefiles'\",\n                         \"\\nDuring handling of the above exception, another exception occurred:\\n\",\n                         \"\\u001b[0;31mFileNotFoundError\\u001b[0m                         Traceback (most recent call last)\",\n                         \"File \\u001b[0;32m/usr/lib/python3.13/pathlib/_local.py:724\\u001b[0m, in \\u001b[0;36mPath.mkdir\\u001b[0;34m(self, mode, parents, exist_ok)\\u001b[0m\\n\\u001b[1;32m    723\\u001b[0m \\u001b[38;5;28;01mtry\\u001b[39;00m:\\n\\u001b[0;32m--> 724\\u001b[0m     \\u001b[43mos\\u001b[49m\\u001b[38;5;241;43m.\\u001b[39;49m\\u001b[43mmkdir\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[38;5;28;43mself\\u001b[39;49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[43mmode\\u001b[49m\\u001b[43m)\\u001b[49m\\n\\u001b[1;32m    725\\u001b[0m \\u001b[38;5;28;01mexcept\\u001b[39;00m \\u001b[38;5;167;01mFileNotFoundError\\u001b[39;00m:\\n\",\n-                        \"\\u001b[0;31mFileNotFoundError\\u001b[0m: [Errno 2] No such file or directory: '/nonexistent/first-build/.local/share/cartopy'\",\n+                        \"\\u001b[0;31mFileNotFoundError\\u001b[0m: [Errno 2] No such file or directory: '/nonexistent/second-build/.local/share/cartopy'\",\n                         \"\\nDuring handling of the above exception, another exception occurred:\\n\",\n                         \"\\u001b[0;31mFileNotFoundError\\u001b[0m                         Traceback (most recent call last)\",\n                         \"File \\u001b[0;32m/usr/lib/python3.13/pathlib/_local.py:724\\u001b[0m, in \\u001b[0;36mPath.mkdir\\u001b[0;34m(self, mode, parents, exist_ok)\\u001b[0m\\n\\u001b[1;32m    723\\u001b[0m \\u001b[38;5;28;01mtry\\u001b[39;00m:\\n\\u001b[0;32m--> 724\\u001b[0m     \\u001b[43mos\\u001b[49m\\u001b[38;5;241;43m.\\u001b[39;49m\\u001b[43mmkdir\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[38;5;28;43mself\\u001b[39;49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[43mmode\\u001b[49m\\u001b[43m)\\u001b[49m\\n\\u001b[1;32m    725\\u001b[0m \\u001b[38;5;28;01mexcept\\u001b[39;00m \\u001b[38;5;167;01mFileNotFoundError\\u001b[39;00m:\\n\",\n-                        \"\\u001b[0;31mFileNotFoundError\\u001b[0m: [Errno 2] No such file or directory: '/nonexistent/first-build/.local/share'\",\n+                        \"\\u001b[0;31mFileNotFoundError\\u001b[0m: [Errno 2] No such file or directory: '/nonexistent/second-build/.local/share'\",\n                         \"\\nDuring handling of the above exception, another exception occurred:\\n\",\n                         \"\\u001b[0;31mFileNotFoundError\\u001b[0m                         Traceback (most recent call last)\",\n                         \"File \\u001b[0;32m/usr/lib/python3.13/pathlib/_local.py:724\\u001b[0m, in \\u001b[0;36mPath.mkdir\\u001b[0;34m(self, mode, parents, exist_ok)\\u001b[0m\\n\\u001b[1;32m    723\\u001b[0m \\u001b[38;5;28;01mtry\\u001b[39;00m:\\n\\u001b[0;32m--> 724\\u001b[0m     \\u001b[43mos\\u001b[49m\\u001b[38;5;241;43m.\\u001b[39;49m\\u001b[43mmkdir\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[38;5;28;43mself\\u001b[39;49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[43mmode\\u001b[49m\\u001b[43m)\\u001b[49m\\n\\u001b[1;32m    725\\u001b[0m \\u001b[38;5;28;01mexcept\\u001b[39;00m \\u001b[38;5;167;01mFileNotFoundError\\u001b[39;00m:\\n\",\n-                        \"\\u001b[0;31mFileNotFoundError\\u001b[0m: [Errno 2] No such file or directory: '/nonexistent/first-build/.local'\",\n+                        \"\\u001b[0;31mFileNotFoundError\\u001b[0m: [Errno 2] No such file or directory: '/nonexistent/second-build/.local'\",\n                         \"\\nDuring handling of the above exception, another exception occurred:\\n\",\n                         \"\\u001b[0;31mFileNotFoundError\\u001b[0m                         Traceback (most recent call last)\",\n                         \"File \\u001b[0;32m/usr/lib/python3.13/pathlib/_local.py:724\\u001b[0m, in \\u001b[0;36mPath.mkdir\\u001b[0;34m(self, mode, parents, exist_ok)\\u001b[0m\\n\\u001b[1;32m    723\\u001b[0m \\u001b[38;5;28;01mtry\\u001b[39;00m:\\n\\u001b[0;32m--> 724\\u001b[0m     \\u001b[43mos\\u001b[49m\\u001b[38;5;241;43m.\\u001b[39;49m\\u001b[43mmkdir\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[38;5;28;43mself\\u001b[39;49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[43mmode\\u001b[49m\\u001b[43m)\\u001b[49m\\n\\u001b[1;32m    725\\u001b[0m \\u001b[38;5;28;01mexcept\\u001b[39;00m \\u001b[38;5;167;01mFileNotFoundError\\u001b[39;00m:\\n\",\n-                        \"\\u001b[0;31mFileNotFoundError\\u001b[0m: [Errno 2] No such file or directory: '/nonexistent/first-build'\",\n+                        \"\\u001b[0;31mFileNotFoundError\\u001b[0m: [Errno 2] No such file or directory: '/nonexistent/second-build'\",\n                         \"\\nDuring handling of the above exception, another exception occurred:\\n\",\n                         \"\\u001b[0;31mPermissionError\\u001b[0m                           Traceback (most recent call last)\",\n                         \"File \\u001b[0;32m/usr/lib/python3/dist-packages/matplotlib/pyplot.py:197\\u001b[0m, in \\u001b[0;36m_draw_all_if_interactive\\u001b[0;34m()\\u001b[0m\\n\\u001b[1;32m    195\\u001b[0m \\u001b[38;5;28;01mdef\\u001b[39;00m \\u001b[38;5;21m_draw_all_if_interactive\\u001b[39m() \\u001b[38;5;241m-\\u001b[39m\\u001b[38;5;241m>\\u001b[39m \\u001b[38;5;28;01mNone\\u001b[39;00m:\\n\\u001b[1;32m    196\\u001b[0m     \\u001b[38;5;28;01mif\\u001b[39;00m matplotlib\\u001b[38;5;241m.\\u001b[39mis_interactive():\\n\\u001b[0;32m--> 197\\u001b[0m         \\u001b[43mdraw_all\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[43m)\\u001b[49m\\n\",\n                         \"File \\u001b[0;32m/usr/lib/python3/dist-packages/matplotlib/_pylab_helpers.py:132\\u001b[0m, in \\u001b[0;36mGcf.draw_all\\u001b[0;34m(cls, force)\\u001b[0m\\n\\u001b[1;32m    130\\u001b[0m \\u001b[38;5;28;01mfor\\u001b[39;00m manager \\u001b[38;5;129;01min\\u001b[39;00m \\u001b[38;5;28mcls\\u001b[39m\\u001b[38;5;241m.\\u001b[39mget_all_fig_managers():\\n\\u001b[1;32m    131\\u001b[0m     \\u001b[38;5;28;01mif\\u001b[39;00m force \\u001b[38;5;129;01mor\\u001b[39;00m manager\\u001b[38;5;241m.\\u001b[39mcanvas\\u001b[38;5;241m.\\u001b[39mfigure\\u001b[38;5;241m.\\u001b[39mstale:\\n\\u001b[0;32m--> 132\\u001b[0m         \\u001b[43mmanager\\u001b[49m\\u001b[38;5;241;43m.\\u001b[39;49m\\u001b[43mcanvas\\u001b[49m\\u001b[38;5;241;43m.\\u001b[39;49m\\u001b[43mdraw_idle\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[43m)\\u001b[49m\\n\",\n                         \"File \\u001b[0;32m/usr/lib/python3/dist-packages/matplotlib/backend_bases.py:1893\\u001b[0m, in \\u001b[0;36mFigureCanvasBase.draw_idle\\u001b[0;34m(self, *args, **kwargs)\\u001b[0m\\n\\u001b[1;32m   1891\\u001b[0m \\u001b[38;5;28;01mif\\u001b[39;00m \\u001b[38;5;129;01mnot\\u001b[39;00m \\u001b[38;5;28mself\\u001b[39m\\u001b[38;5;241m.\\u001b[39m_is_idle_drawing:\\n\\u001b[1;32m   1892\\u001b[0m     \\u001b[38;5;28;01mwith\\u001b[39;00m \\u001b[38;5;28mself\\u001b[39m\\u001b[38;5;241m.\\u001b[39m_idle_draw_cntx():\\n\\u001b[0;32m-> 1893\\u001b[0m         \\u001b[38;5;28;43mself\\u001b[39;49m\\u001b[38;5;241;43m.\\u001b[39;49m\\u001b[43mdraw\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[38;5;241;43m*\\u001b[39;49m\\u001b[43margs\\u001b[49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[38;5;241;43m*\\u001b[39;49m\\u001b[38;5;241;43m*\\u001b[39;49m\\u001b[43mkwargs\\u001b[49m\\u001b[43m)\\u001b[49m\\n\",\n                         \"File \\u001b[0;32m/usr/lib/python3/dist-packages/matplotlib/backends/backend_agg.py:388\\u001b[0m, in \\u001b[0;36mFigureCanvasAgg.draw\\u001b[0;34m(self)\\u001b[0m\\n\\u001b[1;32m    385\\u001b[0m \\u001b[38;5;66;03m# Acquire a lock on the shared font cache.\\u001b[39;00m\\n\\u001b[1;32m    386\\u001b[0m \\u001b[38;5;28;01mwith\\u001b[39;00m (\\u001b[38;5;28mself\\u001b[39m\\u001b[38;5;241m.\\u001b[39mtoolbar\\u001b[38;5;241m.\\u001b[39m_wait_cursor_for_draw_cm() \\u001b[38;5;28;01mif\\u001b[39;00m \\u001b[38;5;28mself\\u001b[39m\\u001b[38;5;241m.\\u001b[39mtoolbar\\n\\u001b[1;32m    387\\u001b[0m       \\u001b[38;5;28;01melse\\u001b[39;00m nullcontext()):\\n\\u001b[0;32m--> 388\\u001b[0m     \\u001b[38;5;28;43mself\\u001b[39;49m\\u001b[38;5;241;43m.\\u001b[39;49m\\u001b[43mfigure\\u001b[49m\\u001b[38;5;241;43m.\\u001b[39;49m\\u001b[43mdraw\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[38;5;28;43mself\\u001b[39;49m\\u001b[38;5;241;43m.\\u001b[39;49m\\u001b[43mrenderer\\u001b[49m\\u001b[43m)\\u001b[49m\\n\\u001b[1;32m    389\\u001b[0m     \\u001b[38;5;66;03m# A GUI class may be need to update a window using this draw, so\\u001b[39;00m\\n\\u001b[1;32m    390\\u001b[0m     \\u001b[38;5;66;03m# don't forget to call the superclass.\\u001b[39;00m\\n\\u001b[1;32m    391\\u001b[0m     \\u001b[38;5;28msuper\\u001b[39m()\\u001b[38;5;241m.\\u001b[39mdraw()\\n\",\n                         \"File \\u001b[0;32m/usr/lib/python3/dist-packages/matplotlib/artist.py:95\\u001b[0m, in \\u001b[0;36m_finalize_rasterization..draw_wrapper\\u001b[0;34m(artist, renderer, *args, **kwargs)\\u001b[0m\\n\\u001b[1;32m     93\\u001b[0m \\u001b[38;5;129m@wraps\\u001b[39m(draw)\\n\\u001b[1;32m     94\\u001b[0m \\u001b[38;5;28;01mdef\\u001b[39;00m \\u001b[38;5;21mdraw_wrapper\\u001b[39m(artist, renderer, \\u001b[38;5;241m*\\u001b[39margs, \\u001b[38;5;241m*\\u001b[39m\\u001b[38;5;241m*\\u001b[39mkwargs):\\n\\u001b[0;32m---> 95\\u001b[0m     result \\u001b[38;5;241m=\\u001b[39m \\u001b[43mdraw\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[43martist\\u001b[49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[43mrenderer\\u001b[49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[38;5;241;43m*\\u001b[39;49m\\u001b[43margs\\u001b[49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[38;5;241;43m*\\u001b[39;49m\\u001b[38;5;241;43m*\\u001b[39;49m\\u001b[43mkwargs\\u001b[49m\\u001b[43m)\\u001b[49m\\n\\u001b[1;32m     96\\u001b[0m     \\u001b[38;5;28;01mif\\u001b[39;00m renderer\\u001b[38;5;241m.\\u001b[39m_rasterizing:\\n\\u001b[1;32m     97\\u001b[0m         renderer\\u001b[38;5;241m.\\u001b[39mstop_rasterizing()\\n\",\n@@ -227,39 +227,39 @@\n                     \"ename\": \"PermissionError\",\n                     \"evalue\": \"[Errno 13] Permission denied: '/nonexistent'\",\n                     \"output_type\": \"error\",\n                     \"traceback\": [\n                         \"\\u001b[0;31m---------------------------------------------------------------------------\\u001b[0m\",\n                         \"\\u001b[0;31mFileNotFoundError\\u001b[0m                         Traceback (most recent call last)\",\n                         \"File \\u001b[0;32m/usr/lib/python3.13/pathlib/_local.py:724\\u001b[0m, in \\u001b[0;36mPath.mkdir\\u001b[0;34m(self, mode, parents, exist_ok)\\u001b[0m\\n\\u001b[1;32m    723\\u001b[0m \\u001b[38;5;28;01mtry\\u001b[39;00m:\\n\\u001b[0;32m--> 724\\u001b[0m     \\u001b[43mos\\u001b[49m\\u001b[38;5;241;43m.\\u001b[39;49m\\u001b[43mmkdir\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[38;5;28;43mself\\u001b[39;49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[43mmode\\u001b[49m\\u001b[43m)\\u001b[49m\\n\\u001b[1;32m    725\\u001b[0m \\u001b[38;5;28;01mexcept\\u001b[39;00m \\u001b[38;5;167;01mFileNotFoundError\\u001b[39;00m:\\n\",\n-                        \"\\u001b[0;31mFileNotFoundError\\u001b[0m: [Errno 2] No such file or directory: '/nonexistent/first-build/.local/share/cartopy/shapefiles/natural_earth/physical'\",\n+                        \"\\u001b[0;31mFileNotFoundError\\u001b[0m: [Errno 2] No such file or directory: '/nonexistent/second-build/.local/share/cartopy/shapefiles/natural_earth/physical'\",\n                         \"\\nDuring handling of the above exception, another exception occurred:\\n\",\n                         \"\\u001b[0;31mFileNotFoundError\\u001b[0m                         Traceback (most recent call last)\",\n                         \"File \\u001b[0;32m/usr/lib/python3.13/pathlib/_local.py:724\\u001b[0m, in \\u001b[0;36mPath.mkdir\\u001b[0;34m(self, mode, parents, exist_ok)\\u001b[0m\\n\\u001b[1;32m    723\\u001b[0m \\u001b[38;5;28;01mtry\\u001b[39;00m:\\n\\u001b[0;32m--> 724\\u001b[0m     \\u001b[43mos\\u001b[49m\\u001b[38;5;241;43m.\\u001b[39;49m\\u001b[43mmkdir\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[38;5;28;43mself\\u001b[39;49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[43mmode\\u001b[49m\\u001b[43m)\\u001b[49m\\n\\u001b[1;32m    725\\u001b[0m \\u001b[38;5;28;01mexcept\\u001b[39;00m \\u001b[38;5;167;01mFileNotFoundError\\u001b[39;00m:\\n\",\n-                        \"\\u001b[0;31mFileNotFoundError\\u001b[0m: [Errno 2] No such file or directory: '/nonexistent/first-build/.local/share/cartopy/shapefiles/natural_earth'\",\n+                        \"\\u001b[0;31mFileNotFoundError\\u001b[0m: [Errno 2] No such file or directory: '/nonexistent/second-build/.local/share/cartopy/shapefiles/natural_earth'\",\n                         \"\\nDuring handling of the above exception, another exception occurred:\\n\",\n                         \"\\u001b[0;31mFileNotFoundError\\u001b[0m                         Traceback (most recent call last)\",\n                         \"File \\u001b[0;32m/usr/lib/python3.13/pathlib/_local.py:724\\u001b[0m, in \\u001b[0;36mPath.mkdir\\u001b[0;34m(self, mode, parents, exist_ok)\\u001b[0m\\n\\u001b[1;32m    723\\u001b[0m \\u001b[38;5;28;01mtry\\u001b[39;00m:\\n\\u001b[0;32m--> 724\\u001b[0m     \\u001b[43mos\\u001b[49m\\u001b[38;5;241;43m.\\u001b[39;49m\\u001b[43mmkdir\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[38;5;28;43mself\\u001b[39;49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[43mmode\\u001b[49m\\u001b[43m)\\u001b[49m\\n\\u001b[1;32m    725\\u001b[0m \\u001b[38;5;28;01mexcept\\u001b[39;00m \\u001b[38;5;167;01mFileNotFoundError\\u001b[39;00m:\\n\",\n-                        \"\\u001b[0;31mFileNotFoundError\\u001b[0m: [Errno 2] No such file or directory: '/nonexistent/first-build/.local/share/cartopy/shapefiles'\",\n+                        \"\\u001b[0;31mFileNotFoundError\\u001b[0m: [Errno 2] No such file or directory: '/nonexistent/second-build/.local/share/cartopy/shapefiles'\",\n                         \"\\nDuring handling of the above exception, another exception occurred:\\n\",\n                         \"\\u001b[0;31mFileNotFoundError\\u001b[0m                         Traceback (most recent call last)\",\n                         \"File \\u001b[0;32m/usr/lib/python3.13/pathlib/_local.py:724\\u001b[0m, in \\u001b[0;36mPath.mkdir\\u001b[0;34m(self, mode, parents, exist_ok)\\u001b[0m\\n\\u001b[1;32m    723\\u001b[0m \\u001b[38;5;28;01mtry\\u001b[39;00m:\\n\\u001b[0;32m--> 724\\u001b[0m     \\u001b[43mos\\u001b[49m\\u001b[38;5;241;43m.\\u001b[39;49m\\u001b[43mmkdir\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[38;5;28;43mself\\u001b[39;49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[43mmode\\u001b[49m\\u001b[43m)\\u001b[49m\\n\\u001b[1;32m    725\\u001b[0m \\u001b[38;5;28;01mexcept\\u001b[39;00m \\u001b[38;5;167;01mFileNotFoundError\\u001b[39;00m:\\n\",\n-                        \"\\u001b[0;31mFileNotFoundError\\u001b[0m: [Errno 2] No such file or directory: '/nonexistent/first-build/.local/share/cartopy'\",\n+                        \"\\u001b[0;31mFileNotFoundError\\u001b[0m: [Errno 2] No such file or directory: '/nonexistent/second-build/.local/share/cartopy'\",\n                         \"\\nDuring handling of the above exception, another exception occurred:\\n\",\n                         \"\\u001b[0;31mFileNotFoundError\\u001b[0m                         Traceback (most recent call last)\",\n                         \"File \\u001b[0;32m/usr/lib/python3.13/pathlib/_local.py:724\\u001b[0m, in \\u001b[0;36mPath.mkdir\\u001b[0;34m(self, mode, parents, exist_ok)\\u001b[0m\\n\\u001b[1;32m    723\\u001b[0m \\u001b[38;5;28;01mtry\\u001b[39;00m:\\n\\u001b[0;32m--> 724\\u001b[0m     \\u001b[43mos\\u001b[49m\\u001b[38;5;241;43m.\\u001b[39;49m\\u001b[43mmkdir\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[38;5;28;43mself\\u001b[39;49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[43mmode\\u001b[49m\\u001b[43m)\\u001b[49m\\n\\u001b[1;32m    725\\u001b[0m \\u001b[38;5;28;01mexcept\\u001b[39;00m \\u001b[38;5;167;01mFileNotFoundError\\u001b[39;00m:\\n\",\n-                        \"\\u001b[0;31mFileNotFoundError\\u001b[0m: [Errno 2] No such file or directory: '/nonexistent/first-build/.local/share'\",\n+                        \"\\u001b[0;31mFileNotFoundError\\u001b[0m: [Errno 2] No such file or directory: '/nonexistent/second-build/.local/share'\",\n                         \"\\nDuring handling of the above exception, another exception occurred:\\n\",\n                         \"\\u001b[0;31mFileNotFoundError\\u001b[0m                         Traceback (most recent call last)\",\n                         \"File \\u001b[0;32m/usr/lib/python3.13/pathlib/_local.py:724\\u001b[0m, in \\u001b[0;36mPath.mkdir\\u001b[0;34m(self, mode, parents, exist_ok)\\u001b[0m\\n\\u001b[1;32m    723\\u001b[0m \\u001b[38;5;28;01mtry\\u001b[39;00m:\\n\\u001b[0;32m--> 724\\u001b[0m     \\u001b[43mos\\u001b[49m\\u001b[38;5;241;43m.\\u001b[39;49m\\u001b[43mmkdir\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[38;5;28;43mself\\u001b[39;49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[43mmode\\u001b[49m\\u001b[43m)\\u001b[49m\\n\\u001b[1;32m    725\\u001b[0m \\u001b[38;5;28;01mexcept\\u001b[39;00m \\u001b[38;5;167;01mFileNotFoundError\\u001b[39;00m:\\n\",\n-                        \"\\u001b[0;31mFileNotFoundError\\u001b[0m: [Errno 2] No such file or directory: '/nonexistent/first-build/.local'\",\n+                        \"\\u001b[0;31mFileNotFoundError\\u001b[0m: [Errno 2] No such file or directory: '/nonexistent/second-build/.local'\",\n                         \"\\nDuring handling of the above exception, another exception occurred:\\n\",\n                         \"\\u001b[0;31mFileNotFoundError\\u001b[0m                         Traceback (most recent call last)\",\n                         \"File \\u001b[0;32m/usr/lib/python3.13/pathlib/_local.py:724\\u001b[0m, in \\u001b[0;36mPath.mkdir\\u001b[0;34m(self, mode, parents, exist_ok)\\u001b[0m\\n\\u001b[1;32m    723\\u001b[0m \\u001b[38;5;28;01mtry\\u001b[39;00m:\\n\\u001b[0;32m--> 724\\u001b[0m     \\u001b[43mos\\u001b[49m\\u001b[38;5;241;43m.\\u001b[39;49m\\u001b[43mmkdir\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[38;5;28;43mself\\u001b[39;49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[43mmode\\u001b[49m\\u001b[43m)\\u001b[49m\\n\\u001b[1;32m    725\\u001b[0m \\u001b[38;5;28;01mexcept\\u001b[39;00m \\u001b[38;5;167;01mFileNotFoundError\\u001b[39;00m:\\n\",\n-                        \"\\u001b[0;31mFileNotFoundError\\u001b[0m: [Errno 2] No such file or directory: '/nonexistent/first-build'\",\n+                        \"\\u001b[0;31mFileNotFoundError\\u001b[0m: [Errno 2] No such file or directory: '/nonexistent/second-build'\",\n                         \"\\nDuring handling of the above exception, another exception occurred:\\n\",\n                         \"\\u001b[0;31mPermissionError\\u001b[0m                           Traceback (most recent call last)\",\n                         \"File \\u001b[0;32m/usr/lib/python3/dist-packages/IPython/core/formatters.py:402\\u001b[0m, in \\u001b[0;36mBaseFormatter.__call__\\u001b[0;34m(self, obj)\\u001b[0m\\n\\u001b[1;32m    400\\u001b[0m     \\u001b[38;5;28;01mpass\\u001b[39;00m\\n\\u001b[1;32m    401\\u001b[0m \\u001b[38;5;28;01melse\\u001b[39;00m:\\n\\u001b[0;32m--> 402\\u001b[0m     \\u001b[38;5;28;01mreturn\\u001b[39;00m \\u001b[43mprinter\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[43mobj\\u001b[49m\\u001b[43m)\\u001b[49m\\n\\u001b[1;32m    403\\u001b[0m \\u001b[38;5;66;03m# Finally look for special method names\\u001b[39;00m\\n\\u001b[1;32m    404\\u001b[0m method \\u001b[38;5;241m=\\u001b[39m get_real_method(obj, \\u001b[38;5;28mself\\u001b[39m\\u001b[38;5;241m.\\u001b[39mprint_method)\\n\",\n                         \"File \\u001b[0;32m/usr/lib/python3/dist-packages/IPython/core/pylabtools.py:170\\u001b[0m, in \\u001b[0;36mprint_figure\\u001b[0;34m(fig, fmt, bbox_inches, base64, **kwargs)\\u001b[0m\\n\\u001b[1;32m    167\\u001b[0m     \\u001b[38;5;28;01mfrom\\u001b[39;00m \\u001b[38;5;21;01mmatplotlib\\u001b[39;00m\\u001b[38;5;21;01m.\\u001b[39;00m\\u001b[38;5;21;01mbackend_bases\\u001b[39;00m \\u001b[38;5;28;01mimport\\u001b[39;00m FigureCanvasBase\\n\\u001b[1;32m    168\\u001b[0m     FigureCanvasBase(fig)\\n\\u001b[0;32m--> 170\\u001b[0m \\u001b[43mfig\\u001b[49m\\u001b[38;5;241;43m.\\u001b[39;49m\\u001b[43mcanvas\\u001b[49m\\u001b[38;5;241;43m.\\u001b[39;49m\\u001b[43mprint_figure\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[43mbytes_io\\u001b[49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[38;5;241;43m*\\u001b[39;49m\\u001b[38;5;241;43m*\\u001b[39;49m\\u001b[43mkw\\u001b[49m\\u001b[43m)\\u001b[49m\\n\\u001b[1;32m    171\\u001b[0m data \\u001b[38;5;241m=\\u001b[39m bytes_io\\u001b[38;5;241m.\\u001b[39mgetvalue()\\n\\u001b[1;32m    172\\u001b[0m \\u001b[38;5;28;01mif\\u001b[39;00m fmt \\u001b[38;5;241m==\\u001b[39m \\u001b[38;5;124m'\\u001b[39m\\u001b[38;5;124msvg\\u001b[39m\\u001b[38;5;124m'\\u001b[39m:\\n\",\n                         \"File \\u001b[0;32m/usr/lib/python3/dist-packages/matplotlib/backend_bases.py:2164\\u001b[0m, in \\u001b[0;36mFigureCanvasBase.print_figure\\u001b[0;34m(self, filename, dpi, facecolor, edgecolor, orientation, format, bbox_inches, pad_inches, bbox_extra_artists, backend, **kwargs)\\u001b[0m\\n\\u001b[1;32m   2161\\u001b[0m     \\u001b[38;5;66;03m# we do this instead of `self.figure.draw_without_rendering`\\u001b[39;00m\\n\\u001b[1;32m   2162\\u001b[0m     \\u001b[38;5;66;03m# so that we can inject the orientation\\u001b[39;00m\\n\\u001b[1;32m   2163\\u001b[0m     \\u001b[38;5;28;01mwith\\u001b[39;00m \\u001b[38;5;28mgetattr\\u001b[39m(renderer, \\u001b[38;5;124m\\\"\\u001b[39m\\u001b[38;5;124m_draw_disabled\\u001b[39m\\u001b[38;5;124m\\\"\\u001b[39m, nullcontext)():\\n\\u001b[0;32m-> 2164\\u001b[0m         \\u001b[38;5;28;43mself\\u001b[39;49m\\u001b[38;5;241;43m.\\u001b[39;49m\\u001b[43mfigure\\u001b[49m\\u001b[38;5;241;43m.\\u001b[39;49m\\u001b[43mdraw\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[43mrenderer\\u001b[49m\\u001b[43m)\\u001b[49m\\n\\u001b[1;32m   2165\\u001b[0m \\u001b[38;5;28;01mif\\u001b[39;00m bbox_inches:\\n\\u001b[1;32m   2166\\u001b[0m     \\u001b[38;5;28;01mif\\u001b[39;00m bbox_inches \\u001b[38;5;241m==\\u001b[39m \\u001b[38;5;124m\\\"\\u001b[39m\\u001b[38;5;124mtight\\u001b[39m\\u001b[38;5;124m\\\"\\u001b[39m:\\n\",\n                         \"File \\u001b[0;32m/usr/lib/python3/dist-packages/matplotlib/artist.py:95\\u001b[0m, in \\u001b[0;36m_finalize_rasterization..draw_wrapper\\u001b[0;34m(artist, renderer, *args, **kwargs)\\u001b[0m\\n\\u001b[1;32m     93\\u001b[0m \\u001b[38;5;129m@wraps\\u001b[39m(draw)\\n\\u001b[1;32m     94\\u001b[0m \\u001b[38;5;28;01mdef\\u001b[39;00m \\u001b[38;5;21mdraw_wrapper\\u001b[39m(artist, renderer, \\u001b[38;5;241m*\\u001b[39margs, \\u001b[38;5;241m*\\u001b[39m\\u001b[38;5;241m*\\u001b[39mkwargs):\\n\\u001b[0;32m---> 95\\u001b[0m     result \\u001b[38;5;241m=\\u001b[39m \\u001b[43mdraw\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[43martist\\u001b[49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[43mrenderer\\u001b[49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[38;5;241;43m*\\u001b[39;49m\\u001b[43margs\\u001b[49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[38;5;241;43m*\\u001b[39;49m\\u001b[38;5;241;43m*\\u001b[39;49m\\u001b[43mkwargs\\u001b[49m\\u001b[43m)\\u001b[49m\\n\\u001b[1;32m     96\\u001b[0m     \\u001b[38;5;28;01mif\\u001b[39;00m renderer\\u001b[38;5;241m.\\u001b[39m_rasterizing:\\n\\u001b[1;32m     97\\u001b[0m         renderer\\u001b[38;5;241m.\\u001b[39mstop_rasterizing()\\n\",\n                         \"File \\u001b[0;32m/usr/lib/python3/dist-packages/matplotlib/artist.py:72\\u001b[0m, in \\u001b[0;36mallow_rasterization..draw_wrapper\\u001b[0;34m(artist, renderer)\\u001b[0m\\n\\u001b[1;32m     69\\u001b[0m     \\u001b[38;5;28;01mif\\u001b[39;00m artist\\u001b[38;5;241m.\\u001b[39mget_agg_filter() \\u001b[38;5;129;01mis\\u001b[39;00m \\u001b[38;5;129;01mnot\\u001b[39;00m \\u001b[38;5;28;01mNone\\u001b[39;00m:\\n\\u001b[1;32m     70\\u001b[0m         renderer\\u001b[38;5;241m.\\u001b[39mstart_filter()\\n\\u001b[0;32m---> 72\\u001b[0m     \\u001b[38;5;28;01mreturn\\u001b[39;00m \\u001b[43mdraw\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[43martist\\u001b[49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[43mrenderer\\u001b[49m\\u001b[43m)\\u001b[49m\\n\\u001b[1;32m     73\\u001b[0m \\u001b[38;5;28;01mfinally\\u001b[39;00m:\\n\\u001b[1;32m     74\\u001b[0m     \\u001b[38;5;28;01mif\\u001b[39;00m artist\\u001b[38;5;241m.\\u001b[39mget_agg_filter() \\u001b[38;5;129;01mis\\u001b[39;00m \\u001b[38;5;129;01mnot\\u001b[39;00m \\u001b[38;5;28;01mNone\\u001b[39;00m:\\n\",\n@@ -317,18 +317,18 @@\n             ]\n         },\n         {\n             \"cell_type\": \"code\",\n             \"execution_count\": 5,\n             \"metadata\": {\n                 \"execution\": {\n-                    \"iopub.execute_input\": \"2026-04-07T09:26:55.005343Z\",\n-                    \"iopub.status.busy\": \"2026-04-07T09:26:55.005099Z\",\n-                    \"iopub.status.idle\": \"2026-04-07T09:26:55.018332Z\",\n-                    \"shell.execute_reply\": \"2026-04-07T09:26:55.017774Z\"\n+                    \"iopub.execute_input\": \"2025-03-05T03:35:44.593467Z\",\n+                    \"iopub.status.busy\": \"2025-03-05T03:35:44.593000Z\",\n+                    \"iopub.status.idle\": \"2025-03-05T03:35:44.711879Z\",\n+                    \"shell.execute_reply\": \"2025-03-05T03:35:44.695883Z\"\n                 }\n             },\n             \"outputs\": [\n                 {\n                     \"ename\": \"NameError\",\n                     \"evalue\": \"name 'ds' is not defined\",\n                     \"output_type\": \"error\",\n"}]}]}, {"source1": "./usr/share/doc/python-xarray-doc/html/examples/ROMS_ocean_model.html", "source2": "./usr/share/doc/python-xarray-doc/html/examples/ROMS_ocean_model.html", "unified_diff": "@@ -191,15 +191,15 @@\n File /usr/lib/python3/dist-packages/pooch/utils.py:276, in make_local_storage(path, env)\n     272 if env is not None:\n     273     message.append(\n     274         f"Use environment variable '{env}' to specify a different location."\n     275     )\n --> 276 raise PermissionError(" ".join(message)) from error\n \n-PermissionError: [Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/first-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\n+PermissionError: [Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/second-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\n 
\n
\n \n
\n

Add a lazilly calculated vertical coordinates\u00b6

\n

Write equations to calculate the vertical coordinate. These will be only evaluated when data is requested. Information about the ROMS vertical coordinate can be found (here)[https://www.myroms.org/wiki/Vertical_S-coordinate]

\n

In short, for Vtransform==2 as used in this example,

\n", "details": [{"source1": "html2text {}", "source2": "html2text {}", "unified_diff": "@@ -131,15 +131,15 @@\n 273 message.append(\n 274 f\"Use environment variable '{env}' to specify a different\n location.\"\n 275 )\n --> 276 raise PermissionError(\" \".join(message)) from error\n \n PermissionError: [Errno 13] Permission denied: '/nonexistent' | Pooch could not\n-create data cache folder '/nonexistent/first-build/.cache/\n+create data cache folder '/nonexistent/second-build/.cache/\n xarray_tutorial_data'. Will not be able to download data files.\n *\b**\b**\b**\b**\b* A\bAd\bdd\bd a\ba l\bla\baz\bzi\bil\bll\bly\by c\bca\bal\blc\bcu\bul\bla\bat\bte\bed\bd v\bve\ber\brt\bti\bic\bca\bal\bl c\bco\boo\bor\brd\bdi\bin\bna\bat\bte\bes\bs_\b?\b\u00b6 *\b**\b**\b**\b**\b*\n Write equations to calculate the vertical coordinate. These will be only\n evaluated when data is requested. Information about the ROMS vertical\n coordinate can be found (here)[_\bh_\bt_\bt_\bp_\bs_\b:_\b/_\b/_\bw_\bw_\bw_\b._\bm_\by_\br_\bo_\bm_\bs_\b._\bo_\br_\bg_\b/_\bw_\bi_\bk_\bi_\b/_\bV_\be_\br_\bt_\bi_\bc_\ba_\bl_\b__\bS_\b-\n _\bc_\bo_\bo_\br_\bd_\bi_\bn_\ba_\bt_\be]\n In short, for Vtransform==2 as used in this example,\n"}]}, {"source1": "./usr/share/doc/python-xarray-doc/html/examples/ROMS_ocean_model.ipynb.gz", "source2": "./usr/share/doc/python-xarray-doc/html/examples/ROMS_ocean_model.ipynb.gz", "unified_diff": null, "details": [{"source1": "ROMS_ocean_model.ipynb", "source2": "ROMS_ocean_model.ipynb", "unified_diff": null, "details": [{"source1": "Pretty-printed", "source2": "Pretty-printed", "comments": ["Similarity: 0.9987017463235294%", "Differences: {\"'cells'\": \"{2: {'metadata': {'execution': {'iopub.execute_input': '2025-03-05T03:35:54.589678Z', \"", " \"'iopub.status.busy': '2025-03-05T03:35:54.589140Z', 'iopub.status.idle': \"", " \"'2025-03-05T03:35:57.849116Z', 'shell.execute_reply': \"", " \"'2025-03-05T03:35:57.847595Z'}}}, 5: {'metadata': {'execution': \"", " \"{'iopub.execute_input': '2025-03-05T03:35:57.861941Z', 'iopub.status.busy': \"", " \"'2025-03-05T03:35:57.861167Z', 'iopub.status.idle': '2025-03-05T03:35:5 [\u2026]"], "unified_diff": "@@ -17,18 +17,18 @@\n ]\n },\n {\n \"cell_type\": \"code\",\n \"execution_count\": 1,\n \"metadata\": {\n \"execution\": {\n- \"iopub.execute_input\": \"2026-04-07T09:26:57.574412Z\",\n- \"iopub.status.busy\": \"2026-04-07T09:26:57.574170Z\",\n- \"iopub.status.idle\": \"2026-04-07T09:26:58.464131Z\",\n- \"shell.execute_reply\": \"2026-04-07T09:26:58.463472Z\"\n+ \"iopub.execute_input\": \"2025-03-05T03:35:54.589678Z\",\n+ \"iopub.status.busy\": \"2025-03-05T03:35:54.589140Z\",\n+ \"iopub.status.idle\": \"2025-03-05T03:35:57.849116Z\",\n+ \"shell.execute_reply\": \"2025-03-05T03:35:57.847595Z\"\n }\n },\n \"outputs\": [],\n \"source\": [\n \"import numpy as np\\n\",\n \"import cartopy.crs as ccrs\\n\",\n \"import cartopy.feature as cfeature\\n\",\n@@ -75,24 +75,24 @@\n ]\n },\n {\n \"cell_type\": \"code\",\n \"execution_count\": 2,\n \"metadata\": {\n \"execution\": {\n- \"iopub.execute_input\": \"2026-04-07T09:26:58.467024Z\",\n- \"iopub.status.busy\": \"2026-04-07T09:26:58.466625Z\",\n- \"iopub.status.idle\": \"2026-04-07T09:26:58.752333Z\",\n- \"shell.execute_reply\": \"2026-04-07T09:26:58.751672Z\"\n+ \"iopub.execute_input\": \"2025-03-05T03:35:57.861941Z\",\n+ \"iopub.status.busy\": \"2025-03-05T03:35:57.861167Z\",\n+ \"iopub.status.idle\": \"2025-03-05T03:35:59.004141Z\",\n+ \"shell.execute_reply\": \"2025-03-05T03:35:58.988658Z\"\n }\n },\n \"outputs\": [\n {\n \"ename\": \"PermissionError\",\n- \"evalue\": \"[Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/first-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\",\n+ \"evalue\": \"[Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/second-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\",\n \"output_type\": \"error\",\n \"traceback\": [\n \"\\u001b[0;31m---------------------------------------------------------------------------\\u001b[0m\",\n \"\\u001b[0;31mPermissionError\\u001b[0m Traceback (most recent call last)\",\n \"File \\u001b[0;32m/usr/lib/python3/dist-packages/pooch/utils.py:262\\u001b[0m, in \\u001b[0;36mmake_local_storage\\u001b[0;34m(path, env)\\u001b[0m\\n\\u001b[1;32m 258\\u001b[0m \\u001b[38;5;28;01mif\\u001b[39;00m action \\u001b[38;5;241m==\\u001b[39m \\u001b[38;5;124m\\\"\\u001b[39m\\u001b[38;5;124mcreate\\u001b[39m\\u001b[38;5;124m\\\"\\u001b[39m:\\n\\u001b[1;32m 259\\u001b[0m \\u001b[38;5;66;03m# When running in parallel, it's possible that multiple jobs will\\u001b[39;00m\\n\\u001b[1;32m 260\\u001b[0m \\u001b[38;5;66;03m# try to create the path at the same time. Use exist_ok to avoid\\u001b[39;00m\\n\\u001b[1;32m 261\\u001b[0m \\u001b[38;5;66;03m# raising an error.\\u001b[39;00m\\n\\u001b[0;32m--> 262\\u001b[0m \\u001b[43mos\\u001b[49m\\u001b[38;5;241;43m.\\u001b[39;49m\\u001b[43mmakedirs\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[43mpath\\u001b[49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[43mexist_ok\\u001b[49m\\u001b[38;5;241;43m=\\u001b[39;49m\\u001b[38;5;28;43;01mTrue\\u001b[39;49;00m\\u001b[43m)\\u001b[49m\\n\\u001b[1;32m 263\\u001b[0m \\u001b[38;5;28;01melse\\u001b[39;00m:\\n\",\n \"File \\u001b[0;32m/usr/lib/python3.13/os.py:217\\u001b[0m, in \\u001b[0;36mmakedirs\\u001b[0;34m(name, mode, exist_ok)\\u001b[0m\\n\\u001b[1;32m 216\\u001b[0m \\u001b[38;5;28;01mtry\\u001b[39;00m:\\n\\u001b[0;32m--> 217\\u001b[0m \\u001b[43mmakedirs\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[43mhead\\u001b[49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[43mexist_ok\\u001b[49m\\u001b[38;5;241;43m=\\u001b[39;49m\\u001b[43mexist_ok\\u001b[49m\\u001b[43m)\\u001b[49m\\n\\u001b[1;32m 218\\u001b[0m \\u001b[38;5;28;01mexcept\\u001b[39;00m \\u001b[38;5;167;01mFileExistsError\\u001b[39;00m:\\n\\u001b[1;32m 219\\u001b[0m \\u001b[38;5;66;03m# Defeats race condition when another thread created the path\\u001b[39;00m\\n\",\n \"File \\u001b[0;32m/usr/lib/python3.13/os.py:217\\u001b[0m, in \\u001b[0;36mmakedirs\\u001b[0;34m(name, mode, exist_ok)\\u001b[0m\\n\\u001b[1;32m 216\\u001b[0m \\u001b[38;5;28;01mtry\\u001b[39;00m:\\n\\u001b[0;32m--> 217\\u001b[0m \\u001b[43mmakedirs\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[43mhead\\u001b[49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[43mexist_ok\\u001b[49m\\u001b[38;5;241;43m=\\u001b[39;49m\\u001b[43mexist_ok\\u001b[49m\\u001b[43m)\\u001b[49m\\n\\u001b[1;32m 218\\u001b[0m \\u001b[38;5;28;01mexcept\\u001b[39;00m \\u001b[38;5;167;01mFileExistsError\\u001b[39;00m:\\n\\u001b[1;32m 219\\u001b[0m \\u001b[38;5;66;03m# Defeats race condition when another thread created the path\\u001b[39;00m\\n\",\n@@ -101,15 +101,15 @@\n \"\\u001b[0;31mPermissionError\\u001b[0m: [Errno 13] Permission denied: '/nonexistent'\",\n \"\\nThe above exception was the direct cause of the following exception:\\n\",\n \"\\u001b[0;31mPermissionError\\u001b[0m Traceback (most recent call last)\",\n \"Cell \\u001b[0;32mIn[2], line 2\\u001b[0m\\n\\u001b[1;32m 1\\u001b[0m \\u001b[38;5;66;03m# load in the file\\u001b[39;00m\\n\\u001b[0;32m----> 2\\u001b[0m ds \\u001b[38;5;241m=\\u001b[39m \\u001b[43mxr\\u001b[49m\\u001b[38;5;241;43m.\\u001b[39;49m\\u001b[43mtutorial\\u001b[49m\\u001b[38;5;241;43m.\\u001b[39;49m\\u001b[43mopen_dataset\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[38;5;124;43m\\\"\\u001b[39;49m\\u001b[38;5;124;43mROMS_example.nc\\u001b[39;49m\\u001b[38;5;124;43m\\\"\\u001b[39;49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[43mchunks\\u001b[49m\\u001b[38;5;241;43m=\\u001b[39;49m\\u001b[43m{\\u001b[49m\\u001b[38;5;124;43m\\\"\\u001b[39;49m\\u001b[38;5;124;43mocean_time\\u001b[39;49m\\u001b[38;5;124;43m\\\"\\u001b[39;49m\\u001b[43m:\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[38;5;241;43m1\\u001b[39;49m\\u001b[43m}\\u001b[49m\\u001b[43m)\\u001b[49m\\n\\u001b[1;32m 4\\u001b[0m \\u001b[38;5;66;03m# This is a way to turn on chunking and lazy evaluation. Opening with mfdataset, or\\u001b[39;00m\\n\\u001b[1;32m 5\\u001b[0m \\u001b[38;5;66;03m# setting the chunking in the open_dataset would also achieve this.\\u001b[39;00m\\n\\u001b[1;32m 6\\u001b[0m ds\\n\",\n \"File \\u001b[0;32m/usr/lib/python3/dist-packages/xarray/tutorial.py:165\\u001b[0m, in \\u001b[0;36mopen_dataset\\u001b[0;34m(name, cache, cache_dir, engine, **kws)\\u001b[0m\\n\\u001b[1;32m 162\\u001b[0m downloader \\u001b[38;5;241m=\\u001b[39m pooch\\u001b[38;5;241m.\\u001b[39mHTTPDownloader(headers\\u001b[38;5;241m=\\u001b[39mheaders)\\n\\u001b[1;32m 164\\u001b[0m \\u001b[38;5;66;03m# retrieve the file\\u001b[39;00m\\n\\u001b[0;32m--> 165\\u001b[0m filepath \\u001b[38;5;241m=\\u001b[39m \\u001b[43mpooch\\u001b[49m\\u001b[38;5;241;43m.\\u001b[39;49m\\u001b[43mretrieve\\u001b[49m\\u001b[43m(\\u001b[49m\\n\\u001b[1;32m 166\\u001b[0m \\u001b[43m \\u001b[49m\\u001b[43murl\\u001b[49m\\u001b[38;5;241;43m=\\u001b[39;49m\\u001b[43murl\\u001b[49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[43mknown_hash\\u001b[49m\\u001b[38;5;241;43m=\\u001b[39;49m\\u001b[38;5;28;43;01mNone\\u001b[39;49;00m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[43mpath\\u001b[49m\\u001b[38;5;241;43m=\\u001b[39;49m\\u001b[43mcache_dir\\u001b[49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[43mdownloader\\u001b[49m\\u001b[38;5;241;43m=\\u001b[39;49m\\u001b[43mdownloader\\u001b[49m\\n\\u001b[1;32m 167\\u001b[0m \\u001b[43m\\u001b[49m\\u001b[43m)\\u001b[49m\\n\\u001b[1;32m 168\\u001b[0m ds \\u001b[38;5;241m=\\u001b[39m _open_dataset(filepath, engine\\u001b[38;5;241m=\\u001b[39mengine, \\u001b[38;5;241m*\\u001b[39m\\u001b[38;5;241m*\\u001b[39mkws)\\n\\u001b[1;32m 169\\u001b[0m \\u001b[38;5;28;01mif\\u001b[39;00m \\u001b[38;5;129;01mnot\\u001b[39;00m cache:\\n\",\n \"File \\u001b[0;32m/usr/lib/python3/dist-packages/pooch/core.py:227\\u001b[0m, in \\u001b[0;36mretrieve\\u001b[0;34m(url, known_hash, fname, path, processor, downloader, progressbar)\\u001b[0m\\n\\u001b[1;32m 222\\u001b[0m action, verb \\u001b[38;5;241m=\\u001b[39m download_action(full_path, known_hash)\\n\\u001b[1;32m 224\\u001b[0m \\u001b[38;5;28;01mif\\u001b[39;00m action \\u001b[38;5;129;01min\\u001b[39;00m (\\u001b[38;5;124m\\\"\\u001b[39m\\u001b[38;5;124mdownload\\u001b[39m\\u001b[38;5;124m\\\"\\u001b[39m, \\u001b[38;5;124m\\\"\\u001b[39m\\u001b[38;5;124mupdate\\u001b[39m\\u001b[38;5;124m\\\"\\u001b[39m):\\n\\u001b[1;32m 225\\u001b[0m \\u001b[38;5;66;03m# We need to write data, so create the local data directory if it\\u001b[39;00m\\n\\u001b[1;32m 226\\u001b[0m \\u001b[38;5;66;03m# doesn't already exist.\\u001b[39;00m\\n\\u001b[0;32m--> 227\\u001b[0m \\u001b[43mmake_local_storage\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[43mpath\\u001b[49m\\u001b[43m)\\u001b[49m\\n\\u001b[1;32m 229\\u001b[0m get_logger()\\u001b[38;5;241m.\\u001b[39minfo(\\n\\u001b[1;32m 230\\u001b[0m \\u001b[38;5;124m\\\"\\u001b[39m\\u001b[38;5;132;01m%s\\u001b[39;00m\\u001b[38;5;124m data from \\u001b[39m\\u001b[38;5;124m'\\u001b[39m\\u001b[38;5;132;01m%s\\u001b[39;00m\\u001b[38;5;124m'\\u001b[39m\\u001b[38;5;124m to file \\u001b[39m\\u001b[38;5;124m'\\u001b[39m\\u001b[38;5;132;01m%s\\u001b[39;00m\\u001b[38;5;124m'\\u001b[39m\\u001b[38;5;124m.\\u001b[39m\\u001b[38;5;124m\\\"\\u001b[39m,\\n\\u001b[1;32m 231\\u001b[0m verb,\\n\\u001b[1;32m 232\\u001b[0m url,\\n\\u001b[1;32m 233\\u001b[0m \\u001b[38;5;28mstr\\u001b[39m(full_path),\\n\\u001b[1;32m 234\\u001b[0m )\\n\\u001b[1;32m 236\\u001b[0m \\u001b[38;5;28;01mif\\u001b[39;00m downloader \\u001b[38;5;129;01mis\\u001b[39;00m \\u001b[38;5;28;01mNone\\u001b[39;00m:\\n\",\n \"File \\u001b[0;32m/usr/lib/python3/dist-packages/pooch/utils.py:276\\u001b[0m, in \\u001b[0;36mmake_local_storage\\u001b[0;34m(path, env)\\u001b[0m\\n\\u001b[1;32m 272\\u001b[0m \\u001b[38;5;28;01mif\\u001b[39;00m env \\u001b[38;5;129;01mis\\u001b[39;00m \\u001b[38;5;129;01mnot\\u001b[39;00m \\u001b[38;5;28;01mNone\\u001b[39;00m:\\n\\u001b[1;32m 273\\u001b[0m message\\u001b[38;5;241m.\\u001b[39mappend(\\n\\u001b[1;32m 274\\u001b[0m \\u001b[38;5;124mf\\u001b[39m\\u001b[38;5;124m\\\"\\u001b[39m\\u001b[38;5;124mUse environment variable \\u001b[39m\\u001b[38;5;124m'\\u001b[39m\\u001b[38;5;132;01m{\\u001b[39;00menv\\u001b[38;5;132;01m}\\u001b[39;00m\\u001b[38;5;124m'\\u001b[39m\\u001b[38;5;124m to specify a different location.\\u001b[39m\\u001b[38;5;124m\\\"\\u001b[39m\\n\\u001b[1;32m 275\\u001b[0m )\\n\\u001b[0;32m--> 276\\u001b[0m \\u001b[38;5;28;01mraise\\u001b[39;00m \\u001b[38;5;167;01mPermissionError\\u001b[39;00m(\\u001b[38;5;124m\\\"\\u001b[39m\\u001b[38;5;124m \\u001b[39m\\u001b[38;5;124m\\\"\\u001b[39m\\u001b[38;5;241m.\\u001b[39mjoin(message)) \\u001b[38;5;28;01mfrom\\u001b[39;00m \\u001b[38;5;21;01merror\\u001b[39;00m\\n\",\n- \"\\u001b[0;31mPermissionError\\u001b[0m: [Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/first-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\"\n+ \"\\u001b[0;31mPermissionError\\u001b[0m: [Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/second-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\"\n ]\n }\n ],\n \"source\": [\n \"# load in the file\\n\",\n \"ds = xr.tutorial.open_dataset(\\\"ROMS_example.nc\\\", chunks={\\\"ocean_time\\\": 1})\\n\",\n \"\\n\",\n@@ -136,18 +136,18 @@\n ]\n },\n {\n \"cell_type\": \"code\",\n \"execution_count\": 3,\n \"metadata\": {\n \"execution\": {\n- \"iopub.execute_input\": \"2026-04-07T09:26:58.754801Z\",\n- \"iopub.status.busy\": \"2026-04-07T09:26:58.754558Z\",\n- \"iopub.status.idle\": \"2026-04-07T09:26:58.773700Z\",\n- \"shell.execute_reply\": \"2026-04-07T09:26:58.773051Z\"\n+ \"iopub.execute_input\": \"2025-03-05T03:35:59.030525Z\",\n+ \"iopub.status.busy\": \"2025-03-05T03:35:59.029910Z\",\n+ \"iopub.status.idle\": \"2025-03-05T03:35:59.175950Z\",\n+ \"shell.execute_reply\": \"2025-03-05T03:35:59.159948Z\"\n }\n },\n \"outputs\": [\n {\n \"ename\": \"NameError\",\n \"evalue\": \"name 'ds' is not defined\",\n \"output_type\": \"error\",\n@@ -181,18 +181,18 @@\n ]\n },\n {\n \"cell_type\": \"code\",\n \"execution_count\": 4,\n \"metadata\": {\n \"execution\": {\n- \"iopub.execute_input\": \"2026-04-07T09:26:58.776396Z\",\n- \"iopub.status.busy\": \"2026-04-07T09:26:58.776152Z\",\n- \"iopub.status.idle\": \"2026-04-07T09:26:58.789073Z\",\n- \"shell.execute_reply\": \"2026-04-07T09:26:58.788509Z\"\n+ \"iopub.execute_input\": \"2025-03-05T03:35:59.205989Z\",\n+ \"iopub.status.busy\": \"2025-03-05T03:35:59.205322Z\",\n+ \"iopub.status.idle\": \"2025-03-05T03:35:59.319903Z\",\n+ \"shell.execute_reply\": \"2025-03-05T03:35:59.304727Z\"\n },\n \"scrolled\": false\n },\n \"outputs\": [\n {\n \"ename\": \"NameError\",\n \"evalue\": \"name 'ds' is not defined\",\n@@ -217,18 +217,18 @@\n ]\n },\n {\n \"cell_type\": \"code\",\n \"execution_count\": 5,\n \"metadata\": {\n \"execution\": {\n- \"iopub.execute_input\": \"2026-04-07T09:26:58.791600Z\",\n- \"iopub.status.busy\": \"2026-04-07T09:26:58.791358Z\",\n- \"iopub.status.idle\": \"2026-04-07T09:26:58.805265Z\",\n- \"shell.execute_reply\": \"2026-04-07T09:26:58.804679Z\"\n+ \"iopub.execute_input\": \"2025-03-05T03:35:59.349691Z\",\n+ \"iopub.status.busy\": \"2025-03-05T03:35:59.348898Z\",\n+ \"iopub.status.idle\": \"2025-03-05T03:35:59.484462Z\",\n+ \"shell.execute_reply\": \"2025-03-05T03:35:59.468233Z\"\n }\n },\n \"outputs\": [\n {\n \"ename\": \"NameError\",\n \"evalue\": \"name 'ds' is not defined\",\n \"output_type\": \"error\",\n@@ -256,18 +256,18 @@\n ]\n },\n {\n \"cell_type\": \"code\",\n \"execution_count\": 6,\n \"metadata\": {\n \"execution\": {\n- \"iopub.execute_input\": \"2026-04-07T09:26:58.807700Z\",\n- \"iopub.status.busy\": \"2026-04-07T09:26:58.807463Z\",\n- \"iopub.status.idle\": \"2026-04-07T09:26:58.819754Z\",\n- \"shell.execute_reply\": \"2026-04-07T09:26:58.819208Z\"\n+ \"iopub.execute_input\": \"2025-03-05T03:35:59.506504Z\",\n+ \"iopub.status.busy\": \"2025-03-05T03:35:59.505749Z\",\n+ \"iopub.status.idle\": \"2025-03-05T03:35:59.644377Z\",\n+ \"shell.execute_reply\": \"2025-03-05T03:35:59.627927Z\"\n }\n },\n \"outputs\": [\n {\n \"ename\": \"NameError\",\n \"evalue\": \"name 'ds' is not defined\",\n \"output_type\": \"error\",\n@@ -291,18 +291,18 @@\n ]\n },\n {\n \"cell_type\": \"code\",\n \"execution_count\": 7,\n \"metadata\": {\n \"execution\": {\n- \"iopub.execute_input\": \"2026-04-07T09:26:58.822005Z\",\n- \"iopub.status.busy\": \"2026-04-07T09:26:58.821728Z\",\n- \"iopub.status.idle\": \"2026-04-07T09:26:58.910775Z\",\n- \"shell.execute_reply\": \"2026-04-07T09:26:58.910193Z\"\n+ \"iopub.execute_input\": \"2025-03-05T03:35:59.666426Z\",\n+ \"iopub.status.busy\": \"2025-03-05T03:35:59.665863Z\",\n+ \"iopub.status.idle\": \"2025-03-05T03:36:00.300134Z\",\n+ \"shell.execute_reply\": \"2025-03-05T03:36:00.284413Z\"\n }\n },\n \"outputs\": [\n {\n \"ename\": \"NameError\",\n \"evalue\": \"name 'ds' is not defined\",\n \"output_type\": \"error\",\n"}]}]}, {"source1": "./usr/share/doc/python-xarray-doc/html/examples/apply_ufunc_vectorize_1d.html", "source2": "./usr/share/doc/python-xarray-doc/html/examples/apply_ufunc_vectorize_1d.html", "unified_diff": "@@ -185,15 +185,15 @@\n File /usr/lib/python3/dist-packages/pooch/utils.py:276, in make_local_storage(path, env)\n 272 if env is not None:\n 273 message.append(\n 274 f"Use environment variable '{env}' to specify a different location."\n 275 )\n --> 276 raise PermissionError(" ".join(message)) from error\n \n-PermissionError: [Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/first-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\n+PermissionError: [Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/second-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\n \n \n

The function we will apply is np.interp which expects 1D numpy arrays. This functionality is already implemented in xarray so we use that capability to make sure we are not making mistakes.

\n
\n
[2]:\n 
\n
\n", "details": [{"source1": "html2text {}", "source2": "html2text {}", "unified_diff": "@@ -123,15 +123,15 @@\n 273 message.append(\n 274 f\"Use environment variable '{env}' to specify a different\n location.\"\n 275 )\n --> 276 raise PermissionError(\" \".join(message)) from error\n \n PermissionError: [Errno 13] Permission denied: '/nonexistent' | Pooch could not\n-create data cache folder '/nonexistent/first-build/.cache/\n+create data cache folder '/nonexistent/second-build/.cache/\n xarray_tutorial_data'. Will not be able to download data files.\n The function we will apply is np.interp which expects 1D numpy arrays. This\n functionality is already implemented in xarray so we use that capability to\n make sure we are not making mistakes.\n [2]:\n newlat = np.linspace(15, 75, 100)\n air.interp(lat=newlat)\n"}]}, {"source1": "./usr/share/doc/python-xarray-doc/html/examples/apply_ufunc_vectorize_1d.ipynb.gz", "source2": "./usr/share/doc/python-xarray-doc/html/examples/apply_ufunc_vectorize_1d.ipynb.gz", "unified_diff": null, "details": [{"source1": "apply_ufunc_vectorize_1d.ipynb", "source2": "apply_ufunc_vectorize_1d.ipynb", "unified_diff": null, "details": [{"source1": "Pretty-printed", "source2": "Pretty-printed", "comments": ["Similarity: 0.9993857604017217%", "Differences: {\"'cells'\": \"{2: {'metadata': {'execution': {'iopub.execute_input': '2025-03-05T03:36:07.310946Z', \"", " \"'iopub.status.busy': '2025-03-05T03:36:07.310396Z', 'iopub.status.idle': \"", " \"'2025-03-05T03:36:09.505849Z', 'shell.execute_reply': \"", " '\\'2025-03-05T03:36:09.504070Z\\'}}, \\'outputs\\': {0: {\\'evalue\\': \"[Errno 13] '", " \"Permission denied: '/nonexistent' | Pooch could not create data cache folder \"", " \"'/nonexistent/second-build/.cache/xarray_tutorial_data'. [\u2026]"], "unified_diff": "@@ -36,24 +36,24 @@\n \"execution_count\": 1,\n \"metadata\": {\n \"ExecuteTime\": {\n \"end_time\": \"2020-01-15T14:45:51.659160Z\",\n \"start_time\": \"2020-01-15T14:45:50.528742Z\"\n },\n \"execution\": {\n- \"iopub.execute_input\": \"2026-04-07T09:27:00.821767Z\",\n- \"iopub.status.busy\": \"2026-04-07T09:27:00.821517Z\",\n- \"iopub.status.idle\": \"2026-04-07T09:27:01.530436Z\",\n- \"shell.execute_reply\": \"2026-04-07T09:27:01.529738Z\"\n+ \"iopub.execute_input\": \"2025-03-05T03:36:07.310946Z\",\n+ \"iopub.status.busy\": \"2025-03-05T03:36:07.310396Z\",\n+ \"iopub.status.idle\": \"2025-03-05T03:36:09.505849Z\",\n+ \"shell.execute_reply\": \"2025-03-05T03:36:09.504070Z\"\n }\n },\n \"outputs\": [\n {\n \"ename\": \"PermissionError\",\n- \"evalue\": \"[Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/first-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\",\n+ \"evalue\": \"[Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/second-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\",\n \"output_type\": \"error\",\n \"traceback\": [\n \"\\u001b[0;31m---------------------------------------------------------------------------\\u001b[0m\",\n \"\\u001b[0;31mPermissionError\\u001b[0m Traceback (most recent call last)\",\n \"File \\u001b[0;32m/usr/lib/python3/dist-packages/pooch/utils.py:262\\u001b[0m, in \\u001b[0;36mmake_local_storage\\u001b[0;34m(path, env)\\u001b[0m\\n\\u001b[1;32m 258\\u001b[0m \\u001b[38;5;28;01mif\\u001b[39;00m action \\u001b[38;5;241m==\\u001b[39m \\u001b[38;5;124m\\\"\\u001b[39m\\u001b[38;5;124mcreate\\u001b[39m\\u001b[38;5;124m\\\"\\u001b[39m:\\n\\u001b[1;32m 259\\u001b[0m \\u001b[38;5;66;03m# When running in parallel, it's possible that multiple jobs will\\u001b[39;00m\\n\\u001b[1;32m 260\\u001b[0m \\u001b[38;5;66;03m# try to create the path at the same time. Use exist_ok to avoid\\u001b[39;00m\\n\\u001b[1;32m 261\\u001b[0m \\u001b[38;5;66;03m# raising an error.\\u001b[39;00m\\n\\u001b[0;32m--> 262\\u001b[0m \\u001b[43mos\\u001b[49m\\u001b[38;5;241;43m.\\u001b[39;49m\\u001b[43mmakedirs\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[43mpath\\u001b[49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[43mexist_ok\\u001b[49m\\u001b[38;5;241;43m=\\u001b[39;49m\\u001b[38;5;28;43;01mTrue\\u001b[39;49;00m\\u001b[43m)\\u001b[49m\\n\\u001b[1;32m 263\\u001b[0m \\u001b[38;5;28;01melse\\u001b[39;00m:\\n\",\n \"File \\u001b[0;32m/usr/lib/python3.13/os.py:217\\u001b[0m, in \\u001b[0;36mmakedirs\\u001b[0;34m(name, mode, exist_ok)\\u001b[0m\\n\\u001b[1;32m 216\\u001b[0m \\u001b[38;5;28;01mtry\\u001b[39;00m:\\n\\u001b[0;32m--> 217\\u001b[0m \\u001b[43mmakedirs\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[43mhead\\u001b[49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[43mexist_ok\\u001b[49m\\u001b[38;5;241;43m=\\u001b[39;49m\\u001b[43mexist_ok\\u001b[49m\\u001b[43m)\\u001b[49m\\n\\u001b[1;32m 218\\u001b[0m \\u001b[38;5;28;01mexcept\\u001b[39;00m \\u001b[38;5;167;01mFileExistsError\\u001b[39;00m:\\n\\u001b[1;32m 219\\u001b[0m \\u001b[38;5;66;03m# Defeats race condition when another thread created the path\\u001b[39;00m\\n\",\n \"File \\u001b[0;32m/usr/lib/python3.13/os.py:217\\u001b[0m, in \\u001b[0;36mmakedirs\\u001b[0;34m(name, mode, exist_ok)\\u001b[0m\\n\\u001b[1;32m 216\\u001b[0m \\u001b[38;5;28;01mtry\\u001b[39;00m:\\n\\u001b[0;32m--> 217\\u001b[0m \\u001b[43mmakedirs\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[43mhead\\u001b[49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[43mexist_ok\\u001b[49m\\u001b[38;5;241;43m=\\u001b[39;49m\\u001b[43mexist_ok\\u001b[49m\\u001b[43m)\\u001b[49m\\n\\u001b[1;32m 218\\u001b[0m \\u001b[38;5;28;01mexcept\\u001b[39;00m \\u001b[38;5;167;01mFileExistsError\\u001b[39;00m:\\n\\u001b[1;32m 219\\u001b[0m \\u001b[38;5;66;03m# Defeats race condition when another thread created the path\\u001b[39;00m\\n\",\n@@ -63,15 +63,15 @@\n \"\\nThe above exception was the direct cause of the following exception:\\n\",\n \"\\u001b[0;31mPermissionError\\u001b[0m Traceback (most recent call last)\",\n \"Cell \\u001b[0;32mIn[1], line 7\\u001b[0m\\n\\u001b[1;32m 2\\u001b[0m \\u001b[38;5;28;01mimport\\u001b[39;00m \\u001b[38;5;21;01mnumpy\\u001b[39;00m \\u001b[38;5;28;01mas\\u001b[39;00m \\u001b[38;5;21;01mnp\\u001b[39;00m\\n\\u001b[1;32m 4\\u001b[0m xr\\u001b[38;5;241m.\\u001b[39mset_options(display_style\\u001b[38;5;241m=\\u001b[39m\\u001b[38;5;124m\\\"\\u001b[39m\\u001b[38;5;124mhtml\\u001b[39m\\u001b[38;5;124m\\\"\\u001b[39m) \\u001b[38;5;66;03m# fancy HTML repr\\u001b[39;00m\\n\\u001b[1;32m 6\\u001b[0m air \\u001b[38;5;241m=\\u001b[39m (\\n\\u001b[0;32m----> 7\\u001b[0m \\u001b[43mxr\\u001b[49m\\u001b[38;5;241;43m.\\u001b[39;49m\\u001b[43mtutorial\\u001b[49m\\u001b[38;5;241;43m.\\u001b[39;49m\\u001b[43mload_dataset\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[38;5;124;43m\\\"\\u001b[39;49m\\u001b[38;5;124;43mair_temperature\\u001b[39;49m\\u001b[38;5;124;43m\\\"\\u001b[39;49m\\u001b[43m)\\u001b[49m\\n\\u001b[1;32m 8\\u001b[0m \\u001b[38;5;241m.\\u001b[39mair\\u001b[38;5;241m.\\u001b[39msortby(\\u001b[38;5;124m\\\"\\u001b[39m\\u001b[38;5;124mlat\\u001b[39m\\u001b[38;5;124m\\\"\\u001b[39m) \\u001b[38;5;66;03m# np.interp needs coordinate in ascending order\\u001b[39;00m\\n\\u001b[1;32m 9\\u001b[0m \\u001b[38;5;241m.\\u001b[39misel(time\\u001b[38;5;241m=\\u001b[39m\\u001b[38;5;28mslice\\u001b[39m(\\u001b[38;5;241m4\\u001b[39m), lon\\u001b[38;5;241m=\\u001b[39m\\u001b[38;5;28mslice\\u001b[39m(\\u001b[38;5;241m3\\u001b[39m))\\n\\u001b[1;32m 10\\u001b[0m ) \\u001b[38;5;66;03m# choose a small subset for convenience\\u001b[39;00m\\n\\u001b[1;32m 11\\u001b[0m air\\n\",\n \"File \\u001b[0;32m/usr/lib/python3/dist-packages/xarray/tutorial.py:213\\u001b[0m, in \\u001b[0;36mload_dataset\\u001b[0;34m(*args, **kwargs)\\u001b[0m\\n\\u001b[1;32m 176\\u001b[0m \\u001b[38;5;28;01mdef\\u001b[39;00m \\u001b[38;5;21mload_dataset\\u001b[39m(\\u001b[38;5;241m*\\u001b[39margs, \\u001b[38;5;241m*\\u001b[39m\\u001b[38;5;241m*\\u001b[39mkwargs) \\u001b[38;5;241m-\\u001b[39m\\u001b[38;5;241m>\\u001b[39m Dataset:\\n\\u001b[1;32m 177\\u001b[0m \\u001b[38;5;250m \\u001b[39m\\u001b[38;5;124;03m\\\"\\\"\\\"\\u001b[39;00m\\n\\u001b[1;32m 178\\u001b[0m \\u001b[38;5;124;03m Open, load into memory, and close a dataset from the online repository\\u001b[39;00m\\n\\u001b[1;32m 179\\u001b[0m \\u001b[38;5;124;03m (requires internet).\\u001b[39;00m\\n\\u001b[0;32m (...)\\u001b[0m\\n\\u001b[1;32m 211\\u001b[0m \\u001b[38;5;124;03m load_dataset\\u001b[39;00m\\n\\u001b[1;32m 212\\u001b[0m \\u001b[38;5;124;03m \\\"\\\"\\\"\\u001b[39;00m\\n\\u001b[0;32m--> 213\\u001b[0m \\u001b[38;5;28;01mwith\\u001b[39;00m \\u001b[43mopen_dataset\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[38;5;241;43m*\\u001b[39;49m\\u001b[43margs\\u001b[49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[38;5;241;43m*\\u001b[39;49m\\u001b[38;5;241;43m*\\u001b[39;49m\\u001b[43mkwargs\\u001b[49m\\u001b[43m)\\u001b[49m \\u001b[38;5;28;01mas\\u001b[39;00m ds:\\n\\u001b[1;32m 214\\u001b[0m \\u001b[38;5;28;01mreturn\\u001b[39;00m ds\\u001b[38;5;241m.\\u001b[39mload()\\n\",\n \"File \\u001b[0;32m/usr/lib/python3/dist-packages/xarray/tutorial.py:165\\u001b[0m, in \\u001b[0;36mopen_dataset\\u001b[0;34m(name, cache, cache_dir, engine, **kws)\\u001b[0m\\n\\u001b[1;32m 162\\u001b[0m downloader \\u001b[38;5;241m=\\u001b[39m pooch\\u001b[38;5;241m.\\u001b[39mHTTPDownloader(headers\\u001b[38;5;241m=\\u001b[39mheaders)\\n\\u001b[1;32m 164\\u001b[0m \\u001b[38;5;66;03m# retrieve the file\\u001b[39;00m\\n\\u001b[0;32m--> 165\\u001b[0m filepath \\u001b[38;5;241m=\\u001b[39m \\u001b[43mpooch\\u001b[49m\\u001b[38;5;241;43m.\\u001b[39;49m\\u001b[43mretrieve\\u001b[49m\\u001b[43m(\\u001b[49m\\n\\u001b[1;32m 166\\u001b[0m \\u001b[43m \\u001b[49m\\u001b[43murl\\u001b[49m\\u001b[38;5;241;43m=\\u001b[39;49m\\u001b[43murl\\u001b[49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[43mknown_hash\\u001b[49m\\u001b[38;5;241;43m=\\u001b[39;49m\\u001b[38;5;28;43;01mNone\\u001b[39;49;00m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[43mpath\\u001b[49m\\u001b[38;5;241;43m=\\u001b[39;49m\\u001b[43mcache_dir\\u001b[49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[43mdownloader\\u001b[49m\\u001b[38;5;241;43m=\\u001b[39;49m\\u001b[43mdownloader\\u001b[49m\\n\\u001b[1;32m 167\\u001b[0m \\u001b[43m\\u001b[49m\\u001b[43m)\\u001b[49m\\n\\u001b[1;32m 168\\u001b[0m ds \\u001b[38;5;241m=\\u001b[39m _open_dataset(filepath, engine\\u001b[38;5;241m=\\u001b[39mengine, \\u001b[38;5;241m*\\u001b[39m\\u001b[38;5;241m*\\u001b[39mkws)\\n\\u001b[1;32m 169\\u001b[0m \\u001b[38;5;28;01mif\\u001b[39;00m \\u001b[38;5;129;01mnot\\u001b[39;00m cache:\\n\",\n \"File \\u001b[0;32m/usr/lib/python3/dist-packages/pooch/core.py:227\\u001b[0m, in \\u001b[0;36mretrieve\\u001b[0;34m(url, known_hash, fname, path, processor, downloader, progressbar)\\u001b[0m\\n\\u001b[1;32m 222\\u001b[0m action, verb \\u001b[38;5;241m=\\u001b[39m download_action(full_path, known_hash)\\n\\u001b[1;32m 224\\u001b[0m \\u001b[38;5;28;01mif\\u001b[39;00m action \\u001b[38;5;129;01min\\u001b[39;00m (\\u001b[38;5;124m\\\"\\u001b[39m\\u001b[38;5;124mdownload\\u001b[39m\\u001b[38;5;124m\\\"\\u001b[39m, \\u001b[38;5;124m\\\"\\u001b[39m\\u001b[38;5;124mupdate\\u001b[39m\\u001b[38;5;124m\\\"\\u001b[39m):\\n\\u001b[1;32m 225\\u001b[0m \\u001b[38;5;66;03m# We need to write data, so create the local data directory if it\\u001b[39;00m\\n\\u001b[1;32m 226\\u001b[0m \\u001b[38;5;66;03m# doesn't already exist.\\u001b[39;00m\\n\\u001b[0;32m--> 227\\u001b[0m \\u001b[43mmake_local_storage\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[43mpath\\u001b[49m\\u001b[43m)\\u001b[49m\\n\\u001b[1;32m 229\\u001b[0m get_logger()\\u001b[38;5;241m.\\u001b[39minfo(\\n\\u001b[1;32m 230\\u001b[0m \\u001b[38;5;124m\\\"\\u001b[39m\\u001b[38;5;132;01m%s\\u001b[39;00m\\u001b[38;5;124m data from \\u001b[39m\\u001b[38;5;124m'\\u001b[39m\\u001b[38;5;132;01m%s\\u001b[39;00m\\u001b[38;5;124m'\\u001b[39m\\u001b[38;5;124m to file \\u001b[39m\\u001b[38;5;124m'\\u001b[39m\\u001b[38;5;132;01m%s\\u001b[39;00m\\u001b[38;5;124m'\\u001b[39m\\u001b[38;5;124m.\\u001b[39m\\u001b[38;5;124m\\\"\\u001b[39m,\\n\\u001b[1;32m 231\\u001b[0m verb,\\n\\u001b[1;32m 232\\u001b[0m url,\\n\\u001b[1;32m 233\\u001b[0m \\u001b[38;5;28mstr\\u001b[39m(full_path),\\n\\u001b[1;32m 234\\u001b[0m )\\n\\u001b[1;32m 236\\u001b[0m \\u001b[38;5;28;01mif\\u001b[39;00m downloader \\u001b[38;5;129;01mis\\u001b[39;00m \\u001b[38;5;28;01mNone\\u001b[39;00m:\\n\",\n \"File \\u001b[0;32m/usr/lib/python3/dist-packages/pooch/utils.py:276\\u001b[0m, in \\u001b[0;36mmake_local_storage\\u001b[0;34m(path, env)\\u001b[0m\\n\\u001b[1;32m 272\\u001b[0m \\u001b[38;5;28;01mif\\u001b[39;00m env \\u001b[38;5;129;01mis\\u001b[39;00m \\u001b[38;5;129;01mnot\\u001b[39;00m \\u001b[38;5;28;01mNone\\u001b[39;00m:\\n\\u001b[1;32m 273\\u001b[0m message\\u001b[38;5;241m.\\u001b[39mappend(\\n\\u001b[1;32m 274\\u001b[0m \\u001b[38;5;124mf\\u001b[39m\\u001b[38;5;124m\\\"\\u001b[39m\\u001b[38;5;124mUse environment variable \\u001b[39m\\u001b[38;5;124m'\\u001b[39m\\u001b[38;5;132;01m{\\u001b[39;00menv\\u001b[38;5;132;01m}\\u001b[39;00m\\u001b[38;5;124m'\\u001b[39m\\u001b[38;5;124m to specify a different location.\\u001b[39m\\u001b[38;5;124m\\\"\\u001b[39m\\n\\u001b[1;32m 275\\u001b[0m )\\n\\u001b[0;32m--> 276\\u001b[0m \\u001b[38;5;28;01mraise\\u001b[39;00m \\u001b[38;5;167;01mPermissionError\\u001b[39;00m(\\u001b[38;5;124m\\\"\\u001b[39m\\u001b[38;5;124m \\u001b[39m\\u001b[38;5;124m\\\"\\u001b[39m\\u001b[38;5;241m.\\u001b[39mjoin(message)) \\u001b[38;5;28;01mfrom\\u001b[39;00m \\u001b[38;5;21;01merror\\u001b[39;00m\\n\",\n- \"\\u001b[0;31mPermissionError\\u001b[0m: [Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/first-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\"\n+ \"\\u001b[0;31mPermissionError\\u001b[0m: [Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/second-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\"\n ]\n }\n ],\n \"source\": [\n \"import xarray as xr\\n\",\n \"import numpy as np\\n\",\n \"\\n\",\n@@ -97,18 +97,18 @@\n \"execution_count\": 2,\n \"metadata\": {\n \"ExecuteTime\": {\n \"end_time\": \"2020-01-15T14:45:55.431708Z\",\n \"start_time\": \"2020-01-15T14:45:55.104701Z\"\n },\n \"execution\": {\n- \"iopub.execute_input\": \"2026-04-07T09:27:01.533193Z\",\n- \"iopub.status.busy\": \"2026-04-07T09:27:01.532648Z\",\n- \"iopub.status.idle\": \"2026-04-07T09:27:01.546707Z\",\n- \"shell.execute_reply\": \"2026-04-07T09:27:01.546157Z\"\n+ \"iopub.execute_input\": \"2025-03-05T03:36:09.525677Z\",\n+ \"iopub.status.busy\": \"2025-03-05T03:36:09.525114Z\",\n+ \"iopub.status.idle\": \"2025-03-05T03:36:09.609575Z\",\n+ \"shell.execute_reply\": \"2025-03-05T03:36:09.607972Z\"\n }\n },\n \"outputs\": [\n {\n \"ename\": \"NameError\",\n \"evalue\": \"name 'air' is not defined\",\n \"output_type\": \"error\",\n@@ -137,18 +137,18 @@\n \"execution_count\": 3,\n \"metadata\": {\n \"ExecuteTime\": {\n \"end_time\": \"2020-01-15T14:45:57.889496Z\",\n \"start_time\": \"2020-01-15T14:45:57.792269Z\"\n },\n \"execution\": {\n- \"iopub.execute_input\": \"2026-04-07T09:27:01.548948Z\",\n- \"iopub.status.busy\": \"2026-04-07T09:27:01.548458Z\",\n- \"iopub.status.idle\": \"2026-04-07T09:27:01.562721Z\",\n- \"shell.execute_reply\": \"2026-04-07T09:27:01.562177Z\"\n+ \"iopub.execute_input\": \"2025-03-05T03:36:09.634024Z\",\n+ \"iopub.status.busy\": \"2025-03-05T03:36:09.633424Z\",\n+ \"iopub.status.idle\": \"2025-03-05T03:36:09.711318Z\",\n+ \"shell.execute_reply\": \"2025-03-05T03:36:09.710014Z\"\n }\n },\n \"outputs\": [\n {\n \"ename\": \"NameError\",\n \"evalue\": \"name 'air' is not defined\",\n \"output_type\": \"error\",\n@@ -196,18 +196,18 @@\n \"execution_count\": 4,\n \"metadata\": {\n \"ExecuteTime\": {\n \"end_time\": \"2020-01-15T14:45:59.768626Z\",\n \"start_time\": \"2020-01-15T14:45:59.543808Z\"\n },\n \"execution\": {\n- \"iopub.execute_input\": \"2026-04-07T09:27:01.565288Z\",\n- \"iopub.status.busy\": \"2026-04-07T09:27:01.564829Z\",\n- \"iopub.status.idle\": \"2026-04-07T09:27:01.576927Z\",\n- \"shell.execute_reply\": \"2026-04-07T09:27:01.576388Z\"\n+ \"iopub.execute_input\": \"2025-03-05T03:36:09.737655Z\",\n+ \"iopub.status.busy\": \"2025-03-05T03:36:09.737053Z\",\n+ \"iopub.status.idle\": \"2025-03-05T03:36:09.817470Z\",\n+ \"shell.execute_reply\": \"2025-03-05T03:36:09.815927Z\"\n }\n },\n \"outputs\": [\n {\n \"ename\": \"NameError\",\n \"evalue\": \"name 'air' is not defined\",\n \"output_type\": \"error\",\n@@ -262,18 +262,18 @@\n \"execution_count\": 5,\n \"metadata\": {\n \"ExecuteTime\": {\n \"end_time\": \"2020-01-15T14:46:02.187012Z\",\n \"start_time\": \"2020-01-15T14:46:02.105563Z\"\n },\n \"execution\": {\n- \"iopub.execute_input\": \"2026-04-07T09:27:01.579010Z\",\n- \"iopub.status.busy\": \"2026-04-07T09:27:01.578756Z\",\n- \"iopub.status.idle\": \"2026-04-07T09:27:01.591026Z\",\n- \"shell.execute_reply\": \"2026-04-07T09:27:01.590480Z\"\n+ \"iopub.execute_input\": \"2025-03-05T03:36:09.842017Z\",\n+ \"iopub.status.busy\": \"2025-03-05T03:36:09.841450Z\",\n+ \"iopub.status.idle\": \"2025-03-05T03:36:09.917521Z\",\n+ \"shell.execute_reply\": \"2025-03-05T03:36:09.916040Z\"\n }\n },\n \"outputs\": [\n {\n \"ename\": \"NameError\",\n \"evalue\": \"name 'air' is not defined\",\n \"output_type\": \"error\",\n@@ -340,18 +340,18 @@\n \"execution_count\": 6,\n \"metadata\": {\n \"ExecuteTime\": {\n \"end_time\": \"2020-01-15T14:46:05.031672Z\",\n \"start_time\": \"2020-01-15T14:46:04.947588Z\"\n },\n \"execution\": {\n- \"iopub.execute_input\": \"2026-04-07T09:27:01.593005Z\",\n- \"iopub.status.busy\": \"2026-04-07T09:27:01.592770Z\",\n- \"iopub.status.idle\": \"2026-04-07T09:27:01.605767Z\",\n- \"shell.execute_reply\": \"2026-04-07T09:27:01.605233Z\"\n+ \"iopub.execute_input\": \"2025-03-05T03:36:09.937522Z\",\n+ \"iopub.status.busy\": \"2025-03-05T03:36:09.936951Z\",\n+ \"iopub.status.idle\": \"2025-03-05T03:36:10.029822Z\",\n+ \"shell.execute_reply\": \"2025-03-05T03:36:10.028055Z\"\n }\n },\n \"outputs\": [\n {\n \"ename\": \"NameError\",\n \"evalue\": \"name 'air' is not defined\",\n \"output_type\": \"error\",\n@@ -386,18 +386,18 @@\n \"execution_count\": 7,\n \"metadata\": {\n \"ExecuteTime\": {\n \"end_time\": \"2020-01-15T14:46:09.325218Z\",\n \"start_time\": \"2020-01-15T14:46:09.303020Z\"\n },\n \"execution\": {\n- \"iopub.execute_input\": \"2026-04-07T09:27:01.607676Z\",\n- \"iopub.status.busy\": \"2026-04-07T09:27:01.607432Z\",\n- \"iopub.status.idle\": \"2026-04-07T09:27:01.620723Z\",\n- \"shell.execute_reply\": \"2026-04-07T09:27:01.620191Z\"\n+ \"iopub.execute_input\": \"2025-03-05T03:36:10.053709Z\",\n+ \"iopub.status.busy\": \"2025-03-05T03:36:10.053015Z\",\n+ \"iopub.status.idle\": \"2025-03-05T03:36:10.141607Z\",\n+ \"shell.execute_reply\": \"2025-03-05T03:36:10.139930Z\"\n }\n },\n \"outputs\": [\n {\n \"ename\": \"NameError\",\n \"evalue\": \"name 'air' is not defined\",\n \"output_type\": \"error\",\n@@ -434,18 +434,18 @@\n \"execution_count\": 8,\n \"metadata\": {\n \"ExecuteTime\": {\n \"end_time\": \"2020-01-15T14:46:11.295440Z\",\n \"start_time\": \"2020-01-15T14:46:11.226553Z\"\n },\n \"execution\": {\n- \"iopub.execute_input\": \"2026-04-07T09:27:01.622574Z\",\n- \"iopub.status.busy\": \"2026-04-07T09:27:01.622338Z\",\n- \"iopub.status.idle\": \"2026-04-07T09:27:01.636167Z\",\n- \"shell.execute_reply\": \"2026-04-07T09:27:01.635615Z\"\n+ \"iopub.execute_input\": \"2025-03-05T03:36:10.154193Z\",\n+ \"iopub.status.busy\": \"2025-03-05T03:36:10.153697Z\",\n+ \"iopub.status.idle\": \"2025-03-05T03:36:10.283938Z\",\n+ \"shell.execute_reply\": \"2025-03-05T03:36:10.267906Z\"\n }\n },\n \"outputs\": [\n {\n \"ename\": \"NameError\",\n \"evalue\": \"name 'air' is not defined\",\n \"output_type\": \"error\",\n@@ -498,18 +498,18 @@\n \"execution_count\": 9,\n \"metadata\": {\n \"ExecuteTime\": {\n \"end_time\": \"2020-01-15T14:46:13.808646Z\",\n \"start_time\": \"2020-01-15T14:46:13.680098Z\"\n },\n \"execution\": {\n- \"iopub.execute_input\": \"2026-04-07T09:27:01.638145Z\",\n- \"iopub.status.busy\": \"2026-04-07T09:27:01.637897Z\",\n- \"iopub.status.idle\": \"2026-04-07T09:27:01.653676Z\",\n- \"shell.execute_reply\": \"2026-04-07T09:27:01.653131Z\"\n+ \"iopub.execute_input\": \"2025-03-05T03:36:10.297550Z\",\n+ \"iopub.status.busy\": \"2025-03-05T03:36:10.296942Z\",\n+ \"iopub.status.idle\": \"2025-03-05T03:36:10.443886Z\",\n+ \"shell.execute_reply\": \"2025-03-05T03:36:10.431940Z\"\n }\n },\n \"outputs\": [\n {\n \"ename\": \"NameError\",\n \"evalue\": \"name 'air' is not defined\",\n \"output_type\": \"error\",\n@@ -571,18 +571,18 @@\n \"execution_count\": 10,\n \"metadata\": {\n \"ExecuteTime\": {\n \"end_time\": \"2020-01-15T14:46:26.633233Z\",\n \"start_time\": \"2020-01-15T14:46:26.515209Z\"\n },\n \"execution\": {\n- \"iopub.execute_input\": \"2026-04-07T09:27:01.655784Z\",\n- \"iopub.status.busy\": \"2026-04-07T09:27:01.655549Z\",\n- \"iopub.status.idle\": \"2026-04-07T09:27:01.674623Z\",\n- \"shell.execute_reply\": \"2026-04-07T09:27:01.674076Z\"\n+ \"iopub.execute_input\": \"2025-03-05T03:36:10.453494Z\",\n+ \"iopub.status.busy\": \"2025-03-05T03:36:10.452958Z\",\n+ \"iopub.status.idle\": \"2025-03-05T03:36:10.590819Z\",\n+ \"shell.execute_reply\": \"2025-03-05T03:36:10.587937Z\"\n }\n },\n \"outputs\": [\n {\n \"ename\": \"NameError\",\n \"evalue\": \"name 'air' is not defined\",\n \"output_type\": \"error\",\n@@ -628,18 +628,18 @@\n \"execution_count\": 11,\n \"metadata\": {\n \"ExecuteTime\": {\n \"end_time\": \"2020-01-15T14:46:30.026663Z\",\n \"start_time\": \"2020-01-15T14:46:29.893267Z\"\n },\n \"execution\": {\n- \"iopub.execute_input\": \"2026-04-07T09:27:01.676509Z\",\n- \"iopub.status.busy\": \"2026-04-07T09:27:01.676273Z\",\n- \"iopub.status.idle\": \"2026-04-07T09:27:01.691952Z\",\n- \"shell.execute_reply\": \"2026-04-07T09:27:01.691394Z\"\n+ \"iopub.execute_input\": \"2025-03-05T03:36:10.611921Z\",\n+ \"iopub.status.busy\": \"2025-03-05T03:36:10.611053Z\",\n+ \"iopub.status.idle\": \"2025-03-05T03:36:10.771898Z\",\n+ \"shell.execute_reply\": \"2025-03-05T03:36:10.755927Z\"\n }\n },\n \"outputs\": [\n {\n \"ename\": \"NameError\",\n \"evalue\": \"name 'air' is not defined\",\n \"output_type\": \"error\",\n@@ -716,18 +716,18 @@\n \"execution_count\": 12,\n \"metadata\": {\n \"ExecuteTime\": {\n \"end_time\": \"2020-01-15T14:48:42.469341Z\",\n \"start_time\": \"2020-01-15T14:48:42.344209Z\"\n },\n \"execution\": {\n- \"iopub.execute_input\": \"2026-04-07T09:27:01.693916Z\",\n- \"iopub.status.busy\": \"2026-04-07T09:27:01.693681Z\",\n- \"iopub.status.idle\": \"2026-04-07T09:27:01.778328Z\",\n- \"shell.execute_reply\": \"2026-04-07T09:27:01.777739Z\"\n+ \"iopub.execute_input\": \"2025-03-05T03:36:10.793788Z\",\n+ \"iopub.status.busy\": \"2025-03-05T03:36:10.793085Z\",\n+ \"iopub.status.idle\": \"2025-03-05T03:36:11.127006Z\",\n+ \"shell.execute_reply\": \"2025-03-05T03:36:11.117040Z\"\n }\n },\n \"outputs\": [\n {\n \"ename\": \"NameError\",\n \"evalue\": \"name 'air' is not defined\",\n \"output_type\": \"error\",\n@@ -802,18 +802,18 @@\n \"execution_count\": 13,\n \"metadata\": {\n \"ExecuteTime\": {\n \"end_time\": \"2020-01-15T14:48:45.267633Z\",\n \"start_time\": \"2020-01-15T14:48:44.943939Z\"\n },\n \"execution\": {\n- \"iopub.execute_input\": \"2026-04-07T09:27:01.780435Z\",\n- \"iopub.status.busy\": \"2026-04-07T09:27:01.780196Z\",\n- \"iopub.status.idle\": \"2026-04-07T09:27:01.795022Z\",\n- \"shell.execute_reply\": \"2026-04-07T09:27:01.794465Z\"\n+ \"iopub.execute_input\": \"2025-03-05T03:36:11.150823Z\",\n+ \"iopub.status.busy\": \"2025-03-05T03:36:11.150257Z\",\n+ \"iopub.status.idle\": \"2025-03-05T03:36:11.264423Z\",\n+ \"shell.execute_reply\": \"2025-03-05T03:36:11.257558Z\"\n }\n },\n \"outputs\": [\n {\n \"ename\": \"ModuleNotFoundError\",\n \"evalue\": \"No module named 'numba'\",\n \"output_type\": \"error\",\n@@ -854,18 +854,18 @@\n \"execution_count\": 14,\n \"metadata\": {\n \"ExecuteTime\": {\n \"end_time\": \"2020-01-15T14:48:54.755405Z\",\n \"start_time\": \"2020-01-15T14:48:54.634724Z\"\n },\n \"execution\": {\n- \"iopub.execute_input\": \"2026-04-07T09:27:01.796955Z\",\n- \"iopub.status.busy\": \"2026-04-07T09:27:01.796716Z\",\n- \"iopub.status.idle\": \"2026-04-07T09:27:01.811995Z\",\n- \"shell.execute_reply\": \"2026-04-07T09:27:01.811443Z\"\n+ \"iopub.execute_input\": \"2025-03-05T03:36:11.281812Z\",\n+ \"iopub.status.busy\": \"2025-03-05T03:36:11.281064Z\",\n+ \"iopub.status.idle\": \"2025-03-05T03:36:11.395442Z\",\n+ \"shell.execute_reply\": \"2025-03-05T03:36:11.391788Z\"\n }\n },\n \"outputs\": [\n {\n \"ename\": \"NameError\",\n \"evalue\": \"name 'interp1d_np_gufunc' is not defined\",\n \"output_type\": \"error\",\n@@ -908,18 +908,18 @@\n \"execution_count\": 15,\n \"metadata\": {\n \"ExecuteTime\": {\n \"end_time\": \"2020-01-15T14:49:28.667528Z\",\n \"start_time\": \"2020-01-15T14:49:28.103914Z\"\n },\n \"execution\": {\n- \"iopub.execute_input\": \"2026-04-07T09:27:01.813938Z\",\n- \"iopub.status.busy\": \"2026-04-07T09:27:01.813701Z\",\n- \"iopub.status.idle\": \"2026-04-07T09:27:01.830406Z\",\n- \"shell.execute_reply\": \"2026-04-07T09:27:01.829875Z\"\n+ \"iopub.execute_input\": \"2025-03-05T03:36:11.419032Z\",\n+ \"iopub.status.busy\": \"2025-03-05T03:36:11.418220Z\",\n+ \"iopub.status.idle\": \"2025-03-05T03:36:11.539033Z\",\n+ \"shell.execute_reply\": \"2025-03-05T03:36:11.526621Z\"\n }\n },\n \"outputs\": [\n {\n \"ename\": \"ModuleNotFoundError\",\n \"evalue\": \"No module named 'numba'\",\n \"output_type\": \"error\",\n"}]}]}, {"source1": "./usr/share/doc/python-xarray-doc/html/examples/area_weighted_temperature.html", "source2": "./usr/share/doc/python-xarray-doc/html/examples/area_weighted_temperature.html", "unified_diff": "@@ -186,15 +186,15 @@\n File /usr/lib/python3/dist-packages/pooch/utils.py:276, in make_local_storage(path, env)\n 272 if env is not None:\n 273 message.append(\n 274 f"Use environment variable '{env}' to specify a different location."\n 275 )\n --> 276 raise PermissionError(" ".join(message)) from error\n \n-PermissionError: [Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/first-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\n+PermissionError: [Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/second-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\n
\n \n

Plot the first timestep:

\n
\n
[3]:\n 
\n
\n", "details": [{"source1": "html2text {}", "source2": "html2text {}", "unified_diff": "@@ -121,15 +121,15 @@\n 273 message.append(\n 274 f\"Use environment variable '{env}' to specify a different\n location.\"\n 275 )\n --> 276 raise PermissionError(\" \".join(message)) from error\n \n PermissionError: [Errno 13] Permission denied: '/nonexistent' | Pooch could not\n-create data cache folder '/nonexistent/first-build/.cache/\n+create data cache folder '/nonexistent/second-build/.cache/\n xarray_tutorial_data'. Will not be able to download data files.\n Plot the first timestep:\n [3]:\n projection = ccrs.LambertConformal(central_longitude=-95, central_latitude=45)\n \n f, ax = plt.subplots(subplot_kw=dict(projection=projection))\n \n"}]}, {"source1": "./usr/share/doc/python-xarray-doc/html/examples/area_weighted_temperature.ipynb.gz", "source2": "./usr/share/doc/python-xarray-doc/html/examples/area_weighted_temperature.ipynb.gz", "unified_diff": null, "details": [{"source1": "area_weighted_temperature.ipynb", "source2": "area_weighted_temperature.ipynb", "unified_diff": null, "details": [{"source1": "Pretty-printed", "source2": "Pretty-printed", "comments": ["Similarity: 0.999094012605042%", "Differences: {\"'cells'\": \"{2: {'metadata': {'execution': {'iopub.execute_input': '2025-03-05T03:36:25.622290Z', \"", " \"'iopub.status.busy': '2025-03-05T03:36:25.621690Z', 'iopub.status.idle': \"", " \"'2025-03-05T03:36:29.508451Z', 'shell.execute_reply': \"", " \"'2025-03-05T03:36:29.502026Z'}}}, 4: {'metadata': {'execution': \"", " \"{'iopub.execute_input': '2025-03-05T03:36:29.522515Z', 'iopub.status.busy': \"", " \"'2025-03-05T03:36:29.521579Z', 'iopub.status.idle': '2025-03-05T03:36:3 [\u2026]"], "unified_diff": "@@ -28,18 +28,18 @@\n \"execution_count\": 1,\n \"metadata\": {\n \"ExecuteTime\": {\n \"end_time\": \"2020-03-17T14:43:57.222351Z\",\n \"start_time\": \"2020-03-17T14:43:56.147541Z\"\n },\n \"execution\": {\n- \"iopub.execute_input\": \"2026-04-07T09:27:04.389995Z\",\n- \"iopub.status.busy\": \"2026-04-07T09:27:04.389755Z\",\n- \"iopub.status.idle\": \"2026-04-07T09:27:05.264629Z\",\n- \"shell.execute_reply\": \"2026-04-07T09:27:05.263997Z\"\n+ \"iopub.execute_input\": \"2025-03-05T03:36:25.622290Z\",\n+ \"iopub.status.busy\": \"2025-03-05T03:36:25.621690Z\",\n+ \"iopub.status.idle\": \"2025-03-05T03:36:29.508451Z\",\n+ \"shell.execute_reply\": \"2025-03-05T03:36:29.502026Z\"\n }\n },\n \"outputs\": [],\n \"source\": [\n \"%matplotlib inline\\n\",\n \"\\n\",\n \"import cartopy.crs as ccrs\\n\",\n@@ -63,24 +63,24 @@\n \"execution_count\": 2,\n \"metadata\": {\n \"ExecuteTime\": {\n \"end_time\": \"2020-03-17T14:43:57.831734Z\",\n \"start_time\": \"2020-03-17T14:43:57.651845Z\"\n },\n \"execution\": {\n- \"iopub.execute_input\": \"2026-04-07T09:27:05.267464Z\",\n- \"iopub.status.busy\": \"2026-04-07T09:27:05.266889Z\",\n- \"iopub.status.idle\": \"2026-04-07T09:27:05.543997Z\",\n- \"shell.execute_reply\": \"2026-04-07T09:27:05.543333Z\"\n+ \"iopub.execute_input\": \"2025-03-05T03:36:29.522515Z\",\n+ \"iopub.status.busy\": \"2025-03-05T03:36:29.521579Z\",\n+ \"iopub.status.idle\": \"2025-03-05T03:36:30.843947Z\",\n+ \"shell.execute_reply\": \"2025-03-05T03:36:30.842493Z\"\n }\n },\n \"outputs\": [\n {\n \"ename\": \"PermissionError\",\n- \"evalue\": \"[Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/first-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\",\n+ \"evalue\": \"[Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/second-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\",\n \"output_type\": \"error\",\n \"traceback\": [\n \"\\u001b[0;31m---------------------------------------------------------------------------\\u001b[0m\",\n \"\\u001b[0;31mPermissionError\\u001b[0m Traceback (most recent call last)\",\n \"File \\u001b[0;32m/usr/lib/python3/dist-packages/pooch/utils.py:262\\u001b[0m, in \\u001b[0;36mmake_local_storage\\u001b[0;34m(path, env)\\u001b[0m\\n\\u001b[1;32m 258\\u001b[0m \\u001b[38;5;28;01mif\\u001b[39;00m action \\u001b[38;5;241m==\\u001b[39m \\u001b[38;5;124m\\\"\\u001b[39m\\u001b[38;5;124mcreate\\u001b[39m\\u001b[38;5;124m\\\"\\u001b[39m:\\n\\u001b[1;32m 259\\u001b[0m \\u001b[38;5;66;03m# When running in parallel, it's possible that multiple jobs will\\u001b[39;00m\\n\\u001b[1;32m 260\\u001b[0m \\u001b[38;5;66;03m# try to create the path at the same time. Use exist_ok to avoid\\u001b[39;00m\\n\\u001b[1;32m 261\\u001b[0m \\u001b[38;5;66;03m# raising an error.\\u001b[39;00m\\n\\u001b[0;32m--> 262\\u001b[0m \\u001b[43mos\\u001b[49m\\u001b[38;5;241;43m.\\u001b[39;49m\\u001b[43mmakedirs\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[43mpath\\u001b[49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[43mexist_ok\\u001b[49m\\u001b[38;5;241;43m=\\u001b[39;49m\\u001b[38;5;28;43;01mTrue\\u001b[39;49;00m\\u001b[43m)\\u001b[49m\\n\\u001b[1;32m 263\\u001b[0m \\u001b[38;5;28;01melse\\u001b[39;00m:\\n\",\n \"File \\u001b[0;32m/usr/lib/python3.13/os.py:217\\u001b[0m, in \\u001b[0;36mmakedirs\\u001b[0;34m(name, mode, exist_ok)\\u001b[0m\\n\\u001b[1;32m 216\\u001b[0m \\u001b[38;5;28;01mtry\\u001b[39;00m:\\n\\u001b[0;32m--> 217\\u001b[0m \\u001b[43mmakedirs\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[43mhead\\u001b[49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[43mexist_ok\\u001b[49m\\u001b[38;5;241;43m=\\u001b[39;49m\\u001b[43mexist_ok\\u001b[49m\\u001b[43m)\\u001b[49m\\n\\u001b[1;32m 218\\u001b[0m \\u001b[38;5;28;01mexcept\\u001b[39;00m \\u001b[38;5;167;01mFileExistsError\\u001b[39;00m:\\n\\u001b[1;32m 219\\u001b[0m \\u001b[38;5;66;03m# Defeats race condition when another thread created the path\\u001b[39;00m\\n\",\n \"File \\u001b[0;32m/usr/lib/python3.13/os.py:217\\u001b[0m, in \\u001b[0;36mmakedirs\\u001b[0;34m(name, mode, exist_ok)\\u001b[0m\\n\\u001b[1;32m 216\\u001b[0m \\u001b[38;5;28;01mtry\\u001b[39;00m:\\n\\u001b[0;32m--> 217\\u001b[0m \\u001b[43mmakedirs\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[43mhead\\u001b[49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[43mexist_ok\\u001b[49m\\u001b[38;5;241;43m=\\u001b[39;49m\\u001b[43mexist_ok\\u001b[49m\\u001b[43m)\\u001b[49m\\n\\u001b[1;32m 218\\u001b[0m \\u001b[38;5;28;01mexcept\\u001b[39;00m \\u001b[38;5;167;01mFileExistsError\\u001b[39;00m:\\n\\u001b[1;32m 219\\u001b[0m \\u001b[38;5;66;03m# Defeats race condition when another thread created the path\\u001b[39;00m\\n\",\n@@ -90,15 +90,15 @@\n \"\\nThe above exception was the direct cause of the following exception:\\n\",\n \"\\u001b[0;31mPermissionError\\u001b[0m Traceback (most recent call last)\",\n \"Cell \\u001b[0;32mIn[2], line 1\\u001b[0m\\n\\u001b[0;32m----> 1\\u001b[0m ds \\u001b[38;5;241m=\\u001b[39m \\u001b[43mxr\\u001b[49m\\u001b[38;5;241;43m.\\u001b[39;49m\\u001b[43mtutorial\\u001b[49m\\u001b[38;5;241;43m.\\u001b[39;49m\\u001b[43mload_dataset\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[38;5;124;43m\\\"\\u001b[39;49m\\u001b[38;5;124;43mair_temperature\\u001b[39;49m\\u001b[38;5;124;43m\\\"\\u001b[39;49m\\u001b[43m)\\u001b[49m\\n\\u001b[1;32m 3\\u001b[0m \\u001b[38;5;66;03m# to celsius\\u001b[39;00m\\n\\u001b[1;32m 4\\u001b[0m air \\u001b[38;5;241m=\\u001b[39m ds\\u001b[38;5;241m.\\u001b[39mair \\u001b[38;5;241m-\\u001b[39m \\u001b[38;5;241m273.15\\u001b[39m\\n\",\n \"File \\u001b[0;32m/usr/lib/python3/dist-packages/xarray/tutorial.py:213\\u001b[0m, in \\u001b[0;36mload_dataset\\u001b[0;34m(*args, **kwargs)\\u001b[0m\\n\\u001b[1;32m 176\\u001b[0m \\u001b[38;5;28;01mdef\\u001b[39;00m \\u001b[38;5;21mload_dataset\\u001b[39m(\\u001b[38;5;241m*\\u001b[39margs, \\u001b[38;5;241m*\\u001b[39m\\u001b[38;5;241m*\\u001b[39mkwargs) \\u001b[38;5;241m-\\u001b[39m\\u001b[38;5;241m>\\u001b[39m Dataset:\\n\\u001b[1;32m 177\\u001b[0m \\u001b[38;5;250m \\u001b[39m\\u001b[38;5;124;03m\\\"\\\"\\\"\\u001b[39;00m\\n\\u001b[1;32m 178\\u001b[0m \\u001b[38;5;124;03m Open, load into memory, and close a dataset from the online repository\\u001b[39;00m\\n\\u001b[1;32m 179\\u001b[0m \\u001b[38;5;124;03m (requires internet).\\u001b[39;00m\\n\\u001b[0;32m (...)\\u001b[0m\\n\\u001b[1;32m 211\\u001b[0m \\u001b[38;5;124;03m load_dataset\\u001b[39;00m\\n\\u001b[1;32m 212\\u001b[0m \\u001b[38;5;124;03m \\\"\\\"\\\"\\u001b[39;00m\\n\\u001b[0;32m--> 213\\u001b[0m \\u001b[38;5;28;01mwith\\u001b[39;00m \\u001b[43mopen_dataset\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[38;5;241;43m*\\u001b[39;49m\\u001b[43margs\\u001b[49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[38;5;241;43m*\\u001b[39;49m\\u001b[38;5;241;43m*\\u001b[39;49m\\u001b[43mkwargs\\u001b[49m\\u001b[43m)\\u001b[49m \\u001b[38;5;28;01mas\\u001b[39;00m ds:\\n\\u001b[1;32m 214\\u001b[0m \\u001b[38;5;28;01mreturn\\u001b[39;00m ds\\u001b[38;5;241m.\\u001b[39mload()\\n\",\n \"File \\u001b[0;32m/usr/lib/python3/dist-packages/xarray/tutorial.py:165\\u001b[0m, in \\u001b[0;36mopen_dataset\\u001b[0;34m(name, cache, cache_dir, engine, **kws)\\u001b[0m\\n\\u001b[1;32m 162\\u001b[0m downloader \\u001b[38;5;241m=\\u001b[39m pooch\\u001b[38;5;241m.\\u001b[39mHTTPDownloader(headers\\u001b[38;5;241m=\\u001b[39mheaders)\\n\\u001b[1;32m 164\\u001b[0m \\u001b[38;5;66;03m# retrieve the file\\u001b[39;00m\\n\\u001b[0;32m--> 165\\u001b[0m filepath \\u001b[38;5;241m=\\u001b[39m \\u001b[43mpooch\\u001b[49m\\u001b[38;5;241;43m.\\u001b[39;49m\\u001b[43mretrieve\\u001b[49m\\u001b[43m(\\u001b[49m\\n\\u001b[1;32m 166\\u001b[0m \\u001b[43m \\u001b[49m\\u001b[43murl\\u001b[49m\\u001b[38;5;241;43m=\\u001b[39;49m\\u001b[43murl\\u001b[49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[43mknown_hash\\u001b[49m\\u001b[38;5;241;43m=\\u001b[39;49m\\u001b[38;5;28;43;01mNone\\u001b[39;49;00m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[43mpath\\u001b[49m\\u001b[38;5;241;43m=\\u001b[39;49m\\u001b[43mcache_dir\\u001b[49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[43mdownloader\\u001b[49m\\u001b[38;5;241;43m=\\u001b[39;49m\\u001b[43mdownloader\\u001b[49m\\n\\u001b[1;32m 167\\u001b[0m \\u001b[43m\\u001b[49m\\u001b[43m)\\u001b[49m\\n\\u001b[1;32m 168\\u001b[0m ds \\u001b[38;5;241m=\\u001b[39m _open_dataset(filepath, engine\\u001b[38;5;241m=\\u001b[39mengine, \\u001b[38;5;241m*\\u001b[39m\\u001b[38;5;241m*\\u001b[39mkws)\\n\\u001b[1;32m 169\\u001b[0m \\u001b[38;5;28;01mif\\u001b[39;00m \\u001b[38;5;129;01mnot\\u001b[39;00m cache:\\n\",\n \"File \\u001b[0;32m/usr/lib/python3/dist-packages/pooch/core.py:227\\u001b[0m, in \\u001b[0;36mretrieve\\u001b[0;34m(url, known_hash, fname, path, processor, downloader, progressbar)\\u001b[0m\\n\\u001b[1;32m 222\\u001b[0m action, verb \\u001b[38;5;241m=\\u001b[39m download_action(full_path, known_hash)\\n\\u001b[1;32m 224\\u001b[0m \\u001b[38;5;28;01mif\\u001b[39;00m action \\u001b[38;5;129;01min\\u001b[39;00m (\\u001b[38;5;124m\\\"\\u001b[39m\\u001b[38;5;124mdownload\\u001b[39m\\u001b[38;5;124m\\\"\\u001b[39m, \\u001b[38;5;124m\\\"\\u001b[39m\\u001b[38;5;124mupdate\\u001b[39m\\u001b[38;5;124m\\\"\\u001b[39m):\\n\\u001b[1;32m 225\\u001b[0m \\u001b[38;5;66;03m# We need to write data, so create the local data directory if it\\u001b[39;00m\\n\\u001b[1;32m 226\\u001b[0m \\u001b[38;5;66;03m# doesn't already exist.\\u001b[39;00m\\n\\u001b[0;32m--> 227\\u001b[0m \\u001b[43mmake_local_storage\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[43mpath\\u001b[49m\\u001b[43m)\\u001b[49m\\n\\u001b[1;32m 229\\u001b[0m get_logger()\\u001b[38;5;241m.\\u001b[39minfo(\\n\\u001b[1;32m 230\\u001b[0m \\u001b[38;5;124m\\\"\\u001b[39m\\u001b[38;5;132;01m%s\\u001b[39;00m\\u001b[38;5;124m data from \\u001b[39m\\u001b[38;5;124m'\\u001b[39m\\u001b[38;5;132;01m%s\\u001b[39;00m\\u001b[38;5;124m'\\u001b[39m\\u001b[38;5;124m to file \\u001b[39m\\u001b[38;5;124m'\\u001b[39m\\u001b[38;5;132;01m%s\\u001b[39;00m\\u001b[38;5;124m'\\u001b[39m\\u001b[38;5;124m.\\u001b[39m\\u001b[38;5;124m\\\"\\u001b[39m,\\n\\u001b[1;32m 231\\u001b[0m verb,\\n\\u001b[1;32m 232\\u001b[0m url,\\n\\u001b[1;32m 233\\u001b[0m \\u001b[38;5;28mstr\\u001b[39m(full_path),\\n\\u001b[1;32m 234\\u001b[0m )\\n\\u001b[1;32m 236\\u001b[0m \\u001b[38;5;28;01mif\\u001b[39;00m downloader \\u001b[38;5;129;01mis\\u001b[39;00m \\u001b[38;5;28;01mNone\\u001b[39;00m:\\n\",\n \"File \\u001b[0;32m/usr/lib/python3/dist-packages/pooch/utils.py:276\\u001b[0m, in \\u001b[0;36mmake_local_storage\\u001b[0;34m(path, env)\\u001b[0m\\n\\u001b[1;32m 272\\u001b[0m \\u001b[38;5;28;01mif\\u001b[39;00m env \\u001b[38;5;129;01mis\\u001b[39;00m \\u001b[38;5;129;01mnot\\u001b[39;00m \\u001b[38;5;28;01mNone\\u001b[39;00m:\\n\\u001b[1;32m 273\\u001b[0m message\\u001b[38;5;241m.\\u001b[39mappend(\\n\\u001b[1;32m 274\\u001b[0m \\u001b[38;5;124mf\\u001b[39m\\u001b[38;5;124m\\\"\\u001b[39m\\u001b[38;5;124mUse environment variable \\u001b[39m\\u001b[38;5;124m'\\u001b[39m\\u001b[38;5;132;01m{\\u001b[39;00menv\\u001b[38;5;132;01m}\\u001b[39;00m\\u001b[38;5;124m'\\u001b[39m\\u001b[38;5;124m to specify a different location.\\u001b[39m\\u001b[38;5;124m\\\"\\u001b[39m\\n\\u001b[1;32m 275\\u001b[0m )\\n\\u001b[0;32m--> 276\\u001b[0m \\u001b[38;5;28;01mraise\\u001b[39;00m \\u001b[38;5;167;01mPermissionError\\u001b[39;00m(\\u001b[38;5;124m\\\"\\u001b[39m\\u001b[38;5;124m \\u001b[39m\\u001b[38;5;124m\\\"\\u001b[39m\\u001b[38;5;241m.\\u001b[39mjoin(message)) \\u001b[38;5;28;01mfrom\\u001b[39;00m \\u001b[38;5;21;01merror\\u001b[39;00m\\n\",\n- \"\\u001b[0;31mPermissionError\\u001b[0m: [Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/first-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\"\n+ \"\\u001b[0;31mPermissionError\\u001b[0m: [Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/second-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\"\n ]\n }\n ],\n \"source\": [\n \"ds = xr.tutorial.load_dataset(\\\"air_temperature\\\")\\n\",\n \"\\n\",\n \"# to celsius\\n\",\n@@ -122,18 +122,18 @@\n \"execution_count\": 3,\n \"metadata\": {\n \"ExecuteTime\": {\n \"end_time\": \"2020-03-17T14:43:59.887120Z\",\n \"start_time\": \"2020-03-17T14:43:59.582894Z\"\n },\n \"execution\": {\n- \"iopub.execute_input\": \"2026-04-07T09:27:05.546179Z\",\n- \"iopub.status.busy\": \"2026-04-07T09:27:05.545937Z\",\n- \"iopub.status.idle\": \"2026-04-07T09:27:05.622282Z\",\n- \"shell.execute_reply\": \"2026-04-07T09:27:05.621737Z\"\n+ \"iopub.execute_input\": \"2025-03-05T03:36:30.854962Z\",\n+ \"iopub.status.busy\": \"2025-03-05T03:36:30.854474Z\",\n+ \"iopub.status.idle\": \"2025-03-05T03:36:31.064880Z\",\n+ \"shell.execute_reply\": \"2025-03-05T03:36:31.063217Z\"\n }\n },\n \"outputs\": [\n {\n \"ename\": \"NameError\",\n \"evalue\": \"name 'air' is not defined\",\n \"output_type\": \"error\",\n@@ -178,18 +178,18 @@\n \"execution_count\": 4,\n \"metadata\": {\n \"ExecuteTime\": {\n \"end_time\": \"2020-03-17T14:44:18.777092Z\",\n \"start_time\": \"2020-03-17T14:44:18.736587Z\"\n },\n \"execution\": {\n- \"iopub.execute_input\": \"2026-04-07T09:27:05.624264Z\",\n- \"iopub.status.busy\": \"2026-04-07T09:27:05.624026Z\",\n- \"iopub.status.idle\": \"2026-04-07T09:27:05.636974Z\",\n- \"shell.execute_reply\": \"2026-04-07T09:27:05.636453Z\"\n+ \"iopub.execute_input\": \"2025-03-05T03:36:31.070732Z\",\n+ \"iopub.status.busy\": \"2025-03-05T03:36:31.070246Z\",\n+ \"iopub.status.idle\": \"2025-03-05T03:36:31.111081Z\",\n+ \"shell.execute_reply\": \"2025-03-05T03:36:31.109999Z\"\n }\n },\n \"outputs\": [\n {\n \"ename\": \"NameError\",\n \"evalue\": \"name 'air' is not defined\",\n \"output_type\": \"error\",\n@@ -219,18 +219,18 @@\n \"execution_count\": 5,\n \"metadata\": {\n \"ExecuteTime\": {\n \"end_time\": \"2020-03-17T14:44:52.607120Z\",\n \"start_time\": \"2020-03-17T14:44:52.564674Z\"\n },\n \"execution\": {\n- \"iopub.execute_input\": \"2026-04-07T09:27:05.638820Z\",\n- \"iopub.status.busy\": \"2026-04-07T09:27:05.638594Z\",\n- \"iopub.status.idle\": \"2026-04-07T09:27:05.649833Z\",\n- \"shell.execute_reply\": \"2026-04-07T09:27:05.649314Z\"\n+ \"iopub.execute_input\": \"2025-03-05T03:36:31.117265Z\",\n+ \"iopub.status.busy\": \"2025-03-05T03:36:31.116775Z\",\n+ \"iopub.status.idle\": \"2025-03-05T03:36:31.153422Z\",\n+ \"shell.execute_reply\": \"2025-03-05T03:36:31.152180Z\"\n }\n },\n \"outputs\": [\n {\n \"ename\": \"NameError\",\n \"evalue\": \"name 'air' is not defined\",\n \"output_type\": \"error\",\n@@ -252,18 +252,18 @@\n \"execution_count\": 6,\n \"metadata\": {\n \"ExecuteTime\": {\n \"end_time\": \"2020-03-17T14:44:54.334279Z\",\n \"start_time\": \"2020-03-17T14:44:54.280022Z\"\n },\n \"execution\": {\n- \"iopub.execute_input\": \"2026-04-07T09:27:05.651673Z\",\n- \"iopub.status.busy\": \"2026-04-07T09:27:05.651442Z\",\n- \"iopub.status.idle\": \"2026-04-07T09:27:05.663288Z\",\n- \"shell.execute_reply\": \"2026-04-07T09:27:05.662744Z\"\n+ \"iopub.execute_input\": \"2025-03-05T03:36:31.159025Z\",\n+ \"iopub.status.busy\": \"2025-03-05T03:36:31.158507Z\",\n+ \"iopub.status.idle\": \"2025-03-05T03:36:31.196790Z\",\n+ \"shell.execute_reply\": \"2025-03-05T03:36:31.195222Z\"\n }\n },\n \"outputs\": [\n {\n \"ename\": \"NameError\",\n \"evalue\": \"name 'air_weighted' is not defined\",\n \"output_type\": \"error\",\n@@ -294,18 +294,18 @@\n \"execution_count\": 7,\n \"metadata\": {\n \"ExecuteTime\": {\n \"end_time\": \"2020-03-17T14:45:08.877307Z\",\n \"start_time\": \"2020-03-17T14:45:08.673383Z\"\n },\n \"execution\": {\n- \"iopub.execute_input\": \"2026-04-07T09:27:05.665167Z\",\n- \"iopub.status.busy\": \"2026-04-07T09:27:05.664939Z\",\n- \"iopub.status.idle\": \"2026-04-07T09:27:05.677113Z\",\n- \"shell.execute_reply\": \"2026-04-07T09:27:05.676589Z\"\n+ \"iopub.execute_input\": \"2025-03-05T03:36:31.208720Z\",\n+ \"iopub.status.busy\": \"2025-03-05T03:36:31.208200Z\",\n+ \"iopub.status.idle\": \"2025-03-05T03:36:31.249886Z\",\n+ \"shell.execute_reply\": \"2025-03-05T03:36:31.248539Z\"\n }\n },\n \"outputs\": [\n {\n \"ename\": \"NameError\",\n \"evalue\": \"name 'weighted_mean' is not defined\",\n \"output_type\": \"error\",\n"}]}]}, {"source1": "./usr/share/doc/python-xarray-doc/html/examples/blank_template.html", "source2": "./usr/share/doc/python-xarray-doc/html/examples/blank_template.html", "unified_diff": "@@ -160,15 +160,15 @@\n File /usr/lib/python3/dist-packages/pooch/utils.py:276, in make_local_storage(path, env)\n 272 if env is not None:\n 273 message.append(\n 274 f"Use environment variable '{env}' to specify a different location."\n 275 )\n --> 276 raise PermissionError(" ".join(message)) from error\n \n-PermissionError: [Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/first-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\n+PermissionError: [Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/second-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\n
\n \n
\n
[ ]:\n 
\n
\n
\n", "details": [{"source1": "html2text {}", "source2": "html2text {}", "unified_diff": "@@ -99,15 +99,15 @@\n     273     message.append(\n     274         f\"Use environment variable '{env}' to specify a different\n location.\"\n     275     )\n --> 276 raise PermissionError(\" \".join(message)) from error\n \n PermissionError: [Errno 13] Permission denied: '/nonexistent' | Pooch could not\n-create data cache folder '/nonexistent/first-build/.cache/\n+create data cache folder '/nonexistent/second-build/.cache/\n xarray_tutorial_data'. Will not be able to download data files.\n [ ]:\n _\b[_\bL_\bo_\bg_\bo_\b _\bo_\bf_\b _\bx_\ba_\br_\br_\ba_\by_\b]\n *\b**\b**\b**\b**\b**\b* _\bx\bx_\ba\ba_\br\br_\br\br_\ba\ba_\by\by *\b**\b**\b**\b**\b**\b*\n *\b**\b**\b**\b* N\bNa\bav\bvi\big\bga\bat\bti\bio\bon\bn *\b**\b**\b**\b*\n For users\n     * _\bG_\be_\bt_\bt_\bi_\bn_\bg_\b _\bS_\bt_\ba_\br_\bt_\be_\bd\n"}]}, {"source1": "./usr/share/doc/python-xarray-doc/html/examples/blank_template.ipynb.gz", "source2": "./usr/share/doc/python-xarray-doc/html/examples/blank_template.ipynb.gz", "unified_diff": null, "details": [{"source1": "blank_template.ipynb", "source2": "blank_template.ipynb", "unified_diff": null, "details": [{"source1": "Pretty-printed", "source2": "Pretty-printed", "comments": ["Similarity: 0.9986468545751634%", "Differences: {\"'cells'\": \"{1: {'metadata': {'execution': {'iopub.execute_input': '2025-03-05T03:36:38.709491Z', \"", "            \"'iopub.status.busy': '2025-03-05T03:36:38.709018Z', 'iopub.status.idle': \"", "            \"'2025-03-05T03:36:41.861727Z', 'shell.execute_reply': \"", "            '\\'2025-03-05T03:36:41.859998Z\\'}}, \\'outputs\\': {0: {\\'evalue\\': \"[Errno 13] '", "            \"Permission denied: '/nonexistent' | Pooch could not create data cache folder \"", "            \"'/nonexistent/second-build/.cache/xarray_tutorial_data'.  [\u2026]"], "unified_diff": "@@ -12,24 +12,24 @@\n         },\n         {\n             \"cell_type\": \"code\",\n             \"execution_count\": 1,\n             \"id\": \"41b90ede\",\n             \"metadata\": {\n                 \"execution\": {\n-                    \"iopub.execute_input\": \"2026-04-07T09:27:07.732799Z\",\n-                    \"iopub.status.busy\": \"2026-04-07T09:27:07.732555Z\",\n-                    \"iopub.status.idle\": \"2026-04-07T09:27:08.437060Z\",\n-                    \"shell.execute_reply\": \"2026-04-07T09:27:08.436143Z\"\n+                    \"iopub.execute_input\": \"2025-03-05T03:36:38.709491Z\",\n+                    \"iopub.status.busy\": \"2025-03-05T03:36:38.709018Z\",\n+                    \"iopub.status.idle\": \"2025-03-05T03:36:41.861727Z\",\n+                    \"shell.execute_reply\": \"2025-03-05T03:36:41.859998Z\"\n                 }\n             },\n             \"outputs\": [\n                 {\n                     \"ename\": \"PermissionError\",\n-                    \"evalue\": \"[Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/first-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\",\n+                    \"evalue\": \"[Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/second-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\",\n                     \"output_type\": \"error\",\n                     \"traceback\": [\n                         \"\\u001b[0;31m---------------------------------------------------------------------------\\u001b[0m\",\n                         \"\\u001b[0;31mPermissionError\\u001b[0m                           Traceback (most recent call last)\",\n                         \"File \\u001b[0;32m/usr/lib/python3/dist-packages/pooch/utils.py:262\\u001b[0m, in \\u001b[0;36mmake_local_storage\\u001b[0;34m(path, env)\\u001b[0m\\n\\u001b[1;32m    258\\u001b[0m \\u001b[38;5;28;01mif\\u001b[39;00m action \\u001b[38;5;241m==\\u001b[39m \\u001b[38;5;124m\\\"\\u001b[39m\\u001b[38;5;124mcreate\\u001b[39m\\u001b[38;5;124m\\\"\\u001b[39m:\\n\\u001b[1;32m    259\\u001b[0m     \\u001b[38;5;66;03m# When running in parallel, it's possible that multiple jobs will\\u001b[39;00m\\n\\u001b[1;32m    260\\u001b[0m     \\u001b[38;5;66;03m# try to create the path at the same time. Use exist_ok to avoid\\u001b[39;00m\\n\\u001b[1;32m    261\\u001b[0m     \\u001b[38;5;66;03m# raising an error.\\u001b[39;00m\\n\\u001b[0;32m--> 262\\u001b[0m     \\u001b[43mos\\u001b[49m\\u001b[38;5;241;43m.\\u001b[39;49m\\u001b[43mmakedirs\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[43mpath\\u001b[49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[43mexist_ok\\u001b[49m\\u001b[38;5;241;43m=\\u001b[39;49m\\u001b[38;5;28;43;01mTrue\\u001b[39;49;00m\\u001b[43m)\\u001b[49m\\n\\u001b[1;32m    263\\u001b[0m \\u001b[38;5;28;01melse\\u001b[39;00m:\\n\",\n                         \"File \\u001b[0;32m/usr/lib/python3.13/os.py:217\\u001b[0m, in \\u001b[0;36mmakedirs\\u001b[0;34m(name, mode, exist_ok)\\u001b[0m\\n\\u001b[1;32m    216\\u001b[0m \\u001b[38;5;28;01mtry\\u001b[39;00m:\\n\\u001b[0;32m--> 217\\u001b[0m     \\u001b[43mmakedirs\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[43mhead\\u001b[49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[43mexist_ok\\u001b[49m\\u001b[38;5;241;43m=\\u001b[39;49m\\u001b[43mexist_ok\\u001b[49m\\u001b[43m)\\u001b[49m\\n\\u001b[1;32m    218\\u001b[0m \\u001b[38;5;28;01mexcept\\u001b[39;00m \\u001b[38;5;167;01mFileExistsError\\u001b[39;00m:\\n\\u001b[1;32m    219\\u001b[0m     \\u001b[38;5;66;03m# Defeats race condition when another thread created the path\\u001b[39;00m\\n\",\n                         \"File \\u001b[0;32m/usr/lib/python3.13/os.py:217\\u001b[0m, in \\u001b[0;36mmakedirs\\u001b[0;34m(name, mode, exist_ok)\\u001b[0m\\n\\u001b[1;32m    216\\u001b[0m \\u001b[38;5;28;01mtry\\u001b[39;00m:\\n\\u001b[0;32m--> 217\\u001b[0m     \\u001b[43mmakedirs\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[43mhead\\u001b[49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[43mexist_ok\\u001b[49m\\u001b[38;5;241;43m=\\u001b[39;49m\\u001b[43mexist_ok\\u001b[49m\\u001b[43m)\\u001b[49m\\n\\u001b[1;32m    218\\u001b[0m \\u001b[38;5;28;01mexcept\\u001b[39;00m \\u001b[38;5;167;01mFileExistsError\\u001b[39;00m:\\n\\u001b[1;32m    219\\u001b[0m     \\u001b[38;5;66;03m# Defeats race condition when another thread created the path\\u001b[39;00m\\n\",\n@@ -39,15 +39,15 @@\n                         \"\\nThe above exception was the direct cause of the following exception:\\n\",\n                         \"\\u001b[0;31mPermissionError\\u001b[0m                           Traceback (most recent call last)\",\n                         \"Cell \\u001b[0;32mIn[1], line 5\\u001b[0m\\n\\u001b[1;32m      2\\u001b[0m \\u001b[38;5;28;01mimport\\u001b[39;00m \\u001b[38;5;21;01mnumpy\\u001b[39;00m \\u001b[38;5;28;01mas\\u001b[39;00m \\u001b[38;5;21;01mnp\\u001b[39;00m\\n\\u001b[1;32m      3\\u001b[0m \\u001b[38;5;28;01mimport\\u001b[39;00m \\u001b[38;5;21;01mpandas\\u001b[39;00m \\u001b[38;5;28;01mas\\u001b[39;00m \\u001b[38;5;21;01mpd\\u001b[39;00m\\n\\u001b[0;32m----> 5\\u001b[0m ds \\u001b[38;5;241m=\\u001b[39m \\u001b[43mxr\\u001b[49m\\u001b[38;5;241;43m.\\u001b[39;49m\\u001b[43mtutorial\\u001b[49m\\u001b[38;5;241;43m.\\u001b[39;49m\\u001b[43mload_dataset\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[38;5;124;43m\\\"\\u001b[39;49m\\u001b[38;5;124;43mair_temperature\\u001b[39;49m\\u001b[38;5;124;43m\\\"\\u001b[39;49m\\u001b[43m)\\u001b[49m\\n\\u001b[1;32m      6\\u001b[0m da \\u001b[38;5;241m=\\u001b[39m ds[\\u001b[38;5;124m\\\"\\u001b[39m\\u001b[38;5;124mair\\u001b[39m\\u001b[38;5;124m\\\"\\u001b[39m]\\n\",\n                         \"File \\u001b[0;32m/usr/lib/python3/dist-packages/xarray/tutorial.py:213\\u001b[0m, in \\u001b[0;36mload_dataset\\u001b[0;34m(*args, **kwargs)\\u001b[0m\\n\\u001b[1;32m    176\\u001b[0m \\u001b[38;5;28;01mdef\\u001b[39;00m \\u001b[38;5;21mload_dataset\\u001b[39m(\\u001b[38;5;241m*\\u001b[39margs, \\u001b[38;5;241m*\\u001b[39m\\u001b[38;5;241m*\\u001b[39mkwargs) \\u001b[38;5;241m-\\u001b[39m\\u001b[38;5;241m>\\u001b[39m Dataset:\\n\\u001b[1;32m    177\\u001b[0m \\u001b[38;5;250m    \\u001b[39m\\u001b[38;5;124;03m\\\"\\\"\\\"\\u001b[39;00m\\n\\u001b[1;32m    178\\u001b[0m \\u001b[38;5;124;03m    Open, load into memory, and close a dataset from the online repository\\u001b[39;00m\\n\\u001b[1;32m    179\\u001b[0m \\u001b[38;5;124;03m    (requires internet).\\u001b[39;00m\\n\\u001b[0;32m   (...)\\u001b[0m\\n\\u001b[1;32m    211\\u001b[0m \\u001b[38;5;124;03m    load_dataset\\u001b[39;00m\\n\\u001b[1;32m    212\\u001b[0m \\u001b[38;5;124;03m    \\\"\\\"\\\"\\u001b[39;00m\\n\\u001b[0;32m--> 213\\u001b[0m     \\u001b[38;5;28;01mwith\\u001b[39;00m \\u001b[43mopen_dataset\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[38;5;241;43m*\\u001b[39;49m\\u001b[43margs\\u001b[49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[38;5;241;43m*\\u001b[39;49m\\u001b[38;5;241;43m*\\u001b[39;49m\\u001b[43mkwargs\\u001b[49m\\u001b[43m)\\u001b[49m \\u001b[38;5;28;01mas\\u001b[39;00m ds:\\n\\u001b[1;32m    214\\u001b[0m         \\u001b[38;5;28;01mreturn\\u001b[39;00m ds\\u001b[38;5;241m.\\u001b[39mload()\\n\",\n                         \"File \\u001b[0;32m/usr/lib/python3/dist-packages/xarray/tutorial.py:165\\u001b[0m, in \\u001b[0;36mopen_dataset\\u001b[0;34m(name, cache, cache_dir, engine, **kws)\\u001b[0m\\n\\u001b[1;32m    162\\u001b[0m downloader \\u001b[38;5;241m=\\u001b[39m pooch\\u001b[38;5;241m.\\u001b[39mHTTPDownloader(headers\\u001b[38;5;241m=\\u001b[39mheaders)\\n\\u001b[1;32m    164\\u001b[0m \\u001b[38;5;66;03m# retrieve the file\\u001b[39;00m\\n\\u001b[0;32m--> 165\\u001b[0m filepath \\u001b[38;5;241m=\\u001b[39m \\u001b[43mpooch\\u001b[49m\\u001b[38;5;241;43m.\\u001b[39;49m\\u001b[43mretrieve\\u001b[49m\\u001b[43m(\\u001b[49m\\n\\u001b[1;32m    166\\u001b[0m \\u001b[43m    \\u001b[49m\\u001b[43murl\\u001b[49m\\u001b[38;5;241;43m=\\u001b[39;49m\\u001b[43murl\\u001b[49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[43mknown_hash\\u001b[49m\\u001b[38;5;241;43m=\\u001b[39;49m\\u001b[38;5;28;43;01mNone\\u001b[39;49;00m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[43mpath\\u001b[49m\\u001b[38;5;241;43m=\\u001b[39;49m\\u001b[43mcache_dir\\u001b[49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[43mdownloader\\u001b[49m\\u001b[38;5;241;43m=\\u001b[39;49m\\u001b[43mdownloader\\u001b[49m\\n\\u001b[1;32m    167\\u001b[0m \\u001b[43m\\u001b[49m\\u001b[43m)\\u001b[49m\\n\\u001b[1;32m    168\\u001b[0m ds \\u001b[38;5;241m=\\u001b[39m _open_dataset(filepath, engine\\u001b[38;5;241m=\\u001b[39mengine, \\u001b[38;5;241m*\\u001b[39m\\u001b[38;5;241m*\\u001b[39mkws)\\n\\u001b[1;32m    169\\u001b[0m \\u001b[38;5;28;01mif\\u001b[39;00m \\u001b[38;5;129;01mnot\\u001b[39;00m cache:\\n\",\n                         \"File \\u001b[0;32m/usr/lib/python3/dist-packages/pooch/core.py:227\\u001b[0m, in \\u001b[0;36mretrieve\\u001b[0;34m(url, known_hash, fname, path, processor, downloader, progressbar)\\u001b[0m\\n\\u001b[1;32m    222\\u001b[0m action, verb \\u001b[38;5;241m=\\u001b[39m download_action(full_path, known_hash)\\n\\u001b[1;32m    224\\u001b[0m \\u001b[38;5;28;01mif\\u001b[39;00m action \\u001b[38;5;129;01min\\u001b[39;00m (\\u001b[38;5;124m\\\"\\u001b[39m\\u001b[38;5;124mdownload\\u001b[39m\\u001b[38;5;124m\\\"\\u001b[39m, \\u001b[38;5;124m\\\"\\u001b[39m\\u001b[38;5;124mupdate\\u001b[39m\\u001b[38;5;124m\\\"\\u001b[39m):\\n\\u001b[1;32m    225\\u001b[0m     \\u001b[38;5;66;03m# We need to write data, so create the local data directory if it\\u001b[39;00m\\n\\u001b[1;32m    226\\u001b[0m     \\u001b[38;5;66;03m# doesn't already exist.\\u001b[39;00m\\n\\u001b[0;32m--> 227\\u001b[0m     \\u001b[43mmake_local_storage\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[43mpath\\u001b[49m\\u001b[43m)\\u001b[49m\\n\\u001b[1;32m    229\\u001b[0m     get_logger()\\u001b[38;5;241m.\\u001b[39minfo(\\n\\u001b[1;32m    230\\u001b[0m         \\u001b[38;5;124m\\\"\\u001b[39m\\u001b[38;5;132;01m%s\\u001b[39;00m\\u001b[38;5;124m data from \\u001b[39m\\u001b[38;5;124m'\\u001b[39m\\u001b[38;5;132;01m%s\\u001b[39;00m\\u001b[38;5;124m'\\u001b[39m\\u001b[38;5;124m to file \\u001b[39m\\u001b[38;5;124m'\\u001b[39m\\u001b[38;5;132;01m%s\\u001b[39;00m\\u001b[38;5;124m'\\u001b[39m\\u001b[38;5;124m.\\u001b[39m\\u001b[38;5;124m\\\"\\u001b[39m,\\n\\u001b[1;32m    231\\u001b[0m         verb,\\n\\u001b[1;32m    232\\u001b[0m         url,\\n\\u001b[1;32m    233\\u001b[0m         \\u001b[38;5;28mstr\\u001b[39m(full_path),\\n\\u001b[1;32m    234\\u001b[0m     )\\n\\u001b[1;32m    236\\u001b[0m     \\u001b[38;5;28;01mif\\u001b[39;00m downloader \\u001b[38;5;129;01mis\\u001b[39;00m \\u001b[38;5;28;01mNone\\u001b[39;00m:\\n\",\n                         \"File \\u001b[0;32m/usr/lib/python3/dist-packages/pooch/utils.py:276\\u001b[0m, in \\u001b[0;36mmake_local_storage\\u001b[0;34m(path, env)\\u001b[0m\\n\\u001b[1;32m    272\\u001b[0m \\u001b[38;5;28;01mif\\u001b[39;00m env \\u001b[38;5;129;01mis\\u001b[39;00m \\u001b[38;5;129;01mnot\\u001b[39;00m \\u001b[38;5;28;01mNone\\u001b[39;00m:\\n\\u001b[1;32m    273\\u001b[0m     message\\u001b[38;5;241m.\\u001b[39mappend(\\n\\u001b[1;32m    274\\u001b[0m         \\u001b[38;5;124mf\\u001b[39m\\u001b[38;5;124m\\\"\\u001b[39m\\u001b[38;5;124mUse environment variable \\u001b[39m\\u001b[38;5;124m'\\u001b[39m\\u001b[38;5;132;01m{\\u001b[39;00menv\\u001b[38;5;132;01m}\\u001b[39;00m\\u001b[38;5;124m'\\u001b[39m\\u001b[38;5;124m to specify a different location.\\u001b[39m\\u001b[38;5;124m\\\"\\u001b[39m\\n\\u001b[1;32m    275\\u001b[0m     )\\n\\u001b[0;32m--> 276\\u001b[0m \\u001b[38;5;28;01mraise\\u001b[39;00m \\u001b[38;5;167;01mPermissionError\\u001b[39;00m(\\u001b[38;5;124m\\\"\\u001b[39m\\u001b[38;5;124m \\u001b[39m\\u001b[38;5;124m\\\"\\u001b[39m\\u001b[38;5;241m.\\u001b[39mjoin(message)) \\u001b[38;5;28;01mfrom\\u001b[39;00m \\u001b[38;5;21;01merror\\u001b[39;00m\\n\",\n-                        \"\\u001b[0;31mPermissionError\\u001b[0m: [Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/first-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\"\n+                        \"\\u001b[0;31mPermissionError\\u001b[0m: [Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/second-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\"\n                     ]\n                 }\n             ],\n             \"source\": [\n                 \"import xarray as xr\\n\",\n                 \"import numpy as np\\n\",\n                 \"import pandas as pd\\n\",\n"}]}]}, {"source1": "./usr/share/doc/python-xarray-doc/html/examples/monthly-means.html", "source2": "./usr/share/doc/python-xarray-doc/html/examples/monthly-means.html", "unified_diff": "@@ -159,15 +159,15 @@\n File /usr/lib/python3/dist-packages/pooch/utils.py:276, in make_local_storage(path, env)\n     272 if env is not None:\n     273     message.append(\n     274         f"Use environment variable '{env}' to specify a different location."\n     275     )\n --> 276 raise PermissionError(" ".join(message)) from error\n \n-PermissionError: [Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/first-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\n+PermissionError: [Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/second-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\n 
\n
\n
\n
\n

Now for the heavy lifting:\u00b6

\n

We first have to come up with the weights, - calculate the month length for each monthly data record - calculate weights using groupby('time.season')

\n

Finally, we just need to multiply our weights by the Dataset and sum along the time dimension. Creating a DataArray for the month length is as easy as using the days_in_month accessor on the time coordinate. The calendar type, in this case 'noleap', is automatically considered in this operation.

\n", "details": [{"source1": "html2text {}", "source2": "html2text {}", "unified_diff": "@@ -92,15 +92,15 @@\n 273 message.append(\n 274 f\"Use environment variable '{env}' to specify a different\n location.\"\n 275 )\n --> 276 raise PermissionError(\" \".join(message)) from error\n \n PermissionError: [Errno 13] Permission denied: '/nonexistent' | Pooch could not\n-create data cache folder '/nonexistent/first-build/.cache/\n+create data cache folder '/nonexistent/second-build/.cache/\n xarray_tutorial_data'. Will not be able to download data files.\n *\b**\b**\b**\b**\b* N\bNo\bow\bw f\bfo\bor\br t\bth\bhe\be h\bhe\bea\bav\bvy\by l\bli\bif\bft\bti\bin\bng\bg:\b:_\b?\b\u00b6 *\b**\b**\b**\b**\b*\n We first have to come up with the weights, - calculate the month length for\n each monthly data record - calculate weights using groupby('time.season')\n Finally, we just need to multiply our weights by the Dataset and sum along the\n time dimension. Creating a DataArray for the month length is as easy as using\n the days_in_month accessor on the time coordinate. The calendar type, in this\n"}]}, {"source1": "./usr/share/doc/python-xarray-doc/html/examples/monthly-means.ipynb.gz", "source2": "./usr/share/doc/python-xarray-doc/html/examples/monthly-means.ipynb.gz", "unified_diff": null, "details": [{"source1": "monthly-means.ipynb", "source2": "monthly-means.ipynb", "unified_diff": null, "details": [{"source1": "Pretty-printed", "source2": "Pretty-printed", "comments": ["Similarity: 0.9985617897727272%", "Differences: {\"'cells'\": \"{1: {'metadata': {'execution': {'iopub.execute_input': '2025-03-05T03:36:48.941196Z', \"", " \"'iopub.status.busy': '2025-03-05T03:36:48.940603Z', 'iopub.status.idle': \"", " \"'2025-03-05T03:36:51.756040Z', 'shell.execute_reply': \"", " \"'2025-03-05T03:36:51.739988Z'}}}, 3: {'metadata': {'execution': \"", " \"{'iopub.execute_input': '2025-03-05T03:36:51.774340Z', 'iopub.status.busy': \"", " \"'2025-03-05T03:36:51.773369Z', 'iopub.status.idle': '2025-03-05T03:36:5 [\u2026]"], "unified_diff": "@@ -19,18 +19,18 @@\n \"execution_count\": 1,\n \"metadata\": {\n \"ExecuteTime\": {\n \"end_time\": \"2018-11-28T20:51:35.958210Z\",\n \"start_time\": \"2018-11-28T20:51:35.936966Z\"\n },\n \"execution\": {\n- \"iopub.execute_input\": \"2026-04-07T09:27:10.204142Z\",\n- \"iopub.status.busy\": \"2026-04-07T09:27:10.203897Z\",\n- \"iopub.status.idle\": \"2026-04-07T09:27:11.015766Z\",\n- \"shell.execute_reply\": \"2026-04-07T09:27:11.015053Z\"\n+ \"iopub.execute_input\": \"2025-03-05T03:36:48.941196Z\",\n+ \"iopub.status.busy\": \"2025-03-05T03:36:48.940603Z\",\n+ \"iopub.status.idle\": \"2025-03-05T03:36:51.756040Z\",\n+ \"shell.execute_reply\": \"2025-03-05T03:36:51.739988Z\"\n }\n },\n \"outputs\": [],\n \"source\": [\n \"%matplotlib inline\\n\",\n \"import numpy as np\\n\",\n \"import pandas as pd\\n\",\n@@ -50,24 +50,24 @@\n \"execution_count\": 2,\n \"metadata\": {\n \"ExecuteTime\": {\n \"end_time\": \"2018-11-28T20:51:36.072316Z\",\n \"start_time\": \"2018-11-28T20:51:36.016594Z\"\n },\n \"execution\": {\n- \"iopub.execute_input\": \"2026-04-07T09:27:11.018675Z\",\n- \"iopub.status.busy\": \"2026-04-07T09:27:11.018289Z\",\n- \"iopub.status.idle\": \"2026-04-07T09:27:11.294873Z\",\n- \"shell.execute_reply\": \"2026-04-07T09:27:11.294188Z\"\n+ \"iopub.execute_input\": \"2025-03-05T03:36:51.774340Z\",\n+ \"iopub.status.busy\": \"2025-03-05T03:36:51.773369Z\",\n+ \"iopub.status.idle\": \"2025-03-05T03:36:54.008786Z\",\n+ \"shell.execute_reply\": \"2025-03-05T03:36:53.996927Z\"\n }\n },\n \"outputs\": [\n {\n \"ename\": \"PermissionError\",\n- \"evalue\": \"[Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/first-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\",\n+ \"evalue\": \"[Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/second-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\",\n \"output_type\": \"error\",\n \"traceback\": [\n \"\\u001b[0;31m---------------------------------------------------------------------------\\u001b[0m\",\n \"\\u001b[0;31mPermissionError\\u001b[0m Traceback (most recent call last)\",\n \"File \\u001b[0;32m/usr/lib/python3/dist-packages/pooch/utils.py:262\\u001b[0m, in \\u001b[0;36mmake_local_storage\\u001b[0;34m(path, env)\\u001b[0m\\n\\u001b[1;32m 258\\u001b[0m \\u001b[38;5;28;01mif\\u001b[39;00m action \\u001b[38;5;241m==\\u001b[39m \\u001b[38;5;124m\\\"\\u001b[39m\\u001b[38;5;124mcreate\\u001b[39m\\u001b[38;5;124m\\\"\\u001b[39m:\\n\\u001b[1;32m 259\\u001b[0m \\u001b[38;5;66;03m# When running in parallel, it's possible that multiple jobs will\\u001b[39;00m\\n\\u001b[1;32m 260\\u001b[0m \\u001b[38;5;66;03m# try to create the path at the same time. Use exist_ok to avoid\\u001b[39;00m\\n\\u001b[1;32m 261\\u001b[0m \\u001b[38;5;66;03m# raising an error.\\u001b[39;00m\\n\\u001b[0;32m--> 262\\u001b[0m \\u001b[43mos\\u001b[49m\\u001b[38;5;241;43m.\\u001b[39;49m\\u001b[43mmakedirs\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[43mpath\\u001b[49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[43mexist_ok\\u001b[49m\\u001b[38;5;241;43m=\\u001b[39;49m\\u001b[38;5;28;43;01mTrue\\u001b[39;49;00m\\u001b[43m)\\u001b[49m\\n\\u001b[1;32m 263\\u001b[0m \\u001b[38;5;28;01melse\\u001b[39;00m:\\n\",\n \"File \\u001b[0;32m/usr/lib/python3.13/os.py:217\\u001b[0m, in \\u001b[0;36mmakedirs\\u001b[0;34m(name, mode, exist_ok)\\u001b[0m\\n\\u001b[1;32m 216\\u001b[0m \\u001b[38;5;28;01mtry\\u001b[39;00m:\\n\\u001b[0;32m--> 217\\u001b[0m \\u001b[43mmakedirs\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[43mhead\\u001b[49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[43mexist_ok\\u001b[49m\\u001b[38;5;241;43m=\\u001b[39;49m\\u001b[43mexist_ok\\u001b[49m\\u001b[43m)\\u001b[49m\\n\\u001b[1;32m 218\\u001b[0m \\u001b[38;5;28;01mexcept\\u001b[39;00m \\u001b[38;5;167;01mFileExistsError\\u001b[39;00m:\\n\\u001b[1;32m 219\\u001b[0m \\u001b[38;5;66;03m# Defeats race condition when another thread created the path\\u001b[39;00m\\n\",\n \"File \\u001b[0;32m/usr/lib/python3.13/os.py:217\\u001b[0m, in \\u001b[0;36mmakedirs\\u001b[0;34m(name, mode, exist_ok)\\u001b[0m\\n\\u001b[1;32m 216\\u001b[0m \\u001b[38;5;28;01mtry\\u001b[39;00m:\\n\\u001b[0;32m--> 217\\u001b[0m \\u001b[43mmakedirs\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[43mhead\\u001b[49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[43mexist_ok\\u001b[49m\\u001b[38;5;241;43m=\\u001b[39;49m\\u001b[43mexist_ok\\u001b[49m\\u001b[43m)\\u001b[49m\\n\\u001b[1;32m 218\\u001b[0m \\u001b[38;5;28;01mexcept\\u001b[39;00m \\u001b[38;5;167;01mFileExistsError\\u001b[39;00m:\\n\\u001b[1;32m 219\\u001b[0m \\u001b[38;5;66;03m# Defeats race condition when another thread created the path\\u001b[39;00m\\n\",\n@@ -76,15 +76,15 @@\n \"\\u001b[0;31mPermissionError\\u001b[0m: [Errno 13] Permission denied: '/nonexistent'\",\n \"\\nThe above exception was the direct cause of the following exception:\\n\",\n \"\\u001b[0;31mPermissionError\\u001b[0m Traceback (most recent call last)\",\n \"Cell \\u001b[0;32mIn[2], line 1\\u001b[0m\\n\\u001b[0;32m----> 1\\u001b[0m ds \\u001b[38;5;241m=\\u001b[39m \\u001b[43mxr\\u001b[49m\\u001b[38;5;241;43m.\\u001b[39;49m\\u001b[43mtutorial\\u001b[49m\\u001b[38;5;241;43m.\\u001b[39;49m\\u001b[43mopen_dataset\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[38;5;124;43m\\\"\\u001b[39;49m\\u001b[38;5;124;43mrasm\\u001b[39;49m\\u001b[38;5;124;43m\\\"\\u001b[39;49m\\u001b[43m)\\u001b[49m\\u001b[38;5;241m.\\u001b[39mload()\\n\\u001b[1;32m 2\\u001b[0m ds\\n\",\n \"File \\u001b[0;32m/usr/lib/python3/dist-packages/xarray/tutorial.py:165\\u001b[0m, in \\u001b[0;36mopen_dataset\\u001b[0;34m(name, cache, cache_dir, engine, **kws)\\u001b[0m\\n\\u001b[1;32m 162\\u001b[0m downloader \\u001b[38;5;241m=\\u001b[39m pooch\\u001b[38;5;241m.\\u001b[39mHTTPDownloader(headers\\u001b[38;5;241m=\\u001b[39mheaders)\\n\\u001b[1;32m 164\\u001b[0m \\u001b[38;5;66;03m# retrieve the file\\u001b[39;00m\\n\\u001b[0;32m--> 165\\u001b[0m filepath \\u001b[38;5;241m=\\u001b[39m \\u001b[43mpooch\\u001b[49m\\u001b[38;5;241;43m.\\u001b[39;49m\\u001b[43mretrieve\\u001b[49m\\u001b[43m(\\u001b[49m\\n\\u001b[1;32m 166\\u001b[0m \\u001b[43m \\u001b[49m\\u001b[43murl\\u001b[49m\\u001b[38;5;241;43m=\\u001b[39;49m\\u001b[43murl\\u001b[49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[43mknown_hash\\u001b[49m\\u001b[38;5;241;43m=\\u001b[39;49m\\u001b[38;5;28;43;01mNone\\u001b[39;49;00m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[43mpath\\u001b[49m\\u001b[38;5;241;43m=\\u001b[39;49m\\u001b[43mcache_dir\\u001b[49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[43mdownloader\\u001b[49m\\u001b[38;5;241;43m=\\u001b[39;49m\\u001b[43mdownloader\\u001b[49m\\n\\u001b[1;32m 167\\u001b[0m \\u001b[43m\\u001b[49m\\u001b[43m)\\u001b[49m\\n\\u001b[1;32m 168\\u001b[0m ds \\u001b[38;5;241m=\\u001b[39m _open_dataset(filepath, engine\\u001b[38;5;241m=\\u001b[39mengine, \\u001b[38;5;241m*\\u001b[39m\\u001b[38;5;241m*\\u001b[39mkws)\\n\\u001b[1;32m 169\\u001b[0m \\u001b[38;5;28;01mif\\u001b[39;00m \\u001b[38;5;129;01mnot\\u001b[39;00m cache:\\n\",\n \"File \\u001b[0;32m/usr/lib/python3/dist-packages/pooch/core.py:227\\u001b[0m, in \\u001b[0;36mretrieve\\u001b[0;34m(url, known_hash, fname, path, processor, downloader, progressbar)\\u001b[0m\\n\\u001b[1;32m 222\\u001b[0m action, verb \\u001b[38;5;241m=\\u001b[39m download_action(full_path, known_hash)\\n\\u001b[1;32m 224\\u001b[0m \\u001b[38;5;28;01mif\\u001b[39;00m action \\u001b[38;5;129;01min\\u001b[39;00m (\\u001b[38;5;124m\\\"\\u001b[39m\\u001b[38;5;124mdownload\\u001b[39m\\u001b[38;5;124m\\\"\\u001b[39m, \\u001b[38;5;124m\\\"\\u001b[39m\\u001b[38;5;124mupdate\\u001b[39m\\u001b[38;5;124m\\\"\\u001b[39m):\\n\\u001b[1;32m 225\\u001b[0m \\u001b[38;5;66;03m# We need to write data, so create the local data directory if it\\u001b[39;00m\\n\\u001b[1;32m 226\\u001b[0m \\u001b[38;5;66;03m# doesn't already exist.\\u001b[39;00m\\n\\u001b[0;32m--> 227\\u001b[0m \\u001b[43mmake_local_storage\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[43mpath\\u001b[49m\\u001b[43m)\\u001b[49m\\n\\u001b[1;32m 229\\u001b[0m get_logger()\\u001b[38;5;241m.\\u001b[39minfo(\\n\\u001b[1;32m 230\\u001b[0m \\u001b[38;5;124m\\\"\\u001b[39m\\u001b[38;5;132;01m%s\\u001b[39;00m\\u001b[38;5;124m data from \\u001b[39m\\u001b[38;5;124m'\\u001b[39m\\u001b[38;5;132;01m%s\\u001b[39;00m\\u001b[38;5;124m'\\u001b[39m\\u001b[38;5;124m to file \\u001b[39m\\u001b[38;5;124m'\\u001b[39m\\u001b[38;5;132;01m%s\\u001b[39;00m\\u001b[38;5;124m'\\u001b[39m\\u001b[38;5;124m.\\u001b[39m\\u001b[38;5;124m\\\"\\u001b[39m,\\n\\u001b[1;32m 231\\u001b[0m verb,\\n\\u001b[1;32m 232\\u001b[0m url,\\n\\u001b[1;32m 233\\u001b[0m \\u001b[38;5;28mstr\\u001b[39m(full_path),\\n\\u001b[1;32m 234\\u001b[0m )\\n\\u001b[1;32m 236\\u001b[0m \\u001b[38;5;28;01mif\\u001b[39;00m downloader \\u001b[38;5;129;01mis\\u001b[39;00m \\u001b[38;5;28;01mNone\\u001b[39;00m:\\n\",\n \"File \\u001b[0;32m/usr/lib/python3/dist-packages/pooch/utils.py:276\\u001b[0m, in \\u001b[0;36mmake_local_storage\\u001b[0;34m(path, env)\\u001b[0m\\n\\u001b[1;32m 272\\u001b[0m \\u001b[38;5;28;01mif\\u001b[39;00m env \\u001b[38;5;129;01mis\\u001b[39;00m \\u001b[38;5;129;01mnot\\u001b[39;00m \\u001b[38;5;28;01mNone\\u001b[39;00m:\\n\\u001b[1;32m 273\\u001b[0m message\\u001b[38;5;241m.\\u001b[39mappend(\\n\\u001b[1;32m 274\\u001b[0m \\u001b[38;5;124mf\\u001b[39m\\u001b[38;5;124m\\\"\\u001b[39m\\u001b[38;5;124mUse environment variable \\u001b[39m\\u001b[38;5;124m'\\u001b[39m\\u001b[38;5;132;01m{\\u001b[39;00menv\\u001b[38;5;132;01m}\\u001b[39;00m\\u001b[38;5;124m'\\u001b[39m\\u001b[38;5;124m to specify a different location.\\u001b[39m\\u001b[38;5;124m\\\"\\u001b[39m\\n\\u001b[1;32m 275\\u001b[0m )\\n\\u001b[0;32m--> 276\\u001b[0m \\u001b[38;5;28;01mraise\\u001b[39;00m \\u001b[38;5;167;01mPermissionError\\u001b[39;00m(\\u001b[38;5;124m\\\"\\u001b[39m\\u001b[38;5;124m \\u001b[39m\\u001b[38;5;124m\\\"\\u001b[39m\\u001b[38;5;241m.\\u001b[39mjoin(message)) \\u001b[38;5;28;01mfrom\\u001b[39;00m \\u001b[38;5;21;01merror\\u001b[39;00m\\n\",\n- \"\\u001b[0;31mPermissionError\\u001b[0m: [Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/first-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\"\n+ \"\\u001b[0;31mPermissionError\\u001b[0m: [Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/second-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\"\n ]\n }\n ],\n \"source\": [\n \"ds = xr.tutorial.open_dataset(\\\"rasm\\\").load()\\n\",\n \"ds\"\n ]\n@@ -102,18 +102,18 @@\n ]\n },\n {\n \"cell_type\": \"code\",\n \"execution_count\": 3,\n \"metadata\": {\n \"execution\": {\n- \"iopub.execute_input\": \"2026-04-07T09:27:11.297973Z\",\n- \"iopub.status.busy\": \"2026-04-07T09:27:11.297726Z\",\n- \"iopub.status.idle\": \"2026-04-07T09:27:11.311050Z\",\n- \"shell.execute_reply\": \"2026-04-07T09:27:11.310445Z\"\n+ \"iopub.execute_input\": \"2025-03-05T03:36:54.031195Z\",\n+ \"iopub.status.busy\": \"2025-03-05T03:36:54.030667Z\",\n+ \"iopub.status.idle\": \"2025-03-05T03:36:54.117743Z\",\n+ \"shell.execute_reply\": \"2025-03-05T03:36:54.097577Z\"\n }\n },\n \"outputs\": [\n {\n \"ename\": \"NameError\",\n \"evalue\": \"name 'ds' is not defined\",\n \"output_type\": \"error\",\n@@ -135,18 +135,18 @@\n \"execution_count\": 4,\n \"metadata\": {\n \"ExecuteTime\": {\n \"end_time\": \"2018-11-28T20:51:36.132413Z\",\n \"start_time\": \"2018-11-28T20:51:36.073708Z\"\n },\n \"execution\": {\n- \"iopub.execute_input\": \"2026-04-07T09:27:11.313568Z\",\n- \"iopub.status.busy\": \"2026-04-07T09:27:11.313329Z\",\n- \"iopub.status.idle\": \"2026-04-07T09:27:11.326969Z\",\n- \"shell.execute_reply\": \"2026-04-07T09:27:11.326385Z\"\n+ \"iopub.execute_input\": \"2025-03-05T03:36:54.145998Z\",\n+ \"iopub.status.busy\": \"2025-03-05T03:36:54.145323Z\",\n+ \"iopub.status.idle\": \"2025-03-05T03:36:54.364021Z\",\n+ \"shell.execute_reply\": \"2025-03-05T03:36:54.347975Z\"\n }\n },\n \"outputs\": [\n {\n \"ename\": \"NameError\",\n \"evalue\": \"name 'month_length' is not defined\",\n \"output_type\": \"error\",\n@@ -176,18 +176,18 @@\n \"execution_count\": 5,\n \"metadata\": {\n \"ExecuteTime\": {\n \"end_time\": \"2018-11-28T20:51:36.152913Z\",\n \"start_time\": \"2018-11-28T20:51:36.133997Z\"\n },\n \"execution\": {\n- \"iopub.execute_input\": \"2026-04-07T09:27:11.328901Z\",\n- \"iopub.status.busy\": \"2026-04-07T09:27:11.328659Z\",\n- \"iopub.status.idle\": \"2026-04-07T09:27:11.340439Z\",\n- \"shell.execute_reply\": \"2026-04-07T09:27:11.339850Z\"\n+ \"iopub.execute_input\": \"2025-03-05T03:36:54.384541Z\",\n+ \"iopub.status.busy\": \"2025-03-05T03:36:54.383951Z\",\n+ \"iopub.status.idle\": \"2025-03-05T03:36:54.576008Z\",\n+ \"shell.execute_reply\": \"2025-03-05T03:36:54.563960Z\"\n }\n },\n \"outputs\": [\n {\n \"ename\": \"NameError\",\n \"evalue\": \"name 'ds_weighted' is not defined\",\n \"output_type\": \"error\",\n@@ -208,18 +208,18 @@\n \"execution_count\": 6,\n \"metadata\": {\n \"ExecuteTime\": {\n \"end_time\": \"2018-11-28T20:51:36.190765Z\",\n \"start_time\": \"2018-11-28T20:51:36.154416Z\"\n },\n \"execution\": {\n- \"iopub.execute_input\": \"2026-04-07T09:27:11.342275Z\",\n- \"iopub.status.busy\": \"2026-04-07T09:27:11.342038Z\",\n- \"iopub.status.idle\": \"2026-04-07T09:27:11.354073Z\",\n- \"shell.execute_reply\": \"2026-04-07T09:27:11.353483Z\"\n+ \"iopub.execute_input\": \"2025-03-05T03:36:54.597710Z\",\n+ \"iopub.status.busy\": \"2025-03-05T03:36:54.597088Z\",\n+ \"iopub.status.idle\": \"2025-03-05T03:36:54.853236Z\",\n+ \"shell.execute_reply\": \"2025-03-05T03:36:54.831247Z\"\n }\n },\n \"outputs\": [\n {\n \"ename\": \"NameError\",\n \"evalue\": \"name 'ds' is not defined\",\n \"output_type\": \"error\",\n@@ -242,18 +242,18 @@\n \"execution_count\": 7,\n \"metadata\": {\n \"ExecuteTime\": {\n \"end_time\": \"2018-11-28T20:51:40.264871Z\",\n \"start_time\": \"2018-11-28T20:51:36.192467Z\"\n },\n \"execution\": {\n- \"iopub.execute_input\": \"2026-04-07T09:27:11.355957Z\",\n- \"iopub.status.busy\": \"2026-04-07T09:27:11.355721Z\",\n- \"iopub.status.idle\": \"2026-04-07T09:27:11.382364Z\",\n- \"shell.execute_reply\": \"2026-04-07T09:27:11.381767Z\"\n+ \"iopub.execute_input\": \"2025-03-05T03:36:54.878076Z\",\n+ \"iopub.status.busy\": \"2025-03-05T03:36:54.877486Z\",\n+ \"iopub.status.idle\": \"2025-03-05T03:36:55.053538Z\",\n+ \"shell.execute_reply\": \"2025-03-05T03:36:55.036713Z\"\n }\n },\n \"outputs\": [\n {\n \"ename\": \"NameError\",\n \"evalue\": \"name 'ds_unweighted' is not defined\",\n \"output_type\": \"error\",\n@@ -322,18 +322,18 @@\n \"execution_count\": 8,\n \"metadata\": {\n \"ExecuteTime\": {\n \"end_time\": \"2018-11-28T20:51:40.284898Z\",\n \"start_time\": \"2018-11-28T20:51:40.266406Z\"\n },\n \"execution\": {\n- \"iopub.execute_input\": \"2026-04-07T09:27:11.384471Z\",\n- \"iopub.status.busy\": \"2026-04-07T09:27:11.384232Z\",\n- \"iopub.status.idle\": \"2026-04-07T09:27:11.388034Z\",\n- \"shell.execute_reply\": \"2026-04-07T09:27:11.387442Z\"\n+ \"iopub.execute_input\": \"2025-03-05T03:36:55.085414Z\",\n+ \"iopub.status.busy\": \"2025-03-05T03:36:55.079513Z\",\n+ \"iopub.status.idle\": \"2025-03-05T03:36:55.129351Z\",\n+ \"shell.execute_reply\": \"2025-03-05T03:36:55.112930Z\"\n }\n },\n \"outputs\": [],\n \"source\": [\n \"# Wrap it into a simple function\\n\",\n \"def season_mean(ds, calendar=\\\"standard\\\"):\\n\",\n \" # Make a DataArray with the number of days in each month, size = len(time)\\n\",\n"}]}]}, {"source1": "./usr/share/doc/python-xarray-doc/html/examples/multidimensional-coords.html", "source2": "./usr/share/doc/python-xarray-doc/html/examples/multidimensional-coords.html", "unified_diff": "@@ -158,15 +158,15 @@\n File /usr/lib/python3/dist-packages/pooch/utils.py:276, in make_local_storage(path, env)\n 272 if env is not None:\n 273 message.append(\n 274 f"Use environment variable '{env}' to specify a different location."\n 275 )\n --> 276 raise PermissionError(" ".join(message)) from error\n \n-PermissionError: [Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/first-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\n+PermissionError: [Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/second-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\n \n \n

In this example, the logical coordinates are x and y, while the physical coordinates are xc and yc, which represent the longitudes and latitudes of the data.

\n
\n
[3]:\n 
\n
\n", "details": [{"source1": "html2text {}", "source2": "html2text {}", "unified_diff": "@@ -90,15 +90,15 @@\n 273 message.append(\n 274 f\"Use environment variable '{env}' to specify a different\n location.\"\n 275 )\n --> 276 raise PermissionError(\" \".join(message)) from error\n \n PermissionError: [Errno 13] Permission denied: '/nonexistent' | Pooch could not\n-create data cache folder '/nonexistent/first-build/.cache/\n+create data cache folder '/nonexistent/second-build/.cache/\n xarray_tutorial_data'. Will not be able to download data files.\n In this example, the l\blo\bog\bgi\bic\bca\bal\bl c\bco\boo\bor\brd\bdi\bin\bna\bat\bte\bes\bs are x and y, while the p\bph\bhy\bys\bsi\bic\bca\bal\bl\n c\bco\boo\bor\brd\bdi\bin\bna\bat\bte\bes\bs are xc and yc, which represent the longitudes and latitudes of the\n data.\n [3]:\n print(ds.xc.attrs)\n print(ds.yc.attrs)\n"}]}, {"source1": "./usr/share/doc/python-xarray-doc/html/examples/multidimensional-coords.ipynb.gz", "source2": "./usr/share/doc/python-xarray-doc/html/examples/multidimensional-coords.ipynb.gz", "unified_diff": null, "details": [{"source1": "multidimensional-coords.ipynb", "source2": "multidimensional-coords.ipynb", "unified_diff": null, "details": [{"source1": "Pretty-printed", "source2": "Pretty-printed", "comments": ["Similarity: 0.9991536458333333%", "Differences: {\"'cells'\": \"{1: {'metadata': {'execution': {'iopub.execute_input': '2025-03-05T03:37:01.661852Z', \"", " \"'iopub.status.busy': '2025-03-05T03:37:01.661325Z', 'iopub.status.idle': \"", " \"'2025-03-05T03:37:05.709725Z', 'shell.execute_reply': \"", " \"'2025-03-05T03:37:05.697124Z'}}}, 3: {'metadata': {'execution': \"", " \"{'iopub.execute_input': '2025-03-05T03:37:05.742492Z', 'iopub.status.busy': \"", " \"'2025-03-05T03:37:05.741640Z', 'iopub.status.idle': '2025-03-05T03:37:0 [\u2026]"], "unified_diff": "@@ -16,18 +16,18 @@\n \"execution_count\": 1,\n \"metadata\": {\n \"ExecuteTime\": {\n \"end_time\": \"2018-11-28T20:49:56.068395Z\",\n \"start_time\": \"2018-11-28T20:49:56.035349Z\"\n },\n \"execution\": {\n- \"iopub.execute_input\": \"2026-04-07T09:27:13.262634Z\",\n- \"iopub.status.busy\": \"2026-04-07T09:27:13.262398Z\",\n- \"iopub.status.idle\": \"2026-04-07T09:27:14.111171Z\",\n- \"shell.execute_reply\": \"2026-04-07T09:27:14.110451Z\"\n+ \"iopub.execute_input\": \"2025-03-05T03:37:01.661852Z\",\n+ \"iopub.status.busy\": \"2025-03-05T03:37:01.661325Z\",\n+ \"iopub.status.idle\": \"2025-03-05T03:37:05.709725Z\",\n+ \"shell.execute_reply\": \"2025-03-05T03:37:05.697124Z\"\n }\n },\n \"outputs\": [],\n \"source\": [\n \"%matplotlib inline\\n\",\n \"import numpy as np\\n\",\n \"import pandas as pd\\n\",\n@@ -48,24 +48,24 @@\n \"execution_count\": 2,\n \"metadata\": {\n \"ExecuteTime\": {\n \"end_time\": \"2018-11-28T20:50:13.629720Z\",\n \"start_time\": \"2018-11-28T20:50:13.484542Z\"\n },\n \"execution\": {\n- \"iopub.execute_input\": \"2026-04-07T09:27:14.114263Z\",\n- \"iopub.status.busy\": \"2026-04-07T09:27:14.113868Z\",\n- \"iopub.status.idle\": \"2026-04-07T09:27:14.388007Z\",\n- \"shell.execute_reply\": \"2026-04-07T09:27:14.387363Z\"\n+ \"iopub.execute_input\": \"2025-03-05T03:37:05.742492Z\",\n+ \"iopub.status.busy\": \"2025-03-05T03:37:05.741640Z\",\n+ \"iopub.status.idle\": \"2025-03-05T03:37:08.136918Z\",\n+ \"shell.execute_reply\": \"2025-03-05T03:37:08.107980Z\"\n }\n },\n \"outputs\": [\n {\n \"ename\": \"PermissionError\",\n- \"evalue\": \"[Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/first-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\",\n+ \"evalue\": \"[Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/second-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\",\n \"output_type\": \"error\",\n \"traceback\": [\n \"\\u001b[0;31m---------------------------------------------------------------------------\\u001b[0m\",\n \"\\u001b[0;31mPermissionError\\u001b[0m Traceback (most recent call last)\",\n \"File \\u001b[0;32m/usr/lib/python3/dist-packages/pooch/utils.py:262\\u001b[0m, in \\u001b[0;36mmake_local_storage\\u001b[0;34m(path, env)\\u001b[0m\\n\\u001b[1;32m 258\\u001b[0m \\u001b[38;5;28;01mif\\u001b[39;00m action \\u001b[38;5;241m==\\u001b[39m \\u001b[38;5;124m\\\"\\u001b[39m\\u001b[38;5;124mcreate\\u001b[39m\\u001b[38;5;124m\\\"\\u001b[39m:\\n\\u001b[1;32m 259\\u001b[0m \\u001b[38;5;66;03m# When running in parallel, it's possible that multiple jobs will\\u001b[39;00m\\n\\u001b[1;32m 260\\u001b[0m \\u001b[38;5;66;03m# try to create the path at the same time. Use exist_ok to avoid\\u001b[39;00m\\n\\u001b[1;32m 261\\u001b[0m \\u001b[38;5;66;03m# raising an error.\\u001b[39;00m\\n\\u001b[0;32m--> 262\\u001b[0m \\u001b[43mos\\u001b[49m\\u001b[38;5;241;43m.\\u001b[39;49m\\u001b[43mmakedirs\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[43mpath\\u001b[49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[43mexist_ok\\u001b[49m\\u001b[38;5;241;43m=\\u001b[39;49m\\u001b[38;5;28;43;01mTrue\\u001b[39;49;00m\\u001b[43m)\\u001b[49m\\n\\u001b[1;32m 263\\u001b[0m \\u001b[38;5;28;01melse\\u001b[39;00m:\\n\",\n \"File \\u001b[0;32m/usr/lib/python3.13/os.py:217\\u001b[0m, in \\u001b[0;36mmakedirs\\u001b[0;34m(name, mode, exist_ok)\\u001b[0m\\n\\u001b[1;32m 216\\u001b[0m \\u001b[38;5;28;01mtry\\u001b[39;00m:\\n\\u001b[0;32m--> 217\\u001b[0m \\u001b[43mmakedirs\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[43mhead\\u001b[49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[43mexist_ok\\u001b[49m\\u001b[38;5;241;43m=\\u001b[39;49m\\u001b[43mexist_ok\\u001b[49m\\u001b[43m)\\u001b[49m\\n\\u001b[1;32m 218\\u001b[0m \\u001b[38;5;28;01mexcept\\u001b[39;00m \\u001b[38;5;167;01mFileExistsError\\u001b[39;00m:\\n\\u001b[1;32m 219\\u001b[0m \\u001b[38;5;66;03m# Defeats race condition when another thread created the path\\u001b[39;00m\\n\",\n \"File \\u001b[0;32m/usr/lib/python3.13/os.py:217\\u001b[0m, in \\u001b[0;36mmakedirs\\u001b[0;34m(name, mode, exist_ok)\\u001b[0m\\n\\u001b[1;32m 216\\u001b[0m \\u001b[38;5;28;01mtry\\u001b[39;00m:\\n\\u001b[0;32m--> 217\\u001b[0m \\u001b[43mmakedirs\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[43mhead\\u001b[49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[43mexist_ok\\u001b[49m\\u001b[38;5;241;43m=\\u001b[39;49m\\u001b[43mexist_ok\\u001b[49m\\u001b[43m)\\u001b[49m\\n\\u001b[1;32m 218\\u001b[0m \\u001b[38;5;28;01mexcept\\u001b[39;00m \\u001b[38;5;167;01mFileExistsError\\u001b[39;00m:\\n\\u001b[1;32m 219\\u001b[0m \\u001b[38;5;66;03m# Defeats race condition when another thread created the path\\u001b[39;00m\\n\",\n@@ -74,15 +74,15 @@\n \"\\u001b[0;31mPermissionError\\u001b[0m: [Errno 13] Permission denied: '/nonexistent'\",\n \"\\nThe above exception was the direct cause of the following exception:\\n\",\n \"\\u001b[0;31mPermissionError\\u001b[0m Traceback (most recent call last)\",\n \"Cell \\u001b[0;32mIn[2], line 1\\u001b[0m\\n\\u001b[0;32m----> 1\\u001b[0m ds \\u001b[38;5;241m=\\u001b[39m \\u001b[43mxr\\u001b[49m\\u001b[38;5;241;43m.\\u001b[39;49m\\u001b[43mtutorial\\u001b[49m\\u001b[38;5;241;43m.\\u001b[39;49m\\u001b[43mopen_dataset\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[38;5;124;43m\\\"\\u001b[39;49m\\u001b[38;5;124;43mrasm\\u001b[39;49m\\u001b[38;5;124;43m\\\"\\u001b[39;49m\\u001b[43m)\\u001b[49m\\u001b[38;5;241m.\\u001b[39mload()\\n\\u001b[1;32m 2\\u001b[0m ds\\n\",\n \"File \\u001b[0;32m/usr/lib/python3/dist-packages/xarray/tutorial.py:165\\u001b[0m, in \\u001b[0;36mopen_dataset\\u001b[0;34m(name, cache, cache_dir, engine, **kws)\\u001b[0m\\n\\u001b[1;32m 162\\u001b[0m downloader \\u001b[38;5;241m=\\u001b[39m pooch\\u001b[38;5;241m.\\u001b[39mHTTPDownloader(headers\\u001b[38;5;241m=\\u001b[39mheaders)\\n\\u001b[1;32m 164\\u001b[0m \\u001b[38;5;66;03m# retrieve the file\\u001b[39;00m\\n\\u001b[0;32m--> 165\\u001b[0m filepath \\u001b[38;5;241m=\\u001b[39m \\u001b[43mpooch\\u001b[49m\\u001b[38;5;241;43m.\\u001b[39;49m\\u001b[43mretrieve\\u001b[49m\\u001b[43m(\\u001b[49m\\n\\u001b[1;32m 166\\u001b[0m \\u001b[43m \\u001b[49m\\u001b[43murl\\u001b[49m\\u001b[38;5;241;43m=\\u001b[39;49m\\u001b[43murl\\u001b[49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[43mknown_hash\\u001b[49m\\u001b[38;5;241;43m=\\u001b[39;49m\\u001b[38;5;28;43;01mNone\\u001b[39;49;00m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[43mpath\\u001b[49m\\u001b[38;5;241;43m=\\u001b[39;49m\\u001b[43mcache_dir\\u001b[49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[43mdownloader\\u001b[49m\\u001b[38;5;241;43m=\\u001b[39;49m\\u001b[43mdownloader\\u001b[49m\\n\\u001b[1;32m 167\\u001b[0m \\u001b[43m\\u001b[49m\\u001b[43m)\\u001b[49m\\n\\u001b[1;32m 168\\u001b[0m ds \\u001b[38;5;241m=\\u001b[39m _open_dataset(filepath, engine\\u001b[38;5;241m=\\u001b[39mengine, \\u001b[38;5;241m*\\u001b[39m\\u001b[38;5;241m*\\u001b[39mkws)\\n\\u001b[1;32m 169\\u001b[0m \\u001b[38;5;28;01mif\\u001b[39;00m \\u001b[38;5;129;01mnot\\u001b[39;00m cache:\\n\",\n \"File \\u001b[0;32m/usr/lib/python3/dist-packages/pooch/core.py:227\\u001b[0m, in \\u001b[0;36mretrieve\\u001b[0;34m(url, known_hash, fname, path, processor, downloader, progressbar)\\u001b[0m\\n\\u001b[1;32m 222\\u001b[0m action, verb \\u001b[38;5;241m=\\u001b[39m download_action(full_path, known_hash)\\n\\u001b[1;32m 224\\u001b[0m \\u001b[38;5;28;01mif\\u001b[39;00m action \\u001b[38;5;129;01min\\u001b[39;00m (\\u001b[38;5;124m\\\"\\u001b[39m\\u001b[38;5;124mdownload\\u001b[39m\\u001b[38;5;124m\\\"\\u001b[39m, \\u001b[38;5;124m\\\"\\u001b[39m\\u001b[38;5;124mupdate\\u001b[39m\\u001b[38;5;124m\\\"\\u001b[39m):\\n\\u001b[1;32m 225\\u001b[0m \\u001b[38;5;66;03m# We need to write data, so create the local data directory if it\\u001b[39;00m\\n\\u001b[1;32m 226\\u001b[0m \\u001b[38;5;66;03m# doesn't already exist.\\u001b[39;00m\\n\\u001b[0;32m--> 227\\u001b[0m \\u001b[43mmake_local_storage\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[43mpath\\u001b[49m\\u001b[43m)\\u001b[49m\\n\\u001b[1;32m 229\\u001b[0m get_logger()\\u001b[38;5;241m.\\u001b[39minfo(\\n\\u001b[1;32m 230\\u001b[0m \\u001b[38;5;124m\\\"\\u001b[39m\\u001b[38;5;132;01m%s\\u001b[39;00m\\u001b[38;5;124m data from \\u001b[39m\\u001b[38;5;124m'\\u001b[39m\\u001b[38;5;132;01m%s\\u001b[39;00m\\u001b[38;5;124m'\\u001b[39m\\u001b[38;5;124m to file \\u001b[39m\\u001b[38;5;124m'\\u001b[39m\\u001b[38;5;132;01m%s\\u001b[39;00m\\u001b[38;5;124m'\\u001b[39m\\u001b[38;5;124m.\\u001b[39m\\u001b[38;5;124m\\\"\\u001b[39m,\\n\\u001b[1;32m 231\\u001b[0m verb,\\n\\u001b[1;32m 232\\u001b[0m url,\\n\\u001b[1;32m 233\\u001b[0m \\u001b[38;5;28mstr\\u001b[39m(full_path),\\n\\u001b[1;32m 234\\u001b[0m )\\n\\u001b[1;32m 236\\u001b[0m \\u001b[38;5;28;01mif\\u001b[39;00m downloader \\u001b[38;5;129;01mis\\u001b[39;00m \\u001b[38;5;28;01mNone\\u001b[39;00m:\\n\",\n \"File \\u001b[0;32m/usr/lib/python3/dist-packages/pooch/utils.py:276\\u001b[0m, in \\u001b[0;36mmake_local_storage\\u001b[0;34m(path, env)\\u001b[0m\\n\\u001b[1;32m 272\\u001b[0m \\u001b[38;5;28;01mif\\u001b[39;00m env \\u001b[38;5;129;01mis\\u001b[39;00m \\u001b[38;5;129;01mnot\\u001b[39;00m \\u001b[38;5;28;01mNone\\u001b[39;00m:\\n\\u001b[1;32m 273\\u001b[0m message\\u001b[38;5;241m.\\u001b[39mappend(\\n\\u001b[1;32m 274\\u001b[0m \\u001b[38;5;124mf\\u001b[39m\\u001b[38;5;124m\\\"\\u001b[39m\\u001b[38;5;124mUse environment variable \\u001b[39m\\u001b[38;5;124m'\\u001b[39m\\u001b[38;5;132;01m{\\u001b[39;00menv\\u001b[38;5;132;01m}\\u001b[39;00m\\u001b[38;5;124m'\\u001b[39m\\u001b[38;5;124m to specify a different location.\\u001b[39m\\u001b[38;5;124m\\\"\\u001b[39m\\n\\u001b[1;32m 275\\u001b[0m )\\n\\u001b[0;32m--> 276\\u001b[0m \\u001b[38;5;28;01mraise\\u001b[39;00m \\u001b[38;5;167;01mPermissionError\\u001b[39;00m(\\u001b[38;5;124m\\\"\\u001b[39m\\u001b[38;5;124m \\u001b[39m\\u001b[38;5;124m\\\"\\u001b[39m\\u001b[38;5;241m.\\u001b[39mjoin(message)) \\u001b[38;5;28;01mfrom\\u001b[39;00m \\u001b[38;5;21;01merror\\u001b[39;00m\\n\",\n- \"\\u001b[0;31mPermissionError\\u001b[0m: [Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/first-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\"\n+ \"\\u001b[0;31mPermissionError\\u001b[0m: [Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/second-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\"\n ]\n }\n ],\n \"source\": [\n \"ds = xr.tutorial.open_dataset(\\\"rasm\\\").load()\\n\",\n \"ds\"\n ]\n@@ -99,18 +99,18 @@\n \"execution_count\": 3,\n \"metadata\": {\n \"ExecuteTime\": {\n \"end_time\": \"2018-11-28T20:50:15.836061Z\",\n \"start_time\": \"2018-11-28T20:50:15.768376Z\"\n },\n \"execution\": {\n- \"iopub.execute_input\": \"2026-04-07T09:27:14.390250Z\",\n- \"iopub.status.busy\": \"2026-04-07T09:27:14.390007Z\",\n- \"iopub.status.idle\": \"2026-04-07T09:27:14.402773Z\",\n- \"shell.execute_reply\": \"2026-04-07T09:27:14.402236Z\"\n+ \"iopub.execute_input\": \"2025-03-05T03:37:08.169976Z\",\n+ \"iopub.status.busy\": \"2025-03-05T03:37:08.169343Z\",\n+ \"iopub.status.idle\": \"2025-03-05T03:37:08.288406Z\",\n+ \"shell.execute_reply\": \"2025-03-05T03:37:08.265547Z\"\n }\n },\n \"outputs\": [\n {\n \"ename\": \"NameError\",\n \"evalue\": \"name 'ds' is not defined\",\n \"output_type\": \"error\",\n@@ -141,18 +141,18 @@\n \"execution_count\": 4,\n \"metadata\": {\n \"ExecuteTime\": {\n \"end_time\": \"2018-11-28T20:50:17.928556Z\",\n \"start_time\": \"2018-11-28T20:50:17.031211Z\"\n },\n \"execution\": {\n- \"iopub.execute_input\": \"2026-04-07T09:27:14.404671Z\",\n- \"iopub.status.busy\": \"2026-04-07T09:27:14.404439Z\",\n- \"iopub.status.idle\": \"2026-04-07T09:27:14.649170Z\",\n- \"shell.execute_reply\": \"2026-04-07T09:27:14.648608Z\"\n+ \"iopub.execute_input\": \"2025-03-05T03:37:08.339402Z\",\n+ \"iopub.status.busy\": \"2025-03-05T03:37:08.338819Z\",\n+ \"iopub.status.idle\": \"2025-03-05T03:37:09.446432Z\",\n+ \"shell.execute_reply\": \"2025-03-05T03:37:09.439938Z\"\n }\n },\n \"outputs\": [\n {\n \"ename\": \"NameError\",\n \"evalue\": \"name 'ds' is not defined\",\n \"output_type\": \"error\",\n@@ -194,18 +194,18 @@\n \"execution_count\": 5,\n \"metadata\": {\n \"ExecuteTime\": {\n \"end_time\": \"2018-11-28T20:50:20.567749Z\",\n \"start_time\": \"2018-11-28T20:50:19.999393Z\"\n },\n \"execution\": {\n- \"iopub.execute_input\": \"2026-04-07T09:27:14.651738Z\",\n- \"iopub.status.busy\": \"2026-04-07T09:27:14.651312Z\",\n- \"iopub.status.idle\": \"2026-04-07T09:27:14.664428Z\",\n- \"shell.execute_reply\": \"2026-04-07T09:27:14.663900Z\"\n+ \"iopub.execute_input\": \"2025-03-05T03:37:09.466814Z\",\n+ \"iopub.status.busy\": \"2025-03-05T03:37:09.466115Z\",\n+ \"iopub.status.idle\": \"2025-03-05T03:37:09.579985Z\",\n+ \"shell.execute_reply\": \"2025-03-05T03:37:09.563923Z\"\n }\n },\n \"outputs\": [\n {\n \"ename\": \"NameError\",\n \"evalue\": \"name 'ds' is not defined\",\n \"output_type\": \"error\",\n@@ -233,18 +233,18 @@\n \"execution_count\": 6,\n \"metadata\": {\n \"ExecuteTime\": {\n \"end_time\": \"2018-11-28T20:50:31.131708Z\",\n \"start_time\": \"2018-11-28T20:50:30.444697Z\"\n },\n \"execution\": {\n- \"iopub.execute_input\": \"2026-04-07T09:27:14.666870Z\",\n- \"iopub.status.busy\": \"2026-04-07T09:27:14.666363Z\",\n- \"iopub.status.idle\": \"2026-04-07T09:27:14.735377Z\",\n- \"shell.execute_reply\": \"2026-04-07T09:27:14.734659Z\"\n+ \"iopub.execute_input\": \"2025-03-05T03:37:09.597589Z\",\n+ \"iopub.status.busy\": \"2025-03-05T03:37:09.596988Z\",\n+ \"iopub.status.idle\": \"2025-03-05T03:37:10.051853Z\",\n+ \"shell.execute_reply\": \"2025-03-05T03:37:10.039952Z\"\n }\n },\n \"outputs\": [\n {\n \"ename\": \"NameError\",\n \"evalue\": \"name 'ds' is not defined\",\n \"output_type\": \"error\",\n@@ -291,18 +291,18 @@\n \"execution_count\": 7,\n \"metadata\": {\n \"ExecuteTime\": {\n \"end_time\": \"2018-11-28T20:50:43.670463Z\",\n \"start_time\": \"2018-11-28T20:50:43.245501Z\"\n },\n \"execution\": {\n- \"iopub.execute_input\": \"2026-04-07T09:27:14.737645Z\",\n- \"iopub.status.busy\": \"2026-04-07T09:27:14.737178Z\",\n- \"iopub.status.idle\": \"2026-04-07T09:27:14.750688Z\",\n- \"shell.execute_reply\": \"2026-04-07T09:27:14.750154Z\"\n+ \"iopub.execute_input\": \"2025-03-05T03:37:10.074070Z\",\n+ \"iopub.status.busy\": \"2025-03-05T03:37:10.073346Z\",\n+ \"iopub.status.idle\": \"2025-03-05T03:37:10.207959Z\",\n+ \"shell.execute_reply\": \"2025-03-05T03:37:10.191946Z\"\n }\n },\n \"outputs\": [\n {\n \"ename\": \"NameError\",\n \"evalue\": \"name 'ds' is not defined\",\n \"output_type\": \"error\",\n"}]}]}, {"source1": "./usr/share/doc/python-xarray-doc/html/examples/visualization_gallery.html", "source2": "./usr/share/doc/python-xarray-doc/html/examples/visualization_gallery.html", "unified_diff": "@@ -165,15 +165,15 @@\n File /usr/lib/python3/dist-packages/pooch/utils.py:276, in make_local_storage(path, env)\n 272 if env is not None:\n 273 message.append(\n 274 f"Use environment variable '{env}' to specify a different location."\n 275 )\n --> 276 raise PermissionError(" ".join(message)) from error\n \n-PermissionError: [Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/first-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\n+PermissionError: [Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/second-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\n
\n \n
\n

Multiple plots and map projections\u00b6

\n

Control the map projection parameters on multiple axes

\n

This example illustrates how to plot multiple maps and control their extent and aspect ratio.

\n

For more details see this discussion on github.

\n", "details": [{"source1": "html2text {}", "source2": "html2text {}", "unified_diff": "@@ -98,15 +98,15 @@\n 273 message.append(\n 274 f\"Use environment variable '{env}' to specify a different\n location.\"\n 275 )\n --> 276 raise PermissionError(\" \".join(message)) from error\n \n PermissionError: [Errno 13] Permission denied: '/nonexistent' | Pooch could not\n-create data cache folder '/nonexistent/first-build/.cache/\n+create data cache folder '/nonexistent/second-build/.cache/\n xarray_tutorial_data'. Will not be able to download data files.\n *\b**\b**\b**\b**\b* M\bMu\bul\blt\bti\bip\bpl\ble\be p\bpl\blo\bot\bts\bs a\ban\bnd\bd m\bma\bap\bp p\bpr\bro\boj\bje\bec\bct\bti\bio\bon\bns\bs_\b?\b\u00b6 *\b**\b**\b**\b**\b*\n Control the map projection parameters on multiple axes\n This example illustrates how to plot multiple maps and control their extent and\n aspect ratio.\n For more details see _\bt_\bh_\bi_\bs_\b _\bd_\bi_\bs_\bc_\bu_\bs_\bs_\bi_\bo_\bn on github.\n [3]:\n"}]}, {"source1": "./usr/share/doc/python-xarray-doc/html/examples/visualization_gallery.ipynb.gz", "source2": "./usr/share/doc/python-xarray-doc/html/examples/visualization_gallery.ipynb.gz", "unified_diff": null, "details": [{"source1": "visualization_gallery.ipynb", "source2": "visualization_gallery.ipynb", "unified_diff": null, "details": [{"source1": "Pretty-printed", "source2": "Pretty-printed", "comments": ["Similarity: 0.9982919730392157%", "Differences: {\"'cells'\": \"{1: {'metadata': {'execution': {'iopub.execute_input': '2025-03-05T03:37:20.861495Z', \"", " \"'iopub.status.busy': '2025-03-05T03:37:20.860959Z', 'iopub.status.idle': \"", " \"'2025-03-05T03:37:24.475957Z', 'shell.execute_reply': \"", " \"'2025-03-05T03:37:24.461181Z'}}}, 3: {'metadata': {'execution': \"", " \"{'iopub.execute_input': '2025-03-05T03:37:24.505980Z', 'iopub.status.busy': \"", " \"'2025-03-05T03:37:24.505102Z', 'iopub.status.idle': '2025-03-05T03:37:2 [\u2026]"], "unified_diff": "@@ -10,18 +10,18 @@\n ]\n },\n {\n \"cell_type\": \"code\",\n \"execution_count\": 1,\n \"metadata\": {\n \"execution\": {\n- \"iopub.execute_input\": \"2026-04-07T09:27:16.752534Z\",\n- \"iopub.status.busy\": \"2026-04-07T09:27:16.752299Z\",\n- \"iopub.status.idle\": \"2026-04-07T09:27:17.613295Z\",\n- \"shell.execute_reply\": \"2026-04-07T09:27:17.612565Z\"\n+ \"iopub.execute_input\": \"2025-03-05T03:37:20.861495Z\",\n+ \"iopub.status.busy\": \"2025-03-05T03:37:20.860959Z\",\n+ \"iopub.status.idle\": \"2025-03-05T03:37:24.475957Z\",\n+ \"shell.execute_reply\": \"2025-03-05T03:37:24.461181Z\"\n }\n },\n \"outputs\": [],\n \"source\": [\n \"import cartopy.crs as ccrs\\n\",\n \"import matplotlib.pyplot as plt\\n\",\n \"import xarray as xr\\n\",\n@@ -37,24 +37,24 @@\n ]\n },\n {\n \"cell_type\": \"code\",\n \"execution_count\": 2,\n \"metadata\": {\n \"execution\": {\n- \"iopub.execute_input\": \"2026-04-07T09:27:17.616326Z\",\n- \"iopub.status.busy\": \"2026-04-07T09:27:17.615941Z\",\n- \"iopub.status.idle\": \"2026-04-07T09:27:17.902601Z\",\n- \"shell.execute_reply\": \"2026-04-07T09:27:17.901868Z\"\n+ \"iopub.execute_input\": \"2025-03-05T03:37:24.505980Z\",\n+ \"iopub.status.busy\": \"2025-03-05T03:37:24.505102Z\",\n+ \"iopub.status.idle\": \"2025-03-05T03:37:26.612010Z\",\n+ \"shell.execute_reply\": \"2025-03-05T03:37:26.595875Z\"\n }\n },\n \"outputs\": [\n {\n \"ename\": \"PermissionError\",\n- \"evalue\": \"[Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/first-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\",\n+ \"evalue\": \"[Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/second-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\",\n \"output_type\": \"error\",\n \"traceback\": [\n \"\\u001b[0;31m---------------------------------------------------------------------------\\u001b[0m\",\n \"\\u001b[0;31mPermissionError\\u001b[0m Traceback (most recent call last)\",\n \"File \\u001b[0;32m/usr/lib/python3/dist-packages/pooch/utils.py:262\\u001b[0m, in \\u001b[0;36mmake_local_storage\\u001b[0;34m(path, env)\\u001b[0m\\n\\u001b[1;32m 258\\u001b[0m \\u001b[38;5;28;01mif\\u001b[39;00m action \\u001b[38;5;241m==\\u001b[39m \\u001b[38;5;124m\\\"\\u001b[39m\\u001b[38;5;124mcreate\\u001b[39m\\u001b[38;5;124m\\\"\\u001b[39m:\\n\\u001b[1;32m 259\\u001b[0m \\u001b[38;5;66;03m# When running in parallel, it's possible that multiple jobs will\\u001b[39;00m\\n\\u001b[1;32m 260\\u001b[0m \\u001b[38;5;66;03m# try to create the path at the same time. Use exist_ok to avoid\\u001b[39;00m\\n\\u001b[1;32m 261\\u001b[0m \\u001b[38;5;66;03m# raising an error.\\u001b[39;00m\\n\\u001b[0;32m--> 262\\u001b[0m \\u001b[43mos\\u001b[49m\\u001b[38;5;241;43m.\\u001b[39;49m\\u001b[43mmakedirs\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[43mpath\\u001b[49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[43mexist_ok\\u001b[49m\\u001b[38;5;241;43m=\\u001b[39;49m\\u001b[38;5;28;43;01mTrue\\u001b[39;49;00m\\u001b[43m)\\u001b[49m\\n\\u001b[1;32m 263\\u001b[0m \\u001b[38;5;28;01melse\\u001b[39;00m:\\n\",\n \"File \\u001b[0;32m/usr/lib/python3.13/os.py:217\\u001b[0m, in \\u001b[0;36mmakedirs\\u001b[0;34m(name, mode, exist_ok)\\u001b[0m\\n\\u001b[1;32m 216\\u001b[0m \\u001b[38;5;28;01mtry\\u001b[39;00m:\\n\\u001b[0;32m--> 217\\u001b[0m \\u001b[43mmakedirs\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[43mhead\\u001b[49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[43mexist_ok\\u001b[49m\\u001b[38;5;241;43m=\\u001b[39;49m\\u001b[43mexist_ok\\u001b[49m\\u001b[43m)\\u001b[49m\\n\\u001b[1;32m 218\\u001b[0m \\u001b[38;5;28;01mexcept\\u001b[39;00m \\u001b[38;5;167;01mFileExistsError\\u001b[39;00m:\\n\\u001b[1;32m 219\\u001b[0m \\u001b[38;5;66;03m# Defeats race condition when another thread created the path\\u001b[39;00m\\n\",\n \"File \\u001b[0;32m/usr/lib/python3.13/os.py:217\\u001b[0m, in \\u001b[0;36mmakedirs\\u001b[0;34m(name, mode, exist_ok)\\u001b[0m\\n\\u001b[1;32m 216\\u001b[0m \\u001b[38;5;28;01mtry\\u001b[39;00m:\\n\\u001b[0;32m--> 217\\u001b[0m \\u001b[43mmakedirs\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[43mhead\\u001b[49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[43mexist_ok\\u001b[49m\\u001b[38;5;241;43m=\\u001b[39;49m\\u001b[43mexist_ok\\u001b[49m\\u001b[43m)\\u001b[49m\\n\\u001b[1;32m 218\\u001b[0m \\u001b[38;5;28;01mexcept\\u001b[39;00m \\u001b[38;5;167;01mFileExistsError\\u001b[39;00m:\\n\\u001b[1;32m 219\\u001b[0m \\u001b[38;5;66;03m# Defeats race condition when another thread created the path\\u001b[39;00m\\n\",\n@@ -64,15 +64,15 @@\n \"\\nThe above exception was the direct cause of the following exception:\\n\",\n \"\\u001b[0;31mPermissionError\\u001b[0m Traceback (most recent call last)\",\n \"Cell \\u001b[0;32mIn[2], line 1\\u001b[0m\\n\\u001b[0;32m----> 1\\u001b[0m ds \\u001b[38;5;241m=\\u001b[39m \\u001b[43mxr\\u001b[49m\\u001b[38;5;241;43m.\\u001b[39;49m\\u001b[43mtutorial\\u001b[49m\\u001b[38;5;241;43m.\\u001b[39;49m\\u001b[43mload_dataset\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[38;5;124;43m\\\"\\u001b[39;49m\\u001b[38;5;124;43mair_temperature\\u001b[39;49m\\u001b[38;5;124;43m\\\"\\u001b[39;49m\\u001b[43m)\\u001b[49m\\n\",\n \"File \\u001b[0;32m/usr/lib/python3/dist-packages/xarray/tutorial.py:213\\u001b[0m, in \\u001b[0;36mload_dataset\\u001b[0;34m(*args, **kwargs)\\u001b[0m\\n\\u001b[1;32m 176\\u001b[0m \\u001b[38;5;28;01mdef\\u001b[39;00m \\u001b[38;5;21mload_dataset\\u001b[39m(\\u001b[38;5;241m*\\u001b[39margs, \\u001b[38;5;241m*\\u001b[39m\\u001b[38;5;241m*\\u001b[39mkwargs) \\u001b[38;5;241m-\\u001b[39m\\u001b[38;5;241m>\\u001b[39m Dataset:\\n\\u001b[1;32m 177\\u001b[0m \\u001b[38;5;250m \\u001b[39m\\u001b[38;5;124;03m\\\"\\\"\\\"\\u001b[39;00m\\n\\u001b[1;32m 178\\u001b[0m \\u001b[38;5;124;03m Open, load into memory, and close a dataset from the online repository\\u001b[39;00m\\n\\u001b[1;32m 179\\u001b[0m \\u001b[38;5;124;03m (requires internet).\\u001b[39;00m\\n\\u001b[0;32m (...)\\u001b[0m\\n\\u001b[1;32m 211\\u001b[0m \\u001b[38;5;124;03m load_dataset\\u001b[39;00m\\n\\u001b[1;32m 212\\u001b[0m \\u001b[38;5;124;03m \\\"\\\"\\\"\\u001b[39;00m\\n\\u001b[0;32m--> 213\\u001b[0m \\u001b[38;5;28;01mwith\\u001b[39;00m \\u001b[43mopen_dataset\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[38;5;241;43m*\\u001b[39;49m\\u001b[43margs\\u001b[49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[38;5;241;43m*\\u001b[39;49m\\u001b[38;5;241;43m*\\u001b[39;49m\\u001b[43mkwargs\\u001b[49m\\u001b[43m)\\u001b[49m \\u001b[38;5;28;01mas\\u001b[39;00m ds:\\n\\u001b[1;32m 214\\u001b[0m \\u001b[38;5;28;01mreturn\\u001b[39;00m ds\\u001b[38;5;241m.\\u001b[39mload()\\n\",\n \"File \\u001b[0;32m/usr/lib/python3/dist-packages/xarray/tutorial.py:165\\u001b[0m, in \\u001b[0;36mopen_dataset\\u001b[0;34m(name, cache, cache_dir, engine, **kws)\\u001b[0m\\n\\u001b[1;32m 162\\u001b[0m downloader \\u001b[38;5;241m=\\u001b[39m pooch\\u001b[38;5;241m.\\u001b[39mHTTPDownloader(headers\\u001b[38;5;241m=\\u001b[39mheaders)\\n\\u001b[1;32m 164\\u001b[0m \\u001b[38;5;66;03m# retrieve the file\\u001b[39;00m\\n\\u001b[0;32m--> 165\\u001b[0m filepath \\u001b[38;5;241m=\\u001b[39m \\u001b[43mpooch\\u001b[49m\\u001b[38;5;241;43m.\\u001b[39;49m\\u001b[43mretrieve\\u001b[49m\\u001b[43m(\\u001b[49m\\n\\u001b[1;32m 166\\u001b[0m \\u001b[43m \\u001b[49m\\u001b[43murl\\u001b[49m\\u001b[38;5;241;43m=\\u001b[39;49m\\u001b[43murl\\u001b[49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[43mknown_hash\\u001b[49m\\u001b[38;5;241;43m=\\u001b[39;49m\\u001b[38;5;28;43;01mNone\\u001b[39;49;00m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[43mpath\\u001b[49m\\u001b[38;5;241;43m=\\u001b[39;49m\\u001b[43mcache_dir\\u001b[49m\\u001b[43m,\\u001b[49m\\u001b[43m \\u001b[49m\\u001b[43mdownloader\\u001b[49m\\u001b[38;5;241;43m=\\u001b[39;49m\\u001b[43mdownloader\\u001b[49m\\n\\u001b[1;32m 167\\u001b[0m \\u001b[43m\\u001b[49m\\u001b[43m)\\u001b[49m\\n\\u001b[1;32m 168\\u001b[0m ds \\u001b[38;5;241m=\\u001b[39m _open_dataset(filepath, engine\\u001b[38;5;241m=\\u001b[39mengine, \\u001b[38;5;241m*\\u001b[39m\\u001b[38;5;241m*\\u001b[39mkws)\\n\\u001b[1;32m 169\\u001b[0m \\u001b[38;5;28;01mif\\u001b[39;00m \\u001b[38;5;129;01mnot\\u001b[39;00m cache:\\n\",\n \"File \\u001b[0;32m/usr/lib/python3/dist-packages/pooch/core.py:227\\u001b[0m, in \\u001b[0;36mretrieve\\u001b[0;34m(url, known_hash, fname, path, processor, downloader, progressbar)\\u001b[0m\\n\\u001b[1;32m 222\\u001b[0m action, verb \\u001b[38;5;241m=\\u001b[39m download_action(full_path, known_hash)\\n\\u001b[1;32m 224\\u001b[0m \\u001b[38;5;28;01mif\\u001b[39;00m action \\u001b[38;5;129;01min\\u001b[39;00m (\\u001b[38;5;124m\\\"\\u001b[39m\\u001b[38;5;124mdownload\\u001b[39m\\u001b[38;5;124m\\\"\\u001b[39m, \\u001b[38;5;124m\\\"\\u001b[39m\\u001b[38;5;124mupdate\\u001b[39m\\u001b[38;5;124m\\\"\\u001b[39m):\\n\\u001b[1;32m 225\\u001b[0m \\u001b[38;5;66;03m# We need to write data, so create the local data directory if it\\u001b[39;00m\\n\\u001b[1;32m 226\\u001b[0m \\u001b[38;5;66;03m# doesn't already exist.\\u001b[39;00m\\n\\u001b[0;32m--> 227\\u001b[0m \\u001b[43mmake_local_storage\\u001b[49m\\u001b[43m(\\u001b[49m\\u001b[43mpath\\u001b[49m\\u001b[43m)\\u001b[49m\\n\\u001b[1;32m 229\\u001b[0m get_logger()\\u001b[38;5;241m.\\u001b[39minfo(\\n\\u001b[1;32m 230\\u001b[0m \\u001b[38;5;124m\\\"\\u001b[39m\\u001b[38;5;132;01m%s\\u001b[39;00m\\u001b[38;5;124m data from \\u001b[39m\\u001b[38;5;124m'\\u001b[39m\\u001b[38;5;132;01m%s\\u001b[39;00m\\u001b[38;5;124m'\\u001b[39m\\u001b[38;5;124m to file \\u001b[39m\\u001b[38;5;124m'\\u001b[39m\\u001b[38;5;132;01m%s\\u001b[39;00m\\u001b[38;5;124m'\\u001b[39m\\u001b[38;5;124m.\\u001b[39m\\u001b[38;5;124m\\\"\\u001b[39m,\\n\\u001b[1;32m 231\\u001b[0m verb,\\n\\u001b[1;32m 232\\u001b[0m url,\\n\\u001b[1;32m 233\\u001b[0m \\u001b[38;5;28mstr\\u001b[39m(full_path),\\n\\u001b[1;32m 234\\u001b[0m )\\n\\u001b[1;32m 236\\u001b[0m \\u001b[38;5;28;01mif\\u001b[39;00m downloader \\u001b[38;5;129;01mis\\u001b[39;00m \\u001b[38;5;28;01mNone\\u001b[39;00m:\\n\",\n \"File \\u001b[0;32m/usr/lib/python3/dist-packages/pooch/utils.py:276\\u001b[0m, in \\u001b[0;36mmake_local_storage\\u001b[0;34m(path, env)\\u001b[0m\\n\\u001b[1;32m 272\\u001b[0m \\u001b[38;5;28;01mif\\u001b[39;00m env \\u001b[38;5;129;01mis\\u001b[39;00m \\u001b[38;5;129;01mnot\\u001b[39;00m \\u001b[38;5;28;01mNone\\u001b[39;00m:\\n\\u001b[1;32m 273\\u001b[0m message\\u001b[38;5;241m.\\u001b[39mappend(\\n\\u001b[1;32m 274\\u001b[0m \\u001b[38;5;124mf\\u001b[39m\\u001b[38;5;124m\\\"\\u001b[39m\\u001b[38;5;124mUse environment variable \\u001b[39m\\u001b[38;5;124m'\\u001b[39m\\u001b[38;5;132;01m{\\u001b[39;00menv\\u001b[38;5;132;01m}\\u001b[39;00m\\u001b[38;5;124m'\\u001b[39m\\u001b[38;5;124m to specify a different location.\\u001b[39m\\u001b[38;5;124m\\\"\\u001b[39m\\n\\u001b[1;32m 275\\u001b[0m )\\n\\u001b[0;32m--> 276\\u001b[0m \\u001b[38;5;28;01mraise\\u001b[39;00m \\u001b[38;5;167;01mPermissionError\\u001b[39;00m(\\u001b[38;5;124m\\\"\\u001b[39m\\u001b[38;5;124m \\u001b[39m\\u001b[38;5;124m\\\"\\u001b[39m\\u001b[38;5;241m.\\u001b[39mjoin(message)) \\u001b[38;5;28;01mfrom\\u001b[39;00m \\u001b[38;5;21;01merror\\u001b[39;00m\\n\",\n- \"\\u001b[0;31mPermissionError\\u001b[0m: [Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/first-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\"\n+ \"\\u001b[0;31mPermissionError\\u001b[0m: [Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/second-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\"\n ]\n }\n ],\n \"source\": [\n \"ds = xr.tutorial.load_dataset(\\\"air_temperature\\\")\"\n ]\n },\n@@ -91,18 +91,18 @@\n ]\n },\n {\n \"cell_type\": \"code\",\n \"execution_count\": 3,\n \"metadata\": {\n \"execution\": {\n- \"iopub.execute_input\": \"2026-04-07T09:27:17.905034Z\",\n- \"iopub.status.busy\": \"2026-04-07T09:27:17.904786Z\",\n- \"iopub.status.idle\": \"2026-04-07T09:27:17.921976Z\",\n- \"shell.execute_reply\": \"2026-04-07T09:27:17.921257Z\"\n+ \"iopub.execute_input\": \"2025-03-05T03:37:26.639049Z\",\n+ \"iopub.status.busy\": \"2025-03-05T03:37:26.638487Z\",\n+ \"iopub.status.idle\": \"2025-03-05T03:37:26.752752Z\",\n+ \"shell.execute_reply\": \"2025-03-05T03:37:26.739931Z\"\n }\n },\n \"outputs\": [\n {\n \"ename\": \"NameError\",\n \"evalue\": \"name 'ds' is not defined\",\n \"output_type\": \"error\",\n@@ -144,18 +144,18 @@\n ]\n },\n {\n \"cell_type\": \"code\",\n \"execution_count\": 4,\n \"metadata\": {\n \"execution\": {\n- \"iopub.execute_input\": \"2026-04-07T09:27:17.924012Z\",\n- \"iopub.status.busy\": \"2026-04-07T09:27:17.923772Z\",\n- \"iopub.status.idle\": \"2026-04-07T09:27:17.941255Z\",\n- \"shell.execute_reply\": \"2026-04-07T09:27:17.940680Z\"\n+ \"iopub.execute_input\": \"2025-03-05T03:37:26.764478Z\",\n+ \"iopub.status.busy\": \"2025-03-05T03:37:26.763020Z\",\n+ \"iopub.status.idle\": \"2025-03-05T03:37:26.947993Z\",\n+ \"shell.execute_reply\": \"2025-03-05T03:37:26.933322Z\"\n }\n },\n \"outputs\": [\n {\n \"ename\": \"NameError\",\n \"evalue\": \"name 'ds' is not defined\",\n \"output_type\": \"error\",\n@@ -208,18 +208,18 @@\n ]\n },\n {\n \"cell_type\": \"code\",\n \"execution_count\": 5,\n \"metadata\": {\n \"execution\": {\n- \"iopub.execute_input\": \"2026-04-07T09:27:17.943828Z\",\n- \"iopub.status.busy\": \"2026-04-07T09:27:17.943211Z\",\n- \"iopub.status.idle\": \"2026-04-07T09:27:17.958739Z\",\n- \"shell.execute_reply\": \"2026-04-07T09:27:17.957978Z\"\n+ \"iopub.execute_input\": \"2025-03-05T03:37:26.969533Z\",\n+ \"iopub.status.busy\": \"2025-03-05T03:37:26.969039Z\",\n+ \"iopub.status.idle\": \"2025-03-05T03:37:27.052945Z\",\n+ \"shell.execute_reply\": \"2025-03-05T03:37:27.046973Z\"\n }\n },\n \"outputs\": [\n {\n \"ename\": \"NameError\",\n \"evalue\": \"name 'ds' is not defined\",\n \"output_type\": \"error\",\n@@ -264,18 +264,18 @@\n ]\n },\n {\n \"cell_type\": \"code\",\n \"execution_count\": 6,\n \"metadata\": {\n \"execution\": {\n- \"iopub.execute_input\": \"2026-04-07T09:27:17.960696Z\",\n- \"iopub.status.busy\": \"2026-04-07T09:27:17.960446Z\",\n- \"iopub.status.idle\": \"2026-04-07T09:27:17.976505Z\",\n- \"shell.execute_reply\": \"2026-04-07T09:27:17.975734Z\"\n+ \"iopub.execute_input\": \"2025-03-05T03:37:27.060074Z\",\n+ \"iopub.status.busy\": \"2025-03-05T03:37:27.059519Z\",\n+ \"iopub.status.idle\": \"2025-03-05T03:37:27.147976Z\",\n+ \"shell.execute_reply\": \"2025-03-05T03:37:27.131960Z\"\n }\n },\n \"outputs\": [\n {\n \"ename\": \"NameError\",\n \"evalue\": \"name 'ds' is not defined\",\n \"output_type\": \"error\",\n"}]}]}, {"source1": "./usr/share/doc/python-xarray-doc/html/examples/weather-data.html", "source2": "./usr/share/doc/python-xarray-doc/html/examples/weather-data.html", "unified_diff": "@@ -470,37 +470,37 @@\n
<xarray.Dataset> Size: 41kB\n Dimensions:   (time: 731, location: 3)\n Coordinates:\n   * time      (time) datetime64[ns] 6kB 2000-01-01 2000-01-02 ... 2001-12-31\n   * location  (location) <U2 24B 'IA' 'IN' 'IL'\n Data variables:\n     tmin      (time, location) float64 18kB -8.037 -1.788 ... -1.346 -4.544\n-    tmax      (time, location) float64 18kB 12.98 3.31 6.779 ... 3.343 3.805
  • location
    PandasIndex
    PandasIndex(Index(['IA', 'IN', 'IL'], dtype='object', name='location'))
  • \n \n
    \n

    Examine a dataset with pandas and seaborn\u00b6

    \n
    \n

    Convert to a pandas DataFrame\u00b6

    \n
    \n
    [2]:\n@@ -697,15 +697,15 @@\n 
    \n
    \n
    [5]:\n 
    \n
    \n
    \n
    \n-<seaborn.axisgrid.PairGrid at 0x7f998cabf770>\n+<seaborn.axisgrid.PairGrid at 0x7f0b76afb770>\n 
    \n
    \n
    \n
    \n
    \n
    \n \"../_images/examples_weather-data_9_1.png\"\n@@ -1110,26 +1110,26 @@\n [0. , 0. , 0. ],\n [0. , 0. , 0. ],\n [0. , 0.01612903, 0. ],\n [0.33333333, 0.35 , 0.23333333],\n [0.93548387, 0.85483871, 0.82258065]])\n Coordinates:\n * location (location) <U2 24B 'IA' 'IN' 'IL'\n- * month (month) int64 96B 1 2 3 4 5 6 7 8 9 10 11 12
    • location
      (location)
      <U2
      'IA' 'IN' 'IL'
      array(['IA', 'IN', 'IL'], dtype='<U2')
    • month
      (month)
      int64
      1 2 3 4 5 6 7 8 9 10 11 12
      array([ 1,  2,  3,  4,  5,  6,  7,  8,  9, 10, 11, 12])
    • location
      PandasIndex
      PandasIndex(Index(['IA', 'IN', 'IL'], dtype='object', name='location'))
    • month
      PandasIndex
      PandasIndex(Index([1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12], dtype='int64', name='month'))
  • \n \n
    \n
    [7]:\n 
    \n
    \n
    freeze.to_pandas().plot()\n 
    \n@@ -1642,18 +1642,18 @@\n Dimensions: (time: 731, location: 3)\n Coordinates:\n * time (time) datetime64[ns] 6kB 2000-01-01 2000-01-02 ... 2001-12-31\n * location (location) <U2 24B 'IA' 'IN' 'IL'\n month (time) int64 6kB 1 1 1 1 1 1 1 1 1 ... 12 12 12 12 12 12 12 12\n Data variables:\n some_missing (time, location) float64 18kB nan nan nan ... -1.346 -4.544\n- filled (time, location) float64 18kB -5.163 -4.216 ... -1.346 -4.544
  • location
    PandasIndex
    PandasIndex(Index(['IA', 'IN', 'IL'], dtype='object', name='location'))
  • \n \n
    \n
    [12]:\n 
    \n
    \n
    df = both.sel(time="2000").mean("location").reset_coords(drop=True).to_dataframe()\n df.head()\n", "details": [{"source1": "html2text {}", "source2": "html2text {}", "unified_diff": "@@ -142,15 +142,15 @@\n [4]:\n \n [../_images/examples_weather-data_7_1.png]\n *\b**\b**\b**\b* V\bVi\bis\bsu\bua\bal\bli\biz\bze\be u\bus\bsi\bin\bng\bg s\bse\bea\bab\bbo\bor\brn\bn_\b?\b\u00b6 *\b**\b**\b**\b*\n [5]:\n sns.pairplot(df.reset_index(), vars=ds.data_vars)\n [5]:\n-\n+\n [../_images/examples_weather-data_9_1.png]\n *\b**\b**\b**\b**\b* P\bPr\bro\bob\bba\bab\bbi\bil\bli\bit\bty\by o\bof\bf f\bfr\bre\bee\bez\bze\be b\bby\by c\bca\bal\ble\ben\bnd\bda\bar\br m\bmo\bon\bnt\bth\bh_\b?\b\u00b6 *\b**\b**\b**\b**\b*\n [6]:\n freeze = (ds[\"tmin\"] <= 0).groupby(\"time.month\").mean(\"time\")\n freeze\n [6]:\n  Size: 288B\n"}]}, {"source1": "./usr/share/doc/python-xarray-doc/html/examples/weather-data.ipynb.gz", "source2": "./usr/share/doc/python-xarray-doc/html/examples/weather-data.ipynb.gz", "unified_diff": null, "details": [{"source1": "weather-data.ipynb", "source2": "weather-data.ipynb", "unified_diff": null, "details": [{"source1": "Pretty-printed", "source2": "Pretty-printed", "comments": ["Similarity: 0.9992323269378145%", "Differences: {\"'cells'\": \"{1: {'metadata': {'execution': {'iopub.execute_input': '2025-03-05T03:37:35.861512Z', \"", "            \"'iopub.status.busy': '2025-03-05T03:37:35.860991Z', 'iopub.status.idle': \"", "            \"'2025-03-05T03:37:42.433042Z', 'shell.execute_reply': \"", "            \"'2025-03-05T03:37:42.420236Z'}}, 'outputs': {0: {'data': {'text/html': {insert: \"", "            '[(377, \"    tmax      (time, location) float64 18kB 12.98 3.31 6.779 ... 3.343 '", "            \"3.805
    \"\n ],\n \"text/plain\": [\n \" Size: 41kB\\n\",\n \"Dimensions: (time: 731, location: 3)\\n\",\n \"Coordinates:\\n\",\n \" * time (time) datetime64[ns] 6kB 2000-01-01 2000-01-02 ... 2001-12-31\\n\",\n \" * location (location) \\n\",\n@@ -594,18 +594,18 @@\n \"execution_count\": 3,\n \"metadata\": {\n \"ExecuteTime\": {\n \"end_time\": \"2020-01-27T15:47:32.682065Z\",\n \"start_time\": \"2020-01-27T15:47:32.652629Z\"\n },\n \"execution\": {\n- \"iopub.execute_input\": \"2026-04-07T09:27:21.237493Z\",\n- \"iopub.status.busy\": \"2026-04-07T09:27:21.237255Z\",\n- \"iopub.status.idle\": \"2026-04-07T09:27:21.249887Z\",\n- \"shell.execute_reply\": \"2026-04-07T09:27:21.249328Z\"\n+ \"iopub.execute_input\": \"2025-03-05T03:37:42.549438Z\",\n+ \"iopub.status.busy\": \"2025-03-05T03:37:42.548974Z\",\n+ \"iopub.status.idle\": \"2025-03-05T03:37:42.628062Z\",\n+ \"shell.execute_reply\": \"2025-03-05T03:37:42.611910Z\"\n }\n },\n \"outputs\": [\n {\n \"data\": {\n \"text/html\": [\n \"
    \\n\",\n@@ -708,18 +708,18 @@\n \"execution_count\": 4,\n \"metadata\": {\n \"ExecuteTime\": {\n \"end_time\": \"2020-01-27T15:47:34.617042Z\",\n \"start_time\": \"2020-01-27T15:47:34.282605Z\"\n },\n \"execution\": {\n- \"iopub.execute_input\": \"2026-04-07T09:27:21.251799Z\",\n- \"iopub.status.busy\": \"2026-04-07T09:27:21.251564Z\",\n- \"iopub.status.idle\": \"2026-04-07T09:27:21.518847Z\",\n- \"shell.execute_reply\": \"2026-04-07T09:27:21.518145Z\"\n+ \"iopub.execute_input\": \"2025-03-05T03:37:42.650730Z\",\n+ \"iopub.status.busy\": \"2025-03-05T03:37:42.650254Z\",\n+ \"iopub.status.idle\": \"2025-03-05T03:37:44.360477Z\",\n+ \"shell.execute_reply\": \"2025-03-05T03:37:44.344756Z\"\n }\n },\n \"outputs\": [\n {\n \"data\": {\n \"text/plain\": [\n \"\"\n@@ -756,25 +756,25 @@\n \"execution_count\": 5,\n \"metadata\": {\n \"ExecuteTime\": {\n \"end_time\": \"2020-01-27T15:47:37.643175Z\",\n \"start_time\": \"2020-01-27T15:47:37.202479Z\"\n },\n \"execution\": {\n- \"iopub.execute_input\": \"2026-04-07T09:27:21.521453Z\",\n- \"iopub.status.busy\": \"2026-04-07T09:27:21.521198Z\",\n- \"iopub.status.idle\": \"2026-04-07T09:27:22.423723Z\",\n- \"shell.execute_reply\": \"2026-04-07T09:27:22.423034Z\"\n+ \"iopub.execute_input\": \"2025-03-05T03:37:44.382198Z\",\n+ \"iopub.status.busy\": \"2025-03-05T03:37:44.381648Z\",\n+ \"iopub.status.idle\": \"2025-03-05T03:37:50.118299Z\",\n+ \"shell.execute_reply\": \"2025-03-05T03:37:50.116021Z\"\n }\n },\n \"outputs\": [\n {\n \"data\": {\n \"text/plain\": [\n- \"\"\n+ \"\"\n ]\n },\n \"execution_count\": 5,\n \"metadata\": {},\n \"output_type\": \"execute_result\"\n },\n {\n@@ -804,18 +804,18 @@\n \"execution_count\": 6,\n \"metadata\": {\n \"ExecuteTime\": {\n \"end_time\": \"2020-01-27T15:48:11.241224Z\",\n \"start_time\": \"2020-01-27T15:48:11.211156Z\"\n },\n \"execution\": {\n- \"iopub.execute_input\": \"2026-04-07T09:27:22.426089Z\",\n- \"iopub.status.busy\": \"2026-04-07T09:27:22.425835Z\",\n- \"iopub.status.idle\": \"2026-04-07T09:27:22.444874Z\",\n- \"shell.execute_reply\": \"2026-04-07T09:27:22.444295Z\"\n+ \"iopub.execute_input\": \"2025-03-05T03:37:50.133929Z\",\n+ \"iopub.status.busy\": \"2025-03-05T03:37:50.133201Z\",\n+ \"iopub.status.idle\": \"2025-03-05T03:37:50.181184Z\",\n+ \"shell.execute_reply\": \"2025-03-05T03:37:50.179878Z\"\n }\n },\n \"outputs\": [\n {\n \"data\": {\n \"text/html\": [\n \"
    \\n\",\n@@ -1199,26 +1199,26 @@\n \" [0. , 0. , 0. ],\\n\",\n \" [0. , 0. , 0. ],\\n\",\n \" [0. , 0.01612903, 0. ],\\n\",\n \" [0.33333333, 0.35 , 0.23333333],\\n\",\n \" [0.93548387, 0.85483871, 0.82258065]])\\n\",\n \"Coordinates:\\n\",\n \" * location (location) <U2 24B 'IA' 'IN' 'IL'\\n\",\n- \" * month (month) int64 96B 1 2 3 4 5 6 7 8 9 10 11 12
    • location
      (location)
      <U2
      'IA' 'IN' 'IL'
      array(['IA', 'IN', 'IL'], dtype='<U2')
    • month
      (month)
      int64
      1 2 3 4 5 6 7 8 9 10 11 12
      array([ 1,  2,  3,  4,  5,  6,  7,  8,  9, 10, 11, 12])
    • location
      PandasIndex
      PandasIndex(Index(['IA', 'IN', 'IL'], dtype='object', name='location'))
    • month
      PandasIndex
      PandasIndex(Index([1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12], dtype='int64', name='month'))
  • \"\n ],\n \"text/plain\": [\n \" Size: 288B\\n\",\n \"array([[0.9516129 , 0.88709677, 0.93548387],\\n\",\n \" [0.84210526, 0.71929825, 0.77192982],\\n\",\n \" [0.24193548, 0.12903226, 0.16129032],\\n\",\n \" [0. , 0. , 0. ],\\n\",\n@@ -1250,18 +1250,18 @@\n \"execution_count\": 7,\n \"metadata\": {\n \"ExecuteTime\": {\n \"end_time\": \"2020-01-27T15:48:13.131247Z\",\n \"start_time\": \"2020-01-27T15:48:12.924985Z\"\n },\n \"execution\": {\n- \"iopub.execute_input\": \"2026-04-07T09:27:22.446899Z\",\n- \"iopub.status.busy\": \"2026-04-07T09:27:22.446651Z\",\n- \"iopub.status.idle\": \"2026-04-07T09:27:22.633803Z\",\n- \"shell.execute_reply\": \"2026-04-07T09:27:22.633131Z\"\n+ \"iopub.execute_input\": \"2025-03-05T03:37:50.194133Z\",\n+ \"iopub.status.busy\": \"2025-03-05T03:37:50.193568Z\",\n+ \"iopub.status.idle\": \"2025-03-05T03:37:50.836879Z\",\n+ \"shell.execute_reply\": \"2025-03-05T03:37:50.827286Z\"\n }\n },\n \"outputs\": [\n {\n \"data\": {\n \"text/plain\": [\n \"\"\n@@ -1298,18 +1298,18 @@\n \"execution_count\": 8,\n \"metadata\": {\n \"ExecuteTime\": {\n \"end_time\": \"2020-01-27T15:48:08.498259Z\",\n \"start_time\": \"2020-01-27T15:48:08.210890Z\"\n },\n \"execution\": {\n- \"iopub.execute_input\": \"2026-04-07T09:27:22.636762Z\",\n- \"iopub.status.busy\": \"2026-04-07T09:27:22.636497Z\",\n- \"iopub.status.idle\": \"2026-04-07T09:27:22.896347Z\",\n- \"shell.execute_reply\": \"2026-04-07T09:27:22.895535Z\"\n+ \"iopub.execute_input\": \"2025-03-05T03:37:50.857926Z\",\n+ \"iopub.status.busy\": \"2025-03-05T03:37:50.857286Z\",\n+ \"iopub.status.idle\": \"2025-03-05T03:37:53.103998Z\",\n+ \"shell.execute_reply\": \"2025-03-05T03:37:53.083923Z\"\n }\n },\n \"outputs\": [\n {\n \"data\": {\n \"text/plain\": [\n \"\"\n@@ -1363,18 +1363,18 @@\n \"execution_count\": 9,\n \"metadata\": {\n \"ExecuteTime\": {\n \"end_time\": \"2020-01-27T15:49:34.855086Z\",\n \"start_time\": \"2020-01-27T15:49:34.406439Z\"\n },\n \"execution\": {\n- \"iopub.execute_input\": \"2026-04-07T09:27:22.899251Z\",\n- \"iopub.status.busy\": \"2026-04-07T09:27:22.898979Z\",\n- \"iopub.status.idle\": \"2026-04-07T09:27:23.186369Z\",\n- \"shell.execute_reply\": \"2026-04-07T09:27:23.185697Z\"\n+ \"iopub.execute_input\": \"2025-03-05T03:37:53.121835Z\",\n+ \"iopub.status.busy\": \"2025-03-05T03:37:53.121293Z\",\n+ \"iopub.status.idle\": \"2025-03-05T03:37:54.005010Z\",\n+ \"shell.execute_reply\": \"2025-03-05T03:37:53.987997Z\"\n }\n },\n \"outputs\": [\n {\n \"data\": {\n \"text/plain\": [\n \"\"\n@@ -1422,18 +1422,18 @@\n \"execution_count\": 10,\n \"metadata\": {\n \"ExecuteTime\": {\n \"end_time\": \"2020-01-27T15:50:09.144586Z\",\n \"start_time\": \"2020-01-27T15:50:08.734682Z\"\n },\n \"execution\": {\n- \"iopub.execute_input\": \"2026-04-07T09:27:23.189214Z\",\n- \"iopub.status.busy\": \"2026-04-07T09:27:23.188935Z\",\n- \"iopub.status.idle\": \"2026-04-07T09:27:23.543791Z\",\n- \"shell.execute_reply\": \"2026-04-07T09:27:23.543102Z\"\n+ \"iopub.execute_input\": \"2025-03-05T03:37:54.022544Z\",\n+ \"iopub.status.busy\": \"2025-03-05T03:37:54.021903Z\",\n+ \"iopub.status.idle\": \"2025-03-05T03:37:56.624018Z\",\n+ \"shell.execute_reply\": \"2025-03-05T03:37:56.607944Z\"\n }\n },\n \"outputs\": [\n {\n \"data\": {\n \"text/plain\": [\n \"\"\n@@ -1491,18 +1491,18 @@\n \"execution_count\": 11,\n \"metadata\": {\n \"ExecuteTime\": {\n \"end_time\": \"2020-01-27T15:51:40.279299Z\",\n \"start_time\": \"2020-01-27T15:51:40.220342Z\"\n },\n \"execution\": {\n- \"iopub.execute_input\": \"2026-04-07T09:27:23.546285Z\",\n- \"iopub.status.busy\": \"2026-04-07T09:27:23.545997Z\",\n- \"iopub.status.idle\": \"2026-04-07T09:27:23.592220Z\",\n- \"shell.execute_reply\": \"2026-04-07T09:27:23.591645Z\"\n+ \"iopub.execute_input\": \"2025-03-05T03:37:56.642251Z\",\n+ \"iopub.status.busy\": \"2025-03-05T03:37:56.641502Z\",\n+ \"iopub.status.idle\": \"2025-03-05T03:37:56.988424Z\",\n+ \"shell.execute_reply\": \"2025-03-05T03:37:56.968492Z\"\n }\n },\n \"outputs\": [\n {\n \"data\": {\n \"text/html\": [\n \"
    \\n\",\n@@ -1879,18 +1879,18 @@\n \"Dimensions: (time: 731, location: 3)\\n\",\n \"Coordinates:\\n\",\n \" * time (time) datetime64[ns] 6kB 2000-01-01 2000-01-02 ... 2001-12-31\\n\",\n \" * location (location) <U2 24B 'IA' 'IN' 'IL'\\n\",\n \" month (time) int64 6kB 1 1 1 1 1 1 1 1 1 ... 12 12 12 12 12 12 12 12\\n\",\n \"Data variables:\\n\",\n \" some_missing (time, location) float64 18kB nan nan nan ... -1.346 -4.544\\n\",\n- \" filled (time, location) float64 18kB -5.163 -4.216 ... -1.346 -4.544
  • \"\n ],\n \"text/plain\": [\n \" Size: 47kB\\n\",\n \"Dimensions: (time: 731, location: 3)\\n\",\n \"Coordinates:\\n\",\n \" * time (time) datetime64[ns] 6kB 2000-01-01 2000-01-02 ... 2001-12-31\\n\",\n \" * location (location) \\n\",\n@@ -2073,18 +2073,18 @@\n \"execution_count\": 13,\n \"metadata\": {\n \"ExecuteTime\": {\n \"end_time\": \"2020-01-27T15:52:14.867866Z\",\n \"start_time\": \"2020-01-27T15:52:14.449684Z\"\n },\n \"execution\": {\n- \"iopub.execute_input\": \"2026-04-07T09:27:23.605076Z\",\n- \"iopub.status.busy\": \"2026-04-07T09:27:23.604840Z\",\n- \"iopub.status.idle\": \"2026-04-07T09:27:23.930630Z\",\n- \"shell.execute_reply\": \"2026-04-07T09:27:23.929994Z\"\n+ \"iopub.execute_input\": \"2025-03-05T03:37:57.102147Z\",\n+ \"iopub.status.busy\": \"2025-03-05T03:37:57.101283Z\",\n+ \"iopub.status.idle\": \"2025-03-05T03:37:58.736423Z\",\n+ \"shell.execute_reply\": \"2025-03-05T03:37:58.724540Z\"\n }\n },\n \"outputs\": [\n {\n \"data\": {\n \"text/plain\": [\n \"\"\n"}]}]}, {"source1": "./usr/share/doc/python-xarray-doc/html/getting-started-guide/quick-overview.html", "source2": "./usr/share/doc/python-xarray-doc/html/getting-started-guide/quick-overview.html", "unified_diff": "@@ -324,15 +324,15 @@\n
    \n \n
    \n
    \n

    Plotting\u00b6

    \n

    Visualizing your datasets is quick and convenient:

    \n
    In [37]: data.plot()\n-Out[37]: <matplotlib.collections.QuadMesh at 0x7f93c3208440>\n+Out[37]: <matplotlib.collections.QuadMesh at 0x7f39571d3e00>\n 
    \n
    \n \"_build/html/_static/plotting_quick_overview.png\"\n

    Note the automatic labeling with names and units. Our effort in adding metadata attributes has paid off! Many aspects of these figures are customizable: see Plotting.

    \n
    \n
    \n

    pandas\u00b6

    \n", "details": [{"source1": "html2text {}", "source2": "html2text {}", "unified_diff": "@@ -253,15 +253,15 @@\n [0.37342613, 1.49497537, 1.33584385]])\n Coordinates:\n * x (x) int64 16B 10 20\n Dimensions without coordinates: y\n *\b**\b**\b**\b**\b* P\bPl\blo\bot\btt\bti\bin\bng\bg_\b?\b\u00b6 *\b**\b**\b**\b**\b*\n Visualizing your datasets is quick and convenient:\n In [37]: data.plot()\n-Out[37]: \n+Out[37]: \n [_build/html/_static/plotting_quick_overview.png]\n Note the automatic labeling with names and units. Our effort in adding metadata\n attributes has paid off! Many aspects of these figures are customizable: see\n _\bP_\bl_\bo_\bt_\bt_\bi_\bn_\bg.\n *\b**\b**\b**\b**\b* p\bpa\ban\bnd\bda\bas\bs_\b?\b\u00b6 *\b**\b**\b**\b**\b*\n Xarray objects can be easily converted to and from pandas objects using the\n to_series(), to_dataframe() and _\bt_\bo_\b__\bx_\ba_\br_\br_\ba_\by_\b(_\b) methods:\n"}]}, {"source1": "./usr/share/doc/python-xarray-doc/html/internals/internal-design.html", "source2": "./usr/share/doc/python-xarray-doc/html/internals/internal-design.html", "unified_diff": "@@ -210,15 +210,15 @@\n File /usr/lib/python3/dist-packages/pooch/utils.py:276, in make_local_storage(path, env)\n 272 if env is not None:\n 273 message.append(\n 274 f"Use environment variable '{env}' to specify a different location."\n 275 )\n --> 276 raise PermissionError(" ".join(message)) from error\n \n-PermissionError: [Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/first-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\n+PermissionError: [Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/second-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\n \n In [2]: var = da.variable\n ---------------------------------------------------------------------------\n AttributeError Traceback (most recent call last)\n Cell In[2], line 1\n ----> 1 var = da.variable\n \n@@ -312,15 +312,15 @@\n File /usr/lib/python3/dist-packages/pooch/utils.py:276, in make_local_storage(path, env)\n 272 if env is not None:\n 273 message.append(\n 274 f"Use environment variable '{env}' to specify a different location."\n 275 )\n --> 276 raise PermissionError(" ".join(message)) from error\n \n-PermissionError: [Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/first-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\n+PermissionError: [Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/second-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\n \n In [8]: var = da.variable\n ---------------------------------------------------------------------------\n AttributeError Traceback (most recent call last)\n Cell In[8], line 1\n ----> 1 var = da.variable\n \n", "details": [{"source1": "html2text {}", "source2": "html2text {}", "unified_diff": "@@ -159,15 +159,15 @@\n 273 message.append(\n 274 f\"Use environment variable '{env}' to specify a different\n location.\"\n 275 )\n --> 276 raise PermissionError(\" \".join(message)) from error\n \n PermissionError: [Errno 13] Permission denied: '/nonexistent' | Pooch could not\n-create data cache folder '/nonexistent/first-build/.cache/\n+create data cache folder '/nonexistent/second-build/.cache/\n xarray_tutorial_data'. Will not be able to download data files.\n \n In [2]: var = da.variable\n ---------------------------------------------------------------------------\n AttributeError Traceback (most recent call last)\n Cell In[2], line 1\n ----> 1 var = da.variable\n@@ -260,15 +260,15 @@\n 273 message.append(\n 274 f\"Use environment variable '{env}' to specify a different\n location.\"\n 275 )\n --> 276 raise PermissionError(\" \".join(message)) from error\n \n PermissionError: [Errno 13] Permission denied: '/nonexistent' | Pooch could not\n-create data cache folder '/nonexistent/first-build/.cache/\n+create data cache folder '/nonexistent/second-build/.cache/\n xarray_tutorial_data'. Will not be able to download data files.\n \n In [8]: var = da.variable\n ---------------------------------------------------------------------------\n AttributeError Traceback (most recent call last)\n Cell In[8], line 1\n ----> 1 var = da.variable\n"}]}, {"source1": "./usr/share/doc/python-xarray-doc/html/internals/zarr-encoding-spec.html", "source2": "./usr/share/doc/python-xarray-doc/html/internals/zarr-encoding-spec.html", "unified_diff": "@@ -163,23 +163,23 @@\n File /usr/lib/python3/dist-packages/pooch/utils.py:276, in make_local_storage(path, env)\n 272 if env is not None:\n 273 message.append(\n 274 f"Use environment variable '{env}' to specify a different location."\n 275 )\n --> 276 raise PermissionError(" ".join(message)) from error\n \n-PermissionError: [Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/first-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\n+PermissionError: [Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/second-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\n \n In [5]: ds.to_zarr("rasm.zarr", mode="w")\n-Out[5]: <xarray.backends.zarr.ZarrStore at 0x7f939786bd00>\n+Out[5]: <xarray.backends.zarr.ZarrStore at 0x7f3933957910>\n \n In [6]: zgroup = zarr.open("rasm.zarr")\n \n In [7]: print(os.listdir("rasm.zarr"))\n-['latitude', '.zgroup', '.zattrs', 'longitude', '.zmetadata']\n+['.zmetadata', 'longitude', 'latitude', '.zattrs', '.zgroup']\n \n In [8]: print(zgroup.tree())\n /\n \u251c\u2500\u2500 latitude (50,) float64\n \u2514\u2500\u2500 longitude (50,) float64\n \n In [9]: dict(zgroup["Tair"].attrs)\n", "details": [{"source1": "html2text {}", "source2": "html2text {}", "unified_diff": "@@ -111,24 +111,24 @@\n 273 message.append(\n 274 f\"Use environment variable '{env}' to specify a different\n location.\"\n 275 )\n --> 276 raise PermissionError(\" \".join(message)) from error\n \n PermissionError: [Errno 13] Permission denied: '/nonexistent' | Pooch could not\n-create data cache folder '/nonexistent/first-build/.cache/\n+create data cache folder '/nonexistent/second-build/.cache/\n xarray_tutorial_data'. Will not be able to download data files.\n \n In [5]: ds.to_zarr(\"rasm.zarr\", mode=\"w\")\n-Out[5]: \n+Out[5]: \n \n In [6]: zgroup = zarr.open(\"rasm.zarr\")\n \n In [7]: print(os.listdir(\"rasm.zarr\"))\n-['latitude', '.zgroup', '.zattrs', 'longitude', '.zmetadata']\n+['.zmetadata', 'longitude', 'latitude', '.zattrs', '.zgroup']\n \n In [8]: print(zgroup.tree())\n /\n \u251c\u2500\u2500 latitude (50,) float64\n \u2514\u2500\u2500 longitude (50,) float64\n \n In [9]: dict(zgroup[\"Tair\"].attrs)\n"}]}, {"source1": "./usr/share/doc/python-xarray-doc/html/searchindex.js", "source2": "./usr/share/doc/python-xarray-doc/html/searchindex.js", "unified_diff": null, "details": [{"source1": "js-beautify {}", "source2": "js-beautify {}", "unified_diff": "@@ -2353,49 +2353,54 @@\n \"4\": \"py:attribute\",\n \"5\": \"py:function\"\n },\n \"terms\": {\n \"\": [1, 3, 5, 6, 7, 8, 9, 10, 11, 12, 14, 15, 16, 17, 19, 20, 21, 23, 24, 25, 26, 27, 28, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 43, 44, 45, 47, 48, 49, 50, 51, 52],\n \"0\": [3, 6, 7, 8, 9, 11, 12, 13, 14, 16, 18, 19, 20, 22, 24, 25, 26, 27, 28, 30, 33, 35, 36, 37, 38, 40, 41, 43, 44, 45, 47, 48, 49, 50, 51, 52, 53],\n \"00\": [14, 36, 37, 38, 45, 47, 51, 52, 53, 54],\n+ \"000\": 51,\n \"000000\": [14, 16],\n \"000000000\": [14, 37, 38, 52],\n \"0001\": [53, 54],\n \"00010101\": 53,\n \"00010201\": 53,\n \"00010301\": 53,\n \"0002\": 53,\n \"00021001\": 53,\n \"00021101\": 53,\n \"00021201\": 53,\n \"000e\": [48, 51],\n+ \"000j\": 51,\n \"001e\": 37,\n+ \"001j\": 51,\n \"005036\": 40,\n \"005e\": 37,\n \"00688889\": 36,\n \"006e\": 37,\n+ \"007e\": 51,\n \"00914929\": 36,\n \"00941742\": 36,\n \"00968205\": 36,\n \"00973567\": 36,\n- \"00j\": 51,\n- \"01\": [14, 16, 20, 26, 30, 32, 37, 38, 41, 43, 44, 45, 47, 48, 51, 52, 53],\n+ \"01\": [14, 16, 20, 26, 30, 32, 37, 38, 41, 43, 44, 45, 47, 48, 52, 53],\n \"010569\": 14,\n \"01082401\": 36,\n \"01183847\": 36,\n+ \"016\": 51,\n \"01612903\": 14,\n \"01636376\": 36,\n \"01652688\": 36,\n \"01652764\": 36,\n \"0165891\": 36,\n \"01670071\": 36,\n \"01670121\": 36,\n \"01671269\": 36,\n \"01671847\": 36,\n \"01672\": 36,\n+ \"016j\": 51,\n \"017\": 43,\n \"01806694\": 36,\n \"01814439\": 36,\n \"0182217\": 36,\n \"018e\": 37,\n \"019\": 40,\n \"01906\": 48,\n@@ -2411,14 +2416,15 @@\n \"026e\": 37,\n \"02756784\": 19,\n \"029e\": 48,\n \"02t00\": [14, 37, 38],\n \"03\": [6, 14, 37, 43, 44, 45, 48, 52, 53],\n \"03047\": 48,\n \"031\": 41,\n+ \"032e\": 51,\n \"03333\": 44,\n \"03343807\": 36,\n \"03343845\": 36,\n \"03343858\": 36,\n \"03344\": 36,\n \"035e\": 37,\n \"03611368\": 36,\n@@ -2426,29 +2432,28 @@\n \"03642301\": 36,\n \"036e\": 48,\n \"037\": 14,\n \"037369\": 14,\n \"03736932\": 14,\n \"0379266750948\": 45,\n \"037e\": 37,\n- \"038\": 43,\n+ \"038\": [43, 51],\n \"03835\": 41,\n \"03957499\": 19,\n \"03t00\": [14, 37, 38],\n \"04\": [14, 19, 36, 37, 38, 41, 43, 47, 52],\n \"040347\": 14,\n \"04096206\": 36,\n \"04097352\": 36,\n \"040e\": 48,\n \"0417827\": 45,\n \"042e\": 37,\n \"044\": [35, 47],\n \"04423597\": 19,\n \"044236\": 47,\n- \"045\": 51,\n \"045588\": 14,\n \"04569531\": 36,\n \"04569651\": 14,\n \"04703446\": 36,\n \"047e\": [37, 48],\n \"04835611\": 36,\n \"04862391\": 36,\n@@ -2457,15 +2462,14 @@\n \"05\": [14, 36, 38, 45, 48, 52, 53],\n \"05405954\": 36,\n \"05556\": 44,\n \"056\": 44,\n \"057e\": 37,\n \"058e\": 37,\n \"05912615\": 36,\n- \"05j\": 51,\n \"05t00\": 37,\n \"06\": [14, 28, 36, 38, 45, 52],\n \"060403\": 14,\n \"061\": 43,\n \"06141\": 41,\n \"06187252\": 14,\n \"062\": 41,\n@@ -2477,15 +2481,15 @@\n \"06689\": 36,\n \"066e\": [37, 48],\n \"06732\": 41,\n \"067e\": 48,\n \"069\": 44,\n \"06957\": 40,\n \"06t00\": 37,\n- \"07\": [14, 38, 51, 52, 53],\n+ \"07\": [14, 38, 52, 53],\n \"070e\": 37,\n \"07180381\": 19,\n \"071804\": 47,\n \"072\": 47,\n \"072e\": 48,\n \"074e\": 37,\n \"078\": 41,\n@@ -2502,129 +2506,130 @@\n \"08347003\": 36,\n \"08349886\": 36,\n \"083590\": 14,\n \"08361\": 36,\n \"083e\": 48,\n \"08444113\": 36,\n \"084e\": 48,\n+ \"084j\": 51,\n \"0868139\": 36,\n \"08724442\": 36,\n \"08729468\": 36,\n \"088\": 38,\n \"089e\": 37,\n \"08t00\": 37,\n \"09\": [14, 36, 38, 52],\n \"09179\": 36,\n \"091e\": 37,\n+ \"093\": 51,\n \"094\": [41, 43],\n \"094e\": 48,\n \"096\": 43,\n \"096e\": 48,\n \"09705329\": 36,\n \"097e\": 37,\n \"099\": 41,\n \"09t00\": 37,\n \"0alpha10\": 54,\n \"0d\": 54,\n \"0dev\": 54,\n- \"0e\": 51,\n \"0th\": [37, 43],\n \"0x0l\": 54,\n- \"0x7f0d1cd74fe0\": 6,\n- \"0x7f9395de3950\": 48,\n- \"0x7f93961ee4d0\": 45,\n- \"0x7f93961ef520\": 45,\n- \"0x7f93961efb50\": 45,\n- \"0x7f93962802d0\": 54,\n- \"0x7f9396579e10\": 45,\n- \"0x7f9397503cb0\": 48,\n- \"0x7f93975becf0\": 48,\n- \"0x7f939786bd00\": 32,\n- \"0x7f9399bbc1a0\": 48,\n- \"0x7f939a5a2ad0\": 38,\n- \"0x7f939a5a2c10\": 38,\n- \"0x7f93c3208440\": 19,\n- \"0x7f93c3208c20\": 44,\n- \"0x7f93c3209400\": 48,\n- \"0x7f93c323e490\": 44,\n- \"0x7f93c323e5d0\": 44,\n- \"0x7f93c32b0a50\": 48,\n- \"0x7f93c339b250\": 44,\n- \"0x7f93e17a4b90\": 48,\n- \"0x7f93e17a4cd0\": 48,\n- \"0x7f93e17a4e10\": 48,\n- \"0x7f93e17a4f50\": 48,\n- \"0x7f93e17a5090\": 48,\n- \"0x7f93e18fe490\": 48,\n- \"0x7f93e18fe5d0\": 48,\n- \"0x7f93e18fe710\": 48,\n- \"0x7f93e18fe850\": 48,\n- \"0x7f93e1a5e210\": 48,\n- \"0x7f93e1b15090\": 48,\n- \"0x7f93e2304e10\": 48,\n- \"0x7f93e2304f50\": 48,\n- \"0x7f93e2306fd0\": 48,\n- \"0x7f93e2307750\": 48,\n- \"0x7f93e2323ed0\": 48,\n- \"0x7f93e23ade50\": 48,\n- \"0x7f93e23adf90\": 48,\n- \"0x7f93e23af250\": 48,\n- \"0x7f93e23c9590\": 48,\n- \"0x7f93e280f4d0\": 48,\n- \"0x7f93e2967ed0\": 48,\n- \"0x7f93e2a4a710\": 48,\n- \"0x7f93e2af2ad0\": 48,\n- \"0x7f93e2fcc2d0\": 48,\n- \"0x7f93e2fcce10\": 48,\n- \"0x7f93e2fcf390\": 48,\n- \"0x7f93e3016c10\": 48,\n- \"0x7f93e31307d0\": 48,\n- \"0x7f93e333c440\": 48,\n- \"0x7f93e3699310\": 48,\n- \"0x7f93e369b250\": 48,\n- \"0x7f93e390c4c0\": 45,\n- \"0x7f93e390cdc0\": 45,\n- \"0x7f93e390ce50\": 45,\n- \"0x7f93e390d900\": 45,\n- \"0x7f998cabf770\": 14,\n+ \"0x7f0b76afb770\": 14,\n+ \"0x7f39322c84c0\": 45,\n+ \"0x7f39322c8dc0\": 45,\n+ \"0x7f39322c8e50\": 45,\n+ \"0x7f39322c9900\": 45,\n+ \"0x7f39324264d0\": 45,\n+ \"0x7f3932427520\": 45,\n+ \"0x7f3932427b50\": 45,\n+ \"0x7f393252fed0\": 48,\n+ \"0x7f39325b5e10\": 45,\n+ \"0x7f393289b6f0\": 48,\n+ \"0x7f3933703b60\": 48,\n+ \"0x7f3933957910\": 32,\n+ \"0x7f3934ab3890\": 48,\n+ \"0x7f3935fa3770\": 48,\n+ \"0x7f39369a6c10\": 38,\n+ \"0x7f39369a6d50\": 38,\n+ \"0x7f395662cf50\": 48,\n+ \"0x7f39570842f0\": 48,\n+ \"0x7f39570846e0\": 44,\n+ \"0x7f395709bb10\": 48,\n+ \"0x7f39570ce710\": 54,\n+ \"0x7f39570fb750\": 44,\n+ \"0x7f39570fb9d0\": 44,\n+ \"0x7f39570fbd90\": 44,\n+ \"0x7f39571d3e00\": 19,\n+ \"0x7f395757fa10\": 48,\n+ \"0x7f396ee9a490\": 48,\n+ \"0x7f396ee9a5d0\": 48,\n+ \"0x7f396ee9a710\": 48,\n+ \"0x7f396ee9a850\": 48,\n+ \"0x7f396eebcb90\": 48,\n+ \"0x7f396eebccd0\": 48,\n+ \"0x7f396eebce10\": 48,\n+ \"0x7f396eebcf50\": 48,\n+ \"0x7f396eebd090\": 48,\n+ \"0x7f396f065090\": 48,\n+ \"0x7f396f094a50\": 48,\n+ \"0x7f396f120b90\": 48,\n+ \"0x7f396f1239d0\": 48,\n+ \"0x7f396f123b10\": 48,\n+ \"0x7f396f123c50\": 48,\n+ \"0x7f396f1b25d0\": 48,\n+ \"0x7f396f1b2710\": 48,\n+ \"0x7f396f1b2850\": 48,\n+ \"0x7f396f9c1590\": 48,\n+ \"0x7f396fa3c190\": 48,\n+ \"0x7f396ff1b4d0\": 48,\n+ \"0x7f396ff62710\": 48,\n+ \"0x7f3970223d90\": 48,\n+ \"0x7f3970564f50\": 48,\n+ \"0x7f39706e0050\": 48,\n+ \"0x7f39706e2ad0\": 48,\n+ \"0x7f397071e0d0\": 48,\n+ \"0x7f3970777c50\": 48,\n+ \"0x7f3970854440\": 48,\n+ \"0x7f3fcd2ecfe0\": 6,\n \"1\": [3, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 16, 18, 19, 20, 22, 24, 25, 26, 27, 28, 30, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 43, 45, 47, 48, 49, 50, 51, 52, 53],\n \"10\": [3, 6, 7, 8, 12, 13, 14, 16, 18, 19, 24, 25, 26, 27, 28, 30, 35, 36, 37, 38, 39, 40, 41, 43, 44, 45, 47, 48, 49, 50, 51, 52, 53],\n \"100\": [3, 7, 8, 27, 28, 35, 36, 37, 38, 41, 43, 44, 45, 48, 49, 50, 54],\n \"1000\": [27, 37, 54],\n \"10000\": 36,\n \"100000\": 37,\n \"1000x1000\": [6, 37],\n \"1003\": 36,\n \"100b\": 47,\n+ \"100e\": 51,\n \"101\": [36, 38, 41, 43, 48, 54],\n \"101985\": 45,\n \"101e\": 37,\n \"102\": [36, 38, 41, 43, 48, 54],\n \"1025\": 41,\n \"102e\": 37,\n \"103\": [36, 38, 41, 43, 48, 54],\n \"104\": [36, 38, 41, 43, 48, 54],\n \"104569\": 47,\n \"10456922\": 19,\n \"104b\": [35, 38],\n- \"104e\": 51,\n \"105\": [35, 36, 38, 41, 43, 47, 48],\n \"1054\": 30,\n \"1055\": 30,\n \"1056\": 30,\n \"105e\": 37,\n \"106\": [36, 38, 41, 43, 48],\n \"10614938\": 36,\n \"107\": [36, 38, 41, 43, 48],\n \"1074\": 30,\n \"1075\": 30,\n \"1076\": 30,\n \"1078\": 30,\n \"107e\": 48,\n- \"108\": [36, 38, 41, 43, 48, 52],\n+ \"108\": [36, 38, 41, 43, 48, 51, 52],\n \"1080\": [26, 30],\n \"1081\": 30,\n \"108232\": 14,\n \"1087\": 41,\n \"109\": [6, 36, 38, 41, 43, 48],\n \"10kb\": 36,\n \"10m\": [6, 7],\n@@ -2635,53 +2640,54 @@\n \"11\": [3, 7, 8, 14, 19, 27, 35, 36, 37, 38, 39, 40, 41, 43, 44, 45, 47, 48, 49, 50, 51, 52, 53],\n \"110\": [6, 36, 38, 43, 48],\n \"111\": [6, 36, 38, 43, 48],\n \"11111111\": 36,\n \"112\": [6, 36, 38, 43, 48],\n \"1126\": 41,\n \"113\": [6, 36, 38, 43, 48],\n+ \"113e\": 51,\n \"114\": [6, 36, 38, 43, 48],\n- \"115\": [6, 36, 38, 43, 48, 51],\n+ \"115\": [6, 36, 38, 43, 48],\n \"11567869\": 14,\n \"116\": [36, 38, 43, 48],\n \"116e\": 37,\n+ \"116j\": 51,\n \"117\": [36, 38, 43, 48, 52],\n \"118\": [36, 38, 43, 48, 52],\n- \"11855\": 51,\n \"119\": [36, 38, 43, 44, 48, 52],\n \"1192\": [35, 47],\n \"11920871\": 19,\n \"119209\": 47,\n \"119e\": 37,\n \"11t00\": 37,\n \"12\": [8, 11, 14, 18, 19, 35, 36, 37, 38, 39, 40, 41, 43, 44, 45, 47, 48, 49, 50, 51, 52, 53],\n \"120\": [36, 38, 43, 45, 48, 50, 52],\n \"1209\": 36,\n \"120b\": [35, 36, 41, 47],\n \"121\": [36, 38, 43, 48, 52],\n \"1212\": 36,\n- \"122\": [36, 38, 43, 48, 52],\n+ \"122\": [36, 38, 43, 48, 51, 52],\n \"123\": [14, 19, 36, 38, 43, 47, 48, 49, 52, 54],\n \"1231\": 40,\n \"12310214428849964\": 54,\n \"1234\": 3,\n \"124\": [36, 43, 45, 48, 52],\n \"12428\": 53,\n \"125\": [36, 43, 45, 48],\n \"126\": [36, 43, 48, 54],\n \"12696983303810094\": 54,\n \"127\": [36, 38, 40, 43, 48, 54],\n \"128\": [36, 43, 48, 54],\n- \"128b\": [19, 35, 40, 43],\n+ \"128b\": [19, 35, 40, 43, 51],\n \"129\": [36, 43, 48, 54],\n \"12903226\": 14,\n \"1294\": 43,\n \"12944067971751294\": 54,\n \"12arrai\": 14,\n- \"12b\": [19, 35, 43, 47, 49, 51, 54],\n+ \"12b\": [19, 35, 43, 47, 49, 54],\n \"12kb\": 52,\n \"12locat\": 14,\n \"12t00\": 37,\n \"12xarrai\": 14,\n \"13\": [6, 7, 8, 9, 10, 11, 12, 13, 14, 19, 30, 32, 35, 36, 37, 38, 39, 40, 41, 43, 44, 45, 47, 48, 49, 50, 51, 52, 53],\n \"130\": [6, 36, 43, 48],\n \"131\": [6, 36, 43, 48],\n@@ -2719,15 +2725,14 @@\n \"1443657600\": 45,\n \"144b\": [19, 38, 40, 43],\n \"145\": [36, 48],\n \"145e\": 37,\n \"146\": [36, 48],\n \"1460\": 52,\n \"14641918\": 14,\n- \"14645\": 51,\n \"14672529\": 36,\n \"147\": [36, 48],\n \"148\": [16, 36, 48],\n \"14874584\": 36,\n \"14880519\": 19,\n \"149\": 48,\n \"14974655\": 36,\n@@ -2739,21 +2744,20 @@\n \"15\": [6, 7, 8, 9, 13, 14, 19, 35, 36, 37, 38, 39, 40, 41, 43, 44, 45, 47, 48, 49, 50, 51, 52, 53],\n \"150\": [36, 48],\n \"1505\": 36,\n \"150e\": 48,\n \"151\": 48,\n \"152\": [38, 48],\n \"152b\": [38, 50],\n- \"153\": 48,\n+ \"153\": [48, 51],\n \"153e\": 37,\n \"154e\": 37,\n \"155\": 41,\n \"158\": [41, 44],\n \"158e\": 37,\n- \"159\": 51,\n \"15b\": 36,\n \"15t00\": 37,\n \"15th\": 50,\n \"16\": [8, 11, 19, 33, 35, 36, 37, 38, 39, 40, 41, 43, 44, 45, 47, 48, 49, 50, 51, 52, 53],\n \"160\": 13,\n \"160b\": [25, 45, 54],\n \"16129032\": 14,\n@@ -2768,46 +2772,45 @@\n \"1667\": 44,\n \"167\": [6, 7, 8, 9, 10, 11, 12, 13, 30, 32, 38],\n \"1678\": [18, 52, 53],\n \"168\": [6, 7, 8, 9, 10, 11, 12, 13, 30, 32],\n \"168b\": [35, 36],\n \"169\": [6, 7, 8, 9, 10, 11, 12, 13, 30, 32, 41],\n \"16959064\": 36,\n- \"169e\": 51,\n \"16b\": [19, 35, 36, 38, 40, 43, 44, 45, 47, 49, 50, 51, 53, 54],\n \"16t00\": 37,\n \"17\": [8, 19, 35, 36, 37, 38, 39, 40, 41, 43, 44, 45, 47, 48, 49, 50, 51, 52, 53],\n \"170\": 6,\n \"1703814\": 45,\n \"171\": [6, 43],\n \"171e\": [37, 48],\n \"172\": 6,\n \"17234978\": 19,\n \"173\": [47, 49],\n \"1732\": [19, 35, 47],\n \"17321465\": [19, 35],\n \"173215\": [19, 47],\n \"173e\": 37,\n- \"174\": [37, 38],\n+ \"174\": [37, 38, 51],\n \"175\": 37,\n \"175e\": 51,\n \"176\": [6, 8, 9, 10, 13, 32, 37],\n \"177\": [6, 8, 9, 10, 13, 32, 37],\n+ \"17709\": 51,\n \"1779\": 36,\n \"177e\": 37,\n \"178\": [6, 8, 9, 10, 13, 32, 37],\n \"179\": [6, 8, 9, 10, 13, 32, 37, 41],\n \"17t00\": 37,\n \"18\": [3, 8, 18, 19, 27, 35, 36, 37, 38, 39, 40, 41, 43, 44, 45, 47, 48, 49, 50, 51, 52, 53],\n \"180\": [6, 37, 44],\n \"18072141\": 14,\n \"181\": 6,\n \"182\": [6, 36, 38],\n \"183\": 6,\n- \"18322\": 51,\n \"184\": 6,\n \"184b\": 47,\n \"185\": 6,\n \"18672976\": 36,\n \"187\": 6,\n \"188\": 6,\n \"189\": [6, 44],\n@@ -2836,15 +2839,14 @@\n \"1e\": 54,\n \"1e6\": 36,\n \"1h\": 52,\n \"1kb\": [36, 37],\n \"1m\": 14,\n \"1st\": [43, 50],\n \"1ye\": 54,\n- \"1\\u017c\\u013e\\u00e6\\u00ea\": 51,\n \"2\": [3, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 16, 18, 19, 24, 25, 26, 27, 28, 30, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 43, 44, 45, 47, 48, 49, 50, 51, 52, 53],\n \"20\": [8, 13, 14, 16, 19, 24, 25, 26, 28, 35, 36, 37, 38, 39, 40, 41, 43, 44, 45, 47, 48, 49, 50, 51, 52, 53],\n \"200\": [6, 36, 43, 48, 49],\n \"2000\": [14, 16, 27, 36, 38, 43, 44, 45, 47, 52, 54],\n \"2001\": [7, 14, 45, 53, 54],\n \"201\": [6, 38, 43],\n \"2014\": [20, 38],\n@@ -2861,30 +2863,25 @@\n \"2025\": [26, 30, 32, 45],\n \"202e\": 37,\n \"203\": 6,\n \"205\": [6, 43],\n \"206e\": 37,\n \"207\": 45,\n \"208e\": 37,\n- \"20968\": 51,\n \"20995484\": 19,\n \"20b\": 19,\n \"20t00\": 37,\n \"21\": [8, 19, 35, 36, 37, 38, 40, 41, 43, 44, 45, 47, 48, 49, 51, 52, 53],\n \"210e\": 37,\n \"211\": [6, 8, 9, 10, 13, 32],\n \"212\": [6, 8, 9, 10, 13, 19, 32, 35, 47, 49],\n \"212112\": [19, 47],\n \"21211203\": [19, 35],\n \"213\": [6, 8, 9, 10, 13, 32],\n \"214\": [6, 8, 9, 10, 13, 32, 40],\n- \"2147440432\": 51,\n- \"2147469683\": 51,\n- \"2147483559\": 51,\n- \"2147483646\": 51,\n \"216\": [6, 7, 8, 9, 10, 11, 12, 13, 14],\n \"2161\": 6,\n \"21616663\": 14,\n \"2162\": 6,\n \"2163\": 6,\n \"2164\": 6,\n \"2165\": 6,\n@@ -2893,18 +2890,16 @@\n \"2174\": 36,\n \"218\": [6, 7, 8, 9, 10, 11, 12, 13],\n \"219\": [6, 7, 8, 9, 10, 11, 12, 13],\n \"2193\": 14,\n \"21t00\": 37,\n \"22\": [14, 19, 33, 35, 36, 37, 38, 40, 41, 43, 44, 45, 47, 48, 49, 51, 52, 53],\n \"220\": 43,\n- \"221\": 51,\n \"222\": [6, 7, 8, 9, 10, 11, 12, 13, 30, 32],\n \"22222222\": 36,\n- \"22316\": 51,\n \"224\": [6, 7, 8, 9, 10, 11, 12, 13, 30, 32],\n \"224e\": 37,\n \"225\": [6, 7, 8, 9, 10, 11, 12, 13, 30, 32],\n \"22546326\": 36,\n \"225e\": 51,\n \"226\": [6, 7, 8, 9, 10, 11, 12, 13, 30, 32],\n \"2262\": [18, 52, 53],\n@@ -2922,18 +2917,16 @@\n \"233\": [6, 7, 8, 9, 10, 11, 12, 13, 30, 32],\n \"2333\": 14,\n \"23333333\": 14,\n \"234\": [6, 7, 8, 9, 10, 11, 12, 13, 30, 32],\n \"234e\": 37,\n \"2355\": 43,\n \"236\": [6, 7, 8, 9, 10, 11, 12, 13, 30, 32],\n- \"23794\": 51,\n \"2380\": 54,\n \"23859177\": 36,\n- \"239\": 51,\n \"23991312\": 36,\n \"23kb\": 52,\n \"23t00\": 37,\n \"23t12\": 36,\n \"24\": [7, 14, 19, 35, 36, 37, 38, 40, 41, 43, 44, 45, 47, 48, 49, 50, 51, 52, 53],\n \"240\": [44, 48, 52],\n \"240b\": [37, 45],\n@@ -2947,32 +2940,29 @@\n \"245e\": 48,\n \"2467\": 37,\n \"248\": 36,\n \"2483\": 36,\n \"248b\": [19, 45],\n \"248e\": 37,\n \"2493\": 45,\n- \"24b\": [14, 19, 35, 36, 38, 40, 41, 43, 44, 47, 48, 49, 50, 51, 54],\n+ \"24b\": [14, 19, 35, 36, 38, 40, 41, 43, 44, 47, 48, 49, 50, 54],\n \"24h\": 54,\n \"24t00\": 37,\n \"25\": [7, 8, 14, 19, 35, 36, 37, 38, 40, 41, 43, 44, 45, 47, 48, 49, 50, 51, 52, 53],\n \"250\": [13, 48],\n \"2509\": 36,\n \"251\": 36,\n \"2515\": 36,\n \"25176289\": 14,\n \"253\": 38,\n- \"2547821043\": 51,\n \"255\": [13, 43, 45],\n \"2554\": 40,\n- \"2561\": 51,\n \"258\": [6, 7, 8, 9, 10, 11, 12, 13, 30, 32, 43],\n \"25828142\": 36,\n \"259\": [6, 7, 8, 9, 10, 11, 12, 13, 30, 32, 41, 44],\n- \"2592\": 51,\n \"25t00\": 37,\n \"26\": [14, 19, 35, 36, 37, 38, 40, 41, 43, 44, 45, 47, 48, 49, 51, 52, 53],\n \"260\": [6, 7, 8, 9, 10, 11, 12, 13, 30, 32, 43],\n \"26047600586578334\": 54,\n \"2605\": [38, 40],\n \"261\": [6, 7, 8, 9, 10, 11, 12, 13, 30, 32],\n \"261e\": 48,\n@@ -3006,14 +2996,15 @@\n \"275\": [6, 7, 8, 9, 10, 11, 12, 13, 30, 32, 43],\n \"276\": [6, 7, 8, 9, 10, 11, 12, 13, 30, 32],\n \"2762\": 19,\n \"27623202\": 19,\n \"2778\": 44,\n \"277e\": 37,\n \"278\": 44,\n+ \"27830\": 51,\n \"27861203\": 36,\n \"27910634\": 19,\n \"27980632\": 36,\n \"27t00\": 37,\n \"28\": [14, 19, 35, 36, 37, 38, 40, 41, 43, 44, 45, 48, 49, 51, 52, 53, 54],\n \"280\": 13,\n \"28099849\": 36,\n@@ -3045,15 +3036,14 @@\n \"29645358\": 36,\n \"296e\": 37,\n \"297e\": 48,\n \"29844148\": 36,\n \"29t00\": [14, 37],\n \"29t12\": 36,\n \"2d\": [19, 38, 43, 47, 48, 50, 53, 54],\n- \"2e\": 51,\n \"2ecc71\": 48,\n \"2kb\": [36, 52],\n \"2m\": 6,\n \"2mt\": 6,\n \"2nd\": [43, 48],\n \"2x\": 54,\n \"3\": [3, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 16, 18, 19, 24, 25, 26, 27, 30, 32, 33, 35, 36, 37, 38, 39, 40, 41, 43, 44, 45, 47, 48, 49, 50, 51, 52, 53],\n@@ -3073,26 +3063,31 @@\n \"306e\": 37,\n \"307\": [6, 26],\n \"3070\": 6,\n \"3071\": 6,\n \"3073\": 6,\n \"3074\": 6,\n \"307e\": 37,\n- \"308\": [6, 51],\n+ \"308\": 6,\n+ \"3083827208917602196\": 51,\n \"30852683\": 36,\n+ \"308j\": 51,\n \"309\": [6, 44],\n+ \"30b\": 51,\n \"30t00\": [14, 37, 52],\n \"30t1\": 52,\n \"30t12\": 52,\n \"30t18\": 52,\n \"30t21\": 52,\n \"31\": [14, 19, 35, 36, 37, 38, 40, 41, 43, 44, 45, 48, 49, 51, 52, 53],\n \"310\": 13,\n \"310409\": 14,\n \"31040942\": 14,\n+ \"311\": 51,\n+ \"311j\": 51,\n \"3151\": 6,\n \"3153\": 6,\n \"3154\": 6,\n \"3155\": 6,\n \"3157\": 6,\n \"3158\": 6,\n \"315e\": 37,\n@@ -3111,25 +3106,26 @@\n \"3226808\": 19,\n \"32269851\": 14,\n \"322e\": 37,\n \"3261\": 40,\n \"32618\": 45,\n \"326e\": 37,\n \"3297\": 41,\n- \"32b\": [19, 35, 36, 38, 40, 43, 44, 45, 48, 49, 50, 52, 54],\n+ \"32b\": [19, 35, 36, 38, 40, 43, 44, 45, 48, 49, 50, 51, 52, 54],\n \"33\": [14, 19, 35, 36, 38, 40, 41, 43, 44, 45, 48, 49, 51, 52, 54],\n \"331e\": 37,\n- \"333\": [49, 51],\n+ \"333\": 49,\n \"33326004\": 19,\n \"33333333\": 14,\n- \"333e\": [37, 51],\n+ \"333e\": 37,\n \"33419587\": 36,\n \"335\": [40, 53],\n \"3356\": 41,\n \"33584385\": 19,\n+ \"335e\": 51,\n \"336\": [38, 43, 54],\n \"3362\": 40,\n \"33622174433445307\": 54,\n \"337e\": 37,\n \"339\": 40,\n \"34\": [6, 7, 8, 9, 10, 11, 12, 13, 19, 35, 36, 38, 41, 43, 44, 45, 48, 49, 51, 53, 54],\n \"340\": 13,\n@@ -3147,23 +3143,25 @@\n \"34576404\": 14,\n \"346\": [14, 41],\n \"34723825\": 14,\n \"348\": 44,\n \"3498db\": 48,\n \"35\": [7, 14, 19, 35, 36, 38, 41, 43, 44, 45, 48, 49, 50, 51, 54],\n \"350e\": 48,\n+ \"351e\": 51,\n \"352\": [6, 54],\n \"35205353914802473\": 54,\n \"3521\": 43,\n \"354\": [6, 40],\n \"355\": 6,\n \"35677824\": 19,\n+ \"356e\": 51,\n \"357\": [6, 52],\n \"35793963\": 36,\n- \"357e\": 37,\n+ \"357e\": [37, 51],\n \"358\": [36, 52],\n \"358e\": 37,\n \"359\": [6, 38, 52],\n \"36\": [3, 19, 35, 36, 38, 41, 43, 44, 45, 48, 49, 51, 52, 54],\n \"360\": [45, 52],\n \"360_dai\": [45, 53, 54],\n \"361\": 52,\n@@ -3181,15 +3179,15 @@\n \"3652\": 52,\n \"365_dai\": 45,\n \"3667\": 44,\n \"366_dai\": 45,\n \"3684\": 40,\n \"368e\": 37,\n \"369\": 48,\n- \"36b\": [51, 54],\n+ \"36b\": 54,\n \"37\": [19, 35, 36, 38, 40, 41, 43, 44, 45, 48, 49, 51, 54],\n \"371\": 36,\n \"37271154\": 14,\n \"372712\": 14,\n \"373\": [38, 40, 43, 49, 54],\n \"37301222522143085\": 54,\n \"37342613\": 19,\n@@ -3216,15 +3214,14 @@\n \"388\": 6,\n \"3884\": [36, 52],\n \"3885\": 52,\n \"3886\": 52,\n \"3887\": 52,\n \"389\": 6,\n \"389e\": 45,\n- \"38j\": 51,\n \"39\": [6, 7, 8, 9, 10, 11, 12, 13, 14, 19, 35, 36, 38, 41, 43, 44, 45, 48, 49, 54],\n \"390\": 6,\n \"391\": 6,\n \"391e\": 37,\n \"392e\": 45,\n \"395\": [41, 43],\n \"395763\": 14,\n@@ -3239,19 +3236,17 @@\n \"3min\": 53,\n \"3rd\": 28,\n \"4\": [3, 6, 7, 8, 9, 11, 12, 13, 14, 16, 19, 25, 27, 30, 32, 33, 35, 36, 37, 38, 39, 40, 41, 43, 44, 45, 47, 49, 50, 51, 52, 53],\n \"40\": [19, 28, 35, 36, 38, 40, 41, 43, 44, 45, 48, 49, 50, 54],\n \"400\": [6, 48, 49],\n \"400e\": 48,\n \"401\": [6, 43],\n- \"401e\": 51,\n \"402\": 6,\n \"403\": 6,\n \"40324704\": 36,\n- \"403e\": 51,\n \"404\": [6, 43],\n \"405\": 43,\n \"406e\": 48,\n \"4074\": 41,\n \"407e\": 37,\n \"408\": 41,\n \"40824829\": 36,\n@@ -3279,55 +3274,56 @@\n \"423\": 48,\n \"424\": 38,\n \"42497233\": 19,\n \"425\": [19, 41],\n \"427\": 44,\n \"428\": 48,\n \"4281\": 36,\n+ \"429e\": 51,\n \"42b\": 36,\n- \"43\": [14, 19, 35, 36, 38, 41, 43, 44, 45, 48, 49, 54],\n+ \"43\": [14, 19, 35, 36, 38, 41, 43, 44, 45, 48, 49, 51, 54],\n \"4326\": 45,\n \"4333\": 44,\n \"439e\": 37,\n \"44\": [19, 35, 36, 38, 41, 43, 44, 45, 48, 49, 54],\n \"440e\": 48,\n \"441e\": 37,\n \"445e\": [37, 48],\n \"44785582\": 14,\n \"447856\": 14,\n \"4479968246859435\": 54,\n \"448\": [38, 40, 43, 49, 54],\n \"448b\": 43,\n \"448e\": 48,\n \"449\": 36,\n- \"45\": [3, 9, 13, 19, 36, 38, 40, 41, 43, 44, 45, 48, 49, 54],\n+ \"45\": [3, 9, 13, 19, 36, 38, 40, 41, 43, 44, 45, 48, 49, 51, 54],\n \"451\": [38, 43, 54],\n \"45137647047539964\": 54,\n \"4514\": 40,\n \"452\": 53,\n \"45209466\": 19,\n \"4521\": 37,\n \"453\": [40, 43],\n \"453e\": 48,\n \"4555\": 41,\n \"456060\": 14,\n \"456b\": 38,\n \"457e\": 52,\n \"458e\": 52,\n \"459e\": 52,\n- \"45j\": 51,\n \"46\": [19, 36, 38, 40, 41, 43, 44, 45, 48, 49, 54],\n \"46194319\": 36,\n \"462\": 43,\n \"46376911\": 14,\n \"46462434\": 19,\n \"464e\": 37,\n \"465e\": 37,\n \"466\": [38, 44],\n- \"467e\": [36, 37],\n+ \"466e\": 36,\n+ \"467e\": 37,\n \"46830462\": 36,\n \"469\": [45, 47, 49],\n \"4691\": [19, 35, 37, 47],\n \"469112\": [19, 47],\n \"4691123\": [19, 35],\n \"47\": [7, 19, 36, 38, 41, 43, 44, 45, 48, 49, 54],\n \"471\": 43,\n@@ -3348,30 +3344,31 @@\n \"485e\": 37,\n \"4867138\": 36,\n \"48671934\": 36,\n \"48672119\": 36,\n \"4875\": 36,\n \"487e\": 37,\n \"48b\": [19, 35, 36, 40, 43, 44, 47, 49, 51, 54],\n- \"48e0\": 45,\n \"49\": [19, 36, 38, 41, 43, 44, 45, 48, 49, 54],\n \"4909415\": 19,\n \"494929\": 47,\n \"49492927\": 19,\n \"49497537\": 19,\n \"495\": 47,\n \"495e\": 48,\n \"497\": [43, 44],\n \"499e\": 37,\n- \"4b\": [35, 43, 49, 51, 54],\n+ \"4b\": [35, 43, 49, 54],\n \"4d\": 48,\n+ \"4d49\": 45,\n \"4kb\": [48, 52],\n \"5\": [6, 7, 8, 9, 10, 11, 12, 13, 14, 16, 19, 25, 27, 30, 32, 35, 36, 37, 38, 39, 40, 41, 43, 44, 45, 47, 48, 49, 50, 51, 52, 53],\n \"50\": [7, 14, 19, 28, 32, 35, 36, 38, 40, 41, 43, 44, 45, 48, 49, 54],\n \"500\": [13, 45, 48, 54],\n+ \"500e\": 51,\n \"502\": 44,\n \"504\": 40,\n \"505\": 38,\n \"505e\": 48,\n \"506234\": 14,\n \"508\": 44,\n \"5081\": 30,\n@@ -3382,15 +3379,14 @@\n \"509e\": 37,\n \"51\": [6, 19, 36, 38, 41, 43, 44, 45, 48, 49, 54],\n \"510\": 32,\n \"511\": 32,\n \"511e\": 37,\n \"512e\": 48,\n \"5137\": 40,\n- \"51546\": 51,\n \"51565169\": 36,\n \"51565756\": 36,\n \"51565952\": 36,\n \"515e\": 37,\n \"51857326\": 36,\n \"519\": 6,\n \"5199731\": 19,\n@@ -3436,16 +3432,17 @@\n \"550e\": 37,\n \"551\": 38,\n \"552\": 41,\n \"552b\": 38,\n \"552e\": 37,\n \"553\": 41,\n \"556\": 44,\n- \"556e\": [36, 48],\n+ \"556e\": 48,\n \"55799171\": 14,\n+ \"557e\": 36,\n \"558073\": 14,\n \"55807323\": 14,\n \"56\": [3, 19, 36, 38, 41, 43, 44, 45, 48, 49, 54],\n \"5607\": 45,\n \"561\": 43,\n \"562\": 38,\n \"567\": 19,\n@@ -3472,18 +3469,17 @@\n \"59499\": 16,\n \"595e\": 37,\n \"596\": 43,\n \"596e\": 37,\n \"598e\": 37,\n \"5b\": [36, 43],\n \"5d\": 53,\n- \"5e\": 51,\n \"5kb\": 54,\n \"5x\": 54,\n- \"5\\u017f\\u00ff\\u017e\\u014f\": 51,\n+ \"5\\u017e\\u013e\\u00ee\\u00f6\": 51,\n \"6\": [3, 6, 7, 8, 9, 10, 11, 12, 13, 14, 19, 25, 27, 30, 32, 35, 36, 37, 38, 39, 40, 41, 43, 44, 45, 47, 48, 49, 50, 51, 52, 53],\n \"60\": [19, 36, 38, 41, 43, 44, 45, 48, 49, 52, 53, 54],\n \"600e\": 48,\n \"601\": [36, 38, 44],\n \"604\": 44,\n \"607\": [40, 44],\n \"609\": 40,\n@@ -3495,31 +3491,33 @@\n \"616e\": 37,\n \"617e\": 48,\n \"619e\": 48,\n \"62\": [19, 36, 38, 41, 43, 44, 45, 48, 54],\n \"621\": 45,\n \"622e\": 37,\n \"623e\": 37,\n- \"624e\": 37,\n+ \"624e\": [37, 51],\n \"625\": 45,\n \"625e\": 37,\n \"6285\": 41,\n \"62kb\": 36,\n \"63\": [3, 19, 36, 38, 41, 43, 44, 45, 48, 54],\n \"634\": 38,\n \"634e\": 37,\n \"635\": 44,\n \"63593435\": 14,\n \"63696169\": 36,\n \"638e\": 48,\n \"64\": [19, 36, 38, 41, 43, 44, 45, 48, 54],\n+ \"640e\": 51,\n \"642\": 43,\n \"645e\": 37,\n \"648b\": 38,\n- \"64b\": [35, 36, 40, 43, 49, 50, 51, 52],\n+ \"648e\": 51,\n+ \"64b\": [35, 36, 40, 43, 49, 50, 52],\n \"65\": [19, 36, 38, 41, 43, 45, 48, 54],\n \"650e\": 37,\n \"651e\": 37,\n \"6525\": 36,\n \"652e\": 37,\n \"653\": 38,\n \"65348932\": 36,\n@@ -3580,15 +3578,14 @@\n \"726\": [6, 40],\n \"72653812\": 36,\n \"726e\": 37,\n \"727\": 6,\n \"728\": [6, 52],\n \"729\": [6, 52],\n \"72b\": [35, 40, 43, 44],\n- \"72b0e4c9db73\": 45,\n \"73\": [6, 36, 38, 41, 43, 45, 48, 54],\n \"730\": [6, 52],\n \"73021329\": 36,\n \"73078492\": 14,\n \"731\": [6, 14, 52],\n \"731locat\": 14,\n \"732\": 6,\n@@ -3617,24 +3614,23 @@\n \"7523\": 36,\n \"753e\": 37,\n \"754\": 43,\n \"7544\": 36,\n \"754e\": [37, 48],\n \"7553\": 54,\n \"755e\": [37, 48],\n- \"756101856880953354\": 51,\n \"758e\": 37,\n \"759\": 43,\n \"76\": [36, 38, 41, 43, 45, 48, 54],\n \"762e\": 37,\n- \"765380011776258377\": 51,\n \"765e\": 37,\n- \"766e\": 37,\n+ \"766e\": [37, 51],\n \"767e\": 37,\n \"76b\": [19, 49],\n+ \"76ee\": 45,\n \"77\": [36, 38, 41, 43, 48, 54],\n \"771\": 45,\n \"77192982\": 14,\n \"772\": 45,\n \"773\": [44, 45],\n \"7733\": 36,\n \"774\": 45,\n@@ -3658,37 +3654,38 @@\n \"79\": [36, 38, 41, 43, 48, 54],\n \"790e\": 48,\n \"791\": 45,\n \"79119196\": 36,\n \"7917\": 45,\n \"792\": 45,\n \"797e\": 53,\n- \"798e\": [37, 51],\n+ \"798e\": 37,\n \"799e\": 36,\n- \"7c78\": 45,\n \"8\": [3, 6, 7, 8, 11, 12, 13, 14, 16, 18, 19, 25, 27, 30, 32, 35, 36, 37, 38, 39, 40, 41, 43, 44, 45, 47, 48, 49, 50, 51, 52, 53],\n \"80\": [36, 38, 41, 43, 48, 49, 54],\n \"800\": 30,\n \"800b\": [25, 36],\n \"800e\": 37,\n \"800mb\": 37,\n \"801\": 30,\n \"802\": 30,\n+ \"802e\": 51,\n \"803\": 30,\n \"804\": 30,\n \"805\": 44,\n \"80527925\": 14,\n \"805arrai\": 14,\n \"805xarrai\": 14,\n \"806\": 30,\n \"8075\": 36,\n \"808\": 30,\n \"8080\": 54,\n \"809\": 30,\n- \"80b\": [27, 30, 35, 36, 38, 41, 44, 48, 53],\n+ \"80b\": [27, 30, 35, 36, 38, 41, 44, 48, 51, 53],\n+ \"80f0ce670b67\": 45,\n \"81\": [3, 36, 38, 41, 43, 48, 54],\n \"811\": 44,\n \"812e\": 37,\n \"81327024\": 36,\n \"814\": 44,\n \"814e\": 37,\n \"81649658\": 16,\n@@ -3731,14 +3728,15 @@\n \"8568\": 41,\n \"857e\": 37,\n \"858e\": 53,\n \"8599\": 43,\n \"86\": [36, 37, 38, 41, 43, 48, 54],\n \"8601\": [53, 54],\n \"8602\": 41,\n+ \"860e\": 51,\n \"8618\": 35,\n \"86184896\": 19,\n \"861849\": 47,\n \"862\": [43, 47],\n \"862e\": [37, 48],\n \"863\": 44,\n \"86436763\": 19,\n@@ -3782,33 +3780,34 @@\n \"9\": [3, 6, 7, 8, 12, 14, 19, 25, 27, 30, 32, 33, 35, 36, 37, 38, 39, 40, 41, 43, 44, 45, 47, 48, 49, 50, 51, 52, 53],\n \"90\": [3, 12, 35, 36, 38, 41, 43, 48, 49, 54],\n \"900e\": 48,\n \"904e\": 48,\n \"905e\": 48,\n \"90680094\": 19,\n \"906e\": 48,\n- \"91\": [12, 36, 38, 41, 43, 48, 51, 54],\n+ \"91\": [12, 36, 38, 41, 43, 48, 54],\n \"911\": 44,\n \"912\": 44,\n \"91275558\": 36,\n \"912e\": 37,\n \"913e\": 37,\n \"915\": 38,\n \"915e\": 48,\n \"916\": 36,\n \"9167\": 45,\n \"917\": 45,\n \"92\": [7, 36, 38, 41, 43, 48, 54],\n \"921e\": 37,\n- \"9223372035077253998\": 51,\n- \"9223372036854723696\": 51,\n- \"9223372036854727701\": 51,\n- \"9223372036854737559\": 51,\n- \"9223372036854759933\": 51,\n- \"9223372036854775598\": 51,\n+ \"9223372033794027569\": 51,\n+ \"9223372036854727831\": 51,\n+ \"9223372036854734621\": 51,\n+ \"9223372036854746411\": 51,\n+ \"9223372036854754014\": 51,\n+ \"9223372036854775654\": 51,\n+ \"9223372036854775792\": 51,\n \"927\": 38,\n \"929e\": 37,\n \"93\": [6, 36, 38, 41, 43, 44, 48, 54],\n \"931542\": 14,\n \"93154201\": 14,\n \"93221199\": 14,\n \"933\": 36,\n@@ -3818,15 +3817,14 @@\n \"9363595\": 19,\n \"937\": 40,\n \"9399\": 36,\n \"94\": [6, 36, 38, 41, 43, 48, 54],\n \"942\": 43,\n \"944e\": [48, 53],\n \"947726688477\": 45,\n- \"948e\": 51,\n \"95\": [6, 9, 13, 36, 38, 41, 43, 48, 54],\n \"9516\": 14,\n \"9516129\": 14,\n \"953\": 38,\n \"9537291\": 36,\n \"953e\": 48,\n \"958\": 45,\n@@ -3870,14 +3868,15 @@\n \"99809483\": 19,\n \"9986\": 36,\n \"998e\": 37,\n \"999\": [36, 54],\n \"9999\": [36, 45],\n \"99kb\": 53,\n \"9b59b6\": 48,\n+ \"9dca\": 45,\n \"9kb\": [48, 54],\n \"A\": [3, 5, 6, 8, 19, 24, 27, 30, 33, 35, 36, 37, 38, 39, 41, 43, 45, 47, 48, 49, 50, 51, 52, 53, 54],\n \"AS\": 54,\n \"And\": [7, 19, 48, 53],\n \"As\": [12, 16, 24, 25, 32, 36, 37, 38, 40, 41, 43, 45, 47, 48, 49, 50, 53, 54],\n \"At\": [3, 16, 37, 38, 45, 54],\n \"Be\": 3,\n@@ -4335,17 +4334,17 @@\n \"ax3\": 13,\n \"ax4\": 13,\n \"axi\": [11, 16, 18, 19, 20, 22, 24, 30, 36, 37, 38, 39, 40, 41, 45, 47, 50, 51, 54],\n \"axisarrai\": 5,\n \"axisgrid\": 14,\n \"ayrton\": 54,\n \"azur\": 54,\n+ \"a\\u017c\\u0129\": 51,\n \"b\": [3, 19, 25, 35, 36, 37, 38, 40, 41, 43, 44, 47, 48, 49, 50, 51, 52, 54],\n \"b2\": [36, 54],\n- \"b4aa\": 45,\n \"ba\": 54,\n \"back\": [1, 8, 16, 19, 20, 26, 30, 31, 36, 37, 38, 39, 40, 41, 43, 45, 48, 49, 51, 54],\n \"backend\": [1, 5, 6, 16, 24, 29, 30, 31, 32, 33, 37, 38, 43, 45, 53, 54],\n \"backend_agg\": 6,\n \"backend_arrai\": 27,\n \"backend_bas\": 6,\n \"backend_kwarg\": [27, 45, 54],\n@@ -4415,15 +4414,14 @@\n \"bergemann\": 54,\n \"besid\": 54,\n \"best\": [21, 24, 36, 43, 54],\n \"better\": [16, 18, 29, 33, 37, 48, 54],\n \"between\": [3, 8, 14, 16, 24, 32, 33, 35, 36, 38, 39, 43, 44, 45, 47, 48, 50, 52, 53, 54],\n \"bewar\": 37,\n \"beyond\": [3, 16],\n- \"bfb46614\": 45,\n \"bfill\": [22, 24, 36, 39, 52, 54],\n \"bi\": 4,\n \"bibtex\": 16,\n \"big\": [3, 5, 25, 27, 37, 45, 54],\n \"biggest\": 54,\n \"bin\": [12, 19, 48, 52, 54],\n \"binari\": [5, 24, 31, 36, 38, 40, 41, 43, 45, 54],\n@@ -4543,14 +4541,15 @@\n \"by_coord\": [35, 54],\n \"byte\": [24, 45, 54],\n \"bytes_\": 54,\n \"bytes_io\": 6,\n \"bytestr\": 54,\n \"bzip2\": 45,\n \"c\": [3, 5, 7, 13, 16, 18, 19, 24, 29, 35, 36, 38, 40, 41, 43, 44, 45, 47, 48, 49, 50, 53, 54],\n+ \"c16\": 51,\n \"ca\": [43, 45],\n \"cabl\": 54,\n \"cach\": [6, 7, 8, 9, 10, 11, 12, 13, 26, 27, 30, 32, 33, 41, 43, 44, 45, 48, 49, 54],\n \"cache_dir\": [6, 7, 8, 9, 10, 11, 12, 13, 30, 32],\n \"cachedir\": 3,\n \"cachingfilemanag\": [27, 54],\n \"calcul\": [5, 9, 12, 15, 16, 36, 37, 41, 48, 50, 52, 54],\n@@ -4790,15 +4789,14 @@\n \"compet\": 37,\n \"compil\": [8, 20, 29, 36],\n \"complementari\": [47, 49],\n \"complet\": [3, 18, 19, 30, 33, 38, 41, 43, 45, 47, 50, 54],\n \"complevel\": [45, 54],\n \"complex\": [3, 16, 22, 26, 27, 30, 33, 36, 40, 41, 43, 47, 48, 51, 54],\n \"complex128\": 54,\n- \"complex64\": 51,\n \"complex_\": 54,\n \"complex_number_dtyp\": 51,\n \"compliant\": [5, 31, 45, 51, 54],\n \"complic\": [3, 49, 51],\n \"compon\": [5, 22, 41, 43, 48, 53],\n \"compos\": [41, 48],\n \"composit\": [6, 30, 31],\n@@ -5515,16 +5513,15 @@\n \"extract\": [22, 37, 38, 41, 43, 45, 49, 54],\n \"extractal\": 54,\n \"extrapol\": [44, 54],\n \"extrem\": [31, 43, 45, 48, 51],\n \"ey\": [25, 39],\n \"ezequiel\": 54,\n \"f\": [3, 6, 7, 8, 9, 10, 11, 12, 13, 19, 26, 30, 32, 36, 38, 41, 45, 48, 54],\n- \"f8\\u017c\\u010d\": 51,\n- \"fa\": 51,\n+ \"f76aeb1b\": 45,\n \"fabian\": 54,\n \"fabien\": 54,\n \"face\": [20, 30, 33],\n \"facecolor\": [6, 7, 48, 54],\n \"facet\": [49, 54],\n \"facetgrid\": 54,\n \"facilit\": [3, 8, 16, 20, 33, 36, 40, 45, 53, 54],\n@@ -5603,15 +5600,15 @@\n \"find_common_ancestor\": 41,\n \"findal\": 54,\n \"fine\": [3, 19, 45, 51],\n \"finer\": 54,\n \"finish\": [3, 54],\n \"finit\": [5, 12, 36, 54],\n \"firm\": 16,\n- \"first\": [3, 6, 7, 8, 9, 10, 11, 12, 13, 14, 18, 19, 24, 28, 30, 32, 33, 35, 36, 38, 41, 43, 44, 45, 48, 49, 52, 54],\n+ \"first\": [3, 8, 9, 11, 13, 14, 18, 19, 24, 28, 32, 33, 35, 36, 38, 41, 43, 44, 45, 48, 52, 54],\n \"fiscal\": [33, 54],\n \"fischer\": 54,\n \"fish\": 41,\n \"fit\": [16, 33, 37, 41, 45, 48, 54],\n \"fitzgerald\": [16, 54],\n \"five\": [36, 48, 54],\n \"fix\": [3, 8, 16, 37, 38, 45, 48, 50, 53],\n@@ -5627,15 +5624,15 @@\n \"flavor\": 3,\n \"fleischmann\": 54,\n \"fletcher32\": 45,\n \"flexibl\": [8, 16, 30, 31, 39, 40, 43, 44, 45, 48, 54],\n \"flip\": 54,\n \"float\": [8, 16, 26, 35, 36, 37, 40, 45, 50, 54],\n \"float16\": [51, 54],\n- \"float32\": [3, 45, 54],\n+ \"float32\": [3, 45, 51, 54],\n \"float64\": [8, 14, 16, 19, 25, 27, 32, 35, 36, 37, 38, 40, 41, 43, 44, 45, 47, 48, 49, 50, 51, 52, 54],\n \"float6412\": 14,\n \"float64nan\": 14,\n \"float_to_top\": 54,\n \"floor\": [22, 52, 53, 54],\n \"florian\": 54,\n \"flow\": [21, 38, 54],\n@@ -7157,15 +7154,15 @@\n \"instrument\": 38,\n \"insuffici\": 36,\n \"int\": [24, 36, 50, 51, 54],\n \"int16\": [3, 45, 51],\n \"int32\": [3, 54],\n \"int64\": [3, 14, 19, 35, 36, 37, 38, 40, 41, 43, 44, 45, 47, 48, 49, 50, 52, 53, 54],\n \"int641\": 14,\n- \"int8\": 3,\n+ \"int8\": [3, 51],\n \"intact\": 54,\n \"intarr\": 36,\n \"integ\": [19, 20, 24, 27, 30, 36, 38, 43, 45, 51, 54],\n \"integr\": [5, 16, 18, 20, 27, 33, 36, 37, 39, 45, 48, 50, 52, 54],\n \"intend\": [3, 19, 25, 29, 30, 38, 41, 54],\n \"intens\": 45,\n \"intent\": [26, 39, 41],\n@@ -7308,14 +7305,15 @@\n \"jun\": 53,\n \"junip\": 54,\n \"jupyt\": 54,\n \"jupyterbook\": 45,\n \"just\": [3, 7, 11, 19, 20, 24, 25, 28, 30, 33, 38, 39, 41, 43, 45, 48, 49, 50, 51, 53, 54],\n \"justu\": 54,\n \"jwen\": 54,\n+ \"j\\u00e3\\u017f\\u017e\\u0103\": 51,\n \"j\\u00f6rdene\": 54,\n \"k\": [3, 7, 13, 20, 24, 28, 44, 54],\n \"kai\": 54,\n \"kanma\": 54,\n \"karasiak\": 54,\n \"karel\": 54,\n \"karl\": 54,\n@@ -7509,14 +7507,15 @@\n \"lt\": [6, 14],\n \"luka\": 54,\n \"luke\": 54,\n \"lurcock\": 54,\n \"lusewel\": 54,\n \"lxml\": 54,\n \"lzf\": 54,\n+ \"l\\u00e6\": 51,\n \"m\": [3, 6, 8, 14, 18, 24, 37, 47, 52, 53, 54],\n \"ma\": 54,\n \"maahn\": 54,\n \"machin\": [3, 18, 37, 49, 54],\n \"machineri\": [32, 52, 54],\n \"maciek\": 54,\n \"maco\": [3, 54],\n@@ -7960,15 +7959,15 @@\n \"numfocu\": 54,\n \"numpi\": [1, 3, 7, 8, 9, 10, 11, 12, 14, 16, 18, 19, 20, 22, 24, 25, 27, 28, 29, 30, 31, 33, 35, 36, 37, 38, 43, 44, 45, 47, 48, 49, 50, 51, 52, 54],\n \"numpy_experimental_array_funct\": 54,\n \"numpyindexingadapt\": 54,\n \"nx\": 40,\n \"nxarrai\": 5,\n \"ny\": 40,\n- \"o\": [6, 7, 8, 9, 10, 11, 12, 13, 18, 24, 27, 30, 32, 44, 47, 48, 54],\n+ \"o\": [6, 7, 8, 9, 10, 11, 12, 13, 18, 24, 27, 30, 32, 44, 47, 48, 51, 54],\n \"obei\": 25,\n \"obj\": [6, 22, 24, 37],\n \"object\": [3, 5, 8, 14, 16, 18, 19, 20, 22, 24, 25, 26, 27, 28, 31, 32, 33, 35, 36, 37, 38, 41, 43, 44, 45, 47, 49, 50, 51, 52, 53, 54],\n \"oblivi\": 54,\n \"observ\": [5, 14, 31, 33, 36, 41, 47, 48, 54],\n \"obsolet\": 54,\n \"obtain\": [44, 54],\n@@ -9520,15 +9519,15 @@\n \"seamlessli\": [3, 39],\n \"search\": [3, 45, 52],\n \"searchstrategi\": 51,\n \"season\": [14, 15, 40, 52, 53, 54],\n \"season_mean\": 11,\n \"sebastian\": 54,\n \"sec\": 19,\n- \"second\": [3, 8, 13, 19, 27, 32, 35, 38, 39, 43, 45, 47, 52, 53, 54],\n+ \"second\": [3, 6, 7, 8, 9, 10, 11, 12, 13, 19, 27, 30, 32, 35, 38, 39, 41, 43, 44, 45, 47, 48, 49, 52, 53, 54],\n \"section\": [5, 7, 16, 18, 29, 30, 33, 37, 40, 45, 47, 48, 50, 51, 52, 53, 54],\n \"see\": [1, 3, 5, 7, 8, 13, 16, 18, 19, 20, 22, 24, 25, 26, 27, 30, 31, 32, 33, 35, 36, 37, 38, 39, 40, 41, 43, 44, 45, 47, 48, 49, 50, 51, 52, 53, 54],\n \"seed\": [14, 38, 48],\n \"seek\": 27,\n \"seem\": [7, 8, 48, 54],\n \"seen\": [36, 40, 51],\n \"segment\": 54,\n@@ -10048,15 +10047,15 @@\n \"tim\": 54,\n \"time\": [1, 3, 5, 6, 7, 8, 9, 10, 12, 13, 14, 16, 18, 20, 22, 27, 30, 32, 33, 35, 36, 37, 38, 40, 41, 43, 44, 47, 48, 49, 50, 51, 53, 54],\n \"time_stamp\": 41,\n \"time_stamps1\": 41,\n \"time_stamps2\": 41,\n \"time_subset\": 37,\n \"timedelta\": [1, 48, 52, 54],\n- \"timedelta64\": [45, 51, 52, 53, 54],\n+ \"timedelta64\": [45, 52, 53, 54],\n \"timedeltaaccessor\": 54,\n \"timedeltaindex\": 54,\n \"timegroup\": 54,\n \"timelin\": 41,\n \"timeout\": 18,\n \"timepandasindexpandasindex\": 14,\n \"timeresampl\": [37, 40, 54],\n@@ -10123,14 +10122,15 @@\n \"topic\": [3, 5, 51, 54],\n \"topo\": 5,\n \"topograph\": 5,\n \"total\": [30, 37, 40, 41, 43, 52, 54],\n \"total_second\": 54,\n \"touch\": [3, 45],\n \"toward\": [9, 21, 54],\n+ \"tr\": 51,\n \"traceback\": [6, 7, 8, 9, 10, 11, 12, 13, 25, 26, 30, 32],\n \"track\": [3, 16, 19, 20, 31, 33, 36, 39, 54],\n \"tracker\": [3, 18, 24, 25, 39],\n \"trajectori\": 5,\n \"transfer\": [45, 48, 50],\n \"transform\": [5, 6, 7, 9, 12, 13, 27, 31, 45, 48, 54],\n \"transform_func\": 45,\n@@ -10187,26 +10187,27 @@\n \"typeerror\": [27, 54],\n \"typehint\": 54,\n \"typic\": [3, 7, 14, 16, 30, 33, 37, 45, 50],\n \"typing_extens\": 54,\n \"typo\": [3, 23, 54],\n \"tyre\": 54,\n \"u\": [3, 8, 12, 19, 21, 24, 26, 31, 33, 41, 43, 44, 45, 48, 49, 54],\n- \"u000fb3d5\": 51,\n+ \"u0009ff28\": 51,\n+ \"u000b0bbd\": 51,\n \"u1\": [19, 35, 36, 38, 40, 43, 44, 45, 47, 49, 54],\n \"u2\": [14, 36, 38, 43],\n \"u3\": [52, 53, 54],\n- \"u4\": [51, 54],\n+ \"u4\": 54,\n \"u5\": [19, 48],\n \"u6\": [38, 41],\n \"u7\": [36, 38],\n \"u8\": [36, 38],\n \"ubiqu\": 16,\n \"ufunc\": [1, 8, 24, 36, 37, 39, 54],\n- \"uint8\": [39, 45, 51],\n+ \"uint8\": [39, 45],\n \"uk\": [6, 16, 45],\n \"ulrich\": 54,\n \"ultim\": 24,\n \"unabl\": [16, 37],\n \"unaddress\": 54,\n \"unalign\": [19, 41],\n \"unambigu\": [38, 54],\n@@ -10316,15 +10317,14 @@\n \"usr\": [6, 7, 8, 9, 10, 11, 12, 13, 30, 32],\n \"usual\": [3, 16, 20, 27, 36, 37, 40, 43, 45, 49, 50, 54],\n \"utf\": 45,\n \"util\": [3, 5, 6, 7, 8, 9, 10, 11, 12, 13, 20, 30, 32, 33, 45, 54],\n \"utilis\": 52,\n \"uw\": 34,\n \"uxarrai\": 26,\n- \"u\\u017e\\u00e2\": 51,\n \"v\": [3, 8, 13, 16, 18, 28, 38, 41, 48, 49, 50],\n \"v0\": [16, 38, 43, 49],\n \"v1\": [36, 48, 54],\n \"v2\": 54,\n \"v2022\": 28,\n \"v3\": [45, 54],\n \"vacant\": 35,\n@@ -10526,31 +10526,39 @@\n \"write_inherited_coord\": 54,\n \"written\": [3, 18, 24, 29, 36, 37, 38, 45, 51, 54],\n \"wrong\": [3, 54],\n \"wrongli\": 54,\n \"wrote\": 35,\n \"www\": [7, 18],\n \"x\": [3, 5, 7, 8, 12, 13, 14, 18, 19, 20, 24, 25, 27, 28, 30, 35, 36, 37, 38, 39, 40, 41, 43, 44, 45, 47, 49, 50, 51, 53, 54],\n+ \"x03\": 51,\n+ \"x08\": 51,\n \"x0pahjgysxk\": 18,\n \"x1\": 35,\n+ \"x10q\": 51,\n+ \"x1f\": 51,\n \"x2\": [35, 39],\n \"x27\": 14,\n \"x64\": 54,\n+ \"x85\": 51,\n+ \"x8e\": 51,\n+ \"x9e\": 51,\n \"x_and_i\": 36,\n \"x_bin\": 40,\n \"x_bin_label\": 40,\n \"x_chunk\": 24,\n \"x_coars\": 49,\n \"x_fine\": 49,\n \"x_matrix_rank\": 36,\n \"x_onli\": 36,\n \"x_rank\": 37,\n \"x_singular_valu\": 36,\n \"x_win\": 36,\n- \"xa3h\": 51,\n+ \"xa1ep\": 51,\n+ \"xa2\": 51,\n \"xalpha\": 36,\n \"xalpha1\": 36,\n \"xarrai\": [1, 4, 6, 8, 9, 10, 11, 12, 13, 14, 15, 17, 19, 21, 22, 24, 25, 27, 28, 30, 32, 33, 34, 35, 36, 38, 40, 41, 42, 43, 44, 45, 46, 48, 49, 50, 51, 52, 53, 54],\n \"xarray_einstat\": 5,\n \"xarray_extra\": [5, 45],\n \"xarray_obj\": 26,\n \"xarray_object\": 8,\n@@ -10559,20 +10567,29 @@\n \"xbatcher\": 5,\n \"xbpch\": 5,\n \"xc\": [12, 36, 45],\n \"xc0\": 36,\n \"xcdat\": [5, 54],\n \"xclim\": 5,\n \"xd\": 37,\n+ \"xd23\": 51,\n+ \"xd4f\": 51,\n+ \"xdd\": 51,\n \"xdev\": 34,\n \"xdist\": [3, 18, 54],\n+ \"xe0\": 51,\n+ \"xe1\": 51,\n+ \"xe9\": 51,\n+ \"xed\": 51,\n \"xenomorph\": 41,\n \"xeof\": 5,\n \"xesmf\": [5, 12],\n+ \"xf2\": 51,\n \"xfail\": [3, 54],\n+ \"xfe\": 51,\n \"xframe\": 5,\n \"xgcm\": [5, 7],\n \"xi\": 8,\n \"xi_rho\": 7,\n \"xianxiang\": 54,\n \"xin\": 54,\n \"xincreas\": [48, 54],\n@@ -10597,15 +10614,14 @@\n \"xtick\": [48, 54],\n \"xtrude\": 5,\n \"xx\": 36,\n \"xxxx\": 3,\n \"xy_index\": 28,\n \"xyz\": 38,\n \"xyzpi\": 5,\n- \"x\\u00f2\\u016f\\u016f\": 51,\n \"y\": [7, 11, 12, 18, 19, 20, 24, 25, 28, 35, 36, 37, 38, 40, 41, 43, 44, 45, 47, 49, 50, 51, 53, 54],\n \"y_coars\": 49,\n \"y_fine\": 49,\n \"y_rank\": 37,\n \"y_win\": 36,\n \"yai\": 8,\n \"yalpha\": 36,\n@@ -10672,56 +10688,52 @@\n \"zmetadata\": [32, 45],\n \"zo_rho\": 7,\n \"zonal\": [5, 37, 48],\n \"zoom\": 4,\n \"zstd\": 45,\n \"zuckerberg\": 54,\n \"z\\u00fchlke\": 54,\n- \"\\u00b2\": 51,\n- \"\\u00bc\\u0121\\u00e3\\u017e\\u017c\": 51,\n- \"\\u00e7\": 51,\n- \"\\u00e7\\u0115\\u012d\\u00fc\\u0131\": 51,\n- \"\\u00e9\": 51,\n- \"\\u00ea\": 51,\n- \"\\u00ef\\u0135\\u017fec\": 51,\n- \"\\u00ef\\u0144\\u00ec\\u0111\\u011d\": 51,\n- \"\\u00f5\": 51,\n- \"\\u00f6\": 51,\n- \"\\u00f91\": 51,\n- \"\\u00fc\": 51,\n- \"\\u00fdb\\u017c\": 51,\n- \"\\u00ff\\u017f\\u00be\\u017e\\u0148\": 51,\n- \"\\u0107\\u00f8\\u00f8w\\u00e3\": 51,\n- \"\\u010f\": 51,\n- \"\\u0115\": 51,\n- \"\\u0123\\u010f\\u00eb\": 51,\n- \"\\u0125\": 51,\n- \"\\u012d\\u017e\\u017e\\u00e1\\u017c\": 51,\n- \"\\u0137\": 51,\n- \"\\u0137\\u017f\\u0153\\u00f6\\u017f\": 51,\n- \"\\u0142\\u0101\\u017e\\u0115\\u0165\": 51,\n- \"\\u0142\\u0135\\u017eoe\": 51,\n- \"\\u0157\\u0121\\u00e7\\u00ebu\": 51,\n- \"\\u0161\\u017e\": 51,\n- \"\\u0165\\u00e3u\": 51,\n- \"\\u0167\": 51,\n- \"\\u0169\": 51,\n- \"\\u0169e\": 51,\n- \"\\u016b\\u00e7\\u0135\\u017c\\u017f\": 51,\n+ \"\\u00e0\\u00b2\": 51,\n+ \"\\u00e1\\u0148\": 51,\n+ \"\\u00e2\\u00f2\": 51,\n+ \"\\u00e3\": 51,\n+ \"\\u00e8h\\u0157\\u017c\": 51,\n+ \"\\u00eeb\": 51,\n+ \"\\u00eem\": 51,\n+ \"\\u00f3\": 51,\n+ \"\\u00fa\\u013e\\u00e48\\u017f\": 51,\n+ \"\\u00fc\\u00be\": 51,\n+ \"\\u00fd\": 51,\n+ \"\\u0101\\u00f0l\\u0140\\u0146\": 51,\n+ \"\\u0105\\u0113\\u017e\\u00eb\\u017f\": 51,\n+ \"\\u0115\\u0109\\u00fc\\u00f3\\u017f\": 51,\n+ \"\\u011f\\u013e\\u01031\": 51,\n+ \"\\u013a\\u0175\\u013c\": 51,\n+ \"\\u013e\\u00ff\\u017f\": 51,\n+ \"\\u0148\\u014b\\u017ei\\u00f0\": 51,\n+ \"\\u0148\\u017e\\u0105\": 51,\n+ \"\\u0151\": 51,\n+ \"\\u0155\": 51,\n+ \"\\u0155\\u0117a\\u0129n\": 51,\n+ \"\\u0155\\u017c\": 51,\n+ \"\\u015f\\u0117\": 51,\n+ \"\\u0167\\u010b\\u00b20\": 51,\n+ \"\\u0169b\": 51,\n+ \"\\u016bq\\u017f\\u00e7\\u015b\": 51,\n \"\\u016f\": 51,\n- \"\\u0173\\u0109\\u011b\\u00f2\\u00e9\": 51,\n- \"\\u0177\": 51,\n- \"\\u017c\": 51,\n- \"\\u017ct\\u0137a\\u017c\": 51,\n- \"\\u017c\\u0127\": 51,\n- \"\\u017c\\u01518\\u010d\": 51,\n- \"\\u017c\\u017c\\u00b9\": 51,\n- \"\\u017ev\": 51,\n- \"\\u017e\\u00f2\\u017f\\u017cv\": 51,\n- \"\\u017e\\u0148\\u00f0\\u0105\\u017c\": 51\n+ \"\\u0173\\u00ef\\u011f\\u016f\\u010f\": 51,\n+ \"\\u0173\\u0109\\u0113\\u017e\\u017c\": 51,\n+ \"\\u0173\\u0169\\u017e\\u00ee\": 51,\n+ \"\\u0175\\u010d\\u00f0\\u0149\\u017c\": 51,\n+ \"\\u017c9\\u012fc\\u00f4\": 51,\n+ \"\\u017e\": 51,\n+ \"\\u017fi\\u0307\\u0169\\u00bda\": 51,\n+ \"\\u017fxa\\u00e7\\u017c\": 51,\n+ \"\\u017f\\u00e7\\u0107\\u0107\\u0175\": 51,\n+ \"\\u017f\\u017c\": 51\n },\n \"titles\": [\"xarray\", \"API reference\", \"<no title>\", \"Contributing to xarray\", \"Developers meeting\", \"Xarray related projects\", \"GRIB Data Example\", \"ROMS Ocean Model Example\", \"Applying unvectorized functions with apply_ufunc\", \"Compare weighted and unweighted mean temperature\", \"Blank template\", \"Calculating Seasonal Averages from Time Series of Monthly Means\", \"Working with Multidimensional Coordinates\", \"Visualization Gallery\", \"Toy weather data\", \"Gallery\", \"Frequently Asked Questions\", \"Getting Started\", \"Installation\", \"Quick overview\", \"Overview: Why xarray?\", \"Getting Help\", \"How do I \\u2026\", \"Xarray documentation\", \"Alternative chunked array types\", \"Integrating with duck arrays\", \"Extending xarray using accessors\", \"How to add a new backend\", \"How to create a custom index\", \"Xarray Internals\", \"Internal Design\", \"Interoperability of Xarray\", \"Zarr Encoding Specification\", \"Development roadmap\", \"Tutorials and Videos\", \"Combining data\", \"Computation\", \"Parallel Computing with Dask\", \"Data Structures\", \"Working with numpy-like arrays\", \"GroupBy: Group and Bin Data\", \"Hierarchical data\", \"User Guide\", \"Indexing and selecting data\", \"Interpolating data\", \"Reading and writing files\", \"Configuration\", \"Working with pandas\", \"Plotting\", \"Reshaping and reorganizing data\", \"Terminology\", \"Testing your code\", \"Time series data\", \"Weather and climate data\", \"What\\u2019s New\"],\n \"titleterms\": {\n \"\": [13, 54],\n \"0\": 54,\n \"01\": 54,\n \"02\": 54,\n"}]}, {"source1": "./usr/share/doc/python-xarray-doc/html/user-guide/computation.html", "source2": "./usr/share/doc/python-xarray-doc/html/user-guide/computation.html", "unified_diff": "@@ -879,15 +879,15 @@\n * param (param) <U2 16B 'a' 'xc'\n * cov_i (cov_i) <U2 16B 'a' 'xc'\n * cov_j (cov_j) <U2 16B 'a' 'xc'\n Data variables:\n var2_curvefit_coefficients (x, param) float64 2kB 3.0 -5.0 3.0 ... 3.0 4.9\n var2_curvefit_covariance (x, cov_i, cov_j) float64 3kB 9.286e-14 ... 1...\n var3_curvefit_coefficients (x, param) float64 2kB 0.9999 5.0 ... 1.0 -4.9\n- var3_curvefit_covariance (x, cov_i, cov_j) float64 3kB 5.825e-11 ... 1...\n+ var3_curvefit_covariance (x, cov_i, cov_j) float64 3kB 5.825e-11 ... 8...\n \n \n

    We can also fit multi-dimensional functions, and even use a wrapper function to\n simultaneously fit a summation of several functions, such as this field containing\n two gaussian peaks:

    \n
    In [102]: def gaussian_2d(coords, a, xc, yc, xalpha, yalpha):\n    .....:     x, y = coords\n@@ -935,15 +935,15 @@\n Dimensions:                (param: 10, cov_i: 10, cov_j: 10)\n Coordinates:\n   * param                  (param) <U7 280B 'a0' 'xc0' ... 'xalpha1' 'yalpha1'\n   * cov_i                  (cov_i) <U7 280B 'a0' 'xc0' ... 'xalpha1' 'yalpha1'\n   * cov_j                  (cov_j) <U7 280B 'a0' 'xc0' ... 'xalpha1' 'yalpha1'\n Data variables:\n     curvefit_coefficients  (param) float64 80B 1.994 -0.9986 ... 1.999 0.9986\n-    curvefit_covariance    (cov_i, cov_j) float64 800B 6.556e-05 ... 4.467e-06\n+    curvefit_covariance    (cov_i, cov_j) float64 800B 6.557e-05 ... 4.466e-06\n 
    \n
    \n
    \n

    Note

    \n

    This method replicates the behavior of scipy.optimize.curve_fit().

    \n
    \n
    \n", "details": [{"source1": "html2text {}", "source2": "html2text {}", "unified_diff": "@@ -721,15 +721,15 @@\n * cov_j (cov_j) ds.pipe(func)) instead of\n simply calling it (e.g., func(ds)). This allows you to write pipelines for\n transforming your data (using \u201cmethod chaining\u201d) instead of writing hard to\n follow nested function calls:

    \n
    # these lines are equivalent, but with pipe we can make the logic flow\n # entirely from left to right\n In [64]: plt.plot((2 * ds.temperature.sel(loc=0)).mean("instrument"))\n-Out[64]: [<matplotlib.lines.Line2D at 0x7f939a5a2c10>]\n+Out[64]: [<matplotlib.lines.Line2D at 0x7f39369a6d50>]\n \n In [65]: (ds.temperature.sel(loc=0).pipe(lambda x: 2 * x).mean("instrument").pipe(plt.plot))\n-Out[65]: [<matplotlib.lines.Line2D at 0x7f939a5a2ad0>]\n+Out[65]: [<matplotlib.lines.Line2D at 0x7f39369a6c10>]\n 
    \n
    \n

    Both pipe and assign replicate the pandas methods of the same names\n (DataFrame.pipe and\n DataFrame.assign).

    \n

    With xarray, there is no performance penalty for creating new datasets, even if\n variables are lazily loaded from a file on disk. Creating new objects instead\n", "details": [{"source1": "html2text {}", "source2": "html2text {}", "unified_diff": "@@ -585,19 +585,19 @@\n There is also the pipe() method that allows you to use a method call with an\n external function (e.g., ds.pipe(func)) instead of simply calling it (e.g.,\n func(ds)). This allows you to write pipelines for transforming your data (using\n \u201cmethod chaining\u201d) instead of writing hard to follow nested function calls:\n # these lines are equivalent, but with pipe we can make the logic flow\n # entirely from left to right\n In [64]: plt.plot((2 * ds.temperature.sel(loc=0)).mean(\"instrument\"))\n-Out[64]: []\n+Out[64]: []\n \n In [65]: (ds.temperature.sel(loc=0).pipe(lambda x: 2 * x).mean\n (\"instrument\").pipe(plt.plot))\n-Out[65]: []\n+Out[65]: []\n Both pipe and assign replicate the pandas methods of the same names\n (_\bD_\ba_\bt_\ba_\bF_\br_\ba_\bm_\be_\b._\bp_\bi_\bp_\be and _\bD_\ba_\bt_\ba_\bF_\br_\ba_\bm_\be_\b._\ba_\bs_\bs_\bi_\bg_\bn).\n With xarray, there is no performance penalty for creating new datasets, even if\n variables are lazily loaded from a file on disk. Creating new objects instead\n of mutating existing objects often results in easier to understand code, so we\n encourage using this approach.\n *\b**\b**\b**\b* R\bRe\ben\bna\bam\bmi\bin\bng\bg v\bva\bar\bri\bia\bab\bbl\ble\bes\bs_\b?\b\u00b6 *\b**\b**\b**\b*\n"}]}, {"source1": "./usr/share/doc/python-xarray-doc/html/user-guide/hierarchical-data.html", "source2": "./usr/share/doc/python-xarray-doc/html/user-guide/hierarchical-data.html", "unified_diff": "@@ -982,15 +982,15 @@\n

    If you were a previous user of the prototype xarray-contrib/datatree package, this is different from what you\u2019re used to!\n In that package the data model was that the data stored in each node actually was completely unrelated. The data model is now slightly stricter.\n This allows us to provide features like Coordinate Inheritance.

    \n \n

    To demonstrate, let\u2019s first generate some example datasets which are not aligned with one another:

    \n
    # (drop the attributes just to make the printed representation shorter)\n In [89]: ds = xr.tutorial.open_dataset("air_temperature").drop_attrs()\n-PermissionError: [Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/first-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\n+PermissionError: [Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/second-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\n \n \n In [90]: ds_daily = ds.resample(time="D").mean("time")\n KeyError: "No variable named 'time'. Variables on the dataset include ['foo', 'x', 'letters']"\n \n \n In [91]: ds_weekly = ds.resample(time="W").mean("time")\n@@ -1054,15 +1054,15 @@\n     \u2514\u2500\u2500 Group: /b/B\n 
    \n
    \n

    Now we have a valid DataTree structure which contains all the data at each different time frequency, stored in a separate group.

    \n

    This is a useful way to organise our data because we can still operate on all the groups at once.\n For example we can extract all three timeseries at a specific lat-lon location:

    \n
    In [100]: dt.sel(lat=75, lon=300)\n-ValueError: Dimensions {'lon', 'lat'} do not exist. Expected one or more of set()\n+ValueError: Dimensions {'lat', 'lon'} do not exist. Expected one or more of set()\n 
    \n
    \n

    or compute the standard deviation of each timeseries to find out how it varies with sampling frequency:

    \n
    In [101]: dt.std(dim="time")\n ValueError: Dimension(s) 'time' do not exist. Expected one or more of set()\n 
    \n
    \n@@ -1128,15 +1128,15 @@\n
    In [107]: print(dt["/daily"])\n KeyError: 'Could not find node at /daily'\n 
    \n
    \n

    This helps to differentiate which variables are defined on the datatree node that you are currently looking at, and which were defined somewhere above it.

    \n

    We can also still perform all the same operations on the whole tree:

    \n
    In [108]: dt.sel(lat=[75], lon=[300])\n-ValueError: Dimensions {'lon', 'lat'} do not exist. Expected one or more of set()\n+ValueError: Dimensions {'lat', 'lon'} do not exist. Expected one or more of set()\n \n \n In [109]: dt.std(dim="time")\n ValueError: Dimension(s) 'time' do not exist. Expected one or more of set()\n 
    \n
    \n
    \n", "details": [{"source1": "html2text {}", "source2": "html2text {}", "unified_diff": "@@ -868,15 +868,15 @@\n model is now slightly stricter. This allows us to provide features like\n _\bC_\bo_\bo_\br_\bd_\bi_\bn_\ba_\bt_\be_\b _\bI_\bn_\bh_\be_\br_\bi_\bt_\ba_\bn_\bc_\be.\n To demonstrate, let\u2019s first generate some example datasets which are not\n aligned with one another:\n # (drop the attributes just to make the printed representation shorter)\n In [89]: ds = xr.tutorial.open_dataset(\"air_temperature\").drop_attrs()\n PermissionError: [Errno 13] Permission denied: '/nonexistent' | Pooch could not\n-create data cache folder '/nonexistent/first-build/.cache/\n+create data cache folder '/nonexistent/second-build/.cache/\n xarray_tutorial_data'. Will not be able to download data files.\n \n \n In [90]: ds_daily = ds.resample(time=\"D\").mean(\"time\")\n KeyError: \"No variable named 'time'. Variables on the dataset include ['foo',\n 'x', 'letters']\"\n \n@@ -944,15 +944,15 @@\n \u2514\u2500\u2500 Group: /b/B\n Now we have a valid DataTree structure which contains all the data at each\n different time frequency, stored in a separate group.\n This is a useful way to organise our data because we can still operate on all\n the groups at once. For example we can extract all three timeseries at a\n specific lat-lon location:\n In [100]: dt.sel(lat=75, lon=300)\n-ValueError: Dimensions {'lon', 'lat'} do not exist. Expected one or more of set\n+ValueError: Dimensions {'lat', 'lon'} do not exist. Expected one or more of set\n ()\n or compute the standard deviation of each timeseries to find out how it varies\n with sampling frequency:\n In [101]: dt.std(dim=\"time\")\n ValueError: Dimension(s) 'time' do not exist. Expected one or more of set()\n *\b**\b**\b**\b* C\bCo\boo\bor\brd\bdi\bin\bna\bat\bte\be I\bIn\bnh\bhe\ber\bri\bit\bta\ban\bnc\bce\be_\b?\b\u00b6 *\b**\b**\b**\b*\n Notice that in the trees we constructed above there is some redundancy - the\n@@ -1016,15 +1016,15 @@\n coordinates, but explicitly mark them as such:\n In [107]: print(dt[\"/daily\"])\n KeyError: 'Could not find node at /daily'\n This helps to differentiate which variables are defined on the datatree node\n that you are currently looking at, and which were defined somewhere above it.\n We can also still perform all the same operations on the whole tree:\n In [108]: dt.sel(lat=[75], lon=[300])\n-ValueError: Dimensions {'lon', 'lat'} do not exist. Expected one or more of set\n+ValueError: Dimensions {'lat', 'lon'} do not exist. Expected one or more of set\n ()\n \n \n In [109]: dt.std(dim=\"time\")\n ValueError: Dimension(s) 'time' do not exist. Expected one or more of set()\n _\b[_\bL_\bo_\bg_\bo_\b _\bo_\bf_\b _\bx_\ba_\br_\br_\ba_\by_\b]\n *\b**\b**\b**\b**\b**\b* _\bx\bx_\ba\ba_\br\br_\br\br_\ba\ba_\by\by *\b**\b**\b**\b**\b**\b*\n"}]}, {"source1": "./usr/share/doc/python-xarray-doc/html/user-guide/indexing.html", "source2": "./usr/share/doc/python-xarray-doc/html/user-guide/indexing.html", "unified_diff": "@@ -653,15 +653,15 @@\n to a collection specified weather station latitudes and longitudes.\n To trigger vectorized indexing behavior\n you will need to provide the selection dimensions with a new\n shared output dimension name. In the example below, the selections\n of the closest latitude and longitude are renamed to an output\n dimension named \u201cpoints\u201d:

    \n
    In [52]: ds = xr.tutorial.open_dataset("air_temperature")\n-PermissionError: [Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/first-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\n+PermissionError: [Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/second-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\n \n \n # Define target latitude and longitude (where weather stations might be)\n In [53]: target_lon = xr.DataArray([200, 201, 202, 205], dims="points")\n \n In [54]: target_lat = xr.DataArray([31, 41, 42, 42], dims="points")\n \n@@ -697,15 +697,15 @@\n 
    \n
    \n
    \n

    Assigning values with indexing\u00b6

    \n

    To select and assign values to a portion of a DataArray() you\n can use indexing with .loc :

    \n
    In [57]: ds = xr.tutorial.open_dataset("air_temperature")\n-PermissionError: [Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/first-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\n+PermissionError: [Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/second-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\n \n \n # add an empty 2D dataarray\n In [58]: ds["empty"] = xr.full_like(ds.air.mean("time"), fill_value=0)\n AttributeError: 'Dataset' object has no attribute 'air'\n \n \n@@ -869,15 +869,15 @@\n 
    \n
    \n

    You can also assign values to all variables of a Dataset at once:

    \n
    In [83]: ds_org = xr.tutorial.open_dataset("eraint_uvz").isel(\n    ....:     latitude=slice(56, 59), longitude=slice(255, 258), level=0\n    ....: )\n    ....: \n-PermissionError: [Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/first-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\n+PermissionError: [Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/second-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\n \n \n # set all values to 0\n In [84]: ds = xr.zeros_like(ds_org)\n NameError: name 'ds_org' is not defined\n \n \n", "details": [{"source1": "html2text {}", "source2": "html2text {}", "unified_diff": "@@ -474,15 +474,15 @@\n collection specified weather station latitudes and longitudes. To trigger\n vectorized indexing behavior you will need to provide the selection dimensions\n with a new shared output dimension name. In the example below, the selections\n of the closest latitude and longitude are renamed to an output dimension named\n \u201cpoints\u201d:\n In [52]: ds = xr.tutorial.open_dataset(\"air_temperature\")\n PermissionError: [Errno 13] Permission denied: '/nonexistent' | Pooch could not\n-create data cache folder '/nonexistent/first-build/.cache/\n+create data cache folder '/nonexistent/second-build/.cache/\n xarray_tutorial_data'. Will not be able to download data files.\n \n \n # Define target latitude and longitude (where weather stations might be)\n In [53]: target_lon = xr.DataArray([200, 201, 202, 205], dims=\"points\")\n \n In [54]: target_lat = xr.DataArray([31, 41, 42, 42], dims=\"points\")\n@@ -513,15 +513,15 @@\n selected subpart of the target array (except for the explicitly indexed\n dimensions with .loc/.sel). Otherwise, IndexError will be raised.\n *\b**\b**\b**\b**\b* A\bAs\bss\bsi\big\bgn\bni\bin\bng\bg v\bva\bal\blu\bue\bes\bs w\bwi\bit\bth\bh i\bin\bnd\bde\bex\bxi\bin\bng\bg_\b?\b\u00b6 *\b**\b**\b**\b**\b*\n To select and assign values to a portion of a DataArray() you can use indexing\n with .loc :\n In [57]: ds = xr.tutorial.open_dataset(\"air_temperature\")\n PermissionError: [Errno 13] Permission denied: '/nonexistent' | Pooch could not\n-create data cache folder '/nonexistent/first-build/.cache/\n+create data cache folder '/nonexistent/second-build/.cache/\n xarray_tutorial_data'. Will not be able to download data files.\n \n \n # add an empty 2D dataarray\n In [58]: ds[\"empty\"] = xr.full_like(ds.air.mean(\"time\"), fill_value=0)\n AttributeError: 'Dataset' object has no attribute 'air'\n \n@@ -673,15 +673,15 @@\n Dimensions without coordinates: x\n You can also assign values to all variables of a Dataset at once:\n In [83]: ds_org = xr.tutorial.open_dataset(\"eraint_uvz\").isel(\n    ....:     latitude=slice(56, 59), longitude=slice(255, 258), level=0\n    ....: )\n    ....:\n PermissionError: [Errno 13] Permission denied: '/nonexistent' | Pooch could not\n-create data cache folder '/nonexistent/first-build/.cache/\n+create data cache folder '/nonexistent/second-build/.cache/\n xarray_tutorial_data'. Will not be able to download data files.\n \n \n # set all values to 0\n In [84]: ds = xr.zeros_like(ds_org)\n NameError: name 'ds_org' is not defined\n \n"}]}, {"source1": "./usr/share/doc/python-xarray-doc/html/user-guide/interpolation.html", "source2": "./usr/share/doc/python-xarray-doc/html/user-guide/interpolation.html", "unified_diff": "@@ -237,24 +237,24 @@\n    ....:     np.sin(np.linspace(0, 2 * np.pi, 10)),\n    ....:     dims="x",\n    ....:     coords={"x": np.linspace(0, 1, 10)},\n    ....: )\n    ....: \n \n In [17]: da.plot.line("o", label="original")\n-Out[17]: [<matplotlib.lines.Line2D at 0x7f93c339b250>]\n+Out[17]: [<matplotlib.lines.Line2D at 0x7f39570fb9d0>]\n \n In [18]: da.interp(x=np.linspace(0, 1, 100)).plot.line(label="linear (default)")\n-Out[18]: [<matplotlib.lines.Line2D at 0x7f93c323e5d0>]\n+Out[18]: [<matplotlib.lines.Line2D at 0x7f39570fb750>]\n \n In [19]: da.interp(x=np.linspace(0, 1, 100), method="cubic").plot.line(label="cubic")\n-Out[19]: [<matplotlib.lines.Line2D at 0x7f93c323e490>]\n+Out[19]: [<matplotlib.lines.Line2D at 0x7f39570fbd90>]\n \n In [20]: plt.legend()\n-Out[20]: <matplotlib.legend.Legend at 0x7f93c3208c20>\n+Out[20]: <matplotlib.legend.Legend at 0x7f39570846e0>\n 
    \n
    \n \"_build/html/_static/interpolation_sample1.png\"\n \n

    Additional keyword arguments can be passed to scipy\u2019s functions.

    \n
    # fill 0 for the outside of the original coordinates.\n In [21]: da.interp(x=np.linspace(-0.5, 1.5, 10), kwargs={"fill_value": 0.0})\n@@ -439,15 +439,15 @@\n see Missing values.

    \n
    \n
    \n

    Example\u00b6

    \n

    Let\u2019s see how interp() works on real data.

    \n
    # Raw data\n In [44]: ds = xr.tutorial.open_dataset("air_temperature").isel(time=0)\n-PermissionError: [Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/first-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\n+PermissionError: [Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/second-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\n \n \n In [45]: fig, axes = plt.subplots(ncols=2, figsize=(10, 4))\n \n In [46]: ds.air.plot(ax=axes[0])\n AttributeError: 'Dataset' object has no attribute 'air'\n \n@@ -511,15 +511,15 @@\n    ....:     axes[0].plot(*xr.broadcast(lon.isel(z=idx), lat.isel(z=idx)), "--k")\n    ....: \n \n In [61]: axes[0].set_title("Raw data")\n Out[61]: Text(0.5, 1.0, 'Raw data')\n \n In [62]: dsi = ds.interp(lon=lon, lat=lat)\n-ValueError: Dimensions {'lon', 'lat'} do not exist. Expected one or more of FrozenMappingWarningOnValuesAccess({'x': 3, 'y': 4})\n+ValueError: Dimensions {'lat', 'lon'} do not exist. Expected one or more of FrozenMappingWarningOnValuesAccess({'x': 3, 'y': 4})\n \n \n In [63]: dsi.air.plot(ax=axes[1])\n NameError: name 'dsi' is not defined\n \n \n In [64]: axes[1].set_title("Remapped data")\n", "details": [{"source1": "html2text {}", "source2": "html2text {}", "unified_diff": "@@ -154,26 +154,26 @@\n    ....:     np.sin(np.linspace(0, 2 * np.pi, 10)),\n    ....:     dims=\"x\",\n    ....:     coords={\"x\": np.linspace(0, 1, 10)},\n    ....: )\n    ....:\n \n In [17]: da.plot.line(\"o\", label=\"original\")\n-Out[17]: []\n+Out[17]: []\n \n In [18]: da.interp(x=np.linspace(0, 1, 100)).plot.line(label=\"linear\n (default)\")\n-Out[18]: []\n+Out[18]: []\n \n In [19]: da.interp(x=np.linspace(0, 1, 100), method=\"cubic\").plot.line\n (label=\"cubic\")\n-Out[19]: []\n+Out[19]: []\n \n In [20]: plt.legend()\n-Out[20]: \n+Out[20]: \n _\b[_\b__\bb_\bu_\bi_\bl_\bd_\b/_\bh_\bt_\bm_\bl_\b/_\b__\bs_\bt_\ba_\bt_\bi_\bc_\b/_\bi_\bn_\bt_\be_\br_\bp_\bo_\bl_\ba_\bt_\bi_\bo_\bn_\b__\bs_\ba_\bm_\bp_\bl_\be_\b1_\b._\bp_\bn_\bg_\b]\n Additional keyword arguments can be passed to scipy\u2019s functions.\n # fill 0 for the outside of the original coordinates.\n In [21]: da.interp(x=np.linspace(-0.5, 1.5, 10), kwargs={\"fill_value\": 0.0})\n Out[21]:\n  Size: 80B\n array([ 0.   ,  0.   ,  0.   ,  0.814,  0.604, -0.604, -0.814,  0.   ,  0.   ,\n@@ -337,15 +337,15 @@\n   * x        (x) float64 24B 0.5 1.5 2.5\n For the details of interpolate_na(), see _\bM_\bi_\bs_\bs_\bi_\bn_\bg_\b _\bv_\ba_\bl_\bu_\be_\bs.\n *\b**\b**\b**\b**\b* E\bEx\bxa\bam\bmp\bpl\ble\be_\b?\b\u00b6 *\b**\b**\b**\b**\b*\n Let\u2019s see how interp() works on real data.\n # Raw data\n In [44]: ds = xr.tutorial.open_dataset(\"air_temperature\").isel(time=0)\n PermissionError: [Errno 13] Permission denied: '/nonexistent' | Pooch could not\n-create data cache folder '/nonexistent/first-build/.cache/\n+create data cache folder '/nonexistent/second-build/.cache/\n xarray_tutorial_data'. Will not be able to download data files.\n \n \n In [45]: fig, axes = plt.subplots(ncols=2, figsize=(10, 4))\n \n In [46]: ds.air.plot(ax=axes[0])\n AttributeError: 'Dataset' object has no attribute 'air'\n@@ -410,15 +410,15 @@\n k\")\n    ....:\n \n In [61]: axes[0].set_title(\"Raw data\")\n Out[61]: Text(0.5, 1.0, 'Raw data')\n \n In [62]: dsi = ds.interp(lon=lon, lat=lat)\n-ValueError: Dimensions {'lon', 'lat'} do not exist. Expected one or more of\n+ValueError: Dimensions {'lat', 'lon'} do not exist. Expected one or more of\n FrozenMappingWarningOnValuesAccess({'x': 3, 'y': 4})\n \n \n In [63]: dsi.air.plot(ax=axes[1])\n NameError: name 'dsi' is not defined\n \n \n"}]}, {"source1": "./usr/share/doc/python-xarray-doc/html/user-guide/io.html", "source2": "./usr/share/doc/python-xarray-doc/html/user-guide/io.html", "unified_diff": "@@ -630,15 +630,15 @@\n    ....:         "y": pd.date_range("2000-01-01", periods=5),\n    ....:         "z": ("x", list("abcd")),\n    ....:     },\n    ....: )\n    ....: \n \n In [13]: ds.to_zarr("path/to/directory.zarr")\n-Out[13]: <xarray.backends.zarr.ZarrStore at 0x7f93961ee4d0>\n+Out[13]: <xarray.backends.zarr.ZarrStore at 0x7f39324264d0>\n 
    \n
    \n

    (The suffix .zarr is optional\u2013just a reminder that a zarr store lives\n there.) If the directory does not exist, it will be created. If a zarr\n store is already present at that path, an error will be raised, preventing it\n from being overwritten. To override this behavior and overwrite an existing\n store, add mode='w' when invoking to_zarr().

    \n@@ -724,36 +724,36 @@\n \n In [18]: ds = xr.Dataset({"foo": ("x", dummies)}, coords={"x": np.arange(30)})\n \n In [19]: path = "path/to/directory.zarr"\n \n # Now we write the metadata without computing any array values\n In [20]: ds.to_zarr(path, compute=False)\n-Out[20]: Delayed('_finalize_store-bfb46614-7c78-48e0-b4aa-72b0e4c9db73')\n+Out[20]: Delayed('_finalize_store-f76aeb1b-76ee-4d49-9dca-80f0ce670b67')\n \n \n

    Now, a Zarr store with the correct variable shapes and attributes exists that\n can be filled out by subsequent calls to to_zarr.\n Setting region="auto" will open the existing store and determine the\n correct alignment of the new data with the existing dimensions, or as an\n explicit mapping from dimension names to Python slice objects indicating\n where the data should be written (in index space, not label space), e.g.,

    \n
    # For convenience, we'll slice a single dataset, but in the real use-case\n # we would create them separately possibly even from separate processes.\n In [21]: ds = xr.Dataset({"foo": ("x", np.arange(30))}, coords={"x": np.arange(30)})\n \n # Any of the following region specifications are valid\n In [22]: ds.isel(x=slice(0, 10)).to_zarr(path, region="auto")\n-Out[22]: <xarray.backends.zarr.ZarrStore at 0x7f93961efb50>\n+Out[22]: <xarray.backends.zarr.ZarrStore at 0x7f3932427b50>\n \n In [23]: ds.isel(x=slice(10, 20)).to_zarr(path, region={"x": "auto"})\n-Out[23]: <xarray.backends.zarr.ZarrStore at 0x7f93961ef520>\n+Out[23]: <xarray.backends.zarr.ZarrStore at 0x7f3932427520>\n \n In [24]: ds.isel(x=slice(20, 30)).to_zarr(path, region={"x": slice(20, 30)})\n-Out[24]: <xarray.backends.zarr.ZarrStore at 0x7f9396579e10>\n+Out[24]: <xarray.backends.zarr.ZarrStore at 0x7f39325b5e10>\n 
    \n
    \n

    Concurrent writes with region are safe as long as they modify distinct\n chunks in the underlying Zarr arrays (or use an appropriate lock).

    \n

    As a safety check to make it harder to inadvertently override existing values,\n if you set region then all variables included in a Dataset must have\n dimensions included in region. Other variables (typically coordinates)\n@@ -769,15 +769,15 @@\n

    In [25]: import zarr\n \n In [26]: from numcodecs.blosc import Blosc\n \n In [27]: compressor = Blosc(cname="zstd", clevel=3, shuffle=2)\n \n In [28]: ds.to_zarr("foo.zarr", encoding={"foo": {"compressor": compressor}})\n-Out[28]: <xarray.backends.zarr.ZarrStore at 0x7f93e390c4c0>\n+Out[28]: <xarray.backends.zarr.ZarrStore at 0x7f39322c84c0>\n 
    \n
    \n
    \n

    Note

    \n

    Not all native zarr compression and filtering options have been tested with\n xarray.

    \n
    \n@@ -816,28 +816,28 @@\n ....: "y": [1, 2, 3, 4, 5],\n ....: "t": pd.date_range("2001-01-01", periods=2),\n ....: },\n ....: )\n ....: \n \n In [30]: ds1.to_zarr("path/to/directory.zarr")\n-Out[30]: <xarray.backends.zarr.ZarrStore at 0x7f93e390cdc0>\n+Out[30]: <xarray.backends.zarr.ZarrStore at 0x7f39322c8dc0>\n \n In [31]: ds2 = xr.Dataset(\n ....: {"foo": (("x", "y", "t"), np.random.rand(4, 5, 2))},\n ....: coords={\n ....: "x": [10, 20, 30, 40],\n ....: "y": [1, 2, 3, 4, 5],\n ....: "t": pd.date_range("2001-01-03", periods=2),\n ....: },\n ....: )\n ....: \n \n In [32]: ds2.to_zarr("path/to/directory.zarr", append_dim="t")\n-Out[32]: <xarray.backends.zarr.ZarrStore at 0x7f93e390ce50>\n+Out[32]: <xarray.backends.zarr.ZarrStore at 0x7f39322c8e50>\n \n \n
    \n
    \n

    Specifying chunks in a zarr store\u00b6

    \n

    Chunk sizes may be specified in one of three ways when writing to a zarr store:

    \n
      \n@@ -861,15 +861,15 @@\n positional ordering of the dimensions in each array. Watch out for arrays with\n differently-ordered dimensions within a single Dataset.

      \n \n

      For example, let\u2019s say we\u2019re working with a dataset with dimensions\n ('time', 'x', 'y'), a variable Tair which is chunked in x and y,\n and two multi-dimensional coordinates xc and yc:

      \n
      In [33]: ds = xr.tutorial.open_dataset("rasm")\n-PermissionError: [Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/first-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\n+PermissionError: [Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/second-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\n \n \n In [34]: ds["Tair"] = ds["Tair"].chunk({"x": 100, "y": 100})\n KeyError: "No variable named 'Tair'. Variables on the dataset include ['foo', 'x']"\n \n \n In [35]: ds\n@@ -882,15 +882,15 @@\n     foo      (x) int64 240B 0 1 2 3 4 5 6 7 8 9 ... 21 22 23 24 25 26 27 28 29\n 
      \n
      \n

      These multi-dimensional coordinates are only two-dimensional and take up very little\n space on disk or in memory, yet when writing to disk the default zarr behavior is to\n split them into chunks:

      \n
      In [36]: ds.to_zarr("path/to/directory.zarr", mode="w")\n-Out[36]: <xarray.backends.zarr.ZarrStore at 0x7f93e390d900>\n+Out[36]: <xarray.backends.zarr.ZarrStore at 0x7f39322c9900>\n \n In [37]: ! ls -R path/to/directory.zarr\n path/to/directory.zarr:\n foo  x\n \n path/to/directory.zarr/foo:\n 0\n@@ -1062,15 +1062,15 @@\n 

      Ncdata\u00b6

      \n

      Ncdata provides more sophisticated means of transferring data, including entire\n datasets. It uses the file saving and loading functions in both projects to provide a\n more \u201ccorrect\u201d translation between them, but still with very low overhead and not\n using actual disk files.

      \n

      For example:

      \n
      In [48]: ds = xr.tutorial.open_dataset("air_temperature_gradient")\n-PermissionError: [Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/first-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\n+PermissionError: [Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/second-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\n \n \n In [49]: cubes = ncdata.iris_xarray.cubes_from_xarray(ds)\n NameError: name 'ncdata' is not defined\n \n \n In [50]: print(cubes)\n", "details": [{"source1": "html2text {}", "source2": "html2text {}", "unified_diff": "@@ -481,15 +481,15 @@\n    ....:         \"y\": pd.date_range(\"2000-01-01\", periods=5),\n    ....:         \"z\": (\"x\", list(\"abcd\")),\n    ....:     },\n    ....: )\n    ....:\n \n In [13]: ds.to_zarr(\"path/to/directory.zarr\")\n-Out[13]: \n+Out[13]: \n (The suffix .zarr is optional\u2013just a reminder that a zarr store lives there.)\n If the directory does not exist, it will be created. If a zarr store is already\n present at that path, an error will be raised, preventing it from being\n overwritten. To override this behavior and overwrite an existing store, add\n mode='w' when invoking to_zarr().\n DataArrays can also be saved to disk using the DataArray.to_zarr() method, and\n loaded from disk using the open_dataarray() function with engine='zarr'.\n@@ -562,35 +562,35 @@\n \n In [18]: ds = xr.Dataset({\"foo\": (\"x\", dummies)}, coords={\"x\": np.arange(30)})\n \n In [19]: path = \"path/to/directory.zarr\"\n \n # Now we write the metadata without computing any array values\n In [20]: ds.to_zarr(path, compute=False)\n-Out[20]: Delayed('_finalize_store-bfb46614-7c78-48e0-b4aa-72b0e4c9db73')\n+Out[20]: Delayed('_finalize_store-f76aeb1b-76ee-4d49-9dca-80f0ce670b67')\n Now, a Zarr store with the correct variable shapes and attributes exists that\n can be filled out by subsequent calls to to_zarr. Setting region=\"auto\" will\n open the existing store and determine the correct alignment of the new data\n with the existing dimensions, or as an explicit mapping from dimension names to\n Python slice objects indicating where the data should be written (in index\n space, not label space), e.g.,\n # For convenience, we'll slice a single dataset, but in the real use-case\n # we would create them separately possibly even from separate processes.\n In [21]: ds = xr.Dataset({\"foo\": (\"x\", np.arange(30))}, coords={\"x\": np.arange\n (30)})\n \n # Any of the following region specifications are valid\n In [22]: ds.isel(x=slice(0, 10)).to_zarr(path, region=\"auto\")\n-Out[22]: \n+Out[22]: \n \n In [23]: ds.isel(x=slice(10, 20)).to_zarr(path, region={\"x\": \"auto\"})\n-Out[23]: \n+Out[23]: \n \n In [24]: ds.isel(x=slice(20, 30)).to_zarr(path, region={\"x\": slice(20, 30)})\n-Out[24]: \n+Out[24]: \n Concurrent writes with region are safe as long as they modify distinct chunks\n in the underlying Zarr arrays (or use an appropriate lock).\n As a safety check to make it harder to inadvertently override existing values,\n if you set region then a\bal\bll\bl variables included in a Dataset must have dimensions\n included in region. Other variables (typically coordinates) need to be\n explicitly dropped and/or written in a separate calls to to_zarr with mode='a'.\n *\b**\b**\b**\b* Z\bZa\bar\brr\br C\bCo\bom\bmp\bpr\bre\bes\bss\bso\bor\brs\bs a\ban\bnd\bd F\bFi\bil\blt\bte\ber\brs\bs_\b?\b\u00b6 *\b**\b**\b**\b*\n@@ -601,15 +601,15 @@\n In [25]: import zarr\n \n In [26]: from numcodecs.blosc import Blosc\n \n In [27]: compressor = Blosc(cname=\"zstd\", clevel=3, shuffle=2)\n \n In [28]: ds.to_zarr(\"foo.zarr\", encoding={\"foo\": {\"compressor\": compressor}})\n-Out[28]: \n+Out[28]: \n Note\n Not all native zarr compression and filtering options have been tested with\n xarray.\n *\b**\b**\b**\b* M\bMo\bod\bdi\bif\bfy\byi\bin\bng\bg e\bex\bxi\bis\bst\bti\bin\bng\bg Z\bZa\bar\brr\br s\bst\bto\bor\bre\bes\bs_\b?\b\u00b6 *\b**\b**\b**\b*\n Xarray supports several ways of incrementally writing variables to a Zarr\n store. These options are useful for scenarios when it is infeasible or\n undesirable to write your entire dataset at once.\n@@ -635,28 +635,28 @@\n    ....:         \"y\": [1, 2, 3, 4, 5],\n    ....:         \"t\": pd.date_range(\"2001-01-01\", periods=2),\n    ....:     },\n    ....: )\n    ....:\n \n In [30]: ds1.to_zarr(\"path/to/directory.zarr\")\n-Out[30]: \n+Out[30]: \n \n In [31]: ds2 = xr.Dataset(\n    ....:     {\"foo\": ((\"x\", \"y\", \"t\"), np.random.rand(4, 5, 2))},\n    ....:     coords={\n    ....:         \"x\": [10, 20, 30, 40],\n    ....:         \"y\": [1, 2, 3, 4, 5],\n    ....:         \"t\": pd.date_range(\"2001-01-03\", periods=2),\n    ....:     },\n    ....: )\n    ....:\n \n In [32]: ds2.to_zarr(\"path/to/directory.zarr\", append_dim=\"t\")\n-Out[32]: \n+Out[32]: \n *\b**\b**\b**\b* S\bSp\bpe\bec\bci\bif\bfy\byi\bin\bng\bg c\bch\bhu\bun\bnk\bks\bs i\bin\bn a\ba z\bza\bar\brr\br s\bst\bto\bor\bre\be_\b?\b\u00b6 *\b**\b**\b**\b*\n Chunk sizes may be specified in one of three ways when writing to a zarr store:\n    1. Manual chunk sizing through the use of the encoding argument in\n       Dataset.to_zarr():\n    2. Automatic chunking based on chunks in dask arrays\n    3. Default chunk behavior determined by the zarr library\n The resulting chunks will be determined based on the order of the above list;\n@@ -675,15 +675,15 @@\n positional ordering of the dimensions in each array. Watch out for arrays with\n differently-ordered dimensions within a single Dataset.\n For example, let\u2019s say we\u2019re working with a dataset with dimensions ('time',\n 'x', 'y'), a variable Tair which is chunked in x and y, and two multi-\n dimensional coordinates xc and yc:\n In [33]: ds = xr.tutorial.open_dataset(\"rasm\")\n PermissionError: [Errno 13] Permission denied: '/nonexistent' | Pooch could not\n-create data cache folder '/nonexistent/first-build/.cache/\n+create data cache folder '/nonexistent/second-build/.cache/\n xarray_tutorial_data'. Will not be able to download data files.\n \n \n In [34]: ds[\"Tair\"] = ds[\"Tair\"].chunk({\"x\": 100, \"y\": 100})\n KeyError: \"No variable named 'Tair'. Variables on the dataset include ['foo',\n 'x']\"\n \n@@ -696,15 +696,15 @@\n   * x        (x) int64 240B 0 1 2 3 4 5 6 7 8 9 ... 21 22 23 24 25 26 27 28 29\n Data variables:\n     foo      (x) int64 240B 0 1 2 3 4 5 6 7 8 9 ... 21 22 23 24 25 26 27 28 29\n These multi-dimensional coordinates are only two-dimensional and take up very\n little space on disk or in memory, yet when writing to disk the default zarr\n behavior is to split them into chunks:\n In [36]: ds.to_zarr(\"path/to/directory.zarr\", mode=\"w\")\n-Out[36]: \n+Out[36]: \n \n In [37]: ! ls -R path/to/directory.zarr\n path/to/directory.zarr:\n foo  x\n \n path/to/directory.zarr/foo:\n 0\n@@ -850,15 +850,15 @@\n _\bN_\bc_\bd_\ba_\bt_\ba provides more sophisticated means of transferring data, including entire\n datasets. It uses the file saving and loading functions in both projects to\n provide a more \u201ccorrect\u201d translation between them, but still with very low\n overhead and not using actual disk files.\n For example:\n In [48]: ds = xr.tutorial.open_dataset(\"air_temperature_gradient\")\n PermissionError: [Errno 13] Permission denied: '/nonexistent' | Pooch could not\n-create data cache folder '/nonexistent/first-build/.cache/\n+create data cache folder '/nonexistent/second-build/.cache/\n xarray_tutorial_data'. Will not be able to download data files.\n \n \n In [49]: cubes = ncdata.iris_xarray.cubes_from_xarray(ds)\n NameError: name 'ncdata' is not defined\n \n \n"}]}, {"source1": "./usr/share/doc/python-xarray-doc/html/user-guide/plotting.html", "source2": "./usr/share/doc/python-xarray-doc/html/user-guide/plotting.html", "unified_diff": "@@ -100,15 +100,15 @@\n In [3]: import matplotlib.pyplot as plt\n \n In [4]: import xarray as xr\n 
      \n
      \n

      For these examples we\u2019ll use the North American air temperature dataset.

      \n
      In [5]: airtemps = xr.tutorial.open_dataset("air_temperature")\n-PermissionError: [Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/first-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\n+PermissionError: [Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/second-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\n \n \n In [6]: airtemps\n NameError: name 'airtemps' is not defined\n \n \n # Convert to celsius\n@@ -445,15 +445,15 @@\n \n # Apply a nonlinear transformation to one of the coords\n In [50]: b.coords["lat"] = np.log(b.coords["lat"])\n KeyError: 'lat'\n \n \n In [51]: b.plot()\n-Out[51]: [<matplotlib.lines.Line2D at 0x7f93e369b250>]\n+Out[51]: [<matplotlib.lines.Line2D at 0x7f3970777c50>]\n 
      \n
      \n \"_build/html/_static/plotting_nonuniform_coords.png\"\n \n
    \n
    \n

    Other types of plot\u00b6

    \n@@ -857,117 +857,117 @@\n * y (y) float64 88B 0.0 0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 0.9 1.0\n * z (z) int64 32B 0 1 2 3\n * w (w) <U5 80B 'one' 'two' 'three' 'five'\n Attributes:\n units: Aunits\n \n In [99]: ds.A.plot.scatter(x="y")\n-Out[99]: <matplotlib.collections.PathCollection at 0x7f93e333c440>\n+Out[99]: <matplotlib.collections.PathCollection at 0x7f3970854440>\n \n \n \"_build/html/_static/da_A_y.png\"\n

    Same plot can be displayed using the dataset:

    \n
    In [100]: ds.plot.scatter(x="y", y="A")\n-Out[100]: <matplotlib.collections.PathCollection at 0x7f93e31307d0>\n+Out[100]: <matplotlib.collections.PathCollection at 0x7f39706e2ad0>\n 
    \n
    \n \"_build/html/_static/ds_A_y.png\"\n

    Now suppose we want to scatter the A DataArray against the B DataArray

    \n
    In [101]: ds.plot.scatter(x="A", y="B")\n-Out[101]: <matplotlib.collections.PathCollection at 0x7f93e2fcf390>\n+Out[101]: <matplotlib.collections.PathCollection at 0x7f397071e0d0>\n 
    \n
    \n \"_build/html/_static/ds_simple_scatter.png\"\n

    The hue kwarg lets you vary the color by variable value

    \n
    In [102]: ds.plot.scatter(x="A", y="B", hue="w")\n-Out[102]: <matplotlib.collections.PathCollection at 0x7f93e3016c10>\n+Out[102]: <matplotlib.collections.PathCollection at 0x7f3970564f50>\n 
    \n
    \n \"_build/html/_static/ds_hue_scatter.png\"\n

    You can force a legend instead of a colorbar by setting add_legend=True, add_colorbar=False.

    \n
    In [103]: ds.plot.scatter(x="A", y="B", hue="w", add_legend=True, add_colorbar=False)\n-Out[103]: <matplotlib.collections.PathCollection at 0x7f93e2fcc2d0>\n+Out[103]: <matplotlib.collections.PathCollection at 0x7f39706e0050>\n 
    \n
    \n \"_build/html/_static/ds_discrete_legend_hue_scatter.png\"\n
    In [104]: ds.plot.scatter(x="A", y="B", hue="w", add_legend=False, add_colorbar=True)\n-Out[104]: <matplotlib.collections.PathCollection at 0x7f93e2fcce10>\n+Out[104]: <matplotlib.collections.PathCollection at 0x7f393252fed0>\n 
    \n
    \n \"_build/html/_static/ds_discrete_colorbar_hue_scatter.png\"\n

    The markersize kwarg lets you vary the point\u2019s size by variable value.\n You can additionally pass size_norm to control how the variable\u2019s values are mapped to point sizes.

    \n
    In [105]: ds.plot.scatter(x="A", y="B", hue="y", markersize="z")\n-Out[105]: <matplotlib.collections.PathCollection at 0x7f93c32b0a50>\n+Out[105]: <matplotlib.collections.PathCollection at 0x7f395709bb10>\n 
    \n
    \n \"_build/html/_static/ds_hue_size_scatter.png\"\n

    The z kwarg lets you plot the data along the z-axis as well.

    \n
    In [106]: ds.plot.scatter(x="A", y="B", z="z", hue="y", markersize="x")\n-Out[106]: <mpl_toolkits.mplot3d.art3d.Path3DCollection at 0x7f93e3699310>\n+Out[106]: <mpl_toolkits.mplot3d.art3d.Path3DCollection at 0x7f395662cf50>\n 
    \n
    \n \"_build/html/_static/ds_hue_size_scatter_z.png\"\n

    Faceting is also possible

    \n
    In [107]: ds.plot.scatter(x="A", y="B", hue="y", markersize="x", row="x", col="w")\n-Out[107]: <xarray.plot.facetgrid.FacetGrid at 0x7f93c3209400>\n+Out[107]: <xarray.plot.facetgrid.FacetGrid at 0x7f39570842f0>\n 
    \n
    \n \"_build/html/_static/ds_facet_scatter.png\"\n

    And adding the z-axis

    \n
    In [108]: ds.plot.scatter(x="A", y="B", z="z", hue="y", markersize="x", row="x", col="w")\n-Out[108]: <xarray.plot.facetgrid.FacetGrid at 0x7f93e2a4a710>\n+Out[108]: <xarray.plot.facetgrid.FacetGrid at 0x7f396ff62710>\n 
    \n
    \n \"_build/html/_static/ds_facet_scatter_z.png\"\n

    For more advanced scatter plots, we recommend converting the relevant data variables\n to a pandas DataFrame and using the extensive plotting capabilities of seaborn.

    \n
    \n
    \n

    Quiver\u00b6

    \n

    Visualizing vector fields is supported with quiver plots:

    \n
    In [109]: ds.isel(w=1, z=1).plot.quiver(x="x", y="y", u="A", v="B")\n-Out[109]: <matplotlib.quiver.Quiver at 0x7f9399bbc1a0>\n+Out[109]: <matplotlib.quiver.Quiver at 0x7f395757fa10>\n 
    \n
    \n \"_build/html/_static/ds_simple_quiver.png\"\n

    where u and v denote the x and y direction components of the arrow vectors. Again, faceting is also possible:

    \n
    In [110]: ds.plot.quiver(x="x", y="y", u="A", v="B", col="w", row="z", scale=4)\n-Out[110]: <xarray.plot.facetgrid.FacetGrid at 0x7f93e280f4d0>\n+Out[110]: <xarray.plot.facetgrid.FacetGrid at 0x7f396ff1b4d0>\n 
    \n
    \n \"_build/html/_static/ds_facet_quiver.png\"\n

    scale is required for faceted quiver plots.\n The scale determines the number of data units per arrow length unit, i.e. a smaller scale parameter makes the arrow longer.

    \n
    \n
    \n

    Streamplot\u00b6

    \n

    Visualizing vector fields is also supported with streamline plots:

    \n
    In [111]: ds.isel(w=1, z=1).plot.streamplot(x="x", y="y", u="A", v="B")\n-Out[111]: <matplotlib.collections.LineCollection at 0x7f93e2306fd0>\n+Out[111]: <matplotlib.collections.LineCollection at 0x7f3970223d90>\n 
    \n
    \n \"_build/html/_static/ds_simple_streamplot.png\"\n

    where u and v denote the x and y direction components of the vectors tangent to the streamlines.\n Again, faceting is also possible:

    \n
    In [112]: ds.plot.streamplot(x="x", y="y", u="A", v="B", col="w", row="z")\n-Out[112]: <xarray.plot.facetgrid.FacetGrid at 0x7f9395de3950>\n+Out[112]: <xarray.plot.facetgrid.FacetGrid at 0x7f393289b6f0>\n 
    \n
    \n \"_build/html/_static/ds_facet_streamplot.png\"\n
    \n
    \n
    \n

    Maps\u00b6

    \n

    To follow this section you\u2019ll need to have Cartopy installed and working.

    \n

    This script will plot the air temperature on a map.

    \n
    In [113]: import cartopy.crs as ccrs\n \n In [114]: air = xr.tutorial.open_dataset("air_temperature").air\n-PermissionError: [Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/first-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\n+PermissionError: [Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/second-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\n \n \n In [115]: p = air.isel(time=0).plot(\n    .....:     subplot_kws=dict(projection=ccrs.Orthographic(-80, 35), facecolor="gray"),\n    .....:     transform=ccrs.PlateCarree(),\n    .....: )\n    .....: \n@@ -1024,24 +1024,24 @@\n 
    In [121]: import xarray.plot as xplt\n \n In [122]: da = xr.DataArray(range(5))\n \n In [123]: fig, axs = plt.subplots(ncols=2, nrows=2)\n \n In [124]: da.plot(ax=axs[0, 0])\n-Out[124]: [<matplotlib.lines.Line2D at 0x7f93e23ade50>]\n+Out[124]: [<matplotlib.lines.Line2D at 0x7f396f123c50>]\n \n In [125]: da.plot.line(ax=axs[0, 1])\n-Out[125]: [<matplotlib.lines.Line2D at 0x7f93e23adf90>]\n+Out[125]: [<matplotlib.lines.Line2D at 0x7f396f123b10>]\n \n In [126]: xplt.plot(da, ax=axs[1, 0])\n-Out[126]: [<matplotlib.lines.Line2D at 0x7f93e23af250>]\n+Out[126]: [<matplotlib.lines.Line2D at 0x7f396f1239d0>]\n \n In [127]: xplt.line(da, ax=axs[1, 1])\n-Out[127]: [<matplotlib.lines.Line2D at 0x7f93e23c9590>]\n+Out[127]: [<matplotlib.lines.Line2D at 0x7f396f120b90>]\n \n In [128]: plt.tight_layout()\n \n In [129]: plt.draw()\n 
    \n
    \n \"_build/html/_static/plotting_ways_to_use.png\"\n@@ -1091,15 +1091,15 @@\n
    \n

    The plot will produce an image corresponding to the values of the array.\n Hence the top left pixel will be a different color than the others.\n Before reading on, you may want to look at the coordinates and\n think carefully about what the limits, labels, and orientation for\n each of the axes should be.

    \n
    In [134]: a.plot()\n-Out[134]: <matplotlib.collections.QuadMesh at 0x7f93e1b15090>\n+Out[134]: <matplotlib.collections.QuadMesh at 0x7f396f065090>\n 
    \n
    \n
    \"_build/html/_static/plotting_example_2d_simple.png\"\n \n

    It may seem strange that\n the values on the y axis are decreasing with -0.5 on the top. This is because\n the pixels are centered over their coordinates, and the\n@@ -1122,57 +1122,57 @@\n .....: np.arange(20).reshape(4, 5),\n .....: dims=["y", "x"],\n .....: coords={"lat": (("y", "x"), lat), "lon": (("y", "x"), lon)},\n .....: )\n .....: \n \n In [139]: da.plot.pcolormesh(x="lon", y="lat")\n-Out[139]: <matplotlib.collections.QuadMesh at 0x7f93e2967ed0>\n+Out[139]: <matplotlib.collections.QuadMesh at 0x7f396f094a50>\n

    \n \n \"_build/html/_static/plotting_example_2d_irreg.png\"\n \n

    Note that in this case, xarray still follows the pixel centered convention.\n This might be undesirable in some cases, for example when your data is defined\n on a polar projection (GH781). This is why the default is to not follow\n this convention when plotting on a map:

    \n
    In [140]: import cartopy.crs as ccrs\n \n In [141]: ax = plt.subplot(projection=ccrs.PlateCarree())\n \n In [142]: da.plot.pcolormesh(x="lon", y="lat", ax=ax)\n-Out[142]: <cartopy.mpl.geocollection.GeoQuadMesh at 0x7f93e1a5e210>\n+Out[142]: <cartopy.mpl.geocollection.GeoQuadMesh at 0x7f3934ab3890>\n \n In [143]: ax.scatter(lon, lat, transform=ccrs.PlateCarree())\n-Out[143]: <matplotlib.collections.PathCollection at 0x7f93e2323ed0>\n+Out[143]: <matplotlib.collections.PathCollection at 0x7f396fa3c190>\n \n In [144]: ax.coastlines()\n-Out[144]: <cartopy.mpl.feature_artist.FeatureArtist at 0x7f9397503cb0>\n+Out[144]: <cartopy.mpl.feature_artist.FeatureArtist at 0x7f3935fa3770>\n \n In [145]: ax.gridlines(draw_labels=True)\n-Out[145]: <cartopy.mpl.gridliner.Gridliner at 0x7f93975becf0>\n+Out[145]: <cartopy.mpl.gridliner.Gridliner at 0x7f3933703b60>\n 
    \n
    \n \"_build/html/_static/plotting_example_2d_irreg_map.png\"\n \n

    You can however decide to infer the cell boundaries and use the\n infer_intervals keyword:

    \n
    In [146]: ax = plt.subplot(projection=ccrs.PlateCarree())\n \n In [147]: da.plot.pcolormesh(x="lon", y="lat", ax=ax, infer_intervals=True)\n-Out[147]: <cartopy.mpl.geocollection.GeoQuadMesh at 0x7f93e2af2ad0>\n+Out[147]: <cartopy.mpl.geocollection.GeoQuadMesh at 0x7f396f9c1590>\n \n In [148]: ax.scatter(lon, lat, transform=ccrs.PlateCarree())\n-Out[148]: <matplotlib.collections.PathCollection at 0x7f93e2304f50>\n+Out[148]: <matplotlib.collections.PathCollection at 0x7f396f1b2850>\n \n In [149]: ax.coastlines()\n-Out[149]: <cartopy.mpl.feature_artist.FeatureArtist at 0x7f93e2304e10>\n+Out[149]: <cartopy.mpl.feature_artist.FeatureArtist at 0x7f396f1b2710>\n \n In [150]: ax.gridlines(draw_labels=True)\n-Out[150]: <cartopy.mpl.gridliner.Gridliner at 0x7f93e2307750>\n+Out[150]: <cartopy.mpl.gridliner.Gridliner at 0x7f396f1b25d0>\n 
    \n
    \n \"_build/html/_static/plotting_example_2d_irreg_map_infer.png\"\n \n
    \n

    Note

    \n

    The data model of xarray does not support datasets with cell boundaries\n@@ -1180,26 +1180,26 @@\n outside the xarray framework.

    \n
    \n

    One can also make line plots with multidimensional coordinates. In this case, hue must be a dimension name, not a coordinate name.

    \n
    In [151]: f, ax = plt.subplots(2, 1)\n \n In [152]: da.plot.line(x="lon", hue="y", ax=ax[0])\n Out[152]: \n-[<matplotlib.lines.Line2D at 0x7f93e18fe490>,\n- <matplotlib.lines.Line2D at 0x7f93e18fe5d0>,\n- <matplotlib.lines.Line2D at 0x7f93e18fe710>,\n- <matplotlib.lines.Line2D at 0x7f93e18fe850>]\n+[<matplotlib.lines.Line2D at 0x7f396ee9a490>,\n+ <matplotlib.lines.Line2D at 0x7f396ee9a5d0>,\n+ <matplotlib.lines.Line2D at 0x7f396ee9a710>,\n+ <matplotlib.lines.Line2D at 0x7f396ee9a850>]\n \n In [153]: da.plot.line(x="lon", hue="x", ax=ax[1])\n Out[153]: \n-[<matplotlib.lines.Line2D at 0x7f93e17a4b90>,\n- <matplotlib.lines.Line2D at 0x7f93e17a4cd0>,\n- <matplotlib.lines.Line2D at 0x7f93e17a4e10>,\n- <matplotlib.lines.Line2D at 0x7f93e17a4f50>,\n- <matplotlib.lines.Line2D at 0x7f93e17a5090>]\n+[<matplotlib.lines.Line2D at 0x7f396eebcb90>,\n+ <matplotlib.lines.Line2D at 0x7f396eebccd0>,\n+ <matplotlib.lines.Line2D at 0x7f396eebce10>,\n+ <matplotlib.lines.Line2D at 0x7f396eebcf50>,\n+ <matplotlib.lines.Line2D at 0x7f396eebd090>]\n 
    \n
    \n \"_build/html/_static/plotting_example_2d_hue_xy.png\"\n
    \n \n \n \n", "details": [{"source1": "html2text {}", "source2": "html2text {}", "unified_diff": "@@ -30,15 +30,15 @@\n \n In [3]: import matplotlib.pyplot as plt\n \n In [4]: import xarray as xr\n For these examples we\u2019ll use the North American air temperature dataset.\n In [5]: airtemps = xr.tutorial.open_dataset(\"air_temperature\")\n PermissionError: [Errno 13] Permission denied: '/nonexistent' | Pooch could not\n-create data cache folder '/nonexistent/first-build/.cache/\n+create data cache folder '/nonexistent/second-build/.cache/\n xarray_tutorial_data'. Will not be able to download data files.\n \n \n In [6]: airtemps\n NameError: name 'airtemps' is not defined\n \n \n@@ -292,15 +292,15 @@\n \n # Apply a nonlinear transformation to one of the coords\n In [50]: b.coords[\"lat\"] = np.log(b.coords[\"lat\"])\n KeyError: 'lat'\n \n \n In [51]: b.plot()\n-Out[51]: []\n+Out[51]: []\n _\b[_\b__\bb_\bu_\bi_\bl_\bd_\b/_\bh_\bt_\bm_\bl_\b/_\b__\bs_\bt_\ba_\bt_\bi_\bc_\b/_\bp_\bl_\bo_\bt_\bt_\bi_\bn_\bg_\b__\bn_\bo_\bn_\bu_\bn_\bi_\bf_\bo_\br_\bm_\b__\bc_\bo_\bo_\br_\bd_\bs_\b._\bp_\bn_\bg_\b]\n *\b**\b**\b* O\bOt\bth\bhe\ber\br t\bty\byp\bpe\bes\bs o\bof\bf p\bpl\blo\bot\bt_\b?\b\u00b6 *\b**\b**\b*\n There are several other options for plotting 2D data.\n Contour plot using DataArray.plot.contour()\n In [52]: air2d.plot.contour()\n NameError: name 'air2d' is not defined\n _\b[_\b__\bb_\bu_\bi_\bl_\bd_\b/_\bh_\bt_\bm_\bl_\b/_\b__\bs_\bt_\ba_\bt_\bi_\bc_\b/_\bp_\bl_\bo_\bt_\bt_\bi_\bn_\bg_\b__\bc_\bo_\bn_\bt_\bo_\bu_\br_\b._\bp_\bn_\bg_\b]\n@@ -613,92 +613,92 @@\n * y (y) float64 88B 0.0 0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 0.9 1.0\n * z (z) int64 32B 0 1 2 3\n * w (w) \n+Out[99]: \n [_build/html/_static/da_A_y.png]\n Same plot can be displayed using the dataset:\n In [100]: ds.plot.scatter(x=\"y\", y=\"A\")\n-Out[100]: \n+Out[100]: \n [_build/html/_static/ds_A_y.png]\n Now suppose we want to scatter the A DataArray against the B DataArray\n In [101]: ds.plot.scatter(x=\"A\", y=\"B\")\n-Out[101]: \n+Out[101]: \n [_build/html/_static/ds_simple_scatter.png]\n The hue kwarg lets you vary the color by variable value\n In [102]: ds.plot.scatter(x=\"A\", y=\"B\", hue=\"w\")\n-Out[102]: \n+Out[102]: \n [_build/html/_static/ds_hue_scatter.png]\n You can force a legend instead of a colorbar by setting add_legend=True,\n add_colorbar=False.\n In [103]: ds.plot.scatter(x=\"A\", y=\"B\", hue=\"w\", add_legend=True,\n add_colorbar=False)\n-Out[103]: \n+Out[103]: \n [_build/html/_static/ds_discrete_legend_hue_scatter.png]\n In [104]: ds.plot.scatter(x=\"A\", y=\"B\", hue=\"w\", add_legend=False,\n add_colorbar=True)\n-Out[104]: \n+Out[104]: \n [_build/html/_static/ds_discrete_colorbar_hue_scatter.png]\n The markersize kwarg lets you vary the point\u2019s size by variable value. You can\n additionally pass size_norm to control how the variable\u2019s values are mapped to\n point sizes.\n In [105]: ds.plot.scatter(x=\"A\", y=\"B\", hue=\"y\", markersize=\"z\")\n-Out[105]: \n+Out[105]: \n [_build/html/_static/ds_hue_size_scatter.png]\n The z kwarg lets you plot the data along the z-axis as well.\n In [106]: ds.plot.scatter(x=\"A\", y=\"B\", z=\"z\", hue=\"y\", markersize=\"x\")\n-Out[106]: \n+Out[106]: \n [_build/html/_static/ds_hue_size_scatter_z.png]\n Faceting is also possible\n In [107]: ds.plot.scatter(x=\"A\", y=\"B\", hue=\"y\", markersize=\"x\", row=\"x\",\n col=\"w\")\n-Out[107]: \n+Out[107]: \n [_build/html/_static/ds_facet_scatter.png]\n And adding the z-axis\n In [108]: ds.plot.scatter(x=\"A\", y=\"B\", z=\"z\", hue=\"y\", markersize=\"x\",\n row=\"x\", col=\"w\")\n-Out[108]: \n+Out[108]: \n [_build/html/_static/ds_facet_scatter_z.png]\n For more advanced scatter plots, we recommend converting the relevant data\n variables to a pandas DataFrame and using the extensive plotting capabilities\n of seaborn.\n *\b**\b**\b**\b* Q\bQu\bui\biv\bve\ber\br_\b?\b\u00b6 *\b**\b**\b**\b*\n Visualizing vector fields is supported with quiver plots:\n In [109]: ds.isel(w=1, z=1).plot.quiver(x=\"x\", y=\"y\", u=\"A\", v=\"B\")\n-Out[109]: \n+Out[109]: \n [_build/html/_static/ds_simple_quiver.png]\n where u and v denote the x and y direction components of the arrow vectors.\n Again, faceting is also possible:\n In [110]: ds.plot.quiver(x=\"x\", y=\"y\", u=\"A\", v=\"B\", col=\"w\", row=\"z\", scale=4)\n-Out[110]: \n+Out[110]: \n [_build/html/_static/ds_facet_quiver.png]\n scale is required for faceted quiver plots. The scale determines the number of\n data units per arrow length unit, i.e. a smaller scale parameter makes the\n arrow longer.\n *\b**\b**\b**\b* S\bSt\btr\bre\bea\bam\bmp\bpl\blo\bot\bt_\b?\b\u00b6 *\b**\b**\b**\b*\n Visualizing vector fields is also supported with streamline plots:\n In [111]: ds.isel(w=1, z=1).plot.streamplot(x=\"x\", y=\"y\", u=\"A\", v=\"B\")\n-Out[111]: \n+Out[111]: \n [_build/html/_static/ds_simple_streamplot.png]\n where u and v denote the x and y direction components of the vectors tangent to\n the streamlines. Again, faceting is also possible:\n In [112]: ds.plot.streamplot(x=\"x\", y=\"y\", u=\"A\", v=\"B\", col=\"w\", row=\"z\")\n-Out[112]: \n+Out[112]: \n [_build/html/_static/ds_facet_streamplot.png]\n *\b**\b**\b**\b**\b* M\bMa\bap\bps\bs_\b?\b\u00b6 *\b**\b**\b**\b**\b*\n To follow this section you\u2019ll need to have Cartopy installed and working.\n This script will plot the air temperature on a map.\n In [113]: import cartopy.crs as ccrs\n \n In [114]: air = xr.tutorial.open_dataset(\"air_temperature\").air\n PermissionError: [Errno 13] Permission denied: '/nonexistent' | Pooch could not\n-create data cache folder '/nonexistent/first-build/.cache/\n+create data cache folder '/nonexistent/second-build/.cache/\n xarray_tutorial_data'. Will not be able to download data files.\n \n \n In [115]: p = air.isel(time=0).plot(\n .....: subplot_kws=dict(projection=ccrs.Orthographic(-80, 35),\n facecolor=\"gray\"),\n .....: transform=ccrs.PlateCarree(),\n@@ -745,24 +745,24 @@\n In [121]: import xarray.plot as xplt\n \n In [122]: da = xr.DataArray(range(5))\n \n In [123]: fig, axs = plt.subplots(ncols=2, nrows=2)\n \n In [124]: da.plot(ax=axs[0, 0])\n-Out[124]: []\n+Out[124]: []\n \n In [125]: da.plot.line(ax=axs[0, 1])\n-Out[125]: []\n+Out[125]: []\n \n In [126]: xplt.plot(da, ax=axs[1, 0])\n-Out[126]: []\n+Out[126]: []\n \n In [127]: xplt.line(da, ax=axs[1, 1])\n-Out[127]: []\n+Out[127]: []\n \n In [128]: plt.tight_layout()\n \n In [129]: plt.draw()\n _\b[_\b__\bb_\bu_\bi_\bl_\bd_\b/_\bh_\bt_\bm_\bl_\b/_\b__\bs_\bt_\ba_\bt_\bi_\bc_\b/_\bp_\bl_\bo_\bt_\bt_\bi_\bn_\bg_\b__\bw_\ba_\by_\bs_\b__\bt_\bo_\b__\bu_\bs_\be_\b._\bp_\bn_\bg_\b]\n Here the output is the same. Since the data is 1 dimensional the line plot was\n used.\n@@ -793,15 +793,15 @@\n [0., 0., 0.]], shape=(4, 3))\n Dimensions without coordinates: y, x\n The plot will produce an image corresponding to the values of the array. Hence\n the top left pixel will be a different color than the others. Before reading\n on, you may want to look at the coordinates and think carefully about what the\n limits, labels, and orientation for each of the axes should be.\n In [134]: a.plot()\n-Out[134]: \n+Out[134]: \n _\b[_\b__\bb_\bu_\bi_\bl_\bd_\b/_\bh_\bt_\bm_\bl_\b/_\b__\bs_\bt_\ba_\bt_\bi_\bc_\b/_\bp_\bl_\bo_\bt_\bt_\bi_\bn_\bg_\b__\be_\bx_\ba_\bm_\bp_\bl_\be_\b__\b2_\bd_\b__\bs_\bi_\bm_\bp_\bl_\be_\b._\bp_\bn_\bg_\b]\n It may seem strange that the values on the y axis are decreasing with -0.5 on\n the top. This is because the pixels are centered over their coordinates, and\n the axis labels and ranges correspond to the values of the coordinates.\n *\b**\b**\b**\b* M\bMu\bul\blt\bti\bid\bdi\bim\bme\ben\bns\bsi\bio\bon\bna\bal\bl c\bco\boo\bor\brd\bdi\bin\bna\bat\bte\bes\bs_\b?\b\u00b6 *\b**\b**\b**\b*\n See also: _\bW_\bo_\br_\bk_\bi_\bn_\bg_\b _\bw_\bi_\bt_\bh_\b _\bM_\bu_\bl_\bt_\bi_\bd_\bi_\bm_\be_\bn_\bs_\bi_\bo_\bn_\ba_\bl_\b _\bC_\bo_\bo_\br_\bd_\bi_\bn_\ba_\bt_\be_\bs.\n You can plot irregular grids defined by multidimensional coordinates with\n@@ -818,74 +818,74 @@\n .....: np.arange(20).reshape(4, 5),\n .....: dims=[\"y\", \"x\"],\n .....: coords={\"lat\": ((\"y\", \"x\"), lat), \"lon\": ((\"y\", \"x\"), lon)},\n .....: )\n .....:\n \n In [139]: da.plot.pcolormesh(x=\"lon\", y=\"lat\")\n-Out[139]: \n+Out[139]: \n _\b[_\b__\bb_\bu_\bi_\bl_\bd_\b/_\bh_\bt_\bm_\bl_\b/_\b__\bs_\bt_\ba_\bt_\bi_\bc_\b/_\bp_\bl_\bo_\bt_\bt_\bi_\bn_\bg_\b__\be_\bx_\ba_\bm_\bp_\bl_\be_\b__\b2_\bd_\b__\bi_\br_\br_\be_\bg_\b._\bp_\bn_\bg_\b]\n Note that in this case, xarray still follows the pixel centered convention.\n This might be undesirable in some cases, for example when your data is defined\n on a polar projection (_\bG_\bH_\b7_\b8_\b1). This is why the default is to not follow this\n convention when plotting on a map:\n In [140]: import cartopy.crs as ccrs\n \n In [141]: ax = plt.subplot(projection=ccrs.PlateCarree())\n \n In [142]: da.plot.pcolormesh(x=\"lon\", y=\"lat\", ax=ax)\n-Out[142]: \n+Out[142]: \n \n In [143]: ax.scatter(lon, lat, transform=ccrs.PlateCarree())\n-Out[143]: \n+Out[143]: \n \n In [144]: ax.coastlines()\n-Out[144]: \n+Out[144]: \n \n In [145]: ax.gridlines(draw_labels=True)\n-Out[145]: \n+Out[145]: \n _\b[_\b__\bb_\bu_\bi_\bl_\bd_\b/_\bh_\bt_\bm_\bl_\b/_\b__\bs_\bt_\ba_\bt_\bi_\bc_\b/_\bp_\bl_\bo_\bt_\bt_\bi_\bn_\bg_\b__\be_\bx_\ba_\bm_\bp_\bl_\be_\b__\b2_\bd_\b__\bi_\br_\br_\be_\bg_\b__\bm_\ba_\bp_\b._\bp_\bn_\bg_\b]\n You can however decide to infer the cell boundaries and use the infer_intervals\n keyword:\n In [146]: ax = plt.subplot(projection=ccrs.PlateCarree())\n \n In [147]: da.plot.pcolormesh(x=\"lon\", y=\"lat\", ax=ax, infer_intervals=True)\n-Out[147]: \n+Out[147]: \n \n In [148]: ax.scatter(lon, lat, transform=ccrs.PlateCarree())\n-Out[148]: \n+Out[148]: \n \n In [149]: ax.coastlines()\n-Out[149]: \n+Out[149]: \n \n In [150]: ax.gridlines(draw_labels=True)\n-Out[150]: \n+Out[150]: \n _\b[_\b__\bb_\bu_\bi_\bl_\bd_\b/_\bh_\bt_\bm_\bl_\b/_\b__\bs_\bt_\ba_\bt_\bi_\bc_\b/_\bp_\bl_\bo_\bt_\bt_\bi_\bn_\bg_\b__\be_\bx_\ba_\bm_\bp_\bl_\be_\b__\b2_\bd_\b__\bi_\br_\br_\be_\bg_\b__\bm_\ba_\bp_\b__\bi_\bn_\bf_\be_\br_\b._\bp_\bn_\bg_\b]\n Note\n The data model of xarray does not support datasets with _\bc_\be_\bl_\bl_\b _\bb_\bo_\bu_\bn_\bd_\ba_\br_\bi_\be_\bs yet. If\n you want to use these coordinates, you\u2019ll have to make the plots outside the\n xarray framework.\n One can also make line plots with multidimensional coordinates. In this case,\n hue must be a dimension name, not a coordinate name.\n In [151]: f, ax = plt.subplots(2, 1)\n \n In [152]: da.plot.line(x=\"lon\", hue=\"y\", ax=ax[0])\n Out[152]:\n-[,\n- ,\n- ,\n- ]\n+[,\n+ ,\n+ ,\n+ ]\n \n In [153]: da.plot.line(x=\"lon\", hue=\"x\", ax=ax[1])\n Out[153]:\n-[,\n- ,\n- ,\n- ,\n- ]\n+[,\n+ ,\n+ ,\n+ ,\n+ ]\n [_build/html/_static/plotting_example_2d_hue_xy.png]\n _\b[_\bL_\bo_\bg_\bo_\b _\bo_\bf_\b _\bx_\ba_\br_\br_\ba_\by_\b]\n *\b**\b**\b**\b**\b**\b* _\bx\bx_\ba\ba_\br\br_\br\br_\ba\ba_\by\by *\b**\b**\b**\b**\b**\b*\n *\b**\b**\b**\b* N\bNa\bav\bvi\big\bga\bat\bti\bio\bon\bn *\b**\b**\b**\b*\n For users\n * _\bG_\be_\bt_\bt_\bi_\bn_\bg_\b _\bS_\bt_\ba_\br_\bt_\be_\bd\n * _\bU_\bs_\be_\br_\b _\bG_\bu_\bi_\bd_\be\n"}]}, {"source1": "./usr/share/doc/python-xarray-doc/html/user-guide/reshaping.html", "source2": "./usr/share/doc/python-xarray-doc/html/user-guide/reshaping.html", "unified_diff": "@@ -554,15 +554,15 @@\n
    \n

    Reshaping via coarsen\u00b6

    \n

    Whilst coarsen is normally used for reducing your data\u2019s resolution by applying a reduction function\n (see the page on computation),\n it can also be used to reorganise your data without applying a computation via construct().

    \n

    Taking our example tutorial air temperature dataset over the Northern US

    \n
    In [56]: air = xr.tutorial.open_dataset("air_temperature")["air"]\n-PermissionError: [Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/first-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\n+PermissionError: [Errno 13] Permission denied: '/nonexistent' | Pooch could not create data cache folder '/nonexistent/second-build/.cache/xarray_tutorial_data'. Will not be able to download data files.\n \n \n In [57]: air.isel(time=0).plot(x="lon", y="lat")\n NameError: name 'air' is not defined\n 
    \n
    \n \"_build/html/_static/pre_coarsening.png\"\n", "details": [{"source1": "html2text {}", "source2": "html2text {}", "unified_diff": "@@ -440,15 +440,15 @@\n *\b**\b**\b**\b**\b* R\bRe\bes\bsh\bha\bap\bpi\bin\bng\bg v\bvi\bia\ba c\bco\boa\bar\brs\bse\ben\bn_\b?\b\u00b6 *\b**\b**\b**\b**\b*\n Whilst coarsen is normally used for reducing your data\u2019s resolution by applying\n a reduction function (see the _\bp_\ba_\bg_\be_\b _\bo_\bn_\b _\bc_\bo_\bm_\bp_\bu_\bt_\ba_\bt_\bi_\bo_\bn), it can also be used to\n reorganise your data without applying a computation via construct().\n Taking our example tutorial air temperature dataset over the Northern US\n In [56]: air = xr.tutorial.open_dataset(\"air_temperature\")[\"air\"]\n PermissionError: [Errno 13] Permission denied: '/nonexistent' | Pooch could not\n-create data cache folder '/nonexistent/first-build/.cache/\n+create data cache folder '/nonexistent/second-build/.cache/\n xarray_tutorial_data'. Will not be able to download data files.\n \n \n In [57]: air.isel(time=0).plot(x=\"lon\", y=\"lat\")\n NameError: name 'air' is not defined\n [_build/html/_static/pre_coarsening.png]\n we can split this up into sub-regions of size (9, 18) points using construct():\n"}]}, {"source1": "./usr/share/doc/python-xarray-doc/html/user-guide/testing.html", "source2": "./usr/share/doc/python-xarray-doc/html/user-guide/testing.html", "unified_diff": "@@ -84,34 +84,43 @@\n

    Generating Examples\u00b6

    \n

    To see an example of what each of these strategies might produce, you can call one followed by the .example() method,\n which is a general hypothesis method valid for all strategies.

    \n
    In [2]: import xarray.testing.strategies as xrst\n \n In [3]: xrst.variables().example()\n Out[3]: \n-<xarray.Variable (\u017b\u01518\u010c: 3)> Size: 24B\n-array([       nan+nanj, -1.175e-38 +2.j, -3.333e-01 +0.j], dtype=complex64)\n+<xarray.Variable (\u00e2\u00f2: 4)> Size: 16B\n+array([nan, nan, -0., nan], dtype=float32)\n+Attributes:\n+    \u00c1\u0148:       {'\u0166\u010b\u00b20': '\u0154\u017c', '\u016bQ\u017f\u00e7\u015b': '\u017c9\u012fc\u00f4'}\n+    \u0115\u0108\u00dc\u00f3\u017f:    {'\u0101\u00d0l\u0140\u0145': '\u00c8H\u0157\u017c', 'A\u017b\u0129': '', '\u017f\u0130\u0168\u00bdA': True, '': False, '\u017f\u017c': Tr...\n \n In [4]: xrst.variables().example()\n Out[4]: \n-<xarray.Variable (\u00fdB\u017b: 2)> Size: 16B\n-array([-1.9  , -0.333])\n+<xarray.Variable (\u0168B: 4, \u017f\u00e7\u0106\u0107\u0174: 4)> Size: 32B\n+array([[17709, 27830, 17709, 17709],\n+       [17709, 17709, 17709, 17709],\n+       [17709, 17709, 17709, 17709],\n+       [17709, 17709, 17709, 17709]], shape=(4, 4), dtype=int16)\n Attributes:\n-    \u017c:        None\n-    \u0136\u017f\u0153\u00d6\u017f:    None\n+    \u0104\u0113\u017d\u00eb\u017f:    ['' '\\x9e\u00a6=S']\n+    :         False\n+    \u0148\u014a\u017dI\u00f0:    5\u017d\u013e\u00ee\u00f6\n+    \u00da\u013e\u00c48\u017f:    True\n+    \u011f\u013e\u01031:     None\n+    \u015e\u0116:       \u0147\u017e\u0105\n+    \u00fc\u00be:       [b'\\x03\\x10Q(/+26\\xa2\\xe9\\xa1Ep\\x85@']\n \n In [5]: xrst.variables().example()\n Out[5]: \n-<xarray.Variable (\u00cf\u0143\u00ec\u0111\u011c: 1, \u017e\u0148\u00d0\u0105\u017b: 1, \u0172\u0109\u011b\u00d2\u00e9: 3)> Size: 24B\n-array([[[1.798e+308, 1.798e+308, 1.798e+308]]])\n+<xarray.Variable (o: 5)> Size: 80B\n+array([-1.500e+00+1.000e+000j,  9.007e+15-6.429e+016j,        nan       +nanj,\n+        4.802e+16-1.766e+084j,       -inf-2.225e-308j])\n Attributes:\n-    1\u017b\u013d\u00c6\u00ca:    \u00ca\n-    \u012d\u017d\u017e\u00e1\u017c:    False\n-    \u0169E:       [['\u00d6' '\u00d6']\\n ['\u00d6' '\u00d6']]\n-    \u0142\u0135\u017dOE:    None\n+    \u00ceb:       [b'\\x1f']\n 
    \n
    \n

    You can see that calling .example() multiple times will generate different examples, giving you an idea of the wide\n range of data that the xarray strategies can generate.

    \n

    In your tests however you should not use .example() - instead you should parameterize your tests with the\n hypothesis.given() decorator:

    \n
    In [6]: from hypothesis import given\n@@ -129,66 +138,65 @@\n 

    Xarray\u2019s strategies can accept other strategies as arguments, allowing you to customise the contents of the generated\n examples.

    \n
    # generate a Variable containing an array with a complex number dtype, but all other details still arbitrary\n In [8]: from hypothesis.extra.numpy import complex_number_dtypes\n \n In [9]: xrst.variables(dtype=complex_number_dtypes()).example()\n Out[9]: \n-<xarray.Variable (\u0124: 6)> Size: 48B\n-array([-6.948e+15      +nanj, -1.000e+07-6.104e-05j, -0.000e+00-0.000e+00j, -0.000e+00+1.401e-45j,\n-        0.000e+00-1.401e-45j, -3.403e+16+1.175e-38j], dtype=complex64)\n+<xarray.Variable (\u0173\u0168\u017d\u00ce: 2, J: 4)> Size: 128B\n+array([[-1.175e-038-6.860e+016j,  1.100e+000-3.624e+016j, -2.335e+153-1.113e-308j,\n+         5.351e+016+2.225e-311j],\n+       [ 4.032e+016+3.356e+116j, -2.640e-174       +nanj, -2.225e-311+5.357e+016j,\n+        -1.648e-093-5.000e-001j]], dtype='>c16')\n Attributes:\n-    :         [b'']\n-    \u017bT\u0136a\u017c:    [['\\U000fb3d5' '`']\\n ['{' '{']]\n-    \u0114:        [b'\\xa3h']\n-    \u00bc\u0120\u00c3\u017e\u017c:    \u0156\u0120\u00e7\u00cbU\n-    \u016e:        False\n-    \u00c7:        \n+    \u00c3:        [[b'B\\xe1?' b'\\xfe\\x08\\xd4f']\\n [b'=dO\\xd23\\xe0\\xdd\\xf2\\xe9\\xed...\n+    \u0172\u0108\u0113\u017e\u017c:    \u013e\u00ff\u017f\n 
    \n
    \n

    This also works with custom strategies, or strategies defined in other packages.\n For example you could imagine creating a chunks strategy to specify particular chunking patterns for a dask-backed array.

    \n
    \n
    \n

    Fixing Arguments\u00b6

    \n

    If you want to fix one aspect of the data structure, whilst allowing variation in the generated examples\n over all other aspects, then use hypothesis.strategies.just().

    \n
    In [10]: import hypothesis.strategies as st\n \n # Generates only variable objects with dimensions ["x", "y"]\n In [11]: xrst.variables(dims=st.just(["x", "y"])).example()\n Out[11]: \n-<xarray.Variable (x: 3, y: 6)> Size: 36B\n-array([[     inf, -0.0e+00,      inf,      inf,      inf,      inf],\n-       [     inf,      inf,      inf,      inf,      inf,      inf],\n-       [     inf,  1.2e-07,  1.5e+00,      inf,      inf,      inf]], shape=(3, 6), dtype=float16)\n-Attributes:\n-    x\u00f2\u016f\u016f:     {'\u010f': ''}\n-    \u00ff\u017f\u00be\u017e\u0148:    {}\n-    \u00c7\u0114\u012c\u00dc\u0131:    {'\u00b2': array([[2547821043,      51546]], dtype='>u4'), 'u\u017e\u00c2': Fa...\n+<xarray.Variable (x: 5, y: 6)> Size: 30B\n+array([[  43, -108, -108, -108, -108, -108],\n+       [-108, -108, -108, -108,  122, -108],\n+       [-108,  -45, -122, -108, -108, -108],\n+       [-108, -108, -108, -108, -108, -108],\n+       [-108, -108, -108, -108, -108, -108]], shape=(5, 6), dtype=int8)\n 
    \n
    \n

    (This is technically another example of chaining strategies - hypothesis.strategies.just() is simply a\n special strategy that just contains a single example.)

    \n

    To fix the length of dimensions you can instead pass dims as a mapping of dimension names to lengths\n (i.e. following xarray objects\u2019 .sizes() property), e.g.

    \n
    # Generates only variables with dimensions ["x", "y"], of lengths 2 & 3 respectively\n In [12]: xrst.variables(dims=st.just({"x": 2, "y": 3})).example()\n Out[12]: \n-<xarray.Variable (x: 2, y: 3)> Size: 6B\n-array([[ 18, 221, 159],\n-       [ 91, 239,  30]], dtype=uint8)\n+<xarray.Variable (x: 2, y: 3)> Size: 48B\n+array([[-3083827208917602196, -3083827208917602196, -3083827208917602196],\n+       [-3083827208917602196, -3083827208917602196, -3083827208917602196]])\n+Attributes:\n+    :         [False False]\n+    J\u00c3\u017f\u017e\u0102:    ['NaT']\n 
    \n
    \n

    You can also use this to specify that you want examples which are missing some part of the data structure, for instance

    \n
    # Generates a Variable with no attributes\n In [13]: xrst.variables(attrs=st.just({})).example()\n Out[13]: \n-<xarray.Variable (\u00d5: 5)> Size: 40B\n-array([       inf,        inf, 5.169e+115, 2.225e-308, 1.401e-045])\n+<xarray.Variable (\u0154\u0117a\u0129n: 2)> Size: 16B\n+array([-9223372036854727831, -9223372036854746411])\n 
    \n
    \n

    Through a combination of chaining strategies and fixing arguments, you can specify quite complicated requirements on the\n objects your chained strategy will generate.

    \n
    In [14]: fixed_x_variable_y_maybe_z = st.fixed_dictionaries(\n    ....:     {"x": st.just(2), "y": st.integers(3, 4)}, optional={"z": st.just(2)}\n    ....: )\n@@ -197,32 +205,39 @@\n In [15]: fixed_x_variable_y_maybe_z.example()\n Out[15]: {'x': 2, 'y': 3, 'z': 2}\n \n In [16]: special_variables = xrst.variables(dims=fixed_x_variable_y_maybe_z)\n \n In [17]: special_variables.example()\n Out[17]: \n-<xarray.Variable (x: 2, y: 4)> Size: 64B\n-array([[-9223372036854775598, -9223372036854727701,  -765380011776258377, -9223372035077253998],\n-       [ -756101856880953354, -9223372036854737559, -9223372036854723696, -9223372036854759933]])\n+<xarray.Variable (x: 2, y: 4, z: 2)> Size: 128B\n+array([[[-9223372036854734621, -9223372036854734621],\n+        [-9223372036854734621, -9223372036854734621],\n+        [-9223372036854775654, -9223372036854734621],\n+        [-9223372036854734621, -9223372036854734621]],\n+\n+       [[-9223372036854734621, -9223372036854734621],\n+        [-9223372036854754014, -9223372036854734621],\n+        [-9223372036854734621, -9223372036854734621],\n+        [-9223372036854775792, -9223372036854734621]]], shape=(2, 4, 2))\n Attributes:\n-    \u00cf\u0134\u017feC:    {'\u016a\u00e7\u0135\u017b\u017f': array([['NaT', 'NaT']], dtype='timedelta64[Y]'), '': ...\n+    L\u00e6:       \u0155\n+    \u0173\u00cf\u011e\u016e\u010f:    True\n+    \u013a\u0175\u013c:      True\n+    \u017fXa\u00e7\u017b:    ['\\x8e\\U000b0bbd\\U0009ff28']\n+    \u0150:        \u016f\n+    \u017e:        True\n+    \u0175\u010c\u00f0\u0149\u017c:    True\n+    :         \u00cem\n \n In [18]: special_variables.example()\n Out[18]: \n-<xarray.Variable (x: 2, y: 3)> Size: 12B\n-array([[ 11855, -14645,  -2561],\n-       [-18322, -22316, -20968]], dtype=int16)\n-Attributes:\n-    :         False\n-    \u00dc:        True\n-    \u0160\u017d:       False\n-    \u0166:        \u0176\n-    \u0136:        True\n-    5\u017f\u00ff\u017d\u014f:    \u00e9\n+<xarray.Variable (x: 2, y: 3)> Size: 6B\n+array([[0, 0, 0],\n+       [0, 0, 0]], dtype=int8)\n 
    \n
    \n

    Here we have used one of hypothesis\u2019 built-in strategies hypothesis.strategies.fixed_dictionaries() to create a\n strategy which generates mappings of dimension names to lengths (i.e. the size of the xarray object we want).\n This particular strategy will always generate an x dimension of length 2, and a y dimension of\n length either 3 or 4, and will sometimes also generate a z dimension of length 2.\n By feeding this strategy for dictionaries into the dims argument of xarray\u2019s variables() strategy,\n@@ -323,53 +338,47 @@\n ....: array_strategy_fn=xps.arrays,\n ....: dtype=xps.scalar_dtypes(),\n ....: )\n ....: \n \n In [32]: xp_variables.example()\n Out[32]: \n-<xarray.Variable (\u017b\u0126: 2, \u00d91: 1)> Size: 4B\n-array([[23794],\n- [-2592]], dtype=int16)\n+<xarray.Variable (\u00d3: 5)> Size: 40B\n+array([-9223372033794027569, -9223372033794027569, -9223372033794027569, -9223372033794027569,\n+ -9223372033794027569])\n Attributes:\n- f8\u017c\u010d: \u017b\u017c\u00b9\n- \u017e\u00d2\u017f\u017cv: None\n- \u0123\u010e\u00eb: None\n- \u017ev: [[2.]]\n- \u0142\u0100\u017e\u0115\u0165: [[-2147469683 -2147483559]\\n [ 2147483646 -2147440432]]\n- \u0165\u00c3u: \u0169\n- \u0106\u00d8\u00d8w\u00e3: False\n- : \n+ \u00e0\u00b2: None\n+ \u00fd: None\n \n \n

    Another array API-compliant duck array library would replace the import, e.g. import cupy as cp instead.

    \n
    \n
    \n

    Testing over Subsets of Dimensions\u00b6

    \n

    A common task when testing xarray user code is checking that your function works for all valid input dimensions.\n We can chain strategies to achieve this, for which the helper strategy unique_subset_of()\n is useful.

    \n

    It works for lists of dimension names

    \n
    In [33]: dims = ["x", "y", "z"]\n \n In [34]: xrst.unique_subset_of(dims).example()\n-Out[34]: ['x', 'z']\n+Out[34]: ['x', 'y', 'z']\n \n In [35]: xrst.unique_subset_of(dims).example()\n-Out[35]: ['x', 'z']\n+Out[35]: ['y', 'x', 'z']\n 
    \n
    \n

    as well as for mappings of dimension names to sizes

    \n
    In [36]: dim_sizes = {"x": 2, "y": 3, "z": 4}\n \n In [37]: xrst.unique_subset_of(dim_sizes).example()\n-Out[37]: {'y': 3}\n+Out[37]: {'z': 4, 'x': 2, 'y': 3}\n \n In [38]: xrst.unique_subset_of(dim_sizes).example()\n-Out[38]: {'y': 3, 'x': 2, 'z': 4}\n+Out[38]: {'z': 4, 'x': 2}\n 
    \n
    \n

    This is useful because operations like reductions can be performed over any subset of the xarray object\u2019s dimensions.\n For example we can write a pytest test that tests that a reduction gives the expected result when applying that reduction\n along any possible valid subset of the Variable\u2019s dimensions.

    \n
    import numpy.testing as npt\n \n", "details": [{"source1": "html2text {}", "source2": "html2text {}", "unified_diff": "@@ -28,34 +28,44 @@\n To see an example of what each of these strategies might produce, you can call\n one followed by the .example() method, which is a general hypothesis method\n valid for all strategies.\n In [2]: import xarray.testing.strategies as xrst\n \n In [3]: xrst.variables().example()\n Out[3]:\n- Size: 24B\n-array([       nan+nanj, -1.175e-38 +2.j, -3.333e-01 +0.j], dtype=complex64)\n+ Size: 16B\n+array([nan, nan, -0., nan], dtype=float32)\n+Attributes:\n+    \u00c1\u0148:       {'\u0166\u010b\u00b20': '\u0154\u017c', '\u016bQ\u017f\u00e7\u015b': '\u017c9\u012fc\u00f4'}\n+    \u0115\u0108\u00dc\u00f3\u017f:    {'\u0101\u00d0l\u0140\u0145': '\u00c8H\u0157\u017c', 'A\u017b\u0129': '', '\u017f\u0130\u0168\u00bdA': True, '': False, '\u017f\u017c':\n+Tr...\n \n In [4]: xrst.variables().example()\n Out[4]:\n- Size: 16B\n-array([-1.9  , -0.333])\n+ Size: 32B\n+array([[17709, 27830, 17709, 17709],\n+       [17709, 17709, 17709, 17709],\n+       [17709, 17709, 17709, 17709],\n+       [17709, 17709, 17709, 17709]], shape=(4, 4), dtype=int16)\n Attributes:\n-    \u017c:        None\n-    \u0136\u017f\u0153\u00d6\u017f:    None\n+    \u0104\u0113\u017d\u00eb\u017f:    ['' '\\x9e\u00a6=S']\n+    :         False\n+    \u0148\u014a\u017dI\u00f0:    5\u017d\u013e\u00ee\u00f6\n+    \u00da\u013e\u00c48\u017f:    True\n+    \u011f\u013e\u01031:     None\n+    \u015e\u0116:       \u0147\u017e\u0105\n+    \u00fc\u00be:       [b'\\x03\\x10Q(/+26\\xa2\\xe9\\xa1Ep\\x85@']\n \n In [5]: xrst.variables().example()\n Out[5]:\n- Size: 24B\n-array([[[1.798e+308, 1.798e+308, 1.798e+308]]])\n+ Size: 80B\n+array([-1.500e+00+1.000e+000j,  9.007e+15-6.429e+016j,        nan       +nanj,\n+        4.802e+16-1.766e+084j,       -inf-2.225e-308j])\n Attributes:\n-    1\u017b\u013d\u00c6\u00ca:    \u00ca\n-    \u012d\u017d\u017e\u00e1\u017c:    False\n-    \u0169E:       [['\u00d6' '\u00d6']\\n ['\u00d6' '\u00d6']]\n-    \u0142\u0135\u017dOE:    None\n+    \u00ceb:       [b'\\x1f']\n You can see that calling .example() multiple times will generate different\n examples, giving you an idea of the wide range of data that the xarray\n strategies can generate.\n In your tests however you should not use .example() - instead you should\n parameterize your tests with the hypothesis.given() decorator:\n In [6]: from hypothesis import given\n In [7]: @given(xrst.variables())\n@@ -67,67 +77,66 @@\n customise the contents of the generated examples.\n # generate a Variable containing an array with a complex number dtype, but all\n other details still arbitrary\n In [8]: from hypothesis.extra.numpy import complex_number_dtypes\n \n In [9]: xrst.variables(dtype=complex_number_dtypes()).example()\n Out[9]:\n- Size: 48B\n-array([-6.948e+15      +nanj, -1.000e+07-6.104e-05j, -0.000e+00-0.000e+00j, -\n-0.000e+00+1.401e-45j,\n-        0.000e+00-1.401e-45j, -3.403e+16+1.175e-38j], dtype=complex64)\n+ Size: 128B\n+array([[-1.175e-038-6.860e+016j,  1.100e+000-3.624e+016j, -2.335e+153-1.113e-\n+308j,\n+         5.351e+016+2.225e-311j],\n+       [ 4.032e+016+3.356e+116j, -2.640e-174       +nanj, -2.225e-\n+311+5.357e+016j,\n+        -1.648e-093-5.000e-001j]], dtype='>c16')\n Attributes:\n-    :         [b'']\n-    \u017bT\u0136a\u017c:    [['\\U000fb3d5' '`']\\n ['{' '{']]\n-    \u0114:        [b'\\xa3h']\n-    \u00bc\u0120\u00c3\u017e\u017c:    \u0156\u0120\u00e7\u00cbU\n-    \u016e:        False\n-    \u00c7:\n+    \u00c3:        [[b'B\\xe1?' b'\\xfe\\x08\\xd4f']\\n\n+[b'=dO\\xd23\\xe0\\xdd\\xf2\\xe9\\xed...\n+    \u0172\u0108\u0113\u017e\u017c:    \u013e\u00ff\u017f\n This also works with custom strategies, or strategies defined in other\n packages. For example you could imagine creating a chunks strategy to specify\n particular chunking patterns for a dask-backed array.\n *\b**\b**\b**\b* F\bFi\bix\bxi\bin\bng\bg A\bAr\brg\bgu\bum\bme\ben\bnt\bts\bs_\b?\b\u00b6 *\b**\b**\b**\b*\n If you want to fix one aspect of the data structure, whilst allowing variation\n in the generated examples over all other aspects, then use\n hypothesis.strategies.just().\n In [10]: import hypothesis.strategies as st\n \n # Generates only variable objects with dimensions [\"x\", \"y\"]\n In [11]: xrst.variables(dims=st.just([\"x\", \"y\"])).example()\n Out[11]:\n- Size: 36B\n-array([[     inf, -0.0e+00,      inf,      inf,      inf,      inf],\n-       [     inf,      inf,      inf,      inf,      inf,      inf],\n-       [     inf,  1.2e-07,  1.5e+00,      inf,      inf,      inf]], shape=(3,\n-6), dtype=float16)\n-Attributes:\n-    x\u00f2\u016f\u016f:     {'\u010f': ''}\n-    \u00ff\u017f\u00be\u017e\u0148:    {}\n-    \u00c7\u0114\u012c\u00dc\u0131:    {'\u00b2': array([[2547821043,      51546]], dtype='>u4'), 'u\u017e\u00c2':\n-Fa...\n+ Size: 30B\n+array([[  43, -108, -108, -108, -108, -108],\n+       [-108, -108, -108, -108,  122, -108],\n+       [-108,  -45, -122, -108, -108, -108],\n+       [-108, -108, -108, -108, -108, -108],\n+       [-108, -108, -108, -108, -108, -108]], shape=(5, 6), dtype=int8)\n (This is technically another example of chaining strategies -\n hypothesis.strategies.just() is simply a special strategy that just contains a\n single example.)\n To fix the length of dimensions you can instead pass dims as a mapping of\n dimension names to lengths (i.e. following xarray objects\u2019 .sizes() property),\n e.g.\n # Generates only variables with dimensions [\"x\", \"y\"], of lengths 2 & 3\n respectively\n In [12]: xrst.variables(dims=st.just({\"x\": 2, \"y\": 3})).example()\n Out[12]:\n- Size: 6B\n-array([[ 18, 221, 159],\n-       [ 91, 239,  30]], dtype=uint8)\n+ Size: 48B\n+array([[-3083827208917602196, -3083827208917602196, -3083827208917602196],\n+       [-3083827208917602196, -3083827208917602196, -3083827208917602196]])\n+Attributes:\n+    :         [False False]\n+    J\u00c3\u017f\u017e\u0102:    ['NaT']\n You can also use this to specify that you want examples which are missing some\n part of the data structure, for instance\n # Generates a Variable with no attributes\n In [13]: xrst.variables(attrs=st.just({})).example()\n Out[13]:\n- Size: 40B\n-array([       inf,        inf, 5.169e+115, 2.225e-308, 1.401e-045])\n+ Size: 16B\n+array([-9223372036854727831, -9223372036854746411])\n Through a combination of chaining strategies and fixing arguments, you can\n specify quite complicated requirements on the objects your chained strategy\n will generate.\n In [14]: fixed_x_variable_y_maybe_z = st.fixed_dictionaries(\n    ....:     {\"x\": st.just(2), \"y\": st.integers(3, 4)}, optional={\"z\": st.just\n (2)}\n    ....: )\n@@ -136,35 +145,39 @@\n In [15]: fixed_x_variable_y_maybe_z.example()\n Out[15]: {'x': 2, 'y': 3, 'z': 2}\n \n In [16]: special_variables = xrst.variables(dims=fixed_x_variable_y_maybe_z)\n \n In [17]: special_variables.example()\n Out[17]:\n- Size: 64B\n-array([[-9223372036854775598, -9223372036854727701,  -765380011776258377, -\n-9223372035077253998],\n-       [ -756101856880953354, -9223372036854737559, -9223372036854723696, -\n-9223372036854759933]])\n+ Size: 128B\n+array([[[-9223372036854734621, -9223372036854734621],\n+        [-9223372036854734621, -9223372036854734621],\n+        [-9223372036854775654, -9223372036854734621],\n+        [-9223372036854734621, -9223372036854734621]],\n+\n+       [[-9223372036854734621, -9223372036854734621],\n+        [-9223372036854754014, -9223372036854734621],\n+        [-9223372036854734621, -9223372036854734621],\n+        [-9223372036854775792, -9223372036854734621]]], shape=(2, 4, 2))\n Attributes:\n-    \u00cf\u0134\u017feC:    {'\u016a\u00e7\u0135\u017b\u017f': array([['NaT', 'NaT']], dtype='timedelta64[Y]'), '':\n-...\n+    L\u00e6:       \u0155\n+    \u0173\u00cf\u011e\u016e\u010f:    True\n+    \u013a\u0175\u013c:      True\n+    \u017fXa\u00e7\u017b:    ['\\x8e\\U000b0bbd\\U0009ff28']\n+    \u0150:        \u016f\n+    \u017e:        True\n+    \u0175\u010c\u00f0\u0149\u017c:    True\n+    :         \u00cem\n \n In [18]: special_variables.example()\n Out[18]:\n- Size: 12B\n-array([[ 11855, -14645,  -2561],\n-       [-18322, -22316, -20968]], dtype=int16)\n-Attributes:\n-    :         False\n-    \u00dc:        True\n-    \u0160\u017d:       False\n-    \u0166:        \u0176\n-    \u0136:        True\n-    5\u017f\u00ff\u017d\u014f:    \u00e9\n+ Size: 6B\n+array([[0, 0, 0],\n+       [0, 0, 0]], dtype=int8)\n Here we have used one of hypothesis\u2019 built-in strategies\n hypothesis.strategies.fixed_dictionaries() to create a strategy which generates\n mappings of dimension names to lengths (i.e. the size of the xarray object we\n want). This particular strategy will always generate an x dimension of length\n 2, and a y dimension of length either 3 or 4, and will sometimes also generate\n a z dimension of length 2. By feeding this strategy for dictionaries into the\n dims argument of xarray\u2019s variables() strategy, we can generate arbitrary\n@@ -258,48 +271,43 @@\n    ....:     array_strategy_fn=xps.arrays,\n    ....:     dtype=xps.scalar_dtypes(),\n    ....: )\n    ....:\n \n In [32]: xp_variables.example()\n Out[32]:\n- Size: 4B\n-array([[23794],\n-       [-2592]], dtype=int16)\n+ Size: 40B\n+array([-9223372033794027569, -9223372033794027569, -9223372033794027569, -\n+9223372033794027569,\n+       -9223372033794027569])\n Attributes:\n-    f8\u017c\u010d:     \u017b\u017c\u00b9\n-    \u017e\u00d2\u017f\u017cv:    None\n-    \u0123\u010e\u00eb:      None\n-    \u017ev:       [[2.]]\n-    \u0142\u0100\u017e\u0115\u0165:    [[-2147469683 -2147483559]\\n [ 2147483646 -2147440432]]\n-    \u0165\u00c3u:      \u0169\n-    \u0106\u00d8\u00d8w\u00e3:    False\n-    :\n+    \u00e0\u00b2:       None\n+    \u00fd:        None\n Another array API-compliant duck array library would replace the import, e.g.\n import cupy as cp instead.\n *\b**\b**\b**\b* T\bTe\bes\bst\bti\bin\bng\bg o\bov\bve\ber\br S\bSu\bub\bbs\bse\bet\bts\bs o\bof\bf D\bDi\bim\bme\ben\bns\bsi\bio\bon\bns\bs_\b?\b\u00b6 *\b**\b**\b**\b*\n A common task when testing xarray user code is checking that your function\n works for all valid input dimensions. We can chain strategies to achieve this,\n for which the helper strategy unique_subset_of() is useful.\n It works for lists of dimension names\n In [33]: dims = [\"x\", \"y\", \"z\"]\n \n In [34]: xrst.unique_subset_of(dims).example()\n-Out[34]: ['x', 'z']\n+Out[34]: ['x', 'y', 'z']\n \n In [35]: xrst.unique_subset_of(dims).example()\n-Out[35]: ['x', 'z']\n+Out[35]: ['y', 'x', 'z']\n as well as for mappings of dimension names to sizes\n In [36]: dim_sizes = {\"x\": 2, \"y\": 3, \"z\": 4}\n \n In [37]: xrst.unique_subset_of(dim_sizes).example()\n-Out[37]: {'y': 3}\n+Out[37]: {'z': 4, 'x': 2, 'y': 3}\n \n In [38]: xrst.unique_subset_of(dim_sizes).example()\n-Out[38]: {'y': 3, 'x': 2, 'z': 4}\n+Out[38]: {'z': 4, 'x': 2}\n This is useful because operations like reductions can be performed over any\n subset of the xarray object\u2019s dimensions. For example we can write a pytest\n test that tests that a reduction gives the expected result when applying that\n reduction along any possible valid subset of the Variable\u2019s dimensions.\n import numpy.testing as npt\n \n \n"}]}, {"source1": "./usr/share/doc/python-xarray-doc/html/whats-new.html", "source2": "./usr/share/doc/python-xarray-doc/html/whats-new.html", "unified_diff": "@@ -7936,15 +7936,15 @@\n 
  • New xray.Dataset.where method for masking xray objects according\n to some criteria. This works particularly well with multi-dimensional data:

    \n
    In [44]: ds = xray.Dataset(coords={"x": range(100), "y": range(100)})\n \n In [45]: ds["distance"] = np.sqrt(ds.x**2 + ds.y**2)\n \n In [46]: ds.distance.where(ds.distance < 100).plot()\n-Out[46]: <matplotlib.collections.QuadMesh at 0x7f93962802d0>\n+Out[46]: <matplotlib.collections.QuadMesh at 0x7f39570ce710>\n 
    \n
    \n \"_build/html/_static/where_example.png\"\n \n
  • \n
  • Added new methods xray.DataArray.diff and xray.Dataset.diff\n for finite difference calculations along a given axis.

  • \n", "details": [{"source1": "html2text {}", "source2": "html2text {}", "unified_diff": "@@ -5100,15 +5100,15 @@\n * New xray.Dataset.where method for masking xray objects according to some\n criteria. This works particularly well with multi-dimensional data:\n In [44]: ds = xray.Dataset(coords={\"x\": range(100), \"y\": range(100)})\n \n In [45]: ds[\"distance\"] = np.sqrt(ds.x**2 + ds.y**2)\n \n In [46]: ds.distance.where(ds.distance < 100).plot()\n- Out[46]: \n+ Out[46]: \n _\b[_\b__\bb_\bu_\bi_\bl_\bd_\b/_\bh_\bt_\bm_\bl_\b/_\b__\bs_\bt_\ba_\bt_\bi_\bc_\b/_\bw_\bh_\be_\br_\be_\b__\be_\bx_\ba_\bm_\bp_\bl_\be_\b._\bp_\bn_\bg_\b]\n * Added new methods xray.DataArray.diff and xray.Dataset.diff for finite\n difference calculations along a given axis.\n * New xray.DataArray.to_masked_array convenience method for returning a\n numpy.ma.MaskedArray.\n In [47]: da = xray.DataArray(np.random.random_sample(size=(5, 4)))\n \n"}]}]}]}]}]}