{
 "cells": [
  {
   "cell_type": "code",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-04-14T14:10:54.452193Z",
     "start_time": "2025-04-14T14:10:54.064901Z"
    }
   },
   "source": [
    "import pandas as pd\n",
    "\n",
    "\n",
    "MODEL = \"esn\"  # can be \"kirnn\" or \"lstm\"\n",
    "horizon = 168  # can be 24, 168 or None"
   ],
   "outputs": [],
   "execution_count": 1
  },
  {
   "cell_type": "code",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-04-14T14:10:56.308118Z",
     "start_time": "2025-04-14T14:10:56.256027Z"
    }
   },
   "source": [
    "sr_params=['01e-1', '05e-1', '10e-1']\n",
    "\n",
    "full_results = []\n",
    "for sr in sr_params:\n",
    "    results_csv = f\"{MODEL}_sr_{sr}/grid_results.csv\"\n",
    "    temp_df = pd.read_csv(results_csv, index_col=\"run_id\")\n",
    "    temp_df['sr'] = float(sr)\n",
    "    full_results.append(temp_df)\n",
    "full_results = pd.concat(full_results)\n",
    "\n",
    "if horizon is None:\n",
    "    results = full_results\n",
    "else:\n",
    "    results = full_results.query(f\"horizon=={horizon}\")\n",
    "\n",
    "print(f\"#successful experiments: {len(results)}.\")\n",
    "results.head()"
   ],
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "#successful experiments: 540.\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "        training_time  metric_train  metric_val  metric_test  \\\n",
       "run_id                                                         \n",
       "181          3.260191      5.651333    4.815913     6.471306   \n",
       "182          3.274268      6.657193    5.122302    10.640561   \n",
       "183          3.289046      6.107795    6.670335     6.096897   \n",
       "184          3.285753      5.653665    6.215965     5.706885   \n",
       "185          3.296446      5.563153    5.271212     6.660690   \n",
       "\n",
       "        prediction_time_train  prediction_time_val  prediction_time_test  \\\n",
       "run_id                                                                     \n",
       "181                  4.169002             1.185535              0.562640   \n",
       "182                  4.160558             1.182529              0.560992   \n",
       "183                  4.159803             1.184812              0.561784   \n",
       "184                  4.168880             1.181046              0.560736   \n",
       "185                  4.195244             1.193811              0.567138   \n",
       "\n",
       "        config_id              data_folder       output_folder  \\\n",
       "run_id                                                           \n",
       "181            36  real_world/data/weather  weather/output/esn   \n",
       "182            36  real_world/data/weather  weather/output/esn   \n",
       "183            36  real_world/data/weather  weather/output/esn   \n",
       "184            36  real_world/data/weather  weather/output/esn   \n",
       "185            36  real_world/data/weather  weather/output/esn   \n",
       "\n",
       "        save_predictions    target  horizon  time_delay model_name  width  \\\n",
       "run_id                                                                      \n",
       "181                False  T (degC)      168         168        esn     16   \n",
       "182                False  T (degC)      168         168        esn     16   \n",
       "183                False  T (degC)      168         168        esn     16   \n",
       "184                False  T (degC)      168         168        esn     16   \n",
       "185                False  T (degC)      168         168        esn     16   \n",
       "\n",
       "       activation  regularization        seed   sr  \n",
       "run_id                                              \n",
       "181          tanh            0.01  2014450023  0.1  \n",
       "182          tanh            0.01   327087749  0.1  \n",
       "183          tanh            0.01  1068008205  0.1  \n",
       "184          tanh            0.01  1495336618  0.1  \n",
       "185          tanh            0.01  1064348452  0.1  "
      ],
      "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>training_time</th>\n",
       "      <th>metric_train</th>\n",
       "      <th>metric_val</th>\n",
       "      <th>metric_test</th>\n",
       "      <th>prediction_time_train</th>\n",
       "      <th>prediction_time_val</th>\n",
       "      <th>prediction_time_test</th>\n",
       "      <th>config_id</th>\n",
       "      <th>data_folder</th>\n",
       "      <th>output_folder</th>\n",
       "      <th>save_predictions</th>\n",
       "      <th>target</th>\n",
       "      <th>horizon</th>\n",
       "      <th>time_delay</th>\n",
       "      <th>model_name</th>\n",
       "      <th>width</th>\n",
       "      <th>activation</th>\n",
       "      <th>regularization</th>\n",
       "      <th>seed</th>\n",
       "      <th>sr</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>run_id</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></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>181</th>\n",
       "      <td>3.260191</td>\n",
       "      <td>5.651333</td>\n",
       "      <td>4.815913</td>\n",
       "      <td>6.471306</td>\n",
       "      <td>4.169002</td>\n",
       "      <td>1.185535</td>\n",
       "      <td>0.562640</td>\n",
       "      <td>36</td>\n",
       "      <td>real_world/data/weather</td>\n",
       "      <td>weather/output/esn</td>\n",
       "      <td>False</td>\n",
       "      <td>T (degC)</td>\n",
       "      <td>168</td>\n",
       "      <td>168</td>\n",
       "      <td>esn</td>\n",
       "      <td>16</td>\n",
       "      <td>tanh</td>\n",
       "      <td>0.01</td>\n",
       "      <td>2014450023</td>\n",
       "      <td>0.1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>182</th>\n",
       "      <td>3.274268</td>\n",
       "      <td>6.657193</td>\n",
       "      <td>5.122302</td>\n",
       "      <td>10.640561</td>\n",
       "      <td>4.160558</td>\n",
       "      <td>1.182529</td>\n",
       "      <td>0.560992</td>\n",
       "      <td>36</td>\n",
       "      <td>real_world/data/weather</td>\n",
       "      <td>weather/output/esn</td>\n",
       "      <td>False</td>\n",
       "      <td>T (degC)</td>\n",
       "      <td>168</td>\n",
       "      <td>168</td>\n",
       "      <td>esn</td>\n",
       "      <td>16</td>\n",
       "      <td>tanh</td>\n",
       "      <td>0.01</td>\n",
       "      <td>327087749</td>\n",
       "      <td>0.1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>183</th>\n",
       "      <td>3.289046</td>\n",
       "      <td>6.107795</td>\n",
       "      <td>6.670335</td>\n",
       "      <td>6.096897</td>\n",
       "      <td>4.159803</td>\n",
       "      <td>1.184812</td>\n",
       "      <td>0.561784</td>\n",
       "      <td>36</td>\n",
       "      <td>real_world/data/weather</td>\n",
       "      <td>weather/output/esn</td>\n",
       "      <td>False</td>\n",
       "      <td>T (degC)</td>\n",
       "      <td>168</td>\n",
       "      <td>168</td>\n",
       "      <td>esn</td>\n",
       "      <td>16</td>\n",
       "      <td>tanh</td>\n",
       "      <td>0.01</td>\n",
       "      <td>1068008205</td>\n",
       "      <td>0.1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>184</th>\n",
       "      <td>3.285753</td>\n",
       "      <td>5.653665</td>\n",
       "      <td>6.215965</td>\n",
       "      <td>5.706885</td>\n",
       "      <td>4.168880</td>\n",
       "      <td>1.181046</td>\n",
       "      <td>0.560736</td>\n",
       "      <td>36</td>\n",
       "      <td>real_world/data/weather</td>\n",
       "      <td>weather/output/esn</td>\n",
       "      <td>False</td>\n",
       "      <td>T (degC)</td>\n",
       "      <td>168</td>\n",
       "      <td>168</td>\n",
       "      <td>esn</td>\n",
       "      <td>16</td>\n",
       "      <td>tanh</td>\n",
       "      <td>0.01</td>\n",
       "      <td>1495336618</td>\n",
       "      <td>0.1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>185</th>\n",
       "      <td>3.296446</td>\n",
       "      <td>5.563153</td>\n",
       "      <td>5.271212</td>\n",
       "      <td>6.660690</td>\n",
       "      <td>4.195244</td>\n",
       "      <td>1.193811</td>\n",
       "      <td>0.567138</td>\n",
       "      <td>36</td>\n",
       "      <td>real_world/data/weather</td>\n",
       "      <td>weather/output/esn</td>\n",
       "      <td>False</td>\n",
       "      <td>T (degC)</td>\n",
       "      <td>168</td>\n",
       "      <td>168</td>\n",
       "      <td>esn</td>\n",
       "      <td>16</td>\n",
       "      <td>tanh</td>\n",
       "      <td>0.01</td>\n",
       "      <td>1064348452</td>\n",
       "      <td>0.1</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "execution_count": 2
  },
  {
   "cell_type": "code",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-04-14T14:10:56.802692Z",
     "start_time": "2025-04-14T14:10:56.779961Z"
    }
   },
   "source": [
    "TARGET = \"metric_val\"\n",
    "METRIC_COLUMNS = [\n",
    "    \"prediction_time_train\",\n",
    "    \"prediction_time_val\",\n",
    "    \"prediction_time_test\",\n",
    "    \"training_time\",\n",
    "    \"metric_train\",\n",
    "    \"metric_val\",\n",
    "    \"metric_test\",\n",
    "]\n",
    "\n",
    "metrics = results.groupby([\"config_id\", \"sr\"])[METRIC_COLUMNS].mean()\n",
    "metrics.sort_values(by=TARGET)"
   ],
   "outputs": [
    {
     "data": {
      "text/plain": [
       "               prediction_time_train  prediction_time_val  \\\n",
       "config_id sr                                                \n",
       "42        0.1               4.203791             1.190298   \n",
       "          0.5               4.164296             1.180372   \n",
       "36        0.1               4.170697             1.185547   \n",
       "          0.5               4.135839             1.173270   \n",
       "          1.0               4.186395             1.187245   \n",
       "...                              ...                  ...   \n",
       "60        0.1               5.569457             1.580814   \n",
       "          1.0               5.583005             1.585175   \n",
       "66        1.0               9.043233             2.559684   \n",
       "          0.5               9.045470             2.570967   \n",
       "          0.1               8.995337             2.543631   \n",
       "\n",
       "               prediction_time_test  training_time  metric_train  metric_val  \\\n",
       "config_id sr                                                                   \n",
       "42        0.1              0.565184       3.490122      5.541486    5.168943   \n",
       "          0.5              0.558467       3.479677      5.695142    5.529932   \n",
       "36        0.1              0.562658       3.281141      5.926628    5.619145   \n",
       "          0.5              0.557782       3.275795      6.142769    5.782368   \n",
       "          1.0              0.555274       3.290470      6.214659    5.925301   \n",
       "...                             ...            ...           ...         ...   \n",
       "60        0.1              0.750234       4.795971     13.934086   14.024009   \n",
       "          1.0              0.752076       4.809385     13.133029   14.540905   \n",
       "66        1.0              1.216835       6.956398     20.167560   20.014916   \n",
       "          0.5              1.217260       6.978137     21.711924   23.864725   \n",
       "          0.1              1.207467       6.951315     25.647054   28.974943   \n",
       "\n",
       "               metric_test  \n",
       "config_id sr                \n",
       "42        0.1     7.237951  \n",
       "          0.5     7.252184  \n",
       "36        0.1     7.115268  \n",
       "          0.5     7.096135  \n",
       "          1.0     7.053300  \n",
       "...                    ...  \n",
       "60        0.1    16.637779  \n",
       "          1.0    15.108081  \n",
       "66        1.0    23.369281  \n",
       "          0.5    24.084911  \n",
       "          0.1    31.729905  \n",
       "\n",
       "[108 rows x 7 columns]"
      ],
      "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></th>\n",
       "      <th>prediction_time_train</th>\n",
       "      <th>prediction_time_val</th>\n",
       "      <th>prediction_time_test</th>\n",
       "      <th>training_time</th>\n",
       "      <th>metric_train</th>\n",
       "      <th>metric_val</th>\n",
       "      <th>metric_test</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>config_id</th>\n",
       "      <th>sr</th>\n",
       "      <th></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 rowspan=\"2\" valign=\"top\">42</th>\n",
       "      <th>0.1</th>\n",
       "      <td>4.203791</td>\n",
       "      <td>1.190298</td>\n",
       "      <td>0.565184</td>\n",
       "      <td>3.490122</td>\n",
       "      <td>5.541486</td>\n",
       "      <td>5.168943</td>\n",
       "      <td>7.237951</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.5</th>\n",
       "      <td>4.164296</td>\n",
       "      <td>1.180372</td>\n",
       "      <td>0.558467</td>\n",
       "      <td>3.479677</td>\n",
       "      <td>5.695142</td>\n",
       "      <td>5.529932</td>\n",
       "      <td>7.252184</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"3\" valign=\"top\">36</th>\n",
       "      <th>0.1</th>\n",
       "      <td>4.170697</td>\n",
       "      <td>1.185547</td>\n",
       "      <td>0.562658</td>\n",
       "      <td>3.281141</td>\n",
       "      <td>5.926628</td>\n",
       "      <td>5.619145</td>\n",
       "      <td>7.115268</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.5</th>\n",
       "      <td>4.135839</td>\n",
       "      <td>1.173270</td>\n",
       "      <td>0.557782</td>\n",
       "      <td>3.275795</td>\n",
       "      <td>6.142769</td>\n",
       "      <td>5.782368</td>\n",
       "      <td>7.096135</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1.0</th>\n",
       "      <td>4.186395</td>\n",
       "      <td>1.187245</td>\n",
       "      <td>0.555274</td>\n",
       "      <td>3.290470</td>\n",
       "      <td>6.214659</td>\n",
       "      <td>5.925301</td>\n",
       "      <td>7.053300</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">60</th>\n",
       "      <th>0.1</th>\n",
       "      <td>5.569457</td>\n",
       "      <td>1.580814</td>\n",
       "      <td>0.750234</td>\n",
       "      <td>4.795971</td>\n",
       "      <td>13.934086</td>\n",
       "      <td>14.024009</td>\n",
       "      <td>16.637779</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1.0</th>\n",
       "      <td>5.583005</td>\n",
       "      <td>1.585175</td>\n",
       "      <td>0.752076</td>\n",
       "      <td>4.809385</td>\n",
       "      <td>13.133029</td>\n",
       "      <td>14.540905</td>\n",
       "      <td>15.108081</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"3\" valign=\"top\">66</th>\n",
       "      <th>1.0</th>\n",
       "      <td>9.043233</td>\n",
       "      <td>2.559684</td>\n",
       "      <td>1.216835</td>\n",
       "      <td>6.956398</td>\n",
       "      <td>20.167560</td>\n",
       "      <td>20.014916</td>\n",
       "      <td>23.369281</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.5</th>\n",
       "      <td>9.045470</td>\n",
       "      <td>2.570967</td>\n",
       "      <td>1.217260</td>\n",
       "      <td>6.978137</td>\n",
       "      <td>21.711924</td>\n",
       "      <td>23.864725</td>\n",
       "      <td>24.084911</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.1</th>\n",
       "      <td>8.995337</td>\n",
       "      <td>2.543631</td>\n",
       "      <td>1.207467</td>\n",
       "      <td>6.951315</td>\n",
       "      <td>25.647054</td>\n",
       "      <td>28.974943</td>\n",
       "      <td>31.729905</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>108 rows × 7 columns</p>\n",
       "</div>"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "execution_count": 3
  },
  {
   "cell_type": "code",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-04-14T14:10:59.472734Z",
     "start_time": "2025-04-14T14:10:59.432255Z"
    }
   },
   "source": [
    "best_config_id = metrics.index[metrics[TARGET].argmin()]\n",
    "print(f\"Best config: #{best_config_id}.\")\n",
    "print(\"Aggregated metrics of the best config:\")\n",
    "display(metrics.query(f\"config_id=={best_config_id}\"))\n",
    "\n",
    "print(\"All runs of the best config:\")\n",
    "best_runs = results.query(f\"config_id=={best_config_id}\")\n",
    "best_runs"
   ],
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Best config: #(42, 0.1).\n",
      "Aggregated metrics of the best config:\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "               prediction_time_train  prediction_time_val  \\\n",
       "config_id sr                                                \n",
       "42        0.1               4.203791             1.190298   \n",
       "          0.5               4.164296             1.180372   \n",
       "          1.0               4.231763             1.199878   \n",
       "\n",
       "               prediction_time_test  training_time  metric_train  metric_val  \\\n",
       "config_id sr                                                                   \n",
       "42        0.1              0.565184       3.490122      5.541486    5.168943   \n",
       "          0.5              0.558467       3.479677      5.695142    5.529932   \n",
       "          1.0              0.565597       3.503150      6.240941    6.179634   \n",
       "\n",
       "               metric_test  \n",
       "config_id sr                \n",
       "42        0.1     7.237951  \n",
       "          0.5     7.252184  \n",
       "          1.0     7.160442  "
      ],
      "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></th>\n",
       "      <th>prediction_time_train</th>\n",
       "      <th>prediction_time_val</th>\n",
       "      <th>prediction_time_test</th>\n",
       "      <th>training_time</th>\n",
       "      <th>metric_train</th>\n",
       "      <th>metric_val</th>\n",
       "      <th>metric_test</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>config_id</th>\n",
       "      <th>sr</th>\n",
       "      <th></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 rowspan=\"3\" valign=\"top\">42</th>\n",
       "      <th>0.1</th>\n",
       "      <td>4.203791</td>\n",
       "      <td>1.190298</td>\n",
       "      <td>0.565184</td>\n",
       "      <td>3.490122</td>\n",
       "      <td>5.541486</td>\n",
       "      <td>5.168943</td>\n",
       "      <td>7.237951</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.5</th>\n",
       "      <td>4.164296</td>\n",
       "      <td>1.180372</td>\n",
       "      <td>0.558467</td>\n",
       "      <td>3.479677</td>\n",
       "      <td>5.695142</td>\n",
       "      <td>5.529932</td>\n",
       "      <td>7.252184</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1.0</th>\n",
       "      <td>4.231763</td>\n",
       "      <td>1.199878</td>\n",
       "      <td>0.565597</td>\n",
       "      <td>3.503150</td>\n",
       "      <td>6.240941</td>\n",
       "      <td>6.179634</td>\n",
       "      <td>7.160442</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "All runs of the best config:\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "        training_time  metric_train  metric_val  metric_test  \\\n",
       "run_id                                                         \n",
       "211          3.480714      5.374428    4.446005     7.271983   \n",
       "212          3.483549      5.282956    4.586865     6.143739   \n",
       "213          3.500126      5.566571    5.184211     8.109533   \n",
       "214          3.489349      5.465673    5.195425     7.514772   \n",
       "215          3.496871      6.017803    6.432208     7.149729   \n",
       "211          3.478470      5.993057    5.597686     7.075673   \n",
       "212          3.473469      5.687391    5.397681     6.772804   \n",
       "213          3.475978      5.464342    4.974224     7.276380   \n",
       "214          3.482162      5.342690    5.272342     6.751494   \n",
       "215          3.488306      5.988232    6.407726     8.384568   \n",
       "211          3.490283      6.601136    6.368860     7.774004   \n",
       "212          3.498182      6.452692    6.478334     6.576201   \n",
       "213          3.498506      6.098786    6.140010     7.411731   \n",
       "214          3.511989      5.708517    5.675265     5.885808   \n",
       "215          3.516792      6.343573    6.235701     8.154469   \n",
       "\n",
       "        prediction_time_train  prediction_time_val  prediction_time_test  \\\n",
       "run_id                                                                     \n",
       "211                  4.193465             1.191049              0.565547   \n",
       "212                  4.200902             1.189104              0.565443   \n",
       "213                  4.205508             1.190764              0.565956   \n",
       "214                  4.215994             1.190228              0.564310   \n",
       "215                  4.203085             1.190343              0.564666   \n",
       "211                  4.149627             1.177571              0.558135   \n",
       "212                  4.160464             1.183861              0.563732   \n",
       "213                  4.172229             1.181620              0.542556   \n",
       "214                  4.172679             1.191524              0.566117   \n",
       "215                  4.166484             1.167286              0.561794   \n",
       "211                  4.202664             1.194351              0.566406   \n",
       "212                  4.237632             1.201076              0.571187   \n",
       "213                  4.250300             1.201807              0.571954   \n",
       "214                  4.237736             1.203578              0.549895   \n",
       "215                  4.230481             1.198575              0.568542   \n",
       "\n",
       "        config_id              data_folder       output_folder  \\\n",
       "run_id                                                           \n",
       "211            42  real_world/data/weather  weather/output/esn   \n",
       "212            42  real_world/data/weather  weather/output/esn   \n",
       "213            42  real_world/data/weather  weather/output/esn   \n",
       "214            42  real_world/data/weather  weather/output/esn   \n",
       "215            42  real_world/data/weather  weather/output/esn   \n",
       "211            42  real_world/data/weather  weather/output/esn   \n",
       "212            42  real_world/data/weather  weather/output/esn   \n",
       "213            42  real_world/data/weather  weather/output/esn   \n",
       "214            42  real_world/data/weather  weather/output/esn   \n",
       "215            42  real_world/data/weather  weather/output/esn   \n",
       "211            42  real_world/data/weather  weather/output/esn   \n",
       "212            42  real_world/data/weather  weather/output/esn   \n",
       "213            42  real_world/data/weather  weather/output/esn   \n",
       "214            42  real_world/data/weather  weather/output/esn   \n",
       "215            42  real_world/data/weather  weather/output/esn   \n",
       "\n",
       "        save_predictions    target  horizon  time_delay model_name  width  \\\n",
       "run_id                                                                      \n",
       "211                False  T (degC)      168         168        esn     32   \n",
       "212                False  T (degC)      168         168        esn     32   \n",
       "213                False  T (degC)      168         168        esn     32   \n",
       "214                False  T (degC)      168         168        esn     32   \n",
       "215                False  T (degC)      168         168        esn     32   \n",
       "211                False  T (degC)      168         168        esn     32   \n",
       "212                False  T (degC)      168         168        esn     32   \n",
       "213                False  T (degC)      168         168        esn     32   \n",
       "214                False  T (degC)      168         168        esn     32   \n",
       "215                False  T (degC)      168         168        esn     32   \n",
       "211                False  T (degC)      168         168        esn     32   \n",
       "212                False  T (degC)      168         168        esn     32   \n",
       "213                False  T (degC)      168         168        esn     32   \n",
       "214                False  T (degC)      168         168        esn     32   \n",
       "215                False  T (degC)      168         168        esn     32   \n",
       "\n",
       "       activation  regularization        seed   sr  \n",
       "run_id                                              \n",
       "211          tanh            0.01   560793881  0.1  \n",
       "212          tanh            0.01  1539509957  0.1  \n",
       "213          tanh            0.01  1694378689  0.1  \n",
       "214          tanh            0.01   964996477  0.1  \n",
       "215          tanh            0.01  1582522787  0.1  \n",
       "211          tanh            0.01   560793881  0.5  \n",
       "212          tanh            0.01  1539509957  0.5  \n",
       "213          tanh            0.01  1694378689  0.5  \n",
       "214          tanh            0.01   964996477  0.5  \n",
       "215          tanh            0.01  1582522787  0.5  \n",
       "211          tanh            0.01   560793881  1.0  \n",
       "212          tanh            0.01  1539509957  1.0  \n",
       "213          tanh            0.01  1694378689  1.0  \n",
       "214          tanh            0.01   964996477  1.0  \n",
       "215          tanh            0.01  1582522787  1.0  "
      ],
      "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>training_time</th>\n",
       "      <th>metric_train</th>\n",
       "      <th>metric_val</th>\n",
       "      <th>metric_test</th>\n",
       "      <th>prediction_time_train</th>\n",
       "      <th>prediction_time_val</th>\n",
       "      <th>prediction_time_test</th>\n",
       "      <th>config_id</th>\n",
       "      <th>data_folder</th>\n",
       "      <th>output_folder</th>\n",
       "      <th>save_predictions</th>\n",
       "      <th>target</th>\n",
       "      <th>horizon</th>\n",
       "      <th>time_delay</th>\n",
       "      <th>model_name</th>\n",
       "      <th>width</th>\n",
       "      <th>activation</th>\n",
       "      <th>regularization</th>\n",
       "      <th>seed</th>\n",
       "      <th>sr</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>run_id</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></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>211</th>\n",
       "      <td>3.480714</td>\n",
       "      <td>5.374428</td>\n",
       "      <td>4.446005</td>\n",
       "      <td>7.271983</td>\n",
       "      <td>4.193465</td>\n",
       "      <td>1.191049</td>\n",
       "      <td>0.565547</td>\n",
       "      <td>42</td>\n",
       "      <td>real_world/data/weather</td>\n",
       "      <td>weather/output/esn</td>\n",
       "      <td>False</td>\n",
       "      <td>T (degC)</td>\n",
       "      <td>168</td>\n",
       "      <td>168</td>\n",
       "      <td>esn</td>\n",
       "      <td>32</td>\n",
       "      <td>tanh</td>\n",
       "      <td>0.01</td>\n",
       "      <td>560793881</td>\n",
       "      <td>0.1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>212</th>\n",
       "      <td>3.483549</td>\n",
       "      <td>5.282956</td>\n",
       "      <td>4.586865</td>\n",
       "      <td>6.143739</td>\n",
       "      <td>4.200902</td>\n",
       "      <td>1.189104</td>\n",
       "      <td>0.565443</td>\n",
       "      <td>42</td>\n",
       "      <td>real_world/data/weather</td>\n",
       "      <td>weather/output/esn</td>\n",
       "      <td>False</td>\n",
       "      <td>T (degC)</td>\n",
       "      <td>168</td>\n",
       "      <td>168</td>\n",
       "      <td>esn</td>\n",
       "      <td>32</td>\n",
       "      <td>tanh</td>\n",
       "      <td>0.01</td>\n",
       "      <td>1539509957</td>\n",
       "      <td>0.1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>213</th>\n",
       "      <td>3.500126</td>\n",
       "      <td>5.566571</td>\n",
       "      <td>5.184211</td>\n",
       "      <td>8.109533</td>\n",
       "      <td>4.205508</td>\n",
       "      <td>1.190764</td>\n",
       "      <td>0.565956</td>\n",
       "      <td>42</td>\n",
       "      <td>real_world/data/weather</td>\n",
       "      <td>weather/output/esn</td>\n",
       "      <td>False</td>\n",
       "      <td>T (degC)</td>\n",
       "      <td>168</td>\n",
       "      <td>168</td>\n",
       "      <td>esn</td>\n",
       "      <td>32</td>\n",
       "      <td>tanh</td>\n",
       "      <td>0.01</td>\n",
       "      <td>1694378689</td>\n",
       "      <td>0.1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>214</th>\n",
       "      <td>3.489349</td>\n",
       "      <td>5.465673</td>\n",
       "      <td>5.195425</td>\n",
       "      <td>7.514772</td>\n",
       "      <td>4.215994</td>\n",
       "      <td>1.190228</td>\n",
       "      <td>0.564310</td>\n",
       "      <td>42</td>\n",
       "      <td>real_world/data/weather</td>\n",
       "      <td>weather/output/esn</td>\n",
       "      <td>False</td>\n",
       "      <td>T (degC)</td>\n",
       "      <td>168</td>\n",
       "      <td>168</td>\n",
       "      <td>esn</td>\n",
       "      <td>32</td>\n",
       "      <td>tanh</td>\n",
       "      <td>0.01</td>\n",
       "      <td>964996477</td>\n",
       "      <td>0.1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>215</th>\n",
       "      <td>3.496871</td>\n",
       "      <td>6.017803</td>\n",
       "      <td>6.432208</td>\n",
       "      <td>7.149729</td>\n",
       "      <td>4.203085</td>\n",
       "      <td>1.190343</td>\n",
       "      <td>0.564666</td>\n",
       "      <td>42</td>\n",
       "      <td>real_world/data/weather</td>\n",
       "      <td>weather/output/esn</td>\n",
       "      <td>False</td>\n",
       "      <td>T (degC)</td>\n",
       "      <td>168</td>\n",
       "      <td>168</td>\n",
       "      <td>esn</td>\n",
       "      <td>32</td>\n",
       "      <td>tanh</td>\n",
       "      <td>0.01</td>\n",
       "      <td>1582522787</td>\n",
       "      <td>0.1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>211</th>\n",
       "      <td>3.478470</td>\n",
       "      <td>5.993057</td>\n",
       "      <td>5.597686</td>\n",
       "      <td>7.075673</td>\n",
       "      <td>4.149627</td>\n",
       "      <td>1.177571</td>\n",
       "      <td>0.558135</td>\n",
       "      <td>42</td>\n",
       "      <td>real_world/data/weather</td>\n",
       "      <td>weather/output/esn</td>\n",
       "      <td>False</td>\n",
       "      <td>T (degC)</td>\n",
       "      <td>168</td>\n",
       "      <td>168</td>\n",
       "      <td>esn</td>\n",
       "      <td>32</td>\n",
       "      <td>tanh</td>\n",
       "      <td>0.01</td>\n",
       "      <td>560793881</td>\n",
       "      <td>0.5</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>212</th>\n",
       "      <td>3.473469</td>\n",
       "      <td>5.687391</td>\n",
       "      <td>5.397681</td>\n",
       "      <td>6.772804</td>\n",
       "      <td>4.160464</td>\n",
       "      <td>1.183861</td>\n",
       "      <td>0.563732</td>\n",
       "      <td>42</td>\n",
       "      <td>real_world/data/weather</td>\n",
       "      <td>weather/output/esn</td>\n",
       "      <td>False</td>\n",
       "      <td>T (degC)</td>\n",
       "      <td>168</td>\n",
       "      <td>168</td>\n",
       "      <td>esn</td>\n",
       "      <td>32</td>\n",
       "      <td>tanh</td>\n",
       "      <td>0.01</td>\n",
       "      <td>1539509957</td>\n",
       "      <td>0.5</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>213</th>\n",
       "      <td>3.475978</td>\n",
       "      <td>5.464342</td>\n",
       "      <td>4.974224</td>\n",
       "      <td>7.276380</td>\n",
       "      <td>4.172229</td>\n",
       "      <td>1.181620</td>\n",
       "      <td>0.542556</td>\n",
       "      <td>42</td>\n",
       "      <td>real_world/data/weather</td>\n",
       "      <td>weather/output/esn</td>\n",
       "      <td>False</td>\n",
       "      <td>T (degC)</td>\n",
       "      <td>168</td>\n",
       "      <td>168</td>\n",
       "      <td>esn</td>\n",
       "      <td>32</td>\n",
       "      <td>tanh</td>\n",
       "      <td>0.01</td>\n",
       "      <td>1694378689</td>\n",
       "      <td>0.5</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>214</th>\n",
       "      <td>3.482162</td>\n",
       "      <td>5.342690</td>\n",
       "      <td>5.272342</td>\n",
       "      <td>6.751494</td>\n",
       "      <td>4.172679</td>\n",
       "      <td>1.191524</td>\n",
       "      <td>0.566117</td>\n",
       "      <td>42</td>\n",
       "      <td>real_world/data/weather</td>\n",
       "      <td>weather/output/esn</td>\n",
       "      <td>False</td>\n",
       "      <td>T (degC)</td>\n",
       "      <td>168</td>\n",
       "      <td>168</td>\n",
       "      <td>esn</td>\n",
       "      <td>32</td>\n",
       "      <td>tanh</td>\n",
       "      <td>0.01</td>\n",
       "      <td>964996477</td>\n",
       "      <td>0.5</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>215</th>\n",
       "      <td>3.488306</td>\n",
       "      <td>5.988232</td>\n",
       "      <td>6.407726</td>\n",
       "      <td>8.384568</td>\n",
       "      <td>4.166484</td>\n",
       "      <td>1.167286</td>\n",
       "      <td>0.561794</td>\n",
       "      <td>42</td>\n",
       "      <td>real_world/data/weather</td>\n",
       "      <td>weather/output/esn</td>\n",
       "      <td>False</td>\n",
       "      <td>T (degC)</td>\n",
       "      <td>168</td>\n",
       "      <td>168</td>\n",
       "      <td>esn</td>\n",
       "      <td>32</td>\n",
       "      <td>tanh</td>\n",
       "      <td>0.01</td>\n",
       "      <td>1582522787</td>\n",
       "      <td>0.5</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>211</th>\n",
       "      <td>3.490283</td>\n",
       "      <td>6.601136</td>\n",
       "      <td>6.368860</td>\n",
       "      <td>7.774004</td>\n",
       "      <td>4.202664</td>\n",
       "      <td>1.194351</td>\n",
       "      <td>0.566406</td>\n",
       "      <td>42</td>\n",
       "      <td>real_world/data/weather</td>\n",
       "      <td>weather/output/esn</td>\n",
       "      <td>False</td>\n",
       "      <td>T (degC)</td>\n",
       "      <td>168</td>\n",
       "      <td>168</td>\n",
       "      <td>esn</td>\n",
       "      <td>32</td>\n",
       "      <td>tanh</td>\n",
       "      <td>0.01</td>\n",
       "      <td>560793881</td>\n",
       "      <td>1.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>212</th>\n",
       "      <td>3.498182</td>\n",
       "      <td>6.452692</td>\n",
       "      <td>6.478334</td>\n",
       "      <td>6.576201</td>\n",
       "      <td>4.237632</td>\n",
       "      <td>1.201076</td>\n",
       "      <td>0.571187</td>\n",
       "      <td>42</td>\n",
       "      <td>real_world/data/weather</td>\n",
       "      <td>weather/output/esn</td>\n",
       "      <td>False</td>\n",
       "      <td>T (degC)</td>\n",
       "      <td>168</td>\n",
       "      <td>168</td>\n",
       "      <td>esn</td>\n",
       "      <td>32</td>\n",
       "      <td>tanh</td>\n",
       "      <td>0.01</td>\n",
       "      <td>1539509957</td>\n",
       "      <td>1.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>213</th>\n",
       "      <td>3.498506</td>\n",
       "      <td>6.098786</td>\n",
       "      <td>6.140010</td>\n",
       "      <td>7.411731</td>\n",
       "      <td>4.250300</td>\n",
       "      <td>1.201807</td>\n",
       "      <td>0.571954</td>\n",
       "      <td>42</td>\n",
       "      <td>real_world/data/weather</td>\n",
       "      <td>weather/output/esn</td>\n",
       "      <td>False</td>\n",
       "      <td>T (degC)</td>\n",
       "      <td>168</td>\n",
       "      <td>168</td>\n",
       "      <td>esn</td>\n",
       "      <td>32</td>\n",
       "      <td>tanh</td>\n",
       "      <td>0.01</td>\n",
       "      <td>1694378689</td>\n",
       "      <td>1.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>214</th>\n",
       "      <td>3.511989</td>\n",
       "      <td>5.708517</td>\n",
       "      <td>5.675265</td>\n",
       "      <td>5.885808</td>\n",
       "      <td>4.237736</td>\n",
       "      <td>1.203578</td>\n",
       "      <td>0.549895</td>\n",
       "      <td>42</td>\n",
       "      <td>real_world/data/weather</td>\n",
       "      <td>weather/output/esn</td>\n",
       "      <td>False</td>\n",
       "      <td>T (degC)</td>\n",
       "      <td>168</td>\n",
       "      <td>168</td>\n",
       "      <td>esn</td>\n",
       "      <td>32</td>\n",
       "      <td>tanh</td>\n",
       "      <td>0.01</td>\n",
       "      <td>964996477</td>\n",
       "      <td>1.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>215</th>\n",
       "      <td>3.516792</td>\n",
       "      <td>6.343573</td>\n",
       "      <td>6.235701</td>\n",
       "      <td>8.154469</td>\n",
       "      <td>4.230481</td>\n",
       "      <td>1.198575</td>\n",
       "      <td>0.568542</td>\n",
       "      <td>42</td>\n",
       "      <td>real_world/data/weather</td>\n",
       "      <td>weather/output/esn</td>\n",
       "      <td>False</td>\n",
       "      <td>T (degC)</td>\n",
       "      <td>168</td>\n",
       "      <td>168</td>\n",
       "      <td>esn</td>\n",
       "      <td>32</td>\n",
       "      <td>tanh</td>\n",
       "      <td>0.01</td>\n",
       "      <td>1582522787</td>\n",
       "      <td>1.0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "execution_count": 4
  },
  {
   "metadata": {},
   "cell_type": "code",
   "outputs": [],
   "execution_count": null,
   "source": ""
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "swimrnn",
   "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.11.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
