{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "#Probabilistic ScoreCard"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import weatherbench2\n",
    "import xarray as xr\n",
    "import math\n",
    "from weatherbench2.regions import SliceRegion, ExtraTropicalRegion\n",
    "from weatherbench2.evaluation import evaluate_in_memory\n",
    "from weatherbench2 import config\n",
    "import numpy as np\n",
    "import sigkernel\n",
    "import torch\n",
    "from einops import rearrange\n",
    "from itertools import product\n",
    "import cython\n",
    "import matplotlib.pyplot  as plt\n",
    "import tqdm\n",
    "#import Functions as fu\n",
    "import line_profiler\n",
    "from datetime import datetime, timedelta\n",
    "from multiprocessing import Pool, cpu_count\n",
    "import time\n",
    "from weatherbench2.metrics import MSE, ACC\n",
    "from weatherbench2.regions import SliceRegion\n",
    "import seaborn as sns\n",
    "from dateutil.relativedelta import relativedelta\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "import apache_beam"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "overallIFSENSE = xr.open_dataset('WeatherData/NEWENSERAmonths11.nc')\n",
    "for i in range(11):\n",
    "    results = xr.open_dataset('WeatherData/NEWENSERAmonths' + str(i) + '.nc')\n",
    "    overallIFSENSE = overallIFSENSE + results\n",
    "\n",
    "overallIFSENSE = overallIFSENSE/12"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "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[data-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-index-preview {\n",
       "  grid-column: 2 / 5;\n",
       "  color: var(--xr-font-color2);\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",
       ".xr-index-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",
       ".xr-index-data-in:checked ~ .xr-index-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-index-name div,\n",
       ".xr-index-data,\n",
       ".xr-attrs {\n",
       "  padding-left: 25px !important;\n",
       "}\n",
       "\n",
       ".xr-attrs,\n",
       ".xr-var-attrs,\n",
       ".xr-var-data,\n",
       ".xr-index-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",
       ".xr-no-icon {\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.Dataset&gt;\n",
       "Dimensions:              (lead_time: 30, region: 3, metric: 3, level: 2)\n",
       "Coordinates:\n",
       "  * lead_time            (lead_time) timedelta64[ns] 0 days 12:00:00 ... 15 d...\n",
       "  * region               (region) object &#x27;northernhemisphere&#x27; ... &#x27;southernhe...\n",
       "  * metric               (metric) object &#x27;CRPS&#x27; &#x27;EnergyScore&#x27; &#x27;EnsMSE&#x27;\n",
       "  * level                (level) int32 500 850\n",
       "Data variables:\n",
       "    geopotential         (metric, region, lead_time, level) float64 17.79 ......\n",
       "    temperature          (metric, region, lead_time, level) float64 0.1402 .....\n",
       "    u_component_of_wind  (metric, region, lead_time, level) float64 0.3842 .....\n",
       "    v_component_of_wind  (metric, region, lead_time, level) float64 0.4085 .....</pre><div class='xr-wrap' style='display:none'><div class='xr-header'><div class='xr-obj-type'>xarray.Dataset</div></div><ul class='xr-sections'><li class='xr-section-item'><input id='section-b92da0d9-3c86-42f6-b3e7-3c15b76f879e' class='xr-section-summary-in' type='checkbox' disabled ><label for='section-b92da0d9-3c86-42f6-b3e7-3c15b76f879e' class='xr-section-summary'  title='Expand/collapse section'>Dimensions:</label><div class='xr-section-inline-details'><ul class='xr-dim-list'><li><span class='xr-has-index'>lead_time</span>: 30</li><li><span class='xr-has-index'>region</span>: 3</li><li><span class='xr-has-index'>metric</span>: 3</li><li><span class='xr-has-index'>level</span>: 2</li></ul></div><div class='xr-section-details'></div></li><li class='xr-section-item'><input id='section-ecee1431-3ffb-45bd-a197-80203ef80262' class='xr-section-summary-in' type='checkbox'  checked><label for='section-ecee1431-3ffb-45bd-a197-80203ef80262' class='xr-section-summary' >Coordinates: <span>(4)</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'>lead_time</span></div><div class='xr-var-dims'>(lead_time)</div><div class='xr-var-dtype'>timedelta64[ns]</div><div class='xr-var-preview xr-preview'>0 days 12:00:00 ... 15 days 00:0...</div><input id='attrs-68ebe1f6-6789-4975-9f7c-d44610ab5d46' class='xr-var-attrs-in' type='checkbox' disabled><label for='attrs-68ebe1f6-6789-4975-9f7c-d44610ab5d46' title='Show/Hide attributes'><svg class='icon xr-icon-file-text2'><use xlink:href='#icon-file-text2'></use></svg></label><input id='data-12f55e51-99f4-4c23-8920-ac9ab4f833f1' class='xr-var-data-in' type='checkbox'><label for='data-12f55e51-99f4-4c23-8920-ac9ab4f833f1' 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([  43200000000000,   86400000000000,  129600000000000,  172800000000000,\n",
       "        216000000000000,  259200000000000,  302400000000000,  345600000000000,\n",
       "        388800000000000,  432000000000000,  475200000000000,  518400000000000,\n",
       "        561600000000000,  604800000000000,  648000000000000,  691200000000000,\n",
       "        734400000000000,  777600000000000,  820800000000000,  864000000000000,\n",
       "        907200000000000,  950400000000000,  993600000000000, 1036800000000000,\n",
       "       1080000000000000, 1123200000000000, 1166400000000000, 1209600000000000,\n",
       "       1252800000000000, 1296000000000000], dtype=&#x27;timedelta64[ns]&#x27;)</pre></div></li><li class='xr-var-item'><div class='xr-var-name'><span class='xr-has-index'>region</span></div><div class='xr-var-dims'>(region)</div><div class='xr-var-dtype'>object</div><div class='xr-var-preview xr-preview'>&#x27;northernhemisphere&#x27; ... &#x27;southe...</div><input id='attrs-88eb88bc-5019-49cd-8de1-618f24d8649b' class='xr-var-attrs-in' type='checkbox' disabled><label for='attrs-88eb88bc-5019-49cd-8de1-618f24d8649b' title='Show/Hide attributes'><svg class='icon xr-icon-file-text2'><use xlink:href='#icon-file-text2'></use></svg></label><input id='data-c8a66980-1cbd-481e-b36b-3efb5fa228f4' class='xr-var-data-in' type='checkbox'><label for='data-c8a66980-1cbd-481e-b36b-3efb5fa228f4' 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([&#x27;northernhemisphere&#x27;, &#x27;tropics&#x27;, &#x27;southernhemisphere&#x27;], dtype=object)</pre></div></li><li class='xr-var-item'><div class='xr-var-name'><span class='xr-has-index'>metric</span></div><div class='xr-var-dims'>(metric)</div><div class='xr-var-dtype'>object</div><div class='xr-var-preview xr-preview'>&#x27;CRPS&#x27; &#x27;EnergyScore&#x27; &#x27;EnsMSE&#x27;</div><input id='attrs-975fea2d-0107-42e9-a384-8b1a46e99c2f' class='xr-var-attrs-in' type='checkbox' disabled><label for='attrs-975fea2d-0107-42e9-a384-8b1a46e99c2f' title='Show/Hide attributes'><svg class='icon xr-icon-file-text2'><use xlink:href='#icon-file-text2'></use></svg></label><input id='data-3b399b23-2710-4752-92fd-f289a22f44e8' class='xr-var-data-in' type='checkbox'><label for='data-3b399b23-2710-4752-92fd-f289a22f44e8' 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([&#x27;CRPS&#x27;, &#x27;EnergyScore&#x27;, &#x27;EnsMSE&#x27;], dtype=object)</pre></div></li><li class='xr-var-item'><div class='xr-var-name'><span class='xr-has-index'>level</span></div><div class='xr-var-dims'>(level)</div><div class='xr-var-dtype'>int32</div><div class='xr-var-preview xr-preview'>500 850</div><input id='attrs-a0ccc3d1-53fb-4e7e-9b14-958d13c349d4' class='xr-var-attrs-in' type='checkbox' disabled><label for='attrs-a0ccc3d1-53fb-4e7e-9b14-958d13c349d4' title='Show/Hide attributes'><svg class='icon xr-icon-file-text2'><use xlink:href='#icon-file-text2'></use></svg></label><input id='data-b4c38fc5-277e-4f27-bda2-b1615047e691' class='xr-var-data-in' type='checkbox'><label for='data-b4c38fc5-277e-4f27-bda2-b1615047e691' 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([500, 850])</pre></div></li></ul></div></li><li class='xr-section-item'><input id='section-e677a1bd-bc88-472c-bb15-dc93d12bd683' class='xr-section-summary-in' type='checkbox'  checked><label for='section-e677a1bd-bc88-472c-bb15-dc93d12bd683' class='xr-section-summary' >Data variables: <span>(4)</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>geopotential</span></div><div class='xr-var-dims'>(metric, region, lead_time, level)</div><div class='xr-var-dtype'>float64</div><div class='xr-var-preview xr-preview'>17.79 16.75 ... 9.745e+05 4.82e+05</div><input id='attrs-db49b0b7-58bd-4da4-9424-efe65ab657ee' class='xr-var-attrs-in' type='checkbox' disabled><label for='attrs-db49b0b7-58bd-4da4-9424-efe65ab657ee' title='Show/Hide attributes'><svg class='icon xr-icon-file-text2'><use xlink:href='#icon-file-text2'></use></svg></label><input id='data-dae7293f-33c1-4835-9275-da41163e5bd7' class='xr-var-data-in' type='checkbox'><label for='data-dae7293f-33c1-4835-9275-da41163e5bd7' 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([[[[1.77855833e+01, 1.67460173e+01],\n",
       "         [2.36858512e+01, 2.11598812e+01],\n",
       "         [3.26293364e+01, 2.68103605e+01],\n",
       "         [4.27521834e+01, 3.38780767e+01],\n",
       "         [5.59325923e+01, 4.20470025e+01],\n",
       "         [7.02486786e+01, 5.18950441e+01],\n",
       "         [8.69837608e+01, 6.29268255e+01],\n",
       "         [1.05327841e+02, 7.50146453e+01],\n",
       "         [1.23361406e+02, 8.81710523e+01],\n",
       "         [1.42512267e+02, 1.01794802e+02],\n",
       "         [1.62671205e+02, 1.15754798e+02],\n",
       "         [1.84190574e+02, 1.31179779e+02],\n",
       "         [2.06146414e+02, 1.46975737e+02],\n",
       "         [2.26463798e+02, 1.62109917e+02],\n",
       "         [2.44920269e+02, 1.75232966e+02],\n",
       "         [2.63357997e+02, 1.87037072e+02],\n",
       "         [2.82538472e+02, 1.99186545e+02],\n",
       "         [3.02242153e+02, 2.11893183e+02],\n",
       "         [3.21463140e+02, 2.23468109e+02],\n",
       "         [3.38824788e+02, 2.33632606e+02],\n",
       "...\n",
       "         [1.58114951e+05, 9.13489943e+04],\n",
       "         [2.03125290e+05, 1.14797836e+05],\n",
       "         [2.52827184e+05, 1.39796069e+05],\n",
       "         [3.08684283e+05, 1.67138562e+05],\n",
       "         [3.68964269e+05, 1.95535437e+05],\n",
       "         [4.32643105e+05, 2.25504598e+05],\n",
       "         [4.93477554e+05, 2.54512516e+05],\n",
       "         [5.48851534e+05, 2.82599568e+05],\n",
       "         [6.01256506e+05, 3.10203089e+05],\n",
       "         [6.48859724e+05, 3.34156020e+05],\n",
       "         [6.94517723e+05, 3.57126654e+05],\n",
       "         [7.41423008e+05, 3.82332476e+05],\n",
       "         [7.88243732e+05, 4.05620628e+05],\n",
       "         [8.33336124e+05, 4.26971461e+05],\n",
       "         [8.72924414e+05, 4.44128554e+05],\n",
       "         [9.04674516e+05, 4.56331641e+05],\n",
       "         [9.28094974e+05, 4.64830601e+05],\n",
       "         [9.45127832e+05, 4.70578383e+05],\n",
       "         [9.59651472e+05, 4.75360624e+05],\n",
       "         [9.74484938e+05, 4.81980559e+05]]]])</pre></div></li><li class='xr-var-item'><div class='xr-var-name'><span>temperature</span></div><div class='xr-var-dims'>(metric, region, lead_time, level)</div><div class='xr-var-dtype'>float64</div><div class='xr-var-preview xr-preview'>0.1402 0.2434 0.177 ... 12.35 13.86</div><input id='attrs-28eb5b70-fce9-4b8e-93d3-c23310c9ed0d' class='xr-var-attrs-in' type='checkbox' disabled><label for='attrs-28eb5b70-fce9-4b8e-93d3-c23310c9ed0d' title='Show/Hide attributes'><svg class='icon xr-icon-file-text2'><use xlink:href='#icon-file-text2'></use></svg></label><input id='data-f4cb46c4-00c2-4647-9f43-838d3ffcaa93' class='xr-var-data-in' type='checkbox'><label for='data-f4cb46c4-00c2-4647-9f43-838d3ffcaa93' 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.14015346,  0.24343743],\n",
       "         [ 0.17697429,  0.29068936],\n",
       "         [ 0.22505213,  0.34396995],\n",
       "         [ 0.28000689,  0.39507935],\n",
       "         [ 0.34028812,  0.44942009],\n",
       "         [ 0.40804739,  0.50446516],\n",
       "         [ 0.48329808,  0.56972985],\n",
       "         [ 0.56324062,  0.64138857],\n",
       "         [ 0.64383435,  0.72056446],\n",
       "         [ 0.72196117,  0.79875205],\n",
       "         [ 0.80554081,  0.88557855],\n",
       "         [ 0.8869078 ,  0.97368232],\n",
       "         [ 0.96925358,  1.06521868],\n",
       "         [ 1.04621955,  1.15100272],\n",
       "         [ 1.11905862,  1.23160106],\n",
       "         [ 1.19091983,  1.31122049],\n",
       "         [ 1.26191191,  1.3897232 ],\n",
       "         [ 1.33237116,  1.47201205],\n",
       "         [ 1.40372242,  1.55106935],\n",
       "         [ 1.47012662,  1.62011276],\n",
       "...\n",
       "         [ 2.87297455,  3.4094002 ],\n",
       "         [ 3.51726526,  4.10682258],\n",
       "         [ 4.20389299,  4.87790001],\n",
       "         [ 4.94037634,  5.64641571],\n",
       "         [ 5.68392807,  6.35960043],\n",
       "         [ 6.47586102,  7.06847386],\n",
       "         [ 7.22169069,  7.74185233],\n",
       "         [ 7.87464334,  8.36188203],\n",
       "         [ 8.43399944,  8.96538366],\n",
       "         [ 8.95434266,  9.57352523],\n",
       "         [ 9.44394839, 10.15320328],\n",
       "         [ 9.89551919, 10.64692126],\n",
       "         [10.30072455, 11.15134125],\n",
       "         [10.69125973, 11.65203051],\n",
       "         [11.08222429, 12.17855659],\n",
       "         [11.42034164, 12.61408747],\n",
       "         [11.73830325, 12.99219501],\n",
       "         [11.98107144, 13.30620611],\n",
       "         [12.21375424, 13.60466523],\n",
       "         [12.34835035, 13.86097477]]]])</pre></div></li><li class='xr-var-item'><div class='xr-var-name'><span>u_component_of_wind</span></div><div class='xr-var-dims'>(metric, region, lead_time, level)</div><div class='xr-var-dtype'>float64</div><div class='xr-var-preview xr-preview'>0.3842 0.3303 0.476 ... 78.02 38.08</div><input id='attrs-34f32458-cbb2-4f6b-bbe5-cb0d166d9d7f' class='xr-var-attrs-in' type='checkbox' disabled><label for='attrs-34f32458-cbb2-4f6b-bbe5-cb0d166d9d7f' title='Show/Hide attributes'><svg class='icon xr-icon-file-text2'><use xlink:href='#icon-file-text2'></use></svg></label><input id='data-9239ee4a-c52e-4a6d-84c3-1177bbc7c717' class='xr-var-data-in' type='checkbox'><label for='data-9239ee4a-c52e-4a6d-84c3-1177bbc7c717' 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.38416939,  0.33033333],\n",
       "         [ 0.4760423 ,  0.39689155],\n",
       "         [ 0.59627932,  0.47568763],\n",
       "         [ 0.74108465,  0.56535798],\n",
       "         [ 0.90965321,  0.66773736],\n",
       "         [ 1.09146155,  0.77681868],\n",
       "         [ 1.29520226,  0.89645892],\n",
       "         [ 1.50580447,  1.02978075],\n",
       "         [ 1.71187112,  1.16091675],\n",
       "         [ 1.91202955,  1.28759548],\n",
       "         [ 2.10840564,  1.41366087],\n",
       "         [ 2.31667934,  1.55891066],\n",
       "         [ 2.52813663,  1.70057461],\n",
       "         [ 2.71795446,  1.82552733],\n",
       "         [ 2.88951752,  1.93411371],\n",
       "         [ 3.04324306,  2.02582913],\n",
       "         [ 3.20641694,  2.12094825],\n",
       "         [ 3.37346318,  2.21253132],\n",
       "         [ 3.5338853 ,  2.31009245],\n",
       "         [ 3.67958798,  2.39501369],\n",
       "...\n",
       "         [20.27931898, 11.35560608],\n",
       "         [24.37752021, 13.44137252],\n",
       "         [28.67828721, 15.6987151 ],\n",
       "         [33.45442597, 18.17604377],\n",
       "         [38.80323181, 20.69362697],\n",
       "         [44.55997012, 23.27688345],\n",
       "         [49.93755309, 25.76883144],\n",
       "         [54.82895482, 28.01593127],\n",
       "         [59.16887782, 30.11019506],\n",
       "         [62.51637386, 31.41516494],\n",
       "         [64.92056533, 32.45071753],\n",
       "         [66.58908807, 33.23002715],\n",
       "         [68.38136641, 34.05290536],\n",
       "         [70.45081676, 34.90073779],\n",
       "         [72.67862958, 35.76764274],\n",
       "         [74.44601444, 36.60704394],\n",
       "         [75.98740664, 37.21581421],\n",
       "         [76.87683323, 37.65505716],\n",
       "         [77.51629137, 37.82303199],\n",
       "         [78.019494  , 38.07761863]]]])</pre></div></li><li class='xr-var-item'><div class='xr-var-name'><span>v_component_of_wind</span></div><div class='xr-var-dims'>(metric, region, lead_time, level)</div><div class='xr-var-dtype'>float64</div><div class='xr-var-preview xr-preview'>0.4085 0.3511 ... 100.3 43.78</div><input id='attrs-674de632-16d2-465b-a000-afec182b0cac' class='xr-var-attrs-in' type='checkbox' disabled><label for='attrs-674de632-16d2-465b-a000-afec182b0cac' title='Show/Hide attributes'><svg class='icon xr-icon-file-text2'><use xlink:href='#icon-file-text2'></use></svg></label><input id='data-2790164d-ae6a-4b9b-82b7-40e3a02832c8' class='xr-var-data-in' type='checkbox'><label for='data-2790164d-ae6a-4b9b-82b7-40e3a02832c8' 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.40851834,   0.35110469],\n",
       "         [  0.52523674,   0.42338798],\n",
       "         [  0.66569728,   0.51152411],\n",
       "         [  0.83493946,   0.6096623 ],\n",
       "         [  1.02369187,   0.71898997],\n",
       "         [  1.23107095,   0.83825793],\n",
       "         [  1.44259077,   0.96945548],\n",
       "         [  1.67001008,   1.11017795],\n",
       "         [  1.8909849 ,   1.25072559],\n",
       "         [  2.10758132,   1.39182703],\n",
       "         [  2.32708841,   1.52831465],\n",
       "         [  2.55407134,   1.66671363],\n",
       "         [  2.7762084 ,   1.81234251],\n",
       "         [  2.98025164,   1.94957096],\n",
       "         [  3.16098927,   2.06033898],\n",
       "         [  3.34103239,   2.15942684],\n",
       "         [  3.51965712,   2.26599632],\n",
       "         [  3.69275428,   2.36501084],\n",
       "         [  3.83159823,   2.44897033],\n",
       "         [  3.95206842,   2.5113861 ],\n",
       "...\n",
       "         [ 27.3494065 ,  13.32018851],\n",
       "         [ 33.15969944,  15.8491596 ],\n",
       "         [ 39.16661562,  18.40390045],\n",
       "         [ 44.98082459,  21.00847679],\n",
       "         [ 50.88961927,  23.78087218],\n",
       "         [ 56.90587646,  26.47977567],\n",
       "         [ 62.86266721,  28.89655753],\n",
       "         [ 67.97279905,  30.73912558],\n",
       "         [ 71.95826713,  32.22088952],\n",
       "         [ 75.5953272 ,  33.54515556],\n",
       "         [ 78.70672556,  34.9468654 ],\n",
       "         [ 81.80887306,  36.24884935],\n",
       "         [ 84.66047465,  37.45539127],\n",
       "         [ 87.8252008 ,  38.70806524],\n",
       "         [ 90.97912183,  39.96611213],\n",
       "         [ 93.78064195,  40.87603247],\n",
       "         [ 95.93141086,  41.69670162],\n",
       "         [ 97.99458647,  42.46396777],\n",
       "         [ 99.50791874,  43.15649376],\n",
       "         [100.30880293,  43.78290432]]]])</pre></div></li></ul></div></li><li class='xr-section-item'><input id='section-33e43a98-f06d-479b-8d78-9d1fdfa23dad' class='xr-section-summary-in' type='checkbox'  ><label for='section-33e43a98-f06d-479b-8d78-9d1fdfa23dad' class='xr-section-summary' >Indexes: <span>(4)</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-index-name'><div>lead_time</div></div><div class='xr-index-preview'>PandasIndex</div><div></div><input id='index-f567aa7f-96c1-4e8e-a3c6-9d168186329b' class='xr-index-data-in' type='checkbox'/><label for='index-f567aa7f-96c1-4e8e-a3c6-9d168186329b' title='Show/Hide index repr'><svg class='icon xr-icon-database'><use xlink:href='#icon-database'></use></svg></label><div class='xr-index-data'><pre>PandasIndex(TimedeltaIndex([ &#x27;0 days 12:00:00&#x27;,  &#x27;1 days 00:00:00&#x27;,  &#x27;1 days 12:00:00&#x27;,\n",
       "                 &#x27;2 days 00:00:00&#x27;,  &#x27;2 days 12:00:00&#x27;,  &#x27;3 days 00:00:00&#x27;,\n",
       "                 &#x27;3 days 12:00:00&#x27;,  &#x27;4 days 00:00:00&#x27;,  &#x27;4 days 12:00:00&#x27;,\n",
       "                 &#x27;5 days 00:00:00&#x27;,  &#x27;5 days 12:00:00&#x27;,  &#x27;6 days 00:00:00&#x27;,\n",
       "                 &#x27;6 days 12:00:00&#x27;,  &#x27;7 days 00:00:00&#x27;,  &#x27;7 days 12:00:00&#x27;,\n",
       "                 &#x27;8 days 00:00:00&#x27;,  &#x27;8 days 12:00:00&#x27;,  &#x27;9 days 00:00:00&#x27;,\n",
       "                 &#x27;9 days 12:00:00&#x27;, &#x27;10 days 00:00:00&#x27;, &#x27;10 days 12:00:00&#x27;,\n",
       "                &#x27;11 days 00:00:00&#x27;, &#x27;11 days 12:00:00&#x27;, &#x27;12 days 00:00:00&#x27;,\n",
       "                &#x27;12 days 12:00:00&#x27;, &#x27;13 days 00:00:00&#x27;, &#x27;13 days 12:00:00&#x27;,\n",
       "                &#x27;14 days 00:00:00&#x27;, &#x27;14 days 12:00:00&#x27;, &#x27;15 days 00:00:00&#x27;],\n",
       "               dtype=&#x27;timedelta64[ns]&#x27;, name=&#x27;lead_time&#x27;, freq=None))</pre></div></li><li class='xr-var-item'><div class='xr-index-name'><div>region</div></div><div class='xr-index-preview'>PandasIndex</div><div></div><input id='index-ff03eefa-0d82-432b-8b07-947a901c9780' class='xr-index-data-in' type='checkbox'/><label for='index-ff03eefa-0d82-432b-8b07-947a901c9780' title='Show/Hide index repr'><svg class='icon xr-icon-database'><use xlink:href='#icon-database'></use></svg></label><div class='xr-index-data'><pre>PandasIndex(Index([&#x27;northernhemisphere&#x27;, &#x27;tropics&#x27;, &#x27;southernhemisphere&#x27;], dtype=&#x27;object&#x27;, name=&#x27;region&#x27;))</pre></div></li><li class='xr-var-item'><div class='xr-index-name'><div>metric</div></div><div class='xr-index-preview'>PandasIndex</div><div></div><input id='index-2bd12f50-6c7e-4300-a3c7-b54c589d3aca' class='xr-index-data-in' type='checkbox'/><label for='index-2bd12f50-6c7e-4300-a3c7-b54c589d3aca' title='Show/Hide index repr'><svg class='icon xr-icon-database'><use xlink:href='#icon-database'></use></svg></label><div class='xr-index-data'><pre>PandasIndex(Index([&#x27;CRPS&#x27;, &#x27;EnergyScore&#x27;, &#x27;EnsMSE&#x27;], dtype=&#x27;object&#x27;, name=&#x27;metric&#x27;))</pre></div></li><li class='xr-var-item'><div class='xr-index-name'><div>level</div></div><div class='xr-index-preview'>PandasIndex</div><div></div><input id='index-37e9b418-b8f3-4315-9095-9295d13889d7' class='xr-index-data-in' type='checkbox'/><label for='index-37e9b418-b8f3-4315-9095-9295d13889d7' title='Show/Hide index repr'><svg class='icon xr-icon-database'><use xlink:href='#icon-database'></use></svg></label><div class='xr-index-data'><pre>PandasIndex(Index([500, 850], dtype=&#x27;int32&#x27;, name=&#x27;level&#x27;))</pre></div></li></ul></div></li><li class='xr-section-item'><input id='section-407ad7ce-2c8c-4ae3-8eaf-8563f8c5564e' class='xr-section-summary-in' type='checkbox' disabled ><label for='section-407ad7ce-2c8c-4ae3-8eaf-8563f8c5564e' 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.Dataset>\n",
       "Dimensions:              (lead_time: 30, region: 3, metric: 3, level: 2)\n",
       "Coordinates:\n",
       "  * lead_time            (lead_time) timedelta64[ns] 0 days 12:00:00 ... 15 d...\n",
       "  * region               (region) object 'northernhemisphere' ... 'southernhe...\n",
       "  * metric               (metric) object 'CRPS' 'EnergyScore' 'EnsMSE'\n",
       "  * level                (level) int32 500 850\n",
       "Data variables:\n",
       "    geopotential         (metric, region, lead_time, level) float64 17.79 ......\n",
       "    temperature          (metric, region, lead_time, level) float64 0.1402 .....\n",
       "    u_component_of_wind  (metric, region, lead_time, level) float64 0.3842 .....\n",
       "    v_component_of_wind  (metric, region, lead_time, level) float64 0.4085 ....."
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "overallIFSENSE = overallIFSENSE.isel(lead_time=slice(0, None,2)).isel(lead_time=slice(1, None))\n",
    "overallIFSENSE   #This selection reduces 6h time to 12 hour to compare with gcm"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "overallGCM = xr.open_dataset('WeatherData/NEWENSERAmonthsgcm11.nc')\n",
    "for i in range(11):\n",
    "    results = xr.open_dataset('WeatherData/NEWENSERAmonthsgcm' + str(i) + '.nc')\n",
    "    overallGCM = overallGCM + results\n",
    "\n",
    "overallGCM = overallGCM/12"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "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[data-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-index-preview {\n",
       "  grid-column: 2 / 5;\n",
       "  color: var(--xr-font-color2);\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",
       ".xr-index-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",
       ".xr-index-data-in:checked ~ .xr-index-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-index-name div,\n",
       ".xr-index-data,\n",
       ".xr-attrs {\n",
       "  padding-left: 25px !important;\n",
       "}\n",
       "\n",
       ".xr-attrs,\n",
       ".xr-var-attrs,\n",
       ".xr-var-data,\n",
       ".xr-index-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",
       ".xr-no-icon {\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.Dataset&gt;\n",
       "Dimensions:              (lead_time: 30, region: 3, metric: 3, level: 2)\n",
       "Coordinates:\n",
       "  * lead_time            (lead_time) timedelta64[ns] 0 days 12:00:00 ... 15 d...\n",
       "  * region               (region) object &#x27;northernhemisphere&#x27; ... &#x27;southernhe...\n",
       "  * metric               (metric) object &#x27;CRPS&#x27; &#x27;EnergyScore&#x27; &#x27;EnsMSE&#x27;\n",
       "  * level                (level) int32 500 850\n",
       "Data variables:\n",
       "    geopotential         (metric, region, lead_time, level) float64 15.47 ......\n",
       "    temperature          (metric, region, lead_time, level) float64 0.121 ......\n",
       "    u_component_of_wind  (metric, region, lead_time, level) float64 0.3593 .....\n",
       "    v_component_of_wind  (metric, region, lead_time, level) float64 0.3948 .....</pre><div class='xr-wrap' style='display:none'><div class='xr-header'><div class='xr-obj-type'>xarray.Dataset</div></div><ul class='xr-sections'><li class='xr-section-item'><input id='section-28c74ce2-d86c-4003-a633-f03384bf54a7' class='xr-section-summary-in' type='checkbox' disabled ><label for='section-28c74ce2-d86c-4003-a633-f03384bf54a7' class='xr-section-summary'  title='Expand/collapse section'>Dimensions:</label><div class='xr-section-inline-details'><ul class='xr-dim-list'><li><span class='xr-has-index'>lead_time</span>: 30</li><li><span class='xr-has-index'>region</span>: 3</li><li><span class='xr-has-index'>metric</span>: 3</li><li><span class='xr-has-index'>level</span>: 2</li></ul></div><div class='xr-section-details'></div></li><li class='xr-section-item'><input id='section-aa17aff2-d2a9-409f-b435-21353e6f680b' class='xr-section-summary-in' type='checkbox'  checked><label for='section-aa17aff2-d2a9-409f-b435-21353e6f680b' class='xr-section-summary' >Coordinates: <span>(4)</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'>lead_time</span></div><div class='xr-var-dims'>(lead_time)</div><div class='xr-var-dtype'>timedelta64[ns]</div><div class='xr-var-preview xr-preview'>0 days 12:00:00 ... 15 days 00:0...</div><input id='attrs-a26dd7f3-6e01-4545-ab1f-c1f17d15e5f6' class='xr-var-attrs-in' type='checkbox' disabled><label for='attrs-a26dd7f3-6e01-4545-ab1f-c1f17d15e5f6' title='Show/Hide attributes'><svg class='icon xr-icon-file-text2'><use xlink:href='#icon-file-text2'></use></svg></label><input id='data-749f56ce-189d-4bf4-b0fb-b330faf6218c' class='xr-var-data-in' type='checkbox'><label for='data-749f56ce-189d-4bf4-b0fb-b330faf6218c' 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([  43200000000000,   86400000000000,  129600000000000,  172800000000000,\n",
       "        216000000000000,  259200000000000,  302400000000000,  345600000000000,\n",
       "        388800000000000,  432000000000000,  475200000000000,  518400000000000,\n",
       "        561600000000000,  604800000000000,  648000000000000,  691200000000000,\n",
       "        734400000000000,  777600000000000,  820800000000000,  864000000000000,\n",
       "        907200000000000,  950400000000000,  993600000000000, 1036800000000000,\n",
       "       1080000000000000, 1123200000000000, 1166400000000000, 1209600000000000,\n",
       "       1252800000000000, 1296000000000000], dtype=&#x27;timedelta64[ns]&#x27;)</pre></div></li><li class='xr-var-item'><div class='xr-var-name'><span class='xr-has-index'>region</span></div><div class='xr-var-dims'>(region)</div><div class='xr-var-dtype'>object</div><div class='xr-var-preview xr-preview'>&#x27;northernhemisphere&#x27; ... &#x27;southe...</div><input id='attrs-f531d51a-371c-48b3-81c0-3089a65a7aa1' class='xr-var-attrs-in' type='checkbox' disabled><label for='attrs-f531d51a-371c-48b3-81c0-3089a65a7aa1' title='Show/Hide attributes'><svg class='icon xr-icon-file-text2'><use xlink:href='#icon-file-text2'></use></svg></label><input id='data-d267998e-6222-4c96-980d-bb1eb6352b45' class='xr-var-data-in' type='checkbox'><label for='data-d267998e-6222-4c96-980d-bb1eb6352b45' 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([&#x27;northernhemisphere&#x27;, &#x27;tropics&#x27;, &#x27;southernhemisphere&#x27;], dtype=object)</pre></div></li><li class='xr-var-item'><div class='xr-var-name'><span class='xr-has-index'>metric</span></div><div class='xr-var-dims'>(metric)</div><div class='xr-var-dtype'>object</div><div class='xr-var-preview xr-preview'>&#x27;CRPS&#x27; &#x27;EnergyScore&#x27; &#x27;EnsMSE&#x27;</div><input id='attrs-3f50a59f-ba6a-484a-9f77-8b3935879514' class='xr-var-attrs-in' type='checkbox' disabled><label for='attrs-3f50a59f-ba6a-484a-9f77-8b3935879514' title='Show/Hide attributes'><svg class='icon xr-icon-file-text2'><use xlink:href='#icon-file-text2'></use></svg></label><input id='data-ebe99f8c-7370-4acf-93e9-42bb6b357538' class='xr-var-data-in' type='checkbox'><label for='data-ebe99f8c-7370-4acf-93e9-42bb6b357538' 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([&#x27;CRPS&#x27;, &#x27;EnergyScore&#x27;, &#x27;EnsMSE&#x27;], dtype=object)</pre></div></li><li class='xr-var-item'><div class='xr-var-name'><span class='xr-has-index'>level</span></div><div class='xr-var-dims'>(level)</div><div class='xr-var-dtype'>int32</div><div class='xr-var-preview xr-preview'>500 850</div><input id='attrs-124df458-8209-49a9-be5d-80e91449ee70' class='xr-var-attrs-in' type='checkbox' disabled><label for='attrs-124df458-8209-49a9-be5d-80e91449ee70' title='Show/Hide attributes'><svg class='icon xr-icon-file-text2'><use xlink:href='#icon-file-text2'></use></svg></label><input id='data-7d2aa330-4dc8-4a36-9fa8-29c2f9f25ca9' class='xr-var-data-in' type='checkbox'><label for='data-7d2aa330-4dc8-4a36-9fa8-29c2f9f25ca9' 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([500, 850])</pre></div></li></ul></div></li><li class='xr-section-item'><input id='section-ee29022a-9f4c-4986-8a60-301cb482165d' class='xr-section-summary-in' type='checkbox'  checked><label for='section-ee29022a-9f4c-4986-8a60-301cb482165d' class='xr-section-summary' >Data variables: <span>(4)</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>geopotential</span></div><div class='xr-var-dims'>(metric, region, lead_time, level)</div><div class='xr-var-dtype'>float64</div><div class='xr-var-preview xr-preview'>15.47 14.44 ... 9.57e+05 4.715e+05</div><input id='attrs-fce12a62-1a45-4714-98dd-35216014547b' class='xr-var-attrs-in' type='checkbox' disabled><label for='attrs-fce12a62-1a45-4714-98dd-35216014547b' title='Show/Hide attributes'><svg class='icon xr-icon-file-text2'><use xlink:href='#icon-file-text2'></use></svg></label><input id='data-d29e3d4e-1156-48c6-b171-d2928e233fdd' class='xr-var-data-in' type='checkbox'><label for='data-d29e3d4e-1156-48c6-b171-d2928e233fdd' 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([[[[1.54748373e+01, 1.44360438e+01],\n",
       "         [2.09372860e+01, 1.86504414e+01],\n",
       "         [2.89845221e+01, 2.39508660e+01],\n",
       "         [3.86207536e+01, 3.08073452e+01],\n",
       "         [5.08533485e+01, 3.94031456e+01],\n",
       "         [6.49569945e+01, 4.89833065e+01],\n",
       "         [8.05410238e+01, 5.97466251e+01],\n",
       "         [9.77821508e+01, 7.15970603e+01],\n",
       "         [1.16010184e+02, 8.42558633e+01],\n",
       "         [1.34676202e+02, 9.76484500e+01],\n",
       "         [1.54320440e+02, 1.10745453e+02],\n",
       "         [1.75337540e+02, 1.24763098e+02],\n",
       "         [1.97215719e+02, 1.39456421e+02],\n",
       "         [2.18758026e+02, 1.54198163e+02],\n",
       "         [2.37928932e+02, 1.67196560e+02],\n",
       "         [2.56160900e+02, 1.79868390e+02],\n",
       "         [2.75220801e+02, 1.93511698e+02],\n",
       "         [2.95437319e+02, 2.07710586e+02],\n",
       "         [3.15435500e+02, 2.20828866e+02],\n",
       "         [3.35036226e+02, 2.33489930e+02],\n",
       "...\n",
       "         [1.54521960e+05, 8.80883159e+04],\n",
       "         [1.97057944e+05, 1.09379245e+05],\n",
       "         [2.45073560e+05, 1.32692962e+05],\n",
       "         [2.97794043e+05, 1.57811865e+05],\n",
       "         [3.53043639e+05, 1.83827137e+05],\n",
       "         [4.09466400e+05, 2.11309600e+05],\n",
       "         [4.62674423e+05, 2.38535728e+05],\n",
       "         [5.12350384e+05, 2.65668509e+05],\n",
       "         [5.60819003e+05, 2.92127457e+05],\n",
       "         [6.09084965e+05, 3.15733466e+05],\n",
       "         [6.56175659e+05, 3.37647108e+05],\n",
       "         [7.04803434e+05, 3.61765728e+05],\n",
       "         [7.55850962e+05, 3.86083646e+05],\n",
       "         [8.04415392e+05, 4.08470281e+05],\n",
       "         [8.46000283e+05, 4.26147039e+05],\n",
       "         [8.79334247e+05, 4.41023302e+05],\n",
       "         [9.05575805e+05, 4.52249247e+05],\n",
       "         [9.24562737e+05, 4.59550390e+05],\n",
       "         [9.41234003e+05, 4.65634463e+05],\n",
       "         [9.56961556e+05, 4.71539470e+05]]]])</pre></div></li><li class='xr-var-item'><div class='xr-var-name'><span>temperature</span></div><div class='xr-var-dims'>(metric, region, lead_time, level)</div><div class='xr-var-dtype'>float64</div><div class='xr-var-preview xr-preview'>0.121 0.1836 0.1659 ... 12.28 13.5</div><input id='attrs-92455054-efbd-4b6a-9262-8f8158492d9f' class='xr-var-attrs-in' type='checkbox' disabled><label for='attrs-92455054-efbd-4b6a-9262-8f8158492d9f' title='Show/Hide attributes'><svg class='icon xr-icon-file-text2'><use xlink:href='#icon-file-text2'></use></svg></label><input id='data-a0d15a79-04a2-499b-847c-c463704fa47f' class='xr-var-data-in' type='checkbox'><label for='data-a0d15a79-04a2-499b-847c-c463704fa47f' 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.12097569,  0.1836299 ],\n",
       "         [ 0.16593324,  0.23019377],\n",
       "         [ 0.21388644,  0.27839358],\n",
       "         [ 0.26439081,  0.32203507],\n",
       "         [ 0.32093265,  0.37399936],\n",
       "         [ 0.38511682,  0.42787177],\n",
       "         [ 0.45561992,  0.49428632],\n",
       "         [ 0.52788208,  0.56761368],\n",
       "         [ 0.6038937 ,  0.64978689],\n",
       "         [ 0.6796562 ,  0.73452739],\n",
       "         [ 0.76017835,  0.8210355 ],\n",
       "         [ 0.84323305,  0.91263953],\n",
       "         [ 0.92809571,  1.00592366],\n",
       "         [ 1.01512586,  1.09653592],\n",
       "         [ 1.09706484,  1.18248964],\n",
       "         [ 1.17051999,  1.26525314],\n",
       "         [ 1.2325851 ,  1.34313347],\n",
       "         [ 1.29386595,  1.42111558],\n",
       "         [ 1.36119527,  1.49518756],\n",
       "         [ 1.42688999,  1.56721341],\n",
       "...\n",
       "         [ 2.78256351,  3.21558955],\n",
       "         [ 3.3843284 ,  3.90108397],\n",
       "         [ 4.05969325,  4.59378031],\n",
       "         [ 4.75907279,  5.27940559],\n",
       "         [ 5.47222694,  5.9709957 ],\n",
       "         [ 6.16093156,  6.69896677],\n",
       "         [ 6.7886897 ,  7.39915277],\n",
       "         [ 7.40289546,  8.03602146],\n",
       "         [ 8.00242779,  8.59920392],\n",
       "         [ 8.60457053,  9.19033091],\n",
       "         [ 9.15975354,  9.78507119],\n",
       "         [ 9.63886892, 10.34892928],\n",
       "         [10.10093076, 10.92539736],\n",
       "         [10.55991574, 11.48230961],\n",
       "         [10.96755448, 12.022191  ],\n",
       "         [11.28631797, 12.4189325 ],\n",
       "         [11.59445527, 12.72341969],\n",
       "         [11.86154039, 13.00046391],\n",
       "         [12.10529994, 13.2719022 ],\n",
       "         [12.27550663, 13.50089014]]]])</pre></div></li><li class='xr-var-item'><div class='xr-var-name'><span>u_component_of_wind</span></div><div class='xr-var-dims'>(metric, region, lead_time, level)</div><div class='xr-var-dtype'>float64</div><div class='xr-var-preview xr-preview'>0.3593 0.3045 0.4701 ... 76.56 37.3</div><input id='attrs-05de5c84-9eea-42ed-a6fd-1ea39774e82e' class='xr-var-attrs-in' type='checkbox' disabled><label for='attrs-05de5c84-9eea-42ed-a6fd-1ea39774e82e' title='Show/Hide attributes'><svg class='icon xr-icon-file-text2'><use xlink:href='#icon-file-text2'></use></svg></label><input id='data-b5059d37-121a-4c83-989d-b99ebc8e37c3' class='xr-var-data-in' type='checkbox'><label for='data-b5059d37-121a-4c83-989d-b99ebc8e37c3' 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.35927161,  0.30451409],\n",
       "         [ 0.47006928,  0.37025013],\n",
       "         [ 0.59500904,  0.44919811],\n",
       "         [ 0.73019121,  0.53303081],\n",
       "         [ 0.88535518,  0.63389217],\n",
       "         [ 1.05822438,  0.74559388],\n",
       "         [ 1.24440522,  0.86679439],\n",
       "         [ 1.44549416,  0.99442843],\n",
       "         [ 1.64856279,  1.12338025],\n",
       "         [ 1.84755316,  1.25005648],\n",
       "         [ 2.04452712,  1.37228699],\n",
       "         [ 2.24446766,  1.50815276],\n",
       "         [ 2.45026699,  1.63923344],\n",
       "         [ 2.64008151,  1.76250406],\n",
       "         [ 2.81402319,  1.86440917],\n",
       "         [ 2.96999692,  1.95977019],\n",
       "         [ 3.13311151,  2.06077282],\n",
       "         [ 3.29656644,  2.16626236],\n",
       "         [ 3.45916579,  2.26954483],\n",
       "         [ 3.61356524,  2.36183548],\n",
       "...\n",
       "         [19.94888422, 10.98148218],\n",
       "         [23.81854856, 12.93101335],\n",
       "         [27.87308435, 15.16386196],\n",
       "         [32.29267448, 17.56183034],\n",
       "         [37.04810404, 19.76924512],\n",
       "         [42.07659752, 22.05381133],\n",
       "         [46.91764008, 24.46048915],\n",
       "         [51.65074557, 26.78664298],\n",
       "         [55.86338047, 28.92437379],\n",
       "         [59.20909919, 30.12686328],\n",
       "         [61.52617198, 30.91037933],\n",
       "         [63.06268394, 31.6257761 ],\n",
       "         [65.3947384 , 32.60030061],\n",
       "         [67.87835715, 33.73018509],\n",
       "         [70.1484764 , 34.82135758],\n",
       "         [71.93544238, 35.72283391],\n",
       "         [73.50907523, 36.42377   ],\n",
       "         [74.77736245, 36.78874183],\n",
       "         [75.73506007, 37.05561854],\n",
       "         [76.55992141, 37.30378475]]]])</pre></div></li><li class='xr-var-item'><div class='xr-var-name'><span>v_component_of_wind</span></div><div class='xr-var-dims'>(metric, region, lead_time, level)</div><div class='xr-var-dtype'>float64</div><div class='xr-var-preview xr-preview'>0.3948 0.3283 0.538 ... 98.98 43.31</div><input id='attrs-ab30c145-8a63-476e-8d10-887a97fb65f7' class='xr-var-attrs-in' type='checkbox' disabled><label for='attrs-ab30c145-8a63-476e-8d10-887a97fb65f7' title='Show/Hide attributes'><svg class='icon xr-icon-file-text2'><use xlink:href='#icon-file-text2'></use></svg></label><input id='data-1296de64-725a-4719-9cbf-4ee7cddef8de' class='xr-var-data-in' type='checkbox'><label for='data-1296de64-725a-4719-9cbf-4ee7cddef8de' 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.39479327,  0.3283485 ],\n",
       "         [ 0.5379951 ,  0.40804413],\n",
       "         [ 0.67804302,  0.49387761],\n",
       "         [ 0.8360187 ,  0.58682469],\n",
       "         [ 1.01181197,  0.68782254],\n",
       "         [ 1.2033449 ,  0.80232846],\n",
       "         [ 1.40252223,  0.92865526],\n",
       "         [ 1.61485617,  1.06256012],\n",
       "         [ 1.82636412,  1.19925305],\n",
       "         [ 2.03344699,  1.33372217],\n",
       "         [ 2.24512185,  1.46487065],\n",
       "         [ 2.47474463,  1.59985547],\n",
       "         [ 2.70391476,  1.74097956],\n",
       "         [ 2.91791176,  1.87524163],\n",
       "         [ 3.10152555,  1.98162896],\n",
       "         [ 3.27892446,  2.08561976],\n",
       "         [ 3.45059565,  2.1976551 ],\n",
       "         [ 3.62507664,  2.30307551],\n",
       "         [ 3.78470926,  2.39605024],\n",
       "         [ 3.92997922,  2.48345323],\n",
       "...\n",
       "         [27.39485093, 13.36753538],\n",
       "         [33.11433491, 15.90126172],\n",
       "         [38.9917738 , 18.31350135],\n",
       "         [44.51431315, 20.69260624],\n",
       "         [50.21196316, 23.27399238],\n",
       "         [55.70012335, 25.73381854],\n",
       "         [60.91721883, 28.03629035],\n",
       "         [65.47565226, 29.93630164],\n",
       "         [69.70058312, 31.59518224],\n",
       "         [74.07386573, 33.17142476],\n",
       "         [77.76742219, 34.49792769],\n",
       "         [81.22368412, 35.69485456],\n",
       "         [84.39944822, 36.89764166],\n",
       "         [87.55280313, 38.14115922],\n",
       "         [90.41801278, 39.40808782],\n",
       "         [92.94547415, 40.41142239],\n",
       "         [95.09848831, 41.20877189],\n",
       "         [96.8050839 , 41.9387285 ],\n",
       "         [98.38529386, 42.79285518],\n",
       "         [98.98257994, 43.31449066]]]])</pre></div></li></ul></div></li><li class='xr-section-item'><input id='section-75ffd109-4b85-4aaa-ab63-d254298ca9cf' class='xr-section-summary-in' type='checkbox'  ><label for='section-75ffd109-4b85-4aaa-ab63-d254298ca9cf' class='xr-section-summary' >Indexes: <span>(4)</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-index-name'><div>lead_time</div></div><div class='xr-index-preview'>PandasIndex</div><div></div><input id='index-5cee1733-5891-48cc-8823-1b440be4f1d6' class='xr-index-data-in' type='checkbox'/><label for='index-5cee1733-5891-48cc-8823-1b440be4f1d6' title='Show/Hide index repr'><svg class='icon xr-icon-database'><use xlink:href='#icon-database'></use></svg></label><div class='xr-index-data'><pre>PandasIndex(TimedeltaIndex([ &#x27;0 days 12:00:00&#x27;,  &#x27;1 days 00:00:00&#x27;,  &#x27;1 days 12:00:00&#x27;,\n",
       "                 &#x27;2 days 00:00:00&#x27;,  &#x27;2 days 12:00:00&#x27;,  &#x27;3 days 00:00:00&#x27;,\n",
       "                 &#x27;3 days 12:00:00&#x27;,  &#x27;4 days 00:00:00&#x27;,  &#x27;4 days 12:00:00&#x27;,\n",
       "                 &#x27;5 days 00:00:00&#x27;,  &#x27;5 days 12:00:00&#x27;,  &#x27;6 days 00:00:00&#x27;,\n",
       "                 &#x27;6 days 12:00:00&#x27;,  &#x27;7 days 00:00:00&#x27;,  &#x27;7 days 12:00:00&#x27;,\n",
       "                 &#x27;8 days 00:00:00&#x27;,  &#x27;8 days 12:00:00&#x27;,  &#x27;9 days 00:00:00&#x27;,\n",
       "                 &#x27;9 days 12:00:00&#x27;, &#x27;10 days 00:00:00&#x27;, &#x27;10 days 12:00:00&#x27;,\n",
       "                &#x27;11 days 00:00:00&#x27;, &#x27;11 days 12:00:00&#x27;, &#x27;12 days 00:00:00&#x27;,\n",
       "                &#x27;12 days 12:00:00&#x27;, &#x27;13 days 00:00:00&#x27;, &#x27;13 days 12:00:00&#x27;,\n",
       "                &#x27;14 days 00:00:00&#x27;, &#x27;14 days 12:00:00&#x27;, &#x27;15 days 00:00:00&#x27;],\n",
       "               dtype=&#x27;timedelta64[ns]&#x27;, name=&#x27;lead_time&#x27;, freq=None))</pre></div></li><li class='xr-var-item'><div class='xr-index-name'><div>region</div></div><div class='xr-index-preview'>PandasIndex</div><div></div><input id='index-91400c6e-1d1a-4c9c-b438-b30a11316263' class='xr-index-data-in' type='checkbox'/><label for='index-91400c6e-1d1a-4c9c-b438-b30a11316263' title='Show/Hide index repr'><svg class='icon xr-icon-database'><use xlink:href='#icon-database'></use></svg></label><div class='xr-index-data'><pre>PandasIndex(Index([&#x27;northernhemisphere&#x27;, &#x27;tropics&#x27;, &#x27;southernhemisphere&#x27;], dtype=&#x27;object&#x27;, name=&#x27;region&#x27;))</pre></div></li><li class='xr-var-item'><div class='xr-index-name'><div>metric</div></div><div class='xr-index-preview'>PandasIndex</div><div></div><input id='index-5406a1f8-b5fc-4968-aa79-8a649f99eb9c' class='xr-index-data-in' type='checkbox'/><label for='index-5406a1f8-b5fc-4968-aa79-8a649f99eb9c' title='Show/Hide index repr'><svg class='icon xr-icon-database'><use xlink:href='#icon-database'></use></svg></label><div class='xr-index-data'><pre>PandasIndex(Index([&#x27;CRPS&#x27;, &#x27;EnergyScore&#x27;, &#x27;EnsMSE&#x27;], dtype=&#x27;object&#x27;, name=&#x27;metric&#x27;))</pre></div></li><li class='xr-var-item'><div class='xr-index-name'><div>level</div></div><div class='xr-index-preview'>PandasIndex</div><div></div><input id='index-f0f36eb1-895f-4ba4-9d49-f531c4161720' class='xr-index-data-in' type='checkbox'/><label for='index-f0f36eb1-895f-4ba4-9d49-f531c4161720' title='Show/Hide index repr'><svg class='icon xr-icon-database'><use xlink:href='#icon-database'></use></svg></label><div class='xr-index-data'><pre>PandasIndex(Index([500, 850], dtype=&#x27;int32&#x27;, name=&#x27;level&#x27;))</pre></div></li></ul></div></li><li class='xr-section-item'><input id='section-b18335d1-e8de-43e6-937c-cdb9a88f40f3' class='xr-section-summary-in' type='checkbox' disabled ><label for='section-b18335d1-e8de-43e6-937c-cdb9a88f40f3' 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.Dataset>\n",
       "Dimensions:              (lead_time: 30, region: 3, metric: 3, level: 2)\n",
       "Coordinates:\n",
       "  * lead_time            (lead_time) timedelta64[ns] 0 days 12:00:00 ... 15 d...\n",
       "  * region               (region) object 'northernhemisphere' ... 'southernhe...\n",
       "  * metric               (metric) object 'CRPS' 'EnergyScore' 'EnsMSE'\n",
       "  * level                (level) int32 500 850\n",
       "Data variables:\n",
       "    geopotential         (metric, region, lead_time, level) float64 15.47 ......\n",
       "    temperature          (metric, region, lead_time, level) float64 0.121 ......\n",
       "    u_component_of_wind  (metric, region, lead_time, level) float64 0.3593 .....\n",
       "    v_component_of_wind  (metric, region, lead_time, level) float64 0.3948 ....."
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "overallGCM = overallGCM.isel(lead_time=slice(1,-1))\n",
    "overallGCM #This selection cuts number of leadtimes to align with IFS"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "<xarray.Dataset>\n",
      "Dimensions:              (lead_time: 30, region: 3, metric: 3, level: 2)\n",
      "Coordinates:\n",
      "  * lead_time            (lead_time) timedelta64[ns] 0 days 12:00:00 ... 15 d...\n",
      "  * region               (region) object 'northernhemisphere' ... 'southernhe...\n",
      "  * metric               (metric) object 'CRPS' 'EnergyScore' 'EnsMSE'\n",
      "  * level                (level) int32 500 850\n",
      "Data variables:\n",
      "    geopotential         (metric, region, lead_time, level) float64 -12.99 .....\n",
      "    temperature          (metric, region, lead_time, level) float64 -13.68 .....\n",
      "    u_component_of_wind  (metric, region, lead_time, level) float64 -6.481 .....\n",
      "    v_component_of_wind  (metric, region, lead_time, level) float64 -3.36 ......\n"
     ]
    }
   ],
   "source": [
    "percentage_diff = (overallGCM - overallIFSENSE) / overallIFSENSE * 100\n",
    "\n",
    "print(percentage_diff)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "<xarray.Dataset>\n",
      "Dimensions:              (metric: 2, region: 3, lead_time: 30, level: 2)\n",
      "Coordinates:\n",
      "  * lead_time            (lead_time) timedelta64[ns] 0 days 12:00:00 ... 15 d...\n",
      "  * region               (region) object 'northernhemisphere' ... 'southernhe...\n",
      "  * metric               (metric) object 'CRPS' 'EnsMSE'\n",
      "  * level                (level) int32 500 850\n",
      "Data variables:\n",
      "    geopotential         (metric, region, lead_time, level) float64 -12.99 .....\n",
      "    temperature          (metric, region, lead_time, level) float64 -13.68 .....\n",
      "    u_component_of_wind  (metric, region, lead_time, level) float64 -6.481 .....\n",
      "    v_component_of_wind  (metric, region, lead_time, level) float64 -3.36 ......\n"
     ]
    }
   ],
   "source": [
    "percentage_diff = percentage_diff.where(percentage_diff.metric != \"EnergyScore\", drop=True) #Too similar to CRPS so wasn't included\n",
    "print(percentage_diff)\n",
    "geopotential = percentage_diff['geopotential'].values\n",
    "geopotential.shape #now have normal array(metric =2, region =3, leadtime = 60, level =2)\n",
    "\n",
    "temperature = percentage_diff['temperature'].values\n",
    "u_component_of_wind = percentage_diff['u_component_of_wind'].values\n",
    "v_component_of_wind = percentage_diff['v_component_of_wind'].values"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "u_component_of_wind = u_component_of_wind[:,:,:,0]\n",
    "v_component_of_wind = v_component_of_wind[:,:,:,0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "weights = np.array([0.07704437, 0.23039114, 0.38151911, 0.52897285, 0.67133229,\n",
    "       0.80722643, 0.93534654, 1.05445875, 1.16341595, 1.26116882,\n",
    "       1.34677594, 1.41941287, 1.47838008, 1.52310968, 1.55317091,\n",
    "       1.56827425, 1.56827425, 1.55317091, 1.52310968, 1.47838008,\n",
    "       1.41941287, 1.34677594, 1.26116882, 1.16341595, 1.05445875,\n",
    "       0.93534654, 0.80722643, 0.67133229, 0.52897285, 0.38151911,\n",
    "       0.23039114, 0.07704437])\n",
    "\n",
    "southernweights = weights[0:12]\n",
    "tropicweights = weights[12:20]\n",
    "northernweights = weights[20:32]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "def latsplit(input):\n",
    "    input = input[:,:,1:]\n",
    "    inputsouthern = np.sum(input[0:12,:,:] * southernweights[:, None, None], axis=0)\n",
    "    inputst = np.mean(inputsouthern, axis=0)\n",
    "    inputsoutherndistance = inputst\n",
    "\n",
    "    inputtropic = np.sum(input[12:20,:,:] * tropicweights[:, None, None], axis=0)\n",
    "    inputtt = np.mean(inputtropic, axis=0)\n",
    "    inputtropicdistance = inputtt\n",
    "\n",
    "    inputnorthern = np.sum(input[20:32,:,:] * northernweights[:, None, None], axis=0)\n",
    "    inputnt = np.mean(inputnorthern, axis=0)\n",
    "    inputnortherndistance = inputnt\n",
    "\n",
    "    return (inputsoutherndistance,inputtropicdistance,inputnortherndistance)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [],
   "source": [
    "geo500 = np.load('Signature/geo500.npy')\n",
    "geo850 = np.load('Signature/geo850.npy')\n",
    "temp500 = np.load('Signature/temp500.npy')\n",
    "temp850 = np.load('Signature/temp850.npy')\n",
    "u500 = np.load('Signature/u500.npy')\n",
    "v500 = np.load('Signature/v500.npy')\n",
    "\n",
    "\n",
    "geo500gcm = np.load('Signature/geo500gcm.npy')\n",
    "geo850gcm = np.load('Signature/geo850gcm.npy')\n",
    "temp500gcm = np.load('Signature/temp500gcm.npy')\n",
    "temp850gcm = np.load('Signature/temp850gcm.npy')\n",
    "u500gcm = np.load('Signature/u500gcm.npy')\n",
    "v500gcm = np.load('Signature/v500gcm.npy')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "ens = [geo500,geo850,temp500,temp850,u500,v500]\n",
    "gcm = [geo500gcm,geo850gcm,temp500gcm,temp850gcm,u500gcm,v500gcm]\n",
    "\n",
    "storageval = np.zeros((6,30,3))\n",
    "storagevalgcm = np.zeros((6,30,3))\n",
    "\n",
    "for i in range(6):\n",
    "    south, tropics, northern = latsplit(ens[i])\n",
    "    storageval[i,:,0] = northern\n",
    "    storageval[i,:,1] = tropics\n",
    "    storageval[i,:,2] = south\n",
    "    south1, tropics1, northern1 = latsplit(gcm[i])\n",
    "    storagevalgcm[i,:,0] = northern1\n",
    "    storagevalgcm[i,:,1] = tropics1\n",
    "    storagevalgcm[i,:,2] = south1\n",
    "\n",
    "    \n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(6, 30, 3)"
      ]
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "percentage_diffsigkernel = -1*(storagevalgcm - storageval) / storageval * 100\n",
    "percentage_diffsigkernel.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABIwAAAIYCAYAAAAPcXfAAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjAsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvlHJYcgAAAAlwSFlzAAAPYQAAD2EBqD+naQAAY5lJREFUeJzt3Xl8FdX9//H3zc12k5CVfQ+LRGxEEFAUCGgVVAS1LlVrQZQqiHWhrhQQkE3r8rW4IBRj+aqgfClqrVZAFpVFcUFAU1R2AUkuS8i+ze+P/nLvnMlCEkIuF1/Px4OHM3POnfncOTOfmftx7o3LsixLAAAAAAAAwP8XEugAAAAAAAAAcGqhYAQAAAAAAAADBSMAAAAAAAAYKBgBAAAAAADAQMEIAAAAAAAABgpGAAAAAAAAMFAwAgAAAAAAgIGCEQAAAAAAAAwUjAAAAAAAAGCgYITTisvl0oABAwIdxi/Szp075XK5NGLEiAbZ3qpVq+RyufTYY481yPYAIBDat2+v9u3bBzoMADgu7sMDh/twnCwUjHBc5QnI5XJpyJAhlfYpTxp33nnnSY1lxIgRcrlc2rlz50ndTqA99thjcrlcWrhwYZV97rzzTrlcLq1atarhAgOA00D5Na2m/wAgEPLy8jR9+nT16NFDMTExioyMVOvWrdWvXz898sgj+vHHHxs0Hu7D/bgPxy9FaKADQHB57733tGbNGvXv3z/QoeAU06pVK3333XeKi4sLdCgAUK1JkyZVWDZ58mTFxcXp3nvvbfiAqrFixYpAhwAgAI4dO6a+ffvqm2++UadOnfS73/1O8fHx2rNnj7Zu3aqZM2eqY8eO6tixY6BDxSmA+3CcLBSMUGPt27fX7t279dBDD2ndunWBDgenmLCwMKWkpAQ6DAA4rsoeoZ88ebLi4+NPucfr+TAI/DI9++yz+uabb3Tbbbdp7ty5FZ523LFjhwoLCwMUHU413IfjZOEraaixLl266JZbbtH69eu1ZMmSGr9u9+7duu2229SqVSuFh4erdevWuu2227Rnz54KfQcMGCCXy6XCwkJNnDhRnTp1UlhYmB577DG1b99er776qiQpOTnZ91WByr4rnZmZqZEjR6pp06byeDw6//zzq3xk9NixY5o0aZLOOusseTwexcfHa/Dgwfrkk09qFZ/k/+52bbZ/MnzzzTf67W9/qxYtWig8PFzt2rXT3XffLa/Xa/Szf9/5u+++05AhQxQfH6+EhATdeOONysrKkiRt2LBBl1xyiWJjY5WQkKBRo0YpNze3ynXZ7d+/X/fcc486d+4sj8ejxMREpaamasyYMcrOzvb1K3/M+ccff9SMGTPUqVMnRUZGqnPnznryySdVVlZW5fv98ssvNWjQIDVq1EhxcXG6+uqrq3xceseOHbr99tvVtm1bRUREqEWLFhoxYoR27dpVoW/5eP70008aMWKEmjdvrpCQEGMs16xZoyuvvFKNGzdWRESEOnfurD//+c/Ky8urMl4AwcGe1zIyMnTNNdeocePGxlcySkpK9Mwzz6hbt27yeDyKi4vTwIED9d5771VYX3p6ulwul9LT0/WPf/xDvXr1UlRUlJo3b67Ro0fr8OHDFV5T1W8YWZalV199Vf3791d8fLyioqLUuXNn3Xnnndq9e7evX01zMIBTS/n/nB07dmylX41NTk6utECwdetW3XDDDWratKkiIiKUnJys++67T4cOHarQt7rfHHLmHu7Da477cO7DTyc8YYRamTJlihYuXKhHH31Uw4YNk9vtrrb/999/r759++rgwYO68sorddZZZ2nr1q2aP3++/vnPf+rTTz9Vp06dKrzummuu0aZNmzRo0CAlJiaqQ4cOuvfee5Wenq5NmzbpnnvuUXx8vCRVuJE+cuSILrzwQsXGxurmm2/WwYMHtWjRIg0aNEhffPGFfvWrX/n6Hjp0SP3799fWrVvVr18/DRo0SEePHtXbb7+tgQMH6q233tJVV11Vo/jqsv2T4Z133tH1118vt9utoUOHqk2bNvr22281e/Zs/fvf/9aGDRuUkJBgvGbHjh264IIL1LNnT91+++3auHGjFi5cqD179mjWrFm65JJLdMkll+gPf/iDVq1apXnz5kmS5s6dW20seXl5uvDCC7Vz505deumluvrqq1VUVKTt27crPT1dDz74oGJjY43X3HvvvVq/fr2uv/56RUZGasmSJXrwwQf1ww8/aM6cORW2sXHjRj355JMaMGCA7rjjDn311VdaunSpNm/erC1btigyMtLXd8OGDRo0aJByc3N15ZVXqlOnTtq5c6dee+01vf/++1q3bp0xlpLk9XrVp08fJSYm6oYbblBRUZEv5pdeekljxoxRQkKCrrzySjVp0kSff/65pk2bppUrV2rlypUKDw+v+eABOCX98MMPOv/883XWWWdp+PDhOnTokMLDw2VZlm644QYtWbJEZ5xxhu666y7l5ubqzTff1JAhQ/Q///M/+uMf/1hhfYsXL9ayZct03XXX6de//rVWr16tl156SevWrdO6devk8XiqjceyLN14441atGiRWrVqpRtvvFGxsbHauXOnFi1apMGDB6tt27Z1ysEATg2JiYmS/pt/zjnnnBq9Zu3atbr00ktVWFioa6+9Vu3bt9f69ev17LPP6r333tO6deuUlJRUp3i4D68Z7sO5Dz/tWMBx7Nixw5JkDRo0yLIsy7r//vstSdacOXN8fVauXGlJsu644w7jtRdddFGFvpZlWXPmzLEkWRdffLGxPC0tzZJknXPOOZbX660Qy/Dhwy1J1o4dOyqNVZIlyRozZoxVWlrqWz5v3rxK47vpppssSdb8+fON5QcOHLDatGljNWnSxMrPz69xfLXdflUmTZpkSbJ+85vfWJMmTar037nnnmtJslauXOl7XVZWlhUbG2u1bt3a2rVrl7HO119/3ZJkjR071resfGwlWc8++6xveVlZmXX55Zdbkqz4+Hhr6dKlvraioiLr7LPPtsLCwqwDBw5UWNfw4cN9y9555x1LknXfffdVeI/Z2dlWYWGhb758bJs1a2b99NNPvuXHjh2zUlNTLUnWmjVrfMvLjzlJ1sKFC41133LLLZYk64033jDibt++vdWoUSPr66+/Nvp//PHHltvttoYMGWIsL1//rbfeapWUlBhtW7dutUJDQ63u3btXOBZmzJhhSbL+8pe/VHjfAE5Nkqx27doZy+w5csKECRVe8/e//92SZKWlpRn5bM+ePVbTpk2tsLAwa/v27b7lr7zyim99y5cvN9Z16623WpKsKVOmGMvbtWtXIa7nn3/edw3Ny8sz2vLy8nw5qTY5GMCpZenSpZYkKzY21nrooYesFStWWIcOHaqyf2lpqdW5c2dLkvXBBx8YbY888oglybrtttuM5eX5qzKV5R7uw7kPL8d9+C8HBSMcl7Ng5PV6rbi4OKtly5ZWbm6uZVmVF4x2795tSbK6du1qlZWVGessKyuzzjzzTEuStXv3bt/y8gvB22+/XWksNblQRUdHW8eOHTOWFxcXW6GhoVaPHj18yzIzMy23212haFXuueeesyRZ7777bo3jq832q1N+oarJP/uF6umnn7YkWQsWLKh0vT169LAaN27smy8f2w4dOhgXVsvyfxAaOHBghfVMmTKlwraru1A9+uijx33P5WM7bdq0Cm1vvfVWhRud8mOuf//+FfqXt91///2+ZUuWLLEkWVOnTq10+9dcc40VEhJiHT161LdMkhUeHm5lZmZW6P/HP/7RkmR9/PHHFdpKS0utJk2aWOeee271bxrAKaO6glHz5s0rLa6U/0+RDRs2VGgrv2G155zygtEll1xSof9PP/1khYWFWR07djSWV/ahrWvXrpbb7ba2bdtW7XuqTQ4GcOp54oknrJiYGOO+r2PHjtZdd91V4fxfs2aNJcm67LLLKqwnJyfHSkpKsjwej5HLTkbBiPtw7sO5Dz+98JU01FpiYqIeeughPfroo3r22Wf16KOPVtrvq6++kiSlpaVV+O61y+VS//799d1332nTpk1q06aN0d67d+86x9e5c2fFxMQYy0JDQ9WsWTMdOXLEt+zzzz9XaWmpCgoKKv2R0++//16SlJGRoSFDhtQ4vppuvybeeOMN/fa3v6207c4776zwaOj69et9//3hhx8qvKagoEBZWVnKyspS48aNfcu7deumkBDzJ81atGghSZU+Bl3e9tNPP1Ubf//+/dW8eXPNmDFDX3/9ta644gr17dtXqampVf6p6n79+lW57Ouvv67Q1qNHjwrLWrduLUnG/i7fNxkZGZWO94EDB1RWVqZt27apZ8+evuXJycnGvnKu74MPPtDy5csrtIeFhSkjI6PCcgDBp1u3bpU+1v7VV1/J4/FUek0o/12PyvJWZXmuZcuW6tixozIyMnTs2DE1atSo0lhyc3P17bffqlOnTurcuXO1cdclBwM4dTzwwAO688479cEHH2jt2rXauHGjNmzYoOeff15/+9vftGjRIg0dOlSS/767st8Uio6OVs+ePfXvf/9b27ZtO6lfy+I+nPtw7sNPLxSMUCf33nuvZs+erSeeeEJ33HFHpX3Kf0itWbNmlbY3b95cknT06NEKbVW9piaq+nOSoaGhKi0t9c2X//jfp59+qk8//bTK9Tl/VO548dV0+ydD+Xt6/vnnq+2Xm5trJN/KfsMiNDT0uG3FxcXVbicuLk7r1q3TpEmT9O677+pf//qXpP9eSB555BGNGTOmwmuaNm1a6bKQkJBKj5XK9nd5fJWN92uvvVZtzM7xrmqsy9c3bdq0atcHIPhVlQeys7Mr/A+PctVd4yrLc+XbycjIUHZ2dpUFo/Ib8FatWh0v7DrlYACnlkaNGum6667TddddJ+m/OeXRRx/VCy+8oNtuu00//fSTwsPDT+i+uz5xH859OPfhpxf+ShrqxOPx6LHHHtPRo0c1ffr0SvuUJ7iff/650vby5ZUlwob4P5/l2x03bpys/349s9J/kyZNCkh8dVH+njZv3lzte2rXrl2DxVT+VzUyMzP11VdfadasWbIsS3fddZfeeOONCv0PHjxY6bKysrIqbwJqonzfvPvuu9Xum7S0NON1VY11+fqys7OrXR+A4FddHqjLNa6yPHe815Qrz4PH+z/L5WqbgwGc2uLi4jR79my1a9dOWVlZ2rx5s6S63Xe7XC6VlJRU2v9kF5a4D28Y3IfjRFEwQp2NHDlSKSkpev75540/4Vuu/BHKNWvWVDhhLcvSxx9/bPSrifK/ylYf/4egV69ecrlcvj9bejo477zzJOmUfE9ut1vnnHOOHnzwQd8F6p133qnQr/y4qGxZbY4Vp/reN+XrK38kFsAvT/fu3ZWfn6/PPvusQtvq1aslVZ63Kstz+/bt048//qiOHTtW+XSRJMXExKhr167asWOH7ysbNVHTHAzg1OdyuRQVFWUs6969uyRV+ufj8/LytHHjRnk8HnXp0sW3PCEhodLi886dOyv9+hb34dXjPrxq3IcHLwpGqDO3263p06ersLBQU6ZMqdDetm1bDRw4UFu3btX8+fONtvnz52vr1q266KKLqnycvzLlf2J07969Jxa8/vto7vXXX6+1a9fqySefrLQKvWHDBuXl5Z3wthrKrbfeqkaNGmn8+PHaunVrhfa8vLwGTaxbtmzRrl27Kiwv/79clf3p6Oeee0779u3zzefk5PiOr9///vd1jmXYsGFq27atnn76aa1Zs6ZCe3FxsT755JMar2/MmDEKDQ3V3XffrT179lRoP3LkiO/3BACcnoYPHy5JeuSRR4yvBvz00096+umnFRoaqptvvrnC65YtW6YVK1YYy/785z+ruLjYt87q3HXXXSotLdWYMWOUn59vtBUUFPge1a9LDgZwapgzZ44+//zzStuWLFmijIwMxcfH+36P6MILL1THjh31/vvvV/hNlxkzZigrK0s33nij8XtsPXv21M6dO40iU1FRke6///5Kt8t9ePW4D68a9+HBi98wwgm5+uqr1adPnyqrxS+++KL69u2rUaNG6d1331XXrl317bff6p133lGTJk304osv1mp7F110kf7yl7/ojjvu0HXXXafo6Gi1bdtWN910U53if+GFF/Sf//xHDz74oBYsWKA+ffooLi5Oe/bs0RdffKHvv/9e+/fvr/B/cU5VTZo00RtvvKHrrrtO3bp10+DBg5WSkqKCggLt2rVLq1ev1gUXXKAPPvigQeJZvny5xo0bpwsvvFApKSlKSkrS9u3b9c4778jj8Wjs2LEVXtOrVy9169ZNN9xwgyIiIrRkyRLt3LlTo0aNUv/+/escS0REhBYvXqzLLrtMaWlpuvjii303Wbt379bHH3+spKSkGv9A3q9+9Su98MILGj16tLp06aLLL79cHTt2VHZ2trZv367Vq1drxIgReumll+ocM4BT2y233KIlS5bo7bff1tlnn60hQ4YoNzdXb775prxer5566il16NChwuuuuOIKXX755bruuuvUpk0brV69WuvWrVO3bt30pz/96bjbHT16tFavXq0333xTnTt31tChQxUbG6vdu3fr3//+t/72t7/pqquuqlMOBnBqeP/993XnnXeqU6dOuvDCC9WyZUvl5OTo66+/1scff6yQkBC98MILioiIkCSFhIQoPT1dgwYN8uWXdu3aacOGDfroo4/UsWNHzZw509jGfffdpw8//FBXXHGFbrzxRkVFRWnZsmWKj4/3/bCyHffh1eM+vGrchwcvCkY4YbNmzaoygXTp0kUbN27U5MmT9cEHH+i9995TkyZNNGLECE2aNKnW3+G97LLL9MQTT2ju3LmaNWuWiouLlZaWVucLVWJiotauXavZs2dr0aJFeu2111RWVqbmzZurW7dumjBhQqW/zH8qu+KKK/TVV1/pySef1PLly7Vs2TJFR0erdevWuvXWW/W73/2uwWIZNGiQdu7cqTVr1mjJkiXKyclRq1at9Nvf/lYPPvigzjzzzAqvefbZZ/Xmm29q3rx52rt3r9q0aaNZs2Zp3LhxJxxPr169tGnTJj355JP617/+pU8++UQRERFq1aqVrrrqKt144421Wt+oUaN0zjnn+P5vyTvvvKO4uDi1bdtW9913X42eFAAQvFwulxYvXqz/+Z//0auvvqq//vWvCg8PV48ePXT//ff7/nqR07XXXqvbbrtN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MlI9e/ZUr169dO2112rFihVq1qyZ7r33XuXk5FTo37p1a/Xs2VM9evRQhw4d5HK5arSd/v3769JLL1VmZqYOHjxYq/cF07Bhw3ThhRdq0qRJKigoqNFrwsLCNGnSJEnSli1barW9kSNH6uuvv9a7775b6Y/sHc/111+vs88+u9bbxfHVZFwvueQSSdI777xjLI+Pj1fPnj3Vs2dPJSUlVbmNc889V8uXL1dBQYEGDhyo//znP/UUPezI378c5HCUI4efPsjhvxzkcEjk77qgYHSKeOSRR2RZlkaNGqWioqIK7cXFxXr33XerfH1SUpJmzpypn3/+WX/9619rvf2ff/5ZZWVlFZaXlpbq+++/V1RUlOLj42u9XphmzZqlPXv26LnnnqvQtn///kpf891330mSWrZsWatt9enTRyNHjtTVV1+tq6++usp+VW03JydHe/bsqfV2YarruPbs2VOXXnqp5s6dq48//rhO2+7Ro4dWrFihwsJCDRw4UBkZGXVaD6pH/v7lIIf/8pDDT3/k8F8OcvgvC/m7flT8G3MIiD59+ujFF1/UmDFjdO6552r06NE666yzVFxcrK+++kovv/yyfvWrX+nKK6+sch2///3v9fTTT+svf/mL7rrrLsXGxtZ4+wsWLNCcOXN00003qVevXoqLi9PevXs1b948bd26VRMnTlR4eHh9vNXTwpYtW1RSUlJheceOHav9CxkXXnihhg0bprfffrtC26BBg9S6dWtdeeWVSklJUVlZmb7++ms99dRTiomJ0T333FPrOP/2t78dt8+0adP06aef6oYbbtA555wjj8ejHTt2aPbs2fJ6vXryyScrvOaLL75QXFxcheVdu3at1XH3S3Ai4/q///u/GjRokH79619rxIgRGjRokJo2bars7Gx98803Wr58+XH39znnnKMVK1bo4osv1sCBA/XRRx/pzDPPrO+3+YtG/g4+5HByeE2Rw09/5PDgQw4nh9cE+bueBPgrcXD4+uuvreHDh1tt27a1wsPDrejoaKt79+7WxIkTrYMHD1qWVfF7lnbvvfeeJcmaPHmyZVn+708/+eST1W7322+/tcaNG2f17NnTatKkiRUaGmolJCRYaWlp1oIFC+r3TQax6v46gyRr7ty5vr7O706X+/bbby23213hu9OLFi2ybrrpJqtz585WTEyMFRYWZrVt29a6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ICgFXcGopKREY8eO1bx581RWVqbGjRsrMTFRkrRx40a9/vrrGj9+vEaNGqXZs2fL7XYHOGIAAAAAAIDgEnRfSZs+fbrS09M1depU7du3TwcPHlRGRoYyMjJ08OBB7d+/X48//rjS09M1ffr0QIcLAAAAAAAQdILuCaP09HRNmzZN48aNq7S9WbNmevjhhxUaGqrnn39eEyZMaOAIAQAAAAAAglvQPWG0b98+9erV67j9evfurQMHDjRARAAAAAAAAKeXoCsYJScna9myZcft9+GHH6p9+/YnPyAAAAAAAIDTTNB9JW3MmDG699575fV6NWLECKWmpsrj8UiSCgoKtHnzZqWnp2vOnDl69tlnAxssAAAAAABAEAq6gtHdd9+t7OxsTZs2TXPmzJEkRUREyOVyqaCgwDc/ZcoUjR07NpChAgAAAAAABKWgKxhJ0vjx4zV69Gi9//772rp1q7xeryQpKSlJqampGjx4sBISEgIcJQAAAAAAQHAKyoKRJCUmJurmm28OdBgAAAAAAACnnaD70WsAAAAAAACcXEH7hJFdXl6e5s6dq/Xr1yskJER9+vTRbbfd5vsxbAAAAAAAANRc0BWMunbtqkWLFik1NVWSdPjwYfXt21ffffedoqOjZVmW3njjDc2dO1effPKJGjVqFOCIAQAAAAAAgkvQfSUtIyND+fn5vvmJEydq165dWrx4sbKzs3Xs2DEtXLhQ33//vWbMmBHASAEAAAAAAIJT0BWMnJYuXar7779f11xzjVwul1wul66//nrdc889WrJkSaDDAwAAAAAACDpBXzDav3+/0tLSKiwfMGCAdu3aFYCIAAAAAAAAgltQFoxcLpdvukmTJpX2sSxLbre7oUICAAAAAAA4bQRlwWjgwIGKjY1VbGyssrKytGXLlgp9fvjhBzVr1iwA0QEAAAAAAAS3oPsracOHD69Rv4ULF6p79+4nORoAAAAAAIDTT9AVjF555ZUa9Xv99dcVGxt7kqMBAAAAAAA4/QRdwajc0aNHFR4eLo/H41v28ccfa8uWLWrdurUuu+wyhYYG7dsDAAAAAAAImKD7DaP8/HxdffXVSkxMVGxsrO677z5J0u233660tDTddddduuqqq9SjRw8dPnw4wNECAAAAAAAEn6B7BOcvf/mL/vnPf2rUqFGKi4vTyy+/LElavHix5s+fr169emnt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",
      "text/plain": [
       "<Figure size 1200x600 with 70 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import matplotlib.gridspec as gridspec\n",
    "import numpy as np\n",
    "import seaborn as sns\n",
    "\n",
    "# 'CRPS': CRPS(), \n",
    "#             'CRPSSpread': CRPSSpread(),\n",
    "#             'CRPSSkill': CRPSSkill(),\n",
    "#             'EnergyScore': EnergyScore()\n",
    "\n",
    "regions = ['Northern Hemisphere', 'Tropics', 'Southern Hemisphere']\n",
    "metrics = ['CRPS', 'ENS MSE', 'SIGK']\n",
    "levels = [500, 850]\n",
    "\n",
    "fig = plt.figure(figsize=(12, 6)) \n",
    "spec = gridspec.GridSpec(\n",
    "    nrows=2 + len(levels) * 2 + 2,  # 2 header rows + 2 levels for geopotential + 2 levels for temperature + 2 rows for 2m_temperature and 10m_wind speed\n",
    "    ncols=len(regions) * len(metrics), \n",
    "    figure=fig, \n",
    "    height_ratios=[-0.1, -0.1] + [1] * (len(levels) * 2) + [1, 1]  # Adjust header height ratios and add more rows\n",
    ")\n",
    "\n",
    "for region_idx, region in enumerate(regions):\n",
    "    region_start_col = region_idx * len(metrics)\n",
    "    region_end_col = region_start_col + len(metrics)\n",
    "\n",
    "    ax_region = fig.add_subplot(spec[0, region_start_col:region_end_col])\n",
    "    ax_region.set_title(region, fontsize=14) \n",
    "    ax_region.axis('off') \n",
    "\n",
    "for region_idx in range(len(regions)):\n",
    "    for metric_idx, metric in enumerate(metrics):\n",
    "        col_idx = region_idx * len(metrics) + metric_idx\n",
    "\n",
    "        ax_metric = fig.add_subplot(spec[1, col_idx])\n",
    "        ax_metric.text(0.5, 1, metric, ha='center', va='center', fontsize=12, transform=ax_metric.transAxes)\n",
    "        ax_metric.axis('off')\n",
    "\n",
    "fig.text(0.04, 0.75, 'z', ha='center', va='center', fontsize=12, rotation='vertical')\n",
    "for level_idx, level in enumerate(levels):\n",
    "    for region_idx in range(len(regions)):\n",
    "        for metric_idx in range(len(metrics)):\n",
    "            col_idx = region_idx * len(metrics) + metric_idx\n",
    "            ax = fig.add_subplot(spec[level_idx + 2, col_idx])\n",
    "            \n",
    "            if metric_idx<2:\n",
    "                geopotential_plot_data = geopotential[metric_idx, region_idx, :, level_idx]\n",
    "            else:\n",
    "                if level_idx == 0:\n",
    "                    geopotential_plot_data = percentage_diffsigkernel[0,:,region_idx]\n",
    "                else:\n",
    "                    geopotential_plot_data = percentage_diffsigkernel[1,:,region_idx]\n",
    "\n",
    "            data_for_plot = geopotential_plot_data[np.newaxis, :]\n",
    "            sns.heatmap(\n",
    "                data_for_plot,\n",
    "                cmap='RdBu_r',\n",
    "                center=0,\n",
    "                linewidths=0,\n",
    "                cbar=False,\n",
    "                xticklabels=False,\n",
    "                yticklabels=False,\n",
    "                ax=ax\n",
    "            )\n",
    "                \n",
    "    ax_label = fig.add_subplot(spec[level_idx + 2, 0])\n",
    "    ax_label.annotate(f'{level}', xy=(-0.05, 0.5), xycoords='axes fraction',\n",
    "                      ha='right', va='center', fontsize=12, rotation='vertical', annotation_clip=False)\n",
    "    ax_label.axis('off') \n",
    "\n",
    "fig.text(0.04, 0.475, 't', ha='center', va='center', fontsize=12, rotation='vertical')\n",
    "for level_idx, level in enumerate(levels):\n",
    "    for region_idx in range(len(regions)):\n",
    "        for metric_idx in range(len(metrics)):\n",
    "            col_idx = region_idx * len(metrics) + metric_idx\n",
    "            ax = fig.add_subplot(spec[level_idx + 2 + len(levels), col_idx])\n",
    "            \n",
    "            if metric_idx<2:\n",
    "                temperature_plot_data = temperature[metric_idx, region_idx, :, level_idx]\n",
    "            else:\n",
    "                if level_idx == 0:\n",
    "                    temperature_plot_data = percentage_diffsigkernel[2,:,region_idx]\n",
    "                else:\n",
    "                    temperature_plot_data = percentage_diffsigkernel[3,:,region_idx]\n",
    "\n",
    "\n",
    "            data_for_plot = temperature_plot_data[np.newaxis, :]\n",
    "            sns.heatmap(\n",
    "                data_for_plot,\n",
    "                cmap='RdBu_r',\n",
    "                center=0,\n",
    "                linewidths=0,\n",
    "                cbar=False,\n",
    "                xticklabels=False,\n",
    "                yticklabels=False,\n",
    "                ax=ax\n",
    "            )\n",
    "\n",
    "    ax_label = fig.add_subplot(spec[level_idx + 2 + len(levels), 0])\n",
    "    ax_label.annotate(f'{level}', xy=(-0.05, 0.5), xycoords='axes fraction',\n",
    "                      ha='right', va='center', fontsize=12, rotation='vertical', annotation_clip=False)\n",
    "    ax_label.axis('off') \n",
    "\n",
    "fig.text(0.04, 0.27, '2t', ha='center', va='center', fontsize=12, rotation='vertical')\n",
    "for region_idx in range(len(regions)):\n",
    "    for metric_idx in range(len(metrics)):\n",
    "        col_idx = region_idx * len(metrics) + metric_idx\n",
    "        ax = fig.add_subplot(spec[len(levels) * 2 + 2, col_idx])\n",
    "        \n",
    "        if metric_idx<2:\n",
    "            temperature_2m_plot_data = u_component_of_wind[metric_idx, region_idx, :]\n",
    "        else:\n",
    "            temperature_2m_plot_data = percentage_diffsigkernel[4,:,region_idx]\n",
    "\n",
    "        data_for_plot = temperature_2m_plot_data[np.newaxis, :]\n",
    "        sns.heatmap(\n",
    "            data_for_plot,\n",
    "            cmap='RdBu_r',\n",
    "            center=0,\n",
    "            linewidths=0,\n",
    "            cbar=False,\n",
    "            xticklabels=False,\n",
    "            yticklabels=False,\n",
    "            ax=ax\n",
    "        )\n",
    "\n",
    "fig.text(0.04, 0.125, '10ws', ha='center', va='center', fontsize=12, rotation='vertical')\n",
    "for region_idx in range(len(regions)):\n",
    "    for metric_idx in range(len(metrics)):\n",
    "        col_idx = region_idx * len(metrics) + metric_idx\n",
    "        ax = fig.add_subplot(spec[len(levels) * 2 + 3, col_idx])\n",
    "\n",
    "        if metric_idx<2:\n",
    "            wind_speed_10m_plot_data = v_component_of_wind[metric_idx, region_idx, :]\n",
    "        else:\n",
    "            wind_speed_10m_plot_data = percentage_diffsigkernel[5,:,region_idx]\n",
    "\n",
    "        data_for_plot = wind_speed_10m_plot_data[np.newaxis, :]\n",
    "        sns.heatmap(\n",
    "            data_for_plot,\n",
    "            cmap='RdBu_r',\n",
    "            center=0,\n",
    "            linewidths=0,\n",
    "            cbar=False,\n",
    "            xticklabels=False,\n",
    "            yticklabels=False,\n",
    "            ax=ax\n",
    "        )\n",
    "\n",
    "\n",
    "plt.tight_layout(rect=[0.05, 0.05, 1, 0.95]) \n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Diss",
   "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.12.7"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
