{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 94,
   "id": "d4e2558a",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 186,
   "id": "6c5bd40d",
   "metadata": {},
   "outputs": [],
   "source": [
    "# datalist = \"210 497 1099 40916 505 560 566 524 194 42370 511 509 456 8 42360 531 703 534 44968 549 43611 45102 43962 4544 41702 41021 41265 43466 43919 315 41700 42727 43926 507 44055 44061 44136 503 189 558 562 44132 44056 422 44054 44145 44062 42183 44137 44005 44133 44134 44063 44026 45012 537 44148 44066 44984 44064 344 44963 44059 44057 43928 44069 44068 44027 44065\"\n",
    "datalist = \"194 41265 42183 43611 44133 4544 524 537 562 566\"\n",
    "datalist = datalist.split(\" \")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 230,
   "id": "2db22699",
   "metadata": {},
   "outputs": [],
   "source": [
    "models = ['xgboost', 'mlp', 'sslbinsampling', 'sslbinshuffling']\n",
    "\n",
    "p = pd.DataFrame(columns=(\"model\", \"data_id\", \"shot\", \"trial\", \"rmse\"))\n",
    "i = 0\n",
    "for trial in range(10):\n",
    "    for shot in [1, 5]:\n",
    "        for m in models:\n",
    "            for d in [4544]: #datalist:\n",
    "                fname = f'/home/SemiTab/results/seed={trial}/shot={shot}/model={m}/data={d}/results.npy'\n",
    "                try:\n",
    "                    perf = np.load(fname)\n",
    "                    if isinstance(perf, list):\n",
    "                        p.loc[i] = [m, d, shot, trial, perf[1]]\n",
    "                    else:\n",
    "                        p.loc[i] = [m, d, shot, trial, perf[0]]\n",
    "                    i += 1\n",
    "                except FileNotFoundError:\n",
    "#                     print(d)\n",
    "                    pass"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 231,
   "id": "fd869154",
   "metadata": {},
   "outputs": [],
   "source": [
    "q = p.groupby([\"data_id\", \"model\", \"shot\"]).agg(rmse_mean=(\"rmse\", \"mean\")).reset_index()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 229,
   "id": "b9b207f4",
   "metadata": {},
   "outputs": [],
   "source": [
    "import copy\n",
    "rankdata = copy.deepcopy(q)\n",
    "\n",
    "for shot in [1, 5]:\n",
    "    for data in datalist:\n",
    "        q2 = q[(q[\"data_id\"] == data) & (q[\"shot\"] == shot)]\n",
    "        q2 = q2.reset_index(drop=True)\n",
    "    \n",
    "        q2['rank'] = q2[\"rmse_mean\"].rank(ascending=True, method=\"min\")\n",
    "\n",
    "        for i, row in q2.iterrows():\n",
    "            rankdata.loc[(rankdata[\"data_id\"] == row[\"data_id\"]) & \n",
    "                         (rankdata[\"shot\"] == shot) & \n",
    "                         (rankdata[\"rmse_mean\"] == row[\"rmse_mean\"]), 'rank'] = row['rank']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 232,
   "id": "a44191b4",
   "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>data_id</th>\n",
       "      <th>model</th>\n",
       "      <th>shot</th>\n",
       "      <th>rmse_mean</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>4544</td>\n",
       "      <td>mlp</td>\n",
       "      <td>1</td>\n",
       "      <td>1.000694</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>4544</td>\n",
       "      <td>sslbinsampling</td>\n",
       "      <td>1</td>\n",
       "      <td>1.012894</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>4544</td>\n",
       "      <td>sslbinshuffling</td>\n",
       "      <td>1</td>\n",
       "      <td>1.009390</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>4544</td>\n",
       "      <td>xgboost</td>\n",
       "      <td>1</td>\n",
       "      <td>1.238492</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   data_id            model  shot  rmse_mean\n",
       "0     4544              mlp     1   1.000694\n",
       "2     4544   sslbinsampling     1   1.012894\n",
       "4     4544  sslbinshuffling     1   1.009390\n",
       "6     4544          xgboost     1   1.238492"
      ]
     },
     "execution_count": 232,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "rankdata[rankdata[\"shot\"] == 1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 225,
   "id": "fef8fe3c",
   "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>model</th>\n",
       "      <th>data_id</th>\n",
       "      <th>shot</th>\n",
       "      <th>trial</th>\n",
       "      <th>rmse</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>xgboost</td>\n",
       "      <td>4544</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>1.437243</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>mlp</td>\n",
       "      <td>4544</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>1.030350</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>sslbinsampling</td>\n",
       "      <td>4544</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>1.039112</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>sslbinshuffling</td>\n",
       "      <td>4544</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>1.035847</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>xgboost</td>\n",
       "      <td>4544</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1.271916</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>mlp</td>\n",
       "      <td>4544</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1.110194</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>sslbinsampling</td>\n",
       "      <td>4544</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1.077124</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>sslbinshuffling</td>\n",
       "      <td>4544</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1.080960</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>16</th>\n",
       "      <td>xgboost</td>\n",
       "      <td>4544</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "      <td>1.028700</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17</th>\n",
       "      <td>mlp</td>\n",
       "      <td>4544</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "      <td>1.026888</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>18</th>\n",
       "      <td>sslbinsampling</td>\n",
       "      <td>4544</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "      <td>1.067284</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>19</th>\n",
       "      <td>sslbinshuffling</td>\n",
       "      <td>4544</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "      <td>1.079297</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>24</th>\n",
       "      <td>xgboost</td>\n",
       "      <td>4544</td>\n",
       "      <td>1</td>\n",
       "      <td>3</td>\n",
       "      <td>1.067003</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>25</th>\n",
       "      <td>mlp</td>\n",
       "      <td>4544</td>\n",
       "      <td>1</td>\n",
       "      <td>3</td>\n",
       "      <td>1.031315</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>26</th>\n",
       "      <td>sslbinsampling</td>\n",
       "      <td>4544</td>\n",
       "      <td>1</td>\n",
       "      <td>3</td>\n",
       "      <td>1.033630</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>27</th>\n",
       "      <td>sslbinshuffling</td>\n",
       "      <td>4544</td>\n",
       "      <td>1</td>\n",
       "      <td>3</td>\n",
       "      <td>1.033397</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>32</th>\n",
       "      <td>xgboost</td>\n",
       "      <td>4544</td>\n",
       "      <td>1</td>\n",
       "      <td>4</td>\n",
       "      <td>1.179276</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>33</th>\n",
       "      <td>mlp</td>\n",
       "      <td>4544</td>\n",
       "      <td>1</td>\n",
       "      <td>4</td>\n",
       "      <td>0.996306</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>34</th>\n",
       "      <td>sslbinsampling</td>\n",
       "      <td>4544</td>\n",
       "      <td>1</td>\n",
       "      <td>4</td>\n",
       "      <td>1.016370</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>35</th>\n",
       "      <td>sslbinshuffling</td>\n",
       "      <td>4544</td>\n",
       "      <td>1</td>\n",
       "      <td>4</td>\n",
       "      <td>1.013626</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>40</th>\n",
       "      <td>xgboost</td>\n",
       "      <td>4544</td>\n",
       "      <td>1</td>\n",
       "      <td>5</td>\n",
       "      <td>1.243374</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>41</th>\n",
       "      <td>mlp</td>\n",
       "      <td>4544</td>\n",
       "      <td>1</td>\n",
       "      <td>5</td>\n",
       "      <td>0.860649</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>42</th>\n",
       "      <td>sslbinsampling</td>\n",
       "      <td>4544</td>\n",
       "      <td>1</td>\n",
       "      <td>5</td>\n",
       "      <td>0.864782</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>43</th>\n",
       "      <td>sslbinshuffling</td>\n",
       "      <td>4544</td>\n",
       "      <td>1</td>\n",
       "      <td>5</td>\n",
       "      <td>0.866787</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>48</th>\n",
       "      <td>xgboost</td>\n",
       "      <td>4544</td>\n",
       "      <td>1</td>\n",
       "      <td>6</td>\n",
       "      <td>1.023387</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>49</th>\n",
       "      <td>mlp</td>\n",
       "      <td>4544</td>\n",
       "      <td>1</td>\n",
       "      <td>6</td>\n",
       "      <td>1.025216</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>50</th>\n",
       "      <td>sslbinsampling</td>\n",
       "      <td>4544</td>\n",
       "      <td>1</td>\n",
       "      <td>6</td>\n",
       "      <td>1.035722</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>51</th>\n",
       "      <td>sslbinshuffling</td>\n",
       "      <td>4544</td>\n",
       "      <td>1</td>\n",
       "      <td>6</td>\n",
       "      <td>1.031321</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>56</th>\n",
       "      <td>xgboost</td>\n",
       "      <td>4544</td>\n",
       "      <td>1</td>\n",
       "      <td>7</td>\n",
       "      <td>1.441104</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>57</th>\n",
       "      <td>mlp</td>\n",
       "      <td>4544</td>\n",
       "      <td>1</td>\n",
       "      <td>7</td>\n",
       "      <td>0.979615</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>58</th>\n",
       "      <td>sslbinsampling</td>\n",
       "      <td>4544</td>\n",
       "      <td>1</td>\n",
       "      <td>7</td>\n",
       "      <td>0.991000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>59</th>\n",
       "      <td>sslbinshuffling</td>\n",
       "      <td>4544</td>\n",
       "      <td>1</td>\n",
       "      <td>7</td>\n",
       "      <td>0.988337</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>64</th>\n",
       "      <td>xgboost</td>\n",
       "      <td>4544</td>\n",
       "      <td>1</td>\n",
       "      <td>8</td>\n",
       "      <td>0.992449</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>65</th>\n",
       "      <td>mlp</td>\n",
       "      <td>4544</td>\n",
       "      <td>1</td>\n",
       "      <td>8</td>\n",
       "      <td>0.989501</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>66</th>\n",
       "      <td>sslbinsampling</td>\n",
       "      <td>4544</td>\n",
       "      <td>1</td>\n",
       "      <td>8</td>\n",
       "      <td>1.043266</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>67</th>\n",
       "      <td>sslbinshuffling</td>\n",
       "      <td>4544</td>\n",
       "      <td>1</td>\n",
       "      <td>8</td>\n",
       "      <td>1.004280</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>72</th>\n",
       "      <td>xgboost</td>\n",
       "      <td>4544</td>\n",
       "      <td>1</td>\n",
       "      <td>9</td>\n",
       "      <td>1.700463</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>73</th>\n",
       "      <td>mlp</td>\n",
       "      <td>4544</td>\n",
       "      <td>1</td>\n",
       "      <td>9</td>\n",
       "      <td>0.956908</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>74</th>\n",
       "      <td>sslbinsampling</td>\n",
       "      <td>4544</td>\n",
       "      <td>1</td>\n",
       "      <td>9</td>\n",
       "      <td>0.960652</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>75</th>\n",
       "      <td>sslbinshuffling</td>\n",
       "      <td>4544</td>\n",
       "      <td>1</td>\n",
       "      <td>9</td>\n",
       "      <td>0.960044</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "              model  data_id  shot  trial      rmse\n",
       "0           xgboost     4544     1      0  1.437243\n",
       "1               mlp     4544     1      0  1.030350\n",
       "2    sslbinsampling     4544     1      0  1.039112\n",
       "3   sslbinshuffling     4544     1      0  1.035847\n",
       "8           xgboost     4544     1      1  1.271916\n",
       "9               mlp     4544     1      1  1.110194\n",
       "10   sslbinsampling     4544     1      1  1.077124\n",
       "11  sslbinshuffling     4544     1      1  1.080960\n",
       "16          xgboost     4544     1      2  1.028700\n",
       "17              mlp     4544     1      2  1.026888\n",
       "18   sslbinsampling     4544     1      2  1.067284\n",
       "19  sslbinshuffling     4544     1      2  1.079297\n",
       "24          xgboost     4544     1      3  1.067003\n",
       "25              mlp     4544     1      3  1.031315\n",
       "26   sslbinsampling     4544     1      3  1.033630\n",
       "27  sslbinshuffling     4544     1      3  1.033397\n",
       "32          xgboost     4544     1      4  1.179276\n",
       "33              mlp     4544     1      4  0.996306\n",
       "34   sslbinsampling     4544     1      4  1.016370\n",
       "35  sslbinshuffling     4544     1      4  1.013626\n",
       "40          xgboost     4544     1      5  1.243374\n",
       "41              mlp     4544     1      5  0.860649\n",
       "42   sslbinsampling     4544     1      5  0.864782\n",
       "43  sslbinshuffling     4544     1      5  0.866787\n",
       "48          xgboost     4544     1      6  1.023387\n",
       "49              mlp     4544     1      6  1.025216\n",
       "50   sslbinsampling     4544     1      6  1.035722\n",
       "51  sslbinshuffling     4544     1      6  1.031321\n",
       "56          xgboost     4544     1      7  1.441104\n",
       "57              mlp     4544     1      7  0.979615\n",
       "58   sslbinsampling     4544     1      7  0.991000\n",
       "59  sslbinshuffling     4544     1      7  0.988337\n",
       "64          xgboost     4544     1      8  0.992449\n",
       "65              mlp     4544     1      8  0.989501\n",
       "66   sslbinsampling     4544     1      8  1.043266\n",
       "67  sslbinshuffling     4544     1      8  1.004280\n",
       "72          xgboost     4544     1      9  1.700463\n",
       "73              mlp     4544     1      9  0.956908\n",
       "74   sslbinsampling     4544     1      9  0.960652\n",
       "75  sslbinshuffling     4544     1      9  0.960044"
      ]
     },
     "execution_count": 225,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "p[p[\"shot\"] == 1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "10d09141",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 221,
   "id": "7c112fc9",
   "metadata": {},
   "outputs": [
    {
     "ename": "KeyError",
     "evalue": "'rank'",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mKeyError\u001b[0m                                  Traceback (most recent call last)",
      "Input \u001b[0;32mIn [221]\u001b[0m, in \u001b[0;36m<cell line: 1>\u001b[0;34m()\u001b[0m\n\u001b[0;32m----> 1\u001b[0m \u001b[43mrankdata\u001b[49m\u001b[43m[\u001b[49m\u001b[43m(\u001b[49m\u001b[43mrankdata\u001b[49m\u001b[43m[\u001b[49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[38;5;124;43mdata_id\u001b[39;49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[43m]\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m==\u001b[39;49m\u001b[43m \u001b[49m\u001b[38;5;241;43m4544\u001b[39;49m\u001b[43m)\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m&\u001b[39;49m\u001b[43m \u001b[49m\u001b[43m(\u001b[49m\u001b[43mrankdata\u001b[49m\u001b[43m[\u001b[49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[38;5;124;43mshot\u001b[39;49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[43m]\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m==\u001b[39;49m\u001b[43m \u001b[49m\u001b[38;5;241;43m1\u001b[39;49m\u001b[43m)\u001b[49m\u001b[43m]\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43msort_values\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[38;5;124;43mrank\u001b[39;49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[43m)\u001b[49m\n",
      "File \u001b[0;32m/opt/conda/lib/python3.8/site-packages/pandas/util/_decorators.py:311\u001b[0m, in \u001b[0;36mdeprecate_nonkeyword_arguments.<locals>.decorate.<locals>.wrapper\u001b[0;34m(*args, **kwargs)\u001b[0m\n\u001b[1;32m    305\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;28mlen\u001b[39m(args) \u001b[38;5;241m>\u001b[39m num_allow_args:\n\u001b[1;32m    306\u001b[0m     warnings\u001b[38;5;241m.\u001b[39mwarn(\n\u001b[1;32m    307\u001b[0m         msg\u001b[38;5;241m.\u001b[39mformat(arguments\u001b[38;5;241m=\u001b[39marguments),\n\u001b[1;32m    308\u001b[0m         \u001b[38;5;167;01mFutureWarning\u001b[39;00m,\n\u001b[1;32m    309\u001b[0m         stacklevel\u001b[38;5;241m=\u001b[39mstacklevel,\n\u001b[1;32m    310\u001b[0m     )\n\u001b[0;32m--> 311\u001b[0m \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43mfunc\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43margs\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43mkwargs\u001b[49m\u001b[43m)\u001b[49m\n",
      "File \u001b[0;32m/opt/conda/lib/python3.8/site-packages/pandas/core/frame.py:6319\u001b[0m, in \u001b[0;36mDataFrame.sort_values\u001b[0;34m(self, by, axis, ascending, inplace, kind, na_position, ignore_index, key)\u001b[0m\n\u001b[1;32m   6315\u001b[0m \u001b[38;5;28;01melif\u001b[39;00m \u001b[38;5;28mlen\u001b[39m(by):\n\u001b[1;32m   6316\u001b[0m     \u001b[38;5;66;03m# len(by) == 1\u001b[39;00m\n\u001b[1;32m   6318\u001b[0m     by \u001b[38;5;241m=\u001b[39m by[\u001b[38;5;241m0\u001b[39m]\n\u001b[0;32m-> 6319\u001b[0m     k \u001b[38;5;241m=\u001b[39m \u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43m_get_label_or_level_values\u001b[49m\u001b[43m(\u001b[49m\u001b[43mby\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43maxis\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43maxis\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m   6321\u001b[0m     \u001b[38;5;66;03m# need to rewrap column in Series to apply key function\u001b[39;00m\n\u001b[1;32m   6322\u001b[0m     \u001b[38;5;28;01mif\u001b[39;00m key \u001b[38;5;129;01mis\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m \u001b[38;5;28;01mNone\u001b[39;00m:\n\u001b[1;32m   6323\u001b[0m         \u001b[38;5;66;03m# error: Incompatible types in assignment (expression has type\u001b[39;00m\n\u001b[1;32m   6324\u001b[0m         \u001b[38;5;66;03m# \"Series\", variable has type \"ndarray\")\u001b[39;00m\n",
      "File \u001b[0;32m/opt/conda/lib/python3.8/site-packages/pandas/core/generic.py:1840\u001b[0m, in \u001b[0;36mNDFrame._get_label_or_level_values\u001b[0;34m(self, key, axis)\u001b[0m\n\u001b[1;32m   1838\u001b[0m     values \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39maxes[axis]\u001b[38;5;241m.\u001b[39mget_level_values(key)\u001b[38;5;241m.\u001b[39m_values\n\u001b[1;32m   1839\u001b[0m \u001b[38;5;28;01melse\u001b[39;00m:\n\u001b[0;32m-> 1840\u001b[0m     \u001b[38;5;28;01mraise\u001b[39;00m \u001b[38;5;167;01mKeyError\u001b[39;00m(key)\n\u001b[1;32m   1842\u001b[0m \u001b[38;5;66;03m# Check for duplicates\u001b[39;00m\n\u001b[1;32m   1843\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m values\u001b[38;5;241m.\u001b[39mndim \u001b[38;5;241m>\u001b[39m \u001b[38;5;241m1\u001b[39m:\n",
      "\u001b[0;31mKeyError\u001b[0m: 'rank'"
     ]
    }
   ],
   "source": [
    "rankdata[(rankdata[\"data_id\"] == 4544) & (rankdata[\"shot\"] == 1)].sort_values(\"rank\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "747485a2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 61,
   "id": "b19b4e34",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "210 1 xgboost 1.5974084340151913\n",
      "210 1 mlp 1.6537039999356222\n",
      "210 1 sslscarf 1.6163848506788692\n",
      "210 1 sslmasking 1.6163848506788692\n",
      "210 1 sslshuffling 1.6163848506788692\n",
      "210 1 sslnoisemasking 1.6163848506788692\n",
      "210 1 sslrq 1.6163848506788692\n",
      "210 1 sslbinsampling 1.6163848506788692\n",
      "210 1 sslbinshuffling 1.6163848506788692\n",
      "497 1 xgboost 123.3999032933677\n",
      "497 1 mlp 167.14920706325532\n",
      "497 1 sslscarf 167.14783407959553\n",
      "497 1 sslmasking 167.14783407959553\n",
      "497 1 sslshuffling 167.14783407959553\n",
      "497 1 sslnoisemasking 167.14783407959553\n",
      "497 1 sslrq 167.14783407959553\n",
      "497 1 sslbinsampling 167.14783407959553\n",
      "497 1 sslbinshuffling 167.14783407959553\n",
      "497 5 xgboost 116.77598579920017\n",
      "497 5 mlp 149.07798006622238\n",
      "497 5 sslscarf 167.14783407959553\n",
      "497 5 sslmasking 167.14783407959553\n",
      "497 5 sslshuffling 167.14783407959553\n",
      "497 5 sslnoisemasking 167.14783407959553\n",
      "497 5 sslrq 167.14783407959553\n",
      "497 5 sslbinsampling 167.14783407959553\n",
      "497 5 sslbinshuffling 167.14783407959553\n",
      "1099 1 xgboost 1941.884329716886\n",
      "1099 1 mlp 2581.4286742034924\n",
      "1099 1 sslscarf 2581.4439757624027\n",
      "1099 1 sslmasking 2581.4439757624027\n",
      "1099 1 sslshuffling 2581.4439757624027\n",
      "1099 1 sslnoisemasking 2581.4439757624027\n",
      "1099 1 sslrq 2581.4439757624027\n",
      "1099 1 sslbinsampling 2581.4439757624027\n",
      "1099 1 sslbinshuffling 2581.4439757624027\n",
      "40916 1 xgboost 1.0570414517989482\n",
      "40916 1 mlp 5.500483058176892\n",
      "40916 1 sslscarf 5.540247780942939\n",
      "40916 1 sslmasking 5.540247780942939\n",
      "40916 1 sslshuffling 5.540247780942939\n",
      "40916 1 sslnoisemasking 5.540247780942939\n",
      "40916 1 sslrq 5.540247780942939\n",
      "40916 1 sslbinsampling 5.540247780942939\n",
      "40916 1 sslbinshuffling 5.540247780942939\n",
      "505 1 xgboost 18.575668236686752\n",
      "505 1 mlp 24.60881447774354\n",
      "505 1 sslscarf 24.58438090877964\n",
      "505 1 sslmasking 24.626120294948006\n",
      "505 1 sslshuffling 24.607537133753603\n",
      "505 1 sslnoisemasking 24.71082264635022\n",
      "505 1 sslrq 24.59348693474301\n",
      "505 1 sslbinsampling 24.566807182389795\n",
      "505 1 sslbinshuffling 24.646284325526384\n",
      "560 1 xgboost 8.614965378862754\n",
      "560 1 mlp 20.786505884931618\n",
      "560 1 sslscarf 20.83888711780439\n",
      "560 1 sslmasking 20.913092846171224\n",
      "560 1 sslshuffling 20.89326089508476\n",
      "560 1 sslnoisemasking 20.80565853911127\n",
      "560 1 sslrq 20.905384359414292\n",
      "560 1 sslbinsampling 20.830717527838768\n",
      "560 1 sslbinshuffling 20.842748523542305\n",
      "560 5 xgboost 4.452096920798951\n",
      "560 5 mlp 11.210245378243496\n",
      "560 5 sslscarf 20.7965859178819\n",
      "560 5 sslmasking 20.85482599039953\n",
      "560 5 sslshuffling 20.784327779603554\n",
      "560 5 sslnoisemasking 20.86130389606893\n",
      "560 5 sslrq 20.903949331555747\n",
      "560 5 sslbinsampling 20.84601705367126\n",
      "560 5 sslbinshuffling 20.87262058973916\n",
      "566 1 xgboost 186.7899681125836\n",
      "566 1 mlp 212.38674371591557\n",
      "566 1 sslscarf 190.39146555518187\n",
      "566 1 sslmasking 190.372835263464\n",
      "566 1 sslshuffling 190.33179294655426\n",
      "566 1 sslnoisemasking 190.366864156423\n",
      "566 1 sslrq 190.36059531846396\n",
      "566 1 sslbinsampling 190.3668333770355\n",
      "566 1 sslbinshuffling 190.35229469000367\n",
      "524 1 xgboost 1.3363062031901174\n",
      "524 1 mlp 1.3080076812611925\n",
      "524 1 sslscarf 1.2988951242705316\n",
      "524 1 sslmasking 1.333494484620047\n",
      "524 1 sslshuffling 1.30426498241568\n",
      "524 1 sslnoisemasking 1.3288218745604328\n",
      "524 1 sslrq 1.319015723842577\n",
      "524 1 sslbinsampling 1.3053014989402567\n",
      "524 1 sslbinshuffling 1.3046097875053384\n",
      "194 1 xgboost 1.7029386645934819\n",
      "194 1 mlp 1.6933306523299332\n",
      "194 1 sslscarf 1.686142057183369\n",
      "194 1 sslmasking 1.6705892735010286\n",
      "194 1 sslshuffling 1.721133157813139\n",
      "194 1 sslnoisemasking 1.7105139639250158\n",
      "194 1 sslrq 1.718511946404948\n",
      "194 1 sslbinsampling 1.6785151449002615\n",
      "194 1 sslbinshuffling 1.6950552608967933\n",
      "42370 1 xgboost 12.01383746558168\n",
      "42370 1 mlp 14.847565812997397\n",
      "42370 1 sslscarf 14.789435477170805\n",
      "42370 1 sslmasking 14.82876196438814\n",
      "42370 1 sslshuffling 14.813887004056204\n",
      "42370 1 sslnoisemasking 14.790407340299732\n",
      "42370 1 sslrq 14.843668790896276\n",
      "42370 1 sslbinsampling 14.798280482022543\n",
      "42370 1 sslbinshuffling 14.79159010030066\n",
      "511 1 xgboost 265.3843321486783\n",
      "511 1 mlp 607.7741922375448\n",
      "511 1 sslscarf 607.6595726638394\n",
      "511 1 sslmasking 607.6406472990429\n",
      "511 1 sslshuffling 607.737967795332\n",
      "511 1 sslnoisemasking 607.5747639179889\n",
      "511 1 sslrq 607.8045532899536\n",
      "511 1 sslbinsampling 607.6714264304353\n",
      "511 1 sslbinshuffling 607.6661038349926\n",
      "509 1 xgboost 1237.1586397871536\n",
      "509 1 mlp 5633.716002781823\n",
      "509 1 sslscarf 5633.622635569407\n",
      "509 1 sslmasking 5633.65405398663\n",
      "509 1 sslshuffling 5633.664704257789\n",
      "509 1 sslnoisemasking 5633.690087322872\n",
      "509 1 sslrq 5633.6006248224585\n",
      "509 1 sslbinsampling 5633.683697191385\n",
      "509 1 sslbinshuffling 5633.778128396609\n",
      "456 1 xgboost 920.4403837294407\n",
      "456 1 mlp 8955.446164206449\n",
      "456 1 sslscarf 8955.289833388979\n",
      "456 1 sslmasking 8955.268393521214\n",
      "456 1 sslshuffling 8955.394352009296\n",
      "456 1 sslnoisemasking 8955.281793444581\n",
      "456 1 sslrq 8955.51896877004\n",
      "456 1 sslbinsampling 8955.308593231168\n",
      "456 1 sslbinshuffling 8955.256333573037\n",
      "456 5 xgboost 815.7224558635124\n",
      "456 5 mlp 6880.560151615565\n",
      "456 5 sslscarf 8955.344326155193\n",
      "456 5 sslmasking 8955.22238696505\n",
      "456 5 sslshuffling 8955.238913619223\n",
      "456 5 sslnoisemasking 8955.510929031352\n",
      "456 5 sslrq 8955.514948901598\n",
      "456 5 sslbinsampling 8955.28626008125\n",
      "456 5 sslbinshuffling 8955.282686772094\n",
      "8 1 xgboost 4.382111137969083\n",
      "8 1 mlp 4.400951473357734\n",
      "8 1 sslscarf 4.393643790598754\n",
      "8 1 sslmasking 4.444434751394087\n",
      "8 1 sslshuffling 4.400565951969342\n",
      "8 1 sslnoisemasking 4.4010418352055565\n",
      "8 1 sslrq 4.391044623797804\n",
      "8 1 sslbinsampling 4.4216224409571625\n",
      "8 1 sslbinshuffling 4.404981065204987\n",
      "42360 1 xgboost 1.123912179380506\n",
      "42360 1 mlp 2.982001674106673\n",
      "42360 1 sslscarf 3.186655269214034\n",
      "42360 1 sslmasking 3.1668392100927014\n",
      "42360 1 sslshuffling 3.135927245347116\n",
      "42360 1 sslnoisemasking 3.1891600829861315\n",
      "42360 1 sslrq 3.130605019787228\n",
      "42360 1 sslbinsampling 3.260192587142856\n",
      "42360 1 sslbinshuffling 3.269235467691627\n",
      "531 1 xgboost 9.205402396884898\n",
      "531 1 mlp 24.043997807486306\n",
      "531 1 sslscarf 23.807041133234748\n",
      "531 1 sslmasking 23.850115365123237\n",
      "531 1 sslshuffling 23.892671286629664\n",
      "531 1 sslnoisemasking 23.890736132426284\n",
      "531 1 sslrq 23.931536616444394\n",
      "531 1 sslbinsampling 23.906929116171007\n",
      "531 1 sslbinshuffling 23.89829830990849\n",
      "703 1 xgboost 0.8241644384921676\n",
      "703 1 mlp 89.99041018787085\n",
      "703 1 sslscarf 90.17283480471681\n",
      "703 1 sslmasking 90.1533930439878\n",
      "703 1 sslshuffling 90.1427253720454\n",
      "703 1 sslnoisemasking 90.09683375749117\n",
      "703 1 sslrq 90.08654150836017\n",
      "703 1 sslbinsampling 90.13965943537283\n",
      "703 1 sslbinshuffling 90.11984479448047\n",
      "534 1 xgboost 5.319711256294067\n",
      "534 1 mlp 10.300108336832592\n",
      "534 1 sslscarf 10.15287241012461\n",
      "534 1 sslmasking 10.121895396537994\n",
      "534 1 sslshuffling 10.094259432287647\n",
      "534 1 sslnoisemasking 10.127560138811043\n",
      "534 1 sslrq 10.240524750615505\n",
      "534 1 sslbinsampling 10.141392753703176\n",
      "534 1 sslbinshuffling 10.144027350788969\n",
      "44968 1 xgboost 0.2920129315716784\n",
      "44968 1 mlp 1.4985314969204262\n",
      "44968 1 sslscarf 1.6822072136843689\n",
      "44968 1 sslmasking 1.5619663853221497\n",
      "44968 1 sslshuffling 1.8023556924266377\n",
      "44968 1 sslnoisemasking 1.7450095273170418\n",
      "44968 1 sslrq 1.6387896489774338\n",
      "44968 1 sslbinsampling 1.632625222303286\n",
      "44968 1 sslbinshuffling 1.6349678962658771\n",
      "549 1 xgboost 643.9391954990781\n",
      "549 1 mlp 711.6151742690707\n",
      "549 1 sslscarf 711.5758041136587\n",
      "549 1 sslmasking 711.5585227161572\n",
      "549 1 sslshuffling 711.5826111562873\n",
      "549 1 sslnoisemasking 711.572202942189\n",
      "549 1 sslrq 711.5802396778595\n",
      "549 1 sslbinsampling 711.5952808654649\n",
      "549 1 sslbinshuffling 711.580854506359\n",
      "43611 1 xgboost 0.6041220423781717\n",
      "43611 1 mlp 0.5800716001612466\n",
      "43611 1 sslscarf 0.5979242160422424\n",
      "43611 1 sslmasking 0.5544860635266764\n",
      "43611 1 sslshuffling 0.6513037471960983\n",
      "43611 1 sslnoisemasking 0.5975583563522213\n",
      "43611 1 sslrq 0.5748279998438224\n",
      "43611 1 sslbinsampling 0.5447312982297953\n",
      "43611 1 sslbinshuffling 0.5618058265818459\n",
      "45102 1 xgboost 187.0433292882962\n",
      "45102 1 mlp 345.53042331681877\n",
      "45102 1 sslscarf 343.3198331184786\n",
      "45102 1 sslmasking 343.58978084337724\n",
      "45102 1 sslshuffling 343.58532419182285\n",
      "45102 1 sslnoisemasking 343.307840629223\n",
      "45102 1 sslrq 343.534068543427\n",
      "45102 1 sslbinsampling 343.3316659041225\n",
      "45102 1 sslbinshuffling 343.4454673780104\n",
      "43962 1 xgboost 13.001739972387169\n",
      "43962 1 mlp 24.46184449172834\n",
      "43962 1 sslscarf 25.1989495921333\n",
      "43962 1 sslmasking 25.231044188069436\n",
      "43962 1 sslshuffling 25.16447361702356\n",
      "43962 1 sslnoisemasking 25.159178303944813\n",
      "43962 1 sslrq 25.185512871366146\n",
      "43962 1 sslbinsampling 25.099844566563053\n",
      "43962 1 sslbinshuffling 25.060809832348294\n",
      "4544 1 xgboost 1.4372432313561618\n",
      "4544 1 mlp 1.030350148025423\n",
      "4544 1 sslscarf 1.0474642333704904\n",
      "4544 1 sslmasking 1.0348638157466534\n",
      "4544 1 sslshuffling 1.040418385565492\n",
      "4544 1 sslnoisemasking 1.0462389479843008\n",
      "4544 1 sslrq 1.032413693069789\n",
      "4544 1 sslbinsampling 1.041266033694865\n",
      "41702 1 xgboost 32746.987403423846\n",
      "41702 1 mlp 32758.618774301216\n",
      "41702 5 xgboost 39354.972036580075\n",
      "41702 5 mlp 29051.25291618246\n",
      "43466 1 xgboost 0.7555851007470819\n",
      "43466 1 mlp 0.6474371858270691\n",
      "43466 1 sslscarf 0.6909269622109573\n",
      "43466 1 sslmasking 0.7107800319792852\n",
      "43466 1 sslshuffling 0.7413186458689557\n",
      "43466 1 sslnoisemasking 0.7089778595091673\n",
      "43466 1 sslrq 0.6549908274452393\n",
      "43466 1 sslbinsampling 0.6974538554374431\n",
      "43466 1 sslbinshuffling 0.6744455577081601\n",
      "43466 5 xgboost 0.521999604659826\n",
      "43466 5 mlp 0.8129209015105541\n",
      "43466 5 sslscarf 0.6997341196016995\n",
      "43466 5 sslmasking 0.739002057561733\n",
      "43466 5 sslshuffling 0.6790863096835359\n",
      "507 1 xgboost 0.2167320326328654\n",
      "507 1 mlp 0.617682150103035\n",
      "507 1 sslscarf 0.8226225162266307\n",
      "507 1 sslmasking 0.8595709143915823\n",
      "507 1 sslshuffling 0.8250778566094009\n",
      "507 1 sslnoisemasking 0.9103931888081666\n",
      "507 1 sslrq 0.8473775027370788\n",
      "507 1 sslbinsampling 0.8507105914462713\n",
      "507 1 sslbinshuffling 0.8560031632538754\n",
      "45012 1 xgboost 20177.831003356132\n",
      "45012 1 mlp 20564.452436182197\n",
      "45012 1 sslscarf 20564.522459809272\n",
      "45012 1 sslmasking 20564.47733349914\n",
      "45012 1 sslshuffling 20564.555915458033\n",
      "45012 1 sslnoisemasking 20564.506120984282\n",
      "45012 1 sslrq 20564.513901378752\n",
      "45012 1 sslbinsampling 20564.534130390603\n",
      "45012 1 sslbinshuffling 20564.577700502385\n",
      "537 1 xgboost 31.606905257568915\n",
      "537 1 mlp 23.415941908221818\n",
      "537 1 sslscarf 23.526816792724798\n",
      "537 1 sslmasking 23.12315897443581\n",
      "537 1 sslshuffling 23.360527250009525\n",
      "537 1 sslnoisemasking 23.479511825971542\n",
      "537 1 sslrq 23.30441774064456\n",
      "537 1 sslbinsampling 23.28705097611251\n",
      "537 1 sslbinshuffling 23.383198814884295\n",
      "537 5 xgboost 13.647326174703599\n",
      "537 5 mlp 16.36159659879557\n",
      "537 5 sslscarf 23.7065507680136\n",
      "537 5 sslmasking 23.103629800551634\n",
      "537 5 sslshuffling 23.264259477640135\n",
      "537 5 sslnoisemasking 23.58594914499547\n",
      "537 5 sslrq 23.496136286848447\n",
      "537 5 sslbinsampling 23.404358078161028\n"
     ]
    }
   ],
   "source": [
    "for d in datalist:\n",
    "    for shot in [1, 5]:\n",
    "        for m in models:\n",
    "            v = p[(p[\"data_id\"] == d) & (p[\"model\"] == m) & (p[\"shot\"] == shot)][\"rmse\"].mean()\n",
    "            if not np.isnan(v):\n",
    "                print(d, shot, m, v)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 58,
   "id": "d0007619",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "['22',\n",
       " '54',\n",
       " '1063',\n",
       " '1067',\n",
       " '12',\n",
       " '18',\n",
       " '23',\n",
       " '59',\n",
       " '188',\n",
       " '307',\n",
       " '1043',\n",
       " '1459',\n",
       " '1475',\n",
       " '1489',\n",
       " '1492',\n",
       " '1497',\n",
       " '1503',\n",
       " '4153',\n",
       " '40499',\n",
       " '44125',\n",
       " '44131',\n",
       " '45062',\n",
       " '44157',\n",
       " '1462',\n",
       " '44160',\n",
       " '29',\n",
       " '37',\n",
       " '53',\n",
       " '49',\n",
       " '1504',\n",
       " '1494',\n",
       " '41143',\n",
       " '44126',\n",
       " '40981',\n",
       " '41168',\n",
       " '44091',\n",
       " '44158',\n",
       " '44123',\n",
       " '44090',\n",
       " '40922',\n",
       " '44161',\n",
       " '45714']"
      ]
     },
     "execution_count": 58,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "datalist"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 53,
   "id": "690b4da2",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "1.4372432313561618"
      ]
     },
     "execution_count": 53,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "d = \"4544\"\n",
    "m = \"xgboost\"\n",
    "shot = 1\n",
    "p[(p[\"data_id\"] == d) & (p[\"model\"] == m) & (p[\"shot\"] == shot)][\"rmse\"].mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "id": "fa9f2cd3",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array(['xgboost', '4544', 1, 0, 1.4372432313561618], dtype=object)"
      ]
     },
     "execution_count": 51,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "p.loc[0].values"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1624432d",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.8.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
