{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "2c93deb3-989e-4e54-a4d3-99efc7a85ee4",
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "from matplotlib import colors\n",
    "import numpy as np"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "5ca6633c-795e-454f-b3cb-0b8a34d453b6",
   "metadata": {},
   "outputs": [],
   "source": [
    "np.random.seed(42)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "35512475-b098-4e72-b8c7-98f7b33c186a",
   "metadata": {},
   "outputs": [],
   "source": [
    "n = 5\n",
    "T = 20"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "id": "f18c4ab9-6f65-47d0-94d6-9b63d8f7a24b",
   "metadata": {},
   "outputs": [],
   "source": [
    "num_train = int(0.20 * n * T)\n",
    "num_valid = int(0.10 * n * T)\n",
    "num_calib = int(0.35 * n * T)\n",
    "num_test  = int(0.35 * n * T)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "9b70d0d4-a6ca-4116-a0c1-0908db89fffe",
   "metadata": {},
   "source": [
    "#### Example masks"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "id": "72961793-58a8-44da-b86f-ac1825f66793",
   "metadata": {},
   "outputs": [],
   "source": [
    "mask_trans = np.repeat([1, 2, 3, 4], [num_train, num_valid, num_calib, num_test])\n",
    "\n",
    "np.random.shuffle(mask_trans)\n",
    "mask_trans = mask_trans.reshape((T, n)).T"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "id": "b28213f2-b9a1-4192-9fed-68fe7fbdc4a6",
   "metadata": {},
   "outputs": [],
   "source": [
    "mask_semi_ind_1 = np.repeat([1, 2, 3], [num_train, num_valid, num_calib])\n",
    "mask_semi_ind_2 = np.repeat(4, num_test)\n",
    "\n",
    "np.random.shuffle(mask_semi_ind_1)\n",
    "mask_semi_ind = np.concatenate([mask_semi_ind_1, mask_semi_ind_2]).reshape((T, n)).T"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "id": "d91c95dd",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "64"
      ]
     },
     "execution_count": 49,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "num_train + num_valid "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "id": "39f5f916",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "34"
      ]
     },
     "execution_count": 50,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "num_calib + num_test"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "id": "e5c65dbb-c2de-4e07-bf37-38902e21d288",
   "metadata": {},
   "outputs": [],
   "source": [
    "num_train = int((0.65*(2/3)) * n * T)\n",
    "num_valid = int((0.65*(1/3)) * n * T) + 1\n",
    "num_calib = int(0.175 * n * T)\n",
    "num_test  = int(0.175 * n * T) + 1\n",
    "\n",
    "mask_temp_trans_1 = np.repeat([1, 2], [num_train, num_valid])\n",
    "mask_temp_trans_2 = np.repeat([3, 4], [num_calib, num_test])\n",
    "\n",
    "np.random.shuffle(mask_temp_trans_1)\n",
    "np.random.shuffle(mask_temp_trans_2)\n",
    "mask_temp_trans = np.concatenate([mask_temp_trans_1, mask_temp_trans_2]).reshape((T, n)).T"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "17506a20-3c24-47e2-b46d-a9b8b7cdc493",
   "metadata": {},
   "source": [
    "#### Plot masks"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "92659633-de21-4d11-be02-5316b639ace8",
   "metadata": {},
   "source": [
    "Create discrete colormap."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 52,
   "id": "3ed0f3ac-b7df-4f06-b490-6e421a8236b4",
   "metadata": {},
   "outputs": [],
   "source": [
    "cmap = colors.ListedColormap(['tab:red', 'tab:blue', 'tab:orange', 'tab:green'])\n",
    "bounds = [0.5, 1.5, 2.5, 3.5, 4.5]\n",
    "norm = colors.BoundaryNorm(bounds, cmap.N)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "51aa7434-0417-470d-a7ce-08cb76a46cf3",
   "metadata": {},
   "source": [
    "Create legend."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 53,
   "id": "fe9888ff-635a-462b-9552-58040dec1cac",
   "metadata": {},
   "outputs": [],
   "source": [
    "fig = plt.figure()\n",
    "handles = [plt.scatter([],[], color=cmap.colors[0], marker='s', s=16, label='Training'),\n",
    "           plt.scatter([],[], color=cmap.colors[1], marker='s', s=16, label='Validation'),\n",
    "           plt.scatter([],[], color=cmap.colors[2], marker='s', s=16, label='Calibration'),\n",
    "           plt.scatter([],[], color=cmap.colors[3], marker='s', s=16, label='Test')]\n",
    "plt.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "id": "11d5380b-bd9d-45bf-9430-ee15c91b3844",
   "metadata": {},
   "outputs": [],
   "source": [
    "save_plots = True"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 55,
   "id": "3d4a4ae8-c842-4421-8fd1-187a7c490a2e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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6ekpSktLxcWLFwUAcfbsWWV6x44dxd/+9jfl/qeffioee+wx5T4Acfz48QrruX36rFmzxMMPP6xMs1qtombNmuLIkSNCCCEiIiLEhg0blOn//e9/BQBx8eJFIYQQTzzxhFi0aJEy/fjx48L2FLNaraJWrVpi37595dZx52OFECIsLEx88803QgghDh48KPz8/ERhYaEQQojXXntNvPTSS0IIIQ4dOiQCAgKExWJRHrtz504RERFR7rL27NkjAIgbN24oP5s8ebJ44403ysw3fPhwMXv2bGXsX3/9tTLt0KFDZcY+ZswY8frrrwshhOrtdC/1e3h4iIKCAuVn9erVE3Fxccr9t956S4wYMaLcxwshhL+/v/jll1+EEEKMHj1a9OvXT/z22293zRcWFiamT58uQkNDxbp16yrMo+qHR570hwoKCsKCBQvw66+/4vr163jmmWfw/PPPIzs7G8nJybBarWjcuDH8/f3h7++Pjh07wsPDo8wpvgYNGijf16pV6677FV0E5OPjo9x+/vnnCuuz0el08Pb2Vo5Q0tLSEBYWpky//fuqXL9+HQUFBYiMjLT7Mbfr1KkTgoKC8N1336G0tBRffPEFRo8eDeDWadKcnBwEBAQo6+2FF17A1atXK8zz9fWFv7+/cj85ORlxcXHK4/39/fHtt98iLS0NwK2xG41GZf5GjRpVWbO92+le6/f29rYr32q1Yvr06YiMjITBYIC/vz/MZjMyMzMBAB999BFCQ0PRq1cvhIeHIyYmBlarVclasWIFmjRpgiFDhlQ5Zqo+2DzJaQICAhATE4P8/HxcvHgRRqMRHh4eSEtLQ05OjnIrKipCaGjofS8vLy9PuXXp0kX140NCQsqcak5JSSkz3cfHp8xrZenp6cr39erVQ61atSr84GkPj6qfiqNGjcKaNWuwfft21KpVC127dgUAGI1G1K9fv8w6M5vNlV5JfOfyjEYjXn/99TIZeXl5+J//+R9l7KmpqRWO/X7cS/1qrF+/HuvXr8e///1vmM1m5OTkwM/PT3ndsn79+li2bBkuXbqE77//HnFxcWVOSy9evBheXl4YPHgwL64iBZsn/WFu3LiBGTNm4OzZs7BYLCgoKMDChQsREBCAhx56CEFBQRgwYACmTJmiHBVkZGTY9fraH2HYsGH48MMPleY+e/bsMtOjo6OxefNmmM1mXLt2DfPnz1em6XQ6vPLKK5g6dSrOnz8PIQQSExOVZtygQQMkJSVVuvxRo0Zh586dWLRoEUaOHKm87taxY0cYjUbMmDEDN2/ehBACly5duuu108pMmDABK1euxJ49e2CxWCDLMg4cOICEhARl7PPnz0dGRgbMZjP+/ve/251dFS3qr0xubi5q1qyJunXrori4GLNnz1bOJgDAV199hZSUFAgh4O/vD71eX+Y1Ty8vL3z77beQZRmDBg1CcXGxJnWRe2PzpD9MzZo1ceXKFTz77LPw8/NDo0aN8J///Ac//PADateuDQBYtWqVcrrWYDCgS5cuOHr0qJMrv2XGjBno0KEDoqKiYDKZMGDAgDLT//KXvyA4OBhGoxE9evTAiy++WGb6vHnz0LNnT/Tq1QsGgwGDBw9GdnY2AOCNN97Arl274O/vjz59+pS7fNuVsT/++KNyyhYA9Ho9tm7diitXrqBFixbw8/PDc889V+FRbnnatWuHL774AjNmzEC9evUQGhqK9957T7nidcaMGWjbti1atmwJk8mEZ599FgAgSZLdy6iIFvVXZsyYMWjVqhXCwsIQEREBb29vNGzYUJl+9OhRPProo/Dx8UHnzp3x8ssvo1+/fmUyvLy88M0330AIgeeff77CK4Gp+tAJwWuuiUidAwcOoFu3bigqKuKVp1Qt8ciTiKp07do15ZRuWloa3n33XQwaNIiNk6otNk8iqpLFYsFf/vIX+Pn5wWQyITQ0FJ988omzyyJyGp62JSIiUolHnkRERCqxeRIREanE5klERKSS0z7PU5blMv8rZbVakZ2djcDAQF7BR0RETiGEwM2bNxESElLpO385rXl+8MEHiI2NddbiiYiIKpSamlrmzTTu5LSrbe888jSbzWjUqBGWPF0TpiBtenpilgXjv5exvK+E5oF6TTNn12+AcA3eXQUAkmUZM69ddZtMd1mf1bHOAekv4caOpajTewo8Ayp+4turJPsybuxY6pB16YjMkLEhkIK02T5yhoy0VWnMrGaZhSmFyFifobwHckWcduQpSVK5b+1lCqqBrmHalOVTUwdARvvgGogO1uZJasts6e2Nll5emmTW+v3UgLtkusv6rI51SqLpra9BTSEFNb3vPI+at8bqiHXpiEzvcG94h3tXOb89PLxubR9mVq9Mm6pePuQFQ0RERCqxeRIREanE5klERKQSmycREZFKbJ5EREQqsXkSERGpxOZJRESkEpsnERGRSmyeREREKrF5EhERqcTmSUREpBKbJxERkUpsnkRERCqxeRIREanE5klERKQSmycREZFKbJ5EREQq1XDWgmVZhizLyv3c3FwAQGKW5fdPhb9/CZmWMl+1zCxqn4HCunpNMosyLcAl4MJt6+N+2bIcUefu7wy4KEmaZN6qM98hdbrLdteyzpKs1DJftcpzxLp0RKacpt1zyJbFzGqWmWFflk4IITRbqgoxMTGIjY11xqKJiIgqZTabYTAYKpzutOZZ3pGn0WjE8r4S2gdrc0CckGnByM1FWDvQCy00OlpwZOb8oGBEaHhE93ZGerWuszpmPpU2EVlbFyCwz1R4BhrvO68kKxVZWxe4/LhtmQ3HN4QUos2+KafJuLz8MjOrWWZhciHSVqVV2TyddtpWkiRI5fwCbh6oR3SwNk8omxZ13SMzQpLQ0stL08zqXGd1zPSUbzVMz0AjpKCmmmQCrj9uGylEgne4NzOZec+sRVa75uMFQ0RERCqxeRIREanE5klERKQSmycREZFKbJ5EREQqsXkSERGpxOZJRESkEpsnERGRSmyeREREKrF5EhERqcTmSUREpBKbJxERkUpsnkRERCqxeRIREanE5klERKQSmycREZFKbJ5EREQq1XDWgmVZhizLyv3c3FwAwL5tvrjurc0ngl+QZQD5SMi0aJIHQMna/Z0BFyVJk0xbnRduWx/aZMIhY3dEnY5Yn44Yu6vvSyWtU299zUrVJu/3HHdZl3KadvumLYuZ1Swzw84scQ82btwo3n//fSGEEJcvXxYnT55UnTFr1iwBgDfeeOONN95c7mY2myvtYTohhIAKM2fOxOHDh5GUlITffvsN6enpGDRoEPbv368mptwjT6PRiNn1G6Clhkeeb2ekY+1AL7Soq9ckMyHTgpGbizA/KBgRGh4pvZ2R7pBMjl3bsbv6+pzQehCyti5AYJ+p8Aw03ndeSVYqsrYucJt12XB8Q0gh2qxLOU3G5eWXmVnNMguTC5G2Kg1msxkGg6HC+VSftv32229x7NgxdOjQAQAQHByMvLw81QVKkgSpnF8Y4ZKEll5eqvMq06KuHtHB2jxJbSIcUKcjMjl2bcfu6uvT1jA9A42Qgppqkgm4z7qUQiR4h2vzxzczq2emtchq13yqLxjy9vaGXl92h1d58EpEROTWVB95hoWF4eeff4ZOp0NJSQnmzp0Lk8nkgNKIiIhck+rm+fHHH2PMmDE4deoUateuje7du2PdunWOqI2IiMglqW6eDRo0wPbt21FQUAAhBGrXru2IuoiIiFyW3c3zp59+qnR6165d77sYIiIid2B385w6dSoAwGKxID4+HhEREdDpdEhKSoLJZMKxY8ccViQREZErsftq28OHD+Pw4cMwmUzYsWMHzp8/j3PnzmHnzp2Ijo52ZI1EREQuRfW/qhw5cgRPPvmkcr9Xr144fPiwpkURERG5MtXNU6/XY8+ePcr9ffv2wcOD7y9PRETVh+qrbT/99FMMHToUnp6eEELAYrFgw4YNjqiNiIjIJaluno8++iiSkpJw9uxZAMBDDz0ET09PzQsjIiJyVff0kWTHjx/Hrl27ANx6g3fb+9wSERFVB6pfrFy+fDleeOEFXLt2DdevX8egQYOwYsUKR9RGRETkklQfeS5duhRHjx5FvXr1AADTpk1Dz549MW7cOM2LIyIickX3dJmsrXHe+T0REVF1oLp5RkZGYvr06UhJSUFKSgpmzJiByMhIR9RGRETkklQ3z7i4OCQlJSE6Ohrt27dHUlIS4uLiHFEbERGRS7qnN4afPHkyJk2aBADQ6XRISEhQffpWlmXIsqzcz83NBQC83rIfpKCmqrIqUpKVClxagIRMiyZ5AJSsovYZKKyrr2Ju+xRlWoBLwITWg+AZaNQkk2NfgN3fGXBRkjTJvCDLAPJdfn2WpKXe+pqVqk3e7znusi7lNLmKOe1ny2JmNcvMsC9LJ4QQ9szYsWPHux+s0yEtLQ3p6emwWNQ9EWJiYhAbG6vqMURERH8Es9kMg8FQ4XS7m+edsrOzMWfOHKxduxavvfYaZsyYoerx5R15Go1G1Ok9RdMjz6ytC7B2oBdaaPSXfUKmBSM3FzkkM7DPVE2Pvqr72OcHBSNCw6OltzPSXX59PpU2EVlbF2i2Pt1tXTYc3xBSiDZ1ymkyLi+/zMxqllmYXIi0VWlVNk/V/6pSVFSERYsWYcmSJRg+fDgSEhIQGBioukBJkiCV82T0DGioWfO0aVFXj+hgbZ6kjsz0DDRy7BqKkCS09PLSNNPV16enfKthar0+3WVdSiESvMO9mcnMe2Ytsto1n90XDFmtVixfvhyRkZE4e/YsDh48iIULF95T4yQiInJndh95RkVFQZZlzJ07F23btoXZbMbJkyeV6W3atHFIgURERK7G7uZZUFAAnU6HmTNn3jVNp9PhwoULmhZGRETkquxunsnJyQ4sg4iIyH3wU6yJiIhUYvMkIiJSic2TiIhIJTZPIiIildg8iYiIVGLzJCIiUonNk4iISCU2TyIiIpXYPImIiFRi8yQiIlKJzZOIiEglNk8iIiKVVH8YtlZkWYYsy8r93NxcAEBJ9mV41NTmQ3dLslIB3PqUea3YshyRaatXCxw7cOG2/et+2bJcfX3axq7V+nS3dSmnaVenLYuZ1Swzw74snRBCaLZUFWJiYhAbG+uMRRMREVXKbDbDYDBUON1pzbO8I0+j0YjlfSW0D9bmgDgh04KRm4sQ2GcqPAONmmSWZKUia+sCzA8KRoQkaZJ5QZbxdkY61g70Qou6ek0ybWN3l0xHrE9HbHdHjF3LOv+6Yx7ezkjXbH3a1qUjto8jMhuObwgpRJtMOU3G5eWXmVnNMguTC5G2Kq3K5um007aSJEEq54nTPFCP6GBtfjnZeAYaIQU11TQzQpLQ0kub08s2LepqP3Z3yXTE+nTEdnfE2LWs09aMtF6fjtg+jsiUQiR4h3szk5n3zFpktWs+XjBERESkEpsnERGRSmyeREREKrF5EhERqcTmSUREpBKbJxERkUpsnkRERCqxeRIREanE5klERKQSmycREZFKbJ5EREQqsXkSERGpxOZJRESkEpsnERGRSmyeREREKrF5EhERqcTmSUREpFINZy1YlmXIsqzcN5vNAID4jFLNlpGYZbm1rIzzsBYXaZJZkn0ZAHCmsBAFVvs+cbwqyb+vh6PppcgrFppk2sbuLpmOWJ+O2O6OGLuWdZ4pLFS+arE+bevSEdvHEZmFyYWwFmmTKWcwszpmFqbceg4JUfnzXCeqmsNBYmJiEBsb64xFExERVSopKQkREREVTnda87zzyDMnJwdhYWFISUmBn5+fJsvIzc2F0WhEamoqDAYDM5nJTCfnMZOZrp5pNpvRqFEj3LhxA/7+/hXO57TTtpIkQZKku37u5+en2UqwMRgMzGQmM10oj5nMdPVMD4/KLwniBUNEREQqsXkSERGp5DLNU5IkzJo1q9xTucxkJjOdk+kONTKTmc7IdNoFQ0RERO7KZY48iYiI3AWbJxERkUpsnkRERCqxeRIREanE5klERKQSmycREZFKbJ5EREQqsXkSERGpxOZJRESkEpsnERGRSk77SDIiqpzJZAIAFBcXIzExEa1btwYANG/eXLmNGDHCiRUSVV98b1siF5ecnAyTyYScnBxnl0JEv+NpWyI3NHbsWCxevBgAEBMTgyFDhqBv375o1qwZ+vTpg9OnT6N3795o1qwZhg0bBqvVCgC4efMmXnnlFXTq1Alt2rTB+PHjUVxc7MSRELknNk+iB8CRI0ewevVqJCYm4ubNmxg3bhw2btyIM2fOICEhAT/88AMAYOrUqejSpQsOHTqEEydOwGq1YsmSJU6unsj98DVPogfAU089hTp16gAAoqOjIUkSfH19AQDt2rXDuXPnAABbtmzBgQMHsHDhQgBAYWEh9Hq9c4omcmNsnkQPAC8vL+V7vV5/1/3S0lIAgBACmzZtQrNmzf7wGokeJDxtS1SNDBgwAPPmzVOa6Y0bN3D+/HknV0Xkftg8iaqRRYsWwdvbGyaTCW3atEHPnj2RnJzs7LKI3A7/VYWIiEglHnkSERGpxOZJRESkEpsnERGRSmyeREREKrF5EhERqcTmSUREpBKbJxERkUpsnlRt6HQ6xMfHO7sMu5lMJqxatcoh2RMnTsQ777zjkGytrVu3Do8++qizy9Dc2LFj8cYbbzi7DLpHbJ5Uho+Pj3LT6/WQJEm5/8wzzzi7PIeJiYnBgAEDnF2GQ5Q3tri4OMybN885Bak0YsQI7N+/39llEJXBN4anMvLy8pTvu3XrhgEDBrj8X8dCCFitVod/OkhJSQk8PT0duowHTWlpKfR6PXQ6nbNLIdIUjzzJbseOHUP37t0REBCApk2b4h//+IcyLSYmBn369MGECRPg5+eHxo0bY+/evdiyZQuaNm2KOnXqYPr06cr8q1atgslkwrRp0xAYGIhGjRph2bJlynQhBBYsWIAmTZogICAATz/9NC5cuKBMDw8PxwcffIBHHnkEtWrVwpkzZ7B27VpERUXB19cXjRo1wnvvvQd73n1yy5YtmDt3LrZu3aocZQO3Tqu9/PLLGDJkCAwGA+Li4nD8+HE8/vjjCAgIQL169TBs2DBkZWUpWd26dcO7776L3r17w9fXF9HR0Th16pQyfeHChWjUqBF8fX0RHh6OFStWKNOWLl0Ko9GIwMDAMuvKtn7vPHr09/fH3r17lftffPEF2rZtC4PBgLCwMKxatarSsdn+KOrfvz9mz55dJnvSpEmYMGECgFt/NMycORNNmjRBYGAg+vXrh7S0tArXp06nw9KlSxEVFYXatWsjLy8PSUlJ6Nu3L+rVq4ewsDDMmTNH+YBuAPjkk0+Usc+YMaPMKWvbvmJj2/YdO3ZE7dq18cwzzyA7OxuTJ0+Gv78/IiMjyxyp3mv9LVu2RO3atTFq1CjcuHEDL774IgwGA9q1a4ezZ88q8y9cuBCRkZHw9fVFkyZNsHTpUmWaLMt46aWXULduXfj5+SEqKgqHDx++a5mlpaUYO3YsevXqhZs3b1ZYG7kQQVSBJ554QixatEgIIUR6eroICAgQGzZsEKWlpeLUqVMiODhY7Nq1SwghxKxZs4Snp6fYtGmTKC0tFe+9954IDQ0VY8eOFXl5eeLXX38VkiSJo0ePCiGEWLlypdDr9WLatGlClmWxf/9+4evrK/bt2yeEEOJf//qXCAkJESdPnhSFhYXir3/9q2jZsqUoKSkRQggRFhYmmjVrJs6ePStKS0uFLMti27ZtIjExUVitVnH8+HFRv359sXbtWmU8AMTx48fLHeusWbNE//79y/xszJgxwtvbW2zfvl1YLBaRn58v4uPjxc8//yyKi4tFRkaG6NKlixg3blyZdRYaGiri4+NFSUmJeOWVV8QTTzwhhBAiMTFReHt7i4SEBCGEEBkZGeLEiRNCCCF2794tDAaD2L9/v5BlWUybNk3o9XqxcuXKCuvz8/MTe/bsEUII8d1334mAgACxe/duYbFYxNWrV8WxY8cqHdvrr78uhBDi66+/FpGRkco0WZZFQECA+OWXX4QQQrz11luiR48eIi0tTciyLKZOnSq6dOlS7nq0refOnTuLK1euiKKiIpGfny/CwsLEokWLhCzL4tKlS6JVq1ZixYoVQgghdu3aJfz9/cXBgweFLMvivffeEzVq1FDGvnLlStG2bVslPywsTLRt21akpKSInJwc0apVKxEZGansezNnzhStW7dW5r+X+nv16iWysrLElStXRP369UXr1q3Fzz//LEpKSsTYsWNF3759lfk3btwoUlJShNVqFT/++KPw8vJS1t1nn30moqOjxY0bN4TVahWJiYkiJSWlzDbIy8sTzzzzjBgyZIiQZbnCusi1sHlShW5vnvPnzxcDBgwoM33atGnipZdeEkLc+gX9yCOPKNN+/fVXAUCcPXtW+VnHjh3FP/7xDyHErV+IBoNBFBcXK9MnTpwoXn75ZSGEEL169RIffvihMq2oqEj4+vqK//znP0IIofwyrszrr79eprHdS/O882d3+uabb0TTpk2V+0888YR45513lPu//PKL8PHxEUIIcf78eeHl5SU2btwoCgoKyuS89NJLYtKkScr94uJiYTAY7G6eTz/9tIiNjVU1NlvzLCoqEnXq1BEHDhwQQgixefNm0aRJEyGEEFarVdSuXVvEx8crjy0sLBQeHh5KE7gTAPHNN98o97/66ithMpnKzLN8+XLRo0cPZeyvvvpqmbH7+flV2jzj4uKU+2+99dZd+55OpxOyLN9z/du3b1fuDx48WAwdOlS5/+9//1uEhoaW+1ghhOjfv7+YM2eOEEKIzz//XERGRor9+/cLi8VSZr4xY8aIESNGiE6dOok///nPd00n18bTtmSX5ORkbNu2Df7+/srt448/Rnp6ujJPgwYNlO9r1apV7s9uf001JCSkzGuIYWFhuHLlCgDg8uXLCA8PV6ZJkoSQkBBcvnxZ+VmjRo3K1Lhjxw48+uijyimyuLg4ZGZm3te471zG+fPn0b9/f4SEhMBgMGDkyJF3LSMoKEj53nbaEgCaNGmCf/3rX1i6dCkaNGiAp556Srn6Ny0tDWFhYcrjPD09ERwcbHedly5dQmRkpNrhAbi1bocMGYLVq1cDAFavXo1Ro0YBADIzM5Gfn4+uXbsq2z0oKAg1a9ZEampqhZm3r7fk5GScPn26zL4zdepUZGRkALg1dqPRqMxvz9jv3K/uvC+EQEFBwT3XX1X+7fvxunXrEB0djYCAAPj7+2Pbtm3KPjFq1CiMHTsWEydORN26dTF27Ngy+8uuXbuQlJSEd999Fx4e/HXsTri1yC5GoxHPP/88cnJylNvNmzexbdu2e85MS0tDSUmJcj8lJQWhoaEAgIYNG5b5nMni4mKkpaWhYcOGys9u/2VTXFyMgQMHYsKECbhy5QrMZjMmTpxo12ued2ZV9vOJEyciNDQUZ86cQW5uLtauXWv3MgBgyJAh2LNnD65evYq2bdsqTSokJASXLl1S5ispKSnzh4mPjw8KCgqU+/n5+cjNzVXuh4WFVfih1vb8Uh41ahQ2bNiAjIwM/PDDD0pdgYGBqFWrFg4ePFhm2xcWFlb67yO3L9NoNKJ9+/ZlHp+bm4tff/1VGfvtjay0tLTM2O/HvdZvr5SUFIwZMwbz58/HtWvXkJOTg2effVbZJ2rUqIFp06bhxIkTSEhIQEpKCmJjY5XHDx06FK+++iq6deum/OFI7oHNk+wyatQo/Pjjj9i0aRNKSkpQUlKC+Pj4ci9+sFd+fj7+/ve/o7i4GAcPHsS6deswYsQIAMDIkSOxdOlSnDlzBrIsY8aMGQgNDUWnTp3KzZJlGUVFRQgMDIQkSTh48CDWr19vdy0NGjTApUuXUFpaWul8ubm58PX1hcFgQGpqKj766CO7l5GYmIj//d//RWFhIWrWrAkfHx/UqHHrgvdhw4Zh3bp1OHjwIIqLizF79mzk5+crj42OjsaBAwdw9uxZFBUVYdq0aWWuYJ0wYQKWLFmCffv2wWq14tq1azh+/LjdY3vsscdQp04djB07Fh06dEBERASAW01w4sSJmDp1qtLgsrKysGHDBrvH3adPH1y9ehXLli1DUVERLBYLEhMTlYudhg0bhvXr1+PIkSMoKSnBnDlzyoz9fmhRf2Xy8vIghED9+vXh4eGBbdu2YefOncr0H3/8EfHx8SgtLUXt2rXh5eWlbHOb2NhYjBgxAt26dav0aJhcC5sn2SU0NBQ7duzAZ599huDgYDRo0ACvvvpqmaMftaKiolBaWorg4GC88MILeP/999G9e3cAwOjRo/HnP/8Zffr0QVBQEE6cOIHvv//+rl88Nr6+vvj0008xfvx4GAwGvP/++3jxxRftrmXw4MEwGAyoV68e/P39K5xv4cKF2Lp1KwwGA/r3749BgwbZvYzi4mK89957aNCgAQIDA/Hjjz8qV5T26tULf//73zFo0CAEBwfDarUiKipKeWyPHj0wYcIEPProo2jatClat24NX19fZfqAAQOwcOFCvPrqq/Dz80PHjh2Vq3ztHduoUaOwY8cOjB49uszPP/jgA3Tu3Bk9evSAr68v2rdvX6ZBVMXHxwe7du3C7t27ER4ejsDAQAwfPlw5bdurVy/MmjULAwYMQFBQEEpLS9GsWTNIkmT3Mipzv/VXpmXLlpg+fTp69OiBwMBAbNiwAf369VOmX716FcOGDYO/vz8aN24MPz8/zJo1666cmTNn4k9/+hO6detW5gwEuS6dUHPOiUgjq1atwuLFi93qHX/oj1FcXIzAwEBs374djz32mLPLISoXjzyJyOk2b96MwsJC5Ofn45133kFgYCA6duzo7LKIKsTmSUROt2bNGgQHByMkJATHjh3Dd999h5o1azq7LKIK8bQtERGRSjzyJCIiUonNk4iISCWnfaqKLMuQZVm5b7VakZ2djcDAQH4CAxEROYUQAjdv3kRISEilbzDitOb5wQcflHmnDSIiIleRmppa5h3N7uS0C4buPPI0m81o1KgR/HuOR836EZosoyT7Mm7sWIrZ9RsgXKN/uE6WZcy8dtVtMuv0ngLPgIp3ADUcuT6rc51aZk7ZvUjTfcnd9s2QsSGQgrSpU86QkbYqzSGZy/tKaB6ozefPJmZZMP57uVqPXcvM+IxSvL69GDk5OfDz86twPqcdeUqSVO47iNSsHwHvRlHlPEI9j5peAICW3t5o6eWlSWat3w/j3SVTCmoKKaipJpmOXJ/VuU4tM1t6eytftRi7u+2b3uHe8A731ibTy8Nhme2DayA6WJtf9j41dQDkaj12LTNvKa7y5UNeMERERKQSmycREZFKbJ5EREQqsXkSERGpxOZJRESkEpsnERGRSmyeREREKrF5EhERqcTmSUREpBKbJxERkUpsnkRERCqxeRIREanE5klERKQSmycREZFKbJ5EREQqsXkSERGpxOZJRESkUg1nLViWZciyrNzPzc0FAJRkX1Y+Ff5+lWSlAgAu3Lac+2XLcpdM2zrQgiPXZ3WuU8tMrfcld9s35TTt6rRlOSIzIdOiWaYtqzqPXcvMxCz7snRCCKHZUlWIiYlBbGysMxZNRERUKbPZDIPBUOF0pzXP8o48jUYjZtdvgJbe3pos44Is4+2MdMwPCkaEJDGTmfedGdhnKjwDjZpklmSlImvrApceu7ttn4bjG0IK0SZTTpNxefllh2SuHeiFFnX1mmQmZFowcnORQzKr4/o8ml6K8d/LVTZPp522lSQJUjlPnHBJQksvbU7b2kQwk5ka8Qw0QgpqqmmmO4zdHWoEAClEgne4Nn98OzKzRV09ooO1+WXvyMzquD7ziu07nuQFQ0RERCqxeRIREanE5klERKQSmycREZFKbJ5EREQqsXkSERGpxOZJRESkEpsnERGRSmyeREREKrF5EhERqcTmSUREpBKbJxERkUpsnkRERCqxeRIREanE5klERKQSmycREZFKbJ5EREQq1XDWgmVZhizLyv3c3FwAQLIso5aHNj39wu/5F25bDjOZeT+ZJVmpmmXaslx57O62feQ07TJtWY7ITMi0aJZpy3JEZnVcn4lZdmaJe7Bx40bx/vvvCyGEuHz5sjh58qTqjFmzZgkAvPHGG2+88eZyN7PZXGkP0wkhBFSYOXMmDh8+jKSkJPz2229IT0/HoEGDsH//fjUx5R55Go1G1Ok9BVJQU1VZFSnJSkXW1gUI7DMVnoFGTTPnBwUjQpI0ybwgy3g7I90hdbrL2JmpTeaE1oM03e6O3I8ckbl2oBda1NVrkpmQacHIzUUOyWw4viGkEG22uZwm4/Lyy24zdldfn4XJhUhblQaz2QyDwVDhfKpP23777bc4duwYOnToAAAIDg5GXl6e6gIlSYJUzi8Mz4CGmjVPJTPQqHlmhCShpZeXppmOqNNdxs5MbTJtzUjr7e4u+2aLunpEB2vzi9mRmVKIBO9wb00z3WXsrr4+rUVWu+ZT/eKit7c39PqyA1d58EpEROTWVB95hoWF4eeff4ZOp0NJSQnmzp0Lk8nkgNKIiIhck+rm+fHHH2PMmDE4deoUateuje7du2PdunWOqI2IiMglqW6eDRo0wPbt21FQUAAhBGrXru2IuoiIiFyW3c3zp59+qnR6165d77sYIiIid2B385w6dSoAwGKxID4+HhEREdDpdEhKSoLJZMKxY8ccViQREZErsftq28OHD+Pw4cMwmUzYsWMHzp8/j3PnzmHnzp2Ijo52ZI1EREQuRfW/qhw5cgRPPvmkcr9Xr144fPiwpkURERG5MtXNU6/XY8+ePcr9ffv2wUOj96IlIiJyB6qvtv30008xdOhQeHp6QggBi8WCDRs2OKI2IiIil6S6eT766KNISkrC2bNnAQAPPfQQPD09NS+MiIjIVd3TR5IdP34cu3btAnDrDd5t73NLRERUHah+sXL58uV44YUXcO3aNVy/fh2DBg3CihUrHFEbERGRS1J95Ll06VIcPXoU9erVAwBMmzYNPXv2xLhx4zQvjoiIyBXd02WytsZ55/dERETVgermGRkZienTpyMlJQUpKSmYMWMGIiMjHVEbERGRS1LdPOPi4pCUlITo6Gi0b98eSUlJiIuLc0RtRERELume3hh+8uTJmDRpEgBAp9MhISFB9elbWZYhy7JyPzc3FwBQkn0ZHjW9VGVVpCQrtcxXLTMv3Fb7/bJlOaJOdxk7M7Wh9XZ35H7kiMyETItmmbYsR2TKadptc1uWu4zd5ddnhn1ZOiGEsGfGjh073v1gnQ5paWlIT0+HxaJuhcTExCA2NlbVY4iIiP4IZrMZBoOhwul2N887ZWdnY86cOVi7di1ee+01zJgxQ9XjyzvyNBqNmF2/AVp6e99LSXe5IMt4OyMd84OCESFJLp8Z2GcqPAONmmSWZKUia+sCh2S6y/qsjtvorzvmaTp2d9s+Dcc3hBSiTaacJuPy8ssOyVw70Ast6uo1yUzItGDk5iKHZLrL2LWsszC5EGmr0qpsnqr/VaWoqAiLFi3CkiVLMHz4cCQkJCAwMFB1gZIkQSrniRMuSWjppc1pW5sIN8n0DDRCCmrq8pnusj6r4zayNSOtx+4u20cKkeAdrs0f347MbFFXj+hgbRqIIzPdZexa1mktsto1n90XDFmtVixfvhyRkZE4e/YsDh48iIULF95T4yQiInJndh95RkVFQZZlzJ07F23btoXZbMbJkyeV6W3atHFIgURERK7G7uZZUFAAnU6HmTNn3jVNp9PhwoULmhZGRETkquxunsnJyQ4sg4iIyH3wU6yJiIhUYvMkIiJSic2TiIhIJTZPIiIildg8iYiIVGLzJCIiUonNk4iISCU2TyIiIpXYPImIiFRi8yQiIlKJzZOIiEglNk8iIiKV2DyJiIhUsvtTVbQmyzJkWVbu5+bmAgCSZRm1PLTp6Rd+z79w23JcObMkK1WzTFuWIzLdZX1Wx22k9djdbfvIadpl2rIckZmQadEs05bliEx3GbumdWbYl6UTQgjNlqpCTEwMYmNjnbFoIiKiSpnNZhgMhgqnO615lnfkaTQaUaf3FEhBTTVZRklWKrK2LkBgn6nwDDRqmjk/KBgRkqRJ5gVZxtsZ6cxk5n2b0HqQpvu8I/d3Rzwv1w70Qou6ek0yEzItGLm5CA3HN4QUos3Y5TQZl5dfdkimI8ZeHddnYXIh0lalVdk8nXbaVpIkSOU8GT0DGmrWPJXMQKPmmRGShJZeXsxkpktl2pqR1vu8I8btiOdli7p6RAdr88veRgqR4B3u7fKZjhh7dVyf1iKrXfPxgiEiIiKV2DyJiIhUYvMkIiJSic2TiIhIJTZPIiIildg8iYiIVGLzJCIiUonNk4iISCU2TyIiIpXYPImIiFRi8yQiIlKJzZOIiEglNk8iIiKV2DyJiIhUYvMkIiJSic2TiIhIJTZPIiIilWo4a8GyLEOWZeW+2WwGABRfu6DZMkqyL99aVsZ5WIuLNM08U1iIAqt9nzheleTf1wMzmXm/5Izzylct9nlH7u+OeF4eTS9FXrHQJDMxywIAKEwuhLVIq+0jOyzTEWOvjuuzMKUQACBE5ePWiarmcJCYmBjExsY6Y9FERESVSkpKQkRERIXTndY87zzyzMnJQVhYGFJSUuDn56fJMnJzc2E0GpGamgqDwcBMZjLTyXnMZKarZ5rNZjRq1Ag3btyAv79/hfM57bStJEmQJOmun/v5+Wm2EmwMBgMzmclMF8pjJjNdPdPDo/JLgnjBEBERkUpsnkRERCq5TPOUJAmzZs0q91QuM5nJTOdkukONzGSmMzKddsEQERGRu3KZI08iIiJ3weZJRESkEpsnERGRSmyeREREKrF5EhERqcTmSUREpBKbJxERkUpsnkRERCqxeRIREanktE9VIaLKmUwmAEBxcTESExPRunVrAEDz5s2V24gRI5xYIVH1xbfnI3JxycnJMJlMyMnJcXYpRPQ7nrYlckNjx47F4sWLAQAxMTEYMmQI+vbti2bNmqFPnz44ffo0evfujWbNmmHYsGGwWq0AgJs3b+KVV15Bp06d0KZNG4wfPx7FxcVOHAmRe2LzJHoAHDlyBKtXr0ZiYiJu3ryJcePGYePGjThz5gwSEhLwww8/AACmTp2KLl264NChQzhx4gSsViuWLFni5OqJ3A9f8yR6ADz11FOoU6cOACA6OhqSJMHX1xcA0K5dO5w7dw4AsGXLFhw4cAALFy4EABQWFkKv1zunaCI3xuZJ9ADw8vJSvtfr9XfdLy0tBQAIIbBp0yY0a9bsD6+R6EHC07ZE1ciAAQMwb948pZneuHED58+fd3JVRO6HzZOoGlm0aBG8vb1hMpnQpk0b9OzZE8nJyc4ui8jt8F9ViIiIVOKRJxERkUpsnkRERCqxeRIREanE5klERKRStfg/TyEESktLYbFYnF0KEdEDz9PT84F/840HvnkWFxcjPT0dBQUFzi6FiKha0Ol0aNiwIXx8fJxdisM80P+qYrVace7cOej1etSrVw81a9aETqdzdllERA8sIQSuX7+OgoICREZGPrBHoA/0kWdxcTGsViuMRiNq1arl7HKIiKqFevXqITk5GSUlJQ9s86wWFwx5eFSLYRIRuYTqcIaPXYWIiEglNs9yFCcno/DXX++6FdvxHqAmkwkmkwktW7aEXq9X7r/44ot2L/+7777DX/7ylyrnS0tLQ5cuXezOdTUXM/Nx+or5rtvFzPwqH/vss89i6dKld/28bdu22Lx5c7mPWbVqFQYMGADg1udfVrRN8vLy7PrLOScnBx9++GGZn40bNw579uyp8rEuKysJSIu/+5aVZNfDS0tLERsbi4ceeghRUVEwmUwYP348cnJyKnxMRdslOTkZ/v7+9z6W22zZsgX//e9/lfuVbX93cCn3Es5knbnrdin3UpWP1eJ3FADs3bsX27dvv9chuL0H+oKhoqIiXLx4EY0bNy7zEU2VKU5ORtLTz1Q4vcn2H1AzPLzKnOTkZJhMpnJ/aZSWlqJGjQf65eYqXczMR/f/t7fC6Xve7IbGdWtXOH3Tpk2YO3cujh49qvzsyJEjePbZZ3HlyhV4enre9ZhVq1Zhy5Yt2LJlS6W15eXlwdfXF1U9NSrbxm4pKwn4JLri6X8+BgQ2qTRizJgxyM7OxurVq1GnTh0IIbBx40a0b98eERER5T6mou2iZv1W9ZwaO3YsTCYT3njjjSqzXN2l3Evo802fCqdvfX4rwgxhVebc7/4bExODnJwcLF68+K5p9/K7193wyPMOlvzKj3qqml6R8PBwvPPOO+jUqRPGjBmDjIwMdO/eHe3bt0erVq0wZcoUWK1WAGX/Et+7dy+ioqIwefJktG3bFq1atcKRI0cA3P2XuU6nw9y5c9GpUyc0btwYK1euVKbt378fJpMJrVu3xksvvYS2bdti79699zQWLeTLpfc1vV+/fkhNTcXJkyeVn33++efo168fnnrqqXLX6+327t0Lk8mk3P/ss88QGRmJdu3aYdGiRWXmHTFiBDp06IA2bdrgueeeQ0ZGBgBg4sSJuHnzJkwmEzp06AAA6Natm9IErl27hoEDB6J169aIiorCZ599pmSGh4dj5syZ6Ny5Mxo3bow5c+ZUOt4/hHzzvqafP38eX3/9NVauXKl8MLdOp8PgwYNRq1atCvf32925XQDgzTffRJs2bdCqVSvs2rULwP/t+++88w6io6OxdOlS7N69G507d0a7du3QqlUr/POf/wQAbNu2Dd999x0++ugjmEwmrFix4q7lrFmzBm3atFG28ZUrVwDcei726tULw4YNQ+vWrdGhQwdcuHCh8vXkYPkllf8Oqmp6RXbs2IHHH38c7du3R6dOnZQzKOfOncNjjz2Gtm3bonXr1pgxYwbi4+MRFxeHdevWwWQyYfbs2fe0THdWvQ9//mBZWVk4ePAgdDodioqK8P3338PHxwcWiwX9+/fHV199haFDh971uLNnz+Kf//wnli1bhri4OEyfPh07duwodxmSJOHQoUM4e/YsOnbsiFGjRsFqteLFF1/E6tWr0b17d+zZs6dMY3VHnp6eGDVqFD7//HMsXrwYRUVF+OKLL7B//34YjUa71qvN6dOnMWvWLBw/fhzBwcGYNm1amemLFy9GvXr1AAAffvghYmJiEBcXh7i4OJhMJsTHx5eb++c//xnNmzfH5s2bce3aNbRv3x5t27bFI488AuDWad8DBw4gMzMTTZo0wZ/+9CeEhoZqs4Kc4NixY4iMjETdunXvmubv72/3/n47s9mMFi1a4P/9v/+H//73v+jXrx+SkpKUaa1atcK8efMA3Pps0l9++QV6vR7Z2dlo164devfujWeffRb9+vUrc+R5+x+Op0+fxltvvYWjR48iNDQU77//PsaNG4cffvgBAHD48GHEx8ejcePG+Nvf/oZ58+aV+UPoQXDhwgXExMRgx44dMBgMOH/+PLp06YLk5GQsXboUffr0wbvvvgsAyM7ORkBAACZOnFjhkWd1wCPPP9DYsWOV19KsViveeecdtG3bFu3atcORI0cq/CXctGlTPPzwwwCAzp07K788yjNixAgAwEMPPYQaNWogIyMDZ8+eRY0aNdC9e3cAQPfu3dGkSeWn39zByy+/jHXr1qG4uBibN29GixYtEBYWZvd6tfnxxx/xzDPPIDg4GAAwadKkMtPXr1+PDh06ICoqCitWrKgyz2bXrl2YMGECAKB+/foYOHCgcuQEAMOHDwcA1K1bFxEREbh48aKdI3c/avb329WoUQNjx44FADzyyCMICQnB8ePHAdz6A2rkyJHKvFlZWRg8eDCioqLQo0cPZGVl4fTp01UuY8+ePXj66aeVP1wmT56MH3/8UXlHMtvZAdv3lT3/3NX27dtx/vx5dO3aFSaTCS+88AI8PDyQkpKCrl274h//+AemT5+OnTt3avY6tLtj8/wD3f5uGwsXLsS1a9dw8OBBnDx5EsOHD0dRUVG5j7v9NQO9Xo/S0opPado774NwKXnLli3RtGlTfP/99/j888/x8ssvq1qvFbl93fzyyy/4+OOPsW3bNpw+fRoLFy5UnVdeLqBuu7qD6OhonDt3DllZWXdN02K72NjWY61atcr8G9rEiRPx+OOP49SpU4iPj0ezZs3uaRkP+nYqjxACTz75JOLj45XblStXEBkZiUGDBuE///kPmjdvrhyFEpun09y4cQNBQUHw8vJCRkYGvv76a4ctq3nz5igpKcG+ffsAAPv27cP58+cdtrw/0ssvv4y5c+fi0KFDePHFF+9pvfbo0QPbt29XXsuMi4tTpt24cQO+vr4IDAxEcXFxmdN1BoMBhYWFKC4uLje3V69e+Mc//gEAuH79OjZv3ownn3zyfobr0po2bYpBgwbh5ZdfVi5CEUJg06ZNOHr06D3t76WlpVizZg0A4NChQ0hLS7vrNVGbGzduICwsDDqdDj/99BNOnDihTDMYDDCbzeU+rnv37ti+fTvS0tIA3Nr+PXv2fGD/ub88vXv3xq5du8pcQ3Do0CEAt17zbNCgAUaPHo358+crVy1Xtk6rA77meQd97Yqv8LRnur1ef/11vPDCC2jVqhVCQkLQq1cvTXLLI0kSvvzyS7z66quwWq1o3749mjdv7tTTL7Wlyne9qqbbvPjii3jjjTfw4osvwsfH557Wa1RUFGJiYtClSxf4+Phg4MCByrSnn34aa9euRfPmzREYGIhevXopF5MEBARg9OjRaNOmDXx8fJQLuWw+/vhjTJo0Ca1bt4YQAtOnT1dOv7skyff+puPWRVtz5szBww8/jBo1asBqtaJr165YsmTJPe3vfn5+OH36NNq2bYvS0lKsX78evr6+5R7dfvjhh5g8eTL+/ve/w2QylVnXo0aNwtixY7Flyxa8+uqraNq0qTItKioKH330EZ5++mkAgNFoVP7ocUW1PSv/HVTV9PI0bdoU69evx4QJE1BQUIDi4mK0a9cO69evx8aNG7F27VrUrFkTVqtV+ePy+eefx5o1a2AymTBw4EDMnDnznsbjrvivKuUoTk4u96pafe3adv2biiu6efMmfH1v/fI7fPiwcuGFM9+28GJmfrlX1daWalT6byrkQFlJ5V9VK/lW+W8q9Me5lHup3Ktqa3vWtuvfVBytOvyrCo88y+GuDbIymzZtwqJFiyCEQI0aNbBmzRqnv98vG6QLYoN0C67QIKs7HnkSEZGmqsPv3mpxwVB5/4xNRESO8QAfkyke6NO2NWvWhIeHB9LS0vh5nkREfwDb53nqdLpy3ybzQfFAn7YFbn2mZ3p6OgoKCpxdChFRtaDT6dCwYcMy/9v+oHngmydw6y+h0tJS5R1DiIjIcTw9PR/4/5OtFs2TiIhIS9XigiEiIiItsXkSERGpxOZJRESk0v8H9EeaDIIog6IAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 540x540 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, axs = plt.subplots(3, 1, figsize=(5.4, 5.4))\n",
    "\n",
    "axs[0].imshow(mask_trans, cmap=cmap, norm=norm)\n",
    "axs[1].imshow(mask_semi_ind, cmap=cmap, norm=norm)\n",
    "axs[2].imshow(mask_temp_trans, cmap=cmap, norm=norm)\n",
    "\n",
    "for t in range(3):\n",
    "    axs[t].grid(which='major', axis='both', linestyle='-', color='k', linewidth=1)\n",
    "    axs[t].set_xticks(np.arange(-0.5, T, 1)); axs[t].set_yticks(np.arange(-0.5, n, 1))\n",
    "    axs[t].set_xticklabels([]); axs[t].set_yticklabels([])\n",
    "    axs[t].set_xlabel('Time', fontsize=8)\n",
    "    axs[t].set_ylabel('Node', fontsize=8)\n",
    "\n",
    "axs[0].set_title('Transductive regime mask', fontsize=9)\n",
    "axs[1].set_title('Semi-inductive regime mask', fontsize=9)\n",
    "axs[2].set_title('Temporal transductive regime mask', fontsize=9)\n",
    "\n",
    "fig.legend(handles=handles, loc='lower center', ncol=4, fancybox=True, fontsize=8, handletextpad=0.1)\n",
    "plt.subplots_adjust(bottom = 0.07)\n",
    "\n",
    "plt.show\n",
    "\n",
    "if save_plots:\n",
    "    fig.savefig('Mask_Visualisation.pdf', bbox_inches=\"tight\")"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.10.2"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
