Skip to content

Instantly share code, notes, and snippets.

@fmaussion
Created May 8, 2022 14:31
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save fmaussion/48a33deae4fdee1f9433ec58c8956ac6 to your computer and use it in GitHub Desktop.
Save fmaussion/48a33deae4fdee1f9433ec58c8956ac6 to your computer and use it in GitHub Desktop.
Display the source blob
Display the rendered blob
Raw
{
"cells": [
{
"cell_type": "markdown",
"id": "5d3e13c5-f9dd-495f-83f7-b6bd740f7cdd",
"metadata": {},
"source": [
"# Dask experiments with mean() and groupby() over time dimension"
]
},
{
"cell_type": "code",
"execution_count": 3,
"id": "1f432595-053e-45b5-a750-a884d3bded4c",
"metadata": {},
"outputs": [
{
"data": {
"application/vnd.jupyter.widget-view+json": {
"model_id": "74035f2d1eea4acdada1004575e38773",
"version_major": 2,
"version_minor": 0
},
"text/plain": [
"Tab(children=(HTML(value='<div class=\"jp-RenderedHTMLCommon jp-RenderedHTML jp-mod-trusted jp-OutputArea-outpu…"
]
},
"metadata": {},
"output_type": "display_data"
}
],
"source": [
"from dask.distributed import Client\n",
"\n",
"# Setup a local cluster.\n",
"# By default this sets up 1 worker per core\n",
"client = Client(memory_limit=\"2 GiB\")\n",
"client.cluster"
]
},
{
"cell_type": "code",
"execution_count": 6,
"id": "8f8a687c-5700-4268-bcef-c246fe74582c",
"metadata": {},
"outputs": [],
"source": [
"import time"
]
},
{
"cell_type": "code",
"execution_count": 15,
"id": "0cd0527f-48c7-4b05-b063-0ed672a8285e",
"metadata": {},
"outputs": [],
"source": [
"import xarray as xr\n",
"import numpy as np\n",
"from dask.diagnostics import ProgressBar"
]
},
{
"cell_type": "markdown",
"id": "1f1e39c2-8c0e-496e-90ce-7acac919bec5",
"metadata": {},
"source": [
"## The dataset"
]
},
{
"cell_type": "code",
"execution_count": 5,
"id": "b3d52252-a2ac-4f32-b33e-ec3665d13977",
"metadata": {},
"outputs": [
{
"data": {
"text/html": [
"<div><svg style=\"position: absolute; width: 0; height: 0; overflow: hidden\">\n",
"<defs>\n",
"<symbol id=\"icon-database\" viewBox=\"0 0 32 32\">\n",
"<path d=\"M16 0c-8.837 0-16 2.239-16 5v4c0 2.761 7.163 5 16 5s16-2.239 16-5v-4c0-2.761-7.163-5-16-5z\"></path>\n",
"<path d=\"M16 17c-8.837 0-16-2.239-16-5v6c0 2.761 7.163 5 16 5s16-2.239 16-5v-6c0 2.761-7.163 5-16 5z\"></path>\n",
"<path d=\"M16 26c-8.837 0-16-2.239-16-5v6c0 2.761 7.163 5 16 5s16-2.239 16-5v-6c0 2.761-7.163 5-16 5z\"></path>\n",
"</symbol>\n",
"<symbol id=\"icon-file-text2\" viewBox=\"0 0 32 32\">\n",
"<path d=\"M28.681 7.159c-0.694-0.947-1.662-2.053-2.724-3.116s-2.169-2.030-3.116-2.724c-1.612-1.182-2.393-1.319-2.841-1.319h-15.5c-1.378 0-2.5 1.121-2.5 2.5v27c0 1.378 1.122 2.5 2.5 2.5h23c1.378 0 2.5-1.122 2.5-2.5v-19.5c0-0.448-0.137-1.23-1.319-2.841zM24.543 5.457c0.959 0.959 1.712 1.825 2.268 2.543h-4.811v-4.811c0.718 0.556 1.584 1.309 2.543 2.268zM28 29.5c0 0.271-0.229 0.5-0.5 0.5h-23c-0.271 0-0.5-0.229-0.5-0.5v-27c0-0.271 0.229-0.5 0.5-0.5 0 0 15.499-0 15.5 0v7c0 0.552 0.448 1 1 1h7v19.5z\"></path>\n",
"<path d=\"M23 26h-14c-0.552 0-1-0.448-1-1s0.448-1 1-1h14c0.552 0 1 0.448 1 1s-0.448 1-1 1z\"></path>\n",
"<path d=\"M23 22h-14c-0.552 0-1-0.448-1-1s0.448-1 1-1h14c0.552 0 1 0.448 1 1s-0.448 1-1 1z\"></path>\n",
"<path d=\"M23 18h-14c-0.552 0-1-0.448-1-1s0.448-1 1-1h14c0.552 0 1 0.448 1 1s-0.448 1-1 1z\"></path>\n",
"</symbol>\n",
"</defs>\n",
"</svg>\n",
"<style>/* CSS stylesheet for displaying xarray objects in jupyterlab.\n",
" *\n",
" */\n",
"\n",
":root {\n",
" --xr-font-color0: var(--jp-content-font-color0, rgba(0, 0, 0, 1));\n",
" --xr-font-color2: var(--jp-content-font-color2, rgba(0, 0, 0, 0.54));\n",
" --xr-font-color3: var(--jp-content-font-color3, rgba(0, 0, 0, 0.38));\n",
" --xr-border-color: var(--jp-border-color2, #e0e0e0);\n",
" --xr-disabled-color: var(--jp-layout-color3, #bdbdbd);\n",
" --xr-background-color: var(--jp-layout-color0, white);\n",
" --xr-background-color-row-even: var(--jp-layout-color1, white);\n",
" --xr-background-color-row-odd: var(--jp-layout-color2, #eeeeee);\n",
"}\n",
"\n",
"html[theme=dark],\n",
"body.vscode-dark {\n",
" --xr-font-color0: rgba(255, 255, 255, 1);\n",
" --xr-font-color2: rgba(255, 255, 255, 0.54);\n",
" --xr-font-color3: rgba(255, 255, 255, 0.38);\n",
" --xr-border-color: #1F1F1F;\n",
" --xr-disabled-color: #515151;\n",
" --xr-background-color: #111111;\n",
" --xr-background-color-row-even: #111111;\n",
" --xr-background-color-row-odd: #313131;\n",
"}\n",
"\n",
".xr-wrap {\n",
" display: block !important;\n",
" min-width: 300px;\n",
" max-width: 700px;\n",
"}\n",
"\n",
".xr-text-repr-fallback {\n",
" /* fallback to plain text repr when CSS is not injected (untrusted notebook) */\n",
" display: none;\n",
"}\n",
"\n",
".xr-header {\n",
" padding-top: 6px;\n",
" padding-bottom: 6px;\n",
" margin-bottom: 4px;\n",
" border-bottom: solid 1px var(--xr-border-color);\n",
"}\n",
"\n",
".xr-header > div,\n",
".xr-header > ul {\n",
" display: inline;\n",
" margin-top: 0;\n",
" margin-bottom: 0;\n",
"}\n",
"\n",
".xr-obj-type,\n",
".xr-array-name {\n",
" margin-left: 2px;\n",
" margin-right: 10px;\n",
"}\n",
"\n",
".xr-obj-type {\n",
" color: var(--xr-font-color2);\n",
"}\n",
"\n",
".xr-sections {\n",
" padding-left: 0 !important;\n",
" display: grid;\n",
" grid-template-columns: 150px auto auto 1fr 20px 20px;\n",
"}\n",
"\n",
".xr-section-item {\n",
" display: contents;\n",
"}\n",
"\n",
".xr-section-item input {\n",
" display: none;\n",
"}\n",
"\n",
".xr-section-item input + label {\n",
" color: var(--xr-disabled-color);\n",
"}\n",
"\n",
".xr-section-item input:enabled + label {\n",
" cursor: pointer;\n",
" color: var(--xr-font-color2);\n",
"}\n",
"\n",
".xr-section-item input:enabled + label:hover {\n",
" color: var(--xr-font-color0);\n",
"}\n",
"\n",
".xr-section-summary {\n",
" grid-column: 1;\n",
" color: var(--xr-font-color2);\n",
" font-weight: 500;\n",
"}\n",
"\n",
".xr-section-summary > span {\n",
" display: inline-block;\n",
" padding-left: 0.5em;\n",
"}\n",
"\n",
".xr-section-summary-in:disabled + label {\n",
" color: var(--xr-font-color2);\n",
"}\n",
"\n",
".xr-section-summary-in + label:before {\n",
" display: inline-block;\n",
" content: '►';\n",
" font-size: 11px;\n",
" width: 15px;\n",
" text-align: center;\n",
"}\n",
"\n",
".xr-section-summary-in:disabled + label:before {\n",
" color: var(--xr-disabled-color);\n",
"}\n",
"\n",
".xr-section-summary-in:checked + label:before {\n",
" content: '▼';\n",
"}\n",
"\n",
".xr-section-summary-in:checked + label > span {\n",
" display: none;\n",
"}\n",
"\n",
".xr-section-summary,\n",
".xr-section-inline-details {\n",
" padding-top: 4px;\n",
" padding-bottom: 4px;\n",
"}\n",
"\n",
".xr-section-inline-details {\n",
" grid-column: 2 / -1;\n",
"}\n",
"\n",
".xr-section-details {\n",
" display: none;\n",
" grid-column: 1 / -1;\n",
" margin-bottom: 5px;\n",
"}\n",
"\n",
".xr-section-summary-in:checked ~ .xr-section-details {\n",
" display: contents;\n",
"}\n",
"\n",
".xr-array-wrap {\n",
" grid-column: 1 / -1;\n",
" display: grid;\n",
" grid-template-columns: 20px auto;\n",
"}\n",
"\n",
".xr-array-wrap > label {\n",
" grid-column: 1;\n",
" vertical-align: top;\n",
"}\n",
"\n",
".xr-preview {\n",
" color: var(--xr-font-color3);\n",
"}\n",
"\n",
".xr-array-preview,\n",
".xr-array-data {\n",
" padding: 0 5px !important;\n",
" grid-column: 2;\n",
"}\n",
"\n",
".xr-array-data,\n",
".xr-array-in:checked ~ .xr-array-preview {\n",
" display: none;\n",
"}\n",
"\n",
".xr-array-in:checked ~ .xr-array-data,\n",
".xr-array-preview {\n",
" display: inline-block;\n",
"}\n",
"\n",
".xr-dim-list {\n",
" display: inline-block !important;\n",
" list-style: none;\n",
" padding: 0 !important;\n",
" margin: 0;\n",
"}\n",
"\n",
".xr-dim-list li {\n",
" display: inline-block;\n",
" padding: 0;\n",
" margin: 0;\n",
"}\n",
"\n",
".xr-dim-list:before {\n",
" content: '(';\n",
"}\n",
"\n",
".xr-dim-list:after {\n",
" content: ')';\n",
"}\n",
"\n",
".xr-dim-list li:not(:last-child):after {\n",
" content: ',';\n",
" padding-right: 5px;\n",
"}\n",
"\n",
".xr-has-index {\n",
" font-weight: bold;\n",
"}\n",
"\n",
".xr-var-list,\n",
".xr-var-item {\n",
" display: contents;\n",
"}\n",
"\n",
".xr-var-item > div,\n",
".xr-var-item label,\n",
".xr-var-item > .xr-var-name span {\n",
" background-color: var(--xr-background-color-row-even);\n",
" margin-bottom: 0;\n",
"}\n",
"\n",
".xr-var-item > .xr-var-name:hover span {\n",
" padding-right: 5px;\n",
"}\n",
"\n",
".xr-var-list > li:nth-child(odd) > div,\n",
".xr-var-list > li:nth-child(odd) > label,\n",
".xr-var-list > li:nth-child(odd) > .xr-var-name span {\n",
" background-color: var(--xr-background-color-row-odd);\n",
"}\n",
"\n",
".xr-var-name {\n",
" grid-column: 1;\n",
"}\n",
"\n",
".xr-var-dims {\n",
" grid-column: 2;\n",
"}\n",
"\n",
".xr-var-dtype {\n",
" grid-column: 3;\n",
" text-align: right;\n",
" color: var(--xr-font-color2);\n",
"}\n",
"\n",
".xr-var-preview {\n",
" grid-column: 4;\n",
"}\n",
"\n",
".xr-var-name,\n",
".xr-var-dims,\n",
".xr-var-dtype,\n",
".xr-preview,\n",
".xr-attrs dt {\n",
" white-space: nowrap;\n",
" overflow: hidden;\n",
" text-overflow: ellipsis;\n",
" padding-right: 10px;\n",
"}\n",
"\n",
".xr-var-name:hover,\n",
".xr-var-dims:hover,\n",
".xr-var-dtype:hover,\n",
".xr-attrs dt:hover {\n",
" overflow: visible;\n",
" width: auto;\n",
" z-index: 1;\n",
"}\n",
"\n",
".xr-var-attrs,\n",
".xr-var-data {\n",
" display: none;\n",
" background-color: var(--xr-background-color) !important;\n",
" padding-bottom: 5px !important;\n",
"}\n",
"\n",
".xr-var-attrs-in:checked ~ .xr-var-attrs,\n",
".xr-var-data-in:checked ~ .xr-var-data {\n",
" display: block;\n",
"}\n",
"\n",
".xr-var-data > table {\n",
" float: right;\n",
"}\n",
"\n",
".xr-var-name span,\n",
".xr-var-data,\n",
".xr-attrs {\n",
" padding-left: 25px !important;\n",
"}\n",
"\n",
".xr-attrs,\n",
".xr-var-attrs,\n",
".xr-var-data {\n",
" grid-column: 1 / -1;\n",
"}\n",
"\n",
"dl.xr-attrs {\n",
" padding: 0;\n",
" margin: 0;\n",
" display: grid;\n",
" grid-template-columns: 125px auto;\n",
"}\n",
"\n",
".xr-attrs dt,\n",
".xr-attrs dd {\n",
" padding: 0;\n",
" margin: 0;\n",
" float: left;\n",
" padding-right: 10px;\n",
" width: auto;\n",
"}\n",
"\n",
".xr-attrs dt {\n",
" font-weight: normal;\n",
" grid-column: 1;\n",
"}\n",
"\n",
".xr-attrs dt:hover span {\n",
" display: inline-block;\n",
" background: var(--xr-background-color);\n",
" padding-right: 10px;\n",
"}\n",
"\n",
".xr-attrs dd {\n",
" grid-column: 2;\n",
" white-space: pre-wrap;\n",
" word-break: break-all;\n",
"}\n",
"\n",
".xr-icon-database,\n",
".xr-icon-file-text2 {\n",
" display: inline-block;\n",
" vertical-align: middle;\n",
" width: 1em;\n",
" height: 1.5em !important;\n",
" stroke-width: 0;\n",
" stroke: currentColor;\n",
" fill: currentColor;\n",
"}\n",
"</style><pre class='xr-text-repr-fallback'>&lt;xarray.DataArray &#x27;tp&#x27; (time: 8760, latitude: 721, longitude: 1440)&gt;\n",
"dask.array&lt;concatenate, shape=(8760, 721, 1440), dtype=float32, chunksize=(744, 721, 1440), chunktype=numpy.ndarray&gt;\n",
"Coordinates:\n",
" * longitude (longitude) float32 0.0 0.25 0.5 0.75 ... 359.0 359.2 359.5 359.8\n",
" * latitude (latitude) float32 90.0 89.75 89.5 89.25 ... -89.5 -89.75 -90.0\n",
" * time (time) datetime64[ns] 2021-01-01 ... 2021-12-31T23:00:00\n",
"Attributes:\n",
" units: m\n",
" long_name: Total precipitation</pre><div class='xr-wrap' style='display:none'><div class='xr-header'><div class='xr-obj-type'>xarray.DataArray</div><div class='xr-array-name'>'tp'</div><ul class='xr-dim-list'><li><span class='xr-has-index'>time</span>: 8760</li><li><span class='xr-has-index'>latitude</span>: 721</li><li><span class='xr-has-index'>longitude</span>: 1440</li></ul></div><ul class='xr-sections'><li class='xr-section-item'><div class='xr-array-wrap'><input id='section-eca1d359-7d47-4aab-8161-668f62a0a9a8' class='xr-array-in' type='checkbox' checked><label for='section-eca1d359-7d47-4aab-8161-668f62a0a9a8' title='Show/hide data repr'><svg class='icon xr-icon-database'><use xlink:href='#icon-database'></use></svg></label><div class='xr-array-preview xr-preview'><span>dask.array&lt;chunksize=(744, 721, 1440), meta=np.ndarray&gt;</span></div><div class='xr-array-data'><table>\n",
" <tr>\n",
" <td>\n",
" <table>\n",
" <thead>\n",
" <tr>\n",
" <td> </td>\n",
" <th> Array </th>\n",
" <th> Chunk </th>\n",
" </tr>\n",
" </thead>\n",
" <tbody>\n",
" \n",
" <tr>\n",
" <th> Bytes </th>\n",
" <td> 33.88 GiB </td>\n",
" <td> 2.88 GiB </td>\n",
" </tr>\n",
" \n",
" <tr>\n",
" <th> Shape </th>\n",
" <td> (8760, 721, 1440) </td>\n",
" <td> (744, 721, 1440) </td>\n",
" </tr>\n",
" <tr>\n",
" <th> Count </th>\n",
" <td> 36 Tasks </td>\n",
" <td> 12 Chunks </td>\n",
" </tr>\n",
" <tr>\n",
" <th> Type </th>\n",
" <td> float32 </td>\n",
" <td> numpy.ndarray </td>\n",
" </tr>\n",
" </tbody>\n",
" </table>\n",
" </td>\n",
" <td>\n",
" <svg width=\"171\" height=\"158\" style=\"stroke:rgb(0,0,0);stroke-width:1\" >\n",
"\n",
" <!-- Horizontal lines -->\n",
" <line x1=\"10\" y1=\"0\" x2=\"80\" y2=\"70\" style=\"stroke-width:2\" />\n",
" <line x1=\"10\" y1=\"37\" x2=\"80\" y2=\"108\" style=\"stroke-width:2\" />\n",
"\n",
" <!-- Vertical lines -->\n",
" <line x1=\"10\" y1=\"0\" x2=\"10\" y2=\"37\" style=\"stroke-width:2\" />\n",
" <line x1=\"15\" y1=\"5\" x2=\"15\" y2=\"43\" />\n",
" <line x1=\"21\" y1=\"11\" x2=\"21\" y2=\"48\" />\n",
" <line x1=\"27\" y1=\"17\" x2=\"27\" y2=\"54\" />\n",
" <line x1=\"33\" y1=\"23\" x2=\"33\" y2=\"60\" />\n",
" <line x1=\"39\" y1=\"29\" x2=\"39\" y2=\"66\" />\n",
" <line x1=\"45\" y1=\"35\" x2=\"45\" y2=\"72\" />\n",
" <line x1=\"50\" y1=\"40\" x2=\"50\" y2=\"78\" />\n",
" <line x1=\"56\" y1=\"46\" x2=\"56\" y2=\"84\" />\n",
" <line x1=\"62\" y1=\"52\" x2=\"62\" y2=\"90\" />\n",
" <line x1=\"68\" y1=\"58\" x2=\"68\" y2=\"96\" />\n",
" <line x1=\"74\" y1=\"64\" x2=\"74\" y2=\"102\" />\n",
" <line x1=\"80\" y1=\"70\" x2=\"80\" y2=\"108\" style=\"stroke-width:2\" />\n",
"\n",
" <!-- Colored Rectangle -->\n",
" <polygon points=\"10.0,0.0 80.58823529411765,70.58823529411765 80.58823529411765,108.07999437241787 10.0,37.49175907830022\" style=\"fill:#ECB172A0;stroke-width:0\"/>\n",
"\n",
" <!-- Horizontal lines -->\n",
" <line x1=\"10\" y1=\"0\" x2=\"51\" y2=\"0\" style=\"stroke-width:2\" />\n",
" <line x1=\"15\" y1=\"5\" x2=\"57\" y2=\"5\" />\n",
" <line x1=\"21\" y1=\"11\" x2=\"62\" y2=\"11\" />\n",
" <line x1=\"27\" y1=\"17\" x2=\"68\" y2=\"17\" />\n",
" <line x1=\"33\" y1=\"23\" x2=\"74\" y2=\"23\" />\n",
" <line x1=\"39\" y1=\"29\" x2=\"80\" y2=\"29\" />\n",
" <line x1=\"45\" y1=\"35\" x2=\"86\" y2=\"35\" />\n",
" <line x1=\"50\" y1=\"40\" x2=\"92\" y2=\"40\" />\n",
" <line x1=\"56\" y1=\"46\" x2=\"98\" y2=\"46\" />\n",
" <line x1=\"62\" y1=\"52\" x2=\"103\" y2=\"52\" />\n",
" <line x1=\"68\" y1=\"58\" x2=\"109\" y2=\"58\" />\n",
" <line x1=\"74\" y1=\"64\" x2=\"115\" y2=\"64\" />\n",
" <line x1=\"80\" y1=\"70\" x2=\"121\" y2=\"70\" style=\"stroke-width:2\" />\n",
"\n",
" <!-- Vertical lines -->\n",
" <line x1=\"10\" y1=\"0\" x2=\"80\" y2=\"70\" style=\"stroke-width:2\" />\n",
" <line x1=\"51\" y1=\"0\" x2=\"121\" y2=\"70\" style=\"stroke-width:2\" />\n",
"\n",
" <!-- Colored Rectangle -->\n",
" <polygon points=\"10.0,0.0 51.13999720598501,0.0 121.72823250010266,70.58823529411765 80.58823529411765,70.58823529411765\" style=\"fill:#ECB172A0;stroke-width:0\"/>\n",
"\n",
" <!-- Horizontal lines -->\n",
" <line x1=\"80\" y1=\"70\" x2=\"121\" y2=\"70\" style=\"stroke-width:2\" />\n",
" <line x1=\"80\" y1=\"108\" x2=\"121\" y2=\"108\" style=\"stroke-width:2\" />\n",
"\n",
" <!-- Vertical lines -->\n",
" <line x1=\"80\" y1=\"70\" x2=\"80\" y2=\"108\" style=\"stroke-width:2\" />\n",
" <line x1=\"121\" y1=\"70\" x2=\"121\" y2=\"108\" style=\"stroke-width:2\" />\n",
"\n",
" <!-- Colored Rectangle -->\n",
" <polygon points=\"80.58823529411765,70.58823529411765 121.72823250010266,70.58823529411765 121.72823250010266,108.07999437241787 80.58823529411765,108.07999437241787\" style=\"fill:#ECB172A0;stroke-width:0\"/>\n",
"\n",
" <!-- Text -->\n",
" <text x=\"101.158234\" y=\"128.079994\" font-size=\"1.0rem\" font-weight=\"100\" text-anchor=\"middle\" >1440</text>\n",
" <text x=\"141.728233\" y=\"89.334115\" font-size=\"1.0rem\" font-weight=\"100\" text-anchor=\"middle\" transform=\"rotate(-90,141.728233,89.334115)\">721</text>\n",
" <text x=\"35.294118\" y=\"92.785877\" font-size=\"1.0rem\" font-weight=\"100\" text-anchor=\"middle\" transform=\"rotate(45,35.294118,92.785877)\">8760</text>\n",
"</svg>\n",
" </td>\n",
" </tr>\n",
"</table></div></div></li><li class='xr-section-item'><input id='section-0b2e5235-df95-440d-aaaf-275d69398844' class='xr-section-summary-in' type='checkbox' checked><label for='section-0b2e5235-df95-440d-aaaf-275d69398844' class='xr-section-summary' >Coordinates: <span>(3)</span></label><div class='xr-section-inline-details'></div><div class='xr-section-details'><ul class='xr-var-list'><li class='xr-var-item'><div class='xr-var-name'><span class='xr-has-index'>longitude</span></div><div class='xr-var-dims'>(longitude)</div><div class='xr-var-dtype'>float32</div><div class='xr-var-preview xr-preview'>0.0 0.25 0.5 ... 359.2 359.5 359.8</div><input id='attrs-7eb288b7-ae4e-4ccf-8902-af904d929f1d' class='xr-var-attrs-in' type='checkbox' ><label for='attrs-7eb288b7-ae4e-4ccf-8902-af904d929f1d' title='Show/Hide attributes'><svg class='icon xr-icon-file-text2'><use xlink:href='#icon-file-text2'></use></svg></label><input id='data-f956fc97-fb5b-42ab-8d35-c52eac1a7191' class='xr-var-data-in' type='checkbox'><label for='data-f956fc97-fb5b-42ab-8d35-c52eac1a7191' title='Show/Hide data repr'><svg class='icon xr-icon-database'><use xlink:href='#icon-database'></use></svg></label><div class='xr-var-attrs'><dl class='xr-attrs'><dt><span>units :</span></dt><dd>degrees_east</dd><dt><span>long_name :</span></dt><dd>longitude</dd></dl></div><div class='xr-var-data'><pre>array([0.0000e+00, 2.5000e-01, 5.0000e-01, ..., 3.5925e+02, 3.5950e+02,\n",
" 3.5975e+02], dtype=float32)</pre></div></li><li class='xr-var-item'><div class='xr-var-name'><span class='xr-has-index'>latitude</span></div><div class='xr-var-dims'>(latitude)</div><div class='xr-var-dtype'>float32</div><div class='xr-var-preview xr-preview'>90.0 89.75 89.5 ... -89.75 -90.0</div><input id='attrs-2bb50db2-7565-4391-8674-98bdc7823fd8' class='xr-var-attrs-in' type='checkbox' ><label for='attrs-2bb50db2-7565-4391-8674-98bdc7823fd8' title='Show/Hide attributes'><svg class='icon xr-icon-file-text2'><use xlink:href='#icon-file-text2'></use></svg></label><input id='data-66996adf-2239-456c-9efa-4aca532aaac7' class='xr-var-data-in' type='checkbox'><label for='data-66996adf-2239-456c-9efa-4aca532aaac7' title='Show/Hide data repr'><svg class='icon xr-icon-database'><use xlink:href='#icon-database'></use></svg></label><div class='xr-var-attrs'><dl class='xr-attrs'><dt><span>units :</span></dt><dd>degrees_north</dd><dt><span>long_name :</span></dt><dd>latitude</dd></dl></div><div class='xr-var-data'><pre>array([ 90. , 89.75, 89.5 , ..., -89.5 , -89.75, -90. ], dtype=float32)</pre></div></li><li class='xr-var-item'><div class='xr-var-name'><span class='xr-has-index'>time</span></div><div class='xr-var-dims'>(time)</div><div class='xr-var-dtype'>datetime64[ns]</div><div class='xr-var-preview xr-preview'>2021-01-01 ... 2021-12-31T23:00:00</div><input id='attrs-db4521c4-7aca-443b-9c06-cce68c449a62' class='xr-var-attrs-in' type='checkbox' ><label for='attrs-db4521c4-7aca-443b-9c06-cce68c449a62' title='Show/Hide attributes'><svg class='icon xr-icon-file-text2'><use xlink:href='#icon-file-text2'></use></svg></label><input id='data-f18c9622-c604-43e6-8aff-2d2d8ebdbb90' class='xr-var-data-in' type='checkbox'><label for='data-f18c9622-c604-43e6-8aff-2d2d8ebdbb90' title='Show/Hide data repr'><svg class='icon xr-icon-database'><use xlink:href='#icon-database'></use></svg></label><div class='xr-var-attrs'><dl class='xr-attrs'><dt><span>long_name :</span></dt><dd>time</dd></dl></div><div class='xr-var-data'><pre>array([&#x27;2021-01-01T00:00:00.000000000&#x27;, &#x27;2021-01-01T01:00:00.000000000&#x27;,\n",
" &#x27;2021-01-01T02:00:00.000000000&#x27;, ..., &#x27;2021-12-31T21:00:00.000000000&#x27;,\n",
" &#x27;2021-12-31T22:00:00.000000000&#x27;, &#x27;2021-12-31T23:00:00.000000000&#x27;],\n",
" dtype=&#x27;datetime64[ns]&#x27;)</pre></div></li></ul></div></li><li class='xr-section-item'><input id='section-0a654543-521a-4515-bd88-2923a8aaf518' class='xr-section-summary-in' type='checkbox' checked><label for='section-0a654543-521a-4515-bd88-2923a8aaf518' class='xr-section-summary' >Attributes: <span>(2)</span></label><div class='xr-section-inline-details'></div><div class='xr-section-details'><dl class='xr-attrs'><dt><span>units :</span></dt><dd>m</dd><dt><span>long_name :</span></dt><dd>Total precipitation</dd></dl></div></li></ul></div></div>"
],
"text/plain": [
"<xarray.DataArray 'tp' (time: 8760, latitude: 721, longitude: 1440)>\n",
"dask.array<concatenate, shape=(8760, 721, 1440), dtype=float32, chunksize=(744, 721, 1440), chunktype=numpy.ndarray>\n",
"Coordinates:\n",
" * longitude (longitude) float32 0.0 0.25 0.5 0.75 ... 359.0 359.2 359.5 359.8\n",
" * latitude (latitude) float32 90.0 89.75 89.5 89.25 ... -89.5 -89.75 -90.0\n",
" * time (time) datetime64[ns] 2021-01-01 ... 2021-12-31T23:00:00\n",
"Attributes:\n",
" units: m\n",
" long_name: Total precipitation"
]
},
"execution_count": 5,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"ds = xr.open_mfdataset('hourly_tp/ERA5_HiRes_Hourly_tp_2021_*.nc')\n",
"ds.tp"
]
},
{
"cell_type": "markdown",
"id": "6e41490a-5af6-4914-8653-6374751bf1e9",
"metadata": {},
"source": [
"## Exp 1: Averages over time"
]
},
{
"cell_type": "markdown",
"id": "7c223012-696a-456a-ab28-4df26579abf3",
"metadata": {},
"source": [
"### dask + `open_mfdataset`"
]
},
{
"cell_type": "code",
"execution_count": 9,
"id": "229af93b-d424-4da5-90c4-aa42db12f9ae",
"metadata": {},
"outputs": [
{
"data": {
"text/html": [
"<div><svg style=\"position: absolute; width: 0; height: 0; overflow: hidden\">\n",
"<defs>\n",
"<symbol id=\"icon-database\" viewBox=\"0 0 32 32\">\n",
"<path d=\"M16 0c-8.837 0-16 2.239-16 5v4c0 2.761 7.163 5 16 5s16-2.239 16-5v-4c0-2.761-7.163-5-16-5z\"></path>\n",
"<path d=\"M16 17c-8.837 0-16-2.239-16-5v6c0 2.761 7.163 5 16 5s16-2.239 16-5v-6c0 2.761-7.163 5-16 5z\"></path>\n",
"<path d=\"M16 26c-8.837 0-16-2.239-16-5v6c0 2.761 7.163 5 16 5s16-2.239 16-5v-6c0 2.761-7.163 5-16 5z\"></path>\n",
"</symbol>\n",
"<symbol id=\"icon-file-text2\" viewBox=\"0 0 32 32\">\n",
"<path d=\"M28.681 7.159c-0.694-0.947-1.662-2.053-2.724-3.116s-2.169-2.030-3.116-2.724c-1.612-1.182-2.393-1.319-2.841-1.319h-15.5c-1.378 0-2.5 1.121-2.5 2.5v27c0 1.378 1.122 2.5 2.5 2.5h23c1.378 0 2.5-1.122 2.5-2.5v-19.5c0-0.448-0.137-1.23-1.319-2.841zM24.543 5.457c0.959 0.959 1.712 1.825 2.268 2.543h-4.811v-4.811c0.718 0.556 1.584 1.309 2.543 2.268zM28 29.5c0 0.271-0.229 0.5-0.5 0.5h-23c-0.271 0-0.5-0.229-0.5-0.5v-27c0-0.271 0.229-0.5 0.5-0.5 0 0 15.499-0 15.5 0v7c0 0.552 0.448 1 1 1h7v19.5z\"></path>\n",
"<path d=\"M23 26h-14c-0.552 0-1-0.448-1-1s0.448-1 1-1h14c0.552 0 1 0.448 1 1s-0.448 1-1 1z\"></path>\n",
"<path d=\"M23 22h-14c-0.552 0-1-0.448-1-1s0.448-1 1-1h14c0.552 0 1 0.448 1 1s-0.448 1-1 1z\"></path>\n",
"<path d=\"M23 18h-14c-0.552 0-1-0.448-1-1s0.448-1 1-1h14c0.552 0 1 0.448 1 1s-0.448 1-1 1z\"></path>\n",
"</symbol>\n",
"</defs>\n",
"</svg>\n",
"<style>/* CSS stylesheet for displaying xarray objects in jupyterlab.\n",
" *\n",
" */\n",
"\n",
":root {\n",
" --xr-font-color0: var(--jp-content-font-color0, rgba(0, 0, 0, 1));\n",
" --xr-font-color2: var(--jp-content-font-color2, rgba(0, 0, 0, 0.54));\n",
" --xr-font-color3: var(--jp-content-font-color3, rgba(0, 0, 0, 0.38));\n",
" --xr-border-color: var(--jp-border-color2, #e0e0e0);\n",
" --xr-disabled-color: var(--jp-layout-color3, #bdbdbd);\n",
" --xr-background-color: var(--jp-layout-color0, white);\n",
" --xr-background-color-row-even: var(--jp-layout-color1, white);\n",
" --xr-background-color-row-odd: var(--jp-layout-color2, #eeeeee);\n",
"}\n",
"\n",
"html[theme=dark],\n",
"body.vscode-dark {\n",
" --xr-font-color0: rgba(255, 255, 255, 1);\n",
" --xr-font-color2: rgba(255, 255, 255, 0.54);\n",
" --xr-font-color3: rgba(255, 255, 255, 0.38);\n",
" --xr-border-color: #1F1F1F;\n",
" --xr-disabled-color: #515151;\n",
" --xr-background-color: #111111;\n",
" --xr-background-color-row-even: #111111;\n",
" --xr-background-color-row-odd: #313131;\n",
"}\n",
"\n",
".xr-wrap {\n",
" display: block !important;\n",
" min-width: 300px;\n",
" max-width: 700px;\n",
"}\n",
"\n",
".xr-text-repr-fallback {\n",
" /* fallback to plain text repr when CSS is not injected (untrusted notebook) */\n",
" display: none;\n",
"}\n",
"\n",
".xr-header {\n",
" padding-top: 6px;\n",
" padding-bottom: 6px;\n",
" margin-bottom: 4px;\n",
" border-bottom: solid 1px var(--xr-border-color);\n",
"}\n",
"\n",
".xr-header > div,\n",
".xr-header > ul {\n",
" display: inline;\n",
" margin-top: 0;\n",
" margin-bottom: 0;\n",
"}\n",
"\n",
".xr-obj-type,\n",
".xr-array-name {\n",
" margin-left: 2px;\n",
" margin-right: 10px;\n",
"}\n",
"\n",
".xr-obj-type {\n",
" color: var(--xr-font-color2);\n",
"}\n",
"\n",
".xr-sections {\n",
" padding-left: 0 !important;\n",
" display: grid;\n",
" grid-template-columns: 150px auto auto 1fr 20px 20px;\n",
"}\n",
"\n",
".xr-section-item {\n",
" display: contents;\n",
"}\n",
"\n",
".xr-section-item input {\n",
" display: none;\n",
"}\n",
"\n",
".xr-section-item input + label {\n",
" color: var(--xr-disabled-color);\n",
"}\n",
"\n",
".xr-section-item input:enabled + label {\n",
" cursor: pointer;\n",
" color: var(--xr-font-color2);\n",
"}\n",
"\n",
".xr-section-item input:enabled + label:hover {\n",
" color: var(--xr-font-color0);\n",
"}\n",
"\n",
".xr-section-summary {\n",
" grid-column: 1;\n",
" color: var(--xr-font-color2);\n",
" font-weight: 500;\n",
"}\n",
"\n",
".xr-section-summary > span {\n",
" display: inline-block;\n",
" padding-left: 0.5em;\n",
"}\n",
"\n",
".xr-section-summary-in:disabled + label {\n",
" color: var(--xr-font-color2);\n",
"}\n",
"\n",
".xr-section-summary-in + label:before {\n",
" display: inline-block;\n",
" content: '►';\n",
" font-size: 11px;\n",
" width: 15px;\n",
" text-align: center;\n",
"}\n",
"\n",
".xr-section-summary-in:disabled + label:before {\n",
" color: var(--xr-disabled-color);\n",
"}\n",
"\n",
".xr-section-summary-in:checked + label:before {\n",
" content: '▼';\n",
"}\n",
"\n",
".xr-section-summary-in:checked + label > span {\n",
" display: none;\n",
"}\n",
"\n",
".xr-section-summary,\n",
".xr-section-inline-details {\n",
" padding-top: 4px;\n",
" padding-bottom: 4px;\n",
"}\n",
"\n",
".xr-section-inline-details {\n",
" grid-column: 2 / -1;\n",
"}\n",
"\n",
".xr-section-details {\n",
" display: none;\n",
" grid-column: 1 / -1;\n",
" margin-bottom: 5px;\n",
"}\n",
"\n",
".xr-section-summary-in:checked ~ .xr-section-details {\n",
" display: contents;\n",
"}\n",
"\n",
".xr-array-wrap {\n",
" grid-column: 1 / -1;\n",
" display: grid;\n",
" grid-template-columns: 20px auto;\n",
"}\n",
"\n",
".xr-array-wrap > label {\n",
" grid-column: 1;\n",
" vertical-align: top;\n",
"}\n",
"\n",
".xr-preview {\n",
" color: var(--xr-font-color3);\n",
"}\n",
"\n",
".xr-array-preview,\n",
".xr-array-data {\n",
" padding: 0 5px !important;\n",
" grid-column: 2;\n",
"}\n",
"\n",
".xr-array-data,\n",
".xr-array-in:checked ~ .xr-array-preview {\n",
" display: none;\n",
"}\n",
"\n",
".xr-array-in:checked ~ .xr-array-data,\n",
".xr-array-preview {\n",
" display: inline-block;\n",
"}\n",
"\n",
".xr-dim-list {\n",
" display: inline-block !important;\n",
" list-style: none;\n",
" padding: 0 !important;\n",
" margin: 0;\n",
"}\n",
"\n",
".xr-dim-list li {\n",
" display: inline-block;\n",
" padding: 0;\n",
" margin: 0;\n",
"}\n",
"\n",
".xr-dim-list:before {\n",
" content: '(';\n",
"}\n",
"\n",
".xr-dim-list:after {\n",
" content: ')';\n",
"}\n",
"\n",
".xr-dim-list li:not(:last-child):after {\n",
" content: ',';\n",
" padding-right: 5px;\n",
"}\n",
"\n",
".xr-has-index {\n",
" font-weight: bold;\n",
"}\n",
"\n",
".xr-var-list,\n",
".xr-var-item {\n",
" display: contents;\n",
"}\n",
"\n",
".xr-var-item > div,\n",
".xr-var-item label,\n",
".xr-var-item > .xr-var-name span {\n",
" background-color: var(--xr-background-color-row-even);\n",
" margin-bottom: 0;\n",
"}\n",
"\n",
".xr-var-item > .xr-var-name:hover span {\n",
" padding-right: 5px;\n",
"}\n",
"\n",
".xr-var-list > li:nth-child(odd) > div,\n",
".xr-var-list > li:nth-child(odd) > label,\n",
".xr-var-list > li:nth-child(odd) > .xr-var-name span {\n",
" background-color: var(--xr-background-color-row-odd);\n",
"}\n",
"\n",
".xr-var-name {\n",
" grid-column: 1;\n",
"}\n",
"\n",
".xr-var-dims {\n",
" grid-column: 2;\n",
"}\n",
"\n",
".xr-var-dtype {\n",
" grid-column: 3;\n",
" text-align: right;\n",
" color: var(--xr-font-color2);\n",
"}\n",
"\n",
".xr-var-preview {\n",
" grid-column: 4;\n",
"}\n",
"\n",
".xr-var-name,\n",
".xr-var-dims,\n",
".xr-var-dtype,\n",
".xr-preview,\n",
".xr-attrs dt {\n",
" white-space: nowrap;\n",
" overflow: hidden;\n",
" text-overflow: ellipsis;\n",
" padding-right: 10px;\n",
"}\n",
"\n",
".xr-var-name:hover,\n",
".xr-var-dims:hover,\n",
".xr-var-dtype:hover,\n",
".xr-attrs dt:hover {\n",
" overflow: visible;\n",
" width: auto;\n",
" z-index: 1;\n",
"}\n",
"\n",
".xr-var-attrs,\n",
".xr-var-data {\n",
" display: none;\n",
" background-color: var(--xr-background-color) !important;\n",
" padding-bottom: 5px !important;\n",
"}\n",
"\n",
".xr-var-attrs-in:checked ~ .xr-var-attrs,\n",
".xr-var-data-in:checked ~ .xr-var-data {\n",
" display: block;\n",
"}\n",
"\n",
".xr-var-data > table {\n",
" float: right;\n",
"}\n",
"\n",
".xr-var-name span,\n",
".xr-var-data,\n",
".xr-attrs {\n",
" padding-left: 25px !important;\n",
"}\n",
"\n",
".xr-attrs,\n",
".xr-var-attrs,\n",
".xr-var-data {\n",
" grid-column: 1 / -1;\n",
"}\n",
"\n",
"dl.xr-attrs {\n",
" padding: 0;\n",
" margin: 0;\n",
" display: grid;\n",
" grid-template-columns: 125px auto;\n",
"}\n",
"\n",
".xr-attrs dt,\n",
".xr-attrs dd {\n",
" padding: 0;\n",
" margin: 0;\n",
" float: left;\n",
" padding-right: 10px;\n",
" width: auto;\n",
"}\n",
"\n",
".xr-attrs dt {\n",
" font-weight: normal;\n",
" grid-column: 1;\n",
"}\n",
"\n",
".xr-attrs dt:hover span {\n",
" display: inline-block;\n",
" background: var(--xr-background-color);\n",
" padding-right: 10px;\n",
"}\n",
"\n",
".xr-attrs dd {\n",
" grid-column: 2;\n",
" white-space: pre-wrap;\n",
" word-break: break-all;\n",
"}\n",
"\n",
".xr-icon-database,\n",
".xr-icon-file-text2 {\n",
" display: inline-block;\n",
" vertical-align: middle;\n",
" width: 1em;\n",
" height: 1.5em !important;\n",
" stroke-width: 0;\n",
" stroke: currentColor;\n",
" fill: currentColor;\n",
"}\n",
"</style><pre class='xr-text-repr-fallback'>&lt;xarray.DataArray &#x27;tp&#x27; (time: 8760, latitude: 721, longitude: 1440)&gt;\n",
"dask.array&lt;concatenate, shape=(8760, 721, 1440), dtype=float32, chunksize=(744, 50, 1440), chunktype=numpy.ndarray&gt;\n",
"Coordinates:\n",
" * longitude (longitude) float32 0.0 0.25 0.5 0.75 ... 359.0 359.2 359.5 359.8\n",
" * latitude (latitude) float32 90.0 89.75 89.5 89.25 ... -89.5 -89.75 -90.0\n",
" * time (time) datetime64[ns] 2021-01-01 ... 2021-12-31T23:00:00\n",
"Attributes:\n",
" units: m\n",
" long_name: Total precipitation</pre><div class='xr-wrap' style='display:none'><div class='xr-header'><div class='xr-obj-type'>xarray.DataArray</div><div class='xr-array-name'>'tp'</div><ul class='xr-dim-list'><li><span class='xr-has-index'>time</span>: 8760</li><li><span class='xr-has-index'>latitude</span>: 721</li><li><span class='xr-has-index'>longitude</span>: 1440</li></ul></div><ul class='xr-sections'><li class='xr-section-item'><div class='xr-array-wrap'><input id='section-7d29a1ad-e7f7-48b7-a2f0-b178d9905f53' class='xr-array-in' type='checkbox' checked><label for='section-7d29a1ad-e7f7-48b7-a2f0-b178d9905f53' title='Show/hide data repr'><svg class='icon xr-icon-database'><use xlink:href='#icon-database'></use></svg></label><div class='xr-array-preview xr-preview'><span>dask.array&lt;chunksize=(744, 50, 1440), meta=np.ndarray&gt;</span></div><div class='xr-array-data'><table>\n",
" <tr>\n",
" <td>\n",
" <table>\n",
" <thead>\n",
" <tr>\n",
" <td> </td>\n",
" <th> Array </th>\n",
" <th> Chunk </th>\n",
" </tr>\n",
" </thead>\n",
" <tbody>\n",
" \n",
" <tr>\n",
" <th> Bytes </th>\n",
" <td> 33.88 GiB </td>\n",
" <td> 204.35 MiB </td>\n",
" </tr>\n",
" \n",
" <tr>\n",
" <th> Shape </th>\n",
" <td> (8760, 721, 1440) </td>\n",
" <td> (744, 50, 1440) </td>\n",
" </tr>\n",
" <tr>\n",
" <th> Count </th>\n",
" <td> 372 Tasks </td>\n",
" <td> 180 Chunks </td>\n",
" </tr>\n",
" <tr>\n",
" <th> Type </th>\n",
" <td> float32 </td>\n",
" <td> numpy.ndarray </td>\n",
" </tr>\n",
" </tbody>\n",
" </table>\n",
" </td>\n",
" <td>\n",
" <svg width=\"171\" height=\"158\" style=\"stroke:rgb(0,0,0);stroke-width:1\" >\n",
"\n",
" <!-- Horizontal lines -->\n",
" <line x1=\"10\" y1=\"0\" x2=\"80\" y2=\"70\" style=\"stroke-width:2\" />\n",
" <line x1=\"10\" y1=\"2\" x2=\"80\" y2=\"73\" />\n",
" <line x1=\"10\" y1=\"5\" x2=\"80\" y2=\"75\" />\n",
" <line x1=\"10\" y1=\"7\" x2=\"80\" y2=\"78\" />\n",
" <line x1=\"10\" y1=\"10\" x2=\"80\" y2=\"80\" />\n",
" <line x1=\"10\" y1=\"12\" x2=\"80\" y2=\"83\" />\n",
" <line x1=\"10\" y1=\"15\" x2=\"80\" y2=\"86\" />\n",
" <line x1=\"10\" y1=\"18\" x2=\"80\" y2=\"88\" />\n",
" <line x1=\"10\" y1=\"20\" x2=\"80\" y2=\"91\" />\n",
" <line x1=\"10\" y1=\"23\" x2=\"80\" y2=\"93\" />\n",
" <line x1=\"10\" y1=\"25\" x2=\"80\" y2=\"96\" />\n",
" <line x1=\"10\" y1=\"28\" x2=\"80\" y2=\"99\" />\n",
" <line x1=\"10\" y1=\"31\" x2=\"80\" y2=\"101\" />\n",
" <line x1=\"10\" y1=\"33\" x2=\"80\" y2=\"104\" />\n",
" <line x1=\"10\" y1=\"36\" x2=\"80\" y2=\"106\" />\n",
" <line x1=\"10\" y1=\"37\" x2=\"80\" y2=\"108\" style=\"stroke-width:2\" />\n",
"\n",
" <!-- Vertical lines -->\n",
" <line x1=\"10\" y1=\"0\" x2=\"10\" y2=\"37\" style=\"stroke-width:2\" />\n",
" <line x1=\"15\" y1=\"5\" x2=\"15\" y2=\"43\" />\n",
" <line x1=\"21\" y1=\"11\" x2=\"21\" y2=\"48\" />\n",
" <line x1=\"27\" y1=\"17\" x2=\"27\" y2=\"54\" />\n",
" <line x1=\"33\" y1=\"23\" x2=\"33\" y2=\"60\" />\n",
" <line x1=\"39\" y1=\"29\" x2=\"39\" y2=\"66\" />\n",
" <line x1=\"45\" y1=\"35\" x2=\"45\" y2=\"72\" />\n",
" <line x1=\"50\" y1=\"40\" x2=\"50\" y2=\"78\" />\n",
" <line x1=\"56\" y1=\"46\" x2=\"56\" y2=\"84\" />\n",
" <line x1=\"62\" y1=\"52\" x2=\"62\" y2=\"90\" />\n",
" <line x1=\"68\" y1=\"58\" x2=\"68\" y2=\"96\" />\n",
" <line x1=\"74\" y1=\"64\" x2=\"74\" y2=\"102\" />\n",
" <line x1=\"80\" y1=\"70\" x2=\"80\" y2=\"108\" style=\"stroke-width:2\" />\n",
"\n",
" <!-- Colored Rectangle -->\n",
" <polygon points=\"10.0,0.0 80.58823529411765,70.58823529411765 80.58823529411765,108.07999437241787 10.0,37.49175907830022\" style=\"fill:#ECB172A0;stroke-width:0\"/>\n",
"\n",
" <!-- Horizontal lines -->\n",
" <line x1=\"10\" y1=\"0\" x2=\"51\" y2=\"0\" style=\"stroke-width:2\" />\n",
" <line x1=\"15\" y1=\"5\" x2=\"57\" y2=\"5\" />\n",
" <line x1=\"21\" y1=\"11\" x2=\"62\" y2=\"11\" />\n",
" <line x1=\"27\" y1=\"17\" x2=\"68\" y2=\"17\" />\n",
" <line x1=\"33\" y1=\"23\" x2=\"74\" y2=\"23\" />\n",
" <line x1=\"39\" y1=\"29\" x2=\"80\" y2=\"29\" />\n",
" <line x1=\"45\" y1=\"35\" x2=\"86\" y2=\"35\" />\n",
" <line x1=\"50\" y1=\"40\" x2=\"92\" y2=\"40\" />\n",
" <line x1=\"56\" y1=\"46\" x2=\"98\" y2=\"46\" />\n",
" <line x1=\"62\" y1=\"52\" x2=\"103\" y2=\"52\" />\n",
" <line x1=\"68\" y1=\"58\" x2=\"109\" y2=\"58\" />\n",
" <line x1=\"74\" y1=\"64\" x2=\"115\" y2=\"64\" />\n",
" <line x1=\"80\" y1=\"70\" x2=\"121\" y2=\"70\" style=\"stroke-width:2\" />\n",
"\n",
" <!-- Vertical lines -->\n",
" <line x1=\"10\" y1=\"0\" x2=\"80\" y2=\"70\" style=\"stroke-width:2\" />\n",
" <line x1=\"51\" y1=\"0\" x2=\"121\" y2=\"70\" style=\"stroke-width:2\" />\n",
"\n",
" <!-- Colored Rectangle -->\n",
" <polygon points=\"10.0,0.0 51.13999720598501,0.0 121.72823250010266,70.58823529411765 80.58823529411765,70.58823529411765\" style=\"fill:#ECB172A0;stroke-width:0\"/>\n",
"\n",
" <!-- Horizontal lines -->\n",
" <line x1=\"80\" y1=\"70\" x2=\"121\" y2=\"70\" style=\"stroke-width:2\" />\n",
" <line x1=\"80\" y1=\"73\" x2=\"121\" y2=\"73\" />\n",
" <line x1=\"80\" y1=\"75\" x2=\"121\" y2=\"75\" />\n",
" <line x1=\"80\" y1=\"78\" x2=\"121\" y2=\"78\" />\n",
" <line x1=\"80\" y1=\"80\" x2=\"121\" y2=\"80\" />\n",
" <line x1=\"80\" y1=\"83\" x2=\"121\" y2=\"83\" />\n",
" <line x1=\"80\" y1=\"86\" x2=\"121\" y2=\"86\" />\n",
" <line x1=\"80\" y1=\"88\" x2=\"121\" y2=\"88\" />\n",
" <line x1=\"80\" y1=\"91\" x2=\"121\" y2=\"91\" />\n",
" <line x1=\"80\" y1=\"93\" x2=\"121\" y2=\"93\" />\n",
" <line x1=\"80\" y1=\"96\" x2=\"121\" y2=\"96\" />\n",
" <line x1=\"80\" y1=\"99\" x2=\"121\" y2=\"99\" />\n",
" <line x1=\"80\" y1=\"101\" x2=\"121\" y2=\"101\" />\n",
" <line x1=\"80\" y1=\"104\" x2=\"121\" y2=\"104\" />\n",
" <line x1=\"80\" y1=\"106\" x2=\"121\" y2=\"106\" />\n",
" <line x1=\"80\" y1=\"108\" x2=\"121\" y2=\"108\" style=\"stroke-width:2\" />\n",
"\n",
" <!-- Vertical lines -->\n",
" <line x1=\"80\" y1=\"70\" x2=\"80\" y2=\"108\" style=\"stroke-width:2\" />\n",
" <line x1=\"121\" y1=\"70\" x2=\"121\" y2=\"108\" style=\"stroke-width:2\" />\n",
"\n",
" <!-- Colored Rectangle -->\n",
" <polygon points=\"80.58823529411765,70.58823529411765 121.72823250010266,70.58823529411765 121.72823250010266,108.07999437241787 80.58823529411765,108.07999437241787\" style=\"fill:#ECB172A0;stroke-width:0\"/>\n",
"\n",
" <!-- Text -->\n",
" <text x=\"101.158234\" y=\"128.079994\" font-size=\"1.0rem\" font-weight=\"100\" text-anchor=\"middle\" >1440</text>\n",
" <text x=\"141.728233\" y=\"89.334115\" font-size=\"1.0rem\" font-weight=\"100\" text-anchor=\"middle\" transform=\"rotate(-90,141.728233,89.334115)\">721</text>\n",
" <text x=\"35.294118\" y=\"92.785877\" font-size=\"1.0rem\" font-weight=\"100\" text-anchor=\"middle\" transform=\"rotate(45,35.294118,92.785877)\">8760</text>\n",
"</svg>\n",
" </td>\n",
" </tr>\n",
"</table></div></div></li><li class='xr-section-item'><input id='section-368e2e7f-7243-4f07-af06-d9af33fe1444' class='xr-section-summary-in' type='checkbox' checked><label for='section-368e2e7f-7243-4f07-af06-d9af33fe1444' class='xr-section-summary' >Coordinates: <span>(3)</span></label><div class='xr-section-inline-details'></div><div class='xr-section-details'><ul class='xr-var-list'><li class='xr-var-item'><div class='xr-var-name'><span class='xr-has-index'>longitude</span></div><div class='xr-var-dims'>(longitude)</div><div class='xr-var-dtype'>float32</div><div class='xr-var-preview xr-preview'>0.0 0.25 0.5 ... 359.2 359.5 359.8</div><input id='attrs-a6395503-fef5-4012-a350-504df1a7b8a0' class='xr-var-attrs-in' type='checkbox' ><label for='attrs-a6395503-fef5-4012-a350-504df1a7b8a0' title='Show/Hide attributes'><svg class='icon xr-icon-file-text2'><use xlink:href='#icon-file-text2'></use></svg></label><input id='data-241606b4-619b-4fc9-9877-f159bcf24626' class='xr-var-data-in' type='checkbox'><label for='data-241606b4-619b-4fc9-9877-f159bcf24626' title='Show/Hide data repr'><svg class='icon xr-icon-database'><use xlink:href='#icon-database'></use></svg></label><div class='xr-var-attrs'><dl class='xr-attrs'><dt><span>units :</span></dt><dd>degrees_east</dd><dt><span>long_name :</span></dt><dd>longitude</dd></dl></div><div class='xr-var-data'><pre>array([0.0000e+00, 2.5000e-01, 5.0000e-01, ..., 3.5925e+02, 3.5950e+02,\n",
" 3.5975e+02], dtype=float32)</pre></div></li><li class='xr-var-item'><div class='xr-var-name'><span class='xr-has-index'>latitude</span></div><div class='xr-var-dims'>(latitude)</div><div class='xr-var-dtype'>float32</div><div class='xr-var-preview xr-preview'>90.0 89.75 89.5 ... -89.75 -90.0</div><input id='attrs-2275a5ca-2a76-4933-81cf-fff6b5f8bbd7' class='xr-var-attrs-in' type='checkbox' ><label for='attrs-2275a5ca-2a76-4933-81cf-fff6b5f8bbd7' title='Show/Hide attributes'><svg class='icon xr-icon-file-text2'><use xlink:href='#icon-file-text2'></use></svg></label><input id='data-5a600247-0eaf-477e-978b-62b87c047dfe' class='xr-var-data-in' type='checkbox'><label for='data-5a600247-0eaf-477e-978b-62b87c047dfe' title='Show/Hide data repr'><svg class='icon xr-icon-database'><use xlink:href='#icon-database'></use></svg></label><div class='xr-var-attrs'><dl class='xr-attrs'><dt><span>units :</span></dt><dd>degrees_north</dd><dt><span>long_name :</span></dt><dd>latitude</dd></dl></div><div class='xr-var-data'><pre>array([ 90. , 89.75, 89.5 , ..., -89.5 , -89.75, -90. ], dtype=float32)</pre></div></li><li class='xr-var-item'><div class='xr-var-name'><span class='xr-has-index'>time</span></div><div class='xr-var-dims'>(time)</div><div class='xr-var-dtype'>datetime64[ns]</div><div class='xr-var-preview xr-preview'>2021-01-01 ... 2021-12-31T23:00:00</div><input id='attrs-365fba73-d14c-4a90-aa51-0197103e80e5' class='xr-var-attrs-in' type='checkbox' ><label for='attrs-365fba73-d14c-4a90-aa51-0197103e80e5' title='Show/Hide attributes'><svg class='icon xr-icon-file-text2'><use xlink:href='#icon-file-text2'></use></svg></label><input id='data-98037545-cc06-4198-aa0b-932f2a08fc08' class='xr-var-data-in' type='checkbox'><label for='data-98037545-cc06-4198-aa0b-932f2a08fc08' title='Show/Hide data repr'><svg class='icon xr-icon-database'><use xlink:href='#icon-database'></use></svg></label><div class='xr-var-attrs'><dl class='xr-attrs'><dt><span>long_name :</span></dt><dd>time</dd></dl></div><div class='xr-var-data'><pre>array([&#x27;2021-01-01T00:00:00.000000000&#x27;, &#x27;2021-01-01T01:00:00.000000000&#x27;,\n",
" &#x27;2021-01-01T02:00:00.000000000&#x27;, ..., &#x27;2021-12-31T21:00:00.000000000&#x27;,\n",
" &#x27;2021-12-31T22:00:00.000000000&#x27;, &#x27;2021-12-31T23:00:00.000000000&#x27;],\n",
" dtype=&#x27;datetime64[ns]&#x27;)</pre></div></li></ul></div></li><li class='xr-section-item'><input id='section-3f129ce3-8717-4523-a268-c5a2b1ac4607' class='xr-section-summary-in' type='checkbox' checked><label for='section-3f129ce3-8717-4523-a268-c5a2b1ac4607' class='xr-section-summary' >Attributes: <span>(2)</span></label><div class='xr-section-inline-details'></div><div class='xr-section-details'><dl class='xr-attrs'><dt><span>units :</span></dt><dd>m</dd><dt><span>long_name :</span></dt><dd>Total precipitation</dd></dl></div></li></ul></div></div>"
],
"text/plain": [
"<xarray.DataArray 'tp' (time: 8760, latitude: 721, longitude: 1440)>\n",
"dask.array<concatenate, shape=(8760, 721, 1440), dtype=float32, chunksize=(744, 50, 1440), chunktype=numpy.ndarray>\n",
"Coordinates:\n",
" * longitude (longitude) float32 0.0 0.25 0.5 0.75 ... 359.0 359.2 359.5 359.8\n",
" * latitude (latitude) float32 90.0 89.75 89.5 89.25 ... -89.5 -89.75 -90.0\n",
" * time (time) datetime64[ns] 2021-01-01 ... 2021-12-31T23:00:00\n",
"Attributes:\n",
" units: m\n",
" long_name: Total precipitation"
]
},
"execution_count": 9,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"ds = xr.open_mfdataset('hourly_tp/ERA5_HiRes_Hourly_tp_2021_*.nc', chunks={'latitude':50})\n",
"ds.tp"
]
},
{
"cell_type": "code",
"execution_count": 12,
"id": "d8343dd1-ad45-411d-8c50-03b28bc41e94",
"metadata": {},
"outputs": [
{
"data": {
"text/html": [
"<div><svg style=\"position: absolute; width: 0; height: 0; overflow: hidden\">\n",
"<defs>\n",
"<symbol id=\"icon-database\" viewBox=\"0 0 32 32\">\n",
"<path d=\"M16 0c-8.837 0-16 2.239-16 5v4c0 2.761 7.163 5 16 5s16-2.239 16-5v-4c0-2.761-7.163-5-16-5z\"></path>\n",
"<path d=\"M16 17c-8.837 0-16-2.239-16-5v6c0 2.761 7.163 5 16 5s16-2.239 16-5v-6c0 2.761-7.163 5-16 5z\"></path>\n",
"<path d=\"M16 26c-8.837 0-16-2.239-16-5v6c0 2.761 7.163 5 16 5s16-2.239 16-5v-6c0 2.761-7.163 5-16 5z\"></path>\n",
"</symbol>\n",
"<symbol id=\"icon-file-text2\" viewBox=\"0 0 32 32\">\n",
"<path d=\"M28.681 7.159c-0.694-0.947-1.662-2.053-2.724-3.116s-2.169-2.030-3.116-2.724c-1.612-1.182-2.393-1.319-2.841-1.319h-15.5c-1.378 0-2.5 1.121-2.5 2.5v27c0 1.378 1.122 2.5 2.5 2.5h23c1.378 0 2.5-1.122 2.5-2.5v-19.5c0-0.448-0.137-1.23-1.319-2.841zM24.543 5.457c0.959 0.959 1.712 1.825 2.268 2.543h-4.811v-4.811c0.718 0.556 1.584 1.309 2.543 2.268zM28 29.5c0 0.271-0.229 0.5-0.5 0.5h-23c-0.271 0-0.5-0.229-0.5-0.5v-27c0-0.271 0.229-0.5 0.5-0.5 0 0 15.499-0 15.5 0v7c0 0.552 0.448 1 1 1h7v19.5z\"></path>\n",
"<path d=\"M23 26h-14c-0.552 0-1-0.448-1-1s0.448-1 1-1h14c0.552 0 1 0.448 1 1s-0.448 1-1 1z\"></path>\n",
"<path d=\"M23 22h-14c-0.552 0-1-0.448-1-1s0.448-1 1-1h14c0.552 0 1 0.448 1 1s-0.448 1-1 1z\"></path>\n",
"<path d=\"M23 18h-14c-0.552 0-1-0.448-1-1s0.448-1 1-1h14c0.552 0 1 0.448 1 1s-0.448 1-1 1z\"></path>\n",
"</symbol>\n",
"</defs>\n",
"</svg>\n",
"<style>/* CSS stylesheet for displaying xarray objects in jupyterlab.\n",
" *\n",
" */\n",
"\n",
":root {\n",
" --xr-font-color0: var(--jp-content-font-color0, rgba(0, 0, 0, 1));\n",
" --xr-font-color2: var(--jp-content-font-color2, rgba(0, 0, 0, 0.54));\n",
" --xr-font-color3: var(--jp-content-font-color3, rgba(0, 0, 0, 0.38));\n",
" --xr-border-color: var(--jp-border-color2, #e0e0e0);\n",
" --xr-disabled-color: var(--jp-layout-color3, #bdbdbd);\n",
" --xr-background-color: var(--jp-layout-color0, white);\n",
" --xr-background-color-row-even: var(--jp-layout-color1, white);\n",
" --xr-background-color-row-odd: var(--jp-layout-color2, #eeeeee);\n",
"}\n",
"\n",
"html[theme=dark],\n",
"body.vscode-dark {\n",
" --xr-font-color0: rgba(255, 255, 255, 1);\n",
" --xr-font-color2: rgba(255, 255, 255, 0.54);\n",
" --xr-font-color3: rgba(255, 255, 255, 0.38);\n",
" --xr-border-color: #1F1F1F;\n",
" --xr-disabled-color: #515151;\n",
" --xr-background-color: #111111;\n",
" --xr-background-color-row-even: #111111;\n",
" --xr-background-color-row-odd: #313131;\n",
"}\n",
"\n",
".xr-wrap {\n",
" display: block !important;\n",
" min-width: 300px;\n",
" max-width: 700px;\n",
"}\n",
"\n",
".xr-text-repr-fallback {\n",
" /* fallback to plain text repr when CSS is not injected (untrusted notebook) */\n",
" display: none;\n",
"}\n",
"\n",
".xr-header {\n",
" padding-top: 6px;\n",
" padding-bottom: 6px;\n",
" margin-bottom: 4px;\n",
" border-bottom: solid 1px var(--xr-border-color);\n",
"}\n",
"\n",
".xr-header > div,\n",
".xr-header > ul {\n",
" display: inline;\n",
" margin-top: 0;\n",
" margin-bottom: 0;\n",
"}\n",
"\n",
".xr-obj-type,\n",
".xr-array-name {\n",
" margin-left: 2px;\n",
" margin-right: 10px;\n",
"}\n",
"\n",
".xr-obj-type {\n",
" color: var(--xr-font-color2);\n",
"}\n",
"\n",
".xr-sections {\n",
" padding-left: 0 !important;\n",
" display: grid;\n",
" grid-template-columns: 150px auto auto 1fr 20px 20px;\n",
"}\n",
"\n",
".xr-section-item {\n",
" display: contents;\n",
"}\n",
"\n",
".xr-section-item input {\n",
" display: none;\n",
"}\n",
"\n",
".xr-section-item input + label {\n",
" color: var(--xr-disabled-color);\n",
"}\n",
"\n",
".xr-section-item input:enabled + label {\n",
" cursor: pointer;\n",
" color: var(--xr-font-color2);\n",
"}\n",
"\n",
".xr-section-item input:enabled + label:hover {\n",
" color: var(--xr-font-color0);\n",
"}\n",
"\n",
".xr-section-summary {\n",
" grid-column: 1;\n",
" color: var(--xr-font-color2);\n",
" font-weight: 500;\n",
"}\n",
"\n",
".xr-section-summary > span {\n",
" display: inline-block;\n",
" padding-left: 0.5em;\n",
"}\n",
"\n",
".xr-section-summary-in:disabled + label {\n",
" color: var(--xr-font-color2);\n",
"}\n",
"\n",
".xr-section-summary-in + label:before {\n",
" display: inline-block;\n",
" content: '►';\n",
" font-size: 11px;\n",
" width: 15px;\n",
" text-align: center;\n",
"}\n",
"\n",
".xr-section-summary-in:disabled + label:before {\n",
" color: var(--xr-disabled-color);\n",
"}\n",
"\n",
".xr-section-summary-in:checked + label:before {\n",
" content: '▼';\n",
"}\n",
"\n",
".xr-section-summary-in:checked + label > span {\n",
" display: none;\n",
"}\n",
"\n",
".xr-section-summary,\n",
".xr-section-inline-details {\n",
" padding-top: 4px;\n",
" padding-bottom: 4px;\n",
"}\n",
"\n",
".xr-section-inline-details {\n",
" grid-column: 2 / -1;\n",
"}\n",
"\n",
".xr-section-details {\n",
" display: none;\n",
" grid-column: 1 / -1;\n",
" margin-bottom: 5px;\n",
"}\n",
"\n",
".xr-section-summary-in:checked ~ .xr-section-details {\n",
" display: contents;\n",
"}\n",
"\n",
".xr-array-wrap {\n",
" grid-column: 1 / -1;\n",
" display: grid;\n",
" grid-template-columns: 20px auto;\n",
"}\n",
"\n",
".xr-array-wrap > label {\n",
" grid-column: 1;\n",
" vertical-align: top;\n",
"}\n",
"\n",
".xr-preview {\n",
" color: var(--xr-font-color3);\n",
"}\n",
"\n",
".xr-array-preview,\n",
".xr-array-data {\n",
" padding: 0 5px !important;\n",
" grid-column: 2;\n",
"}\n",
"\n",
".xr-array-data,\n",
".xr-array-in:checked ~ .xr-array-preview {\n",
" display: none;\n",
"}\n",
"\n",
".xr-array-in:checked ~ .xr-array-data,\n",
".xr-array-preview {\n",
" display: inline-block;\n",
"}\n",
"\n",
".xr-dim-list {\n",
" display: inline-block !important;\n",
" list-style: none;\n",
" padding: 0 !important;\n",
" margin: 0;\n",
"}\n",
"\n",
".xr-dim-list li {\n",
" display: inline-block;\n",
" padding: 0;\n",
" margin: 0;\n",
"}\n",
"\n",
".xr-dim-list:before {\n",
" content: '(';\n",
"}\n",
"\n",
".xr-dim-list:after {\n",
" content: ')';\n",
"}\n",
"\n",
".xr-dim-list li:not(:last-child):after {\n",
" content: ',';\n",
" padding-right: 5px;\n",
"}\n",
"\n",
".xr-has-index {\n",
" font-weight: bold;\n",
"}\n",
"\n",
".xr-var-list,\n",
".xr-var-item {\n",
" display: contents;\n",
"}\n",
"\n",
".xr-var-item > div,\n",
".xr-var-item label,\n",
".xr-var-item > .xr-var-name span {\n",
" background-color: var(--xr-background-color-row-even);\n",
" margin-bottom: 0;\n",
"}\n",
"\n",
".xr-var-item > .xr-var-name:hover span {\n",
" padding-right: 5px;\n",
"}\n",
"\n",
".xr-var-list > li:nth-child(odd) > div,\n",
".xr-var-list > li:nth-child(odd) > label,\n",
".xr-var-list > li:nth-child(odd) > .xr-var-name span {\n",
" background-color: var(--xr-background-color-row-odd);\n",
"}\n",
"\n",
".xr-var-name {\n",
" grid-column: 1;\n",
"}\n",
"\n",
".xr-var-dims {\n",
" grid-column: 2;\n",
"}\n",
"\n",
".xr-var-dtype {\n",
" grid-column: 3;\n",
" text-align: right;\n",
" color: var(--xr-font-color2);\n",
"}\n",
"\n",
".xr-var-preview {\n",
" grid-column: 4;\n",
"}\n",
"\n",
".xr-var-name,\n",
".xr-var-dims,\n",
".xr-var-dtype,\n",
".xr-preview,\n",
".xr-attrs dt {\n",
" white-space: nowrap;\n",
" overflow: hidden;\n",
" text-overflow: ellipsis;\n",
" padding-right: 10px;\n",
"}\n",
"\n",
".xr-var-name:hover,\n",
".xr-var-dims:hover,\n",
".xr-var-dtype:hover,\n",
".xr-attrs dt:hover {\n",
" overflow: visible;\n",
" width: auto;\n",
" z-index: 1;\n",
"}\n",
"\n",
".xr-var-attrs,\n",
".xr-var-data {\n",
" display: none;\n",
" background-color: var(--xr-background-color) !important;\n",
" padding-bottom: 5px !important;\n",
"}\n",
"\n",
".xr-var-attrs-in:checked ~ .xr-var-attrs,\n",
".xr-var-data-in:checked ~ .xr-var-data {\n",
" display: block;\n",
"}\n",
"\n",
".xr-var-data > table {\n",
" float: right;\n",
"}\n",
"\n",
".xr-var-name span,\n",
".xr-var-data,\n",
".xr-attrs {\n",
" padding-left: 25px !important;\n",
"}\n",
"\n",
".xr-attrs,\n",
".xr-var-attrs,\n",
".xr-var-data {\n",
" grid-column: 1 / -1;\n",
"}\n",
"\n",
"dl.xr-attrs {\n",
" padding: 0;\n",
" margin: 0;\n",
" display: grid;\n",
" grid-template-columns: 125px auto;\n",
"}\n",
"\n",
".xr-attrs dt,\n",
".xr-attrs dd {\n",
" padding: 0;\n",
" margin: 0;\n",
" float: left;\n",
" padding-right: 10px;\n",
" width: auto;\n",
"}\n",
"\n",
".xr-attrs dt {\n",
" font-weight: normal;\n",
" grid-column: 1;\n",
"}\n",
"\n",
".xr-attrs dt:hover span {\n",
" display: inline-block;\n",
" background: var(--xr-background-color);\n",
" padding-right: 10px;\n",
"}\n",
"\n",
".xr-attrs dd {\n",
" grid-column: 2;\n",
" white-space: pre-wrap;\n",
" word-break: break-all;\n",
"}\n",
"\n",
".xr-icon-database,\n",
".xr-icon-file-text2 {\n",
" display: inline-block;\n",
" vertical-align: middle;\n",
" width: 1em;\n",
" height: 1.5em !important;\n",
" stroke-width: 0;\n",
" stroke: currentColor;\n",
" fill: currentColor;\n",
"}\n",
"</style><pre class='xr-text-repr-fallback'>&lt;xarray.DataArray &#x27;tp&#x27; (latitude: 721, longitude: 1440)&gt;\n",
"dask.array&lt;mean_agg-aggregate, shape=(721, 1440), dtype=float32, chunksize=(50, 1440), chunktype=numpy.ndarray&gt;\n",
"Coordinates:\n",
" * longitude (longitude) float32 0.0 0.25 0.5 0.75 ... 359.0 359.2 359.5 359.8\n",
" * latitude (latitude) float32 90.0 89.75 89.5 89.25 ... -89.5 -89.75 -90.0</pre><div class='xr-wrap' style='display:none'><div class='xr-header'><div class='xr-obj-type'>xarray.DataArray</div><div class='xr-array-name'>'tp'</div><ul class='xr-dim-list'><li><span class='xr-has-index'>latitude</span>: 721</li><li><span class='xr-has-index'>longitude</span>: 1440</li></ul></div><ul class='xr-sections'><li class='xr-section-item'><div class='xr-array-wrap'><input id='section-c333b17b-837c-4d8a-8ce5-db9ba0c97c70' class='xr-array-in' type='checkbox' checked><label for='section-c333b17b-837c-4d8a-8ce5-db9ba0c97c70' title='Show/hide data repr'><svg class='icon xr-icon-database'><use xlink:href='#icon-database'></use></svg></label><div class='xr-array-preview xr-preview'><span>dask.array&lt;chunksize=(50, 1440), meta=np.ndarray&gt;</span></div><div class='xr-array-data'><table>\n",
" <tr>\n",
" <td>\n",
" <table>\n",
" <thead>\n",
" <tr>\n",
" <td> </td>\n",
" <th> Array </th>\n",
" <th> Chunk </th>\n",
" </tr>\n",
" </thead>\n",
" <tbody>\n",
" \n",
" <tr>\n",
" <th> Bytes </th>\n",
" <td> 3.96 MiB </td>\n",
" <td> 281.25 kiB </td>\n",
" </tr>\n",
" \n",
" <tr>\n",
" <th> Shape </th>\n",
" <td> (721, 1440) </td>\n",
" <td> (50, 1440) </td>\n",
" </tr>\n",
" <tr>\n",
" <th> Count </th>\n",
" <td> 612 Tasks </td>\n",
" <td> 15 Chunks </td>\n",
" </tr>\n",
" <tr>\n",
" <th> Type </th>\n",
" <td> float32 </td>\n",
" <td> numpy.ndarray </td>\n",
" </tr>\n",
" </tbody>\n",
" </table>\n",
" </td>\n",
" <td>\n",
" <svg width=\"170\" height=\"110\" style=\"stroke:rgb(0,0,0);stroke-width:1\" >\n",
"\n",
" <!-- Horizontal lines -->\n",
" <line x1=\"0\" y1=\"0\" x2=\"120\" y2=\"0\" style=\"stroke-width:2\" />\n",
" <line x1=\"0\" y1=\"4\" x2=\"120\" y2=\"4\" />\n",
" <line x1=\"0\" y1=\"8\" x2=\"120\" y2=\"8\" />\n",
" <line x1=\"0\" y1=\"12\" x2=\"120\" y2=\"12\" />\n",
" <line x1=\"0\" y1=\"16\" x2=\"120\" y2=\"16\" />\n",
" <line x1=\"0\" y1=\"20\" x2=\"120\" y2=\"20\" />\n",
" <line x1=\"0\" y1=\"25\" x2=\"120\" y2=\"25\" />\n",
" <line x1=\"0\" y1=\"29\" x2=\"120\" y2=\"29\" />\n",
" <line x1=\"0\" y1=\"33\" x2=\"120\" y2=\"33\" />\n",
" <line x1=\"0\" y1=\"37\" x2=\"120\" y2=\"37\" />\n",
" <line x1=\"0\" y1=\"41\" x2=\"120\" y2=\"41\" />\n",
" <line x1=\"0\" y1=\"45\" x2=\"120\" y2=\"45\" />\n",
" <line x1=\"0\" y1=\"50\" x2=\"120\" y2=\"50\" />\n",
" <line x1=\"0\" y1=\"54\" x2=\"120\" y2=\"54\" />\n",
" <line x1=\"0\" y1=\"58\" x2=\"120\" y2=\"58\" />\n",
" <line x1=\"0\" y1=\"60\" x2=\"120\" y2=\"60\" style=\"stroke-width:2\" />\n",
"\n",
" <!-- Vertical lines -->\n",
" <line x1=\"0\" y1=\"0\" x2=\"0\" y2=\"60\" style=\"stroke-width:2\" />\n",
" <line x1=\"120\" y1=\"0\" x2=\"120\" y2=\"60\" style=\"stroke-width:2\" />\n",
"\n",
" <!-- Colored Rectangle -->\n",
" <polygon points=\"0.0,0.0 120.0,0.0 120.0,60.083333333333336 0.0,60.083333333333336\" style=\"fill:#ECB172A0;stroke-width:0\"/>\n",
"\n",
" <!-- Text -->\n",
" <text x=\"60.000000\" y=\"80.083333\" font-size=\"1.0rem\" font-weight=\"100\" text-anchor=\"middle\" >1440</text>\n",
" <text x=\"140.000000\" y=\"30.041667\" font-size=\"1.0rem\" font-weight=\"100\" text-anchor=\"middle\" transform=\"rotate(-90,140.000000,30.041667)\">721</text>\n",
"</svg>\n",
" </td>\n",
" </tr>\n",
"</table></div></div></li><li class='xr-section-item'><input id='section-f7ce3bb7-009f-4f6e-a96b-3d2383d98e1c' class='xr-section-summary-in' type='checkbox' checked><label for='section-f7ce3bb7-009f-4f6e-a96b-3d2383d98e1c' class='xr-section-summary' >Coordinates: <span>(2)</span></label><div class='xr-section-inline-details'></div><div class='xr-section-details'><ul class='xr-var-list'><li class='xr-var-item'><div class='xr-var-name'><span class='xr-has-index'>longitude</span></div><div class='xr-var-dims'>(longitude)</div><div class='xr-var-dtype'>float32</div><div class='xr-var-preview xr-preview'>0.0 0.25 0.5 ... 359.2 359.5 359.8</div><input id='attrs-b508ea31-2853-4449-9316-e00422279f50' class='xr-var-attrs-in' type='checkbox' ><label for='attrs-b508ea31-2853-4449-9316-e00422279f50' title='Show/Hide attributes'><svg class='icon xr-icon-file-text2'><use xlink:href='#icon-file-text2'></use></svg></label><input id='data-98507bd6-c905-4e41-aeb3-345dc8c5b25b' class='xr-var-data-in' type='checkbox'><label for='data-98507bd6-c905-4e41-aeb3-345dc8c5b25b' title='Show/Hide data repr'><svg class='icon xr-icon-database'><use xlink:href='#icon-database'></use></svg></label><div class='xr-var-attrs'><dl class='xr-attrs'><dt><span>units :</span></dt><dd>degrees_east</dd><dt><span>long_name :</span></dt><dd>longitude</dd></dl></div><div class='xr-var-data'><pre>array([0.0000e+00, 2.5000e-01, 5.0000e-01, ..., 3.5925e+02, 3.5950e+02,\n",
" 3.5975e+02], dtype=float32)</pre></div></li><li class='xr-var-item'><div class='xr-var-name'><span class='xr-has-index'>latitude</span></div><div class='xr-var-dims'>(latitude)</div><div class='xr-var-dtype'>float32</div><div class='xr-var-preview xr-preview'>90.0 89.75 89.5 ... -89.75 -90.0</div><input id='attrs-1f81a2e6-08f8-49cd-9a9b-5c660f3403eb' class='xr-var-attrs-in' type='checkbox' ><label for='attrs-1f81a2e6-08f8-49cd-9a9b-5c660f3403eb' title='Show/Hide attributes'><svg class='icon xr-icon-file-text2'><use xlink:href='#icon-file-text2'></use></svg></label><input id='data-97c077c3-6724-4261-b027-65381265209e' class='xr-var-data-in' type='checkbox'><label for='data-97c077c3-6724-4261-b027-65381265209e' title='Show/Hide data repr'><svg class='icon xr-icon-database'><use xlink:href='#icon-database'></use></svg></label><div class='xr-var-attrs'><dl class='xr-attrs'><dt><span>units :</span></dt><dd>degrees_north</dd><dt><span>long_name :</span></dt><dd>latitude</dd></dl></div><div class='xr-var-data'><pre>array([ 90. , 89.75, 89.5 , ..., -89.5 , -89.75, -90. ], dtype=float32)</pre></div></li></ul></div></li><li class='xr-section-item'><input id='section-41829fc3-ef94-442e-ae38-424c68d86f92' class='xr-section-summary-in' type='checkbox' disabled ><label for='section-41829fc3-ef94-442e-ae38-424c68d86f92' class='xr-section-summary' title='Expand/collapse section'>Attributes: <span>(0)</span></label><div class='xr-section-inline-details'></div><div class='xr-section-details'><dl class='xr-attrs'></dl></div></li></ul></div></div>"
],
"text/plain": [
"<xarray.DataArray 'tp' (latitude: 721, longitude: 1440)>\n",
"dask.array<mean_agg-aggregate, shape=(721, 1440), dtype=float32, chunksize=(50, 1440), chunktype=numpy.ndarray>\n",
"Coordinates:\n",
" * longitude (longitude) float32 0.0 0.25 0.5 0.75 ... 359.0 359.2 359.5 359.8\n",
" * latitude (latitude) float32 90.0 89.75 89.5 89.25 ... -89.5 -89.75 -90.0"
]
},
"execution_count": 12,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"tpm = ds.tp.mean(dim='time')\n",
"tpm"
]
},
{
"cell_type": "code",
"execution_count": 13,
"id": "6e80dcb6-eccd-4cbf-bc44-65bf466dfec4",
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"Yep: 52.2s\n"
]
}
],
"source": [
"t0 = time.time()\n",
"tpm = tpm.load()\n",
"print(f'Yep: {time.time() - t0:.1f}s')"
]
},
{
"cell_type": "markdown",
"id": "b859d98a-8269-40ea-9d09-eb56644f114a",
"metadata": {},
"source": [
"Process manager:\n",
"\n",
"![]( )"
]
},
{
"cell_type": "markdown",
"id": "afba48ef-3251-4aa6-824a-327b7553e593",
"metadata": {},
"source": [
"**Summary: it works fine, BUT some swap memory pollution -> why?**"
]
},
{
"cell_type": "markdown",
"id": "fda18196-4fd1-4f1f-a945-88aae167f98e",
"metadata": {},
"source": [
"### Dask + `open_dataset` + for loop "
]
},
{
"cell_type": "code",
"execution_count": 18,
"id": "97edd093-3203-45a2-b9ee-ad855f28c6c1",
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"1\n",
"2\n",
"3\n",
"4\n",
"5\n",
"6\n",
"7\n",
"8\n",
"9\n",
"10\n",
"11\n",
"12\n",
"Yep: 53.1s\n"
]
}
],
"source": [
"t0 = time.time()\n",
"out_ds = []\n",
"nn = []\n",
"for i in range(1, 13):\n",
" print(i)\n",
" with xr.open_dataset(f'/home/mowglie/tmp/xarray_adv/hourly_tp/ERA5_HiRes_Hourly_tp_2021_{i:02d}.nc',\n",
" chunks={'latitude':50}) as ds:\n",
" tph = ds.tp.mean(dim='time').load()\n",
" out_ds.append(tph)\n",
" nn.append(len(ds.time))\n",
"out = 0\n",
"for ds, n in zip(out_ds, nn):\n",
" out += ds * n\n",
"out /= np.sum(nn)\n",
"print(f'Yep: {time.time() - t0:.1f}s')"
]
},
{
"cell_type": "markdown",
"id": "7c1be79c-8041-44e6-b9fc-96589f99e91a",
"metadata": {},
"source": [
"Process manager:\n",
"\n",
"![]( )"
]
},
{
"cell_type": "markdown",
"id": "55f3b859-d4b8-4bd1-84ca-7e80c6652a98",
"metadata": {},
"source": [
"**Summary: similar performance, negligible swap memory pollution.**"
]
},
{
"cell_type": "markdown",
"id": "bafdad6e-37f2-4a16-a32a-39b26c160481",
"metadata": {},
"source": [
"### No Dask + for loop "
]
},
{
"cell_type": "code",
"execution_count": 17,
"id": "643a72b6-8121-4b1d-8c0c-6a14c26b51b9",
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"1\n",
"2\n",
"3\n",
"4\n",
"5\n",
"6\n",
"7\n",
"8\n",
"9\n",
"10\n",
"11\n",
"12\n",
"Yep: 126.4s\n"
]
}
],
"source": [
"t0 = time.time()\n",
"out_ds = []\n",
"nn = []\n",
"for i in range(1, 13):\n",
" print(i)\n",
" with xr.open_dataset(f'/home/mowglie/tmp/xarray_adv/hourly_tp/ERA5_HiRes_Hourly_tp_2021_{i:02d}.nc') as ds:\n",
" tph = ds.tp.mean(dim='time').load()\n",
" out_ds.append(tph)\n",
" nn.append(len(ds.time))\n",
"out = 0\n",
"for ds, n in zip(out_ds, nn):\n",
" out += ds * n\n",
"out /= np.sum(nn)\n",
"print(f'Yep: {time.time() - t0:.1f}s')"
]
},
{
"cell_type": "markdown",
"id": "854221cc-5c02-4978-83b8-c9ce00039b11",
"metadata": {},
"source": [
"**Summary: all good: worse performance, bad memory performance.**"
]
},
{
"cell_type": "markdown",
"id": "42bc606d-d705-4bb6-a2b6-5221b33110df",
"metadata": {},
"source": [
"## Exp 2: groupby + averages over time"
]
},
{
"cell_type": "markdown",
"id": "b6d5b248-b865-4822-8411-3f0ecf6e2fd4",
"metadata": {},
"source": [
"### dask + `open_mfdataset`"
]
},
{
"cell_type": "code",
"execution_count": 19,
"id": "81a52c78-08a5-4346-b222-59dfcecccc19",
"metadata": {},
"outputs": [
{
"data": {
"text/html": [
"<div><svg style=\"position: absolute; width: 0; height: 0; overflow: hidden\">\n",
"<defs>\n",
"<symbol id=\"icon-database\" viewBox=\"0 0 32 32\">\n",
"<path d=\"M16 0c-8.837 0-16 2.239-16 5v4c0 2.761 7.163 5 16 5s16-2.239 16-5v-4c0-2.761-7.163-5-16-5z\"></path>\n",
"<path d=\"M16 17c-8.837 0-16-2.239-16-5v6c0 2.761 7.163 5 16 5s16-2.239 16-5v-6c0 2.761-7.163 5-16 5z\"></path>\n",
"<path d=\"M16 26c-8.837 0-16-2.239-16-5v6c0 2.761 7.163 5 16 5s16-2.239 16-5v-6c0 2.761-7.163 5-16 5z\"></path>\n",
"</symbol>\n",
"<symbol id=\"icon-file-text2\" viewBox=\"0 0 32 32\">\n",
"<path d=\"M28.681 7.159c-0.694-0.947-1.662-2.053-2.724-3.116s-2.169-2.030-3.116-2.724c-1.612-1.182-2.393-1.319-2.841-1.319h-15.5c-1.378 0-2.5 1.121-2.5 2.5v27c0 1.378 1.122 2.5 2.5 2.5h23c1.378 0 2.5-1.122 2.5-2.5v-19.5c0-0.448-0.137-1.23-1.319-2.841zM24.543 5.457c0.959 0.959 1.712 1.825 2.268 2.543h-4.811v-4.811c0.718 0.556 1.584 1.309 2.543 2.268zM28 29.5c0 0.271-0.229 0.5-0.5 0.5h-23c-0.271 0-0.5-0.229-0.5-0.5v-27c0-0.271 0.229-0.5 0.5-0.5 0 0 15.499-0 15.5 0v7c0 0.552 0.448 1 1 1h7v19.5z\"></path>\n",
"<path d=\"M23 26h-14c-0.552 0-1-0.448-1-1s0.448-1 1-1h14c0.552 0 1 0.448 1 1s-0.448 1-1 1z\"></path>\n",
"<path d=\"M23 22h-14c-0.552 0-1-0.448-1-1s0.448-1 1-1h14c0.552 0 1 0.448 1 1s-0.448 1-1 1z\"></path>\n",
"<path d=\"M23 18h-14c-0.552 0-1-0.448-1-1s0.448-1 1-1h14c0.552 0 1 0.448 1 1s-0.448 1-1 1z\"></path>\n",
"</symbol>\n",
"</defs>\n",
"</svg>\n",
"<style>/* CSS stylesheet for displaying xarray objects in jupyterlab.\n",
" *\n",
" */\n",
"\n",
":root {\n",
" --xr-font-color0: var(--jp-content-font-color0, rgba(0, 0, 0, 1));\n",
" --xr-font-color2: var(--jp-content-font-color2, rgba(0, 0, 0, 0.54));\n",
" --xr-font-color3: var(--jp-content-font-color3, rgba(0, 0, 0, 0.38));\n",
" --xr-border-color: var(--jp-border-color2, #e0e0e0);\n",
" --xr-disabled-color: var(--jp-layout-color3, #bdbdbd);\n",
" --xr-background-color: var(--jp-layout-color0, white);\n",
" --xr-background-color-row-even: var(--jp-layout-color1, white);\n",
" --xr-background-color-row-odd: var(--jp-layout-color2, #eeeeee);\n",
"}\n",
"\n",
"html[theme=dark],\n",
"body.vscode-dark {\n",
" --xr-font-color0: rgba(255, 255, 255, 1);\n",
" --xr-font-color2: rgba(255, 255, 255, 0.54);\n",
" --xr-font-color3: rgba(255, 255, 255, 0.38);\n",
" --xr-border-color: #1F1F1F;\n",
" --xr-disabled-color: #515151;\n",
" --xr-background-color: #111111;\n",
" --xr-background-color-row-even: #111111;\n",
" --xr-background-color-row-odd: #313131;\n",
"}\n",
"\n",
".xr-wrap {\n",
" display: block !important;\n",
" min-width: 300px;\n",
" max-width: 700px;\n",
"}\n",
"\n",
".xr-text-repr-fallback {\n",
" /* fallback to plain text repr when CSS is not injected (untrusted notebook) */\n",
" display: none;\n",
"}\n",
"\n",
".xr-header {\n",
" padding-top: 6px;\n",
" padding-bottom: 6px;\n",
" margin-bottom: 4px;\n",
" border-bottom: solid 1px var(--xr-border-color);\n",
"}\n",
"\n",
".xr-header > div,\n",
".xr-header > ul {\n",
" display: inline;\n",
" margin-top: 0;\n",
" margin-bottom: 0;\n",
"}\n",
"\n",
".xr-obj-type,\n",
".xr-array-name {\n",
" margin-left: 2px;\n",
" margin-right: 10px;\n",
"}\n",
"\n",
".xr-obj-type {\n",
" color: var(--xr-font-color2);\n",
"}\n",
"\n",
".xr-sections {\n",
" padding-left: 0 !important;\n",
" display: grid;\n",
" grid-template-columns: 150px auto auto 1fr 20px 20px;\n",
"}\n",
"\n",
".xr-section-item {\n",
" display: contents;\n",
"}\n",
"\n",
".xr-section-item input {\n",
" display: none;\n",
"}\n",
"\n",
".xr-section-item input + label {\n",
" color: var(--xr-disabled-color);\n",
"}\n",
"\n",
".xr-section-item input:enabled + label {\n",
" cursor: pointer;\n",
" color: var(--xr-font-color2);\n",
"}\n",
"\n",
".xr-section-item input:enabled + label:hover {\n",
" color: var(--xr-font-color0);\n",
"}\n",
"\n",
".xr-section-summary {\n",
" grid-column: 1;\n",
" color: var(--xr-font-color2);\n",
" font-weight: 500;\n",
"}\n",
"\n",
".xr-section-summary > span {\n",
" display: inline-block;\n",
" padding-left: 0.5em;\n",
"}\n",
"\n",
".xr-section-summary-in:disabled + label {\n",
" color: var(--xr-font-color2);\n",
"}\n",
"\n",
".xr-section-summary-in + label:before {\n",
" display: inline-block;\n",
" content: '►';\n",
" font-size: 11px;\n",
" width: 15px;\n",
" text-align: center;\n",
"}\n",
"\n",
".xr-section-summary-in:disabled + label:before {\n",
" color: var(--xr-disabled-color);\n",
"}\n",
"\n",
".xr-section-summary-in:checked + label:before {\n",
" content: '▼';\n",
"}\n",
"\n",
".xr-section-summary-in:checked + label > span {\n",
" display: none;\n",
"}\n",
"\n",
".xr-section-summary,\n",
".xr-section-inline-details {\n",
" padding-top: 4px;\n",
" padding-bottom: 4px;\n",
"}\n",
"\n",
".xr-section-inline-details {\n",
" grid-column: 2 / -1;\n",
"}\n",
"\n",
".xr-section-details {\n",
" display: none;\n",
" grid-column: 1 / -1;\n",
" margin-bottom: 5px;\n",
"}\n",
"\n",
".xr-section-summary-in:checked ~ .xr-section-details {\n",
" display: contents;\n",
"}\n",
"\n",
".xr-array-wrap {\n",
" grid-column: 1 / -1;\n",
" display: grid;\n",
" grid-template-columns: 20px auto;\n",
"}\n",
"\n",
".xr-array-wrap > label {\n",
" grid-column: 1;\n",
" vertical-align: top;\n",
"}\n",
"\n",
".xr-preview {\n",
" color: var(--xr-font-color3);\n",
"}\n",
"\n",
".xr-array-preview,\n",
".xr-array-data {\n",
" padding: 0 5px !important;\n",
" grid-column: 2;\n",
"}\n",
"\n",
".xr-array-data,\n",
".xr-array-in:checked ~ .xr-array-preview {\n",
" display: none;\n",
"}\n",
"\n",
".xr-array-in:checked ~ .xr-array-data,\n",
".xr-array-preview {\n",
" display: inline-block;\n",
"}\n",
"\n",
".xr-dim-list {\n",
" display: inline-block !important;\n",
" list-style: none;\n",
" padding: 0 !important;\n",
" margin: 0;\n",
"}\n",
"\n",
".xr-dim-list li {\n",
" display: inline-block;\n",
" padding: 0;\n",
" margin: 0;\n",
"}\n",
"\n",
".xr-dim-list:before {\n",
" content: '(';\n",
"}\n",
"\n",
".xr-dim-list:after {\n",
" content: ')';\n",
"}\n",
"\n",
".xr-dim-list li:not(:last-child):after {\n",
" content: ',';\n",
" padding-right: 5px;\n",
"}\n",
"\n",
".xr-has-index {\n",
" font-weight: bold;\n",
"}\n",
"\n",
".xr-var-list,\n",
".xr-var-item {\n",
" display: contents;\n",
"}\n",
"\n",
".xr-var-item > div,\n",
".xr-var-item label,\n",
".xr-var-item > .xr-var-name span {\n",
" background-color: var(--xr-background-color-row-even);\n",
" margin-bottom: 0;\n",
"}\n",
"\n",
".xr-var-item > .xr-var-name:hover span {\n",
" padding-right: 5px;\n",
"}\n",
"\n",
".xr-var-list > li:nth-child(odd) > div,\n",
".xr-var-list > li:nth-child(odd) > label,\n",
".xr-var-list > li:nth-child(odd) > .xr-var-name span {\n",
" background-color: var(--xr-background-color-row-odd);\n",
"}\n",
"\n",
".xr-var-name {\n",
" grid-column: 1;\n",
"}\n",
"\n",
".xr-var-dims {\n",
" grid-column: 2;\n",
"}\n",
"\n",
".xr-var-dtype {\n",
" grid-column: 3;\n",
" text-align: right;\n",
" color: var(--xr-font-color2);\n",
"}\n",
"\n",
".xr-var-preview {\n",
" grid-column: 4;\n",
"}\n",
"\n",
".xr-var-name,\n",
".xr-var-dims,\n",
".xr-var-dtype,\n",
".xr-preview,\n",
".xr-attrs dt {\n",
" white-space: nowrap;\n",
" overflow: hidden;\n",
" text-overflow: ellipsis;\n",
" padding-right: 10px;\n",
"}\n",
"\n",
".xr-var-name:hover,\n",
".xr-var-dims:hover,\n",
".xr-var-dtype:hover,\n",
".xr-attrs dt:hover {\n",
" overflow: visible;\n",
" width: auto;\n",
" z-index: 1;\n",
"}\n",
"\n",
".xr-var-attrs,\n",
".xr-var-data {\n",
" display: none;\n",
" background-color: var(--xr-background-color) !important;\n",
" padding-bottom: 5px !important;\n",
"}\n",
"\n",
".xr-var-attrs-in:checked ~ .xr-var-attrs,\n",
".xr-var-data-in:checked ~ .xr-var-data {\n",
" display: block;\n",
"}\n",
"\n",
".xr-var-data > table {\n",
" float: right;\n",
"}\n",
"\n",
".xr-var-name span,\n",
".xr-var-data,\n",
".xr-attrs {\n",
" padding-left: 25px !important;\n",
"}\n",
"\n",
".xr-attrs,\n",
".xr-var-attrs,\n",
".xr-var-data {\n",
" grid-column: 1 / -1;\n",
"}\n",
"\n",
"dl.xr-attrs {\n",
" padding: 0;\n",
" margin: 0;\n",
" display: grid;\n",
" grid-template-columns: 125px auto;\n",
"}\n",
"\n",
".xr-attrs dt,\n",
".xr-attrs dd {\n",
" padding: 0;\n",
" margin: 0;\n",
" float: left;\n",
" padding-right: 10px;\n",
" width: auto;\n",
"}\n",
"\n",
".xr-attrs dt {\n",
" font-weight: normal;\n",
" grid-column: 1;\n",
"}\n",
"\n",
".xr-attrs dt:hover span {\n",
" display: inline-block;\n",
" background: var(--xr-background-color);\n",
" padding-right: 10px;\n",
"}\n",
"\n",
".xr-attrs dd {\n",
" grid-column: 2;\n",
" white-space: pre-wrap;\n",
" word-break: break-all;\n",
"}\n",
"\n",
".xr-icon-database,\n",
".xr-icon-file-text2 {\n",
" display: inline-block;\n",
" vertical-align: middle;\n",
" width: 1em;\n",
" height: 1.5em !important;\n",
" stroke-width: 0;\n",
" stroke: currentColor;\n",
" fill: currentColor;\n",
"}\n",
"</style><pre class='xr-text-repr-fallback'>&lt;xarray.DataArray &#x27;tp&#x27; (time: 8760, latitude: 721, longitude: 1440)&gt;\n",
"dask.array&lt;concatenate, shape=(8760, 721, 1440), dtype=float32, chunksize=(744, 50, 1440), chunktype=numpy.ndarray&gt;\n",
"Coordinates:\n",
" * longitude (longitude) float32 0.0 0.25 0.5 0.75 ... 359.0 359.2 359.5 359.8\n",
" * latitude (latitude) float32 90.0 89.75 89.5 89.25 ... -89.5 -89.75 -90.0\n",
" * time (time) datetime64[ns] 2021-01-01 ... 2021-12-31T23:00:00\n",
"Attributes:\n",
" units: m\n",
" long_name: Total precipitation</pre><div class='xr-wrap' style='display:none'><div class='xr-header'><div class='xr-obj-type'>xarray.DataArray</div><div class='xr-array-name'>'tp'</div><ul class='xr-dim-list'><li><span class='xr-has-index'>time</span>: 8760</li><li><span class='xr-has-index'>latitude</span>: 721</li><li><span class='xr-has-index'>longitude</span>: 1440</li></ul></div><ul class='xr-sections'><li class='xr-section-item'><div class='xr-array-wrap'><input id='section-813126ec-1491-475b-b7d0-e8255f5d5e06' class='xr-array-in' type='checkbox' checked><label for='section-813126ec-1491-475b-b7d0-e8255f5d5e06' title='Show/hide data repr'><svg class='icon xr-icon-database'><use xlink:href='#icon-database'></use></svg></label><div class='xr-array-preview xr-preview'><span>dask.array&lt;chunksize=(744, 50, 1440), meta=np.ndarray&gt;</span></div><div class='xr-array-data'><table>\n",
" <tr>\n",
" <td>\n",
" <table>\n",
" <thead>\n",
" <tr>\n",
" <td> </td>\n",
" <th> Array </th>\n",
" <th> Chunk </th>\n",
" </tr>\n",
" </thead>\n",
" <tbody>\n",
" \n",
" <tr>\n",
" <th> Bytes </th>\n",
" <td> 33.88 GiB </td>\n",
" <td> 204.35 MiB </td>\n",
" </tr>\n",
" \n",
" <tr>\n",
" <th> Shape </th>\n",
" <td> (8760, 721, 1440) </td>\n",
" <td> (744, 50, 1440) </td>\n",
" </tr>\n",
" <tr>\n",
" <th> Count </th>\n",
" <td> 372 Tasks </td>\n",
" <td> 180 Chunks </td>\n",
" </tr>\n",
" <tr>\n",
" <th> Type </th>\n",
" <td> float32 </td>\n",
" <td> numpy.ndarray </td>\n",
" </tr>\n",
" </tbody>\n",
" </table>\n",
" </td>\n",
" <td>\n",
" <svg width=\"171\" height=\"158\" style=\"stroke:rgb(0,0,0);stroke-width:1\" >\n",
"\n",
" <!-- Horizontal lines -->\n",
" <line x1=\"10\" y1=\"0\" x2=\"80\" y2=\"70\" style=\"stroke-width:2\" />\n",
" <line x1=\"10\" y1=\"2\" x2=\"80\" y2=\"73\" />\n",
" <line x1=\"10\" y1=\"5\" x2=\"80\" y2=\"75\" />\n",
" <line x1=\"10\" y1=\"7\" x2=\"80\" y2=\"78\" />\n",
" <line x1=\"10\" y1=\"10\" x2=\"80\" y2=\"80\" />\n",
" <line x1=\"10\" y1=\"12\" x2=\"80\" y2=\"83\" />\n",
" <line x1=\"10\" y1=\"15\" x2=\"80\" y2=\"86\" />\n",
" <line x1=\"10\" y1=\"18\" x2=\"80\" y2=\"88\" />\n",
" <line x1=\"10\" y1=\"20\" x2=\"80\" y2=\"91\" />\n",
" <line x1=\"10\" y1=\"23\" x2=\"80\" y2=\"93\" />\n",
" <line x1=\"10\" y1=\"25\" x2=\"80\" y2=\"96\" />\n",
" <line x1=\"10\" y1=\"28\" x2=\"80\" y2=\"99\" />\n",
" <line x1=\"10\" y1=\"31\" x2=\"80\" y2=\"101\" />\n",
" <line x1=\"10\" y1=\"33\" x2=\"80\" y2=\"104\" />\n",
" <line x1=\"10\" y1=\"36\" x2=\"80\" y2=\"106\" />\n",
" <line x1=\"10\" y1=\"37\" x2=\"80\" y2=\"108\" style=\"stroke-width:2\" />\n",
"\n",
" <!-- Vertical lines -->\n",
" <line x1=\"10\" y1=\"0\" x2=\"10\" y2=\"37\" style=\"stroke-width:2\" />\n",
" <line x1=\"15\" y1=\"5\" x2=\"15\" y2=\"43\" />\n",
" <line x1=\"21\" y1=\"11\" x2=\"21\" y2=\"48\" />\n",
" <line x1=\"27\" y1=\"17\" x2=\"27\" y2=\"54\" />\n",
" <line x1=\"33\" y1=\"23\" x2=\"33\" y2=\"60\" />\n",
" <line x1=\"39\" y1=\"29\" x2=\"39\" y2=\"66\" />\n",
" <line x1=\"45\" y1=\"35\" x2=\"45\" y2=\"72\" />\n",
" <line x1=\"50\" y1=\"40\" x2=\"50\" y2=\"78\" />\n",
" <line x1=\"56\" y1=\"46\" x2=\"56\" y2=\"84\" />\n",
" <line x1=\"62\" y1=\"52\" x2=\"62\" y2=\"90\" />\n",
" <line x1=\"68\" y1=\"58\" x2=\"68\" y2=\"96\" />\n",
" <line x1=\"74\" y1=\"64\" x2=\"74\" y2=\"102\" />\n",
" <line x1=\"80\" y1=\"70\" x2=\"80\" y2=\"108\" style=\"stroke-width:2\" />\n",
"\n",
" <!-- Colored Rectangle -->\n",
" <polygon points=\"10.0,0.0 80.58823529411765,70.58823529411765 80.58823529411765,108.07999437241787 10.0,37.49175907830022\" style=\"fill:#ECB172A0;stroke-width:0\"/>\n",
"\n",
" <!-- Horizontal lines -->\n",
" <line x1=\"10\" y1=\"0\" x2=\"51\" y2=\"0\" style=\"stroke-width:2\" />\n",
" <line x1=\"15\" y1=\"5\" x2=\"57\" y2=\"5\" />\n",
" <line x1=\"21\" y1=\"11\" x2=\"62\" y2=\"11\" />\n",
" <line x1=\"27\" y1=\"17\" x2=\"68\" y2=\"17\" />\n",
" <line x1=\"33\" y1=\"23\" x2=\"74\" y2=\"23\" />\n",
" <line x1=\"39\" y1=\"29\" x2=\"80\" y2=\"29\" />\n",
" <line x1=\"45\" y1=\"35\" x2=\"86\" y2=\"35\" />\n",
" <line x1=\"50\" y1=\"40\" x2=\"92\" y2=\"40\" />\n",
" <line x1=\"56\" y1=\"46\" x2=\"98\" y2=\"46\" />\n",
" <line x1=\"62\" y1=\"52\" x2=\"103\" y2=\"52\" />\n",
" <line x1=\"68\" y1=\"58\" x2=\"109\" y2=\"58\" />\n",
" <line x1=\"74\" y1=\"64\" x2=\"115\" y2=\"64\" />\n",
" <line x1=\"80\" y1=\"70\" x2=\"121\" y2=\"70\" style=\"stroke-width:2\" />\n",
"\n",
" <!-- Vertical lines -->\n",
" <line x1=\"10\" y1=\"0\" x2=\"80\" y2=\"70\" style=\"stroke-width:2\" />\n",
" <line x1=\"51\" y1=\"0\" x2=\"121\" y2=\"70\" style=\"stroke-width:2\" />\n",
"\n",
" <!-- Colored Rectangle -->\n",
" <polygon points=\"10.0,0.0 51.13999720598501,0.0 121.72823250010266,70.58823529411765 80.58823529411765,70.58823529411765\" style=\"fill:#ECB172A0;stroke-width:0\"/>\n",
"\n",
" <!-- Horizontal lines -->\n",
" <line x1=\"80\" y1=\"70\" x2=\"121\" y2=\"70\" style=\"stroke-width:2\" />\n",
" <line x1=\"80\" y1=\"73\" x2=\"121\" y2=\"73\" />\n",
" <line x1=\"80\" y1=\"75\" x2=\"121\" y2=\"75\" />\n",
" <line x1=\"80\" y1=\"78\" x2=\"121\" y2=\"78\" />\n",
" <line x1=\"80\" y1=\"80\" x2=\"121\" y2=\"80\" />\n",
" <line x1=\"80\" y1=\"83\" x2=\"121\" y2=\"83\" />\n",
" <line x1=\"80\" y1=\"86\" x2=\"121\" y2=\"86\" />\n",
" <line x1=\"80\" y1=\"88\" x2=\"121\" y2=\"88\" />\n",
" <line x1=\"80\" y1=\"91\" x2=\"121\" y2=\"91\" />\n",
" <line x1=\"80\" y1=\"93\" x2=\"121\" y2=\"93\" />\n",
" <line x1=\"80\" y1=\"96\" x2=\"121\" y2=\"96\" />\n",
" <line x1=\"80\" y1=\"99\" x2=\"121\" y2=\"99\" />\n",
" <line x1=\"80\" y1=\"101\" x2=\"121\" y2=\"101\" />\n",
" <line x1=\"80\" y1=\"104\" x2=\"121\" y2=\"104\" />\n",
" <line x1=\"80\" y1=\"106\" x2=\"121\" y2=\"106\" />\n",
" <line x1=\"80\" y1=\"108\" x2=\"121\" y2=\"108\" style=\"stroke-width:2\" />\n",
"\n",
" <!-- Vertical lines -->\n",
" <line x1=\"80\" y1=\"70\" x2=\"80\" y2=\"108\" style=\"stroke-width:2\" />\n",
" <line x1=\"121\" y1=\"70\" x2=\"121\" y2=\"108\" style=\"stroke-width:2\" />\n",
"\n",
" <!-- Colored Rectangle -->\n",
" <polygon points=\"80.58823529411765,70.58823529411765 121.72823250010266,70.58823529411765 121.72823250010266,108.07999437241787 80.58823529411765,108.07999437241787\" style=\"fill:#ECB172A0;stroke-width:0\"/>\n",
"\n",
" <!-- Text -->\n",
" <text x=\"101.158234\" y=\"128.079994\" font-size=\"1.0rem\" font-weight=\"100\" text-anchor=\"middle\" >1440</text>\n",
" <text x=\"141.728233\" y=\"89.334115\" font-size=\"1.0rem\" font-weight=\"100\" text-anchor=\"middle\" transform=\"rotate(-90,141.728233,89.334115)\">721</text>\n",
" <text x=\"35.294118\" y=\"92.785877\" font-size=\"1.0rem\" font-weight=\"100\" text-anchor=\"middle\" transform=\"rotate(45,35.294118,92.785877)\">8760</text>\n",
"</svg>\n",
" </td>\n",
" </tr>\n",
"</table></div></div></li><li class='xr-section-item'><input id='section-7740edda-3e69-459c-8754-2feab9a0d900' class='xr-section-summary-in' type='checkbox' checked><label for='section-7740edda-3e69-459c-8754-2feab9a0d900' class='xr-section-summary' >Coordinates: <span>(3)</span></label><div class='xr-section-inline-details'></div><div class='xr-section-details'><ul class='xr-var-list'><li class='xr-var-item'><div class='xr-var-name'><span class='xr-has-index'>longitude</span></div><div class='xr-var-dims'>(longitude)</div><div class='xr-var-dtype'>float32</div><div class='xr-var-preview xr-preview'>0.0 0.25 0.5 ... 359.2 359.5 359.8</div><input id='attrs-f7826ed1-d317-46b2-b090-f1512ebe2d78' class='xr-var-attrs-in' type='checkbox' ><label for='attrs-f7826ed1-d317-46b2-b090-f1512ebe2d78' title='Show/Hide attributes'><svg class='icon xr-icon-file-text2'><use xlink:href='#icon-file-text2'></use></svg></label><input id='data-aa1e8484-3aea-47c5-b651-ff8cb891b436' class='xr-var-data-in' type='checkbox'><label for='data-aa1e8484-3aea-47c5-b651-ff8cb891b436' title='Show/Hide data repr'><svg class='icon xr-icon-database'><use xlink:href='#icon-database'></use></svg></label><div class='xr-var-attrs'><dl class='xr-attrs'><dt><span>units :</span></dt><dd>degrees_east</dd><dt><span>long_name :</span></dt><dd>longitude</dd></dl></div><div class='xr-var-data'><pre>array([0.0000e+00, 2.5000e-01, 5.0000e-01, ..., 3.5925e+02, 3.5950e+02,\n",
" 3.5975e+02], dtype=float32)</pre></div></li><li class='xr-var-item'><div class='xr-var-name'><span class='xr-has-index'>latitude</span></div><div class='xr-var-dims'>(latitude)</div><div class='xr-var-dtype'>float32</div><div class='xr-var-preview xr-preview'>90.0 89.75 89.5 ... -89.75 -90.0</div><input id='attrs-2c71fb23-e983-4eb8-ac45-dfb9bdc0a3fa' class='xr-var-attrs-in' type='checkbox' ><label for='attrs-2c71fb23-e983-4eb8-ac45-dfb9bdc0a3fa' title='Show/Hide attributes'><svg class='icon xr-icon-file-text2'><use xlink:href='#icon-file-text2'></use></svg></label><input id='data-a8c3fbe4-fe2f-46e5-a53e-bf9a332c3e6d' class='xr-var-data-in' type='checkbox'><label for='data-a8c3fbe4-fe2f-46e5-a53e-bf9a332c3e6d' title='Show/Hide data repr'><svg class='icon xr-icon-database'><use xlink:href='#icon-database'></use></svg></label><div class='xr-var-attrs'><dl class='xr-attrs'><dt><span>units :</span></dt><dd>degrees_north</dd><dt><span>long_name :</span></dt><dd>latitude</dd></dl></div><div class='xr-var-data'><pre>array([ 90. , 89.75, 89.5 , ..., -89.5 , -89.75, -90. ], dtype=float32)</pre></div></li><li class='xr-var-item'><div class='xr-var-name'><span class='xr-has-index'>time</span></div><div class='xr-var-dims'>(time)</div><div class='xr-var-dtype'>datetime64[ns]</div><div class='xr-var-preview xr-preview'>2021-01-01 ... 2021-12-31T23:00:00</div><input id='attrs-ab17e4ae-2b07-49a2-9d80-f3a2fff6ad38' class='xr-var-attrs-in' type='checkbox' ><label for='attrs-ab17e4ae-2b07-49a2-9d80-f3a2fff6ad38' title='Show/Hide attributes'><svg class='icon xr-icon-file-text2'><use xlink:href='#icon-file-text2'></use></svg></label><input id='data-5ec64b82-b663-4481-b858-aa748dc21d0b' class='xr-var-data-in' type='checkbox'><label for='data-5ec64b82-b663-4481-b858-aa748dc21d0b' title='Show/Hide data repr'><svg class='icon xr-icon-database'><use xlink:href='#icon-database'></use></svg></label><div class='xr-var-attrs'><dl class='xr-attrs'><dt><span>long_name :</span></dt><dd>time</dd></dl></div><div class='xr-var-data'><pre>array([&#x27;2021-01-01T00:00:00.000000000&#x27;, &#x27;2021-01-01T01:00:00.000000000&#x27;,\n",
" &#x27;2021-01-01T02:00:00.000000000&#x27;, ..., &#x27;2021-12-31T21:00:00.000000000&#x27;,\n",
" &#x27;2021-12-31T22:00:00.000000000&#x27;, &#x27;2021-12-31T23:00:00.000000000&#x27;],\n",
" dtype=&#x27;datetime64[ns]&#x27;)</pre></div></li></ul></div></li><li class='xr-section-item'><input id='section-e8ae387d-36d4-423c-afa0-7d070f8f362c' class='xr-section-summary-in' type='checkbox' checked><label for='section-e8ae387d-36d4-423c-afa0-7d070f8f362c' class='xr-section-summary' >Attributes: <span>(2)</span></label><div class='xr-section-inline-details'></div><div class='xr-section-details'><dl class='xr-attrs'><dt><span>units :</span></dt><dd>m</dd><dt><span>long_name :</span></dt><dd>Total precipitation</dd></dl></div></li></ul></div></div>"
],
"text/plain": [
"<xarray.DataArray 'tp' (time: 8760, latitude: 721, longitude: 1440)>\n",
"dask.array<concatenate, shape=(8760, 721, 1440), dtype=float32, chunksize=(744, 50, 1440), chunktype=numpy.ndarray>\n",
"Coordinates:\n",
" * longitude (longitude) float32 0.0 0.25 0.5 0.75 ... 359.0 359.2 359.5 359.8\n",
" * latitude (latitude) float32 90.0 89.75 89.5 89.25 ... -89.5 -89.75 -90.0\n",
" * time (time) datetime64[ns] 2021-01-01 ... 2021-12-31T23:00:00\n",
"Attributes:\n",
" units: m\n",
" long_name: Total precipitation"
]
},
"execution_count": 19,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"ds = xr.open_mfdataset('hourly_tp/ERA5_HiRes_Hourly_tp_2021_*.nc', chunks={'latitude':50})\n",
"ds.tp"
]
},
{
"cell_type": "code",
"execution_count": 20,
"id": "c5e382de-2b7b-4882-bb7f-75bae1d268c7",
"metadata": {},
"outputs": [
{
"data": {
"text/html": [
"<div><svg style=\"position: absolute; width: 0; height: 0; overflow: hidden\">\n",
"<defs>\n",
"<symbol id=\"icon-database\" viewBox=\"0 0 32 32\">\n",
"<path d=\"M16 0c-8.837 0-16 2.239-16 5v4c0 2.761 7.163 5 16 5s16-2.239 16-5v-4c0-2.761-7.163-5-16-5z\"></path>\n",
"<path d=\"M16 17c-8.837 0-16-2.239-16-5v6c0 2.761 7.163 5 16 5s16-2.239 16-5v-6c0 2.761-7.163 5-16 5z\"></path>\n",
"<path d=\"M16 26c-8.837 0-16-2.239-16-5v6c0 2.761 7.163 5 16 5s16-2.239 16-5v-6c0 2.761-7.163 5-16 5z\"></path>\n",
"</symbol>\n",
"<symbol id=\"icon-file-text2\" viewBox=\"0 0 32 32\">\n",
"<path d=\"M28.681 7.159c-0.694-0.947-1.662-2.053-2.724-3.116s-2.169-2.030-3.116-2.724c-1.612-1.182-2.393-1.319-2.841-1.319h-15.5c-1.378 0-2.5 1.121-2.5 2.5v27c0 1.378 1.122 2.5 2.5 2.5h23c1.378 0 2.5-1.122 2.5-2.5v-19.5c0-0.448-0.137-1.23-1.319-2.841zM24.543 5.457c0.959 0.959 1.712 1.825 2.268 2.543h-4.811v-4.811c0.718 0.556 1.584 1.309 2.543 2.268zM28 29.5c0 0.271-0.229 0.5-0.5 0.5h-23c-0.271 0-0.5-0.229-0.5-0.5v-27c0-0.271 0.229-0.5 0.5-0.5 0 0 15.499-0 15.5 0v7c0 0.552 0.448 1 1 1h7v19.5z\"></path>\n",
"<path d=\"M23 26h-14c-0.552 0-1-0.448-1-1s0.448-1 1-1h14c0.552 0 1 0.448 1 1s-0.448 1-1 1z\"></path>\n",
"<path d=\"M23 22h-14c-0.552 0-1-0.448-1-1s0.448-1 1-1h14c0.552 0 1 0.448 1 1s-0.448 1-1 1z\"></path>\n",
"<path d=\"M23 18h-14c-0.552 0-1-0.448-1-1s0.448-1 1-1h14c0.552 0 1 0.448 1 1s-0.448 1-1 1z\"></path>\n",
"</symbol>\n",
"</defs>\n",
"</svg>\n",
"<style>/* CSS stylesheet for displaying xarray objects in jupyterlab.\n",
" *\n",
" */\n",
"\n",
":root {\n",
" --xr-font-color0: var(--jp-content-font-color0, rgba(0, 0, 0, 1));\n",
" --xr-font-color2: var(--jp-content-font-color2, rgba(0, 0, 0, 0.54));\n",
" --xr-font-color3: var(--jp-content-font-color3, rgba(0, 0, 0, 0.38));\n",
" --xr-border-color: var(--jp-border-color2, #e0e0e0);\n",
" --xr-disabled-color: var(--jp-layout-color3, #bdbdbd);\n",
" --xr-background-color: var(--jp-layout-color0, white);\n",
" --xr-background-color-row-even: var(--jp-layout-color1, white);\n",
" --xr-background-color-row-odd: var(--jp-layout-color2, #eeeeee);\n",
"}\n",
"\n",
"html[theme=dark],\n",
"body.vscode-dark {\n",
" --xr-font-color0: rgba(255, 255, 255, 1);\n",
" --xr-font-color2: rgba(255, 255, 255, 0.54);\n",
" --xr-font-color3: rgba(255, 255, 255, 0.38);\n",
" --xr-border-color: #1F1F1F;\n",
" --xr-disabled-color: #515151;\n",
" --xr-background-color: #111111;\n",
" --xr-background-color-row-even: #111111;\n",
" --xr-background-color-row-odd: #313131;\n",
"}\n",
"\n",
".xr-wrap {\n",
" display: block !important;\n",
" min-width: 300px;\n",
" max-width: 700px;\n",
"}\n",
"\n",
".xr-text-repr-fallback {\n",
" /* fallback to plain text repr when CSS is not injected (untrusted notebook) */\n",
" display: none;\n",
"}\n",
"\n",
".xr-header {\n",
" padding-top: 6px;\n",
" padding-bottom: 6px;\n",
" margin-bottom: 4px;\n",
" border-bottom: solid 1px var(--xr-border-color);\n",
"}\n",
"\n",
".xr-header > div,\n",
".xr-header > ul {\n",
" display: inline;\n",
" margin-top: 0;\n",
" margin-bottom: 0;\n",
"}\n",
"\n",
".xr-obj-type,\n",
".xr-array-name {\n",
" margin-left: 2px;\n",
" margin-right: 10px;\n",
"}\n",
"\n",
".xr-obj-type {\n",
" color: var(--xr-font-color2);\n",
"}\n",
"\n",
".xr-sections {\n",
" padding-left: 0 !important;\n",
" display: grid;\n",
" grid-template-columns: 150px auto auto 1fr 20px 20px;\n",
"}\n",
"\n",
".xr-section-item {\n",
" display: contents;\n",
"}\n",
"\n",
".xr-section-item input {\n",
" display: none;\n",
"}\n",
"\n",
".xr-section-item input + label {\n",
" color: var(--xr-disabled-color);\n",
"}\n",
"\n",
".xr-section-item input:enabled + label {\n",
" cursor: pointer;\n",
" color: var(--xr-font-color2);\n",
"}\n",
"\n",
".xr-section-item input:enabled + label:hover {\n",
" color: var(--xr-font-color0);\n",
"}\n",
"\n",
".xr-section-summary {\n",
" grid-column: 1;\n",
" color: var(--xr-font-color2);\n",
" font-weight: 500;\n",
"}\n",
"\n",
".xr-section-summary > span {\n",
" display: inline-block;\n",
" padding-left: 0.5em;\n",
"}\n",
"\n",
".xr-section-summary-in:disabled + label {\n",
" color: var(--xr-font-color2);\n",
"}\n",
"\n",
".xr-section-summary-in + label:before {\n",
" display: inline-block;\n",
" content: '►';\n",
" font-size: 11px;\n",
" width: 15px;\n",
" text-align: center;\n",
"}\n",
"\n",
".xr-section-summary-in:disabled + label:before {\n",
" color: var(--xr-disabled-color);\n",
"}\n",
"\n",
".xr-section-summary-in:checked + label:before {\n",
" content: '▼';\n",
"}\n",
"\n",
".xr-section-summary-in:checked + label > span {\n",
" display: none;\n",
"}\n",
"\n",
".xr-section-summary,\n",
".xr-section-inline-details {\n",
" padding-top: 4px;\n",
" padding-bottom: 4px;\n",
"}\n",
"\n",
".xr-section-inline-details {\n",
" grid-column: 2 / -1;\n",
"}\n",
"\n",
".xr-section-details {\n",
" display: none;\n",
" grid-column: 1 / -1;\n",
" margin-bottom: 5px;\n",
"}\n",
"\n",
".xr-section-summary-in:checked ~ .xr-section-details {\n",
" display: contents;\n",
"}\n",
"\n",
".xr-array-wrap {\n",
" grid-column: 1 / -1;\n",
" display: grid;\n",
" grid-template-columns: 20px auto;\n",
"}\n",
"\n",
".xr-array-wrap > label {\n",
" grid-column: 1;\n",
" vertical-align: top;\n",
"}\n",
"\n",
".xr-preview {\n",
" color: var(--xr-font-color3);\n",
"}\n",
"\n",
".xr-array-preview,\n",
".xr-array-data {\n",
" padding: 0 5px !important;\n",
" grid-column: 2;\n",
"}\n",
"\n",
".xr-array-data,\n",
".xr-array-in:checked ~ .xr-array-preview {\n",
" display: none;\n",
"}\n",
"\n",
".xr-array-in:checked ~ .xr-array-data,\n",
".xr-array-preview {\n",
" display: inline-block;\n",
"}\n",
"\n",
".xr-dim-list {\n",
" display: inline-block !important;\n",
" list-style: none;\n",
" padding: 0 !important;\n",
" margin: 0;\n",
"}\n",
"\n",
".xr-dim-list li {\n",
" display: inline-block;\n",
" padding: 0;\n",
" margin: 0;\n",
"}\n",
"\n",
".xr-dim-list:before {\n",
" content: '(';\n",
"}\n",
"\n",
".xr-dim-list:after {\n",
" content: ')';\n",
"}\n",
"\n",
".xr-dim-list li:not(:last-child):after {\n",
" content: ',';\n",
" padding-right: 5px;\n",
"}\n",
"\n",
".xr-has-index {\n",
" font-weight: bold;\n",
"}\n",
"\n",
".xr-var-list,\n",
".xr-var-item {\n",
" display: contents;\n",
"}\n",
"\n",
".xr-var-item > div,\n",
".xr-var-item label,\n",
".xr-var-item > .xr-var-name span {\n",
" background-color: var(--xr-background-color-row-even);\n",
" margin-bottom: 0;\n",
"}\n",
"\n",
".xr-var-item > .xr-var-name:hover span {\n",
" padding-right: 5px;\n",
"}\n",
"\n",
".xr-var-list > li:nth-child(odd) > div,\n",
".xr-var-list > li:nth-child(odd) > label,\n",
".xr-var-list > li:nth-child(odd) > .xr-var-name span {\n",
" background-color: var(--xr-background-color-row-odd);\n",
"}\n",
"\n",
".xr-var-name {\n",
" grid-column: 1;\n",
"}\n",
"\n",
".xr-var-dims {\n",
" grid-column: 2;\n",
"}\n",
"\n",
".xr-var-dtype {\n",
" grid-column: 3;\n",
" text-align: right;\n",
" color: var(--xr-font-color2);\n",
"}\n",
"\n",
".xr-var-preview {\n",
" grid-column: 4;\n",
"}\n",
"\n",
".xr-var-name,\n",
".xr-var-dims,\n",
".xr-var-dtype,\n",
".xr-preview,\n",
".xr-attrs dt {\n",
" white-space: nowrap;\n",
" overflow: hidden;\n",
" text-overflow: ellipsis;\n",
" padding-right: 10px;\n",
"}\n",
"\n",
".xr-var-name:hover,\n",
".xr-var-dims:hover,\n",
".xr-var-dtype:hover,\n",
".xr-attrs dt:hover {\n",
" overflow: visible;\n",
" width: auto;\n",
" z-index: 1;\n",
"}\n",
"\n",
".xr-var-attrs,\n",
".xr-var-data {\n",
" display: none;\n",
" background-color: var(--xr-background-color) !important;\n",
" padding-bottom: 5px !important;\n",
"}\n",
"\n",
".xr-var-attrs-in:checked ~ .xr-var-attrs,\n",
".xr-var-data-in:checked ~ .xr-var-data {\n",
" display: block;\n",
"}\n",
"\n",
".xr-var-data > table {\n",
" float: right;\n",
"}\n",
"\n",
".xr-var-name span,\n",
".xr-var-data,\n",
".xr-attrs {\n",
" padding-left: 25px !important;\n",
"}\n",
"\n",
".xr-attrs,\n",
".xr-var-attrs,\n",
".xr-var-data {\n",
" grid-column: 1 / -1;\n",
"}\n",
"\n",
"dl.xr-attrs {\n",
" padding: 0;\n",
" margin: 0;\n",
" display: grid;\n",
" grid-template-columns: 125px auto;\n",
"}\n",
"\n",
".xr-attrs dt,\n",
".xr-attrs dd {\n",
" padding: 0;\n",
" margin: 0;\n",
" float: left;\n",
" padding-right: 10px;\n",
" width: auto;\n",
"}\n",
"\n",
".xr-attrs dt {\n",
" font-weight: normal;\n",
" grid-column: 1;\n",
"}\n",
"\n",
".xr-attrs dt:hover span {\n",
" display: inline-block;\n",
" background: var(--xr-background-color);\n",
" padding-right: 10px;\n",
"}\n",
"\n",
".xr-attrs dd {\n",
" grid-column: 2;\n",
" white-space: pre-wrap;\n",
" word-break: break-all;\n",
"}\n",
"\n",
".xr-icon-database,\n",
".xr-icon-file-text2 {\n",
" display: inline-block;\n",
" vertical-align: middle;\n",
" width: 1em;\n",
" height: 1.5em !important;\n",
" stroke-width: 0;\n",
" stroke: currentColor;\n",
" fill: currentColor;\n",
"}\n",
"</style><pre class='xr-text-repr-fallback'>&lt;xarray.DataArray &#x27;tp&#x27; (hour: 24, latitude: 721, longitude: 1440)&gt;\n",
"dask.array&lt;stack, shape=(24, 721, 1440), dtype=float32, chunksize=(1, 50, 1440), chunktype=numpy.ndarray&gt;\n",
"Coordinates:\n",
" * longitude (longitude) float32 0.0 0.25 0.5 0.75 ... 359.0 359.2 359.5 359.8\n",
" * latitude (latitude) float32 90.0 89.75 89.5 89.25 ... -89.5 -89.75 -90.0\n",
" * hour (hour) int64 0 1 2 3 4 5 6 7 8 9 ... 15 16 17 18 19 20 21 22 23</pre><div class='xr-wrap' style='display:none'><div class='xr-header'><div class='xr-obj-type'>xarray.DataArray</div><div class='xr-array-name'>'tp'</div><ul class='xr-dim-list'><li><span class='xr-has-index'>hour</span>: 24</li><li><span class='xr-has-index'>latitude</span>: 721</li><li><span class='xr-has-index'>longitude</span>: 1440</li></ul></div><ul class='xr-sections'><li class='xr-section-item'><div class='xr-array-wrap'><input id='section-8e1e463e-3be5-420f-82c4-bbfd0ea9529e' class='xr-array-in' type='checkbox' checked><label for='section-8e1e463e-3be5-420f-82c4-bbfd0ea9529e' title='Show/hide data repr'><svg class='icon xr-icon-database'><use xlink:href='#icon-database'></use></svg></label><div class='xr-array-preview xr-preview'><span>dask.array&lt;chunksize=(1, 50, 1440), meta=np.ndarray&gt;</span></div><div class='xr-array-data'><table>\n",
" <tr>\n",
" <td>\n",
" <table>\n",
" <thead>\n",
" <tr>\n",
" <td> </td>\n",
" <th> Array </th>\n",
" <th> Chunk </th>\n",
" </tr>\n",
" </thead>\n",
" <tbody>\n",
" \n",
" <tr>\n",
" <th> Bytes </th>\n",
" <td> 95.05 MiB </td>\n",
" <td> 281.25 kiB </td>\n",
" </tr>\n",
" \n",
" <tr>\n",
" <th> Shape </th>\n",
" <td> (24, 721, 1440) </td>\n",
" <td> (1, 50, 1440) </td>\n",
" </tr>\n",
" <tr>\n",
" <th> Count </th>\n",
" <td> 10812 Tasks </td>\n",
" <td> 360 Chunks </td>\n",
" </tr>\n",
" <tr>\n",
" <th> Type </th>\n",
" <td> float32 </td>\n",
" <td> numpy.ndarray </td>\n",
" </tr>\n",
" </tbody>\n",
" </table>\n",
" </td>\n",
" <td>\n",
" <svg width=\"196\" height=\"126\" style=\"stroke:rgb(0,0,0);stroke-width:1\" >\n",
"\n",
" <!-- Horizontal lines -->\n",
" <line x1=\"10\" y1=\"0\" x2=\"26\" y2=\"16\" style=\"stroke-width:2\" />\n",
" <line x1=\"10\" y1=\"4\" x2=\"26\" y2=\"20\" />\n",
" <line x1=\"10\" y1=\"8\" x2=\"26\" y2=\"24\" />\n",
" <line x1=\"10\" y1=\"12\" x2=\"26\" y2=\"28\" />\n",
" <line x1=\"10\" y1=\"16\" x2=\"26\" y2=\"33\" />\n",
" <line x1=\"10\" y1=\"20\" x2=\"26\" y2=\"37\" />\n",
" <line x1=\"10\" y1=\"25\" x2=\"26\" y2=\"41\" />\n",
" <line x1=\"10\" y1=\"29\" x2=\"26\" y2=\"45\" />\n",
" <line x1=\"10\" y1=\"33\" x2=\"26\" y2=\"49\" />\n",
" <line x1=\"10\" y1=\"37\" x2=\"26\" y2=\"53\" />\n",
" <line x1=\"10\" y1=\"41\" x2=\"26\" y2=\"58\" />\n",
" <line x1=\"10\" y1=\"45\" x2=\"26\" y2=\"62\" />\n",
" <line x1=\"10\" y1=\"50\" x2=\"26\" y2=\"66\" />\n",
" <line x1=\"10\" y1=\"54\" x2=\"26\" y2=\"70\" />\n",
" <line x1=\"10\" y1=\"58\" x2=\"26\" y2=\"74\" />\n",
" <line x1=\"10\" y1=\"60\" x2=\"26\" y2=\"76\" style=\"stroke-width:2\" />\n",
"\n",
" <!-- Vertical lines -->\n",
" <line x1=\"10\" y1=\"0\" x2=\"10\" y2=\"60\" style=\"stroke-width:2\" />\n",
" <line x1=\"10\" y1=\"0\" x2=\"10\" y2=\"60\" />\n",
" <line x1=\"11\" y1=\"1\" x2=\"11\" y2=\"61\" />\n",
" <line x1=\"12\" y1=\"2\" x2=\"12\" y2=\"62\" />\n",
" <line x1=\"13\" y1=\"3\" x2=\"13\" y2=\"63\" />\n",
" <line x1=\"14\" y1=\"4\" x2=\"14\" y2=\"64\" />\n",
" <line x1=\"14\" y1=\"4\" x2=\"14\" y2=\"64\" />\n",
" <line x1=\"15\" y1=\"5\" x2=\"15\" y2=\"65\" />\n",
" <line x1=\"16\" y1=\"6\" x2=\"16\" y2=\"66\" />\n",
" <line x1=\"17\" y1=\"7\" x2=\"17\" y2=\"67\" />\n",
" <line x1=\"18\" y1=\"8\" x2=\"18\" y2=\"68\" />\n",
" <line x1=\"18\" y1=\"8\" x2=\"18\" y2=\"69\" />\n",
" <line x1=\"20\" y1=\"10\" x2=\"20\" y2=\"70\" />\n",
" <line x1=\"20\" y1=\"10\" x2=\"20\" y2=\"71\" />\n",
" <line x1=\"21\" y1=\"11\" x2=\"21\" y2=\"71\" />\n",
" <line x1=\"22\" y1=\"12\" x2=\"22\" y2=\"72\" />\n",
" <line x1=\"23\" y1=\"13\" x2=\"23\" y2=\"73\" />\n",
" <line x1=\"24\" y1=\"14\" x2=\"24\" y2=\"74\" />\n",
" <line x1=\"25\" y1=\"15\" x2=\"25\" y2=\"75\" />\n",
" <line x1=\"26\" y1=\"16\" x2=\"26\" y2=\"76\" style=\"stroke-width:2\" />\n",
"\n",
" <!-- Colored Rectangle -->\n",
" <polygon points=\"10.0,0.0 26.484080952415905,16.484080952415905 26.484080952415905,76.56741428574924 10.0,60.083333333333336\" style=\"fill:#8B4903A0;stroke-width:0\"/>\n",
"\n",
" <!-- Horizontal lines -->\n",
" <line x1=\"10\" y1=\"0\" x2=\"130\" y2=\"0\" style=\"stroke-width:2\" />\n",
" <line x1=\"10\" y1=\"0\" x2=\"130\" y2=\"0\" />\n",
" <line x1=\"11\" y1=\"1\" x2=\"131\" y2=\"1\" />\n",
" <line x1=\"12\" y1=\"2\" x2=\"132\" y2=\"2\" />\n",
" <line x1=\"13\" y1=\"3\" x2=\"133\" y2=\"3\" />\n",
" <line x1=\"14\" y1=\"4\" x2=\"134\" y2=\"4\" />\n",
" <line x1=\"14\" y1=\"4\" x2=\"134\" y2=\"4\" />\n",
" <line x1=\"15\" y1=\"5\" x2=\"135\" y2=\"5\" />\n",
" <line x1=\"16\" y1=\"6\" x2=\"136\" y2=\"6\" />\n",
" <line x1=\"17\" y1=\"7\" x2=\"137\" y2=\"7\" />\n",
" <line x1=\"18\" y1=\"8\" x2=\"138\" y2=\"8\" />\n",
" <line x1=\"18\" y1=\"8\" x2=\"138\" y2=\"8\" />\n",
" <line x1=\"20\" y1=\"10\" x2=\"140\" y2=\"10\" />\n",
" <line x1=\"20\" y1=\"10\" x2=\"140\" y2=\"10\" />\n",
" <line x1=\"21\" y1=\"11\" x2=\"141\" y2=\"11\" />\n",
" <line x1=\"22\" y1=\"12\" x2=\"142\" y2=\"12\" />\n",
" <line x1=\"23\" y1=\"13\" x2=\"143\" y2=\"13\" />\n",
" <line x1=\"24\" y1=\"14\" x2=\"144\" y2=\"14\" />\n",
" <line x1=\"25\" y1=\"15\" x2=\"145\" y2=\"15\" />\n",
" <line x1=\"26\" y1=\"16\" x2=\"146\" y2=\"16\" style=\"stroke-width:2\" />\n",
"\n",
" <!-- Vertical lines -->\n",
" <line x1=\"10\" y1=\"0\" x2=\"26\" y2=\"16\" style=\"stroke-width:2\" />\n",
" <line x1=\"130\" y1=\"0\" x2=\"146\" y2=\"16\" style=\"stroke-width:2\" />\n",
"\n",
" <!-- Colored Rectangle -->\n",
" <polygon points=\"10.0,0.0 130.0,0.0 146.4840809524159,16.484080952415905 26.484080952415905,16.484080952415905\" style=\"fill:#8B4903A0;stroke-width:0\"/>\n",
"\n",
" <!-- Horizontal lines -->\n",
" <line x1=\"26\" y1=\"16\" x2=\"146\" y2=\"16\" style=\"stroke-width:2\" />\n",
" <line x1=\"26\" y1=\"20\" x2=\"146\" y2=\"20\" />\n",
" <line x1=\"26\" y1=\"24\" x2=\"146\" y2=\"24\" />\n",
" <line x1=\"26\" y1=\"28\" x2=\"146\" y2=\"28\" />\n",
" <line x1=\"26\" y1=\"33\" x2=\"146\" y2=\"33\" />\n",
" <line x1=\"26\" y1=\"37\" x2=\"146\" y2=\"37\" />\n",
" <line x1=\"26\" y1=\"41\" x2=\"146\" y2=\"41\" />\n",
" <line x1=\"26\" y1=\"45\" x2=\"146\" y2=\"45\" />\n",
" <line x1=\"26\" y1=\"49\" x2=\"146\" y2=\"49\" />\n",
" <line x1=\"26\" y1=\"53\" x2=\"146\" y2=\"53\" />\n",
" <line x1=\"26\" y1=\"58\" x2=\"146\" y2=\"58\" />\n",
" <line x1=\"26\" y1=\"62\" x2=\"146\" y2=\"62\" />\n",
" <line x1=\"26\" y1=\"66\" x2=\"146\" y2=\"66\" />\n",
" <line x1=\"26\" y1=\"70\" x2=\"146\" y2=\"70\" />\n",
" <line x1=\"26\" y1=\"74\" x2=\"146\" y2=\"74\" />\n",
" <line x1=\"26\" y1=\"76\" x2=\"146\" y2=\"76\" style=\"stroke-width:2\" />\n",
"\n",
" <!-- Vertical lines -->\n",
" <line x1=\"26\" y1=\"16\" x2=\"26\" y2=\"76\" style=\"stroke-width:2\" />\n",
" <line x1=\"146\" y1=\"16\" x2=\"146\" y2=\"76\" style=\"stroke-width:2\" />\n",
"\n",
" <!-- Colored Rectangle -->\n",
" <polygon points=\"26.484080952415905,16.484080952415905 146.4840809524159,16.484080952415905 146.4840809524159,76.56741428574924 26.484080952415905,76.56741428574924\" style=\"fill:#ECB172A0;stroke-width:0\"/>\n",
"\n",
" <!-- Text -->\n",
" <text x=\"86.484081\" y=\"96.567414\" font-size=\"1.0rem\" font-weight=\"100\" text-anchor=\"middle\" >1440</text>\n",
" <text x=\"166.484081\" y=\"46.525748\" font-size=\"1.0rem\" font-weight=\"100\" text-anchor=\"middle\" transform=\"rotate(-90,166.484081,46.525748)\">721</text>\n",
" <text x=\"8.242040\" y=\"88.325374\" font-size=\"1.0rem\" font-weight=\"100\" text-anchor=\"middle\" transform=\"rotate(45,8.242040,88.325374)\">24</text>\n",
"</svg>\n",
" </td>\n",
" </tr>\n",
"</table></div></div></li><li class='xr-section-item'><input id='section-010b282c-7bbe-4a45-9f79-e53dc51a08a1' class='xr-section-summary-in' type='checkbox' checked><label for='section-010b282c-7bbe-4a45-9f79-e53dc51a08a1' class='xr-section-summary' >Coordinates: <span>(3)</span></label><div class='xr-section-inline-details'></div><div class='xr-section-details'><ul class='xr-var-list'><li class='xr-var-item'><div class='xr-var-name'><span class='xr-has-index'>longitude</span></div><div class='xr-var-dims'>(longitude)</div><div class='xr-var-dtype'>float32</div><div class='xr-var-preview xr-preview'>0.0 0.25 0.5 ... 359.2 359.5 359.8</div><input id='attrs-5b31b086-8a40-464a-ae08-a22555c4fa19' class='xr-var-attrs-in' type='checkbox' ><label for='attrs-5b31b086-8a40-464a-ae08-a22555c4fa19' title='Show/Hide attributes'><svg class='icon xr-icon-file-text2'><use xlink:href='#icon-file-text2'></use></svg></label><input id='data-00d39ca7-d5ad-4bf8-8f5e-3f90ec3e83ae' class='xr-var-data-in' type='checkbox'><label for='data-00d39ca7-d5ad-4bf8-8f5e-3f90ec3e83ae' title='Show/Hide data repr'><svg class='icon xr-icon-database'><use xlink:href='#icon-database'></use></svg></label><div class='xr-var-attrs'><dl class='xr-attrs'><dt><span>units :</span></dt><dd>degrees_east</dd><dt><span>long_name :</span></dt><dd>longitude</dd></dl></div><div class='xr-var-data'><pre>array([0.0000e+00, 2.5000e-01, 5.0000e-01, ..., 3.5925e+02, 3.5950e+02,\n",
" 3.5975e+02], dtype=float32)</pre></div></li><li class='xr-var-item'><div class='xr-var-name'><span class='xr-has-index'>latitude</span></div><div class='xr-var-dims'>(latitude)</div><div class='xr-var-dtype'>float32</div><div class='xr-var-preview xr-preview'>90.0 89.75 89.5 ... -89.75 -90.0</div><input id='attrs-0d0d8604-5203-4082-bd8f-e8e26e835b06' class='xr-var-attrs-in' type='checkbox' ><label for='attrs-0d0d8604-5203-4082-bd8f-e8e26e835b06' title='Show/Hide attributes'><svg class='icon xr-icon-file-text2'><use xlink:href='#icon-file-text2'></use></svg></label><input id='data-b21958ad-542a-419d-8302-36b0cd987fb7' class='xr-var-data-in' type='checkbox'><label for='data-b21958ad-542a-419d-8302-36b0cd987fb7' title='Show/Hide data repr'><svg class='icon xr-icon-database'><use xlink:href='#icon-database'></use></svg></label><div class='xr-var-attrs'><dl class='xr-attrs'><dt><span>units :</span></dt><dd>degrees_north</dd><dt><span>long_name :</span></dt><dd>latitude</dd></dl></div><div class='xr-var-data'><pre>array([ 90. , 89.75, 89.5 , ..., -89.5 , -89.75, -90. ], dtype=float32)</pre></div></li><li class='xr-var-item'><div class='xr-var-name'><span class='xr-has-index'>hour</span></div><div class='xr-var-dims'>(hour)</div><div class='xr-var-dtype'>int64</div><div class='xr-var-preview xr-preview'>0 1 2 3 4 5 6 ... 18 19 20 21 22 23</div><input id='attrs-475d6a89-a660-409e-ace7-83fde7331a95' class='xr-var-attrs-in' type='checkbox' disabled><label for='attrs-475d6a89-a660-409e-ace7-83fde7331a95' title='Show/Hide attributes'><svg class='icon xr-icon-file-text2'><use xlink:href='#icon-file-text2'></use></svg></label><input id='data-0f882634-34bc-48d0-9249-c6c834873200' class='xr-var-data-in' type='checkbox'><label for='data-0f882634-34bc-48d0-9249-c6c834873200' title='Show/Hide data repr'><svg class='icon xr-icon-database'><use xlink:href='#icon-database'></use></svg></label><div class='xr-var-attrs'><dl class='xr-attrs'></dl></div><div class='xr-var-data'><pre>array([ 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17,\n",
" 18, 19, 20, 21, 22, 23])</pre></div></li></ul></div></li><li class='xr-section-item'><input id='section-36a9b49b-846a-4350-a5c9-45de60714940' class='xr-section-summary-in' type='checkbox' disabled ><label for='section-36a9b49b-846a-4350-a5c9-45de60714940' class='xr-section-summary' title='Expand/collapse section'>Attributes: <span>(0)</span></label><div class='xr-section-inline-details'></div><div class='xr-section-details'><dl class='xr-attrs'></dl></div></li></ul></div></div>"
],
"text/plain": [
"<xarray.DataArray 'tp' (hour: 24, latitude: 721, longitude: 1440)>\n",
"dask.array<stack, shape=(24, 721, 1440), dtype=float32, chunksize=(1, 50, 1440), chunktype=numpy.ndarray>\n",
"Coordinates:\n",
" * longitude (longitude) float32 0.0 0.25 0.5 0.75 ... 359.0 359.2 359.5 359.8\n",
" * latitude (latitude) float32 90.0 89.75 89.5 89.25 ... -89.5 -89.75 -90.0\n",
" * hour (hour) int64 0 1 2 3 4 5 6 7 8 9 ... 15 16 17 18 19 20 21 22 23"
]
},
"execution_count": 20,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"tpm = ds.tp.groupby('time.hour').mean(dim='time')\n",
"tpm"
]
},
{
"cell_type": "code",
"execution_count": 21,
"id": "7069dc59-dbde-43b7-8903-21f9dd500427",
"metadata": {},
"outputs": [
{
"name": "stderr",
"output_type": "stream",
"text": [
"2022-05-08 16:07:36,732 - distributed.worker_memory - WARNING - Worker is at 86% memory usage. Pausing worker. Process memory: 1.74 GiB -- Worker memory limit: 2.00 GiB\n",
"2022-05-08 16:07:36,957 - distributed.worker_memory - WARNING - Worker exceeded 95% memory budget. Restarting\n",
"2022-05-08 16:07:37,309 - distributed.nanny - WARNING - Restarting worker\n",
"2022-05-08 16:07:37,979 - distributed.worker - ERROR - failed during get data with tcp://127.0.0.1:42667 -> tcp://127.0.0.1:44165\n",
"Traceback (most recent call last):\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/tornado/iostream.py\", line 971, in _handle_write\n",
" num_bytes = self.write_to_fd(self._write_buffer.peek(size))\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/tornado/iostream.py\", line 1148, in write_to_fd\n",
" return self.socket.send(data) # type: ignore\n",
"BrokenPipeError: [Errno 32] Broken pipe\n",
"\n",
"The above exception was the direct cause of the following exception:\n",
"\n",
"Traceback (most recent call last):\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/worker.py\", line 1728, in get_data\n",
" response = await comm.read(deserializers=serializers)\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/comm/tcp.py\", line 242, in read\n",
" convert_stream_closed_error(self, e)\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/comm/tcp.py\", line 148, in convert_stream_closed_error\n",
" raise CommClosedError(f\"in {obj}: {exc.__class__.__name__}: {exc}\") from exc\n",
"distributed.comm.core.CommClosedError: in <TCP (closed) local=tcp://127.0.0.1:42667 remote=tcp://127.0.0.1:44488>: BrokenPipeError: [Errno 32] Broken pipe\n",
"2022-05-08 16:07:39,032 - distributed.worker - ERROR - Worker stream died during communication: tcp://127.0.0.1:44165\n",
"Traceback (most recent call last):\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/comm/tcp.py\", line 236, in read\n",
" n = await stream.read_into(chunk)\n",
"tornado.iostream.StreamClosedError: Stream is closed\n",
"\n",
"The above exception was the direct cause of the following exception:\n",
"\n",
"Traceback (most recent call last):\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/worker.py\", line 3162, in gather_dep\n",
" response = await get_data_from_worker(\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/worker.py\", line 4488, in get_data_from_worker\n",
" return await retry_operation(_get_data, operation=\"get_data_from_worker\")\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/utils_comm.py\", line 381, in retry_operation\n",
" return await retry(\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/utils_comm.py\", line 366, in retry\n",
" return await coro()\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/worker.py\", line 4468, in _get_data\n",
" response = await send_recv(\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/core.py\", line 708, in send_recv\n",
" response = await comm.read(deserializers=deserializers)\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/comm/tcp.py\", line 242, in read\n",
" convert_stream_closed_error(self, e)\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/comm/tcp.py\", line 150, in convert_stream_closed_error\n",
" raise CommClosedError(f\"in {obj}: {exc}\") from exc\n",
"distributed.comm.core.CommClosedError: in <TCP (closed) Ephemeral Worker->Worker for gather local=tcp://127.0.0.1:56808 remote=tcp://127.0.0.1:44165>: Stream is closed\n",
"2022-05-08 16:07:39,863 - distributed.worker_memory - WARNING - Worker exceeded 95% memory budget. Restarting\n",
"2022-05-08 16:07:40,268 - distributed.worker - ERROR - Worker stream died during communication: tcp://127.0.0.1:42667\n",
"Traceback (most recent call last):\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/tornado/iostream.py\", line 867, in _read_to_buffer\n",
" bytes_read = self.read_from_fd(buf)\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/tornado/iostream.py\", line 1140, in read_from_fd\n",
" return self.socket.recv_into(buf, len(buf))\n",
"ConnectionResetError: [Errno 104] Connection reset by peer\n",
"\n",
"The above exception was the direct cause of the following exception:\n",
"\n",
"Traceback (most recent call last):\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/comm/core.py\", line 326, in connect\n",
" handshake = await asyncio.wait_for(comm.read(), time_left())\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/asyncio/tasks.py\", line 481, in wait_for\n",
" return fut.result()\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/comm/tcp.py\", line 242, in read\n",
" convert_stream_closed_error(self, e)\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/comm/tcp.py\", line 148, in convert_stream_closed_error\n",
" raise CommClosedError(f\"in {obj}: {exc.__class__.__name__}: {exc}\") from exc\n",
"distributed.comm.core.CommClosedError: in <TCP (closed) local=tcp://127.0.0.1:44494 remote=tcp://127.0.0.1:42667>: ConnectionResetError: [Errno 104] Connection reset by peer\n",
"\n",
"The above exception was the direct cause of the following exception:\n",
"\n",
"Traceback (most recent call last):\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/worker.py\", line 3162, in gather_dep\n",
" response = await get_data_from_worker(\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/worker.py\", line 4488, in get_data_from_worker\n",
" return await retry_operation(_get_data, operation=\"get_data_from_worker\")\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/utils_comm.py\", line 381, in retry_operation\n",
" return await retry(\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/utils_comm.py\", line 366, in retry\n",
" return await coro()\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/worker.py\", line 4465, in _get_data\n",
" comm = await rpc.connect(worker)\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/core.py\", line 1162, in connect\n",
" return await connect_attempt\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/core.py\", line 1098, in _connect\n",
" comm = await connect(\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/comm/core.py\", line 331, in connect\n",
" raise OSError(\n",
"OSError: Timed out during handshake while connecting to tcp://127.0.0.1:42667 after 30 s\n",
"2022-05-08 16:07:40,601 - distributed.nanny - WARNING - Restarting worker\n",
"2022-05-08 16:07:40,658 - distributed.worker - ERROR - Worker stream died during communication: tcp://127.0.0.1:42667\n",
"Traceback (most recent call last):\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/tornado/iostream.py\", line 867, in _read_to_buffer\n",
" bytes_read = self.read_from_fd(buf)\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/tornado/iostream.py\", line 1140, in read_from_fd\n",
" return self.socket.recv_into(buf, len(buf))\n",
"ConnectionResetError: [Errno 104] Connection reset by peer\n",
"\n",
"The above exception was the direct cause of the following exception:\n",
"\n",
"Traceback (most recent call last):\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/worker.py\", line 3162, in gather_dep\n",
" response = await get_data_from_worker(\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/worker.py\", line 4488, in get_data_from_worker\n",
" return await retry_operation(_get_data, operation=\"get_data_from_worker\")\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/utils_comm.py\", line 381, in retry_operation\n",
" return await retry(\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/utils_comm.py\", line 366, in retry\n",
" return await coro()\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/worker.py\", line 4468, in _get_data\n",
" response = await send_recv(\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/core.py\", line 708, in send_recv\n",
" response = await comm.read(deserializers=deserializers)\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/comm/tcp.py\", line 242, in read\n",
" convert_stream_closed_error(self, e)\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/comm/tcp.py\", line 148, in convert_stream_closed_error\n",
" raise CommClosedError(f\"in {obj}: {exc.__class__.__name__}: {exc}\") from exc\n",
"distributed.comm.core.CommClosedError: in <TCP (closed) Ephemeral Worker->Worker for gather local=tcp://127.0.0.1:44484 remote=tcp://127.0.0.1:42667>: ConnectionResetError: [Errno 104] Connection reset by peer\n",
"2022-05-08 16:07:42,675 - distributed.worker - ERROR - failed during get data with tcp://127.0.0.1:44723 -> tcp://127.0.0.1:42667\n",
"Traceback (most recent call last):\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/comm/tcp.py\", line 226, in read\n",
" frames_nbytes = await stream.read_bytes(fmt_size)\n",
"tornado.iostream.StreamClosedError: Stream is closed\n",
"\n",
"The above exception was the direct cause of the following exception:\n",
"\n",
"Traceback (most recent call last):\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/worker.py\", line 1728, in get_data\n",
" response = await comm.read(deserializers=serializers)\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/comm/tcp.py\", line 242, in read\n",
" convert_stream_closed_error(self, e)\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/comm/tcp.py\", line 150, in convert_stream_closed_error\n",
" raise CommClosedError(f\"in {obj}: {exc}\") from exc\n",
"distributed.comm.core.CommClosedError: in <TCP (closed) local=tcp://127.0.0.1:44723 remote=tcp://127.0.0.1:43488>: Stream is closed\n",
"2022-05-08 16:08:00,141 - distributed.worker_memory - WARNING - Worker is at 84% memory usage. Pausing worker. Process memory: 1.68 GiB -- Worker memory limit: 2.00 GiB\n",
"2022-05-08 16:08:01,102 - distributed.worker_memory - WARNING - Worker is at 71% memory usage. Resuming worker. Process memory: 1.43 GiB -- Worker memory limit: 2.00 GiB\n",
"2022-05-08 16:08:13,453 - distributed.worker - ERROR - Worker stream died during communication: tcp://127.0.0.1:42667\n",
"ConnectionRefusedError: [Errno 111] Connection refused\n",
"\n",
"The above exception was the direct cause of the following exception:\n",
"\n",
"Traceback (most recent call last):\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/comm/core.py\", line 289, in connect\n",
" comm = await asyncio.wait_for(\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/asyncio/tasks.py\", line 481, in wait_for\n",
" return fut.result()\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/comm/tcp.py\", line 451, in connect\n",
" convert_stream_closed_error(self, e)\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/comm/tcp.py\", line 148, in convert_stream_closed_error\n",
" raise CommClosedError(f\"in {obj}: {exc.__class__.__name__}: {exc}\") from exc\n",
"distributed.comm.core.CommClosedError: in <distributed.comm.tcp.TCPConnector object at 0x7f71f139d820>: ConnectionRefusedError: [Errno 111] Connection refused\n",
"\n",
"The above exception was the direct cause of the following exception:\n",
"\n",
"Traceback (most recent call last):\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/worker.py\", line 3162, in gather_dep\n",
" response = await get_data_from_worker(\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/worker.py\", line 4488, in get_data_from_worker\n",
" return await retry_operation(_get_data, operation=\"get_data_from_worker\")\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/utils_comm.py\", line 381, in retry_operation\n",
" return await retry(\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/utils_comm.py\", line 366, in retry\n",
" return await coro()\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/worker.py\", line 4465, in _get_data\n",
" comm = await rpc.connect(worker)\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/core.py\", line 1162, in connect\n",
" return await connect_attempt\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/core.py\", line 1098, in _connect\n",
" comm = await connect(\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/comm/core.py\", line 315, in connect\n",
" raise OSError(\n",
"OSError: Timed out trying to connect to tcp://127.0.0.1:42667 after 30 s\n",
"2022-05-08 16:08:28,757 - distributed.worker_memory - WARNING - Worker exceeded 95% memory budget. Restarting\n",
"2022-05-08 16:08:28,807 - distributed.worker_memory - WARNING - Worker exceeded 95% memory budget. Restarting\n",
"2022-05-08 16:08:28,847 - distributed.worker - ERROR - Worker stream died during communication: tcp://127.0.0.1:44723\n",
"Traceback (most recent call last):\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/comm/tcp.py\", line 226, in read\n",
" frames_nbytes = await stream.read_bytes(fmt_size)\n",
"tornado.iostream.StreamClosedError: Stream is closed\n",
"\n",
"The above exception was the direct cause of the following exception:\n",
"\n",
"Traceback (most recent call last):\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/worker.py\", line 3162, in gather_dep\n",
" response = await get_data_from_worker(\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/worker.py\", line 4488, in get_data_from_worker\n",
" return await retry_operation(_get_data, operation=\"get_data_from_worker\")\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/utils_comm.py\", line 381, in retry_operation\n",
" return await retry(\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/utils_comm.py\", line 366, in retry\n",
" return await coro()\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/worker.py\", line 4468, in _get_data\n",
" response = await send_recv(\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/core.py\", line 708, in send_recv\n",
" response = await comm.read(deserializers=deserializers)\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/comm/tcp.py\", line 242, in read\n",
" convert_stream_closed_error(self, e)\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/comm/tcp.py\", line 150, in convert_stream_closed_error\n",
" raise CommClosedError(f\"in {obj}: {exc}\") from exc\n",
"distributed.comm.core.CommClosedError: in <TCP (closed) Ephemeral Worker->Worker for gather local=tcp://127.0.0.1:43498 remote=tcp://127.0.0.1:44723>: Stream is closed\n",
"2022-05-08 16:08:28,852 - distributed.worker - ERROR - Worker stream died during communication: tcp://127.0.0.1:44723\n",
"Traceback (most recent call last):\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/tornado/iostream.py\", line 867, in _read_to_buffer\n",
" bytes_read = self.read_from_fd(buf)\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/tornado/iostream.py\", line 1140, in read_from_fd\n",
" return self.socket.recv_into(buf, len(buf))\n",
"ConnectionResetError: [Errno 104] Connection reset by peer\n",
"\n",
"The above exception was the direct cause of the following exception:\n",
"\n",
"Traceback (most recent call last):\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/worker.py\", line 3162, in gather_dep\n",
" response = await get_data_from_worker(\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/worker.py\", line 4488, in get_data_from_worker\n",
" return await retry_operation(_get_data, operation=\"get_data_from_worker\")\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/utils_comm.py\", line 381, in retry_operation\n",
" return await retry(\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/utils_comm.py\", line 366, in retry\n",
" return await coro()\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/worker.py\", line 4468, in _get_data\n",
" response = await send_recv(\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/core.py\", line 708, in send_recv\n",
" response = await comm.read(deserializers=deserializers)\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/comm/tcp.py\", line 242, in read\n",
" convert_stream_closed_error(self, e)\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/comm/tcp.py\", line 148, in convert_stream_closed_error\n",
" raise CommClosedError(f\"in {obj}: {exc.__class__.__name__}: {exc}\") from exc\n",
"distributed.comm.core.CommClosedError: in <TCP (closed) Ephemeral Worker->Worker for gather local=tcp://127.0.0.1:43496 remote=tcp://127.0.0.1:44723>: ConnectionResetError: [Errno 104] Connection reset by peer\n",
"2022-05-08 16:08:28,903 - distributed.worker - ERROR - Worker stream died during communication: tcp://127.0.0.1:36537\n",
"Traceback (most recent call last):\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/comm/tcp.py\", line 226, in read\n",
" frames_nbytes = await stream.read_bytes(fmt_size)\n",
"tornado.iostream.StreamClosedError: Stream is closed\n",
"\n",
"The above exception was the direct cause of the following exception:\n",
"\n",
"Traceback (most recent call last):\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/worker.py\", line 3162, in gather_dep\n",
" response = await get_data_from_worker(\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/worker.py\", line 4488, in get_data_from_worker\n",
" return await retry_operation(_get_data, operation=\"get_data_from_worker\")\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/utils_comm.py\", line 381, in retry_operation\n",
" return await retry(\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/utils_comm.py\", line 366, in retry\n",
" return await coro()\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/worker.py\", line 4468, in _get_data\n",
" response = await send_recv(\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/core.py\", line 708, in send_recv\n",
" response = await comm.read(deserializers=deserializers)\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/comm/tcp.py\", line 242, in read\n",
" convert_stream_closed_error(self, e)\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/comm/tcp.py\", line 150, in convert_stream_closed_error\n",
" raise CommClosedError(f\"in {obj}: {exc}\") from exc\n",
"distributed.comm.core.CommClosedError: in <TCP (closed) Ephemeral Worker->Worker for gather local=tcp://127.0.0.1:36416 remote=tcp://127.0.0.1:36537>: Stream is closed\n",
"2022-05-08 16:08:28,904 - distributed.worker - ERROR - Worker stream died during communication: tcp://127.0.0.1:36537\n",
"Traceback (most recent call last):\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/comm/tcp.py\", line 236, in read\n",
" n = await stream.read_into(chunk)\n",
"tornado.iostream.StreamClosedError: Stream is closed\n",
"\n",
"The above exception was the direct cause of the following exception:\n",
"\n",
"Traceback (most recent call last):\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/worker.py\", line 3162, in gather_dep\n",
" response = await get_data_from_worker(\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/worker.py\", line 4488, in get_data_from_worker\n",
" return await retry_operation(_get_data, operation=\"get_data_from_worker\")\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/utils_comm.py\", line 381, in retry_operation\n",
" return await retry(\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/utils_comm.py\", line 366, in retry\n",
" return await coro()\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/worker.py\", line 4468, in _get_data\n",
" response = await send_recv(\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/core.py\", line 708, in send_recv\n",
" response = await comm.read(deserializers=deserializers)\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/comm/tcp.py\", line 242, in read\n",
" convert_stream_closed_error(self, e)\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/comm/tcp.py\", line 150, in convert_stream_closed_error\n",
" raise CommClosedError(f\"in {obj}: {exc}\") from exc\n",
"distributed.comm.core.CommClosedError: in <TCP (closed) Ephemeral Worker->Worker for gather local=tcp://127.0.0.1:36414 remote=tcp://127.0.0.1:36537>: Stream is closed\n",
"2022-05-08 16:08:29,232 - distributed.nanny - WARNING - Restarting worker\n",
"2022-05-08 16:08:29,238 - distributed.nanny - WARNING - Restarting worker\n",
"2022-05-08 16:08:32,963 - distributed.worker_memory - WARNING - Worker exceeded 95% memory budget. Restarting\n",
"2022-05-08 16:08:33,032 - distributed.worker - ERROR - Worker stream died during communication: tcp://127.0.0.1:33975\n",
"Traceback (most recent call last):\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/comm/tcp.py\", line 226, in read\n",
" frames_nbytes = await stream.read_bytes(fmt_size)\n",
"tornado.iostream.StreamClosedError: Stream is closed\n",
"\n",
"The above exception was the direct cause of the following exception:\n",
"\n",
"Traceback (most recent call last):\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/worker.py\", line 3162, in gather_dep\n",
" response = await get_data_from_worker(\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/worker.py\", line 4488, in get_data_from_worker\n",
" return await retry_operation(_get_data, operation=\"get_data_from_worker\")\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/utils_comm.py\", line 381, in retry_operation\n",
" return await retry(\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/utils_comm.py\", line 366, in retry\n",
" return await coro()\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/worker.py\", line 4468, in _get_data\n",
" response = await send_recv(\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/core.py\", line 708, in send_recv\n",
" response = await comm.read(deserializers=deserializers)\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/comm/tcp.py\", line 242, in read\n",
" convert_stream_closed_error(self, e)\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/comm/tcp.py\", line 150, in convert_stream_closed_error\n",
" raise CommClosedError(f\"in {obj}: {exc}\") from exc\n",
"distributed.comm.core.CommClosedError: in <TCP (closed) Ephemeral Worker->Worker for gather local=tcp://127.0.0.1:33040 remote=tcp://127.0.0.1:33975>: Stream is closed\n",
"2022-05-08 16:08:33,032 - distributed.worker - ERROR - Worker stream died during communication: tcp://127.0.0.1:33975\n",
"Traceback (most recent call last):\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/comm/tcp.py\", line 226, in read\n",
" frames_nbytes = await stream.read_bytes(fmt_size)\n",
"tornado.iostream.StreamClosedError: Stream is closed\n",
"\n",
"The above exception was the direct cause of the following exception:\n",
"\n",
"Traceback (most recent call last):\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/worker.py\", line 3162, in gather_dep\n",
" response = await get_data_from_worker(\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/worker.py\", line 4488, in get_data_from_worker\n",
" return await retry_operation(_get_data, operation=\"get_data_from_worker\")\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/utils_comm.py\", line 381, in retry_operation\n",
" return await retry(\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/utils_comm.py\", line 366, in retry\n",
" return await coro()\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/worker.py\", line 4468, in _get_data\n",
" response = await send_recv(\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/core.py\", line 708, in send_recv\n",
" response = await comm.read(deserializers=deserializers)\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/comm/tcp.py\", line 242, in read\n",
" convert_stream_closed_error(self, e)\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/comm/tcp.py\", line 150, in convert_stream_closed_error\n",
" raise CommClosedError(f\"in {obj}: {exc}\") from exc\n",
"distributed.comm.core.CommClosedError: in <TCP (closed) Ephemeral Worker->Worker for gather local=tcp://127.0.0.1:33042 remote=tcp://127.0.0.1:33975>: Stream is closed\n",
"2022-05-08 16:08:33,173 - distributed.worker - ERROR - failed during get data with tcp://127.0.0.1:44595 -> tcp://127.0.0.1:33975\n",
"Traceback (most recent call last):\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/comm/tcp.py\", line 226, in read\n",
" frames_nbytes = await stream.read_bytes(fmt_size)\n",
"tornado.iostream.StreamClosedError: Stream is closed\n",
"\n",
"The above exception was the direct cause of the following exception:\n",
"\n",
"Traceback (most recent call last):\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/worker.py\", line 1728, in get_data\n",
" response = await comm.read(deserializers=serializers)\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/comm/tcp.py\", line 242, in read\n",
" convert_stream_closed_error(self, e)\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/comm/tcp.py\", line 150, in convert_stream_closed_error\n",
" raise CommClosedError(f\"in {obj}: {exc}\") from exc\n",
"distributed.comm.core.CommClosedError: in <TCP (closed) local=tcp://127.0.0.1:44595 remote=tcp://127.0.0.1:58932>: Stream is closed\n",
"2022-05-08 16:08:33,347 - distributed.nanny - WARNING - Restarting worker\n"
]
},
{
"ename": "KilledWorker",
"evalue": "(\"('getitem-mean_chunk-36794663cd3dbdf4b2b7cd7445c39a39', 5, 14, 0)\", <WorkerState 'tcp://127.0.0.1:33975', name: 0, status: closed, memory: 0, processing: 87>)",
"output_type": "error",
"traceback": [
"\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
"\u001b[0;31mKilledWorker\u001b[0m Traceback (most recent call last)",
"\u001b[0;32m/tmp/ipykernel_155890/4239941597.py\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m 1\u001b[0m \u001b[0mt0\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mtime\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mtime\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m----> 2\u001b[0;31m \u001b[0mtpm\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mtpm\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mload\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m 3\u001b[0m \u001b[0mprint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34mf'Yep: {time.time() - t0:.1f}s'\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
"\u001b[0;32m~/.miniconda3/envs/climate/lib/python3.9/site-packages/xarray/core/dataarray.py\u001b[0m in \u001b[0;36mload\u001b[0;34m(self, **kwargs)\u001b[0m\n\u001b[1;32m 919\u001b[0m \u001b[0mdask\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mcompute\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 920\u001b[0m \"\"\"\n\u001b[0;32m--> 921\u001b[0;31m \u001b[0mds\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_to_temp_dataset\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mload\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m 922\u001b[0m \u001b[0mnew\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_from_temp_dataset\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mds\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 923\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_variable\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mnew\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_variable\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
"\u001b[0;32m~/.miniconda3/envs/climate/lib/python3.9/site-packages/xarray/core/dataset.py\u001b[0m in \u001b[0;36mload\u001b[0;34m(self, **kwargs)\u001b[0m\n\u001b[1;32m 859\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 860\u001b[0m \u001b[0;31m# evaluate all the dask arrays simultaneously\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 861\u001b[0;31m \u001b[0mevaluated_data\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mda\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mcompute\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0mlazy_data\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mvalues\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m 862\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 863\u001b[0m \u001b[0;32mfor\u001b[0m \u001b[0mk\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mdata\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mzip\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mlazy_data\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mevaluated_data\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
"\u001b[0;32m~/.miniconda3/envs/climate/lib/python3.9/site-packages/dask/base.py\u001b[0m in \u001b[0;36mcompute\u001b[0;34m(traverse, optimize_graph, scheduler, get, *args, **kwargs)\u001b[0m\n\u001b[1;32m 573\u001b[0m \u001b[0mpostcomputes\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mappend\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mx\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m__dask_postcompute__\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 574\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 575\u001b[0;31m \u001b[0mresults\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mschedule\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mdsk\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mkeys\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m 576\u001b[0m \u001b[0;32mreturn\u001b[0m \u001b[0mrepack\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mf\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mr\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m*\u001b[0m\u001b[0ma\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;32mfor\u001b[0m \u001b[0mr\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m(\u001b[0m\u001b[0mf\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0ma\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mzip\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mresults\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mpostcomputes\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 577\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
"\u001b[0;32m~/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/client.py\u001b[0m in \u001b[0;36mget\u001b[0;34m(self, dsk, keys, workers, allow_other_workers, resources, sync, asynchronous, direct, retries, priority, fifo_timeout, actors, **kwargs)\u001b[0m\n\u001b[1;32m 3002\u001b[0m \u001b[0mshould_rejoin\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;32mFalse\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 3003\u001b[0m \u001b[0;32mtry\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m-> 3004\u001b[0;31m \u001b[0mresults\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mgather\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mpacked\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0masynchronous\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0masynchronous\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mdirect\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mdirect\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m 3005\u001b[0m \u001b[0;32mfinally\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 3006\u001b[0m \u001b[0;32mfor\u001b[0m \u001b[0mf\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mfutures\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mvalues\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
"\u001b[0;32m~/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/client.py\u001b[0m in \u001b[0;36mgather\u001b[0;34m(self, futures, errors, direct, asynchronous)\u001b[0m\n\u001b[1;32m 2176\u001b[0m \u001b[0;32melse\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 2177\u001b[0m \u001b[0mlocal_worker\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;32mNone\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m-> 2178\u001b[0;31m return self.sync(\n\u001b[0m\u001b[1;32m 2179\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_gather\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 2180\u001b[0m \u001b[0mfutures\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
"\u001b[0;32m~/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/utils.py\u001b[0m in \u001b[0;36msync\u001b[0;34m(self, func, asynchronous, callback_timeout, *args, **kwargs)\u001b[0m\n\u001b[1;32m 316\u001b[0m \u001b[0;32mreturn\u001b[0m \u001b[0mfuture\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 317\u001b[0m \u001b[0;32melse\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 318\u001b[0;31m return sync(\n\u001b[0m\u001b[1;32m 319\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mloop\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mfunc\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mcallback_timeout\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mcallback_timeout\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 320\u001b[0m )\n",
"\u001b[0;32m~/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/utils.py\u001b[0m in \u001b[0;36msync\u001b[0;34m(loop, func, callback_timeout, *args, **kwargs)\u001b[0m\n\u001b[1;32m 383\u001b[0m \u001b[0;32mif\u001b[0m \u001b[0merror\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 384\u001b[0m \u001b[0mtyp\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mexc\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mtb\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0merror\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 385\u001b[0;31m \u001b[0;32mraise\u001b[0m \u001b[0mexc\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mwith_traceback\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mtb\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m 386\u001b[0m \u001b[0;32melse\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 387\u001b[0m \u001b[0;32mreturn\u001b[0m \u001b[0mresult\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
"\u001b[0;32m~/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/utils.py\u001b[0m in \u001b[0;36mf\u001b[0;34m()\u001b[0m\n\u001b[1;32m 356\u001b[0m \u001b[0mfuture\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0masyncio\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mwait_for\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mfuture\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mcallback_timeout\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 357\u001b[0m \u001b[0mfuture\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0masyncio\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mensure_future\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mfuture\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 358\u001b[0;31m \u001b[0mresult\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;32myield\u001b[0m \u001b[0mfuture\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m 359\u001b[0m \u001b[0;32mexcept\u001b[0m \u001b[0mException\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 360\u001b[0m \u001b[0merror\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0msys\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mexc_info\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
"\u001b[0;32m~/.miniconda3/envs/climate/lib/python3.9/site-packages/tornado/gen.py\u001b[0m in \u001b[0;36mrun\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m 760\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 761\u001b[0m \u001b[0;32mtry\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 762\u001b[0;31m \u001b[0mvalue\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mfuture\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mresult\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m 763\u001b[0m \u001b[0;32mexcept\u001b[0m \u001b[0mException\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 764\u001b[0m \u001b[0mexc_info\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0msys\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mexc_info\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
"\u001b[0;32m~/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/client.py\u001b[0m in \u001b[0;36m_gather\u001b[0;34m(self, futures, errors, direct, local_worker)\u001b[0m\n\u001b[1;32m 2039\u001b[0m \u001b[0mexc\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mCancelledError\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mkey\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 2040\u001b[0m \u001b[0;32melse\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m-> 2041\u001b[0;31m \u001b[0;32mraise\u001b[0m \u001b[0mexception\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mwith_traceback\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mtraceback\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m 2042\u001b[0m \u001b[0;32mraise\u001b[0m \u001b[0mexc\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 2043\u001b[0m \u001b[0;32mif\u001b[0m \u001b[0merrors\u001b[0m \u001b[0;34m==\u001b[0m \u001b[0;34m\"skip\"\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
"\u001b[0;31mKilledWorker\u001b[0m: (\"('getitem-mean_chunk-36794663cd3dbdf4b2b7cd7445c39a39', 5, 14, 0)\", <WorkerState 'tcp://127.0.0.1:33975', name: 0, status: closed, memory: 0, processing: 87>)"
]
},
{
"name": "stderr",
"output_type": "stream",
"text": [
"2022-05-08 16:08:34,682 - distributed.worker_memory - WARNING - Worker is at 83% memory usage. Pausing worker. Process memory: 1.67 GiB -- Worker memory limit: 2.00 GiB\n",
"2022-05-08 16:08:34,757 - distributed.worker_memory - WARNING - Worker exceeded 95% memory budget. Restarting\n",
"2022-05-08 16:08:34,835 - distributed.worker - ERROR - Worker stream died during communication: tcp://127.0.0.1:44595\n",
"Traceback (most recent call last):\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/comm/tcp.py\", line 226, in read\n",
" frames_nbytes = await stream.read_bytes(fmt_size)\n",
"tornado.iostream.StreamClosedError: Stream is closed\n",
"\n",
"The above exception was the direct cause of the following exception:\n",
"\n",
"Traceback (most recent call last):\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/worker.py\", line 3162, in gather_dep\n",
" response = await get_data_from_worker(\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/worker.py\", line 4488, in get_data_from_worker\n",
" return await retry_operation(_get_data, operation=\"get_data_from_worker\")\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/utils_comm.py\", line 381, in retry_operation\n",
" return await retry(\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/utils_comm.py\", line 366, in retry\n",
" return await coro()\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/worker.py\", line 4468, in _get_data\n",
" response = await send_recv(\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/core.py\", line 708, in send_recv\n",
" response = await comm.read(deserializers=deserializers)\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/comm/tcp.py\", line 242, in read\n",
" convert_stream_closed_error(self, e)\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/comm/tcp.py\", line 150, in convert_stream_closed_error\n",
" raise CommClosedError(f\"in {obj}: {exc}\") from exc\n",
"distributed.comm.core.CommClosedError: in <TCP (closed) Ephemeral Worker->Worker for gather local=tcp://127.0.0.1:58938 remote=tcp://127.0.0.1:44595>: Stream is closed\n",
"2022-05-08 16:08:34,835 - distributed.worker - ERROR - Worker stream died during communication: tcp://127.0.0.1:44595\n",
"Traceback (most recent call last):\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/comm/tcp.py\", line 226, in read\n",
" frames_nbytes = await stream.read_bytes(fmt_size)\n",
"tornado.iostream.StreamClosedError: Stream is closed\n",
"\n",
"The above exception was the direct cause of the following exception:\n",
"\n",
"Traceback (most recent call last):\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/worker.py\", line 3162, in gather_dep\n",
" response = await get_data_from_worker(\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/worker.py\", line 4488, in get_data_from_worker\n",
" return await retry_operation(_get_data, operation=\"get_data_from_worker\")\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/utils_comm.py\", line 381, in retry_operation\n",
" return await retry(\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/utils_comm.py\", line 366, in retry\n",
" return await coro()\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/worker.py\", line 4468, in _get_data\n",
" response = await send_recv(\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/core.py\", line 708, in send_recv\n",
" response = await comm.read(deserializers=deserializers)\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/comm/tcp.py\", line 242, in read\n",
" convert_stream_closed_error(self, e)\n",
" File \"/home/mowglie/.miniconda3/envs/climate/lib/python3.9/site-packages/distributed/comm/tcp.py\", line 150, in convert_stream_closed_error\n",
" raise CommClosedError(f\"in {obj}: {exc}\") from exc\n",
"distributed.comm.core.CommClosedError: in <TCP (closed) Ephemeral Worker->Worker for gather local=tcp://127.0.0.1:58940 remote=tcp://127.0.0.1:44595>: Stream is closed\n",
"2022-05-08 16:08:34,878 - distributed.nanny - WARNING - Restarting worker\n"
]
}
],
"source": [
"t0 = time.time()\n",
"tpm = tpm.load()\n",
"print(f'Yep: {time.time() - t0:.1f}s')"
]
},
{
"cell_type": "code",
"execution_count": null,
"id": "0a44c789-596d-42a4-ada6-c92ce29bdd33",
"metadata": {},
"outputs": [],
"source": []
}
],
"metadata": {
"kernelspec": {
"display_name": "Python 3 (ipykernel)",
"language": "python",
"name": "python3"
},
"language_info": {
"codemirror_mode": {
"name": "ipython",
"version": 3
},
"file_extension": ".py",
"mimetype": "text/x-python",
"name": "python",
"nbconvert_exporter": "python",
"pygments_lexer": "ipython3",
"version": "3.9.7"
}
},
"nbformat": 4,
"nbformat_minor": 5
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment