{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import json\n",
    "import numpy as np\n",
    "import pandas as pd"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "PROJECT_PATH = \"./Data_Pattern_Learnability\" # Absolute path to the project directory\n",
    "block_size = 100000\n",
    "path_to_res = f\"{PROJECT_PATH}/results_data/spin_xps/results_exp_{block_size}.json\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "with open(path_to_res, 'r') as f:\n",
    "    res = json.load(f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Extract relevant results\n",
    "universal_learning_curve = res['universal_learning_curve']\n",
    "evorate_empirical = res['evoRate_empirical']\n",
    "data_rows = []\n",
    "\n",
    "# Iterate over models and k values\n",
    "for model_name in ['LSTM', 'MLP']:\n",
    "    for k in range(1, 19):  # k from 1 to 19\n",
    "        model_data = res[\"models\"][model_name][f\"k_{k}\"]\n",
    "        train_losses = model_data[\"train_losses\"]\n",
    "        \n",
    "        # Compute the mean of the last 100 epochs\n",
    "        final_loss = np.mean(train_losses[-100:])\n",
    "        \n",
    "        # Compute the difference with the universal learning curve λ(k)\n",
    "        loss_minus_lambda = final_loss - universal_learning_curve[k - 1]\n",
    "        \n",
    "        # Store the results\n",
    "        data_rows.append({\n",
    "            'Model': model_name,\n",
    "            'k': k,\n",
    "            'Final Loss (mean last 100)': final_loss,\n",
    "            'Universal Learning Rate λ(k)': universal_learning_curve[k - 1],\n",
    "            'Loss - λ(k)': loss_minus_lambda,\n",
    "            'EvoRate': evorate_empirical[k - 1],\n",
    "        })\n",
    "\n",
    "# Create and reshape the DataFrame\n",
    "df = pd.DataFrame(data_rows)\n",
    "df = (\n",
    "    df.set_index(['k', 'Model'])        # Multi-level index: (k, Model)\n",
    "      .sort_index()\n",
    "      .unstack(level='Model')          # Unstack the 'Model' level into columns\n",
    ")\n",
    "\n",
    "# Flatten multi-level columns and reset index\n",
    "df.columns = [' '.join(col).strip() for col in df.columns.values]\n",
    "df.reset_index(inplace=True)\n",
    "df.set_index('k', inplace=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "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>Final Loss (mean last 100) LSTM</th>\n",
       "      <th>Final Loss (mean last 100) MLP</th>\n",
       "      <th>Universal Learning Rate λ(k) LSTM</th>\n",
       "      <th>Universal Learning Rate λ(k) MLP</th>\n",
       "      <th>Loss - λ(k) LSTM</th>\n",
       "      <th>Loss - λ(k) MLP</th>\n",
       "      <th>EvoRate LSTM</th>\n",
       "      <th>EvoRate MLP</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>k</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>1</th>\n",
       "      <td>0.690613</td>\n",
       "      <td>0.691878</td>\n",
       "      <td>0.400561</td>\n",
       "      <td>0.400561</td>\n",
       "      <td>0.290052</td>\n",
       "      <td>0.291318</td>\n",
       "      <td>0.000568</td>\n",
       "      <td>0.000568</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>0.636663</td>\n",
       "      <td>0.618060</td>\n",
       "      <td>0.253679</td>\n",
       "      <td>0.253679</td>\n",
       "      <td>0.382985</td>\n",
       "      <td>0.364381</td>\n",
       "      <td>0.147451</td>\n",
       "      <td>0.147451</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>0.572902</td>\n",
       "      <td>0.586900</td>\n",
       "      <td>0.189203</td>\n",
       "      <td>0.189203</td>\n",
       "      <td>0.383699</td>\n",
       "      <td>0.397697</td>\n",
       "      <td>0.211926</td>\n",
       "      <td>0.211926</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0.528862</td>\n",
       "      <td>0.567959</td>\n",
       "      <td>0.153010</td>\n",
       "      <td>0.153010</td>\n",
       "      <td>0.375852</td>\n",
       "      <td>0.414949</td>\n",
       "      <td>0.248119</td>\n",
       "      <td>0.248119</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>0.546956</td>\n",
       "      <td>0.518018</td>\n",
       "      <td>0.129847</td>\n",
       "      <td>0.129847</td>\n",
       "      <td>0.417109</td>\n",
       "      <td>0.388171</td>\n",
       "      <td>0.271282</td>\n",
       "      <td>0.271282</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>0.516119</td>\n",
       "      <td>0.546645</td>\n",
       "      <td>0.113811</td>\n",
       "      <td>0.113811</td>\n",
       "      <td>0.402308</td>\n",
       "      <td>0.432834</td>\n",
       "      <td>0.287318</td>\n",
       "      <td>0.287318</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>0.519312</td>\n",
       "      <td>0.521442</td>\n",
       "      <td>0.101975</td>\n",
       "      <td>0.101975</td>\n",
       "      <td>0.417338</td>\n",
       "      <td>0.419467</td>\n",
       "      <td>0.299155</td>\n",
       "      <td>0.299155</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>0.504945</td>\n",
       "      <td>0.526263</td>\n",
       "      <td>0.092834</td>\n",
       "      <td>0.092834</td>\n",
       "      <td>0.412111</td>\n",
       "      <td>0.433429</td>\n",
       "      <td>0.308296</td>\n",
       "      <td>0.308296</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>0.503641</td>\n",
       "      <td>0.500135</td>\n",
       "      <td>0.085633</td>\n",
       "      <td>0.085633</td>\n",
       "      <td>0.418008</td>\n",
       "      <td>0.414502</td>\n",
       "      <td>0.315497</td>\n",
       "      <td>0.315497</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>0.523940</td>\n",
       "      <td>0.497466</td>\n",
       "      <td>0.079696</td>\n",
       "      <td>0.079696</td>\n",
       "      <td>0.444244</td>\n",
       "      <td>0.417770</td>\n",
       "      <td>0.321434</td>\n",
       "      <td>0.321434</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>0.510496</td>\n",
       "      <td>0.522972</td>\n",
       "      <td>0.074710</td>\n",
       "      <td>0.074710</td>\n",
       "      <td>0.435785</td>\n",
       "      <td>0.448262</td>\n",
       "      <td>0.326419</td>\n",
       "      <td>0.326419</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12</th>\n",
       "      <td>0.497343</td>\n",
       "      <td>0.481861</td>\n",
       "      <td>0.070464</td>\n",
       "      <td>0.070464</td>\n",
       "      <td>0.426879</td>\n",
       "      <td>0.411397</td>\n",
       "      <td>0.330665</td>\n",
       "      <td>0.330665</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>0.500107</td>\n",
       "      <td>0.476379</td>\n",
       "      <td>0.066590</td>\n",
       "      <td>0.066590</td>\n",
       "      <td>0.433517</td>\n",
       "      <td>0.409790</td>\n",
       "      <td>0.334540</td>\n",
       "      <td>0.334540</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>14</th>\n",
       "      <td>0.503154</td>\n",
       "      <td>0.500697</td>\n",
       "      <td>0.062957</td>\n",
       "      <td>0.062957</td>\n",
       "      <td>0.440196</td>\n",
       "      <td>0.437740</td>\n",
       "      <td>0.338172</td>\n",
       "      <td>0.338172</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>15</th>\n",
       "      <td>0.557774</td>\n",
       "      <td>0.513251</td>\n",
       "      <td>0.059135</td>\n",
       "      <td>0.059135</td>\n",
       "      <td>0.498638</td>\n",
       "      <td>0.454116</td>\n",
       "      <td>0.341994</td>\n",
       "      <td>0.341994</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>16</th>\n",
       "      <td>0.493124</td>\n",
       "      <td>0.525233</td>\n",
       "      <td>0.054398</td>\n",
       "      <td>0.054398</td>\n",
       "      <td>0.438726</td>\n",
       "      <td>0.470836</td>\n",
       "      <td>0.346731</td>\n",
       "      <td>0.346731</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17</th>\n",
       "      <td>0.491820</td>\n",
       "      <td>0.530333</td>\n",
       "      <td>0.047417</td>\n",
       "      <td>0.047417</td>\n",
       "      <td>0.444403</td>\n",
       "      <td>0.482916</td>\n",
       "      <td>0.353712</td>\n",
       "      <td>0.353712</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>18</th>\n",
       "      <td>0.517479</td>\n",
       "      <td>0.479512</td>\n",
       "      <td>0.035077</td>\n",
       "      <td>0.035077</td>\n",
       "      <td>0.482402</td>\n",
       "      <td>0.444435</td>\n",
       "      <td>0.366052</td>\n",
       "      <td>0.366052</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "    Final Loss (mean last 100) LSTM  Final Loss (mean last 100) MLP  \\\n",
       "k                                                                     \n",
       "1                          0.690613                        0.691878   \n",
       "2                          0.636663                        0.618060   \n",
       "3                          0.572902                        0.586900   \n",
       "4                          0.528862                        0.567959   \n",
       "5                          0.546956                        0.518018   \n",
       "6                          0.516119                        0.546645   \n",
       "7                          0.519312                        0.521442   \n",
       "8                          0.504945                        0.526263   \n",
       "9                          0.503641                        0.500135   \n",
       "10                         0.523940                        0.497466   \n",
       "11                         0.510496                        0.522972   \n",
       "12                         0.497343                        0.481861   \n",
       "13                         0.500107                        0.476379   \n",
       "14                         0.503154                        0.500697   \n",
       "15                         0.557774                        0.513251   \n",
       "16                         0.493124                        0.525233   \n",
       "17                         0.491820                        0.530333   \n",
       "18                         0.517479                        0.479512   \n",
       "\n",
       "    Universal Learning Rate λ(k) LSTM  Universal Learning Rate λ(k) MLP  \\\n",
       "k                                                                         \n",
       "1                            0.400561                          0.400561   \n",
       "2                            0.253679                          0.253679   \n",
       "3                            0.189203                          0.189203   \n",
       "4                            0.153010                          0.153010   \n",
       "5                            0.129847                          0.129847   \n",
       "6                            0.113811                          0.113811   \n",
       "7                            0.101975                          0.101975   \n",
       "8                            0.092834                          0.092834   \n",
       "9                            0.085633                          0.085633   \n",
       "10                           0.079696                          0.079696   \n",
       "11                           0.074710                          0.074710   \n",
       "12                           0.070464                          0.070464   \n",
       "13                           0.066590                          0.066590   \n",
       "14                           0.062957                          0.062957   \n",
       "15                           0.059135                          0.059135   \n",
       "16                           0.054398                          0.054398   \n",
       "17                           0.047417                          0.047417   \n",
       "18                           0.035077                          0.035077   \n",
       "\n",
       "    Loss - λ(k) LSTM  Loss - λ(k) MLP  EvoRate LSTM  EvoRate MLP  \n",
       "k                                                                 \n",
       "1           0.290052         0.291318      0.000568     0.000568  \n",
       "2           0.382985         0.364381      0.147451     0.147451  \n",
       "3           0.383699         0.397697      0.211926     0.211926  \n",
       "4           0.375852         0.414949      0.248119     0.248119  \n",
       "5           0.417109         0.388171      0.271282     0.271282  \n",
       "6           0.402308         0.432834      0.287318     0.287318  \n",
       "7           0.417338         0.419467      0.299155     0.299155  \n",
       "8           0.412111         0.433429      0.308296     0.308296  \n",
       "9           0.418008         0.414502      0.315497     0.315497  \n",
       "10          0.444244         0.417770      0.321434     0.321434  \n",
       "11          0.435785         0.448262      0.326419     0.326419  \n",
       "12          0.426879         0.411397      0.330665     0.330665  \n",
       "13          0.433517         0.409790      0.334540     0.334540  \n",
       "14          0.440196         0.437740      0.338172     0.338172  \n",
       "15          0.498638         0.454116      0.341994     0.341994  \n",
       "16          0.438726         0.470836      0.346731     0.346731  \n",
       "17          0.444403         0.482916      0.353712     0.353712  \n",
       "18          0.482402         0.444435      0.366052     0.366052  "
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "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.13.2"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
