{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import numpy as np\n",
    "import pickle\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "from glob import glob\n",
    "from sklearn import metrics\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "# set figure size\n",
    "plt.rcParams['figure.figsize'] = (4, 3)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "traffic 405 486 h3 ARIMA\n",
      "traffic 900 963 h1 ARIMA\n",
      "exchangereturns 0 8 h1 Prophet\n",
      "traffic 896 928 h1 Prophet\n",
      "electricity 289 290 h1 ARIMA\n",
      "electricity 343 344 h1 ARIMA\n",
      "electricity 254 255 h1 ARIMA\n",
      "electricity 37 74 h1 Prophet\n",
      "electricity 298 299 h1 ARIMA\n",
      "electricity 0 50 h1 ARIMA\n",
      "traffic 480 512 h1 Prophet\n",
      "electricity 263 264 h1 ARIMA\n",
      "synthetic 0 5 h1 ARIMA\n",
      "traffic 567 648 h3 ARIMA\n",
      "traffic 81 162 h3 ARIMA\n",
      "electricity 270 271 h1 ARIMA\n",
      "electricity 100 150 h1 ARIMA\n",
      "electricity 297 298 h1 ARIMA\n",
      "electricity 256 257 h1 ARIMA\n",
      "electricity 328 329 h1 ARIMA\n",
      "traffic 324 405 h3 ARIMA\n",
      "electricity 301 302 h1 ARIMA\n",
      "traffic 0 963 h1 SAMoSSA\n",
      "electricity 260 261 h1 ARIMA\n",
      "electricity 270 300 h2 ARIMA\n",
      "electricity 339 340 h1 ARIMA\n",
      "traffic 352 384 h1 Prophet\n",
      "electricity 345 346 h1 ARIMA\n",
      "traffic 0 81 h2 ARIMA\n",
      "exchangestd 0 8 h1 SAMoSSA\n",
      "traffic 891 963 h3 ARIMA\n",
      "traffic 0 963 h1 mSSA\n",
      "electricity 294 295 h1 ARIMA\n",
      "electricity 259 296 h1 Prophet\n",
      "electricity 148 185 h1 Prophet\n",
      "traffic 384 416 h1 Prophet\n",
      "traffic 243 324 h2 ARIMA\n",
      "electricity 292 293 h1 ARIMA\n",
      "electricity 250 251 h1 ARIMA\n",
      "electricity 222 259 h1 Prophet\n",
      "electricity 311 312 h1 ARIMA\n",
      "electricity 150 180 h2 ARIMA\n",
      "traffic 500 600 h1 ARIMA\n",
      "synthetic 4 6 h1 Prophet\n",
      "electricity 60 90 h2 ARIMA\n",
      "traffic 736 768 h1 Prophet\n",
      "electricity 326 327 h1 ARIMA\n",
      "electricity 305 306 h1 ARIMA\n",
      "electricity 276 277 h1 ARIMA\n",
      "electricity 303 304 h1 ARIMA\n",
      "electricity 30 60 h3 ARIMA\n",
      "electricity 309 310 h1 ARIMA\n",
      "electricity 300 301 h1 ARIMA\n",
      "exchange 0 8 h1 SAMoSSA\n",
      "exchange 0 8 h1 Prophet\n",
      "electricity 325 326 h1 ARIMA\n",
      "electricity 273 274 h1 ARIMA\n",
      "traffic 810 891 h2 ARIMA\n",
      "electricity 293 294 h1 ARIMA\n",
      "synthetic 14 16 h1 Prophet\n",
      "electricity 310 311 h1 ARIMA\n",
      "electricity 150 180 h3 ARIMA\n",
      "traffic 224 256 h1 Prophet\n",
      "electricity 0 30 h3 ARIMA\n",
      "electricity 315 316 h1 ARIMA\n",
      "synthetic 6 8 h1 Prophet\n",
      "traffic 800 900 h1 ARIMA\n",
      "electricity 267 268 h1 ARIMA\n",
      "electricity 30 60 h2 ARIMA\n",
      "traffic 928 960 h1 Prophet\n",
      "electricity 306 307 h1 ARIMA\n",
      "electricity 330 331 h1 ARIMA\n",
      "traffic 100 200 h1 ARIMA\n",
      "electricity 185 222 h1 Prophet\n",
      "exchangereturns 0 8 h1 SAMoSSA\n",
      "synthetic 16 18 h1 Prophet\n",
      "electricity 270 300 h3 ARIMA\n",
      "synthetic 20 22 h1 Prophet\n",
      "electricity 287 288 h1 ARIMA\n",
      "electricity 346 347 h1 ARIMA\n",
      "traffic 200 300 h1 ARIMA\n",
      "electricity 302 303 h1 ARIMA\n",
      "exchangestd 0 8 h1 ARIMA\n",
      "electricity 284 285 h1 ARIMA\n",
      "electricity 330 360 h2 ARIMA\n",
      "traffic 405 486 h2 ARIMA\n",
      "electricity 319 320 h1 ARIMA\n",
      "traffic 0 32 h1 Prophet\n",
      "electricity 348 349 h1 ARIMA\n",
      "electricity 120 150 h2 ARIMA\n",
      "electricity 257 258 h1 ARIMA\n",
      "electricity 0 30 h2 ARIMA\n",
      "traffic 640 672 h1 Prophet\n",
      "traffic 891 963 h2 ARIMA\n",
      "traffic 704 736 h1 Prophet\n",
      "electricity 304 305 h1 ARIMA\n",
      "electricity 333 370 h1 Prophet\n",
      "electricity 299 300 h1 ARIMA\n",
      "synthetic 22 24 h1 Prophet\n",
      "electricity 360 370 h2 ARIMA\n",
      "exchangestd 0 8 h1 Prophet\n",
      "electricity 266 267 h1 ARIMA\n",
      "electricity 111 148 h1 Prophet\n",
      "electricity 324 325 h1 ARIMA\n",
      "electricity 286 287 h1 ARIMA\n",
      "electricity 261 262 h1 ARIMA\n",
      "traffic 32 64 h1 Prophet\n",
      "electricity 50 100 h1 ARIMA\n",
      "traffic 256 288 h1 Prophet\n",
      "traffic 512 544 h1 Prophet\n",
      "electricity 255 256 h1 ARIMA\n",
      "synthetic 0 25 h1 mSSA\n",
      "electricity 269 270 h1 ARIMA\n",
      "electricity 265 266 h1 ARIMA\n",
      "synthetic 10 12 h1 Prophet\n",
      "traffic 416 448 h1 Prophet\n",
      "electricity 300 330 h3 ARIMA\n",
      "traffic 128 160 h1 Prophet\n",
      "electricity 327 328 h1 ARIMA\n",
      "traffic 320 352 h1 Prophet\n",
      "electricity 277 278 h1 ARIMA\n",
      "electricity 308 309 h1 ARIMA\n",
      "electricity 251 252 h1 ARIMA\n",
      "traffic 810 891 h3 ARIMA\n",
      "traffic 162 243 h3 ARIMA\n",
      "traffic 576 608 h1 Prophet\n",
      "electricity 338 339 h1 ARIMA\n",
      "traffic 864 896 h1 Prophet\n",
      "traffic 729 810 h3 ARIMA\n",
      "electricity 334 335 h1 ARIMA\n",
      "traffic 608 640 h1 Prophet\n",
      "electricity 0 37 h1 Prophet\n",
      "traffic 832 864 h1 Prophet\n",
      "traffic 544 576 h1 Prophet\n",
      "traffic 162 243 h2 ARIMA\n",
      "electricity 252 253 h1 ARIMA\n",
      "electricity 74 111 h1 Prophet\n",
      "electricity 210 240 h3 ARIMA\n",
      "electricity 312 313 h1 ARIMA\n",
      "synthetic 0 25 h1 SAMoSSA\n",
      "electricity 278 279 h1 ARIMA\n",
      "traffic 81 162 h2 ARIMA\n",
      "traffic 648 729 h3 ARIMA\n",
      "electricity 335 336 h1 ARIMA\n",
      "traffic 600 700 h1 ARIMA\n",
      "electricity 337 338 h1 ARIMA\n",
      "electricity 291 292 h1 ARIMA\n",
      "electricity 0 370 h1 SAMoSSA\n",
      "traffic 486 567 h2 ARIMA\n",
      "traffic 0 100 h1 ARIMA\n",
      "traffic 288 320 h1 Prophet\n",
      "traffic 64 96 h1 Prophet\n",
      "electricity 274 275 h1 ARIMA\n",
      "synthetic 0 25 h2 ARIMA\n",
      "traffic 243 324 h3 ARIMA\n",
      "electricity 296 297 h1 ARIMA\n",
      "electricity 300 330 h2 ARIMA\n",
      "traffic 300 400 h1 ARIMA\n",
      "electricity 329 330 h1 ARIMA\n",
      "traffic 800 832 h1 Prophet\n",
      "electricity 150 200 h1 ARIMA\n",
      "electricity 322 323 h1 ARIMA\n",
      "traffic 400 500 h1 ARIMA\n",
      "traffic 768 800 h1 Prophet\n",
      "electricity 275 276 h1 ARIMA\n",
      "electricity 279 280 h1 ARIMA\n",
      "electricity 282 283 h1 ARIMA\n",
      "electricity 318 319 h1 ARIMA\n",
      "electricity 344 345 h1 ARIMA\n",
      "electricity 350 370 h1 ARIMA\n",
      "synthetic 15 20 h1 ARIMA\n",
      "synthetic 2 4 h1 Prophet\n",
      "electricity 200 250 h1 ARIMA\n",
      "electricity 0 370 h1 mSSA\n",
      "synthetic 12 14 h1 Prophet\n",
      "electricity 180 210 h2 ARIMA\n",
      "electricity 341 342 h1 ARIMA\n",
      "synthetic 0 2 h1 Prophet\n",
      "electricity 259 260 h1 ARIMA\n",
      "synthetic 18 20 h1 Prophet\n",
      "synthetic 8 10 h1 Prophet\n",
      "electricity 296 333 h1 Prophet\n",
      "electricity 316 317 h1 ARIMA\n",
      "electricity 336 337 h1 ARIMA\n",
      "exchangereturns 0 8 h1 ARIMA\n",
      "electricity 285 286 h1 ARIMA\n",
      "synthetic 5 10 h1 ARIMA\n",
      "electricity 307 308 h1 ARIMA\n",
      "synthetic 20 25 h1 ARIMA\n",
      "electricity 264 265 h1 ARIMA\n",
      "electricity 331 332 h1 ARIMA\n",
      "electricity 272 273 h1 ARIMA\n",
      "electricity 90 120 h3 ARIMA\n",
      "electricity 349 350 h1 ARIMA\n",
      "synthetic 10 15 h1 ARIMA\n",
      "electricity 281 282 h1 ARIMA\n",
      "traffic 567 648 h2 ARIMA\n",
      "electricity 180 210 h3 ARIMA\n",
      "electricity 283 284 h1 ARIMA\n",
      "traffic 729 810 h2 ARIMA\n",
      "traffic 700 800 h1 ARIMA\n",
      "electricity 332 333 h1 ARIMA\n",
      "electricity 340 341 h1 ARIMA\n",
      "electricity 360 370 h3 ARIMA\n",
      "electricity 333 334 h1 ARIMA\n",
      "electricity 323 324 h1 ARIMA\n",
      "traffic 192 224 h1 Prophet\n",
      "electricity 240 270 h3 ARIMA\n",
      "electricity 342 343 h1 ARIMA\n",
      "synthetic 0 25 h3 ARIMA\n",
      "electricity 317 318 h1 ARIMA\n",
      "synthetic 24 25 h1 Prophet\n",
      "electricity 210 240 h2 ARIMA\n",
      "electricity 240 270 h2 ARIMA\n",
      "electricity 290 291 h1 ARIMA\n",
      "electricity 60 90 h3 ARIMA\n",
      "traffic 448 480 h1 Prophet\n",
      "electricity 268 269 h1 ARIMA\n",
      "traffic 324 405 h2 ARIMA\n",
      "traffic 160 192 h1 Prophet\n",
      "traffic 960 963 h1 Prophet\n",
      "electricity 313 314 h1 ARIMA\n",
      "electricity 330 360 h3 ARIMA\n",
      "electricity 295 296 h1 ARIMA\n",
      "electricity 321 322 h1 ARIMA\n",
      "traffic 672 704 h1 Prophet\n",
      "exchange 0 8 h1 mSSA\n",
      "electricity 253 254 h1 ARIMA\n",
      "exchangereturns 0 8 h1 mSSA\n",
      "electricity 288 289 h1 ARIMA\n",
      "exchange 0 8 h1 ARIMA\n",
      "electricity 258 259 h1 ARIMA\n",
      "electricity 90 120 h2 ARIMA\n",
      "electricity 280 281 h1 ARIMA\n",
      "electricity 120 150 h3 ARIMA\n",
      "traffic 648 729 h2 ARIMA\n",
      "electricity 347 348 h1 ARIMA\n",
      "electricity 314 315 h1 ARIMA\n",
      "electricity 320 321 h1 ARIMA\n",
      "traffic 96 128 h1 Prophet\n",
      "exchangestd 0 8 h1 mSSA\n",
      "traffic 486 567 h3 ARIMA\n",
      "electricity 271 272 h1 ARIMA\n",
      "traffic 0 81 h3 ARIMA\n",
      "electricity 262 263 h1 ARIMA\n"
     ]
    }
   ],
   "source": [
    "datasetIter = []\n",
    "modelIter = []\n",
    "r2Iter = []\n",
    "for filename in glob(\"../results/*.pkl\"):\n",
    "    dataset, startIncl, endExcl, window, model, _ = filename.split(\"/\")[-1].split(\"_\")\n",
    "    print(dataset, startIncl, endExcl, window, model)\n",
    "    if window != \"h1\":\n",
    "        continue\n",
    "    with open(filename, \"rb\") as f:\n",
    "        data = pickle.load(f)\n",
    "    truth = data[\"results\"][\"groundTruth\"]\n",
    "    preds = data[\"results\"][model]\n",
    "    r2s = np.array(metrics.r2_score(truth, preds, multioutput=\"raw_values\")).tolist()\n",
    "    r2Iter.extend(r2s)\n",
    "    datasetIter.extend([dataset] * len(r2s))\n",
    "    modelIter.extend([model] * len(r2s))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>dataset</th>\n",
       "      <th>model</th>\n",
       "      <th>r2</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>traffic</td>\n",
       "      <td>ARIMA</td>\n",
       "      <td>0.880725</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>traffic</td>\n",
       "      <td>ARIMA</td>\n",
       "      <td>0.813384</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>traffic</td>\n",
       "      <td>ARIMA</td>\n",
       "      <td>0.819462</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>traffic</td>\n",
       "      <td>ARIMA</td>\n",
       "      <td>0.781558</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>traffic</td>\n",
       "      <td>ARIMA</td>\n",
       "      <td>0.852702</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5523</th>\n",
       "      <td>exchangestd</td>\n",
       "      <td>mSSA</td>\n",
       "      <td>0.707880</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5524</th>\n",
       "      <td>exchangestd</td>\n",
       "      <td>mSSA</td>\n",
       "      <td>0.783073</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5525</th>\n",
       "      <td>exchangestd</td>\n",
       "      <td>mSSA</td>\n",
       "      <td>0.686994</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5526</th>\n",
       "      <td>electricity</td>\n",
       "      <td>ARIMA</td>\n",
       "      <td>0.794970</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5527</th>\n",
       "      <td>electricity</td>\n",
       "      <td>ARIMA</td>\n",
       "      <td>0.905937</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>5528 rows × 3 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "          dataset  model        r2\n",
       "0         traffic  ARIMA  0.880725\n",
       "1         traffic  ARIMA  0.813384\n",
       "2         traffic  ARIMA  0.819462\n",
       "3         traffic  ARIMA  0.781558\n",
       "4         traffic  ARIMA  0.852702\n",
       "...           ...    ...       ...\n",
       "5523  exchangestd   mSSA  0.707880\n",
       "5524  exchangestd   mSSA  0.783073\n",
       "5525  exchangestd   mSSA  0.686994\n",
       "5526  electricity  ARIMA  0.794970\n",
       "5527  electricity  ARIMA  0.905937\n",
       "\n",
       "[5528 rows x 3 columns]"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df = pd.DataFrame(\n",
    "    {\n",
    "        \"dataset\": datasetIter,\n",
    "        \"model\": modelIter,\n",
    "        \"r2\": r2Iter,\n",
    "    }\n",
    ")\n",
    "df\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "dataset          model  \n",
       "electricity      ARIMA      370\n",
       "                 Prophet    370\n",
       "                 SAMoSSA    370\n",
       "                 mSSA       370\n",
       "exchange         ARIMA        8\n",
       "                 Prophet      8\n",
       "                 SAMoSSA      8\n",
       "                 mSSA         8\n",
       "exchangereturns  ARIMA        8\n",
       "                 Prophet      8\n",
       "                 SAMoSSA      8\n",
       "                 mSSA         8\n",
       "exchangestd      ARIMA        8\n",
       "                 Prophet      8\n",
       "                 SAMoSSA      8\n",
       "                 mSSA         8\n",
       "synthetic        ARIMA       25\n",
       "                 Prophet     25\n",
       "                 SAMoSSA     25\n",
       "                 mSSA        25\n",
       "traffic          ARIMA      963\n",
       "                 Prophet    963\n",
       "                 SAMoSSA    963\n",
       "                 mSSA       963\n",
       "dtype: int64"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df.groupby([\"dataset\", \"model\"]).size()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th>dataset</th>\n",
       "      <th>electricity</th>\n",
       "      <th>exchange</th>\n",
       "      <th>exchangereturns</th>\n",
       "      <th>exchangestd</th>\n",
       "      <th>synthetic</th>\n",
       "      <th>traffic</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>model</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>ARIMA</th>\n",
       "      <td>-10.000</td>\n",
       "      <td>0.765</td>\n",
       "      <td>-0.054</td>\n",
       "      <td>0.756</td>\n",
       "      <td>0.305</td>\n",
       "      <td>0.723</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Prophet</th>\n",
       "      <td>0.197</td>\n",
       "      <td>-10.000</td>\n",
       "      <td>-0.012</td>\n",
       "      <td>-10.000</td>\n",
       "      <td>-0.445</td>\n",
       "      <td>0.462</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>SAMoSSA</th>\n",
       "      <td>0.829</td>\n",
       "      <td>0.726</td>\n",
       "      <td>-0.076</td>\n",
       "      <td>0.731</td>\n",
       "      <td>0.476</td>\n",
       "      <td>0.776</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>mSSA</th>\n",
       "      <td>0.605</td>\n",
       "      <td>0.688</td>\n",
       "      <td>-0.076</td>\n",
       "      <td>0.674</td>\n",
       "      <td>0.366</td>\n",
       "      <td>0.747</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "dataset  electricity  exchange  exchangereturns  exchangestd  synthetic  \\\n",
       "model                                                                     \n",
       "ARIMA        -10.000     0.765           -0.054        0.756      0.305   \n",
       "Prophet        0.197   -10.000           -0.012      -10.000     -0.445   \n",
       "SAMoSSA        0.829     0.726           -0.076        0.731      0.476   \n",
       "mSSA           0.605     0.688           -0.076        0.674      0.366   \n",
       "\n",
       "dataset  traffic  \n",
       "model             \n",
       "ARIMA      0.723  \n",
       "Prophet    0.462  \n",
       "SAMoSSA    0.776  \n",
       "mSSA       0.747  "
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "table = (\n",
    "    df\n",
    "    .groupby([\"dataset\", \"model\"])\n",
    "    .mean()\n",
    "    .reset_index()\n",
    "    .pivot(index=\"model\", columns=\"dataset\", values=\"r2\")\n",
    ").clip(lower=-10)\n",
    "table.round(3)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "table.to_csv(\"../results/results.csv\")\n"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "ds",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.9.7"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
