{
 "cells": [
  {
   "cell_type": "code",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2026-03-02T09:00:49.323997012Z",
     "start_time": "2026-03-02T09:00:48.705710137Z"
    }
   },
   "source": [
    "import pandas as pd\n",
    "\n",
    "\n",
    "MODEL = \"esn\"  # can be \"kirnn\" or \"esn\"\n",
    "horizon = 120"
   ],
   "outputs": [],
   "execution_count": 1
  },
  {
   "cell_type": "code",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2026-03-02T09:02:30.158027552Z",
     "start_time": "2026-03-02T09:02:29.995759389Z"
    }
   },
   "source": [
    "results_csv = f\"./grid_results.csv\"\n",
    "results = pd.read_csv(results_csv, index_col=\"run_id\")\n",
    "results= results.loc[results[\"horizon\"]==horizon]\n",
    "print(f\"#successful experiments: {len(results)}.\")\n",
    "results.head()"
   ],
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "#successful experiments: 150.\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "        training_time  metric_train  metric_val  metric_test  \\\n",
       "run_id                                                         \n",
       "151          3.311489      2.346492    2.162257     2.541908   \n",
       "152          3.332146      2.341219    2.153706     2.238657   \n",
       "153          3.336969      2.367483    2.377168     2.594905   \n",
       "154          3.270136      2.351979    2.426246     2.458243   \n",
       "155          3.283732      2.236485    2.108236     2.255143   \n",
       "\n",
       "        prediction_time_train  prediction_time_val  prediction_time_test  \\\n",
       "run_id                                                                     \n",
       "151                  6.609277             3.400275              3.398109   \n",
       "152                  6.591604             3.245798              3.262887   \n",
       "153                  6.478596             3.212236              3.197541   \n",
       "154                  6.545033             3.261825              3.308389   \n",
       "155                  6.755427             3.284749              3.246305   \n",
       "\n",
       "        config_id                  data_folder  \\\n",
       "run_id                                           \n",
       "151            30  real_world/data/electricity   \n",
       "152            30  real_world/data/electricity   \n",
       "153            30  real_world/data/electricity   \n",
       "154            30  real_world/data/electricity   \n",
       "155            30  real_world/data/electricity   \n",
       "\n",
       "                                        output_folder  save_predictions  \\\n",
       "run_id                                                                    \n",
       "151     real_world/grid_search/output/electricity/esn              True   \n",
       "152     real_world/grid_search/output/electricity/esn              True   \n",
       "153     real_world/grid_search/output/electricity/esn              True   \n",
       "154     real_world/grid_search/output/electricity/esn              True   \n",
       "155     real_world/grid_search/output/electricity/esn              True   \n",
       "\n",
       "         target  horizon  time_delay model_name  width activation  \\\n",
       "run_id                                                              \n",
       "151     Voltage      120         240        esn     32       tanh   \n",
       "152     Voltage      120         240        esn     32       tanh   \n",
       "153     Voltage      120         240        esn     32       tanh   \n",
       "154     Voltage      120         240        esn     32       tanh   \n",
       "155     Voltage      120         240        esn     32       tanh   \n",
       "\n",
       "        regularization        seed  \n",
       "run_id                              \n",
       "151               0.01  1837539164  \n",
       "152               0.01   604267306  \n",
       "153               0.01  1970642945  \n",
       "154               0.01   630487793  \n",
       "155               0.01   932688237  "
      ],
      "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",
       "    </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",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>151</th>\n",
       "      <td>3.311489</td>\n",
       "      <td>2.346492</td>\n",
       "      <td>2.162257</td>\n",
       "      <td>2.541908</td>\n",
       "      <td>6.609277</td>\n",
       "      <td>3.400275</td>\n",
       "      <td>3.398109</td>\n",
       "      <td>30</td>\n",
       "      <td>real_world/data/electricity</td>\n",
       "      <td>real_world/grid_search/output/electricity/esn</td>\n",
       "      <td>True</td>\n",
       "      <td>Voltage</td>\n",
       "      <td>120</td>\n",
       "      <td>240</td>\n",
       "      <td>esn</td>\n",
       "      <td>32</td>\n",
       "      <td>tanh</td>\n",
       "      <td>0.01</td>\n",
       "      <td>1837539164</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>152</th>\n",
       "      <td>3.332146</td>\n",
       "      <td>2.341219</td>\n",
       "      <td>2.153706</td>\n",
       "      <td>2.238657</td>\n",
       "      <td>6.591604</td>\n",
       "      <td>3.245798</td>\n",
       "      <td>3.262887</td>\n",
       "      <td>30</td>\n",
       "      <td>real_world/data/electricity</td>\n",
       "      <td>real_world/grid_search/output/electricity/esn</td>\n",
       "      <td>True</td>\n",
       "      <td>Voltage</td>\n",
       "      <td>120</td>\n",
       "      <td>240</td>\n",
       "      <td>esn</td>\n",
       "      <td>32</td>\n",
       "      <td>tanh</td>\n",
       "      <td>0.01</td>\n",
       "      <td>604267306</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>153</th>\n",
       "      <td>3.336969</td>\n",
       "      <td>2.367483</td>\n",
       "      <td>2.377168</td>\n",
       "      <td>2.594905</td>\n",
       "      <td>6.478596</td>\n",
       "      <td>3.212236</td>\n",
       "      <td>3.197541</td>\n",
       "      <td>30</td>\n",
       "      <td>real_world/data/electricity</td>\n",
       "      <td>real_world/grid_search/output/electricity/esn</td>\n",
       "      <td>True</td>\n",
       "      <td>Voltage</td>\n",
       "      <td>120</td>\n",
       "      <td>240</td>\n",
       "      <td>esn</td>\n",
       "      <td>32</td>\n",
       "      <td>tanh</td>\n",
       "      <td>0.01</td>\n",
       "      <td>1970642945</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>154</th>\n",
       "      <td>3.270136</td>\n",
       "      <td>2.351979</td>\n",
       "      <td>2.426246</td>\n",
       "      <td>2.458243</td>\n",
       "      <td>6.545033</td>\n",
       "      <td>3.261825</td>\n",
       "      <td>3.308389</td>\n",
       "      <td>30</td>\n",
       "      <td>real_world/data/electricity</td>\n",
       "      <td>real_world/grid_search/output/electricity/esn</td>\n",
       "      <td>True</td>\n",
       "      <td>Voltage</td>\n",
       "      <td>120</td>\n",
       "      <td>240</td>\n",
       "      <td>esn</td>\n",
       "      <td>32</td>\n",
       "      <td>tanh</td>\n",
       "      <td>0.01</td>\n",
       "      <td>630487793</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>155</th>\n",
       "      <td>3.283732</td>\n",
       "      <td>2.236485</td>\n",
       "      <td>2.108236</td>\n",
       "      <td>2.255143</td>\n",
       "      <td>6.755427</td>\n",
       "      <td>3.284749</td>\n",
       "      <td>3.246305</td>\n",
       "      <td>30</td>\n",
       "      <td>real_world/data/electricity</td>\n",
       "      <td>real_world/grid_search/output/electricity/esn</td>\n",
       "      <td>True</td>\n",
       "      <td>Voltage</td>\n",
       "      <td>120</td>\n",
       "      <td>240</td>\n",
       "      <td>esn</td>\n",
       "      <td>32</td>\n",
       "      <td>tanh</td>\n",
       "      <td>0.01</td>\n",
       "      <td>932688237</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": "2026-03-02T09:02:31.041534459Z",
     "start_time": "2026-03-02T09:02:30.907570407Z"
    }
   },
   "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\"])[METRIC_COLUMNS].mean()\n",
    "metrics.sort_values(by=TARGET)"
   ],
   "outputs": [
    {
     "data": {
      "text/plain": [
       "           prediction_time_train  prediction_time_val  prediction_time_test  \\\n",
       "config_id                                                                     \n",
       "30                      6.595987             3.280976              3.282646   \n",
       "37                      6.845273             3.394404              3.379193   \n",
       "31                      6.732718             3.338640              3.298011   \n",
       "36                      6.781650             3.383077              3.355979   \n",
       "43                      7.347684             3.688668              3.698792   \n",
       "44                      7.392444             3.674337              3.686056   \n",
       "40                      6.785307             3.403735              3.364345   \n",
       "32                      6.862879             3.417548              3.403201   \n",
       "38                      6.808111             3.388081              3.392020   \n",
       "34                      6.580747             3.264173              3.253320   \n",
       "53                      8.890142             4.448005              4.425794   \n",
       "39                      6.723122             3.311771              3.347458   \n",
       "41                      6.824314             3.445143              3.442809   \n",
       "33                      6.710388             3.346533              3.348099   \n",
       "45                      7.431560             3.683080              3.686294   \n",
       "46                      7.357040             3.672619              3.684615   \n",
       "57                     14.895329             7.384275              7.364916   \n",
       "52                      9.033533             4.481104              4.498579   \n",
       "50                      9.051130             4.486020              4.489603   \n",
       "49                      9.088365             4.514114              4.520867   \n",
       "59                     14.850105             7.339187              7.322935   \n",
       "56                     14.949909             7.394617              7.395217   \n",
       "35                      6.654063             3.287156              3.266504   \n",
       "51                      9.026589             4.470070              4.462172   \n",
       "55                     15.022482             7.439837              7.431012   \n",
       "47                      7.448269             3.694156              3.679521   \n",
       "58                     14.874679             7.414162              7.447611   \n",
       "42                      7.491351             3.711607              3.713622   \n",
       "48                      8.967950             4.487885              4.488822   \n",
       "54                     14.913169             7.380508              7.374769   \n",
       "\n",
       "           training_time  metric_train  metric_val  metric_test  \n",
       "config_id                                                        \n",
       "30              3.306894      2.328732    2.245523     2.417771  \n",
       "37              3.566493      2.730500    2.351771     2.613860  \n",
       "31              3.304837      2.788614    2.409906     2.609060  \n",
       "36              3.515536      2.485619    2.746732     2.678312  \n",
       "43              3.970958      3.036761    2.855067     2.936475  \n",
       "44              3.996310      3.398576    2.874448     3.164045  \n",
       "40              3.641080      3.003636    3.118957     3.049063  \n",
       "32              3.351863      3.270981    3.159067     3.144195  \n",
       "38              3.603886      3.209981    3.243379     3.047358  \n",
       "34              3.426107      3.541252    3.402193     3.279632  \n",
       "53              4.956123      3.889150    3.481858     3.587357  \n",
       "39              3.636466      3.450427    3.527518     3.287394  \n",
       "41              3.688805      3.703103    3.569868     3.561803  \n",
       "33              3.381453      3.685066    3.605754     3.386959  \n",
       "45              4.036903      3.617659    3.615576     3.723128  \n",
       "46              4.036414      3.718463    3.809748     3.801030  \n",
       "57              7.330680      4.353578    3.855104     4.214115  \n",
       "52              4.958272      4.124277    3.996505     3.931285  \n",
       "50              4.847196      3.930955    4.111137     3.931094  \n",
       "49              4.845516      4.015818    4.121050     3.987677  \n",
       "59              7.412379      4.735378    4.327055     4.459777  \n",
       "56              7.283796      4.469795    4.352692     4.318511  \n",
       "35              3.428413      4.291838    4.488896     4.189960  \n",
       "51              4.899781      4.871015    4.869102     4.608062  \n",
       "55              7.259230      5.285105    5.154005     5.443120  \n",
       "47              4.107392      4.535486    5.160896     4.470228  \n",
       "58              7.382973      4.867226    5.414109     4.786507  \n",
       "42              3.965871      6.127080    7.066321     7.936007  \n",
       "48              4.777773      7.524735    8.118106     7.992299  \n",
       "54              7.296141     17.368639   19.233720    20.015421  "
      ],
      "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>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></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>30</th>\n",
       "      <td>6.595987</td>\n",
       "      <td>3.280976</td>\n",
       "      <td>3.282646</td>\n",
       "      <td>3.306894</td>\n",
       "      <td>2.328732</td>\n",
       "      <td>2.245523</td>\n",
       "      <td>2.417771</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>37</th>\n",
       "      <td>6.845273</td>\n",
       "      <td>3.394404</td>\n",
       "      <td>3.379193</td>\n",
       "      <td>3.566493</td>\n",
       "      <td>2.730500</td>\n",
       "      <td>2.351771</td>\n",
       "      <td>2.613860</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>31</th>\n",
       "      <td>6.732718</td>\n",
       "      <td>3.338640</td>\n",
       "      <td>3.298011</td>\n",
       "      <td>3.304837</td>\n",
       "      <td>2.788614</td>\n",
       "      <td>2.409906</td>\n",
       "      <td>2.609060</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>36</th>\n",
       "      <td>6.781650</td>\n",
       "      <td>3.383077</td>\n",
       "      <td>3.355979</td>\n",
       "      <td>3.515536</td>\n",
       "      <td>2.485619</td>\n",
       "      <td>2.746732</td>\n",
       "      <td>2.678312</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>43</th>\n",
       "      <td>7.347684</td>\n",
       "      <td>3.688668</td>\n",
       "      <td>3.698792</td>\n",
       "      <td>3.970958</td>\n",
       "      <td>3.036761</td>\n",
       "      <td>2.855067</td>\n",
       "      <td>2.936475</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>44</th>\n",
       "      <td>7.392444</td>\n",
       "      <td>3.674337</td>\n",
       "      <td>3.686056</td>\n",
       "      <td>3.996310</td>\n",
       "      <td>3.398576</td>\n",
       "      <td>2.874448</td>\n",
       "      <td>3.164045</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>40</th>\n",
       "      <td>6.785307</td>\n",
       "      <td>3.403735</td>\n",
       "      <td>3.364345</td>\n",
       "      <td>3.641080</td>\n",
       "      <td>3.003636</td>\n",
       "      <td>3.118957</td>\n",
       "      <td>3.049063</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>32</th>\n",
       "      <td>6.862879</td>\n",
       "      <td>3.417548</td>\n",
       "      <td>3.403201</td>\n",
       "      <td>3.351863</td>\n",
       "      <td>3.270981</td>\n",
       "      <td>3.159067</td>\n",
       "      <td>3.144195</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>38</th>\n",
       "      <td>6.808111</td>\n",
       "      <td>3.388081</td>\n",
       "      <td>3.392020</td>\n",
       "      <td>3.603886</td>\n",
       "      <td>3.209981</td>\n",
       "      <td>3.243379</td>\n",
       "      <td>3.047358</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>34</th>\n",
       "      <td>6.580747</td>\n",
       "      <td>3.264173</td>\n",
       "      <td>3.253320</td>\n",
       "      <td>3.426107</td>\n",
       "      <td>3.541252</td>\n",
       "      <td>3.402193</td>\n",
       "      <td>3.279632</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>53</th>\n",
       "      <td>8.890142</td>\n",
       "      <td>4.448005</td>\n",
       "      <td>4.425794</td>\n",
       "      <td>4.956123</td>\n",
       "      <td>3.889150</td>\n",
       "      <td>3.481858</td>\n",
       "      <td>3.587357</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>39</th>\n",
       "      <td>6.723122</td>\n",
       "      <td>3.311771</td>\n",
       "      <td>3.347458</td>\n",
       "      <td>3.636466</td>\n",
       "      <td>3.450427</td>\n",
       "      <td>3.527518</td>\n",
       "      <td>3.287394</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>41</th>\n",
       "      <td>6.824314</td>\n",
       "      <td>3.445143</td>\n",
       "      <td>3.442809</td>\n",
       "      <td>3.688805</td>\n",
       "      <td>3.703103</td>\n",
       "      <td>3.569868</td>\n",
       "      <td>3.561803</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>33</th>\n",
       "      <td>6.710388</td>\n",
       "      <td>3.346533</td>\n",
       "      <td>3.348099</td>\n",
       "      <td>3.381453</td>\n",
       "      <td>3.685066</td>\n",
       "      <td>3.605754</td>\n",
       "      <td>3.386959</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>45</th>\n",
       "      <td>7.431560</td>\n",
       "      <td>3.683080</td>\n",
       "      <td>3.686294</td>\n",
       "      <td>4.036903</td>\n",
       "      <td>3.617659</td>\n",
       "      <td>3.615576</td>\n",
       "      <td>3.723128</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>46</th>\n",
       "      <td>7.357040</td>\n",
       "      <td>3.672619</td>\n",
       "      <td>3.684615</td>\n",
       "      <td>4.036414</td>\n",
       "      <td>3.718463</td>\n",
       "      <td>3.809748</td>\n",
       "      <td>3.801030</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>57</th>\n",
       "      <td>14.895329</td>\n",
       "      <td>7.384275</td>\n",
       "      <td>7.364916</td>\n",
       "      <td>7.330680</td>\n",
       "      <td>4.353578</td>\n",
       "      <td>3.855104</td>\n",
       "      <td>4.214115</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>52</th>\n",
       "      <td>9.033533</td>\n",
       "      <td>4.481104</td>\n",
       "      <td>4.498579</td>\n",
       "      <td>4.958272</td>\n",
       "      <td>4.124277</td>\n",
       "      <td>3.996505</td>\n",
       "      <td>3.931285</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>50</th>\n",
       "      <td>9.051130</td>\n",
       "      <td>4.486020</td>\n",
       "      <td>4.489603</td>\n",
       "      <td>4.847196</td>\n",
       "      <td>3.930955</td>\n",
       "      <td>4.111137</td>\n",
       "      <td>3.931094</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>49</th>\n",
       "      <td>9.088365</td>\n",
       "      <td>4.514114</td>\n",
       "      <td>4.520867</td>\n",
       "      <td>4.845516</td>\n",
       "      <td>4.015818</td>\n",
       "      <td>4.121050</td>\n",
       "      <td>3.987677</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>59</th>\n",
       "      <td>14.850105</td>\n",
       "      <td>7.339187</td>\n",
       "      <td>7.322935</td>\n",
       "      <td>7.412379</td>\n",
       "      <td>4.735378</td>\n",
       "      <td>4.327055</td>\n",
       "      <td>4.459777</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>56</th>\n",
       "      <td>14.949909</td>\n",
       "      <td>7.394617</td>\n",
       "      <td>7.395217</td>\n",
       "      <td>7.283796</td>\n",
       "      <td>4.469795</td>\n",
       "      <td>4.352692</td>\n",
       "      <td>4.318511</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>35</th>\n",
       "      <td>6.654063</td>\n",
       "      <td>3.287156</td>\n",
       "      <td>3.266504</td>\n",
       "      <td>3.428413</td>\n",
       "      <td>4.291838</td>\n",
       "      <td>4.488896</td>\n",
       "      <td>4.189960</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>51</th>\n",
       "      <td>9.026589</td>\n",
       "      <td>4.470070</td>\n",
       "      <td>4.462172</td>\n",
       "      <td>4.899781</td>\n",
       "      <td>4.871015</td>\n",
       "      <td>4.869102</td>\n",
       "      <td>4.608062</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>55</th>\n",
       "      <td>15.022482</td>\n",
       "      <td>7.439837</td>\n",
       "      <td>7.431012</td>\n",
       "      <td>7.259230</td>\n",
       "      <td>5.285105</td>\n",
       "      <td>5.154005</td>\n",
       "      <td>5.443120</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>47</th>\n",
       "      <td>7.448269</td>\n",
       "      <td>3.694156</td>\n",
       "      <td>3.679521</td>\n",
       "      <td>4.107392</td>\n",
       "      <td>4.535486</td>\n",
       "      <td>5.160896</td>\n",
       "      <td>4.470228</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>58</th>\n",
       "      <td>14.874679</td>\n",
       "      <td>7.414162</td>\n",
       "      <td>7.447611</td>\n",
       "      <td>7.382973</td>\n",
       "      <td>4.867226</td>\n",
       "      <td>5.414109</td>\n",
       "      <td>4.786507</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>42</th>\n",
       "      <td>7.491351</td>\n",
       "      <td>3.711607</td>\n",
       "      <td>3.713622</td>\n",
       "      <td>3.965871</td>\n",
       "      <td>6.127080</td>\n",
       "      <td>7.066321</td>\n",
       "      <td>7.936007</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>48</th>\n",
       "      <td>8.967950</td>\n",
       "      <td>4.487885</td>\n",
       "      <td>4.488822</td>\n",
       "      <td>4.777773</td>\n",
       "      <td>7.524735</td>\n",
       "      <td>8.118106</td>\n",
       "      <td>7.992299</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>54</th>\n",
       "      <td>14.913169</td>\n",
       "      <td>7.380508</td>\n",
       "      <td>7.374769</td>\n",
       "      <td>7.296141</td>\n",
       "      <td>17.368639</td>\n",
       "      <td>19.233720</td>\n",
       "      <td>20.015421</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "execution_count": 3
  },
  {
   "cell_type": "code",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2026-03-02T09:02:32.584320316Z",
     "start_time": "2026-03-02T09:02:32.235081947Z"
    }
   },
   "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: #30.\n",
      "Aggregated metrics of the best config:\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "           prediction_time_train  prediction_time_val  prediction_time_test  \\\n",
       "config_id                                                                     \n",
       "30                      6.595987             3.280976              3.282646   \n",
       "\n",
       "           training_time  metric_train  metric_val  metric_test  \n",
       "config_id                                                        \n",
       "30              3.306894      2.328732    2.245523     2.417771  "
      ],
      "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>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></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>30</th>\n",
       "      <td>6.595987</td>\n",
       "      <td>3.280976</td>\n",
       "      <td>3.282646</td>\n",
       "      <td>3.306894</td>\n",
       "      <td>2.328732</td>\n",
       "      <td>2.245523</td>\n",
       "      <td>2.417771</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ]
     },
     "metadata": {},
     "output_type": "display_data",
     "jetTransient": {
      "display_id": null
     }
    },
    {
     "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",
       "151          3.311489      2.346492    2.162257     2.541908   \n",
       "152          3.332146      2.341219    2.153706     2.238657   \n",
       "153          3.336969      2.367483    2.377168     2.594905   \n",
       "154          3.270136      2.351979    2.426246     2.458243   \n",
       "155          3.283732      2.236485    2.108236     2.255143   \n",
       "\n",
       "        prediction_time_train  prediction_time_val  prediction_time_test  \\\n",
       "run_id                                                                     \n",
       "151                  6.609277             3.400275              3.398109   \n",
       "152                  6.591604             3.245798              3.262887   \n",
       "153                  6.478596             3.212236              3.197541   \n",
       "154                  6.545033             3.261825              3.308389   \n",
       "155                  6.755427             3.284749              3.246305   \n",
       "\n",
       "        config_id                  data_folder  \\\n",
       "run_id                                           \n",
       "151            30  real_world/data/electricity   \n",
       "152            30  real_world/data/electricity   \n",
       "153            30  real_world/data/electricity   \n",
       "154            30  real_world/data/electricity   \n",
       "155            30  real_world/data/electricity   \n",
       "\n",
       "                                        output_folder  save_predictions  \\\n",
       "run_id                                                                    \n",
       "151     real_world/grid_search/output/electricity/esn              True   \n",
       "152     real_world/grid_search/output/electricity/esn              True   \n",
       "153     real_world/grid_search/output/electricity/esn              True   \n",
       "154     real_world/grid_search/output/electricity/esn              True   \n",
       "155     real_world/grid_search/output/electricity/esn              True   \n",
       "\n",
       "         target  horizon  time_delay model_name  width activation  \\\n",
       "run_id                                                              \n",
       "151     Voltage      120         240        esn     32       tanh   \n",
       "152     Voltage      120         240        esn     32       tanh   \n",
       "153     Voltage      120         240        esn     32       tanh   \n",
       "154     Voltage      120         240        esn     32       tanh   \n",
       "155     Voltage      120         240        esn     32       tanh   \n",
       "\n",
       "        regularization        seed  \n",
       "run_id                              \n",
       "151               0.01  1837539164  \n",
       "152               0.01   604267306  \n",
       "153               0.01  1970642945  \n",
       "154               0.01   630487793  \n",
       "155               0.01   932688237  "
      ],
      "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",
       "    </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",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>151</th>\n",
       "      <td>3.311489</td>\n",
       "      <td>2.346492</td>\n",
       "      <td>2.162257</td>\n",
       "      <td>2.541908</td>\n",
       "      <td>6.609277</td>\n",
       "      <td>3.400275</td>\n",
       "      <td>3.398109</td>\n",
       "      <td>30</td>\n",
       "      <td>real_world/data/electricity</td>\n",
       "      <td>real_world/grid_search/output/electricity/esn</td>\n",
       "      <td>True</td>\n",
       "      <td>Voltage</td>\n",
       "      <td>120</td>\n",
       "      <td>240</td>\n",
       "      <td>esn</td>\n",
       "      <td>32</td>\n",
       "      <td>tanh</td>\n",
       "      <td>0.01</td>\n",
       "      <td>1837539164</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>152</th>\n",
       "      <td>3.332146</td>\n",
       "      <td>2.341219</td>\n",
       "      <td>2.153706</td>\n",
       "      <td>2.238657</td>\n",
       "      <td>6.591604</td>\n",
       "      <td>3.245798</td>\n",
       "      <td>3.262887</td>\n",
       "      <td>30</td>\n",
       "      <td>real_world/data/electricity</td>\n",
       "      <td>real_world/grid_search/output/electricity/esn</td>\n",
       "      <td>True</td>\n",
       "      <td>Voltage</td>\n",
       "      <td>120</td>\n",
       "      <td>240</td>\n",
       "      <td>esn</td>\n",
       "      <td>32</td>\n",
       "      <td>tanh</td>\n",
       "      <td>0.01</td>\n",
       "      <td>604267306</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>153</th>\n",
       "      <td>3.336969</td>\n",
       "      <td>2.367483</td>\n",
       "      <td>2.377168</td>\n",
       "      <td>2.594905</td>\n",
       "      <td>6.478596</td>\n",
       "      <td>3.212236</td>\n",
       "      <td>3.197541</td>\n",
       "      <td>30</td>\n",
       "      <td>real_world/data/electricity</td>\n",
       "      <td>real_world/grid_search/output/electricity/esn</td>\n",
       "      <td>True</td>\n",
       "      <td>Voltage</td>\n",
       "      <td>120</td>\n",
       "      <td>240</td>\n",
       "      <td>esn</td>\n",
       "      <td>32</td>\n",
       "      <td>tanh</td>\n",
       "      <td>0.01</td>\n",
       "      <td>1970642945</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>154</th>\n",
       "      <td>3.270136</td>\n",
       "      <td>2.351979</td>\n",
       "      <td>2.426246</td>\n",
       "      <td>2.458243</td>\n",
       "      <td>6.545033</td>\n",
       "      <td>3.261825</td>\n",
       "      <td>3.308389</td>\n",
       "      <td>30</td>\n",
       "      <td>real_world/data/electricity</td>\n",
       "      <td>real_world/grid_search/output/electricity/esn</td>\n",
       "      <td>True</td>\n",
       "      <td>Voltage</td>\n",
       "      <td>120</td>\n",
       "      <td>240</td>\n",
       "      <td>esn</td>\n",
       "      <td>32</td>\n",
       "      <td>tanh</td>\n",
       "      <td>0.01</td>\n",
       "      <td>630487793</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>155</th>\n",
       "      <td>3.283732</td>\n",
       "      <td>2.236485</td>\n",
       "      <td>2.108236</td>\n",
       "      <td>2.255143</td>\n",
       "      <td>6.755427</td>\n",
       "      <td>3.284749</td>\n",
       "      <td>3.246305</td>\n",
       "      <td>30</td>\n",
       "      <td>real_world/data/electricity</td>\n",
       "      <td>real_world/grid_search/output/electricity/esn</td>\n",
       "      <td>True</td>\n",
       "      <td>Voltage</td>\n",
       "      <td>120</td>\n",
       "      <td>240</td>\n",
       "      <td>esn</td>\n",
       "      <td>32</td>\n",
       "      <td>tanh</td>\n",
       "      <td>0.01</td>\n",
       "      <td>932688237</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "execution_count": 4
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2026-03-02T09:02:33.260470382Z",
     "start_time": "2026-03-02T09:02:33.067082819Z"
    }
   },
   "cell_type": "code",
   "source": [
    "print(\"Average fit time\", best_runs[\"training_time\"].mean())\n",
    "print(\"Maximum fit time\", best_runs[\"training_time\"].max())\n",
    "print(\"Minimum fit time\", best_runs[\"training_time\"].min())\n",
    "\n",
    "print(\"Average test MSE\", best_runs[\"metric_test\"].mean())\n",
    "print(\"Maximum test MSE\", best_runs[\"metric_test\"].max())\n",
    "print(\"Minimum test MSE\", best_runs[\"metric_test\"].min())"
   ],
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Average fit time 3.3068944454193114\n",
      "Maximum fit time 3.3369691371917725\n",
      "Minimum fit time 3.2701358795166016\n",
      "Average test MSE 2.417771430827428\n",
      "Maximum test MSE 2.594905237113508\n",
      "Minimum test MSE 2.238657491206683\n"
     ]
    }
   ],
   "execution_count": 5
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2026-02-27T18:01:17.498119159Z",
     "start_time": "2026-02-27T18:01:17.394073650Z"
    }
   },
   "cell_type": "code",
   "source": "",
   "outputs": [],
   "execution_count": 5
  }
 ],
 "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
}
