{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "92f9431b-d05f-4dd2-a437-4b83b8e088b9",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Using device: cuda\n",
      "All sweep results will be saved in: results_data_size_sweep/20250514_045146\n",
      "Sweeping over training dataset sizes (number of samples): [160, 320, 640, 960, 1280, 1600, 2400, 3200]\n",
      "Fixed number of task coefficients (k): 15\n",
      "Warning: Modulated readout requested but N_nm is 0. Using fixed readout.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/conda/lib/python3.10/site-packages/torch/nn/init.py:405: UserWarning: Initializing zero-element tensors is a no-op\n",
      "  warnings.warn(\"Initializing zero-element tensors is a no-op\")\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "========================= Running for train_samples: 160, k: 15 =========================\n",
      "Results for train_samples=160 will be saved in: results_data_size_sweep/20250514_045146/samples_160\n",
      "Loading dataset...\n",
      "Dataset loaded.\n",
      "Warning: Modulated readout requested but N_nm is 0. Using fixed readout.\n",
      "\n",
      "--- Training RNN_Vanillia (samples=160, k=15) ---\n",
      "Number of parameters: 51301\n",
      "Epoch 1/200, Train Loss: 16.8715, Val Loss: 15.8734\n",
      "  New best validation loss: 15.8734\n",
      "Epoch 2/200, Train Loss: 16.6775, Val Loss: 15.8723\n",
      "  New best validation loss: 15.8723\n",
      "Epoch 3/200, Train Loss: 16.6023, Val Loss: 15.8196\n",
      "  New best validation loss: 15.8196\n",
      "Epoch 4/200, Train Loss: 16.5249, Val Loss: 15.7837\n",
      "  New best validation loss: 15.7837\n",
      "Epoch 5/200, Train Loss: 16.4689, Val Loss: 15.7499\n",
      "  New best validation loss: 15.7499\n",
      "Epoch 6/200, Train Loss: 16.4334, Val Loss: 15.7482\n",
      "  New best validation loss: 15.7482\n",
      "Epoch 7/200, Train Loss: 16.4013, Val Loss: 15.7932\n",
      "Epoch 8/200, Train Loss: 16.3856, Val Loss: 15.8013\n",
      "Epoch 9/200, Train Loss: 16.3633, Val Loss: 15.7991\n",
      "Epoch 10/200, Train Loss: 16.3380, Val Loss: 15.7578\n",
      "Epoch 11/200, Train Loss: 16.3165, Val Loss: 15.7471\n",
      "  New best validation loss: 15.7471\n",
      "Epoch 12/200, Train Loss: 16.3066, Val Loss: 15.7528\n",
      "Epoch 13/200, Train Loss: 16.2973, Val Loss: 15.7752\n",
      "Epoch 14/200, Train Loss: 16.2906, Val Loss: 15.7646\n",
      "Epoch 15/200, Train Loss: 16.2755, Val Loss: 15.7614\n",
      "Epoch 16/200, Train Loss: 16.2720, Val Loss: 15.7629\n",
      "Epoch 17/200, Train Loss: 16.2640, Val Loss: 15.7693\n",
      "Epoch 18/200, Train Loss: 16.2568, Val Loss: 15.7773\n",
      "Epoch 19/200, Train Loss: 16.2546, Val Loss: 15.7918\n",
      "Epoch 20/200, Train Loss: 16.2591, Val Loss: 15.7773\n",
      "Epoch 21/200, Train Loss: 16.2474, Val Loss: 15.7770\n",
      "Epoch 22/200, Train Loss: 16.2387, Val Loss: 15.7747\n",
      "Epoch 23/200, Train Loss: 16.2304, Val Loss: 15.7879\n",
      "Epoch 24/200, Train Loss: 16.2339, Val Loss: 15.8091\n",
      "Epoch 25/200, Train Loss: 16.2271, Val Loss: 15.7941\n",
      "Epoch 26/200, Train Loss: 16.2205, Val Loss: 15.7747\n",
      "Epoch 27/200, Train Loss: 16.2170, Val Loss: 15.7763\n",
      "Epoch 28/200, Train Loss: 16.2158, Val Loss: 15.7703\n",
      "Epoch 29/200, Train Loss: 16.2074, Val Loss: 15.7739\n",
      "Epoch 30/200, Train Loss: 16.2000, Val Loss: 15.7803\n",
      "Epoch 31/200, Train Loss: 16.1985, Val Loss: 15.7878\n",
      "Epoch 32/200, Train Loss: 16.1940, Val Loss: 15.7788\n",
      "Epoch 33/200, Train Loss: 16.1920, Val Loss: 15.7786\n",
      "Epoch 34/200, Train Loss: 16.1904, Val Loss: 15.7935\n",
      "Epoch 35/200, Train Loss: 16.1850, Val Loss: 15.7886\n",
      "Epoch 36/200, Train Loss: 16.1797, Val Loss: 15.7836\n",
      "Epoch 37/200, Train Loss: 16.1814, Val Loss: 15.7752\n",
      "Epoch 38/200, Train Loss: 16.1781, Val Loss: 15.7818\n",
      "Epoch 39/200, Train Loss: 16.1829, Val Loss: 15.8069\n",
      "Epoch 40/200, Train Loss: 16.1722, Val Loss: 15.8006\n",
      "Epoch 41/200, Train Loss: 16.1676, Val Loss: 15.7955\n",
      "Epoch 42/200, Train Loss: 16.1622, Val Loss: 15.7885\n",
      "Epoch 43/200, Train Loss: 16.1616, Val Loss: 15.7876\n",
      "Epoch 44/200, Train Loss: 16.1532, Val Loss: 15.7927\n",
      "Epoch 45/200, Train Loss: 16.1495, Val Loss: 15.7938\n",
      "Epoch 46/200, Train Loss: 16.1495, Val Loss: 15.8027\n",
      "Epoch 47/200, Train Loss: 16.1490, Val Loss: 15.7923\n",
      "Epoch 48/200, Train Loss: 16.1419, Val Loss: 15.7844\n",
      "Epoch 49/200, Train Loss: 16.1399, Val Loss: 15.7846\n",
      "Epoch 50/200, Train Loss: 16.1370, Val Loss: 15.7794\n",
      "Epoch 51/200, Train Loss: 16.1361, Val Loss: 15.7801\n",
      "Epoch 52/200, Train Loss: 16.1319, Val Loss: 15.7790\n",
      "Epoch 53/200, Train Loss: 16.1307, Val Loss: 15.7824\n",
      "Epoch 54/200, Train Loss: 16.1292, Val Loss: 15.7722\n",
      "Epoch 55/200, Train Loss: 16.1271, Val Loss: 15.7884\n",
      "Epoch 56/200, Train Loss: 16.1202, Val Loss: 15.7946\n",
      "Epoch 57/200, Train Loss: 16.1187, Val Loss: 15.7863\n",
      "Epoch 58/200, Train Loss: 16.1109, Val Loss: 15.7780\n",
      "Epoch 59/200, Train Loss: 16.1101, Val Loss: 15.7812\n",
      "Epoch 60/200, Train Loss: 16.1069, Val Loss: 15.7878\n",
      "Epoch 61/200, Train Loss: 16.1051, Val Loss: 15.7905\n",
      "Epoch 62/200, Train Loss: 16.1057, Val Loss: 15.7834\n",
      "Epoch 63/200, Train Loss: 16.1123, Val Loss: 15.7842\n",
      "Epoch 64/200, Train Loss: 16.1051, Val Loss: 15.8025\n",
      "Epoch 65/200, Train Loss: 16.0926, Val Loss: 15.8119\n",
      "Epoch 66/200, Train Loss: 16.0935, Val Loss: 15.8155\n",
      "Epoch 67/200, Train Loss: 16.0867, Val Loss: 15.7903\n",
      "Epoch 68/200, Train Loss: 16.0826, Val Loss: 15.7887\n",
      "Epoch 69/200, Train Loss: 16.0761, Val Loss: 15.7893\n",
      "Epoch 70/200, Train Loss: 16.0707, Val Loss: 15.7887\n",
      "Epoch 71/200, Train Loss: 16.0654, Val Loss: 15.7879\n",
      "Epoch 72/200, Train Loss: 16.0631, Val Loss: 15.8103\n",
      "Epoch 73/200, Train Loss: 16.0635, Val Loss: 15.8142\n",
      "Epoch 74/200, Train Loss: 16.0593, Val Loss: 15.7943\n",
      "Epoch 75/200, Train Loss: 16.0504, Val Loss: 15.7935\n",
      "Epoch 76/200, Train Loss: 16.0524, Val Loss: 15.7856\n",
      "Epoch 77/200, Train Loss: 16.0446, Val Loss: 15.7893\n",
      "Epoch 78/200, Train Loss: 16.0440, Val Loss: 15.8042\n",
      "Epoch 79/200, Train Loss: 16.0344, Val Loss: 15.7986\n",
      "Epoch 80/200, Train Loss: 16.0364, Val Loss: 15.7823\n",
      "Epoch 81/200, Train Loss: 16.0275, Val Loss: 15.7896\n",
      "Epoch 82/200, Train Loss: 16.0275, Val Loss: 15.8083\n",
      "Epoch 83/200, Train Loss: 16.0188, Val Loss: 15.7923\n",
      "Epoch 84/200, Train Loss: 16.0167, Val Loss: 15.7734\n",
      "Epoch 85/200, Train Loss: 16.0139, Val Loss: 15.7781\n",
      "Epoch 86/200, Train Loss: 16.0051, Val Loss: 15.7936\n",
      "Epoch 87/200, Train Loss: 15.9990, Val Loss: 15.7940\n",
      "Epoch 88/200, Train Loss: 15.9998, Val Loss: 15.7947\n",
      "Epoch 89/200, Train Loss: 15.9995, Val Loss: 15.8183\n",
      "Epoch 90/200, Train Loss: 15.9871, Val Loss: 15.8058\n",
      "Epoch 91/200, Train Loss: 15.9914, Val Loss: 15.7826\n",
      "Epoch 92/200, Train Loss: 15.9801, Val Loss: 15.7783\n",
      "Epoch 93/200, Train Loss: 15.9658, Val Loss: 15.7924\n",
      "Epoch 94/200, Train Loss: 15.9683, Val Loss: 15.8205\n",
      "Epoch 95/200, Train Loss: 15.9791, Val Loss: 15.7858\n",
      "Epoch 96/200, Train Loss: 15.9575, Val Loss: 15.7883\n",
      "Epoch 97/200, Train Loss: 15.9505, Val Loss: 15.7946\n",
      "Epoch 98/200, Train Loss: 15.9460, Val Loss: 15.7849\n",
      "Epoch 99/200, Train Loss: 15.9404, Val Loss: 15.7747\n",
      "Epoch 100/200, Train Loss: 15.9464, Val Loss: 15.7733\n",
      "Epoch 101/200, Train Loss: 15.9366, Val Loss: 15.7813\n",
      "Epoch 102/200, Train Loss: 15.9275, Val Loss: 15.8160\n",
      "Epoch 103/200, Train Loss: 15.9228, Val Loss: 15.8355\n",
      "Epoch 104/200, Train Loss: 15.9206, Val Loss: 15.8453\n",
      "Epoch 105/200, Train Loss: 15.9155, Val Loss: 15.8407\n",
      "Epoch 106/200, Train Loss: 15.9063, Val Loss: 15.8250\n",
      "Epoch 107/200, Train Loss: 15.9072, Val Loss: 15.8278\n",
      "Epoch 108/200, Train Loss: 15.9042, Val Loss: 15.8143\n",
      "Epoch 109/200, Train Loss: 15.8900, Val Loss: 15.8167\n",
      "Epoch 110/200, Train Loss: 15.8863, Val Loss: 15.8351\n",
      "Epoch 111/200, Train Loss: 15.8808, Val Loss: 15.8413\n",
      "Epoch 112/200, Train Loss: 15.8722, Val Loss: 15.8276\n",
      "Epoch 113/200, Train Loss: 15.8773, Val Loss: 15.8208\n",
      "Epoch 114/200, Train Loss: 15.8677, Val Loss: 15.8300\n",
      "Epoch 115/200, Train Loss: 15.8579, Val Loss: 15.8571\n",
      "Epoch 116/200, Train Loss: 15.8527, Val Loss: 15.8578\n",
      "Epoch 117/200, Train Loss: 15.8418, Val Loss: 15.8576\n",
      "Epoch 118/200, Train Loss: 15.8377, Val Loss: 15.8565\n",
      "Epoch 119/200, Train Loss: 15.8326, Val Loss: 15.8548\n",
      "Epoch 120/200, Train Loss: 15.8259, Val Loss: 15.8671\n",
      "Epoch 121/200, Train Loss: 15.8222, Val Loss: 15.8706\n",
      "Epoch 122/200, Train Loss: 15.8156, Val Loss: 15.8594\n",
      "Epoch 123/200, Train Loss: 15.8094, Val Loss: 15.8807\n",
      "Epoch 124/200, Train Loss: 15.7982, Val Loss: 15.8689\n",
      "Epoch 125/200, Train Loss: 15.7938, Val Loss: 15.8512\n",
      "Epoch 126/200, Train Loss: 15.7932, Val Loss: 15.8663\n",
      "Epoch 127/200, Train Loss: 15.7823, Val Loss: 15.8648\n",
      "Epoch 128/200, Train Loss: 15.7757, Val Loss: 15.8845\n",
      "Epoch 129/200, Train Loss: 15.7643, Val Loss: 15.9226\n",
      "Epoch 130/200, Train Loss: 15.7644, Val Loss: 15.9309\n",
      "Epoch 131/200, Train Loss: 15.7559, Val Loss: 15.9231\n",
      "Epoch 132/200, Train Loss: 15.7538, Val Loss: 15.8945\n",
      "Epoch 133/200, Train Loss: 15.7414, Val Loss: 15.8945\n",
      "Epoch 134/200, Train Loss: 15.7378, Val Loss: 15.9007\n",
      "Epoch 135/200, Train Loss: 15.7304, Val Loss: 15.8840\n",
      "Epoch 136/200, Train Loss: 15.7145, Val Loss: 15.8990\n",
      "Epoch 137/200, Train Loss: 15.7222, Val Loss: 15.9043\n",
      "Epoch 138/200, Train Loss: 15.7064, Val Loss: 15.8916\n",
      "Epoch 139/200, Train Loss: 15.6956, Val Loss: 15.9027\n",
      "Epoch 140/200, Train Loss: 15.6888, Val Loss: 15.9165\n",
      "Epoch 141/200, Train Loss: 15.6835, Val Loss: 15.8783\n",
      "Epoch 142/200, Train Loss: 15.6816, Val Loss: 15.8722\n",
      "Epoch 143/200, Train Loss: 15.6676, Val Loss: 15.9060\n",
      "Epoch 144/200, Train Loss: 15.6546, Val Loss: 15.9431\n",
      "Epoch 145/200, Train Loss: 15.6468, Val Loss: 15.9508\n",
      "Epoch 146/200, Train Loss: 15.6417, Val Loss: 15.9949\n",
      "Epoch 147/200, Train Loss: 15.6334, Val Loss: 15.9845\n",
      "Epoch 148/200, Train Loss: 15.6228, Val Loss: 15.9514\n",
      "Epoch 149/200, Train Loss: 15.6130, Val Loss: 15.9555\n",
      "Epoch 150/200, Train Loss: 15.6054, Val Loss: 15.9739\n",
      "Epoch 151/200, Train Loss: 15.5867, Val Loss: 16.0089\n",
      "Epoch 152/200, Train Loss: 15.5882, Val Loss: 16.0125\n",
      "Epoch 153/200, Train Loss: 15.5774, Val Loss: 15.9804\n",
      "Epoch 154/200, Train Loss: 15.5654, Val Loss: 15.9866\n",
      "Epoch 155/200, Train Loss: 15.5547, Val Loss: 15.9802\n",
      "Epoch 156/200, Train Loss: 15.5431, Val Loss: 15.9868\n",
      "Epoch 157/200, Train Loss: 15.5404, Val Loss: 16.0257\n",
      "Epoch 158/200, Train Loss: 15.5324, Val Loss: 16.0402\n",
      "Epoch 159/200, Train Loss: 15.5163, Val Loss: 16.0373\n",
      "Epoch 160/200, Train Loss: 15.5048, Val Loss: 16.0271\n",
      "Epoch 161/200, Train Loss: 15.5054, Val Loss: 15.9978\n",
      "Epoch 162/200, Train Loss: 15.4985, Val Loss: 16.0237\n",
      "Epoch 163/200, Train Loss: 15.4888, Val Loss: 16.0274\n",
      "Epoch 164/200, Train Loss: 15.4789, Val Loss: 16.0757\n",
      "Epoch 165/200, Train Loss: 15.4542, Val Loss: 16.0629\n",
      "Epoch 166/200, Train Loss: 15.4433, Val Loss: 16.0805\n",
      "Epoch 167/200, Train Loss: 15.4312, Val Loss: 16.0797\n",
      "Epoch 168/200, Train Loss: 15.4173, Val Loss: 16.1053\n",
      "Epoch 169/200, Train Loss: 15.4225, Val Loss: 16.1370\n",
      "Epoch 170/200, Train Loss: 15.3979, Val Loss: 16.0821\n",
      "Epoch 171/200, Train Loss: 15.3943, Val Loss: 16.0252\n",
      "Epoch 172/200, Train Loss: 15.3941, Val Loss: 16.0409\n",
      "Epoch 173/200, Train Loss: 15.3649, Val Loss: 16.1114\n",
      "Epoch 174/200, Train Loss: 15.3628, Val Loss: 16.1261\n",
      "Epoch 175/200, Train Loss: 15.3601, Val Loss: 16.1560\n",
      "Epoch 176/200, Train Loss: 15.3346, Val Loss: 16.1029\n",
      "Epoch 177/200, Train Loss: 15.3277, Val Loss: 16.1116\n",
      "Epoch 178/200, Train Loss: 15.3228, Val Loss: 16.0949\n",
      "Epoch 179/200, Train Loss: 15.3032, Val Loss: 16.0882\n",
      "Epoch 180/200, Train Loss: 15.2872, Val Loss: 16.1224\n",
      "Epoch 181/200, Train Loss: 15.2770, Val Loss: 16.1576\n",
      "Epoch 182/200, Train Loss: 15.2650, Val Loss: 16.1141\n",
      "Epoch 183/200, Train Loss: 15.2525, Val Loss: 16.0755\n",
      "Epoch 184/200, Train Loss: 15.2293, Val Loss: 16.1279\n",
      "Epoch 185/200, Train Loss: 15.2248, Val Loss: 16.2267\n",
      "Epoch 186/200, Train Loss: 15.2176, Val Loss: 16.2212\n",
      "Epoch 187/200, Train Loss: 15.1918, Val Loss: 16.2083\n",
      "Epoch 188/200, Train Loss: 15.2034, Val Loss: 16.2184\n",
      "Epoch 189/200, Train Loss: 15.1689, Val Loss: 16.1493\n",
      "Epoch 190/200, Train Loss: 15.1558, Val Loss: 16.1633\n",
      "Epoch 191/200, Train Loss: 15.1379, Val Loss: 16.1781\n",
      "Epoch 192/200, Train Loss: 15.1243, Val Loss: 16.2706\n",
      "Epoch 193/200, Train Loss: 15.1076, Val Loss: 16.2928\n",
      "Epoch 194/200, Train Loss: 15.0922, Val Loss: 16.2724\n",
      "Epoch 195/200, Train Loss: 15.0661, Val Loss: 16.2476\n",
      "Epoch 196/200, Train Loss: 15.0735, Val Loss: 16.1827\n",
      "Epoch 197/200, Train Loss: 15.0463, Val Loss: 16.2007\n",
      "Epoch 198/200, Train Loss: 15.0303, Val Loss: 16.2701\n",
      "Epoch 199/200, Train Loss: 15.0269, Val Loss: 16.3792\n",
      "Epoch 200/200, Train Loss: 15.0062, Val Loss: 16.3174\n",
      "\n",
      "Loaded best model (Val Loss: 15.7471) for final hidden state extraction.\n",
      "Saved best model for RNN_Vanillia (samples=160) to results_data_size_sweep/20250514_045146/samples_160/RNN_Vanillia_samples_160_best.pt\n",
      "\n",
      "--- Performing Decodability Analysis for RNN_Vanillia (samples=160, k=15) ---\n",
      "  Analyzing decodability for RNN_Vanillia...\n",
      "  Hidden states shape: torch.Size([160, 200, 225])\n",
      "  Coefficients shape: torch.Size([160, 15])\n",
      "  Processed hidden states shape for decoder: torch.Size([160, 225])\n",
      "  RidgeCV Decoder for RNN_Vanillia - Test MSE: 1.7749, Test R2: 0.0972 (best alpha: 48.3293)\n",
      "  Decodability plot saved to results_data_size_sweep/20250514_045146/samples_160/decodability_RNN_Vanillia_coeff1.png\n",
      "Decodability (R2 score) for RNN_Vanillia (samples=160): 0.0972\n",
      "\n",
      "--- Training ComplexOscillatorNet (samples=160, k=15) ---\n",
      "Number of parameters: 17152\n",
      "Epoch 1/200, Train Loss: 16.7508, Val Loss: 15.6915\n",
      "  New best validation loss: 15.6915\n",
      "Epoch 2/200, Train Loss: 16.1876, Val Loss: 15.2792\n",
      "  New best validation loss: 15.2792\n",
      "Epoch 3/200, Train Loss: 15.6936, Val Loss: 15.1080\n",
      "  New best validation loss: 15.1080\n",
      "Epoch 4/200, Train Loss: 15.2816, Val Loss: 15.0734\n",
      "  New best validation loss: 15.0734\n",
      "Epoch 5/200, Train Loss: 15.0556, Val Loss: 14.9350\n",
      "  New best validation loss: 14.9350\n",
      "Epoch 6/200, Train Loss: 14.8298, Val Loss: 14.8385\n",
      "  New best validation loss: 14.8385\n",
      "Epoch 7/200, Train Loss: 14.6111, Val Loss: 14.7099\n",
      "  New best validation loss: 14.7099\n",
      "Epoch 8/200, Train Loss: 14.4533, Val Loss: 14.7590\n",
      "Epoch 9/200, Train Loss: 14.2896, Val Loss: 14.7666\n",
      "Epoch 10/200, Train Loss: 14.1429, Val Loss: 14.6614\n",
      "  New best validation loss: 14.6614\n",
      "Epoch 11/200, Train Loss: 14.0166, Val Loss: 14.7215\n",
      "Epoch 12/200, Train Loss: 13.8800, Val Loss: 14.5761\n",
      "  New best validation loss: 14.5761\n",
      "Epoch 13/200, Train Loss: 13.7658, Val Loss: 14.6415\n",
      "Epoch 14/200, Train Loss: 13.6643, Val Loss: 14.6408\n",
      "Epoch 15/200, Train Loss: 13.5472, Val Loss: 14.5844\n",
      "Epoch 16/200, Train Loss: 13.4237, Val Loss: 14.6906\n",
      "Epoch 17/200, Train Loss: 13.3328, Val Loss: 14.6275\n",
      "Epoch 18/200, Train Loss: 13.2521, Val Loss: 14.6595\n",
      "Epoch 19/200, Train Loss: 13.1597, Val Loss: 14.6441\n",
      "Epoch 20/200, Train Loss: 13.0871, Val Loss: 14.6431\n",
      "Epoch 21/200, Train Loss: 13.0020, Val Loss: 14.7266\n",
      "Epoch 22/200, Train Loss: 12.9167, Val Loss: 14.6809\n",
      "Epoch 23/200, Train Loss: 12.8179, Val Loss: 14.7562\n",
      "Epoch 24/200, Train Loss: 12.7561, Val Loss: 14.6680\n",
      "Epoch 25/200, Train Loss: 12.6666, Val Loss: 14.8744\n",
      "Epoch 26/200, Train Loss: 12.6110, Val Loss: 14.7005\n",
      "Epoch 27/200, Train Loss: 12.5477, Val Loss: 14.8250\n",
      "Epoch 28/200, Train Loss: 12.4763, Val Loss: 14.8318\n",
      "Epoch 29/200, Train Loss: 12.4123, Val Loss: 14.8656\n",
      "Epoch 30/200, Train Loss: 12.3307, Val Loss: 14.8968\n",
      "Epoch 31/200, Train Loss: 12.2939, Val Loss: 14.9237\n",
      "Epoch 32/200, Train Loss: 12.2373, Val Loss: 14.9431\n",
      "Epoch 33/200, Train Loss: 12.1811, Val Loss: 14.9794\n",
      "Epoch 34/200, Train Loss: 12.1474, Val Loss: 14.9675\n",
      "Epoch 35/200, Train Loss: 12.1004, Val Loss: 15.0072\n",
      "Epoch 36/200, Train Loss: 12.0458, Val Loss: 15.0552\n",
      "Epoch 37/200, Train Loss: 12.0059, Val Loss: 15.0496\n",
      "Epoch 38/200, Train Loss: 11.9724, Val Loss: 15.1090\n",
      "Epoch 39/200, Train Loss: 11.9013, Val Loss: 15.0658\n",
      "Epoch 40/200, Train Loss: 11.8613, Val Loss: 15.2112\n",
      "Epoch 41/200, Train Loss: 11.8299, Val Loss: 15.2442\n",
      "Epoch 42/200, Train Loss: 11.7830, Val Loss: 15.1036\n",
      "Epoch 43/200, Train Loss: 11.7290, Val Loss: 15.3214\n",
      "Epoch 44/200, Train Loss: 11.6824, Val Loss: 15.2993\n",
      "Epoch 45/200, Train Loss: 11.6620, Val Loss: 15.4438\n",
      "Epoch 46/200, Train Loss: 11.6388, Val Loss: 15.3032\n",
      "Epoch 47/200, Train Loss: 11.5973, Val Loss: 15.4681\n",
      "Epoch 48/200, Train Loss: 11.5662, Val Loss: 15.4091\n",
      "Epoch 49/200, Train Loss: 11.5453, Val Loss: 15.4618\n",
      "Epoch 50/200, Train Loss: 11.5174, Val Loss: 15.4242\n",
      "Epoch 51/200, Train Loss: 11.5043, Val Loss: 15.5170\n",
      "Epoch 52/200, Train Loss: 11.4880, Val Loss: 15.5403\n",
      "Epoch 53/200, Train Loss: 11.4513, Val Loss: 15.5024\n",
      "Epoch 54/200, Train Loss: 11.4292, Val Loss: 15.5758\n",
      "Epoch 55/200, Train Loss: 11.4031, Val Loss: 15.6333\n",
      "Epoch 56/200, Train Loss: 11.3754, Val Loss: 15.6374\n",
      "Epoch 57/200, Train Loss: 11.3528, Val Loss: 15.7065\n",
      "Epoch 58/200, Train Loss: 11.3169, Val Loss: 15.6063\n",
      "Epoch 59/200, Train Loss: 11.2882, Val Loss: 15.8827\n",
      "Epoch 60/200, Train Loss: 11.2707, Val Loss: 15.6810\n",
      "Epoch 61/200, Train Loss: 11.2151, Val Loss: 15.9295\n",
      "Epoch 62/200, Train Loss: 11.1860, Val Loss: 15.7472\n",
      "Epoch 63/200, Train Loss: 11.1794, Val Loss: 15.8771\n",
      "Epoch 64/200, Train Loss: 11.1519, Val Loss: 15.8214\n",
      "Epoch 65/200, Train Loss: 11.1481, Val Loss: 15.9801\n",
      "Epoch 66/200, Train Loss: 11.1269, Val Loss: 15.7734\n",
      "Epoch 67/200, Train Loss: 11.1000, Val Loss: 15.9377\n",
      "Epoch 68/200, Train Loss: 11.1137, Val Loss: 15.8509\n",
      "Epoch 69/200, Train Loss: 11.0963, Val Loss: 15.8982\n",
      "Epoch 70/200, Train Loss: 11.0681, Val Loss: 15.9923\n",
      "Epoch 71/200, Train Loss: 11.0443, Val Loss: 15.8004\n",
      "Epoch 72/200, Train Loss: 11.0708, Val Loss: 16.1768\n",
      "Epoch 73/200, Train Loss: 11.0588, Val Loss: 15.9724\n",
      "Epoch 74/200, Train Loss: 11.0855, Val Loss: 16.1209\n",
      "Epoch 75/200, Train Loss: 11.0709, Val Loss: 16.2020\n",
      "Epoch 76/200, Train Loss: 11.0807, Val Loss: 15.8374\n",
      "Epoch 77/200, Train Loss: 11.0346, Val Loss: 16.1769\n",
      "Epoch 78/200, Train Loss: 10.9977, Val Loss: 15.8771\n",
      "Epoch 79/200, Train Loss: 10.9937, Val Loss: 16.3768\n",
      "Epoch 80/200, Train Loss: 10.9534, Val Loss: 15.9863\n",
      "Epoch 81/200, Train Loss: 10.9408, Val Loss: 16.1400\n",
      "Epoch 82/200, Train Loss: 10.9098, Val Loss: 15.9842\n",
      "Epoch 83/200, Train Loss: 10.8859, Val Loss: 16.0114\n",
      "Epoch 84/200, Train Loss: 10.8369, Val Loss: 16.1356\n",
      "Epoch 85/200, Train Loss: 10.8517, Val Loss: 16.1945\n",
      "Epoch 86/200, Train Loss: 10.8166, Val Loss: 16.1658\n",
      "Epoch 87/200, Train Loss: 10.8240, Val Loss: 16.2661\n",
      "Epoch 88/200, Train Loss: 10.8061, Val Loss: 16.1453\n",
      "Epoch 89/200, Train Loss: 10.7743, Val Loss: 16.2136\n",
      "Epoch 90/200, Train Loss: 10.7636, Val Loss: 16.1213\n",
      "Epoch 91/200, Train Loss: 10.7793, Val Loss: 16.2593\n",
      "Epoch 92/200, Train Loss: 10.7475, Val Loss: 16.3236\n",
      "Epoch 93/200, Train Loss: 10.7410, Val Loss: 16.2925\n",
      "Epoch 94/200, Train Loss: 10.7399, Val Loss: 16.4083\n",
      "Epoch 95/200, Train Loss: 10.7173, Val Loss: 16.3640\n",
      "Epoch 96/200, Train Loss: 10.7356, Val Loss: 16.4300\n",
      "Epoch 97/200, Train Loss: 10.7198, Val Loss: 16.4399\n",
      "Epoch 98/200, Train Loss: 10.7149, Val Loss: 16.4071\n",
      "Epoch 99/200, Train Loss: 10.6734, Val Loss: 16.3994\n",
      "Epoch 100/200, Train Loss: 10.6652, Val Loss: 16.4938\n",
      "Epoch 101/200, Train Loss: 10.6463, Val Loss: 16.4893\n",
      "Epoch 102/200, Train Loss: 10.6262, Val Loss: 16.3354\n",
      "Epoch 103/200, Train Loss: 10.6106, Val Loss: 16.5188\n",
      "Epoch 104/200, Train Loss: 10.6010, Val Loss: 16.5366\n",
      "Epoch 105/200, Train Loss: 10.5826, Val Loss: 16.5028\n",
      "Epoch 106/200, Train Loss: 10.5722, Val Loss: 16.5662\n",
      "Epoch 107/200, Train Loss: 10.5841, Val Loss: 16.5427\n",
      "Epoch 108/200, Train Loss: 10.5856, Val Loss: 16.6427\n",
      "Epoch 109/200, Train Loss: 10.5824, Val Loss: 16.6496\n",
      "Epoch 110/200, Train Loss: 10.5862, Val Loss: 16.6696\n",
      "Epoch 111/200, Train Loss: 10.5773, Val Loss: 16.8504\n",
      "Epoch 112/200, Train Loss: 10.6174, Val Loss: 16.6233\n",
      "Epoch 113/200, Train Loss: 10.6096, Val Loss: 16.8173\n",
      "Epoch 114/200, Train Loss: 10.6248, Val Loss: 16.6528\n",
      "Epoch 115/200, Train Loss: 10.5890, Val Loss: 16.6418\n",
      "Epoch 116/200, Train Loss: 10.5850, Val Loss: 16.6892\n",
      "Epoch 117/200, Train Loss: 10.5764, Val Loss: 16.6495\n",
      "Epoch 118/200, Train Loss: 10.6076, Val Loss: 16.6523\n",
      "Epoch 119/200, Train Loss: 10.5425, Val Loss: 16.6366\n",
      "Epoch 120/200, Train Loss: 10.5438, Val Loss: 16.7413\n",
      "Epoch 121/200, Train Loss: 10.5132, Val Loss: 16.7741\n",
      "Epoch 122/200, Train Loss: 10.4997, Val Loss: 16.6720\n",
      "Epoch 123/200, Train Loss: 10.4974, Val Loss: 16.7798\n",
      "Epoch 124/200, Train Loss: 10.4877, Val Loss: 16.7574\n",
      "Epoch 125/200, Train Loss: 10.4518, Val Loss: 16.8201\n",
      "Epoch 126/200, Train Loss: 10.4281, Val Loss: 16.7940\n",
      "Epoch 127/200, Train Loss: 10.4081, Val Loss: 16.8108\n",
      "Epoch 128/200, Train Loss: 10.3979, Val Loss: 16.8538\n",
      "Epoch 129/200, Train Loss: 10.4071, Val Loss: 16.8888\n",
      "Epoch 130/200, Train Loss: 10.4099, Val Loss: 16.8916\n",
      "Epoch 131/200, Train Loss: 10.4196, Val Loss: 16.9362\n",
      "Epoch 132/200, Train Loss: 10.4256, Val Loss: 16.8396\n",
      "Epoch 133/200, Train Loss: 10.4451, Val Loss: 16.8778\n",
      "Epoch 134/200, Train Loss: 10.4099, Val Loss: 16.8470\n",
      "Epoch 135/200, Train Loss: 10.4074, Val Loss: 16.9965\n",
      "Epoch 136/200, Train Loss: 10.3878, Val Loss: 16.8072\n",
      "Epoch 137/200, Train Loss: 10.4054, Val Loss: 16.9986\n",
      "Epoch 138/200, Train Loss: 10.3847, Val Loss: 16.8143\n",
      "Epoch 139/200, Train Loss: 10.4025, Val Loss: 17.0167\n",
      "Epoch 140/200, Train Loss: 10.3877, Val Loss: 16.8996\n",
      "Epoch 141/200, Train Loss: 10.4255, Val Loss: 17.0619\n",
      "Epoch 142/200, Train Loss: 10.4067, Val Loss: 16.8048\n",
      "Epoch 143/200, Train Loss: 10.3992, Val Loss: 17.0610\n",
      "Epoch 144/200, Train Loss: 10.4015, Val Loss: 16.9559\n",
      "Epoch 145/200, Train Loss: 10.3996, Val Loss: 17.0216\n",
      "Epoch 146/200, Train Loss: 10.3752, Val Loss: 17.0176\n",
      "Epoch 147/200, Train Loss: 10.3780, Val Loss: 16.8002\n",
      "Epoch 148/200, Train Loss: 10.3397, Val Loss: 17.1128\n",
      "Epoch 149/200, Train Loss: 10.3521, Val Loss: 16.8959\n",
      "Epoch 150/200, Train Loss: 10.3284, Val Loss: 17.1180\n",
      "Epoch 151/200, Train Loss: 10.3310, Val Loss: 16.9199\n",
      "Epoch 152/200, Train Loss: 10.3219, Val Loss: 17.0120\n",
      "Epoch 153/200, Train Loss: 10.3166, Val Loss: 16.9925\n",
      "Epoch 154/200, Train Loss: 10.3349, Val Loss: 16.9736\n",
      "Epoch 155/200, Train Loss: 10.3179, Val Loss: 17.0874\n",
      "Epoch 156/200, Train Loss: 10.3607, Val Loss: 17.0661\n",
      "Epoch 157/200, Train Loss: 10.3480, Val Loss: 16.9826\n",
      "Epoch 158/200, Train Loss: 10.3540, Val Loss: 17.1835\n",
      "Epoch 159/200, Train Loss: 10.3544, Val Loss: 17.0766\n",
      "Epoch 160/200, Train Loss: 10.3602, Val Loss: 16.9162\n",
      "Epoch 161/200, Train Loss: 10.3258, Val Loss: 17.1644\n",
      "Epoch 162/200, Train Loss: 10.3439, Val Loss: 16.9135\n",
      "Epoch 163/200, Train Loss: 10.3503, Val Loss: 17.2621\n",
      "Epoch 164/200, Train Loss: 10.3524, Val Loss: 16.8339\n",
      "Epoch 165/200, Train Loss: 10.2844, Val Loss: 17.2076\n",
      "Epoch 166/200, Train Loss: 10.2850, Val Loss: 16.9929\n",
      "Epoch 167/200, Train Loss: 10.2633, Val Loss: 16.8344\n",
      "Epoch 168/200, Train Loss: 10.2543, Val Loss: 17.1829\n",
      "Epoch 169/200, Train Loss: 10.2388, Val Loss: 16.7584\n",
      "Epoch 170/200, Train Loss: 10.2031, Val Loss: 17.2346\n",
      "Epoch 171/200, Train Loss: 10.2111, Val Loss: 16.8082\n",
      "Epoch 172/200, Train Loss: 10.2145, Val Loss: 17.3686\n",
      "Epoch 173/200, Train Loss: 10.1969, Val Loss: 16.8850\n",
      "Epoch 174/200, Train Loss: 10.2019, Val Loss: 17.4140\n",
      "Epoch 175/200, Train Loss: 10.2131, Val Loss: 16.8113\n",
      "Epoch 176/200, Train Loss: 10.2171, Val Loss: 17.3079\n",
      "Epoch 177/200, Train Loss: 10.2283, Val Loss: 16.9768\n",
      "Epoch 178/200, Train Loss: 10.2566, Val Loss: 17.3529\n",
      "Epoch 179/200, Train Loss: 10.2198, Val Loss: 17.0219\n",
      "Epoch 180/200, Train Loss: 10.2390, Val Loss: 17.2175\n",
      "Epoch 181/200, Train Loss: 10.2355, Val Loss: 17.0726\n",
      "Epoch 182/200, Train Loss: 10.2198, Val Loss: 17.3267\n",
      "Epoch 183/200, Train Loss: 10.2014, Val Loss: 17.1180\n",
      "Epoch 184/200, Train Loss: 10.1937, Val Loss: 17.2793\n",
      "Epoch 185/200, Train Loss: 10.2216, Val Loss: 16.9386\n",
      "Epoch 186/200, Train Loss: 10.2022, Val Loss: 17.3787\n",
      "Epoch 187/200, Train Loss: 10.1862, Val Loss: 16.9326\n",
      "Epoch 188/200, Train Loss: 10.2012, Val Loss: 17.3599\n",
      "Epoch 189/200, Train Loss: 10.1979, Val Loss: 16.9738\n",
      "Epoch 190/200, Train Loss: 10.2073, Val Loss: 17.3526\n",
      "Epoch 191/200, Train Loss: 10.1959, Val Loss: 17.0775\n",
      "Epoch 192/200, Train Loss: 10.1872, Val Loss: 17.1770\n",
      "Epoch 193/200, Train Loss: 10.1591, Val Loss: 17.2353\n",
      "Epoch 194/200, Train Loss: 10.1693, Val Loss: 17.1870\n",
      "Epoch 195/200, Train Loss: 10.1732, Val Loss: 17.1701\n",
      "Epoch 196/200, Train Loss: 10.1465, Val Loss: 17.2644\n",
      "Epoch 197/200, Train Loss: 10.1373, Val Loss: 17.1564\n",
      "Epoch 198/200, Train Loss: 10.1440, Val Loss: 17.2809\n",
      "Epoch 199/200, Train Loss: 10.1220, Val Loss: 17.1927\n",
      "Epoch 200/200, Train Loss: 10.1249, Val Loss: 17.3253\n",
      "\n",
      "Loaded best model (Val Loss: 14.5761) for final hidden state extraction.\n",
      "Saved best model for ComplexOscillatorNet (samples=160) to results_data_size_sweep/20250514_045146/samples_160/ComplexOscillatorNet_samples_160_best.pt\n",
      "\n",
      "--- Performing Decodability Analysis for ComplexOscillatorNet (samples=160, k=15) ---\n",
      "  Analyzing decodability for ComplexOscillatorNet...\n",
      "  Hidden states shape: torch.Size([160, 200, 128])\n",
      "  Coefficients shape: torch.Size([160, 15])\n",
      "  Processed hidden states shape for decoder: torch.Size([160, 256])\n",
      "  RidgeCV Decoder for ComplexOscillatorNet - Test MSE: 1.2232, Test R2: 0.3889 (best alpha: 100.0000)\n",
      "  Decodability plot saved to results_data_size_sweep/20250514_045146/samples_160/decodability_ComplexOscillatorNet_coeff1.png\n",
      "Decodability (R2 score) for ComplexOscillatorNet (samples=160): 0.3889\n",
      "\n",
      "--- Training RNN_GRU (samples=160, k=15) ---\n",
      "Number of parameters: 12993\n",
      "Epoch 1/200, Train Loss: 16.4477, Val Loss: 15.8146\n",
      "  New best validation loss: 15.8146\n",
      "Epoch 2/200, Train Loss: 16.4389, Val Loss: 15.8116\n",
      "  New best validation loss: 15.8116\n",
      "Epoch 3/200, Train Loss: 16.4313, Val Loss: 15.8098\n",
      "  New best validation loss: 15.8098\n",
      "Epoch 4/200, Train Loss: 16.4245, Val Loss: 15.8013\n",
      "  New best validation loss: 15.8013\n",
      "Epoch 5/200, Train Loss: 16.4183, Val Loss: 15.7956\n",
      "  New best validation loss: 15.7956\n",
      "Epoch 6/200, Train Loss: 16.4133, Val Loss: 15.7832\n",
      "  New best validation loss: 15.7832\n",
      "Epoch 7/200, Train Loss: 16.4083, Val Loss: 15.7790\n",
      "  New best validation loss: 15.7790\n",
      "Epoch 8/200, Train Loss: 16.4012, Val Loss: 15.7766\n",
      "  New best validation loss: 15.7766\n",
      "Epoch 9/200, Train Loss: 16.3958, Val Loss: 15.7716\n",
      "  New best validation loss: 15.7716\n",
      "Epoch 10/200, Train Loss: 16.3901, Val Loss: 15.7646\n",
      "  New best validation loss: 15.7646\n",
      "Epoch 11/200, Train Loss: 16.3837, Val Loss: 15.7655\n",
      "Epoch 12/200, Train Loss: 16.3783, Val Loss: 15.7612\n",
      "  New best validation loss: 15.7612\n",
      "Epoch 13/200, Train Loss: 16.3708, Val Loss: 15.7579\n",
      "  New best validation loss: 15.7579\n",
      "Epoch 14/200, Train Loss: 16.3666, Val Loss: 15.7497\n",
      "  New best validation loss: 15.7497\n",
      "Epoch 15/200, Train Loss: 16.3601, Val Loss: 15.7504\n",
      "Epoch 16/200, Train Loss: 16.3536, Val Loss: 15.7411\n",
      "  New best validation loss: 15.7411\n",
      "Epoch 17/200, Train Loss: 16.3496, Val Loss: 15.7385\n",
      "  New best validation loss: 15.7385\n",
      "Epoch 18/200, Train Loss: 16.3443, Val Loss: 15.7299\n",
      "  New best validation loss: 15.7299\n",
      "Epoch 19/200, Train Loss: 16.3402, Val Loss: 15.7270\n",
      "  New best validation loss: 15.7270\n",
      "Epoch 20/200, Train Loss: 16.3333, Val Loss: 15.7345\n",
      "Epoch 21/200, Train Loss: 16.3281, Val Loss: 15.7359\n",
      "Epoch 22/200, Train Loss: 16.3276, Val Loss: 15.7365\n",
      "Epoch 23/200, Train Loss: 16.3272, Val Loss: 15.7302\n",
      "Epoch 24/200, Train Loss: 16.3201, Val Loss: 15.7372\n",
      "Epoch 25/200, Train Loss: 16.3188, Val Loss: 15.7467\n",
      "Epoch 26/200, Train Loss: 16.3172, Val Loss: 15.7502\n",
      "Epoch 27/200, Train Loss: 16.3144, Val Loss: 15.7455\n",
      "Epoch 28/200, Train Loss: 16.3142, Val Loss: 15.7444\n",
      "Epoch 29/200, Train Loss: 16.3120, Val Loss: 15.7303\n",
      "Epoch 30/200, Train Loss: 16.3146, Val Loss: 15.7227\n",
      "  New best validation loss: 15.7227\n",
      "Epoch 31/200, Train Loss: 16.3106, Val Loss: 15.7287\n",
      "Epoch 32/200, Train Loss: 16.3163, Val Loss: 15.7496\n",
      "Epoch 33/200, Train Loss: 16.3076, Val Loss: 15.7463\n",
      "Epoch 34/200, Train Loss: 16.3142, Val Loss: 15.7323\n",
      "Epoch 35/200, Train Loss: 16.3065, Val Loss: 15.7422\n",
      "Epoch 36/200, Train Loss: 16.3050, Val Loss: 15.7420\n",
      "Epoch 37/200, Train Loss: 16.3042, Val Loss: 15.7408\n",
      "Epoch 38/200, Train Loss: 16.3041, Val Loss: 15.7497\n",
      "Epoch 39/200, Train Loss: 16.3023, Val Loss: 15.7439\n",
      "Epoch 40/200, Train Loss: 16.3012, Val Loss: 15.7436\n",
      "Epoch 41/200, Train Loss: 16.3010, Val Loss: 15.7472\n",
      "Epoch 42/200, Train Loss: 16.2992, Val Loss: 15.7422\n",
      "Epoch 43/200, Train Loss: 16.2990, Val Loss: 15.7361\n",
      "Epoch 44/200, Train Loss: 16.3028, Val Loss: 15.7452\n",
      "Epoch 45/200, Train Loss: 16.2971, Val Loss: 15.7431\n",
      "Epoch 46/200, Train Loss: 16.2967, Val Loss: 15.7436\n",
      "Epoch 47/200, Train Loss: 16.2949, Val Loss: 15.7392\n",
      "Epoch 48/200, Train Loss: 16.2966, Val Loss: 15.7316\n",
      "Epoch 49/200, Train Loss: 16.2981, Val Loss: 15.7431\n",
      "Epoch 50/200, Train Loss: 16.2933, Val Loss: 15.7435\n",
      "Epoch 51/200, Train Loss: 16.2970, Val Loss: 15.7375\n",
      "Epoch 52/200, Train Loss: 16.2918, Val Loss: 15.7372\n",
      "Epoch 53/200, Train Loss: 16.2932, Val Loss: 15.7312\n",
      "Epoch 54/200, Train Loss: 16.2913, Val Loss: 15.7415\n",
      "Epoch 55/200, Train Loss: 16.2897, Val Loss: 15.7361\n",
      "Epoch 56/200, Train Loss: 16.2880, Val Loss: 15.7432\n",
      "Epoch 57/200, Train Loss: 16.2868, Val Loss: 15.7440\n",
      "Epoch 58/200, Train Loss: 16.2867, Val Loss: 15.7408\n",
      "Epoch 59/200, Train Loss: 16.2880, Val Loss: 15.7469\n",
      "Epoch 60/200, Train Loss: 16.2843, Val Loss: 15.7385\n",
      "Epoch 61/200, Train Loss: 16.2826, Val Loss: 15.7334\n",
      "Epoch 62/200, Train Loss: 16.2822, Val Loss: 15.7314\n",
      "Epoch 63/200, Train Loss: 16.2812, Val Loss: 15.7385\n",
      "Epoch 64/200, Train Loss: 16.2813, Val Loss: 15.7355\n",
      "Epoch 65/200, Train Loss: 16.2794, Val Loss: 15.7363\n",
      "Epoch 66/200, Train Loss: 16.2783, Val Loss: 15.7436\n",
      "Epoch 67/200, Train Loss: 16.2801, Val Loss: 15.7321\n",
      "Epoch 68/200, Train Loss: 16.2780, Val Loss: 15.7431\n",
      "Epoch 69/200, Train Loss: 16.2747, Val Loss: 15.7382\n",
      "Epoch 70/200, Train Loss: 16.2729, Val Loss: 15.7344\n",
      "Epoch 71/200, Train Loss: 16.2709, Val Loss: 15.7344\n",
      "Epoch 72/200, Train Loss: 16.2710, Val Loss: 15.7394\n",
      "Epoch 73/200, Train Loss: 16.2704, Val Loss: 15.7413\n",
      "Epoch 74/200, Train Loss: 16.2676, Val Loss: 15.7349\n",
      "Epoch 75/200, Train Loss: 16.2651, Val Loss: 15.7314\n",
      "Epoch 76/200, Train Loss: 16.2647, Val Loss: 15.7295\n",
      "Epoch 77/200, Train Loss: 16.2625, Val Loss: 15.7266\n",
      "Epoch 78/200, Train Loss: 16.2614, Val Loss: 15.7300\n",
      "Epoch 79/200, Train Loss: 16.2634, Val Loss: 15.7414\n",
      "Epoch 80/200, Train Loss: 16.2578, Val Loss: 15.7412\n",
      "Epoch 81/200, Train Loss: 16.2547, Val Loss: 15.7326\n",
      "Epoch 82/200, Train Loss: 16.2558, Val Loss: 15.7221\n",
      "  New best validation loss: 15.7221\n",
      "Epoch 83/200, Train Loss: 16.2539, Val Loss: 15.7307\n",
      "Epoch 84/200, Train Loss: 16.2483, Val Loss: 15.7285\n",
      "Epoch 85/200, Train Loss: 16.2522, Val Loss: 15.7192\n",
      "  New best validation loss: 15.7192\n",
      "Epoch 86/200, Train Loss: 16.2451, Val Loss: 15.7282\n",
      "Epoch 87/200, Train Loss: 16.2417, Val Loss: 15.7315\n",
      "Epoch 88/200, Train Loss: 16.2399, Val Loss: 15.7341\n",
      "Epoch 89/200, Train Loss: 16.2374, Val Loss: 15.7272\n",
      "Epoch 90/200, Train Loss: 16.2354, Val Loss: 15.7267\n",
      "Epoch 91/200, Train Loss: 16.2318, Val Loss: 15.7192\n",
      "  New best validation loss: 15.7192\n",
      "Epoch 92/200, Train Loss: 16.2305, Val Loss: 15.7135\n",
      "  New best validation loss: 15.7135\n",
      "Epoch 93/200, Train Loss: 16.2278, Val Loss: 15.7191\n",
      "Epoch 94/200, Train Loss: 16.2216, Val Loss: 15.7196\n",
      "Epoch 95/200, Train Loss: 16.2196, Val Loss: 15.7252\n",
      "Epoch 96/200, Train Loss: 16.2150, Val Loss: 15.7174\n",
      "Epoch 97/200, Train Loss: 16.2149, Val Loss: 15.7207\n",
      "Epoch 98/200, Train Loss: 16.2082, Val Loss: 15.7124\n",
      "  New best validation loss: 15.7124\n",
      "Epoch 99/200, Train Loss: 16.2079, Val Loss: 15.7016\n",
      "  New best validation loss: 15.7016\n",
      "Epoch 100/200, Train Loss: 16.2040, Val Loss: 15.6989\n",
      "  New best validation loss: 15.6989\n",
      "Epoch 101/200, Train Loss: 16.1999, Val Loss: 15.7084\n",
      "Epoch 102/200, Train Loss: 16.1981, Val Loss: 15.7203\n",
      "Epoch 103/200, Train Loss: 16.1925, Val Loss: 15.7161\n",
      "Epoch 104/200, Train Loss: 16.1895, Val Loss: 15.7094\n",
      "Epoch 105/200, Train Loss: 16.1922, Val Loss: 15.6967\n",
      "  New best validation loss: 15.6967\n",
      "Epoch 106/200, Train Loss: 16.1806, Val Loss: 15.7007\n",
      "Epoch 107/200, Train Loss: 16.1770, Val Loss: 15.7013\n",
      "Epoch 108/200, Train Loss: 16.1754, Val Loss: 15.6968\n",
      "Epoch 109/200, Train Loss: 16.1718, Val Loss: 15.6928\n",
      "  New best validation loss: 15.6928\n",
      "Epoch 110/200, Train Loss: 16.1680, Val Loss: 15.6942\n",
      "Epoch 111/200, Train Loss: 16.1648, Val Loss: 15.6962\n",
      "Epoch 112/200, Train Loss: 16.1607, Val Loss: 15.6912\n",
      "  New best validation loss: 15.6912\n",
      "Epoch 113/200, Train Loss: 16.1569, Val Loss: 15.6865\n",
      "  New best validation loss: 15.6865\n",
      "Epoch 114/200, Train Loss: 16.1541, Val Loss: 15.6894\n",
      "Epoch 115/200, Train Loss: 16.1576, Val Loss: 15.6941\n",
      "Epoch 116/200, Train Loss: 16.1464, Val Loss: 15.6777\n",
      "  New best validation loss: 15.6777\n",
      "Epoch 117/200, Train Loss: 16.1458, Val Loss: 15.6819\n",
      "Epoch 118/200, Train Loss: 16.1445, Val Loss: 15.6694\n",
      "  New best validation loss: 15.6694\n",
      "Epoch 119/200, Train Loss: 16.1371, Val Loss: 15.6817\n",
      "Epoch 120/200, Train Loss: 16.1347, Val Loss: 15.6889\n",
      "Epoch 121/200, Train Loss: 16.1326, Val Loss: 15.6696\n",
      "Epoch 122/200, Train Loss: 16.1235, Val Loss: 15.6784\n",
      "Epoch 123/200, Train Loss: 16.1142, Val Loss: 15.6775\n",
      "Epoch 124/200, Train Loss: 16.1147, Val Loss: 15.6888\n",
      "Epoch 125/200, Train Loss: 16.1057, Val Loss: 15.6733\n",
      "Epoch 126/200, Train Loss: 16.1000, Val Loss: 15.6737\n",
      "Epoch 127/200, Train Loss: 16.0902, Val Loss: 15.6707\n",
      "Epoch 128/200, Train Loss: 16.0883, Val Loss: 15.6713\n",
      "Epoch 129/200, Train Loss: 16.0776, Val Loss: 15.6715\n",
      "Epoch 130/200, Train Loss: 16.0697, Val Loss: 15.6697\n",
      "Epoch 131/200, Train Loss: 16.0589, Val Loss: 15.6702\n",
      "Epoch 132/200, Train Loss: 16.0546, Val Loss: 15.6810\n",
      "Epoch 133/200, Train Loss: 16.0425, Val Loss: 15.6805\n",
      "Epoch 134/200, Train Loss: 16.0313, Val Loss: 15.6773\n",
      "Epoch 135/200, Train Loss: 16.0156, Val Loss: 15.6768\n",
      "Epoch 136/200, Train Loss: 16.0046, Val Loss: 15.6862\n",
      "Epoch 137/200, Train Loss: 15.9889, Val Loss: 15.6859\n",
      "Epoch 138/200, Train Loss: 15.9740, Val Loss: 15.6848\n",
      "Epoch 139/200, Train Loss: 15.9563, Val Loss: 15.7103\n",
      "Epoch 140/200, Train Loss: 15.9409, Val Loss: 15.6834\n",
      "Epoch 141/200, Train Loss: 15.9197, Val Loss: 15.7535\n",
      "Epoch 142/200, Train Loss: 15.8781, Val Loss: 15.7287\n",
      "Epoch 143/200, Train Loss: 15.8593, Val Loss: 15.7543\n",
      "Epoch 144/200, Train Loss: 15.8509, Val Loss: 15.7339\n",
      "Epoch 145/200, Train Loss: 15.8663, Val Loss: 15.7851\n",
      "Epoch 146/200, Train Loss: 15.8474, Val Loss: 15.8303\n",
      "Epoch 147/200, Train Loss: 15.8152, Val Loss: 15.7649\n",
      "Epoch 148/200, Train Loss: 15.7869, Val Loss: 15.8012\n",
      "Epoch 149/200, Train Loss: 15.7736, Val Loss: 15.7594\n",
      "Epoch 150/200, Train Loss: 15.7422, Val Loss: 15.7931\n",
      "Epoch 151/200, Train Loss: 15.7517, Val Loss: 15.7731\n",
      "Epoch 152/200, Train Loss: 15.7331, Val Loss: 15.7456\n",
      "Epoch 153/200, Train Loss: 15.7398, Val Loss: 15.8546\n",
      "Epoch 154/200, Train Loss: 15.7080, Val Loss: 15.8548\n",
      "Epoch 155/200, Train Loss: 15.7325, Val Loss: 15.8205\n",
      "Epoch 156/200, Train Loss: 15.7016, Val Loss: 15.8190\n",
      "Epoch 157/200, Train Loss: 15.6551, Val Loss: 15.7961\n",
      "Epoch 158/200, Train Loss: 15.6742, Val Loss: 15.8618\n",
      "Epoch 159/200, Train Loss: 15.6914, Val Loss: 15.8808\n",
      "Epoch 160/200, Train Loss: 15.6778, Val Loss: 15.8488\n",
      "Epoch 161/200, Train Loss: 15.6306, Val Loss: 15.9149\n",
      "Epoch 162/200, Train Loss: 15.6496, Val Loss: 15.8854\n",
      "Epoch 163/200, Train Loss: 15.6270, Val Loss: 15.7992\n",
      "Epoch 164/200, Train Loss: 15.6174, Val Loss: 15.8175\n",
      "Epoch 165/200, Train Loss: 15.6008, Val Loss: 15.8786\n",
      "Epoch 166/200, Train Loss: 15.5798, Val Loss: 15.9068\n",
      "Epoch 167/200, Train Loss: 15.5979, Val Loss: 15.9241\n",
      "Epoch 168/200, Train Loss: 15.5894, Val Loss: 15.8826\n",
      "Epoch 169/200, Train Loss: 15.5610, Val Loss: 15.8881\n",
      "Epoch 170/200, Train Loss: 15.5548, Val Loss: 15.8799\n",
      "Epoch 171/200, Train Loss: 15.5593, Val Loss: 15.8970\n",
      "Epoch 172/200, Train Loss: 15.5663, Val Loss: 15.8579\n",
      "Epoch 173/200, Train Loss: 15.5495, Val Loss: 15.8650\n",
      "Epoch 174/200, Train Loss: 15.5336, Val Loss: 15.9043\n",
      "Epoch 175/200, Train Loss: 15.5573, Val Loss: 15.9346\n",
      "Epoch 176/200, Train Loss: 15.5586, Val Loss: 15.8884\n",
      "Epoch 177/200, Train Loss: 15.6139, Val Loss: 15.8380\n",
      "Epoch 178/200, Train Loss: 15.5532, Val Loss: 15.8052\n",
      "Epoch 179/200, Train Loss: 15.5529, Val Loss: 15.8602\n",
      "Epoch 180/200, Train Loss: 15.5412, Val Loss: 15.9165\n",
      "Epoch 181/200, Train Loss: 15.5391, Val Loss: 15.8962\n",
      "Epoch 182/200, Train Loss: 15.5442, Val Loss: 15.8883\n",
      "Epoch 183/200, Train Loss: 15.5075, Val Loss: 15.8607\n",
      "Epoch 184/200, Train Loss: 15.5046, Val Loss: 15.8489\n",
      "Epoch 185/200, Train Loss: 15.4966, Val Loss: 15.9564\n",
      "Epoch 186/200, Train Loss: 15.4826, Val Loss: 15.9377\n",
      "Epoch 187/200, Train Loss: 15.4938, Val Loss: 15.8720\n",
      "Epoch 188/200, Train Loss: 15.5154, Val Loss: 15.9015\n",
      "Epoch 189/200, Train Loss: 15.4650, Val Loss: 15.8860\n",
      "Epoch 190/200, Train Loss: 15.4909, Val Loss: 15.9366\n",
      "Epoch 191/200, Train Loss: 15.4621, Val Loss: 15.9789\n",
      "Epoch 192/200, Train Loss: 15.4567, Val Loss: 15.8959\n",
      "Epoch 193/200, Train Loss: 15.4640, Val Loss: 15.9089\n",
      "Epoch 194/200, Train Loss: 15.4478, Val Loss: 15.9233\n",
      "Epoch 195/200, Train Loss: 15.4283, Val Loss: 15.9670\n",
      "Epoch 196/200, Train Loss: 15.4324, Val Loss: 15.9370\n",
      "Epoch 197/200, Train Loss: 15.4331, Val Loss: 16.0118\n",
      "Epoch 198/200, Train Loss: 15.4238, Val Loss: 15.9161\n",
      "Epoch 199/200, Train Loss: 15.4734, Val Loss: 15.9584\n",
      "Epoch 200/200, Train Loss: 15.4295, Val Loss: 15.9877\n",
      "\n",
      "Loaded best model (Val Loss: 15.6694) for final hidden state extraction.\n",
      "Saved best model for RNN_GRU (samples=160) to results_data_size_sweep/20250514_045146/samples_160/RNN_GRU_samples_160_best.pt\n",
      "\n",
      "--- Performing Decodability Analysis for RNN_GRU (samples=160, k=15) ---\n",
      "  Analyzing decodability for RNN_GRU...\n",
      "  Hidden states shape: torch.Size([160, 200, 64])\n",
      "  Coefficients shape: torch.Size([160, 15])\n",
      "  Processed hidden states shape for decoder: torch.Size([160, 64])\n",
      "  RidgeCV Decoder for RNN_GRU - Test MSE: 1.7005, Test R2: 0.1320 (best alpha: 2.6367)\n",
      "  Decodability plot saved to results_data_size_sweep/20250514_045146/samples_160/decodability_RNN_GRU_coeff1.png\n",
      "Decodability (R2 score) for RNN_GRU (samples=160): 0.1320\n",
      "\n",
      "--- Training Transformer (samples=160, k=15) ---\n",
      "Number of parameters: 85809\n",
      "Epoch 1/200, Train Loss: 18.7613, Val Loss: 17.3818\n",
      "  New best validation loss: 17.3818\n",
      "Epoch 2/200, Train Loss: 17.0385, Val Loss: 15.9120\n",
      "  New best validation loss: 15.9120\n",
      "Epoch 3/200, Train Loss: 16.7167, Val Loss: 15.8394\n",
      "  New best validation loss: 15.8394\n",
      "Epoch 4/200, Train Loss: 16.6220, Val Loss: 15.9669\n",
      "Epoch 5/200, Train Loss: 16.5860, Val Loss: 15.9830\n",
      "Epoch 6/200, Train Loss: 16.5279, Val Loss: 15.9174\n",
      "Epoch 7/200, Train Loss: 16.4825, Val Loss: 15.8663\n",
      "Epoch 8/200, Train Loss: 16.4961, Val Loss: 15.8488\n",
      "Epoch 9/200, Train Loss: 16.4859, Val Loss: 15.8998\n",
      "Epoch 10/200, Train Loss: 16.4835, Val Loss: 15.9113\n",
      "Epoch 11/200, Train Loss: 16.4491, Val Loss: 15.8578\n",
      "Epoch 12/200, Train Loss: 16.4599, Val Loss: 15.8392\n",
      "  New best validation loss: 15.8392\n",
      "Epoch 13/200, Train Loss: 16.4679, Val Loss: 15.8366\n",
      "  New best validation loss: 15.8366\n",
      "Epoch 14/200, Train Loss: 16.4673, Val Loss: 15.8732\n",
      "Epoch 15/200, Train Loss: 16.4440, Val Loss: 15.8500\n",
      "Epoch 16/200, Train Loss: 16.4296, Val Loss: 15.8354\n",
      "  New best validation loss: 15.8354\n",
      "Epoch 17/200, Train Loss: 16.4279, Val Loss: 15.8596\n",
      "Epoch 18/200, Train Loss: 16.4334, Val Loss: 15.8658\n",
      "Epoch 19/200, Train Loss: 16.4208, Val Loss: 15.8031\n",
      "  New best validation loss: 15.8031\n",
      "Epoch 20/200, Train Loss: 16.4362, Val Loss: 15.8320\n",
      "Epoch 21/200, Train Loss: 16.4059, Val Loss: 15.8737\n",
      "Epoch 22/200, Train Loss: 16.4183, Val Loss: 15.8107\n",
      "Epoch 23/200, Train Loss: 16.3868, Val Loss: 15.8263\n",
      "Epoch 24/200, Train Loss: 16.4194, Val Loss: 15.8365\n",
      "Epoch 25/200, Train Loss: 16.4182, Val Loss: 15.8157\n",
      "Epoch 26/200, Train Loss: 16.4081, Val Loss: 15.8227\n",
      "Epoch 27/200, Train Loss: 16.3962, Val Loss: 15.7814\n",
      "  New best validation loss: 15.7814\n",
      "Epoch 28/200, Train Loss: 16.3991, Val Loss: 15.8277\n",
      "Epoch 29/200, Train Loss: 16.4033, Val Loss: 15.8131\n",
      "Epoch 30/200, Train Loss: 16.3918, Val Loss: 15.7780\n",
      "  New best validation loss: 15.7780\n",
      "Epoch 31/200, Train Loss: 16.3820, Val Loss: 15.8313\n",
      "Epoch 32/200, Train Loss: 16.3725, Val Loss: 15.8341\n",
      "Epoch 33/200, Train Loss: 16.3364, Val Loss: 15.7836\n",
      "Epoch 34/200, Train Loss: 16.3782, Val Loss: 15.8113\n",
      "Epoch 35/200, Train Loss: 16.3409, Val Loss: 15.8117\n",
      "Epoch 36/200, Train Loss: 16.3550, Val Loss: 15.8142\n",
      "Epoch 37/200, Train Loss: 16.3791, Val Loss: 15.7908\n",
      "Epoch 38/200, Train Loss: 16.3462, Val Loss: 15.8496\n",
      "Epoch 39/200, Train Loss: 16.3352, Val Loss: 15.8118\n",
      "Epoch 40/200, Train Loss: 16.3415, Val Loss: 15.7928\n",
      "Epoch 41/200, Train Loss: 16.3443, Val Loss: 15.7965\n",
      "Epoch 42/200, Train Loss: 16.3576, Val Loss: 15.8193\n",
      "Epoch 43/200, Train Loss: 16.3368, Val Loss: 15.7725\n",
      "  New best validation loss: 15.7725\n",
      "Epoch 44/200, Train Loss: 16.3478, Val Loss: 15.8415\n",
      "Epoch 45/200, Train Loss: 16.3425, Val Loss: 15.8037\n",
      "Epoch 46/200, Train Loss: 16.3694, Val Loss: 15.7374\n",
      "  New best validation loss: 15.7374\n",
      "Epoch 47/200, Train Loss: 16.3269, Val Loss: 15.8770\n",
      "Epoch 48/200, Train Loss: 16.3293, Val Loss: 15.7916\n",
      "Epoch 49/200, Train Loss: 16.2981, Val Loss: 15.7319\n",
      "  New best validation loss: 15.7319\n",
      "Epoch 50/200, Train Loss: 16.3368, Val Loss: 15.7705\n",
      "Epoch 51/200, Train Loss: 16.3277, Val Loss: 15.7917\n",
      "Epoch 52/200, Train Loss: 16.2894, Val Loss: 15.7700\n",
      "Epoch 53/200, Train Loss: 16.3077, Val Loss: 15.7867\n",
      "Epoch 54/200, Train Loss: 16.2999, Val Loss: 15.8241\n",
      "Epoch 55/200, Train Loss: 16.3248, Val Loss: 15.7423\n",
      "Epoch 56/200, Train Loss: 16.2513, Val Loss: 15.7972\n",
      "Epoch 57/200, Train Loss: 16.2920, Val Loss: 15.8128\n",
      "Epoch 58/200, Train Loss: 16.3046, Val Loss: 15.7202\n",
      "  New best validation loss: 15.7202\n",
      "Epoch 59/200, Train Loss: 16.2947, Val Loss: 15.8046\n",
      "Epoch 60/200, Train Loss: 16.2750, Val Loss: 15.7711\n",
      "Epoch 61/200, Train Loss: 16.2877, Val Loss: 15.7745\n",
      "Epoch 62/200, Train Loss: 16.2732, Val Loss: 15.7418\n",
      "Epoch 63/200, Train Loss: 16.3140, Val Loss: 15.8738\n",
      "Epoch 64/200, Train Loss: 16.2656, Val Loss: 15.7340\n",
      "Epoch 65/200, Train Loss: 16.2785, Val Loss: 15.8119\n",
      "Epoch 66/200, Train Loss: 16.3239, Val Loss: 15.6895\n",
      "  New best validation loss: 15.6895\n",
      "Epoch 67/200, Train Loss: 16.2647, Val Loss: 15.9697\n",
      "Epoch 68/200, Train Loss: 16.2947, Val Loss: 15.7361\n",
      "Epoch 69/200, Train Loss: 16.2915, Val Loss: 15.6737\n",
      "  New best validation loss: 15.6737\n",
      "Epoch 70/200, Train Loss: 16.2730, Val Loss: 15.8268\n",
      "Epoch 71/200, Train Loss: 16.2933, Val Loss: 15.7000\n",
      "Epoch 72/200, Train Loss: 16.2938, Val Loss: 15.7244\n",
      "Epoch 73/200, Train Loss: 16.2732, Val Loss: 15.7586\n",
      "Epoch 74/200, Train Loss: 16.2711, Val Loss: 15.6972\n",
      "Epoch 75/200, Train Loss: 16.2555, Val Loss: 15.7323\n",
      "Epoch 76/200, Train Loss: 16.2527, Val Loss: 15.6930\n",
      "Epoch 77/200, Train Loss: 16.2733, Val Loss: 15.7972\n",
      "Epoch 78/200, Train Loss: 16.1946, Val Loss: 15.6612\n",
      "  New best validation loss: 15.6612\n",
      "Epoch 79/200, Train Loss: 16.2458, Val Loss: 15.6960\n",
      "Epoch 80/200, Train Loss: 16.2233, Val Loss: 15.7640\n",
      "Epoch 81/200, Train Loss: 16.2127, Val Loss: 15.6959\n",
      "Epoch 82/200, Train Loss: 16.2537, Val Loss: 15.7924\n",
      "Epoch 83/200, Train Loss: 16.2353, Val Loss: 15.7121\n",
      "Epoch 84/200, Train Loss: 16.2362, Val Loss: 15.6737\n",
      "Epoch 85/200, Train Loss: 16.2502, Val Loss: 15.8361\n",
      "Epoch 86/200, Train Loss: 16.2335, Val Loss: 15.6596\n",
      "  New best validation loss: 15.6596\n",
      "Epoch 87/200, Train Loss: 16.2019, Val Loss: 15.7054\n",
      "Epoch 88/200, Train Loss: 16.2057, Val Loss: 15.7404\n",
      "Epoch 89/200, Train Loss: 16.1758, Val Loss: 15.6660\n",
      "Epoch 90/200, Train Loss: 16.1829, Val Loss: 15.7320\n",
      "Epoch 91/200, Train Loss: 16.1645, Val Loss: 15.7469\n",
      "Epoch 92/200, Train Loss: 16.1344, Val Loss: 15.6358\n",
      "  New best validation loss: 15.6358\n",
      "Epoch 93/200, Train Loss: 16.2129, Val Loss: 15.7487\n",
      "Epoch 94/200, Train Loss: 16.1956, Val Loss: 15.7319\n",
      "Epoch 95/200, Train Loss: 16.2027, Val Loss: 15.6663\n",
      "Epoch 96/200, Train Loss: 16.1658, Val Loss: 15.7811\n",
      "Epoch 97/200, Train Loss: 16.2065, Val Loss: 15.6380\n",
      "Epoch 98/200, Train Loss: 16.1842, Val Loss: 15.7627\n",
      "Epoch 99/200, Train Loss: 16.1755, Val Loss: 15.6315\n",
      "  New best validation loss: 15.6315\n",
      "Epoch 100/200, Train Loss: 16.2098, Val Loss: 15.7547\n",
      "Epoch 101/200, Train Loss: 16.1348, Val Loss: 15.6235\n",
      "  New best validation loss: 15.6235\n",
      "Epoch 102/200, Train Loss: 16.2030, Val Loss: 15.7380\n",
      "Epoch 103/200, Train Loss: 16.1153, Val Loss: 15.6247\n",
      "Epoch 104/200, Train Loss: 16.1347, Val Loss: 15.7536\n",
      "Epoch 105/200, Train Loss: 16.1994, Val Loss: 15.7453\n",
      "Epoch 106/200, Train Loss: 16.1557, Val Loss: 15.6180\n",
      "  New best validation loss: 15.6180\n",
      "Epoch 107/200, Train Loss: 16.1596, Val Loss: 15.7610\n",
      "Epoch 108/200, Train Loss: 16.1257, Val Loss: 15.6758\n",
      "Epoch 109/200, Train Loss: 16.1485, Val Loss: 15.6111\n",
      "  New best validation loss: 15.6111\n",
      "Epoch 110/200, Train Loss: 16.2406, Val Loss: 15.8681\n",
      "Epoch 111/200, Train Loss: 16.1056, Val Loss: 15.6187\n",
      "Epoch 112/200, Train Loss: 16.1238, Val Loss: 15.6868\n",
      "Epoch 113/200, Train Loss: 16.1137, Val Loss: 15.6954\n",
      "Epoch 114/200, Train Loss: 16.1323, Val Loss: 15.6215\n",
      "Epoch 115/200, Train Loss: 16.1023, Val Loss: 15.6525\n",
      "Epoch 116/200, Train Loss: 16.1449, Val Loss: 15.6555\n",
      "Epoch 117/200, Train Loss: 16.0639, Val Loss: 15.6748\n",
      "Epoch 118/200, Train Loss: 16.1072, Val Loss: 15.5965\n",
      "  New best validation loss: 15.5965\n",
      "Epoch 119/200, Train Loss: 16.0844, Val Loss: 15.6346\n",
      "Epoch 120/200, Train Loss: 16.0963, Val Loss: 15.7230\n",
      "Epoch 121/200, Train Loss: 16.0404, Val Loss: 15.5711\n",
      "  New best validation loss: 15.5711\n",
      "Epoch 122/200, Train Loss: 16.0509, Val Loss: 15.6354\n",
      "Epoch 123/200, Train Loss: 16.0529, Val Loss: 15.6744\n",
      "Epoch 124/200, Train Loss: 16.0294, Val Loss: 15.5592\n",
      "  New best validation loss: 15.5592\n",
      "Epoch 125/200, Train Loss: 16.0596, Val Loss: 15.7479\n",
      "Epoch 126/200, Train Loss: 16.0820, Val Loss: 15.6197\n",
      "Epoch 127/200, Train Loss: 16.1387, Val Loss: 15.5531\n",
      "  New best validation loss: 15.5531\n",
      "Epoch 128/200, Train Loss: 16.1126, Val Loss: 15.7676\n",
      "Epoch 129/200, Train Loss: 16.0928, Val Loss: 15.5666\n",
      "Epoch 130/200, Train Loss: 16.0961, Val Loss: 15.7151\n",
      "Epoch 131/200, Train Loss: 16.0332, Val Loss: 15.5688\n",
      "Epoch 132/200, Train Loss: 16.0139, Val Loss: 15.6104\n",
      "Epoch 133/200, Train Loss: 16.0141, Val Loss: 15.6264\n",
      "Epoch 134/200, Train Loss: 16.0520, Val Loss: 15.5992\n",
      "Epoch 135/200, Train Loss: 15.9480, Val Loss: 15.5780\n",
      "Epoch 136/200, Train Loss: 16.0003, Val Loss: 15.6394\n",
      "Epoch 137/200, Train Loss: 16.0045, Val Loss: 15.5776\n",
      "Epoch 138/200, Train Loss: 16.0047, Val Loss: 15.6536\n",
      "Epoch 139/200, Train Loss: 15.9418, Val Loss: 15.5480\n",
      "  New best validation loss: 15.5480\n",
      "Epoch 140/200, Train Loss: 15.9916, Val Loss: 15.5898\n",
      "Epoch 141/200, Train Loss: 16.0333, Val Loss: 15.5718\n",
      "Epoch 142/200, Train Loss: 15.9744, Val Loss: 15.6210\n",
      "Epoch 143/200, Train Loss: 15.9227, Val Loss: 15.4967\n",
      "  New best validation loss: 15.4967\n",
      "Epoch 144/200, Train Loss: 15.9394, Val Loss: 15.6320\n",
      "Epoch 145/200, Train Loss: 15.9021, Val Loss: 15.4997\n",
      "Epoch 146/200, Train Loss: 15.9335, Val Loss: 15.5456\n",
      "Epoch 147/200, Train Loss: 15.8786, Val Loss: 15.5062\n",
      "Epoch 148/200, Train Loss: 15.9230, Val Loss: 15.5892\n",
      "Epoch 149/200, Train Loss: 15.9253, Val Loss: 15.5035\n",
      "Epoch 150/200, Train Loss: 15.9502, Val Loss: 15.5653\n",
      "Epoch 151/200, Train Loss: 15.9501, Val Loss: 15.5186\n",
      "Epoch 152/200, Train Loss: 15.9837, Val Loss: 15.5567\n",
      "Epoch 153/200, Train Loss: 15.9238, Val Loss: 15.4529\n",
      "  New best validation loss: 15.4529\n",
      "Epoch 154/200, Train Loss: 15.8814, Val Loss: 15.5509\n",
      "Epoch 155/200, Train Loss: 15.8671, Val Loss: 15.4323\n",
      "  New best validation loss: 15.4323\n",
      "Epoch 156/200, Train Loss: 15.8177, Val Loss: 15.4821\n",
      "Epoch 157/200, Train Loss: 15.8363, Val Loss: 15.4731\n",
      "Epoch 158/200, Train Loss: 15.8525, Val Loss: 15.4997\n",
      "Epoch 159/200, Train Loss: 15.8227, Val Loss: 15.4201\n",
      "  New best validation loss: 15.4201\n",
      "Epoch 160/200, Train Loss: 15.8265, Val Loss: 15.4159\n",
      "  New best validation loss: 15.4159\n",
      "Epoch 161/200, Train Loss: 15.8324, Val Loss: 15.4020\n",
      "  New best validation loss: 15.4020\n",
      "Epoch 162/200, Train Loss: 15.8646, Val Loss: 15.4064\n",
      "Epoch 163/200, Train Loss: 15.8896, Val Loss: 15.3129\n",
      "  New best validation loss: 15.3129\n",
      "Epoch 164/200, Train Loss: 15.8792, Val Loss: 15.4527\n",
      "Epoch 165/200, Train Loss: 15.8162, Val Loss: 15.3597\n",
      "Epoch 166/200, Train Loss: 15.7696, Val Loss: 15.4272\n",
      "Epoch 167/200, Train Loss: 15.7308, Val Loss: 15.2247\n",
      "  New best validation loss: 15.2247\n",
      "Epoch 168/200, Train Loss: 15.7327, Val Loss: 15.2939\n",
      "Epoch 169/200, Train Loss: 15.7290, Val Loss: 15.2565\n",
      "Epoch 170/200, Train Loss: 15.6322, Val Loss: 15.1521\n",
      "  New best validation loss: 15.1521\n",
      "Epoch 171/200, Train Loss: 15.6974, Val Loss: 15.1690\n",
      "Epoch 172/200, Train Loss: 15.6317, Val Loss: 15.2215\n",
      "Epoch 173/200, Train Loss: 15.6570, Val Loss: 14.9988\n",
      "  New best validation loss: 14.9988\n",
      "Epoch 174/200, Train Loss: 15.7518, Val Loss: 15.3207\n",
      "Epoch 175/200, Train Loss: 15.9382, Val Loss: 15.4228\n",
      "Epoch 176/200, Train Loss: 15.7602, Val Loss: 15.1415\n",
      "Epoch 177/200, Train Loss: 15.6769, Val Loss: 15.3119\n",
      "Epoch 178/200, Train Loss: 15.6793, Val Loss: 15.1200\n",
      "Epoch 179/200, Train Loss: 15.6711, Val Loss: 15.0397\n",
      "Epoch 180/200, Train Loss: 15.6380, Val Loss: 14.9007\n",
      "  New best validation loss: 14.9007\n",
      "Epoch 181/200, Train Loss: 15.4776, Val Loss: 14.8256\n",
      "  New best validation loss: 14.8256\n",
      "Epoch 182/200, Train Loss: 15.5591, Val Loss: 14.8026\n",
      "  New best validation loss: 14.8026\n",
      "Epoch 183/200, Train Loss: 15.4029, Val Loss: 14.8575\n",
      "Epoch 184/200, Train Loss: 15.4094, Val Loss: 14.7686\n",
      "  New best validation loss: 14.7686\n",
      "Epoch 185/200, Train Loss: 15.3851, Val Loss: 14.7319\n",
      "  New best validation loss: 14.7319\n",
      "Epoch 186/200, Train Loss: 15.3158, Val Loss: 14.6124\n",
      "  New best validation loss: 14.6124\n",
      "Epoch 187/200, Train Loss: 15.3999, Val Loss: 14.6870\n",
      "Epoch 188/200, Train Loss: 15.2576, Val Loss: 14.6650\n",
      "Epoch 189/200, Train Loss: 15.2438, Val Loss: 14.5241\n",
      "  New best validation loss: 14.5241\n",
      "Epoch 190/200, Train Loss: 15.2022, Val Loss: 14.5077\n",
      "  New best validation loss: 14.5077\n",
      "Epoch 191/200, Train Loss: 15.1817, Val Loss: 14.5432\n",
      "Epoch 192/200, Train Loss: 15.2503, Val Loss: 14.3864\n",
      "  New best validation loss: 14.3864\n",
      "Epoch 193/200, Train Loss: 15.1169, Val Loss: 14.7097\n",
      "Epoch 194/200, Train Loss: 15.2188, Val Loss: 14.2707\n",
      "  New best validation loss: 14.2707\n",
      "Epoch 195/200, Train Loss: 15.2901, Val Loss: 14.5330\n",
      "Epoch 196/200, Train Loss: 15.1537, Val Loss: 14.3775\n",
      "Epoch 197/200, Train Loss: 15.0689, Val Loss: 14.3162\n",
      "Epoch 198/200, Train Loss: 15.0092, Val Loss: 14.2322\n",
      "  New best validation loss: 14.2322\n",
      "Epoch 199/200, Train Loss: 14.9399, Val Loss: 14.2756\n",
      "Epoch 200/200, Train Loss: 15.0230, Val Loss: 14.1612\n",
      "  New best validation loss: 14.1612\n",
      "\n",
      "Loaded best model (Val Loss: 14.1612) for final hidden state extraction.\n",
      "Saved best model for Transformer (samples=160) to results_data_size_sweep/20250514_045146/samples_160/Transformer_samples_160_best.pt\n",
      "\n",
      "--- Performing Decodability Analysis for Transformer (samples=160, k=15) ---\n",
      "  Analyzing decodability for Transformer...\n",
      "  Hidden states shape: torch.Size([160, 200, 20])\n",
      "  Coefficients shape: torch.Size([160, 15])\n",
      "  Processed hidden states shape for decoder: torch.Size([160, 20])\n",
      "  RidgeCV Decoder for Transformer - Test MSE: 1.7899, Test R2: 0.0941 (best alpha: 0.1438)\n",
      "  Decodability plot saved to results_data_size_sweep/20250514_045146/samples_160/decodability_Transformer_coeff1.png\n",
      "Decodability (R2 score) for Transformer (samples=160): 0.0941\n",
      "\n",
      "--- Training TransformerCausal (samples=160, k=15) ---\n",
      "Number of parameters: 85809\n",
      "Epoch 1/200, Train Loss: 19.0478, Val Loss: 17.7879\n",
      "  New best validation loss: 17.7879\n",
      "Epoch 2/200, Train Loss: 17.4107, Val Loss: 16.3279\n",
      "  New best validation loss: 16.3279\n",
      "Epoch 3/200, Train Loss: 16.6924, Val Loss: 15.8182\n",
      "  New best validation loss: 15.8182\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/conda/lib/python3.10/site-packages/torch/nn/modules/activation.py:1160: UserWarning: Converting mask without torch.bool dtype to bool; this will negatively affect performance. Prefer to use a boolean mask directly. (Triggered internally at /opt/conda/conda-bld/pytorch_1682343995026/work/aten/src/ATen/native/transformers/attention.cpp:150.)\n",
      "  return torch._native_multi_head_attention(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4/200, Train Loss: 16.6141, Val Loss: 15.8160\n",
      "  New best validation loss: 15.8160\n",
      "Epoch 5/200, Train Loss: 16.5685, Val Loss: 15.8794\n",
      "Epoch 6/200, Train Loss: 16.4663, Val Loss: 16.0096\n",
      "Epoch 7/200, Train Loss: 16.4950, Val Loss: 15.9651\n",
      "Epoch 8/200, Train Loss: 16.4218, Val Loss: 15.8910\n",
      "Epoch 9/200, Train Loss: 16.4695, Val Loss: 15.8314\n",
      "Epoch 10/200, Train Loss: 16.4169, Val Loss: 15.8447\n",
      "Epoch 11/200, Train Loss: 16.4106, Val Loss: 15.9233\n",
      "Epoch 12/200, Train Loss: 16.3797, Val Loss: 15.8609\n",
      "Epoch 13/200, Train Loss: 16.3637, Val Loss: 15.8470\n",
      "Epoch 14/200, Train Loss: 16.3662, Val Loss: 15.8410\n",
      "Epoch 15/200, Train Loss: 16.3987, Val Loss: 15.8278\n",
      "Epoch 16/200, Train Loss: 16.3772, Val Loss: 15.8672\n",
      "Epoch 17/200, Train Loss: 16.3639, Val Loss: 15.8522\n",
      "Epoch 18/200, Train Loss: 16.3579, Val Loss: 15.8605\n",
      "Epoch 19/200, Train Loss: 16.3510, Val Loss: 15.8725\n",
      "Epoch 20/200, Train Loss: 16.3140, Val Loss: 15.8205\n",
      "Epoch 21/200, Train Loss: 16.3461, Val Loss: 15.8023\n",
      "  New best validation loss: 15.8023\n",
      "Epoch 22/200, Train Loss: 16.3311, Val Loss: 15.8445\n",
      "Epoch 23/200, Train Loss: 16.3316, Val Loss: 15.8794\n",
      "Epoch 24/200, Train Loss: 16.3048, Val Loss: 15.8273\n",
      "Epoch 25/200, Train Loss: 16.2949, Val Loss: 15.8425\n",
      "Epoch 26/200, Train Loss: 16.3153, Val Loss: 15.7983\n",
      "  New best validation loss: 15.7983\n",
      "Epoch 27/200, Train Loss: 16.2975, Val Loss: 15.8547\n",
      "Epoch 28/200, Train Loss: 16.2959, Val Loss: 15.9185\n",
      "Epoch 29/200, Train Loss: 16.3300, Val Loss: 15.7840\n",
      "  New best validation loss: 15.7840\n",
      "Epoch 30/200, Train Loss: 16.2785, Val Loss: 15.8259\n",
      "Epoch 31/200, Train Loss: 16.2762, Val Loss: 15.8388\n",
      "Epoch 32/200, Train Loss: 16.2878, Val Loss: 15.8560\n",
      "Epoch 33/200, Train Loss: 16.2916, Val Loss: 15.7899\n",
      "Epoch 34/200, Train Loss: 16.3006, Val Loss: 15.8866\n",
      "Epoch 35/200, Train Loss: 16.2579, Val Loss: 15.8622\n",
      "Epoch 36/200, Train Loss: 16.2292, Val Loss: 15.8126\n",
      "Epoch 37/200, Train Loss: 16.2311, Val Loss: 15.7950\n",
      "Epoch 38/200, Train Loss: 16.2315, Val Loss: 15.8495\n",
      "Epoch 39/200, Train Loss: 16.2329, Val Loss: 15.8324\n",
      "Epoch 40/200, Train Loss: 16.2395, Val Loss: 15.8006\n",
      "Epoch 41/200, Train Loss: 16.1924, Val Loss: 15.8275\n",
      "Epoch 42/200, Train Loss: 16.2135, Val Loss: 15.8730\n",
      "Epoch 43/200, Train Loss: 16.2010, Val Loss: 15.8636\n",
      "Epoch 44/200, Train Loss: 16.2623, Val Loss: 15.7364\n",
      "  New best validation loss: 15.7364\n",
      "Epoch 45/200, Train Loss: 16.2253, Val Loss: 15.9931\n",
      "Epoch 46/200, Train Loss: 16.2323, Val Loss: 15.9111\n",
      "Epoch 47/200, Train Loss: 16.2146, Val Loss: 15.7428\n",
      "Epoch 48/200, Train Loss: 16.2087, Val Loss: 15.8687\n",
      "Epoch 49/200, Train Loss: 16.1732, Val Loss: 15.8920\n",
      "Epoch 50/200, Train Loss: 16.1836, Val Loss: 15.8261\n",
      "Epoch 51/200, Train Loss: 16.1530, Val Loss: 15.7846\n",
      "Epoch 52/200, Train Loss: 16.1507, Val Loss: 15.8924\n",
      "Epoch 53/200, Train Loss: 16.1579, Val Loss: 15.8584\n",
      "Epoch 54/200, Train Loss: 16.1691, Val Loss: 15.8273\n",
      "Epoch 55/200, Train Loss: 16.1690, Val Loss: 15.7981\n",
      "Epoch 56/200, Train Loss: 16.1683, Val Loss: 15.9111\n",
      "Epoch 57/200, Train Loss: 16.1610, Val Loss: 15.8911\n",
      "Epoch 58/200, Train Loss: 16.1627, Val Loss: 15.8052\n",
      "Epoch 59/200, Train Loss: 16.1345, Val Loss: 15.9697\n",
      "Epoch 60/200, Train Loss: 16.1074, Val Loss: 15.8660\n",
      "Epoch 61/200, Train Loss: 16.1391, Val Loss: 15.7901\n",
      "Epoch 62/200, Train Loss: 16.1298, Val Loss: 16.0710\n",
      "Epoch 63/200, Train Loss: 16.0940, Val Loss: 15.7694\n",
      "Epoch 64/200, Train Loss: 16.1778, Val Loss: 15.8457\n",
      "Epoch 65/200, Train Loss: 16.1026, Val Loss: 15.8889\n",
      "Epoch 66/200, Train Loss: 16.0917, Val Loss: 15.8356\n",
      "Epoch 67/200, Train Loss: 16.0836, Val Loss: 15.9192\n",
      "Epoch 68/200, Train Loss: 16.1092, Val Loss: 15.8870\n",
      "Epoch 69/200, Train Loss: 16.1131, Val Loss: 15.8390\n",
      "Epoch 70/200, Train Loss: 16.0684, Val Loss: 15.9832\n",
      "Epoch 71/200, Train Loss: 16.0823, Val Loss: 15.8350\n",
      "Epoch 72/200, Train Loss: 16.0922, Val Loss: 15.8590\n",
      "Epoch 73/200, Train Loss: 16.0841, Val Loss: 15.8338\n",
      "Epoch 74/200, Train Loss: 16.0443, Val Loss: 15.8755\n",
      "Epoch 75/200, Train Loss: 16.1221, Val Loss: 16.0187\n",
      "Epoch 76/200, Train Loss: 16.0204, Val Loss: 15.8105\n",
      "Epoch 77/200, Train Loss: 16.0267, Val Loss: 15.9131\n",
      "Epoch 78/200, Train Loss: 16.0377, Val Loss: 15.9617\n",
      "Epoch 79/200, Train Loss: 16.0377, Val Loss: 15.7976\n",
      "Epoch 80/200, Train Loss: 16.0552, Val Loss: 15.9485\n",
      "Epoch 81/200, Train Loss: 16.0365, Val Loss: 15.8972\n",
      "Epoch 82/200, Train Loss: 16.0749, Val Loss: 15.7686\n",
      "Epoch 83/200, Train Loss: 16.0359, Val Loss: 16.0711\n",
      "Epoch 84/200, Train Loss: 16.0286, Val Loss: 15.7822\n",
      "Epoch 85/200, Train Loss: 16.0738, Val Loss: 15.8915\n",
      "Epoch 86/200, Train Loss: 16.0871, Val Loss: 16.0851\n",
      "Epoch 87/200, Train Loss: 16.0614, Val Loss: 15.7332\n",
      "  New best validation loss: 15.7332\n",
      "Epoch 88/200, Train Loss: 15.9714, Val Loss: 16.0702\n",
      "Epoch 89/200, Train Loss: 16.0329, Val Loss: 15.8789\n",
      "Epoch 90/200, Train Loss: 15.9978, Val Loss: 15.8199\n",
      "Epoch 91/200, Train Loss: 16.0117, Val Loss: 15.8562\n",
      "Epoch 92/200, Train Loss: 16.0164, Val Loss: 15.9704\n",
      "Epoch 93/200, Train Loss: 15.9706, Val Loss: 15.8178\n",
      "Epoch 94/200, Train Loss: 15.9939, Val Loss: 15.9641\n",
      "Epoch 95/200, Train Loss: 15.9993, Val Loss: 15.9184\n",
      "Epoch 96/200, Train Loss: 16.0702, Val Loss: 15.7526\n",
      "Epoch 97/200, Train Loss: 15.9492, Val Loss: 16.2311\n",
      "Epoch 98/200, Train Loss: 15.9570, Val Loss: 15.8160\n",
      "Epoch 99/200, Train Loss: 16.0034, Val Loss: 15.7741\n",
      "Epoch 100/200, Train Loss: 16.0062, Val Loss: 16.1456\n",
      "Epoch 101/200, Train Loss: 15.9807, Val Loss: 15.7852\n",
      "Epoch 102/200, Train Loss: 15.9947, Val Loss: 16.0314\n",
      "Epoch 103/200, Train Loss: 15.9557, Val Loss: 15.9007\n",
      "Epoch 104/200, Train Loss: 15.9292, Val Loss: 15.7861\n",
      "Epoch 105/200, Train Loss: 15.9382, Val Loss: 15.8973\n",
      "Epoch 106/200, Train Loss: 15.9139, Val Loss: 15.8865\n",
      "Epoch 107/200, Train Loss: 15.9455, Val Loss: 15.8149\n",
      "Epoch 108/200, Train Loss: 15.9240, Val Loss: 15.9117\n",
      "Epoch 109/200, Train Loss: 15.9607, Val Loss: 15.8458\n",
      "Epoch 110/200, Train Loss: 15.9202, Val Loss: 15.8695\n",
      "Epoch 111/200, Train Loss: 15.9152, Val Loss: 15.7939\n",
      "Epoch 112/200, Train Loss: 15.8857, Val Loss: 15.9898\n",
      "Epoch 113/200, Train Loss: 15.9283, Val Loss: 15.8165\n",
      "Epoch 114/200, Train Loss: 15.9011, Val Loss: 15.8746\n",
      "Epoch 115/200, Train Loss: 15.9359, Val Loss: 15.8322\n",
      "Epoch 116/200, Train Loss: 15.8900, Val Loss: 15.8999\n",
      "Epoch 117/200, Train Loss: 15.9126, Val Loss: 15.8326\n",
      "Epoch 118/200, Train Loss: 15.8644, Val Loss: 15.8739\n",
      "Epoch 119/200, Train Loss: 15.9298, Val Loss: 15.8812\n",
      "Epoch 120/200, Train Loss: 15.9096, Val Loss: 15.8474\n",
      "Epoch 121/200, Train Loss: 15.8835, Val Loss: 15.7389\n",
      "Epoch 122/200, Train Loss: 15.8979, Val Loss: 15.9864\n",
      "Epoch 123/200, Train Loss: 15.8754, Val Loss: 15.7820\n",
      "Epoch 124/200, Train Loss: 15.9443, Val Loss: 15.8513\n",
      "Epoch 125/200, Train Loss: 15.9464, Val Loss: 15.7666\n",
      "Epoch 126/200, Train Loss: 15.8810, Val Loss: 16.0713\n",
      "Epoch 127/200, Train Loss: 15.8405, Val Loss: 15.7118\n",
      "  New best validation loss: 15.7118\n",
      "Epoch 128/200, Train Loss: 15.8666, Val Loss: 15.8077\n",
      "Epoch 129/200, Train Loss: 15.9163, Val Loss: 15.9257\n",
      "Epoch 130/200, Train Loss: 15.9380, Val Loss: 15.6932\n",
      "  New best validation loss: 15.6932\n",
      "Epoch 131/200, Train Loss: 15.9135, Val Loss: 16.0381\n",
      "Epoch 132/200, Train Loss: 15.8122, Val Loss: 15.7332\n",
      "Epoch 133/200, Train Loss: 15.8725, Val Loss: 15.7807\n",
      "Epoch 134/200, Train Loss: 15.8618, Val Loss: 15.7336\n",
      "Epoch 135/200, Train Loss: 15.8807, Val Loss: 15.7842\n",
      "Epoch 136/200, Train Loss: 15.8686, Val Loss: 15.7803\n",
      "Epoch 137/200, Train Loss: 15.8583, Val Loss: 15.7197\n",
      "Epoch 138/200, Train Loss: 15.9203, Val Loss: 15.8840\n",
      "Epoch 139/200, Train Loss: 15.8424, Val Loss: 15.6857\n",
      "  New best validation loss: 15.6857\n",
      "Epoch 140/200, Train Loss: 15.8654, Val Loss: 15.8215\n",
      "Epoch 141/200, Train Loss: 15.8713, Val Loss: 15.7629\n",
      "Epoch 142/200, Train Loss: 15.7837, Val Loss: 15.7411\n",
      "Epoch 143/200, Train Loss: 15.7797, Val Loss: 15.8631\n",
      "Epoch 144/200, Train Loss: 15.7748, Val Loss: 15.7127\n",
      "Epoch 145/200, Train Loss: 15.7546, Val Loss: 15.7685\n",
      "Epoch 146/200, Train Loss: 15.7807, Val Loss: 15.7968\n",
      "Epoch 147/200, Train Loss: 15.7691, Val Loss: 15.8512\n",
      "Epoch 148/200, Train Loss: 15.7547, Val Loss: 15.6950\n",
      "Epoch 149/200, Train Loss: 15.8060, Val Loss: 15.7205\n",
      "Epoch 150/200, Train Loss: 15.8078, Val Loss: 15.6771\n",
      "  New best validation loss: 15.6771\n",
      "Epoch 151/200, Train Loss: 15.7761, Val Loss: 15.6857\n",
      "Epoch 152/200, Train Loss: 15.7260, Val Loss: 15.9129\n",
      "Epoch 153/200, Train Loss: 15.7377, Val Loss: 15.7127\n",
      "Epoch 154/200, Train Loss: 15.8135, Val Loss: 15.6450\n",
      "  New best validation loss: 15.6450\n",
      "Epoch 155/200, Train Loss: 15.7681, Val Loss: 15.9051\n",
      "Epoch 156/200, Train Loss: 15.8338, Val Loss: 15.6397\n",
      "  New best validation loss: 15.6397\n",
      "Epoch 157/200, Train Loss: 15.7763, Val Loss: 15.9349\n",
      "Epoch 158/200, Train Loss: 15.7740, Val Loss: 15.6643\n",
      "Epoch 159/200, Train Loss: 15.7788, Val Loss: 15.8424\n",
      "Epoch 160/200, Train Loss: 15.8032, Val Loss: 15.7670\n",
      "Epoch 161/200, Train Loss: 15.8298, Val Loss: 15.5890\n",
      "  New best validation loss: 15.5890\n",
      "Epoch 162/200, Train Loss: 15.8132, Val Loss: 15.8328\n",
      "Epoch 163/200, Train Loss: 15.7556, Val Loss: 15.6718\n",
      "Epoch 164/200, Train Loss: 15.7107, Val Loss: 15.7386\n",
      "Epoch 165/200, Train Loss: 15.6561, Val Loss: 15.6995\n",
      "Epoch 166/200, Train Loss: 15.7207, Val Loss: 15.6569\n",
      "Epoch 167/200, Train Loss: 15.7310, Val Loss: 15.7349\n",
      "Epoch 168/200, Train Loss: 15.6903, Val Loss: 15.7057\n",
      "Epoch 169/200, Train Loss: 15.7003, Val Loss: 15.7487\n",
      "Epoch 170/200, Train Loss: 15.6948, Val Loss: 15.6545\n",
      "Epoch 171/200, Train Loss: 15.7110, Val Loss: 15.6971\n",
      "Epoch 172/200, Train Loss: 15.7022, Val Loss: 15.6073\n",
      "Epoch 173/200, Train Loss: 15.6808, Val Loss: 15.6962\n",
      "Epoch 174/200, Train Loss: 15.6585, Val Loss: 15.6991\n",
      "Epoch 175/200, Train Loss: 15.6756, Val Loss: 15.6821\n",
      "Epoch 176/200, Train Loss: 15.6936, Val Loss: 15.7077\n",
      "Epoch 177/200, Train Loss: 15.6463, Val Loss: 15.6314\n",
      "Epoch 178/200, Train Loss: 15.6568, Val Loss: 15.6790\n",
      "Epoch 179/200, Train Loss: 15.7014, Val Loss: 15.5849\n",
      "  New best validation loss: 15.5849\n",
      "Epoch 180/200, Train Loss: 15.6166, Val Loss: 15.7484\n",
      "Epoch 181/200, Train Loss: 15.6638, Val Loss: 15.6369\n",
      "Epoch 182/200, Train Loss: 15.6587, Val Loss: 15.5222\n",
      "  New best validation loss: 15.5222\n",
      "Epoch 183/200, Train Loss: 15.7867, Val Loss: 15.7149\n",
      "Epoch 184/200, Train Loss: 15.7636, Val Loss: 15.5162\n",
      "  New best validation loss: 15.5162\n",
      "Epoch 185/200, Train Loss: 15.5944, Val Loss: 15.8107\n",
      "Epoch 186/200, Train Loss: 15.6584, Val Loss: 15.5787\n",
      "Epoch 187/200, Train Loss: 15.6898, Val Loss: 15.6141\n",
      "Epoch 188/200, Train Loss: 15.6295, Val Loss: 15.6090\n",
      "Epoch 189/200, Train Loss: 15.6693, Val Loss: 15.5390\n",
      "Epoch 190/200, Train Loss: 15.6800, Val Loss: 15.6332\n",
      "Epoch 191/200, Train Loss: 15.6172, Val Loss: 15.5337\n",
      "Epoch 192/200, Train Loss: 15.5694, Val Loss: 15.6655\n",
      "Epoch 193/200, Train Loss: 15.6101, Val Loss: 15.5413\n",
      "Epoch 194/200, Train Loss: 15.6534, Val Loss: 15.4916\n",
      "  New best validation loss: 15.4916\n",
      "Epoch 195/200, Train Loss: 15.5538, Val Loss: 15.6263\n",
      "Epoch 196/200, Train Loss: 15.5968, Val Loss: 15.5672\n",
      "Epoch 197/200, Train Loss: 15.5901, Val Loss: 15.5167\n",
      "Epoch 198/200, Train Loss: 15.5667, Val Loss: 15.5899\n",
      "Epoch 199/200, Train Loss: 15.6567, Val Loss: 15.5673\n",
      "Epoch 200/200, Train Loss: 15.6158, Val Loss: 15.6317\n",
      "\n",
      "Loaded best model (Val Loss: 15.4916) for final hidden state extraction.\n",
      "Saved best model for TransformerCausal (samples=160) to results_data_size_sweep/20250514_045146/samples_160/TransformerCausal_samples_160_best.pt\n",
      "\n",
      "--- Performing Decodability Analysis for TransformerCausal (samples=160, k=15) ---\n",
      "  Analyzing decodability for TransformerCausal...\n",
      "  Hidden states shape: torch.Size([160, 200, 20])\n",
      "  Coefficients shape: torch.Size([160, 15])\n",
      "  Processed hidden states shape for decoder: torch.Size([160, 20])\n",
      "  RidgeCV Decoder for TransformerCausal - Test MSE: 1.7340, Test R2: 0.1352 (best alpha: 0.2976)\n",
      "  Decodability plot saved to results_data_size_sweep/20250514_045146/samples_160/decodability_TransformerCausal_coeff1.png\n",
      "Decodability (R2 score) for TransformerCausal (samples=160): 0.1352\n",
      "\n",
      "--- Training HIPPORNN_LegT (samples=160, k=15) ---\n",
      "Number of parameters: 4029\n",
      "Epoch 1/200, Train Loss: 16.7059, Val Loss: 15.8522\n",
      "  New best validation loss: 15.8522\n",
      "Epoch 2/200, Train Loss: 16.7042, Val Loss: 15.8510\n",
      "  New best validation loss: 15.8510\n",
      "Epoch 3/200, Train Loss: 16.7028, Val Loss: 15.8500\n",
      "  New best validation loss: 15.8500\n",
      "Epoch 4/200, Train Loss: 16.7010, Val Loss: 15.8490\n",
      "  New best validation loss: 15.8490\n",
      "Epoch 5/200, Train Loss: 16.6989, Val Loss: 15.8478\n",
      "  New best validation loss: 15.8478\n",
      "Epoch 6/200, Train Loss: 16.6969, Val Loss: 15.8468\n",
      "  New best validation loss: 15.8468\n",
      "Epoch 7/200, Train Loss: 16.6945, Val Loss: 15.8456\n",
      "  New best validation loss: 15.8456\n",
      "Epoch 8/200, Train Loss: 16.6920, Val Loss: 15.8441\n",
      "  New best validation loss: 15.8441\n",
      "Epoch 9/200, Train Loss: 16.6891, Val Loss: 15.8428\n",
      "  New best validation loss: 15.8428\n",
      "Epoch 10/200, Train Loss: 16.6854, Val Loss: 15.8411\n",
      "  New best validation loss: 15.8411\n",
      "Epoch 11/200, Train Loss: 16.6819, Val Loss: 15.8392\n",
      "  New best validation loss: 15.8392\n",
      "Epoch 12/200, Train Loss: 16.6776, Val Loss: 15.8373\n",
      "  New best validation loss: 15.8373\n",
      "Epoch 13/200, Train Loss: 16.6729, Val Loss: 15.8350\n",
      "  New best validation loss: 15.8350\n",
      "Epoch 14/200, Train Loss: 16.6674, Val Loss: 15.8321\n",
      "  New best validation loss: 15.8321\n",
      "Epoch 15/200, Train Loss: 16.6608, Val Loss: 15.8291\n",
      "  New best validation loss: 15.8291\n",
      "Epoch 16/200, Train Loss: 16.6541, Val Loss: 15.8253\n",
      "  New best validation loss: 15.8253\n",
      "Epoch 17/200, Train Loss: 16.6468, Val Loss: 15.8210\n",
      "  New best validation loss: 15.8210\n",
      "Epoch 18/200, Train Loss: 16.6367, Val Loss: 15.8157\n",
      "  New best validation loss: 15.8157\n",
      "Epoch 19/200, Train Loss: 16.6252, Val Loss: 15.8099\n",
      "  New best validation loss: 15.8099\n",
      "Epoch 20/200, Train Loss: 16.6124, Val Loss: 15.8029\n",
      "  New best validation loss: 15.8029\n",
      "Epoch 21/200, Train Loss: 16.5959, Val Loss: 15.7946\n",
      "  New best validation loss: 15.7946\n",
      "Epoch 22/200, Train Loss: 16.5759, Val Loss: 15.7848\n",
      "  New best validation loss: 15.7848\n",
      "Epoch 23/200, Train Loss: 16.5537, Val Loss: 15.7737\n",
      "  New best validation loss: 15.7737\n",
      "Epoch 24/200, Train Loss: 16.5237, Val Loss: 15.7639\n",
      "  New best validation loss: 15.7639\n",
      "Epoch 25/200, Train Loss: 16.5001, Val Loss: 15.7551\n",
      "  New best validation loss: 15.7551\n",
      "Epoch 26/200, Train Loss: 16.4636, Val Loss: 15.7494\n",
      "  New best validation loss: 15.7494\n",
      "Epoch 27/200, Train Loss: 16.4281, Val Loss: 15.7410\n",
      "  New best validation loss: 15.7410\n",
      "Epoch 28/200, Train Loss: 16.3979, Val Loss: 15.7418\n",
      "Epoch 29/200, Train Loss: 16.3738, Val Loss: 15.7367\n",
      "  New best validation loss: 15.7367\n",
      "Epoch 30/200, Train Loss: 16.3474, Val Loss: 15.7353\n",
      "  New best validation loss: 15.7353\n",
      "Epoch 31/200, Train Loss: 16.3186, Val Loss: 15.7281\n",
      "  New best validation loss: 15.7281\n",
      "Epoch 32/200, Train Loss: 16.2944, Val Loss: 15.7139\n",
      "  New best validation loss: 15.7139\n",
      "Epoch 33/200, Train Loss: 16.2680, Val Loss: 15.7055\n",
      "  New best validation loss: 15.7055\n",
      "Epoch 34/200, Train Loss: 16.2432, Val Loss: 15.6927\n",
      "  New best validation loss: 15.6927\n",
      "Epoch 35/200, Train Loss: 16.2150, Val Loss: 15.6958\n",
      "Epoch 36/200, Train Loss: 16.1952, Val Loss: 15.7024\n",
      "Epoch 37/200, Train Loss: 16.1747, Val Loss: 15.7001\n",
      "Epoch 38/200, Train Loss: 16.1560, Val Loss: 15.6963\n",
      "Epoch 39/200, Train Loss: 16.1398, Val Loss: 15.6968\n",
      "Epoch 40/200, Train Loss: 16.1292, Val Loss: 15.6922\n",
      "  New best validation loss: 15.6922\n",
      "Epoch 41/200, Train Loss: 16.1215, Val Loss: 15.6964\n",
      "Epoch 42/200, Train Loss: 16.1072, Val Loss: 15.6802\n",
      "  New best validation loss: 15.6802\n",
      "Epoch 43/200, Train Loss: 16.1005, Val Loss: 15.6752\n",
      "  New best validation loss: 15.6752\n",
      "Epoch 44/200, Train Loss: 16.0869, Val Loss: 15.6669\n",
      "  New best validation loss: 15.6669\n",
      "Epoch 45/200, Train Loss: 16.0776, Val Loss: 15.6646\n",
      "  New best validation loss: 15.6646\n",
      "Epoch 46/200, Train Loss: 16.0702, Val Loss: 15.6618\n",
      "  New best validation loss: 15.6618\n",
      "Epoch 47/200, Train Loss: 16.0623, Val Loss: 15.6628\n",
      "Epoch 48/200, Train Loss: 16.0569, Val Loss: 15.6489\n",
      "  New best validation loss: 15.6489\n",
      "Epoch 49/200, Train Loss: 16.0477, Val Loss: 15.6432\n",
      "  New best validation loss: 15.6432\n",
      "Epoch 50/200, Train Loss: 16.0391, Val Loss: 15.6458\n",
      "Epoch 51/200, Train Loss: 16.0318, Val Loss: 15.6453\n",
      "Epoch 52/200, Train Loss: 16.0241, Val Loss: 15.6445\n",
      "Epoch 53/200, Train Loss: 16.0212, Val Loss: 15.6498\n",
      "Epoch 54/200, Train Loss: 16.0109, Val Loss: 15.6387\n",
      "  New best validation loss: 15.6387\n",
      "Epoch 55/200, Train Loss: 16.0030, Val Loss: 15.6279\n",
      "  New best validation loss: 15.6279\n",
      "Epoch 56/200, Train Loss: 15.9946, Val Loss: 15.6260\n",
      "  New best validation loss: 15.6260\n",
      "Epoch 57/200, Train Loss: 15.9897, Val Loss: 15.6146\n",
      "  New best validation loss: 15.6146\n",
      "Epoch 58/200, Train Loss: 15.9908, Val Loss: 15.6220\n",
      "Epoch 59/200, Train Loss: 15.9720, Val Loss: 15.6120\n",
      "  New best validation loss: 15.6120\n",
      "Epoch 60/200, Train Loss: 15.9670, Val Loss: 15.6013\n",
      "  New best validation loss: 15.6013\n",
      "Epoch 61/200, Train Loss: 15.9584, Val Loss: 15.5954\n",
      "  New best validation loss: 15.5954\n",
      "Epoch 62/200, Train Loss: 15.9526, Val Loss: 15.5980\n",
      "Epoch 63/200, Train Loss: 15.9441, Val Loss: 15.5976\n",
      "Epoch 64/200, Train Loss: 15.9389, Val Loss: 15.6013\n",
      "Epoch 65/200, Train Loss: 15.9281, Val Loss: 15.5846\n",
      "  New best validation loss: 15.5846\n",
      "Epoch 66/200, Train Loss: 15.9196, Val Loss: 15.5723\n",
      "  New best validation loss: 15.5723\n",
      "Epoch 67/200, Train Loss: 15.9110, Val Loss: 15.5659\n",
      "  New best validation loss: 15.5659\n",
      "Epoch 68/200, Train Loss: 15.9014, Val Loss: 15.5652\n",
      "  New best validation loss: 15.5652\n",
      "Epoch 69/200, Train Loss: 15.8916, Val Loss: 15.5578\n",
      "  New best validation loss: 15.5578\n",
      "Epoch 70/200, Train Loss: 15.8840, Val Loss: 15.5546\n",
      "  New best validation loss: 15.5546\n",
      "Epoch 71/200, Train Loss: 15.8753, Val Loss: 15.5505\n",
      "  New best validation loss: 15.5505\n",
      "Epoch 72/200, Train Loss: 15.8643, Val Loss: 15.5376\n",
      "  New best validation loss: 15.5376\n",
      "Epoch 73/200, Train Loss: 15.8544, Val Loss: 15.5290\n",
      "  New best validation loss: 15.5290\n",
      "Epoch 74/200, Train Loss: 15.8433, Val Loss: 15.5204\n",
      "  New best validation loss: 15.5204\n",
      "Epoch 75/200, Train Loss: 15.8368, Val Loss: 15.5042\n",
      "  New best validation loss: 15.5042\n",
      "Epoch 76/200, Train Loss: 15.8228, Val Loss: 15.4934\n",
      "  New best validation loss: 15.4934\n",
      "Epoch 77/200, Train Loss: 15.8124, Val Loss: 15.4917\n",
      "  New best validation loss: 15.4917\n",
      "Epoch 78/200, Train Loss: 15.7996, Val Loss: 15.4888\n",
      "  New best validation loss: 15.4888\n",
      "Epoch 79/200, Train Loss: 15.7871, Val Loss: 15.4720\n",
      "  New best validation loss: 15.4720\n",
      "Epoch 80/200, Train Loss: 15.7753, Val Loss: 15.4613\n",
      "  New best validation loss: 15.4613\n",
      "Epoch 81/200, Train Loss: 15.7627, Val Loss: 15.4483\n",
      "  New best validation loss: 15.4483\n",
      "Epoch 82/200, Train Loss: 15.7468, Val Loss: 15.4327\n",
      "  New best validation loss: 15.4327\n",
      "Epoch 83/200, Train Loss: 15.7329, Val Loss: 15.4235\n",
      "  New best validation loss: 15.4235\n",
      "Epoch 84/200, Train Loss: 15.7163, Val Loss: 15.4020\n",
      "  New best validation loss: 15.4020\n",
      "Epoch 85/200, Train Loss: 15.7017, Val Loss: 15.3844\n",
      "  New best validation loss: 15.3844\n",
      "Epoch 86/200, Train Loss: 15.6884, Val Loss: 15.3610\n",
      "  New best validation loss: 15.3610\n",
      "Epoch 87/200, Train Loss: 15.6697, Val Loss: 15.3478\n",
      "  New best validation loss: 15.3478\n",
      "Epoch 88/200, Train Loss: 15.6488, Val Loss: 15.3419\n",
      "  New best validation loss: 15.3419\n",
      "Epoch 89/200, Train Loss: 15.6305, Val Loss: 15.3336\n",
      "  New best validation loss: 15.3336\n",
      "Epoch 90/200, Train Loss: 15.6096, Val Loss: 15.3064\n",
      "  New best validation loss: 15.3064\n",
      "Epoch 91/200, Train Loss: 15.5882, Val Loss: 15.2875\n",
      "  New best validation loss: 15.2875\n",
      "Epoch 92/200, Train Loss: 15.5686, Val Loss: 15.2605\n",
      "  New best validation loss: 15.2605\n",
      "Epoch 93/200, Train Loss: 15.5395, Val Loss: 15.2431\n",
      "  New best validation loss: 15.2431\n",
      "Epoch 94/200, Train Loss: 15.5185, Val Loss: 15.2318\n",
      "  New best validation loss: 15.2318\n",
      "Epoch 95/200, Train Loss: 15.4913, Val Loss: 15.2119\n",
      "  New best validation loss: 15.2119\n",
      "Epoch 96/200, Train Loss: 15.4659, Val Loss: 15.2004\n",
      "  New best validation loss: 15.2004\n",
      "Epoch 97/200, Train Loss: 15.4384, Val Loss: 15.1814\n",
      "  New best validation loss: 15.1814\n",
      "Epoch 98/200, Train Loss: 15.4180, Val Loss: 15.1659\n",
      "  New best validation loss: 15.1659\n",
      "Epoch 99/200, Train Loss: 15.3843, Val Loss: 15.1606\n",
      "  New best validation loss: 15.1606\n",
      "Epoch 100/200, Train Loss: 15.3537, Val Loss: 15.1444\n",
      "  New best validation loss: 15.1444\n",
      "Epoch 101/200, Train Loss: 15.3294, Val Loss: 15.1334\n",
      "  New best validation loss: 15.1334\n",
      "Epoch 102/200, Train Loss: 15.3014, Val Loss: 15.1050\n",
      "  New best validation loss: 15.1050\n",
      "Epoch 103/200, Train Loss: 15.2763, Val Loss: 15.0850\n",
      "  New best validation loss: 15.0850\n",
      "Epoch 104/200, Train Loss: 15.2457, Val Loss: 15.0842\n",
      "  New best validation loss: 15.0842\n",
      "Epoch 105/200, Train Loss: 15.2216, Val Loss: 15.0921\n",
      "Epoch 106/200, Train Loss: 15.1935, Val Loss: 15.0865\n",
      "Epoch 107/200, Train Loss: 15.1691, Val Loss: 15.0882\n",
      "Epoch 108/200, Train Loss: 15.1423, Val Loss: 15.0675\n",
      "  New best validation loss: 15.0675\n",
      "Epoch 109/200, Train Loss: 15.1130, Val Loss: 15.0553\n",
      "  New best validation loss: 15.0553\n",
      "Epoch 110/200, Train Loss: 15.0877, Val Loss: 15.0513\n",
      "  New best validation loss: 15.0513\n",
      "Epoch 111/200, Train Loss: 15.0685, Val Loss: 15.0361\n",
      "  New best validation loss: 15.0361\n",
      "Epoch 112/200, Train Loss: 15.0447, Val Loss: 15.0297\n",
      "  New best validation loss: 15.0297\n",
      "Epoch 113/200, Train Loss: 15.0149, Val Loss: 15.0262\n",
      "  New best validation loss: 15.0262\n",
      "Epoch 114/200, Train Loss: 14.9873, Val Loss: 15.0083\n",
      "  New best validation loss: 15.0083\n",
      "Epoch 115/200, Train Loss: 14.9666, Val Loss: 14.9867\n",
      "  New best validation loss: 14.9867\n",
      "Epoch 116/200, Train Loss: 14.9413, Val Loss: 14.9942\n",
      "Epoch 117/200, Train Loss: 14.9249, Val Loss: 15.0091\n",
      "Epoch 118/200, Train Loss: 14.9111, Val Loss: 15.0072\n",
      "Epoch 119/200, Train Loss: 14.8625, Val Loss: 14.9626\n",
      "  New best validation loss: 14.9626\n",
      "Epoch 120/200, Train Loss: 14.8784, Val Loss: 14.9477\n",
      "  New best validation loss: 14.9477\n",
      "Epoch 121/200, Train Loss: 14.8401, Val Loss: 14.9431\n",
      "  New best validation loss: 14.9431\n",
      "Epoch 122/200, Train Loss: 14.7996, Val Loss: 14.9548\n",
      "Epoch 123/200, Train Loss: 14.7881, Val Loss: 14.9548\n",
      "Epoch 124/200, Train Loss: 14.7599, Val Loss: 14.9323\n",
      "  New best validation loss: 14.9323\n",
      "Epoch 125/200, Train Loss: 14.7367, Val Loss: 14.9133\n",
      "  New best validation loss: 14.9133\n",
      "Epoch 126/200, Train Loss: 14.7395, Val Loss: 14.9098\n",
      "  New best validation loss: 14.9098\n",
      "Epoch 127/200, Train Loss: 14.6933, Val Loss: 14.9340\n",
      "Epoch 128/200, Train Loss: 14.6638, Val Loss: 14.9410\n",
      "Epoch 129/200, Train Loss: 14.6582, Val Loss: 14.9193\n",
      "Epoch 130/200, Train Loss: 14.6352, Val Loss: 14.8803\n",
      "  New best validation loss: 14.8803\n",
      "Epoch 131/200, Train Loss: 14.6042, Val Loss: 14.8752\n",
      "  New best validation loss: 14.8752\n",
      "Epoch 132/200, Train Loss: 14.5884, Val Loss: 14.8783\n",
      "Epoch 133/200, Train Loss: 14.5617, Val Loss: 14.8920\n",
      "Epoch 134/200, Train Loss: 14.5443, Val Loss: 14.8779\n",
      "Epoch 135/200, Train Loss: 14.5272, Val Loss: 14.8831\n",
      "Epoch 136/200, Train Loss: 14.5006, Val Loss: 14.8777\n",
      "Epoch 137/200, Train Loss: 14.4768, Val Loss: 14.8549\n",
      "  New best validation loss: 14.8549\n",
      "Epoch 138/200, Train Loss: 14.4610, Val Loss: 14.8504\n",
      "  New best validation loss: 14.8504\n",
      "Epoch 139/200, Train Loss: 14.4393, Val Loss: 14.8535\n",
      "Epoch 140/200, Train Loss: 14.4201, Val Loss: 14.8515\n",
      "Epoch 141/200, Train Loss: 14.4029, Val Loss: 14.8520\n",
      "Epoch 142/200, Train Loss: 14.3809, Val Loss: 14.8445\n",
      "  New best validation loss: 14.8445\n",
      "Epoch 143/200, Train Loss: 14.3596, Val Loss: 14.8539\n",
      "Epoch 144/200, Train Loss: 14.3407, Val Loss: 14.8413\n",
      "  New best validation loss: 14.8413\n",
      "Epoch 145/200, Train Loss: 14.3221, Val Loss: 14.8269\n",
      "  New best validation loss: 14.8269\n",
      "Epoch 146/200, Train Loss: 14.2961, Val Loss: 14.8283\n",
      "Epoch 147/200, Train Loss: 14.2804, Val Loss: 14.8230\n",
      "  New best validation loss: 14.8230\n",
      "Epoch 148/200, Train Loss: 14.2593, Val Loss: 14.8293\n",
      "Epoch 149/200, Train Loss: 14.2331, Val Loss: 14.8264\n",
      "Epoch 150/200, Train Loss: 14.2289, Val Loss: 14.8240\n",
      "Epoch 151/200, Train Loss: 14.2054, Val Loss: 14.8282\n",
      "Epoch 152/200, Train Loss: 14.1763, Val Loss: 14.8006\n",
      "  New best validation loss: 14.8006\n",
      "Epoch 153/200, Train Loss: 14.1639, Val Loss: 14.7895\n",
      "  New best validation loss: 14.7895\n",
      "Epoch 154/200, Train Loss: 14.1341, Val Loss: 14.7986\n",
      "Epoch 155/200, Train Loss: 14.1191, Val Loss: 14.8060\n",
      "Epoch 156/200, Train Loss: 14.0943, Val Loss: 14.8147\n",
      "Epoch 157/200, Train Loss: 14.0752, Val Loss: 14.7737\n",
      "  New best validation loss: 14.7737\n",
      "Epoch 158/200, Train Loss: 14.0467, Val Loss: 14.7702\n",
      "  New best validation loss: 14.7702\n",
      "Epoch 159/200, Train Loss: 14.0618, Val Loss: 14.7952\n",
      "Epoch 160/200, Train Loss: 14.0290, Val Loss: 14.7498\n",
      "  New best validation loss: 14.7498\n",
      "Epoch 161/200, Train Loss: 14.0115, Val Loss: 14.7711\n",
      "Epoch 162/200, Train Loss: 13.9732, Val Loss: 14.7660\n",
      "Epoch 163/200, Train Loss: 13.9363, Val Loss: 14.7495\n",
      "  New best validation loss: 14.7495\n",
      "Epoch 164/200, Train Loss: 13.9197, Val Loss: 14.7522\n",
      "Epoch 165/200, Train Loss: 13.8941, Val Loss: 14.7616\n",
      "Epoch 166/200, Train Loss: 13.8759, Val Loss: 14.7555\n",
      "Epoch 167/200, Train Loss: 13.8520, Val Loss: 14.7444\n",
      "  New best validation loss: 14.7444\n",
      "Epoch 168/200, Train Loss: 13.8346, Val Loss: 14.7063\n",
      "  New best validation loss: 14.7063\n",
      "Epoch 169/200, Train Loss: 13.8229, Val Loss: 14.7250\n",
      "Epoch 170/200, Train Loss: 13.7883, Val Loss: 14.6949\n",
      "  New best validation loss: 14.6949\n",
      "Epoch 171/200, Train Loss: 13.7879, Val Loss: 14.6354\n",
      "  New best validation loss: 14.6354\n",
      "Epoch 172/200, Train Loss: 13.7526, Val Loss: 14.6801\n",
      "Epoch 173/200, Train Loss: 13.7430, Val Loss: 14.6946\n",
      "Epoch 174/200, Train Loss: 13.7355, Val Loss: 14.6149\n",
      "  New best validation loss: 14.6149\n",
      "Epoch 175/200, Train Loss: 13.7177, Val Loss: 14.6448\n",
      "Epoch 176/200, Train Loss: 13.6815, Val Loss: 14.6746\n",
      "Epoch 177/200, Train Loss: 13.6717, Val Loss: 14.6116\n",
      "  New best validation loss: 14.6116\n",
      "Epoch 178/200, Train Loss: 13.6603, Val Loss: 14.5757\n",
      "  New best validation loss: 14.5757\n",
      "Epoch 179/200, Train Loss: 13.6435, Val Loss: 14.6237\n",
      "Epoch 180/200, Train Loss: 13.6437, Val Loss: 14.5951\n",
      "Epoch 181/200, Train Loss: 13.6143, Val Loss: 14.5674\n",
      "  New best validation loss: 14.5674\n",
      "Epoch 182/200, Train Loss: 13.6110, Val Loss: 14.6026\n",
      "Epoch 183/200, Train Loss: 13.5871, Val Loss: 14.5764\n",
      "Epoch 184/200, Train Loss: 13.5740, Val Loss: 14.5636\n",
      "  New best validation loss: 14.5636\n",
      "Epoch 185/200, Train Loss: 13.5520, Val Loss: 14.5616\n",
      "  New best validation loss: 14.5616\n",
      "Epoch 186/200, Train Loss: 13.5621, Val Loss: 14.5865\n",
      "Epoch 187/200, Train Loss: 13.5728, Val Loss: 14.5973\n",
      "Epoch 188/200, Train Loss: 13.5187, Val Loss: 14.5485\n",
      "  New best validation loss: 14.5485\n",
      "Epoch 189/200, Train Loss: 13.5090, Val Loss: 14.5581\n",
      "Epoch 190/200, Train Loss: 13.5080, Val Loss: 14.6054\n",
      "Epoch 191/200, Train Loss: 13.4594, Val Loss: 14.5329\n",
      "  New best validation loss: 14.5329\n",
      "Epoch 192/200, Train Loss: 13.4669, Val Loss: 14.4583\n",
      "  New best validation loss: 14.4583\n",
      "Epoch 193/200, Train Loss: 13.4457, Val Loss: 14.5331\n",
      "Epoch 194/200, Train Loss: 13.4232, Val Loss: 14.6056\n",
      "Epoch 195/200, Train Loss: 13.4188, Val Loss: 14.5115\n",
      "Epoch 196/200, Train Loss: 13.3986, Val Loss: 14.4768\n",
      "Epoch 197/200, Train Loss: 13.4019, Val Loss: 14.5136\n",
      "Epoch 198/200, Train Loss: 13.3905, Val Loss: 14.5383\n",
      "Epoch 199/200, Train Loss: 13.3971, Val Loss: 14.5480\n",
      "Epoch 200/200, Train Loss: 13.3751, Val Loss: 14.4790\n",
      "\n",
      "Loaded best model (Val Loss: 14.4583) for final hidden state extraction.\n",
      "Saved best model for HIPPORNN_LegT (samples=160) to results_data_size_sweep/20250514_045146/samples_160/HIPPORNN_LegT_samples_160_best.pt\n",
      "\n",
      "--- Performing Decodability Analysis for HIPPORNN_LegT (samples=160, k=15) ---\n",
      "  Analyzing decodability for HIPPORNN_LegT...\n",
      "  Hidden states shape: torch.Size([160, 200, 25])\n",
      "  Coefficients shape: torch.Size([160, 15])\n",
      "  Processed hidden states shape for decoder: torch.Size([160, 25])\n",
      "  RidgeCV Decoder for HIPPORNN_LegT - Test MSE: 1.4513, Test R2: 0.2727 (best alpha: 11.2884)\n",
      "  Decodability plot saved to results_data_size_sweep/20250514_045146/samples_160/decodability_HIPPORNN_LegT_coeff1.png\n",
      "Decodability (R2 score) for HIPPORNN_LegT (samples=160): 0.2727\n",
      "\n",
      "--- Training NMRNN_Spatial_ModReadout (samples=160, k=15) ---\n",
      "Number of parameters: 66832\n",
      "Epoch 1/200, Train Loss: 16.6973, Val Loss: 15.7933\n",
      "  New best validation loss: 15.7933\n",
      "Epoch 2/200, Train Loss: 16.6124, Val Loss: 15.7225\n",
      "  New best validation loss: 15.7225\n",
      "Epoch 3/200, Train Loss: 16.5283, Val Loss: 15.7475\n",
      "Epoch 4/200, Train Loss: 16.5043, Val Loss: 15.7317\n",
      "Epoch 5/200, Train Loss: 16.4509, Val Loss: 15.7072\n",
      "  New best validation loss: 15.7072\n",
      "Epoch 6/200, Train Loss: 16.4005, Val Loss: 15.6940\n",
      "  New best validation loss: 15.6940\n",
      "Epoch 7/200, Train Loss: 16.3571, Val Loss: 15.7114\n",
      "Epoch 8/200, Train Loss: 16.3212, Val Loss: 15.7511\n",
      "Epoch 9/200, Train Loss: 16.2892, Val Loss: 15.7965\n",
      "Epoch 10/200, Train Loss: 16.2581, Val Loss: 15.8494\n",
      "Epoch 11/200, Train Loss: 16.2392, Val Loss: 15.8726\n",
      "Epoch 12/200, Train Loss: 16.2174, Val Loss: 15.8938\n",
      "Epoch 13/200, Train Loss: 16.1924, Val Loss: 15.8884\n",
      "Epoch 14/200, Train Loss: 16.1809, Val Loss: 15.8853\n",
      "Epoch 15/200, Train Loss: 16.1394, Val Loss: 15.8609\n",
      "Epoch 16/200, Train Loss: 16.1179, Val Loss: 15.8600\n",
      "Epoch 17/200, Train Loss: 16.0910, Val Loss: 15.8780\n",
      "Epoch 18/200, Train Loss: 16.0684, Val Loss: 15.8834\n",
      "Epoch 19/200, Train Loss: 16.0382, Val Loss: 15.9007\n",
      "Epoch 20/200, Train Loss: 16.0179, Val Loss: 15.9458\n",
      "Epoch 21/200, Train Loss: 15.9884, Val Loss: 15.9256\n",
      "Epoch 22/200, Train Loss: 15.9591, Val Loss: 15.9423\n",
      "Epoch 23/200, Train Loss: 15.9294, Val Loss: 15.9662\n",
      "Epoch 24/200, Train Loss: 15.9125, Val Loss: 16.0070\n",
      "Epoch 25/200, Train Loss: 15.8732, Val Loss: 16.0227\n",
      "Epoch 26/200, Train Loss: 15.8616, Val Loss: 16.0272\n",
      "Epoch 27/200, Train Loss: 15.8227, Val Loss: 16.0353\n",
      "Epoch 28/200, Train Loss: 15.7968, Val Loss: 16.0062\n",
      "Epoch 29/200, Train Loss: 15.7749, Val Loss: 16.0030\n",
      "Epoch 30/200, Train Loss: 15.7537, Val Loss: 16.0290\n",
      "Epoch 31/200, Train Loss: 15.7041, Val Loss: 16.0420\n",
      "Epoch 32/200, Train Loss: 15.6689, Val Loss: 16.0207\n",
      "Epoch 33/200, Train Loss: 15.6425, Val Loss: 16.0310\n",
      "Epoch 34/200, Train Loss: 15.6290, Val Loss: 16.0311\n",
      "Epoch 35/200, Train Loss: 15.5634, Val Loss: 16.0239\n",
      "Epoch 36/200, Train Loss: 15.5161, Val Loss: 16.0709\n",
      "Epoch 37/200, Train Loss: 15.5261, Val Loss: 16.0407\n",
      "Epoch 38/200, Train Loss: 15.4485, Val Loss: 16.0858\n",
      "Epoch 39/200, Train Loss: 15.3809, Val Loss: 16.0666\n",
      "Epoch 40/200, Train Loss: 15.3336, Val Loss: 16.1743\n",
      "Epoch 41/200, Train Loss: 15.2808, Val Loss: 16.1705\n",
      "Epoch 42/200, Train Loss: 15.1963, Val Loss: 16.2985\n",
      "Epoch 43/200, Train Loss: 15.1676, Val Loss: 16.2424\n",
      "Epoch 44/200, Train Loss: 15.0965, Val Loss: 16.2874\n",
      "Epoch 45/200, Train Loss: 15.0103, Val Loss: 16.2732\n",
      "Epoch 46/200, Train Loss: 15.0140, Val Loss: 16.3926\n",
      "Epoch 47/200, Train Loss: 15.0183, Val Loss: 16.3695\n",
      "Epoch 48/200, Train Loss: 14.9812, Val Loss: 16.3492\n",
      "Epoch 49/200, Train Loss: 14.8879, Val Loss: 16.3261\n",
      "Epoch 50/200, Train Loss: 14.8589, Val Loss: 16.4446\n",
      "Epoch 51/200, Train Loss: 14.8037, Val Loss: 16.3428\n",
      "Epoch 52/200, Train Loss: 14.7183, Val Loss: 16.3981\n",
      "Epoch 53/200, Train Loss: 14.7333, Val Loss: 16.4429\n",
      "Epoch 54/200, Train Loss: 14.6765, Val Loss: 16.5169\n",
      "Epoch 55/200, Train Loss: 14.6144, Val Loss: 16.3795\n",
      "Epoch 56/200, Train Loss: 14.5706, Val Loss: 16.5219\n",
      "Epoch 57/200, Train Loss: 14.5101, Val Loss: 16.5073\n",
      "Epoch 58/200, Train Loss: 14.4278, Val Loss: 16.6617\n",
      "Epoch 59/200, Train Loss: 14.4265, Val Loss: 16.5936\n",
      "Epoch 60/200, Train Loss: 14.4589, Val Loss: 16.6684\n",
      "Epoch 61/200, Train Loss: 14.3570, Val Loss: 16.7185\n",
      "Epoch 62/200, Train Loss: 14.2625, Val Loss: 16.8064\n",
      "Epoch 63/200, Train Loss: 14.2673, Val Loss: 16.9427\n",
      "Epoch 64/200, Train Loss: 14.1950, Val Loss: 16.6751\n",
      "Epoch 65/200, Train Loss: 14.1431, Val Loss: 16.9781\n",
      "Epoch 66/200, Train Loss: 14.1374, Val Loss: 17.0722\n",
      "Epoch 67/200, Train Loss: 14.0636, Val Loss: 16.8192\n",
      "Epoch 68/200, Train Loss: 13.9923, Val Loss: 16.9901\n",
      "Epoch 69/200, Train Loss: 13.9491, Val Loss: 17.1264\n",
      "Epoch 70/200, Train Loss: 13.9465, Val Loss: 16.9059\n",
      "Epoch 71/200, Train Loss: 13.8587, Val Loss: 17.1940\n",
      "Epoch 72/200, Train Loss: 13.7910, Val Loss: 17.1545\n",
      "Epoch 73/200, Train Loss: 13.8431, Val Loss: 17.3061\n",
      "Epoch 74/200, Train Loss: 13.7207, Val Loss: 17.3679\n",
      "Epoch 75/200, Train Loss: 13.7391, Val Loss: 17.3172\n",
      "Epoch 76/200, Train Loss: 13.6564, Val Loss: 17.3322\n",
      "Epoch 77/200, Train Loss: 13.6692, Val Loss: 17.7147\n",
      "Epoch 78/200, Train Loss: 13.6454, Val Loss: 17.4827\n",
      "Epoch 79/200, Train Loss: 13.6301, Val Loss: 17.4052\n",
      "Epoch 80/200, Train Loss: 13.4970, Val Loss: 17.6217\n",
      "Epoch 81/200, Train Loss: 13.4927, Val Loss: 17.6264\n",
      "Epoch 82/200, Train Loss: 13.3812, Val Loss: 17.6813\n",
      "Epoch 83/200, Train Loss: 13.3310, Val Loss: 17.4457\n",
      "Epoch 84/200, Train Loss: 13.3554, Val Loss: 17.8018\n",
      "Epoch 85/200, Train Loss: 13.2860, Val Loss: 17.8244\n",
      "Epoch 86/200, Train Loss: 13.2921, Val Loss: 17.6455\n",
      "Epoch 87/200, Train Loss: 13.2018, Val Loss: 17.8564\n",
      "Epoch 88/200, Train Loss: 13.2144, Val Loss: 17.7959\n",
      "Epoch 89/200, Train Loss: 13.1745, Val Loss: 17.5999\n",
      "Epoch 90/200, Train Loss: 13.1018, Val Loss: 18.0794\n",
      "Epoch 91/200, Train Loss: 13.1171, Val Loss: 17.6904\n",
      "Epoch 92/200, Train Loss: 13.0370, Val Loss: 17.8391\n",
      "Epoch 93/200, Train Loss: 12.9895, Val Loss: 18.0218\n",
      "Epoch 94/200, Train Loss: 12.9563, Val Loss: 17.9126\n",
      "Epoch 95/200, Train Loss: 12.9039, Val Loss: 18.0959\n",
      "Epoch 96/200, Train Loss: 12.8125, Val Loss: 17.8174\n",
      "Epoch 97/200, Train Loss: 12.7810, Val Loss: 18.3700\n",
      "Epoch 98/200, Train Loss: 12.8081, Val Loss: 18.1971\n",
      "Epoch 99/200, Train Loss: 12.7326, Val Loss: 17.9854\n",
      "Epoch 100/200, Train Loss: 12.6516, Val Loss: 18.2887\n",
      "Epoch 101/200, Train Loss: 12.6265, Val Loss: 18.3480\n",
      "Epoch 102/200, Train Loss: 12.5935, Val Loss: 18.2463\n",
      "Epoch 103/200, Train Loss: 12.4721, Val Loss: 18.4255\n",
      "Epoch 104/200, Train Loss: 12.5153, Val Loss: 18.3627\n",
      "Epoch 105/200, Train Loss: 12.4671, Val Loss: 18.4374\n",
      "Epoch 106/200, Train Loss: 12.3973, Val Loss: 18.3838\n",
      "Epoch 107/200, Train Loss: 12.3336, Val Loss: 18.7114\n",
      "Epoch 108/200, Train Loss: 12.2962, Val Loss: 18.3406\n",
      "Epoch 109/200, Train Loss: 12.2506, Val Loss: 18.7264\n",
      "Epoch 110/200, Train Loss: 12.2743, Val Loss: 18.5296\n",
      "Epoch 111/200, Train Loss: 12.2092, Val Loss: 18.7548\n",
      "Epoch 112/200, Train Loss: 12.1193, Val Loss: 18.8603\n",
      "Epoch 113/200, Train Loss: 12.2154, Val Loss: 18.5712\n",
      "Epoch 114/200, Train Loss: 12.1244, Val Loss: 18.9514\n",
      "Epoch 115/200, Train Loss: 12.1410, Val Loss: 18.6026\n",
      "Epoch 116/200, Train Loss: 12.0162, Val Loss: 19.1057\n",
      "Epoch 117/200, Train Loss: 12.1217, Val Loss: 18.7813\n",
      "Epoch 118/200, Train Loss: 12.0221, Val Loss: 18.9216\n",
      "Epoch 119/200, Train Loss: 12.3094, Val Loss: 18.4189\n",
      "Epoch 120/200, Train Loss: 12.0287, Val Loss: 19.0699\n",
      "Epoch 121/200, Train Loss: 12.0326, Val Loss: 18.8243\n",
      "Epoch 122/200, Train Loss: 11.9337, Val Loss: 18.9496\n",
      "Epoch 123/200, Train Loss: 11.8932, Val Loss: 19.0202\n",
      "Epoch 124/200, Train Loss: 11.8541, Val Loss: 18.8960\n",
      "Epoch 125/200, Train Loss: 11.9472, Val Loss: 19.0817\n",
      "Epoch 126/200, Train Loss: 11.7674, Val Loss: 19.2056\n",
      "Epoch 127/200, Train Loss: 11.7420, Val Loss: 18.9689\n",
      "Epoch 128/200, Train Loss: 11.6897, Val Loss: 19.3346\n",
      "Epoch 129/200, Train Loss: 11.7900, Val Loss: 18.8583\n",
      "Epoch 130/200, Train Loss: 11.7209, Val Loss: 19.4427\n",
      "Epoch 131/200, Train Loss: 11.6905, Val Loss: 18.9325\n",
      "Epoch 132/200, Train Loss: 11.7566, Val Loss: 19.2885\n",
      "Epoch 133/200, Train Loss: 11.6727, Val Loss: 19.4927\n",
      "Epoch 134/200, Train Loss: 11.6378, Val Loss: 19.1618\n",
      "Epoch 135/200, Train Loss: 11.5664, Val Loss: 19.5476\n",
      "Epoch 136/200, Train Loss: 11.5251, Val Loss: 19.0256\n",
      "Epoch 137/200, Train Loss: 11.5008, Val Loss: 19.5076\n",
      "Epoch 138/200, Train Loss: 11.4673, Val Loss: 19.5468\n",
      "Epoch 139/200, Train Loss: 11.5974, Val Loss: 19.2696\n",
      "Epoch 140/200, Train Loss: 11.4194, Val Loss: 19.6121\n",
      "Epoch 141/200, Train Loss: 11.4591, Val Loss: 19.0037\n",
      "Epoch 142/200, Train Loss: 11.3930, Val Loss: 19.6269\n",
      "Epoch 143/200, Train Loss: 11.3566, Val Loss: 19.8827\n",
      "Epoch 144/200, Train Loss: 11.3399, Val Loss: 19.4425\n",
      "Epoch 145/200, Train Loss: 11.2938, Val Loss: 19.8161\n",
      "Epoch 146/200, Train Loss: 11.3471, Val Loss: 19.4834\n",
      "Epoch 147/200, Train Loss: 11.4281, Val Loss: 19.7765\n",
      "Epoch 148/200, Train Loss: 11.2831, Val Loss: 19.3374\n",
      "Epoch 149/200, Train Loss: 11.3105, Val Loss: 19.5292\n",
      "Epoch 150/200, Train Loss: 11.3041, Val Loss: 19.4088\n",
      "Epoch 151/200, Train Loss: 11.1410, Val Loss: 19.5425\n",
      "Epoch 152/200, Train Loss: 11.2218, Val Loss: 20.0137\n",
      "Epoch 153/200, Train Loss: 11.0810, Val Loss: 19.7919\n",
      "Epoch 154/200, Train Loss: 11.0523, Val Loss: 19.7557\n",
      "Epoch 155/200, Train Loss: 11.0188, Val Loss: 19.5890\n",
      "Epoch 156/200, Train Loss: 10.9855, Val Loss: 19.9266\n",
      "Epoch 157/200, Train Loss: 10.9463, Val Loss: 19.5889\n",
      "Epoch 158/200, Train Loss: 10.8837, Val Loss: 19.8492\n",
      "Epoch 159/200, Train Loss: 10.8529, Val Loss: 20.3292\n",
      "Epoch 160/200, Train Loss: 10.8912, Val Loss: 19.7260\n",
      "Epoch 161/200, Train Loss: 10.7858, Val Loss: 20.4170\n",
      "Epoch 162/200, Train Loss: 10.7764, Val Loss: 19.9044\n",
      "Epoch 163/200, Train Loss: 10.7504, Val Loss: 20.3581\n",
      "Epoch 164/200, Train Loss: 10.6398, Val Loss: 19.7833\n",
      "Epoch 165/200, Train Loss: 10.6618, Val Loss: 20.6131\n",
      "Epoch 166/200, Train Loss: 10.7278, Val Loss: 20.1736\n",
      "Epoch 167/200, Train Loss: 10.6696, Val Loss: 20.2627\n",
      "Epoch 168/200, Train Loss: 10.5811, Val Loss: 20.4152\n",
      "Epoch 169/200, Train Loss: 10.5625, Val Loss: 19.9864\n",
      "Epoch 170/200, Train Loss: 10.5218, Val Loss: 20.7335\n",
      "Epoch 171/200, Train Loss: 10.6053, Val Loss: 20.1297\n",
      "Epoch 172/200, Train Loss: 10.4618, Val Loss: 21.1525\n",
      "Epoch 173/200, Train Loss: 10.4743, Val Loss: 20.1567\n",
      "Epoch 174/200, Train Loss: 10.4488, Val Loss: 20.5617\n",
      "Epoch 175/200, Train Loss: 10.4051, Val Loss: 20.4700\n",
      "Epoch 176/200, Train Loss: 10.3677, Val Loss: 20.2367\n",
      "Epoch 177/200, Train Loss: 10.4308, Val Loss: 20.5165\n",
      "Epoch 178/200, Train Loss: 10.3394, Val Loss: 20.3635\n",
      "Epoch 179/200, Train Loss: 10.3028, Val Loss: 20.9703\n",
      "Epoch 180/200, Train Loss: 10.3566, Val Loss: 20.4340\n",
      "Epoch 181/200, Train Loss: 10.4251, Val Loss: 20.6469\n",
      "Epoch 182/200, Train Loss: 10.3208, Val Loss: 19.8170\n",
      "Epoch 183/200, Train Loss: 10.3000, Val Loss: 21.2833\n",
      "Epoch 184/200, Train Loss: 10.2416, Val Loss: 20.0907\n",
      "Epoch 185/200, Train Loss: 10.2641, Val Loss: 20.6514\n",
      "Epoch 186/200, Train Loss: 10.2148, Val Loss: 20.5636\n",
      "Epoch 187/200, Train Loss: 10.1663, Val Loss: 20.8833\n",
      "Epoch 188/200, Train Loss: 10.1517, Val Loss: 21.1426\n",
      "Epoch 189/200, Train Loss: 10.1846, Val Loss: 21.0545\n",
      "Epoch 190/200, Train Loss: 10.1066, Val Loss: 20.0480\n",
      "Epoch 191/200, Train Loss: 10.1860, Val Loss: 21.5405\n",
      "Epoch 192/200, Train Loss: 10.0856, Val Loss: 20.7719\n",
      "Epoch 193/200, Train Loss: 10.0175, Val Loss: 20.7267\n",
      "Epoch 194/200, Train Loss: 9.9134, Val Loss: 21.1470\n",
      "Epoch 195/200, Train Loss: 9.9293, Val Loss: 21.1018\n",
      "Epoch 196/200, Train Loss: 9.9360, Val Loss: 20.5897\n",
      "Epoch 197/200, Train Loss: 9.8365, Val Loss: 21.4868\n",
      "Epoch 198/200, Train Loss: 9.9790, Val Loss: 20.8598\n",
      "Epoch 199/200, Train Loss: 9.8486, Val Loss: 20.7879\n",
      "Epoch 200/200, Train Loss: 9.8764, Val Loss: 21.4894\n",
      "\n",
      "Loaded best model (Val Loss: 15.6940) for final hidden state extraction.\n",
      "Saved best model for NMRNN_Spatial_ModReadout (samples=160) to results_data_size_sweep/20250514_045146/samples_160/NMRNN_Spatial_ModReadout_samples_160_best.pt\n",
      "\n",
      "--- Performing Decodability Analysis for NMRNN_Spatial_ModReadout (samples=160, k=15) ---\n",
      "  Analyzing decodability for NMRNN_Spatial_ModReadout...\n",
      "  Hidden states shape: torch.Size([160, 200, 128])\n",
      "  Coefficients shape: torch.Size([160, 15])\n",
      "  Processed hidden states shape for decoder: torch.Size([160, 128])\n",
      "  RidgeCV Decoder for NMRNN_Spatial_ModReadout - Test MSE: 1.8015, Test R2: 0.0865 (best alpha: 100.0000)\n",
      "  Decodability plot saved to results_data_size_sweep/20250514_045146/samples_160/decodability_NMRNN_Spatial_ModReadout_coeff1.png\n",
      "Decodability (R2 score) for NMRNN_Spatial_ModReadout (samples=160): 0.0865\n",
      "\n",
      "--- Training NMRNN_NoSpatial_ModReadout (samples=160, k=15) ---\n",
      "Number of parameters: 66832\n",
      "Epoch 1/200, Train Loss: 16.6996, Val Loss: 15.7836\n",
      "  New best validation loss: 15.7836\n",
      "Epoch 2/200, Train Loss: 16.5791, Val Loss: 15.7462\n",
      "  New best validation loss: 15.7462\n",
      "Epoch 3/200, Train Loss: 16.5935, Val Loss: 15.8365\n",
      "Epoch 4/200, Train Loss: 16.5250, Val Loss: 15.7056\n",
      "  New best validation loss: 15.7056\n",
      "Epoch 5/200, Train Loss: 16.4718, Val Loss: 15.6877\n",
      "  New best validation loss: 15.6877\n",
      "Epoch 6/200, Train Loss: 16.4390, Val Loss: 15.6798\n",
      "  New best validation loss: 15.6798\n",
      "Epoch 7/200, Train Loss: 16.3753, Val Loss: 15.6944\n",
      "Epoch 8/200, Train Loss: 16.3161, Val Loss: 15.7734\n",
      "Epoch 9/200, Train Loss: 16.2744, Val Loss: 15.8063\n",
      "Epoch 10/200, Train Loss: 16.2474, Val Loss: 15.8216\n",
      "Epoch 11/200, Train Loss: 16.2135, Val Loss: 15.8482\n",
      "Epoch 12/200, Train Loss: 16.1946, Val Loss: 15.8540\n",
      "Epoch 13/200, Train Loss: 16.1670, Val Loss: 15.8987\n",
      "Epoch 14/200, Train Loss: 16.1309, Val Loss: 15.8789\n",
      "Epoch 15/200, Train Loss: 16.1028, Val Loss: 15.8666\n",
      "Epoch 16/200, Train Loss: 16.0734, Val Loss: 15.8841\n",
      "Epoch 17/200, Train Loss: 16.0621, Val Loss: 15.9350\n",
      "Epoch 18/200, Train Loss: 16.0180, Val Loss: 15.9007\n",
      "Epoch 19/200, Train Loss: 15.9996, Val Loss: 15.9287\n",
      "Epoch 20/200, Train Loss: 15.9834, Val Loss: 15.9585\n",
      "Epoch 21/200, Train Loss: 15.9433, Val Loss: 15.9366\n",
      "Epoch 22/200, Train Loss: 15.9220, Val Loss: 15.9977\n",
      "Epoch 23/200, Train Loss: 15.8924, Val Loss: 16.0172\n",
      "Epoch 24/200, Train Loss: 15.8713, Val Loss: 16.0047\n",
      "Epoch 25/200, Train Loss: 15.8493, Val Loss: 16.0158\n",
      "Epoch 26/200, Train Loss: 15.8093, Val Loss: 16.0294\n",
      "Epoch 27/200, Train Loss: 15.7539, Val Loss: 16.0671\n",
      "Epoch 28/200, Train Loss: 15.7241, Val Loss: 16.0726\n",
      "Epoch 29/200, Train Loss: 15.7371, Val Loss: 16.0759\n",
      "Epoch 30/200, Train Loss: 15.6636, Val Loss: 16.1172\n",
      "Epoch 31/200, Train Loss: 15.6262, Val Loss: 16.0900\n",
      "Epoch 32/200, Train Loss: 15.5942, Val Loss: 16.0477\n",
      "Epoch 33/200, Train Loss: 15.5374, Val Loss: 16.1194\n",
      "Epoch 34/200, Train Loss: 15.5205, Val Loss: 16.1624\n",
      "Epoch 35/200, Train Loss: 15.4425, Val Loss: 16.1979\n",
      "Epoch 36/200, Train Loss: 15.3749, Val Loss: 16.2154\n",
      "Epoch 37/200, Train Loss: 15.3198, Val Loss: 16.1614\n",
      "Epoch 38/200, Train Loss: 15.2638, Val Loss: 16.2754\n",
      "Epoch 39/200, Train Loss: 15.2024, Val Loss: 16.2787\n",
      "Epoch 40/200, Train Loss: 15.1721, Val Loss: 16.3268\n",
      "Epoch 41/200, Train Loss: 15.1310, Val Loss: 16.3274\n",
      "Epoch 42/200, Train Loss: 15.0036, Val Loss: 16.3597\n",
      "Epoch 43/200, Train Loss: 14.9477, Val Loss: 16.3677\n",
      "Epoch 44/200, Train Loss: 14.8575, Val Loss: 16.4873\n",
      "Epoch 45/200, Train Loss: 14.8365, Val Loss: 16.4698\n",
      "Epoch 46/200, Train Loss: 14.7639, Val Loss: 16.5706\n",
      "Epoch 47/200, Train Loss: 14.7078, Val Loss: 16.5431\n",
      "Epoch 48/200, Train Loss: 14.6772, Val Loss: 16.6128\n",
      "Epoch 49/200, Train Loss: 14.5898, Val Loss: 16.4864\n",
      "Epoch 50/200, Train Loss: 14.5711, Val Loss: 16.6505\n",
      "Epoch 51/200, Train Loss: 14.4862, Val Loss: 16.5957\n",
      "Epoch 52/200, Train Loss: 14.4675, Val Loss: 16.6248\n",
      "Epoch 53/200, Train Loss: 14.4224, Val Loss: 16.7636\n",
      "Epoch 54/200, Train Loss: 14.4087, Val Loss: 16.6735\n",
      "Epoch 55/200, Train Loss: 14.4062, Val Loss: 16.8753\n",
      "Epoch 56/200, Train Loss: 14.2472, Val Loss: 16.8539\n",
      "Epoch 57/200, Train Loss: 14.1905, Val Loss: 16.9239\n",
      "Epoch 58/200, Train Loss: 14.1609, Val Loss: 16.8534\n",
      "Epoch 59/200, Train Loss: 14.1281, Val Loss: 16.9532\n",
      "Epoch 60/200, Train Loss: 14.0783, Val Loss: 17.0009\n",
      "Epoch 61/200, Train Loss: 14.0711, Val Loss: 17.1795\n",
      "Epoch 62/200, Train Loss: 13.9933, Val Loss: 17.1644\n",
      "Epoch 63/200, Train Loss: 13.9383, Val Loss: 17.1276\n",
      "Epoch 64/200, Train Loss: 13.8888, Val Loss: 17.2159\n",
      "Epoch 65/200, Train Loss: 13.9141, Val Loss: 17.1915\n",
      "Epoch 66/200, Train Loss: 13.8278, Val Loss: 17.2727\n",
      "Epoch 67/200, Train Loss: 13.7715, Val Loss: 17.3901\n",
      "Epoch 68/200, Train Loss: 13.7260, Val Loss: 17.3754\n",
      "Epoch 69/200, Train Loss: 13.6587, Val Loss: 17.3963\n",
      "Epoch 70/200, Train Loss: 13.5925, Val Loss: 17.6664\n",
      "Epoch 71/200, Train Loss: 13.6654, Val Loss: 17.3105\n",
      "Epoch 72/200, Train Loss: 13.7038, Val Loss: 17.8299\n",
      "Epoch 73/200, Train Loss: 13.6919, Val Loss: 17.5762\n",
      "Epoch 74/200, Train Loss: 13.5885, Val Loss: 17.5220\n",
      "Epoch 75/200, Train Loss: 13.4823, Val Loss: 17.7280\n",
      "Epoch 76/200, Train Loss: 13.5301, Val Loss: 17.7694\n",
      "Epoch 77/200, Train Loss: 13.4199, Val Loss: 17.6797\n",
      "Epoch 78/200, Train Loss: 13.3545, Val Loss: 18.0244\n",
      "Epoch 79/200, Train Loss: 13.3634, Val Loss: 17.8127\n",
      "Epoch 80/200, Train Loss: 13.3344, Val Loss: 18.1000\n",
      "Epoch 81/200, Train Loss: 13.2551, Val Loss: 17.9357\n",
      "Epoch 82/200, Train Loss: 13.2702, Val Loss: 17.8407\n",
      "Epoch 83/200, Train Loss: 13.2689, Val Loss: 18.0619\n",
      "Epoch 84/200, Train Loss: 13.1405, Val Loss: 17.9929\n",
      "Epoch 85/200, Train Loss: 13.1129, Val Loss: 18.2896\n",
      "Epoch 86/200, Train Loss: 13.1203, Val Loss: 18.0143\n",
      "Epoch 87/200, Train Loss: 12.9838, Val Loss: 17.8583\n",
      "Epoch 88/200, Train Loss: 12.9064, Val Loss: 18.4799\n",
      "Epoch 89/200, Train Loss: 12.9574, Val Loss: 18.1624\n",
      "Epoch 90/200, Train Loss: 12.8618, Val Loss: 18.0043\n",
      "Epoch 91/200, Train Loss: 12.7619, Val Loss: 18.4862\n",
      "Epoch 92/200, Train Loss: 12.7996, Val Loss: 18.3963\n",
      "Epoch 93/200, Train Loss: 12.7353, Val Loss: 18.1124\n",
      "Epoch 94/200, Train Loss: 12.7310, Val Loss: 18.5315\n",
      "Epoch 95/200, Train Loss: 12.6235, Val Loss: 18.3299\n",
      "Epoch 96/200, Train Loss: 12.5953, Val Loss: 18.5598\n",
      "Epoch 97/200, Train Loss: 12.5753, Val Loss: 18.5646\n",
      "Epoch 98/200, Train Loss: 12.4780, Val Loss: 18.4521\n",
      "Epoch 99/200, Train Loss: 12.4211, Val Loss: 18.5276\n",
      "Epoch 100/200, Train Loss: 12.4443, Val Loss: 18.6491\n",
      "Epoch 101/200, Train Loss: 12.4092, Val Loss: 18.5286\n",
      "Epoch 102/200, Train Loss: 12.3692, Val Loss: 18.8012\n",
      "Epoch 103/200, Train Loss: 12.3154, Val Loss: 18.6181\n",
      "Epoch 104/200, Train Loss: 12.2064, Val Loss: 18.6761\n",
      "Epoch 105/200, Train Loss: 12.2834, Val Loss: 18.7744\n",
      "Epoch 106/200, Train Loss: 12.1729, Val Loss: 18.4762\n",
      "Epoch 107/200, Train Loss: 12.0253, Val Loss: 18.6350\n",
      "Epoch 108/200, Train Loss: 12.0202, Val Loss: 18.8949\n",
      "Epoch 109/200, Train Loss: 12.0740, Val Loss: 18.8920\n",
      "Epoch 110/200, Train Loss: 12.0535, Val Loss: 18.5251\n",
      "Epoch 111/200, Train Loss: 12.0077, Val Loss: 19.3338\n",
      "Epoch 112/200, Train Loss: 11.9158, Val Loss: 18.7052\n",
      "Epoch 113/200, Train Loss: 11.9269, Val Loss: 19.3456\n",
      "Epoch 114/200, Train Loss: 11.8945, Val Loss: 18.8404\n",
      "Epoch 115/200, Train Loss: 11.8578, Val Loss: 18.9756\n",
      "Epoch 116/200, Train Loss: 11.8952, Val Loss: 18.7112\n",
      "Epoch 117/200, Train Loss: 11.7922, Val Loss: 19.0120\n",
      "Epoch 118/200, Train Loss: 11.7033, Val Loss: 18.9536\n",
      "Epoch 119/200, Train Loss: 11.7548, Val Loss: 19.0695\n",
      "Epoch 120/200, Train Loss: 11.7088, Val Loss: 19.2713\n",
      "Epoch 121/200, Train Loss: 11.6192, Val Loss: 19.1794\n",
      "Epoch 122/200, Train Loss: 11.6194, Val Loss: 19.0329\n",
      "Epoch 123/200, Train Loss: 11.5123, Val Loss: 19.1009\n",
      "Epoch 124/200, Train Loss: 11.3926, Val Loss: 19.2602\n",
      "Epoch 125/200, Train Loss: 11.5113, Val Loss: 18.8563\n",
      "Epoch 126/200, Train Loss: 11.3720, Val Loss: 19.5768\n",
      "Epoch 127/200, Train Loss: 11.3400, Val Loss: 19.5368\n",
      "Epoch 128/200, Train Loss: 11.2872, Val Loss: 18.7148\n",
      "Epoch 129/200, Train Loss: 11.2877, Val Loss: 19.2128\n",
      "Epoch 130/200, Train Loss: 11.2312, Val Loss: 19.0255\n",
      "Epoch 131/200, Train Loss: 11.2328, Val Loss: 19.2300\n",
      "Epoch 132/200, Train Loss: 11.2642, Val Loss: 19.2074\n",
      "Epoch 133/200, Train Loss: 11.1187, Val Loss: 19.6415\n",
      "Epoch 134/200, Train Loss: 11.2188, Val Loss: 19.1625\n",
      "Epoch 135/200, Train Loss: 11.0519, Val Loss: 19.6089\n",
      "Epoch 136/200, Train Loss: 11.0926, Val Loss: 19.4361\n",
      "Epoch 137/200, Train Loss: 10.9305, Val Loss: 19.3686\n",
      "Epoch 138/200, Train Loss: 11.0451, Val Loss: 19.7380\n",
      "Epoch 139/200, Train Loss: 10.9939, Val Loss: 19.7837\n",
      "Epoch 140/200, Train Loss: 10.9191, Val Loss: 19.2288\n",
      "Epoch 141/200, Train Loss: 10.8166, Val Loss: 19.5763\n",
      "Epoch 142/200, Train Loss: 10.7793, Val Loss: 19.5805\n",
      "Epoch 143/200, Train Loss: 10.6930, Val Loss: 19.8056\n",
      "Epoch 144/200, Train Loss: 10.6981, Val Loss: 19.9419\n",
      "Epoch 145/200, Train Loss: 10.6375, Val Loss: 19.8308\n",
      "Epoch 146/200, Train Loss: 10.5551, Val Loss: 19.5528\n",
      "Epoch 147/200, Train Loss: 10.5472, Val Loss: 20.4669\n",
      "Epoch 148/200, Train Loss: 10.7089, Val Loss: 19.5501\n",
      "Epoch 149/200, Train Loss: 10.7240, Val Loss: 19.3748\n",
      "Epoch 150/200, Train Loss: 10.5909, Val Loss: 19.2627\n",
      "Epoch 151/200, Train Loss: 10.5347, Val Loss: 19.3307\n",
      "Epoch 152/200, Train Loss: 10.4462, Val Loss: 19.9085\n",
      "Epoch 153/200, Train Loss: 10.3837, Val Loss: 19.5176\n",
      "Epoch 154/200, Train Loss: 10.3619, Val Loss: 19.6939\n",
      "Epoch 155/200, Train Loss: 10.2297, Val Loss: 19.7730\n",
      "Epoch 156/200, Train Loss: 10.2810, Val Loss: 19.8302\n",
      "Epoch 157/200, Train Loss: 10.2756, Val Loss: 20.0451\n",
      "Epoch 158/200, Train Loss: 10.2168, Val Loss: 19.4213\n",
      "Epoch 159/200, Train Loss: 10.2443, Val Loss: 19.6800\n",
      "Epoch 160/200, Train Loss: 10.1935, Val Loss: 19.6695\n",
      "Epoch 161/200, Train Loss: 10.1052, Val Loss: 20.1022\n",
      "Epoch 162/200, Train Loss: 10.0936, Val Loss: 19.3520\n",
      "Epoch 163/200, Train Loss: 10.0607, Val Loss: 20.4456\n",
      "Epoch 164/200, Train Loss: 10.0271, Val Loss: 19.4940\n",
      "Epoch 165/200, Train Loss: 10.0824, Val Loss: 20.1116\n",
      "Epoch 166/200, Train Loss: 9.9988, Val Loss: 19.7094\n",
      "Epoch 167/200, Train Loss: 9.9779, Val Loss: 19.5278\n",
      "Epoch 168/200, Train Loss: 10.0083, Val Loss: 19.4969\n",
      "Epoch 169/200, Train Loss: 9.9233, Val Loss: 20.1961\n",
      "Epoch 170/200, Train Loss: 9.8411, Val Loss: 19.6234\n",
      "Epoch 171/200, Train Loss: 9.8347, Val Loss: 19.7929\n",
      "Epoch 172/200, Train Loss: 9.8076, Val Loss: 19.5282\n",
      "Epoch 173/200, Train Loss: 9.7430, Val Loss: 19.6613\n",
      "Epoch 174/200, Train Loss: 9.7072, Val Loss: 19.5801\n",
      "Epoch 175/200, Train Loss: 9.6817, Val Loss: 20.1216\n",
      "Epoch 176/200, Train Loss: 9.6422, Val Loss: 20.0233\n",
      "Epoch 177/200, Train Loss: 9.5340, Val Loss: 20.1838\n",
      "Epoch 178/200, Train Loss: 9.5284, Val Loss: 19.7949\n",
      "Epoch 179/200, Train Loss: 9.4789, Val Loss: 19.8713\n",
      "Epoch 180/200, Train Loss: 9.4684, Val Loss: 20.4056\n",
      "Epoch 181/200, Train Loss: 9.4211, Val Loss: 19.8514\n",
      "Epoch 182/200, Train Loss: 9.5441, Val Loss: 20.2006\n",
      "Epoch 183/200, Train Loss: 9.5819, Val Loss: 20.0526\n",
      "Epoch 184/200, Train Loss: 9.4808, Val Loss: 19.7188\n",
      "Epoch 185/200, Train Loss: 9.4096, Val Loss: 20.4895\n",
      "Epoch 186/200, Train Loss: 9.3345, Val Loss: 19.4580\n",
      "Epoch 187/200, Train Loss: 9.2995, Val Loss: 20.5170\n",
      "Epoch 188/200, Train Loss: 9.4192, Val Loss: 19.8354\n",
      "Epoch 189/200, Train Loss: 9.2954, Val Loss: 20.7893\n",
      "Epoch 190/200, Train Loss: 9.4630, Val Loss: 19.9689\n",
      "Epoch 191/200, Train Loss: 9.4663, Val Loss: 19.7924\n",
      "Epoch 192/200, Train Loss: 9.3249, Val Loss: 20.6114\n",
      "Epoch 193/200, Train Loss: 9.2604, Val Loss: 19.5742\n",
      "Epoch 194/200, Train Loss: 9.2214, Val Loss: 20.4822\n",
      "Epoch 195/200, Train Loss: 9.1837, Val Loss: 19.5959\n",
      "Epoch 196/200, Train Loss: 9.0478, Val Loss: 20.1502\n",
      "Epoch 197/200, Train Loss: 9.0436, Val Loss: 19.9939\n",
      "Epoch 198/200, Train Loss: 9.0096, Val Loss: 20.1917\n",
      "Epoch 199/200, Train Loss: 9.1177, Val Loss: 20.1513\n",
      "Epoch 200/200, Train Loss: 9.0561, Val Loss: 20.2574\n",
      "\n",
      "Loaded best model (Val Loss: 15.6798) for final hidden state extraction.\n",
      "Saved best model for NMRNN_NoSpatial_ModReadout (samples=160) to results_data_size_sweep/20250514_045146/samples_160/NMRNN_NoSpatial_ModReadout_samples_160_best.pt\n",
      "\n",
      "--- Performing Decodability Analysis for NMRNN_NoSpatial_ModReadout (samples=160, k=15) ---\n",
      "  Analyzing decodability for NMRNN_NoSpatial_ModReadout...\n",
      "  Hidden states shape: torch.Size([160, 200, 128])\n",
      "  Coefficients shape: torch.Size([160, 15])\n",
      "  Processed hidden states shape for decoder: torch.Size([160, 128])\n",
      "  RidgeCV Decoder for NMRNN_NoSpatial_ModReadout - Test MSE: 1.7771, Test R2: 0.0961 (best alpha: 100.0000)\n",
      "  Decodability plot saved to results_data_size_sweep/20250514_045146/samples_160/decodability_NMRNN_NoSpatial_ModReadout_coeff1.png\n",
      "Decodability (R2 score) for NMRNN_NoSpatial_ModReadout (samples=160): 0.0961\n",
      "\n",
      "--- Training NMRNN_Spatial_FixedReadout (samples=160, k=15) ---\n",
      "Number of parameters: 66449\n",
      "Epoch 1/200, Train Loss: 16.8359, Val Loss: 15.7740\n",
      "  New best validation loss: 15.7740\n",
      "Epoch 2/200, Train Loss: 16.5617, Val Loss: 15.8068\n",
      "Epoch 3/200, Train Loss: 16.4787, Val Loss: 15.7742\n",
      "Epoch 4/200, Train Loss: 16.4369, Val Loss: 15.7767\n",
      "Epoch 5/200, Train Loss: 16.4013, Val Loss: 15.8081\n",
      "Epoch 6/200, Train Loss: 16.3442, Val Loss: 15.8033\n",
      "Epoch 7/200, Train Loss: 16.3017, Val Loss: 15.7836\n",
      "Epoch 8/200, Train Loss: 16.2602, Val Loss: 15.7873\n",
      "Epoch 9/200, Train Loss: 16.2350, Val Loss: 15.8006\n",
      "Epoch 10/200, Train Loss: 16.2019, Val Loss: 15.8170\n",
      "Epoch 11/200, Train Loss: 16.1772, Val Loss: 15.8194\n",
      "Epoch 12/200, Train Loss: 16.1529, Val Loss: 15.8197\n",
      "Epoch 13/200, Train Loss: 16.1558, Val Loss: 15.8330\n",
      "Epoch 14/200, Train Loss: 16.1182, Val Loss: 15.8530\n",
      "Epoch 15/200, Train Loss: 16.0881, Val Loss: 15.9179\n",
      "Epoch 16/200, Train Loss: 16.0538, Val Loss: 15.9110\n",
      "Epoch 17/200, Train Loss: 16.0139, Val Loss: 15.8765\n",
      "Epoch 18/200, Train Loss: 15.9667, Val Loss: 15.9226\n",
      "Epoch 19/200, Train Loss: 15.9218, Val Loss: 15.9065\n",
      "Epoch 20/200, Train Loss: 15.8749, Val Loss: 15.9071\n",
      "Epoch 21/200, Train Loss: 15.8241, Val Loss: 15.9230\n",
      "Epoch 22/200, Train Loss: 15.7605, Val Loss: 15.9545\n",
      "Epoch 23/200, Train Loss: 15.7004, Val Loss: 15.9572\n",
      "Epoch 24/200, Train Loss: 15.6420, Val Loss: 15.9781\n",
      "Epoch 25/200, Train Loss: 15.5600, Val Loss: 16.0179\n",
      "Epoch 26/200, Train Loss: 15.4972, Val Loss: 16.0632\n",
      "Epoch 27/200, Train Loss: 15.4717, Val Loss: 16.0570\n",
      "Epoch 28/200, Train Loss: 15.4084, Val Loss: 16.0942\n",
      "Epoch 29/200, Train Loss: 15.3140, Val Loss: 16.1102\n",
      "Epoch 30/200, Train Loss: 15.2495, Val Loss: 16.0907\n",
      "Epoch 31/200, Train Loss: 15.1625, Val Loss: 16.1390\n",
      "Epoch 32/200, Train Loss: 15.0860, Val Loss: 16.2288\n",
      "Epoch 33/200, Train Loss: 15.0710, Val Loss: 16.2426\n",
      "Epoch 34/200, Train Loss: 14.9735, Val Loss: 16.2526\n",
      "Epoch 35/200, Train Loss: 14.9339, Val Loss: 16.2761\n",
      "Epoch 36/200, Train Loss: 14.8241, Val Loss: 16.2987\n",
      "Epoch 37/200, Train Loss: 14.7938, Val Loss: 16.3174\n",
      "Epoch 38/200, Train Loss: 14.7375, Val Loss: 16.3134\n",
      "Epoch 39/200, Train Loss: 14.7045, Val Loss: 16.2333\n",
      "Epoch 40/200, Train Loss: 14.6730, Val Loss: 16.4392\n",
      "Epoch 41/200, Train Loss: 14.6813, Val Loss: 16.4952\n",
      "Epoch 42/200, Train Loss: 14.5963, Val Loss: 16.6684\n",
      "Epoch 43/200, Train Loss: 14.4665, Val Loss: 16.5302\n",
      "Epoch 44/200, Train Loss: 14.4718, Val Loss: 16.6377\n",
      "Epoch 45/200, Train Loss: 14.4340, Val Loss: 16.5549\n",
      "Epoch 46/200, Train Loss: 14.3490, Val Loss: 16.7369\n",
      "Epoch 47/200, Train Loss: 14.2326, Val Loss: 16.7803\n",
      "Epoch 48/200, Train Loss: 14.4469, Val Loss: 16.6303\n",
      "Epoch 49/200, Train Loss: 14.2325, Val Loss: 16.7553\n",
      "Epoch 50/200, Train Loss: 14.1242, Val Loss: 17.0143\n",
      "Epoch 51/200, Train Loss: 14.0650, Val Loss: 16.7255\n",
      "Epoch 52/200, Train Loss: 13.9828, Val Loss: 16.8542\n",
      "Epoch 53/200, Train Loss: 14.0225, Val Loss: 16.7614\n",
      "Epoch 54/200, Train Loss: 13.8767, Val Loss: 16.9158\n",
      "Epoch 55/200, Train Loss: 13.7971, Val Loss: 16.7799\n",
      "Epoch 56/200, Train Loss: 13.8863, Val Loss: 16.9748\n",
      "Epoch 57/200, Train Loss: 13.8599, Val Loss: 17.0035\n",
      "Epoch 58/200, Train Loss: 13.7722, Val Loss: 17.0047\n",
      "Epoch 59/200, Train Loss: 13.7761, Val Loss: 17.2130\n",
      "Epoch 60/200, Train Loss: 13.5369, Val Loss: 16.9323\n",
      "Epoch 61/200, Train Loss: 13.4510, Val Loss: 17.0192\n",
      "Epoch 62/200, Train Loss: 13.3409, Val Loss: 17.0378\n",
      "Epoch 63/200, Train Loss: 13.2685, Val Loss: 17.1296\n",
      "Epoch 64/200, Train Loss: 13.1815, Val Loss: 17.3045\n",
      "Epoch 65/200, Train Loss: 13.1606, Val Loss: 17.2463\n",
      "Epoch 66/200, Train Loss: 13.1861, Val Loss: 17.3716\n",
      "Epoch 67/200, Train Loss: 13.0328, Val Loss: 17.3031\n",
      "Epoch 68/200, Train Loss: 12.9364, Val Loss: 17.4706\n",
      "Epoch 69/200, Train Loss: 12.8933, Val Loss: 17.5746\n",
      "Epoch 70/200, Train Loss: 13.0125, Val Loss: 17.4771\n",
      "Epoch 71/200, Train Loss: 12.8148, Val Loss: 17.6398\n",
      "Epoch 72/200, Train Loss: 12.7810, Val Loss: 17.4393\n",
      "Epoch 73/200, Train Loss: 12.8653, Val Loss: 17.9661\n",
      "Epoch 74/200, Train Loss: 12.9579, Val Loss: 17.5021\n",
      "Epoch 75/200, Train Loss: 12.8272, Val Loss: 17.8052\n",
      "Epoch 76/200, Train Loss: 12.8101, Val Loss: 17.8356\n",
      "Epoch 77/200, Train Loss: 12.7111, Val Loss: 17.7582\n",
      "Epoch 78/200, Train Loss: 12.5779, Val Loss: 17.8595\n",
      "Epoch 79/200, Train Loss: 12.6041, Val Loss: 17.9554\n",
      "Epoch 80/200, Train Loss: 12.4800, Val Loss: 17.9538\n",
      "Epoch 81/200, Train Loss: 12.4381, Val Loss: 18.2389\n",
      "Epoch 82/200, Train Loss: 12.3966, Val Loss: 17.9382\n",
      "Epoch 83/200, Train Loss: 12.3252, Val Loss: 18.0097\n",
      "Epoch 84/200, Train Loss: 12.3938, Val Loss: 17.8938\n",
      "Epoch 85/200, Train Loss: 12.4276, Val Loss: 17.9486\n",
      "Epoch 86/200, Train Loss: 12.3358, Val Loss: 18.2821\n",
      "Epoch 87/200, Train Loss: 12.3271, Val Loss: 18.0690\n",
      "Epoch 88/200, Train Loss: 12.1950, Val Loss: 18.1588\n",
      "Epoch 89/200, Train Loss: 12.1173, Val Loss: 18.2793\n",
      "Epoch 90/200, Train Loss: 12.0668, Val Loss: 18.2018\n",
      "Epoch 91/200, Train Loss: 11.8805, Val Loss: 18.2712\n",
      "Epoch 92/200, Train Loss: 11.7670, Val Loss: 18.4225\n",
      "Epoch 93/200, Train Loss: 11.7064, Val Loss: 18.7346\n",
      "Epoch 94/200, Train Loss: 11.6121, Val Loss: 18.6061\n",
      "Epoch 95/200, Train Loss: 11.6558, Val Loss: 18.6277\n",
      "Epoch 96/200, Train Loss: 11.6173, Val Loss: 18.8767\n",
      "Epoch 97/200, Train Loss: 11.7701, Val Loss: 19.0088\n",
      "Epoch 98/200, Train Loss: 11.7240, Val Loss: 18.4414\n",
      "Epoch 99/200, Train Loss: 11.5425, Val Loss: 18.6262\n",
      "Epoch 100/200, Train Loss: 11.5258, Val Loss: 18.6863\n",
      "Epoch 101/200, Train Loss: 11.7793, Val Loss: 19.2392\n",
      "Epoch 102/200, Train Loss: 11.6591, Val Loss: 18.3868\n",
      "Epoch 103/200, Train Loss: 11.7112, Val Loss: 18.5579\n",
      "Epoch 104/200, Train Loss: 11.3898, Val Loss: 18.9134\n",
      "Epoch 105/200, Train Loss: 11.3320, Val Loss: 19.0129\n",
      "Epoch 106/200, Train Loss: 11.2630, Val Loss: 18.6980\n",
      "Epoch 107/200, Train Loss: 11.1841, Val Loss: 18.8632\n",
      "Epoch 108/200, Train Loss: 11.0829, Val Loss: 19.1006\n",
      "Epoch 109/200, Train Loss: 11.1239, Val Loss: 18.7139\n",
      "Epoch 110/200, Train Loss: 10.9728, Val Loss: 19.2103\n",
      "Epoch 111/200, Train Loss: 11.0477, Val Loss: 18.9032\n",
      "Epoch 112/200, Train Loss: 10.9790, Val Loss: 19.0615\n",
      "Epoch 113/200, Train Loss: 10.9347, Val Loss: 19.2333\n",
      "Epoch 114/200, Train Loss: 10.8486, Val Loss: 18.8222\n",
      "Epoch 115/200, Train Loss: 10.8307, Val Loss: 19.5093\n",
      "Epoch 116/200, Train Loss: 10.7917, Val Loss: 19.4491\n",
      "Epoch 117/200, Train Loss: 10.7801, Val Loss: 18.9520\n",
      "Epoch 118/200, Train Loss: 10.8059, Val Loss: 19.4918\n",
      "Epoch 119/200, Train Loss: 10.7724, Val Loss: 18.8413\n",
      "Epoch 120/200, Train Loss: 10.5681, Val Loss: 19.3433\n",
      "Epoch 121/200, Train Loss: 10.6397, Val Loss: 19.3635\n",
      "Epoch 122/200, Train Loss: 10.5473, Val Loss: 19.3127\n",
      "Epoch 123/200, Train Loss: 10.3981, Val Loss: 18.9968\n",
      "Epoch 124/200, Train Loss: 10.3281, Val Loss: 19.7162\n",
      "Epoch 125/200, Train Loss: 10.3626, Val Loss: 19.5796\n",
      "Epoch 126/200, Train Loss: 10.3586, Val Loss: 19.7377\n",
      "Epoch 127/200, Train Loss: 10.3694, Val Loss: 19.3222\n",
      "Epoch 128/200, Train Loss: 10.3308, Val Loss: 19.7695\n",
      "Epoch 129/200, Train Loss: 10.2433, Val Loss: 19.1912\n",
      "Epoch 130/200, Train Loss: 10.1520, Val Loss: 19.8545\n",
      "Epoch 131/200, Train Loss: 10.1795, Val Loss: 19.8717\n",
      "Epoch 132/200, Train Loss: 10.0993, Val Loss: 19.4199\n",
      "Epoch 133/200, Train Loss: 10.0669, Val Loss: 19.8730\n",
      "Epoch 134/200, Train Loss: 9.9723, Val Loss: 19.4288\n",
      "Epoch 135/200, Train Loss: 9.8401, Val Loss: 19.7222\n",
      "Epoch 136/200, Train Loss: 10.0088, Val Loss: 20.2572\n",
      "Epoch 137/200, Train Loss: 10.1425, Val Loss: 19.5511\n",
      "Epoch 138/200, Train Loss: 10.0885, Val Loss: 19.8894\n",
      "Epoch 139/200, Train Loss: 10.1131, Val Loss: 19.6090\n",
      "Epoch 140/200, Train Loss: 9.8933, Val Loss: 20.0153\n",
      "Epoch 141/200, Train Loss: 9.9088, Val Loss: 19.7463\n",
      "Epoch 142/200, Train Loss: 9.9462, Val Loss: 19.5406\n",
      "Epoch 143/200, Train Loss: 9.7942, Val Loss: 19.3010\n",
      "Epoch 144/200, Train Loss: 9.6810, Val Loss: 19.7903\n",
      "Epoch 145/200, Train Loss: 9.7413, Val Loss: 20.1586\n",
      "Epoch 146/200, Train Loss: 9.7533, Val Loss: 19.9278\n",
      "Epoch 147/200, Train Loss: 9.5699, Val Loss: 19.7728\n",
      "Epoch 148/200, Train Loss: 9.5408, Val Loss: 19.7042\n",
      "Epoch 149/200, Train Loss: 9.5583, Val Loss: 19.6873\n",
      "Epoch 150/200, Train Loss: 9.5325, Val Loss: 19.7358\n",
      "Epoch 151/200, Train Loss: 9.4575, Val Loss: 19.6023\n",
      "Epoch 152/200, Train Loss: 9.5433, Val Loss: 19.9386\n",
      "Epoch 153/200, Train Loss: 9.3660, Val Loss: 19.8331\n",
      "Epoch 154/200, Train Loss: 9.3542, Val Loss: 19.7938\n",
      "Epoch 155/200, Train Loss: 9.3400, Val Loss: 20.2524\n",
      "Epoch 156/200, Train Loss: 9.2195, Val Loss: 19.6143\n",
      "Epoch 157/200, Train Loss: 9.3074, Val Loss: 19.8761\n",
      "Epoch 158/200, Train Loss: 9.3880, Val Loss: 20.5201\n",
      "Epoch 159/200, Train Loss: 9.2623, Val Loss: 20.1648\n",
      "Epoch 160/200, Train Loss: 9.2474, Val Loss: 20.6706\n",
      "Epoch 161/200, Train Loss: 9.1581, Val Loss: 20.3497\n",
      "Epoch 162/200, Train Loss: 9.3445, Val Loss: 20.5024\n",
      "Epoch 163/200, Train Loss: 9.1260, Val Loss: 20.0332\n",
      "Epoch 164/200, Train Loss: 9.1139, Val Loss: 20.4032\n",
      "Epoch 165/200, Train Loss: 9.0147, Val Loss: 20.1130\n",
      "Epoch 166/200, Train Loss: 8.9454, Val Loss: 19.8028\n",
      "Epoch 167/200, Train Loss: 8.8833, Val Loss: 19.8167\n",
      "Epoch 168/200, Train Loss: 8.8722, Val Loss: 20.0341\n",
      "Epoch 169/200, Train Loss: 8.8986, Val Loss: 20.5752\n",
      "Epoch 170/200, Train Loss: 8.8677, Val Loss: 20.3191\n",
      "Epoch 171/200, Train Loss: 8.9357, Val Loss: 20.2762\n",
      "Epoch 172/200, Train Loss: 8.7314, Val Loss: 20.6429\n",
      "Epoch 173/200, Train Loss: 8.7553, Val Loss: 20.2453\n",
      "Epoch 174/200, Train Loss: 8.8902, Val Loss: 20.2492\n",
      "Epoch 175/200, Train Loss: 8.9224, Val Loss: 20.4631\n",
      "Epoch 176/200, Train Loss: 8.6823, Val Loss: 20.0925\n",
      "Epoch 177/200, Train Loss: 8.6224, Val Loss: 20.4864\n",
      "Epoch 178/200, Train Loss: 8.8221, Val Loss: 20.4252\n",
      "Epoch 179/200, Train Loss: 8.7682, Val Loss: 20.6395\n",
      "Epoch 180/200, Train Loss: 8.6955, Val Loss: 20.3957\n",
      "Epoch 181/200, Train Loss: 8.5865, Val Loss: 20.4252\n",
      "Epoch 182/200, Train Loss: 8.6077, Val Loss: 20.4185\n",
      "Epoch 183/200, Train Loss: 8.5984, Val Loss: 20.1475\n",
      "Epoch 184/200, Train Loss: 8.6519, Val Loss: 20.0496\n",
      "Epoch 185/200, Train Loss: 8.5154, Val Loss: 20.3962\n",
      "Epoch 186/200, Train Loss: 8.4421, Val Loss: 20.8127\n",
      "Epoch 187/200, Train Loss: 8.4762, Val Loss: 20.6198\n",
      "Epoch 188/200, Train Loss: 8.8090, Val Loss: 20.3314\n",
      "Epoch 189/200, Train Loss: 8.5422, Val Loss: 20.7288\n",
      "Epoch 190/200, Train Loss: 8.6705, Val Loss: 20.8275\n",
      "Epoch 191/200, Train Loss: 8.4066, Val Loss: 20.2057\n",
      "Epoch 192/200, Train Loss: 8.2633, Val Loss: 20.8360\n",
      "Epoch 193/200, Train Loss: 8.2928, Val Loss: 20.3530\n",
      "Epoch 194/200, Train Loss: 8.2347, Val Loss: 20.5958\n",
      "Epoch 195/200, Train Loss: 8.1886, Val Loss: 20.4519\n",
      "Epoch 196/200, Train Loss: 8.1205, Val Loss: 20.4504\n",
      "Epoch 197/200, Train Loss: 8.1881, Val Loss: 20.4260\n",
      "Epoch 198/200, Train Loss: 8.1747, Val Loss: 20.5286\n",
      "Epoch 199/200, Train Loss: 8.1046, Val Loss: 20.9323\n",
      "Epoch 200/200, Train Loss: 8.0558, Val Loss: 20.5864\n",
      "\n",
      "Loaded best model (Val Loss: 15.7740) for final hidden state extraction.\n",
      "Saved best model for NMRNN_Spatial_FixedReadout (samples=160) to results_data_size_sweep/20250514_045146/samples_160/NMRNN_Spatial_FixedReadout_samples_160_best.pt\n",
      "\n",
      "--- Performing Decodability Analysis for NMRNN_Spatial_FixedReadout (samples=160, k=15) ---\n",
      "  Analyzing decodability for NMRNN_Spatial_FixedReadout...\n",
      "  Hidden states shape: torch.Size([160, 200, 128])\n",
      "  Coefficients shape: torch.Size([160, 15])\n",
      "  Processed hidden states shape for decoder: torch.Size([160, 128])\n",
      "  RidgeCV Decoder for NMRNN_Spatial_FixedReadout - Test MSE: 1.8544, Test R2: 0.0679 (best alpha: 100.0000)\n",
      "  Decodability plot saved to results_data_size_sweep/20250514_045146/samples_160/decodability_NMRNN_Spatial_FixedReadout_coeff1.png\n",
      "Decodability (R2 score) for NMRNN_Spatial_FixedReadout (samples=160): 0.0679\n",
      "Learning curves saved to results_data_size_sweep/20250514_045146/samples_160/learning_curves_validation.png\n",
      "\n",
      "Validation learning curves for samples=160 plotted.\n",
      "Learning curves saved to results_data_size_sweep/20250514_045146/samples_160/learning_curves_training.png\n",
      "\n",
      "Training learning curves for samples=160 plotted.\n",
      "Decodability summary for samples=160 saved to results_data_size_sweep/20250514_045146/samples_160/decodability_summary.txt\n",
      "\n",
      "========================= Running for train_samples: 320, k: 15 =========================\n",
      "Results for train_samples=320 will be saved in: results_data_size_sweep/20250514_045146/samples_320\n",
      "Loading dataset...\n",
      "Dataset loaded.\n",
      "Warning: Modulated readout requested but N_nm is 0. Using fixed readout.\n",
      "\n",
      "--- Training RNN_Vanillia (samples=320, k=15) ---\n",
      "Number of parameters: 51301\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/conda/lib/python3.10/site-packages/torch/nn/init.py:405: UserWarning: Initializing zero-element tensors is a no-op\n",
      "  warnings.warn(\"Initializing zero-element tensors is a no-op\")\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/200, Train Loss: 17.5221, Val Loss: 15.8601\n",
      "  New best validation loss: 15.8601\n",
      "Epoch 2/200, Train Loss: 17.2830, Val Loss: 15.8258\n",
      "  New best validation loss: 15.8258\n",
      "Epoch 3/200, Train Loss: 17.1782, Val Loss: 15.7920\n",
      "  New best validation loss: 15.7920\n",
      "Epoch 4/200, Train Loss: 17.1155, Val Loss: 15.7970\n",
      "Epoch 5/200, Train Loss: 17.0751, Val Loss: 15.7772\n",
      "  New best validation loss: 15.7772\n",
      "Epoch 6/200, Train Loss: 17.0576, Val Loss: 15.7648\n",
      "  New best validation loss: 15.7648\n",
      "Epoch 7/200, Train Loss: 17.0425, Val Loss: 15.7651\n",
      "Epoch 8/200, Train Loss: 17.0372, Val Loss: 15.7563\n",
      "  New best validation loss: 15.7563\n",
      "Epoch 9/200, Train Loss: 17.0183, Val Loss: 15.7530\n",
      "  New best validation loss: 15.7530\n",
      "Epoch 10/200, Train Loss: 17.0094, Val Loss: 15.7568\n",
      "Epoch 11/200, Train Loss: 17.0016, Val Loss: 15.7817\n",
      "Epoch 12/200, Train Loss: 16.9945, Val Loss: 15.7793\n",
      "Epoch 13/200, Train Loss: 16.9985, Val Loss: 15.7580\n",
      "Epoch 14/200, Train Loss: 16.9927, Val Loss: 15.7643\n",
      "Epoch 15/200, Train Loss: 16.9819, Val Loss: 15.8028\n",
      "Epoch 16/200, Train Loss: 16.9769, Val Loss: 15.7788\n",
      "Epoch 17/200, Train Loss: 16.9712, Val Loss: 15.7600\n",
      "Epoch 18/200, Train Loss: 16.9640, Val Loss: 15.7706\n",
      "Epoch 19/200, Train Loss: 16.9572, Val Loss: 15.7693\n",
      "Epoch 20/200, Train Loss: 16.9537, Val Loss: 15.7932\n",
      "Epoch 21/200, Train Loss: 16.9469, Val Loss: 15.7735\n",
      "Epoch 22/200, Train Loss: 16.9539, Val Loss: 15.7686\n",
      "Epoch 23/200, Train Loss: 16.9418, Val Loss: 15.7843\n",
      "Epoch 24/200, Train Loss: 16.9364, Val Loss: 15.7693\n",
      "Epoch 25/200, Train Loss: 16.9354, Val Loss: 15.7615\n",
      "Epoch 26/200, Train Loss: 16.9320, Val Loss: 15.7595\n",
      "Epoch 27/200, Train Loss: 16.9219, Val Loss: 15.7890\n",
      "Epoch 28/200, Train Loss: 16.9212, Val Loss: 15.7782\n",
      "Epoch 29/200, Train Loss: 16.9128, Val Loss: 15.7762\n",
      "Epoch 30/200, Train Loss: 16.9101, Val Loss: 15.7772\n",
      "Epoch 31/200, Train Loss: 16.9073, Val Loss: 15.7797\n",
      "Epoch 32/200, Train Loss: 16.9011, Val Loss: 15.8011\n",
      "Epoch 33/200, Train Loss: 16.9017, Val Loss: 15.7945\n",
      "Epoch 34/200, Train Loss: 16.9032, Val Loss: 15.7663\n",
      "Epoch 35/200, Train Loss: 16.9072, Val Loss: 15.8003\n",
      "Epoch 36/200, Train Loss: 16.8942, Val Loss: 15.7694\n",
      "Epoch 37/200, Train Loss: 16.8926, Val Loss: 15.7857\n",
      "Epoch 38/200, Train Loss: 16.8903, Val Loss: 15.7740\n",
      "Epoch 39/200, Train Loss: 16.8818, Val Loss: 15.8109\n",
      "Epoch 40/200, Train Loss: 16.8824, Val Loss: 15.7791\n",
      "Epoch 41/200, Train Loss: 16.8750, Val Loss: 15.7948\n",
      "Epoch 42/200, Train Loss: 16.8713, Val Loss: 15.7742\n",
      "Epoch 43/200, Train Loss: 16.8699, Val Loss: 15.7979\n",
      "Epoch 44/200, Train Loss: 16.8649, Val Loss: 15.8015\n",
      "Epoch 45/200, Train Loss: 16.8582, Val Loss: 15.7925\n",
      "Epoch 46/200, Train Loss: 16.8540, Val Loss: 15.7940\n",
      "Epoch 47/200, Train Loss: 16.8519, Val Loss: 15.7670\n",
      "Epoch 48/200, Train Loss: 16.8531, Val Loss: 15.7966\n",
      "Epoch 49/200, Train Loss: 16.8553, Val Loss: 15.7972\n",
      "Epoch 50/200, Train Loss: 16.8518, Val Loss: 15.7844\n",
      "Epoch 51/200, Train Loss: 16.8381, Val Loss: 15.8014\n",
      "Epoch 52/200, Train Loss: 16.8318, Val Loss: 15.8224\n",
      "Epoch 53/200, Train Loss: 16.8273, Val Loss: 15.7938\n",
      "Epoch 54/200, Train Loss: 16.8196, Val Loss: 15.7966\n",
      "Epoch 55/200, Train Loss: 16.8104, Val Loss: 15.7800\n",
      "Epoch 56/200, Train Loss: 16.8232, Val Loss: 15.7700\n",
      "Epoch 57/200, Train Loss: 16.8165, Val Loss: 15.8253\n",
      "Epoch 58/200, Train Loss: 16.8114, Val Loss: 15.7763\n",
      "Epoch 59/200, Train Loss: 16.7963, Val Loss: 15.8037\n",
      "Epoch 60/200, Train Loss: 16.7853, Val Loss: 15.7986\n",
      "Epoch 61/200, Train Loss: 16.7770, Val Loss: 15.8070\n",
      "Epoch 62/200, Train Loss: 16.7697, Val Loss: 15.8190\n",
      "Epoch 63/200, Train Loss: 16.7713, Val Loss: 15.8186\n",
      "Epoch 64/200, Train Loss: 16.7668, Val Loss: 15.8293\n",
      "Epoch 65/200, Train Loss: 16.7584, Val Loss: 15.8439\n",
      "Epoch 66/200, Train Loss: 16.7489, Val Loss: 15.8260\n",
      "Epoch 67/200, Train Loss: 16.7453, Val Loss: 15.8302\n",
      "Epoch 68/200, Train Loss: 16.7429, Val Loss: 15.8251\n",
      "Epoch 69/200, Train Loss: 16.7321, Val Loss: 15.8169\n",
      "Epoch 70/200, Train Loss: 16.7401, Val Loss: 15.8176\n",
      "Epoch 71/200, Train Loss: 16.7284, Val Loss: 15.8636\n",
      "Epoch 72/200, Train Loss: 16.7218, Val Loss: 15.8358\n",
      "Epoch 73/200, Train Loss: 16.7161, Val Loss: 15.8276\n",
      "Epoch 74/200, Train Loss: 16.7252, Val Loss: 15.8579\n",
      "Epoch 75/200, Train Loss: 16.7099, Val Loss: 15.8313\n",
      "Epoch 76/200, Train Loss: 16.7053, Val Loss: 15.8324\n",
      "Epoch 77/200, Train Loss: 16.6987, Val Loss: 15.8293\n",
      "Epoch 78/200, Train Loss: 16.7262, Val Loss: 15.8881\n",
      "Epoch 79/200, Train Loss: 16.7026, Val Loss: 15.8541\n",
      "Epoch 80/200, Train Loss: 16.6902, Val Loss: 15.8604\n",
      "Epoch 81/200, Train Loss: 16.6743, Val Loss: 15.8555\n",
      "Epoch 82/200, Train Loss: 16.6705, Val Loss: 15.8657\n",
      "Epoch 83/200, Train Loss: 16.6695, Val Loss: 15.8942\n",
      "Epoch 84/200, Train Loss: 16.6691, Val Loss: 15.8962\n",
      "Epoch 85/200, Train Loss: 16.6664, Val Loss: 15.8817\n",
      "Epoch 86/200, Train Loss: 16.6518, Val Loss: 15.8526\n",
      "Epoch 87/200, Train Loss: 16.6475, Val Loss: 15.8456\n",
      "Epoch 88/200, Train Loss: 16.6460, Val Loss: 15.8969\n",
      "Epoch 89/200, Train Loss: 16.6327, Val Loss: 15.8633\n",
      "Epoch 90/200, Train Loss: 16.6225, Val Loss: 15.8797\n",
      "Epoch 91/200, Train Loss: 16.6255, Val Loss: 15.8828\n",
      "Epoch 92/200, Train Loss: 16.6113, Val Loss: 15.8685\n",
      "Epoch 93/200, Train Loss: 16.6180, Val Loss: 15.9064\n",
      "Epoch 94/200, Train Loss: 16.6195, Val Loss: 15.8877\n",
      "Epoch 95/200, Train Loss: 16.5960, Val Loss: 15.8741\n",
      "Epoch 96/200, Train Loss: 16.5884, Val Loss: 15.8663\n",
      "Epoch 97/200, Train Loss: 16.5994, Val Loss: 15.8931\n",
      "Epoch 98/200, Train Loss: 16.5899, Val Loss: 15.9090\n",
      "Epoch 99/200, Train Loss: 16.5701, Val Loss: 15.8663\n",
      "Epoch 100/200, Train Loss: 16.5707, Val Loss: 15.8722\n",
      "Epoch 101/200, Train Loss: 16.5639, Val Loss: 15.8557\n",
      "Epoch 102/200, Train Loss: 16.5459, Val Loss: 15.8593\n",
      "Epoch 103/200, Train Loss: 16.5446, Val Loss: 15.9013\n",
      "Epoch 104/200, Train Loss: 16.5294, Val Loss: 15.8760\n",
      "Epoch 105/200, Train Loss: 16.5199, Val Loss: 15.8873\n",
      "Epoch 106/200, Train Loss: 16.5254, Val Loss: 15.9101\n",
      "Epoch 107/200, Train Loss: 16.5215, Val Loss: 15.8927\n",
      "Epoch 108/200, Train Loss: 16.5046, Val Loss: 15.8870\n",
      "Epoch 109/200, Train Loss: 16.5025, Val Loss: 15.9156\n",
      "Epoch 110/200, Train Loss: 16.4844, Val Loss: 15.8879\n",
      "Epoch 111/200, Train Loss: 16.4867, Val Loss: 15.9007\n",
      "Epoch 112/200, Train Loss: 16.4668, Val Loss: 15.9179\n",
      "Epoch 113/200, Train Loss: 16.4601, Val Loss: 15.8822\n",
      "Epoch 114/200, Train Loss: 16.4494, Val Loss: 15.9477\n",
      "Epoch 115/200, Train Loss: 16.4382, Val Loss: 15.9434\n",
      "Epoch 116/200, Train Loss: 16.4365, Val Loss: 15.8838\n",
      "Epoch 117/200, Train Loss: 16.4475, Val Loss: 16.0166\n",
      "Epoch 118/200, Train Loss: 16.4096, Val Loss: 15.9089\n",
      "Epoch 119/200, Train Loss: 16.3987, Val Loss: 15.9278\n",
      "Epoch 120/200, Train Loss: 16.3892, Val Loss: 15.9538\n",
      "Epoch 121/200, Train Loss: 16.3731, Val Loss: 15.9348\n",
      "Epoch 122/200, Train Loss: 16.3778, Val Loss: 15.9032\n",
      "Epoch 123/200, Train Loss: 16.3631, Val Loss: 15.9015\n",
      "Epoch 124/200, Train Loss: 16.3544, Val Loss: 15.9226\n",
      "Epoch 125/200, Train Loss: 16.3428, Val Loss: 15.8955\n",
      "Epoch 126/200, Train Loss: 16.3415, Val Loss: 15.9168\n",
      "Epoch 127/200, Train Loss: 16.3284, Val Loss: 15.9605\n",
      "Epoch 128/200, Train Loss: 16.3166, Val Loss: 15.9477\n",
      "Epoch 129/200, Train Loss: 16.3028, Val Loss: 15.9485\n",
      "Epoch 130/200, Train Loss: 16.3129, Val Loss: 15.9014\n",
      "Epoch 131/200, Train Loss: 16.2944, Val Loss: 15.9697\n",
      "Epoch 132/200, Train Loss: 16.2901, Val Loss: 15.9292\n",
      "Epoch 133/200, Train Loss: 16.3056, Val Loss: 15.9691\n",
      "Epoch 134/200, Train Loss: 16.2784, Val Loss: 15.9789\n",
      "Epoch 135/200, Train Loss: 16.2842, Val Loss: 15.9191\n",
      "Epoch 136/200, Train Loss: 16.2722, Val Loss: 16.0403\n",
      "Epoch 137/200, Train Loss: 16.2603, Val Loss: 15.9672\n",
      "Epoch 138/200, Train Loss: 16.2282, Val Loss: 15.8883\n",
      "Epoch 139/200, Train Loss: 16.2207, Val Loss: 15.9666\n",
      "Epoch 140/200, Train Loss: 16.2216, Val Loss: 15.9351\n",
      "Epoch 141/200, Train Loss: 16.2073, Val Loss: 15.9394\n",
      "Epoch 142/200, Train Loss: 16.2082, Val Loss: 15.9129\n",
      "Epoch 143/200, Train Loss: 16.1929, Val Loss: 15.9565\n",
      "Epoch 144/200, Train Loss: 16.1773, Val Loss: 15.9048\n",
      "Epoch 145/200, Train Loss: 16.1787, Val Loss: 15.9508\n",
      "Epoch 146/200, Train Loss: 16.1583, Val Loss: 15.8975\n",
      "Epoch 147/200, Train Loss: 16.1636, Val Loss: 15.9683\n",
      "Epoch 148/200, Train Loss: 16.1451, Val Loss: 16.0367\n",
      "Epoch 149/200, Train Loss: 16.1355, Val Loss: 15.9329\n",
      "Epoch 150/200, Train Loss: 16.1166, Val Loss: 15.9602\n",
      "Epoch 151/200, Train Loss: 16.1416, Val Loss: 15.9663\n",
      "Epoch 152/200, Train Loss: 16.0911, Val Loss: 15.9111\n",
      "Epoch 153/200, Train Loss: 16.0841, Val Loss: 16.0040\n",
      "Epoch 154/200, Train Loss: 16.0963, Val Loss: 15.9366\n",
      "Epoch 155/200, Train Loss: 16.0835, Val Loss: 15.9330\n",
      "Epoch 156/200, Train Loss: 16.0521, Val Loss: 15.9470\n",
      "Epoch 157/200, Train Loss: 16.0490, Val Loss: 15.9498\n",
      "Epoch 158/200, Train Loss: 16.0469, Val Loss: 15.9710\n",
      "Epoch 159/200, Train Loss: 16.0369, Val Loss: 15.8639\n",
      "Epoch 160/200, Train Loss: 16.0143, Val Loss: 15.9770\n",
      "Epoch 161/200, Train Loss: 16.0223, Val Loss: 15.9426\n",
      "Epoch 162/200, Train Loss: 16.0031, Val Loss: 15.9314\n",
      "Epoch 163/200, Train Loss: 16.0169, Val Loss: 16.0216\n",
      "Epoch 164/200, Train Loss: 15.9846, Val Loss: 15.8917\n",
      "Epoch 165/200, Train Loss: 15.9457, Val Loss: 16.0038\n",
      "Epoch 166/200, Train Loss: 15.9445, Val Loss: 15.9296\n",
      "Epoch 167/200, Train Loss: 15.9223, Val Loss: 15.8963\n",
      "Epoch 168/200, Train Loss: 15.9104, Val Loss: 16.0457\n",
      "Epoch 169/200, Train Loss: 15.9119, Val Loss: 15.9223\n",
      "Epoch 170/200, Train Loss: 15.8983, Val Loss: 16.0768\n",
      "Epoch 171/200, Train Loss: 15.9120, Val Loss: 15.9075\n",
      "Epoch 172/200, Train Loss: 15.8514, Val Loss: 16.0739\n",
      "Epoch 173/200, Train Loss: 15.8473, Val Loss: 15.9741\n",
      "Epoch 174/200, Train Loss: 15.8466, Val Loss: 15.9583\n",
      "Epoch 175/200, Train Loss: 15.8310, Val Loss: 15.9780\n",
      "Epoch 176/200, Train Loss: 15.8160, Val Loss: 15.9828\n",
      "Epoch 177/200, Train Loss: 15.8187, Val Loss: 15.8623\n",
      "Epoch 178/200, Train Loss: 15.7643, Val Loss: 16.1907\n",
      "Epoch 179/200, Train Loss: 15.8141, Val Loss: 15.9777\n",
      "Epoch 180/200, Train Loss: 15.7519, Val Loss: 15.9276\n",
      "Epoch 181/200, Train Loss: 15.7486, Val Loss: 16.0241\n",
      "Epoch 182/200, Train Loss: 15.7524, Val Loss: 15.9638\n",
      "Epoch 183/200, Train Loss: 15.7479, Val Loss: 16.0035\n",
      "Epoch 184/200, Train Loss: 15.7037, Val Loss: 16.1416\n",
      "Epoch 185/200, Train Loss: 15.6898, Val Loss: 15.9528\n",
      "Epoch 186/200, Train Loss: 15.7017, Val Loss: 16.1092\n",
      "Epoch 187/200, Train Loss: 15.6751, Val Loss: 16.0218\n",
      "Epoch 188/200, Train Loss: 15.6611, Val Loss: 16.0101\n",
      "Epoch 189/200, Train Loss: 15.6485, Val Loss: 16.0588\n",
      "Epoch 190/200, Train Loss: 15.6482, Val Loss: 16.0312\n",
      "Epoch 191/200, Train Loss: 15.6150, Val Loss: 16.1247\n",
      "Epoch 192/200, Train Loss: 15.5816, Val Loss: 16.0400\n",
      "Epoch 193/200, Train Loss: 15.6068, Val Loss: 16.0592\n",
      "Epoch 194/200, Train Loss: 15.5554, Val Loss: 16.1740\n",
      "Epoch 195/200, Train Loss: 15.5569, Val Loss: 16.1239\n",
      "Epoch 196/200, Train Loss: 15.6290, Val Loss: 15.9530\n",
      "Epoch 197/200, Train Loss: 15.5409, Val Loss: 16.1598\n",
      "Epoch 198/200, Train Loss: 15.5180, Val Loss: 16.0317\n",
      "Epoch 199/200, Train Loss: 15.4890, Val Loss: 16.1379\n",
      "Epoch 200/200, Train Loss: 15.5101, Val Loss: 16.0712\n",
      "\n",
      "Loaded best model (Val Loss: 15.7530) for final hidden state extraction.\n",
      "Saved best model for RNN_Vanillia (samples=320) to results_data_size_sweep/20250514_045146/samples_320/RNN_Vanillia_samples_320_best.pt\n",
      "\n",
      "--- Performing Decodability Analysis for RNN_Vanillia (samples=320, k=15) ---\n",
      "  Analyzing decodability for RNN_Vanillia...\n",
      "  Hidden states shape: torch.Size([160, 200, 225])\n",
      "  Coefficients shape: torch.Size([160, 15])\n",
      "  Processed hidden states shape for decoder: torch.Size([160, 225])\n",
      "  RidgeCV Decoder for RNN_Vanillia - Test MSE: 1.8004, Test R2: 0.0917 (best alpha: 100.0000)\n",
      "  Decodability plot saved to results_data_size_sweep/20250514_045146/samples_320/decodability_RNN_Vanillia_coeff1.png\n",
      "Decodability (R2 score) for RNN_Vanillia (samples=320): 0.0917\n",
      "\n",
      "--- Training ComplexOscillatorNet (samples=320, k=15) ---\n",
      "Number of parameters: 17152\n",
      "Epoch 1/200, Train Loss: 17.3191, Val Loss: 15.4402\n",
      "  New best validation loss: 15.4402\n",
      "Epoch 2/200, Train Loss: 16.6662, Val Loss: 15.0262\n",
      "  New best validation loss: 15.0262\n",
      "Epoch 3/200, Train Loss: 16.2754, Val Loss: 14.8645\n",
      "  New best validation loss: 14.8645\n",
      "Epoch 4/200, Train Loss: 15.9023, Val Loss: 14.7118\n",
      "  New best validation loss: 14.7118\n",
      "Epoch 5/200, Train Loss: 15.6945, Val Loss: 14.6909\n",
      "  New best validation loss: 14.6909\n",
      "Epoch 6/200, Train Loss: 15.4657, Val Loss: 14.5044\n",
      "  New best validation loss: 14.5044\n",
      "Epoch 7/200, Train Loss: 15.3430, Val Loss: 14.6072\n",
      "Epoch 8/200, Train Loss: 15.2147, Val Loss: 14.5390\n",
      "Epoch 9/200, Train Loss: 15.0370, Val Loss: 14.4324\n",
      "  New best validation loss: 14.4324\n",
      "Epoch 10/200, Train Loss: 14.9382, Val Loss: 14.4653\n",
      "Epoch 11/200, Train Loss: 14.8435, Val Loss: 14.3612\n",
      "  New best validation loss: 14.3612\n",
      "Epoch 12/200, Train Loss: 14.7334, Val Loss: 14.5192\n",
      "Epoch 13/200, Train Loss: 14.5830, Val Loss: 14.4724\n",
      "Epoch 14/200, Train Loss: 14.4907, Val Loss: 14.3969\n",
      "Epoch 15/200, Train Loss: 14.3925, Val Loss: 14.3265\n",
      "  New best validation loss: 14.3265\n",
      "Epoch 16/200, Train Loss: 14.3013, Val Loss: 14.5157\n",
      "Epoch 17/200, Train Loss: 14.1885, Val Loss: 14.4263\n",
      "Epoch 18/200, Train Loss: 14.1258, Val Loss: 14.4329\n",
      "Epoch 19/200, Train Loss: 14.0614, Val Loss: 14.4334\n",
      "Epoch 20/200, Train Loss: 13.9476, Val Loss: 14.5979\n",
      "Epoch 21/200, Train Loss: 13.9090, Val Loss: 14.5340\n",
      "Epoch 22/200, Train Loss: 13.8475, Val Loss: 14.5924\n",
      "Epoch 23/200, Train Loss: 13.7787, Val Loss: 14.4740\n",
      "Epoch 24/200, Train Loss: 13.7381, Val Loss: 14.5234\n",
      "Epoch 25/200, Train Loss: 13.6777, Val Loss: 14.6709\n",
      "Epoch 26/200, Train Loss: 13.6151, Val Loss: 14.4658\n",
      "Epoch 27/200, Train Loss: 13.5270, Val Loss: 14.5872\n",
      "Epoch 28/200, Train Loss: 13.4783, Val Loss: 14.5401\n",
      "Epoch 29/200, Train Loss: 13.3769, Val Loss: 14.4654\n",
      "Epoch 30/200, Train Loss: 13.3183, Val Loss: 14.6318\n",
      "Epoch 31/200, Train Loss: 13.2918, Val Loss: 14.5027\n",
      "Epoch 32/200, Train Loss: 13.2538, Val Loss: 14.5221\n",
      "Epoch 33/200, Train Loss: 13.2422, Val Loss: 14.7057\n",
      "Epoch 34/200, Train Loss: 13.2267, Val Loss: 14.6513\n",
      "Epoch 35/200, Train Loss: 13.1290, Val Loss: 14.5338\n",
      "Epoch 36/200, Train Loss: 13.0737, Val Loss: 14.8502\n",
      "Epoch 37/200, Train Loss: 13.0075, Val Loss: 14.5966\n",
      "Epoch 38/200, Train Loss: 13.0130, Val Loss: 14.6816\n",
      "Epoch 39/200, Train Loss: 13.0191, Val Loss: 14.6883\n",
      "Epoch 40/200, Train Loss: 12.9884, Val Loss: 14.7338\n",
      "Epoch 41/200, Train Loss: 12.8968, Val Loss: 14.8116\n",
      "Epoch 42/200, Train Loss: 12.8465, Val Loss: 14.7641\n",
      "Epoch 43/200, Train Loss: 12.8124, Val Loss: 14.7343\n",
      "Epoch 44/200, Train Loss: 12.7528, Val Loss: 14.8650\n",
      "Epoch 45/200, Train Loss: 12.7141, Val Loss: 14.7359\n",
      "Epoch 46/200, Train Loss: 12.7528, Val Loss: 15.0691\n",
      "Epoch 47/200, Train Loss: 12.6922, Val Loss: 14.8073\n",
      "Epoch 48/200, Train Loss: 12.6945, Val Loss: 14.9453\n",
      "Epoch 49/200, Train Loss: 12.7098, Val Loss: 14.9677\n",
      "Epoch 50/200, Train Loss: 12.6681, Val Loss: 14.9133\n",
      "Epoch 51/200, Train Loss: 12.6996, Val Loss: 14.9370\n",
      "Epoch 52/200, Train Loss: 12.6683, Val Loss: 14.8926\n",
      "Epoch 53/200, Train Loss: 12.5777, Val Loss: 14.9457\n",
      "Epoch 54/200, Train Loss: 12.5614, Val Loss: 14.9213\n",
      "Epoch 55/200, Train Loss: 12.4866, Val Loss: 14.8355\n",
      "Epoch 56/200, Train Loss: 12.4838, Val Loss: 14.9637\n",
      "Epoch 57/200, Train Loss: 12.4279, Val Loss: 15.0820\n",
      "Epoch 58/200, Train Loss: 12.4320, Val Loss: 15.0410\n",
      "Epoch 59/200, Train Loss: 12.3782, Val Loss: 15.0718\n",
      "Epoch 60/200, Train Loss: 12.3281, Val Loss: 15.0884\n",
      "Epoch 61/200, Train Loss: 12.3658, Val Loss: 15.0404\n",
      "Epoch 62/200, Train Loss: 12.3146, Val Loss: 15.1099\n",
      "Epoch 63/200, Train Loss: 12.2895, Val Loss: 15.0242\n",
      "Epoch 64/200, Train Loss: 12.2341, Val Loss: 15.2754\n",
      "Epoch 65/200, Train Loss: 12.2237, Val Loss: 15.0846\n",
      "Epoch 66/200, Train Loss: 12.2381, Val Loss: 15.1204\n",
      "Epoch 67/200, Train Loss: 12.1916, Val Loss: 15.3777\n",
      "Epoch 68/200, Train Loss: 12.2098, Val Loss: 15.3097\n",
      "Epoch 69/200, Train Loss: 12.1968, Val Loss: 15.1784\n",
      "Epoch 70/200, Train Loss: 12.1568, Val Loss: 15.2515\n",
      "Epoch 71/200, Train Loss: 12.0989, Val Loss: 15.2364\n",
      "Epoch 72/200, Train Loss: 12.0684, Val Loss: 15.1707\n",
      "Epoch 73/200, Train Loss: 12.0574, Val Loss: 15.3799\n",
      "Epoch 74/200, Train Loss: 12.0812, Val Loss: 15.2684\n",
      "Epoch 75/200, Train Loss: 12.1134, Val Loss: 15.3417\n",
      "Epoch 76/200, Train Loss: 12.2633, Val Loss: 15.3612\n",
      "Epoch 77/200, Train Loss: 12.2357, Val Loss: 15.2968\n",
      "Epoch 78/200, Train Loss: 12.1638, Val Loss: 15.3594\n",
      "Epoch 79/200, Train Loss: 12.1415, Val Loss: 15.1972\n",
      "Epoch 80/200, Train Loss: 12.1223, Val Loss: 15.3108\n",
      "Epoch 81/200, Train Loss: 12.0554, Val Loss: 15.3116\n",
      "Epoch 82/200, Train Loss: 12.0358, Val Loss: 15.4649\n",
      "Epoch 83/200, Train Loss: 12.0072, Val Loss: 15.2734\n",
      "Epoch 84/200, Train Loss: 11.9508, Val Loss: 15.1264\n",
      "Epoch 85/200, Train Loss: 11.9019, Val Loss: 15.3364\n",
      "Epoch 86/200, Train Loss: 11.9004, Val Loss: 15.2967\n",
      "Epoch 87/200, Train Loss: 11.8786, Val Loss: 15.4010\n",
      "Epoch 88/200, Train Loss: 11.8784, Val Loss: 15.5270\n",
      "Epoch 89/200, Train Loss: 11.8241, Val Loss: 15.4533\n",
      "Epoch 90/200, Train Loss: 11.8208, Val Loss: 15.4623\n",
      "Epoch 91/200, Train Loss: 11.7968, Val Loss: 15.4381\n",
      "Epoch 92/200, Train Loss: 11.7945, Val Loss: 15.4470\n",
      "Epoch 93/200, Train Loss: 11.8051, Val Loss: 15.4522\n",
      "Epoch 94/200, Train Loss: 11.8073, Val Loss: 15.4591\n",
      "Epoch 95/200, Train Loss: 11.8221, Val Loss: 15.4815\n",
      "Epoch 96/200, Train Loss: 11.8464, Val Loss: 15.6203\n",
      "Epoch 97/200, Train Loss: 11.7994, Val Loss: 15.6468\n",
      "Epoch 98/200, Train Loss: 11.8078, Val Loss: 15.5339\n",
      "Epoch 99/200, Train Loss: 11.8130, Val Loss: 15.5025\n",
      "Epoch 100/200, Train Loss: 11.7467, Val Loss: 15.6362\n",
      "Epoch 101/200, Train Loss: 11.7405, Val Loss: 15.5064\n",
      "Epoch 102/200, Train Loss: 11.7381, Val Loss: 15.5524\n",
      "Epoch 103/200, Train Loss: 11.7295, Val Loss: 15.4538\n",
      "Epoch 104/200, Train Loss: 11.6896, Val Loss: 15.6513\n",
      "Epoch 105/200, Train Loss: 11.6591, Val Loss: 15.7399\n",
      "Epoch 106/200, Train Loss: 11.6984, Val Loss: 15.4602\n",
      "Epoch 107/200, Train Loss: 11.6704, Val Loss: 15.7330\n",
      "Epoch 108/200, Train Loss: 11.6701, Val Loss: 15.6257\n",
      "Epoch 109/200, Train Loss: 11.6617, Val Loss: 15.6416\n",
      "Epoch 110/200, Train Loss: 11.6786, Val Loss: 15.6549\n",
      "Epoch 111/200, Train Loss: 11.7236, Val Loss: 15.5250\n",
      "Epoch 112/200, Train Loss: 11.7408, Val Loss: 15.9519\n",
      "Epoch 113/200, Train Loss: 11.6588, Val Loss: 15.6023\n",
      "Epoch 114/200, Train Loss: 11.6193, Val Loss: 15.6821\n",
      "Epoch 115/200, Train Loss: 11.5977, Val Loss: 15.7708\n",
      "Epoch 116/200, Train Loss: 11.6491, Val Loss: 15.6436\n",
      "Epoch 117/200, Train Loss: 11.6646, Val Loss: 15.6072\n",
      "Epoch 118/200, Train Loss: 11.6265, Val Loss: 15.7149\n",
      "Epoch 119/200, Train Loss: 11.5792, Val Loss: 15.5748\n",
      "Epoch 120/200, Train Loss: 11.5628, Val Loss: 15.7031\n",
      "Epoch 121/200, Train Loss: 11.5157, Val Loss: 15.6514\n",
      "Epoch 122/200, Train Loss: 11.5058, Val Loss: 15.6940\n",
      "Epoch 123/200, Train Loss: 11.5524, Val Loss: 15.7012\n",
      "Epoch 124/200, Train Loss: 11.4808, Val Loss: 15.6542\n",
      "Epoch 125/200, Train Loss: 11.4783, Val Loss: 15.8524\n",
      "Epoch 126/200, Train Loss: 11.4702, Val Loss: 15.7273\n",
      "Epoch 127/200, Train Loss: 11.4298, Val Loss: 15.8518\n",
      "Epoch 128/200, Train Loss: 11.4377, Val Loss: 15.7804\n",
      "Epoch 129/200, Train Loss: 11.4886, Val Loss: 15.8669\n",
      "Epoch 130/200, Train Loss: 11.4590, Val Loss: 15.8396\n",
      "Epoch 131/200, Train Loss: 11.4866, Val Loss: 15.8979\n",
      "Epoch 132/200, Train Loss: 11.4948, Val Loss: 15.7871\n",
      "Epoch 133/200, Train Loss: 11.4752, Val Loss: 15.8229\n",
      "Epoch 134/200, Train Loss: 11.4515, Val Loss: 15.7413\n",
      "Epoch 135/200, Train Loss: 11.4472, Val Loss: 15.9113\n",
      "Epoch 136/200, Train Loss: 11.4558, Val Loss: 15.7904\n",
      "Epoch 137/200, Train Loss: 11.4854, Val Loss: 15.8854\n",
      "Epoch 138/200, Train Loss: 11.4613, Val Loss: 16.0385\n",
      "Epoch 139/200, Train Loss: 11.4801, Val Loss: 15.7831\n",
      "Epoch 140/200, Train Loss: 11.4532, Val Loss: 15.7333\n",
      "Epoch 141/200, Train Loss: 11.4457, Val Loss: 15.8746\n",
      "Epoch 142/200, Train Loss: 11.4905, Val Loss: 15.8029\n",
      "Epoch 143/200, Train Loss: 11.4557, Val Loss: 15.7844\n",
      "Epoch 144/200, Train Loss: 11.4315, Val Loss: 15.9177\n",
      "Epoch 145/200, Train Loss: 11.3849, Val Loss: 15.7605\n",
      "Epoch 146/200, Train Loss: 11.4098, Val Loss: 15.8998\n",
      "Epoch 147/200, Train Loss: 11.3854, Val Loss: 15.9300\n",
      "Epoch 148/200, Train Loss: 11.3687, Val Loss: 15.8036\n",
      "Epoch 149/200, Train Loss: 11.3447, Val Loss: 15.9765\n",
      "Epoch 150/200, Train Loss: 11.2998, Val Loss: 15.9557\n",
      "Epoch 151/200, Train Loss: 11.3065, Val Loss: 15.8880\n",
      "Epoch 152/200, Train Loss: 11.2990, Val Loss: 15.9023\n",
      "Epoch 153/200, Train Loss: 11.2895, Val Loss: 16.0961\n",
      "Epoch 154/200, Train Loss: 11.2560, Val Loss: 16.0364\n",
      "Epoch 155/200, Train Loss: 11.2582, Val Loss: 15.9916\n",
      "Epoch 156/200, Train Loss: 11.2648, Val Loss: 15.9001\n",
      "Epoch 157/200, Train Loss: 11.3514, Val Loss: 16.1945\n",
      "Epoch 158/200, Train Loss: 11.4175, Val Loss: 15.9101\n",
      "Epoch 159/200, Train Loss: 11.4158, Val Loss: 16.1172\n",
      "Epoch 160/200, Train Loss: 11.3539, Val Loss: 15.9270\n",
      "Epoch 161/200, Train Loss: 11.3213, Val Loss: 16.0076\n",
      "Epoch 162/200, Train Loss: 11.3132, Val Loss: 16.0951\n",
      "Epoch 163/200, Train Loss: 11.3168, Val Loss: 15.8864\n",
      "Epoch 164/200, Train Loss: 11.2704, Val Loss: 15.9583\n",
      "Epoch 165/200, Train Loss: 11.2476, Val Loss: 15.9874\n",
      "Epoch 166/200, Train Loss: 11.2161, Val Loss: 16.0849\n",
      "Epoch 167/200, Train Loss: 11.2264, Val Loss: 16.1903\n",
      "Epoch 168/200, Train Loss: 11.2434, Val Loss: 15.9997\n",
      "Epoch 169/200, Train Loss: 11.2528, Val Loss: 16.0351\n",
      "Epoch 170/200, Train Loss: 11.2327, Val Loss: 16.0951\n",
      "Epoch 171/200, Train Loss: 11.2342, Val Loss: 15.9959\n",
      "Epoch 172/200, Train Loss: 11.2002, Val Loss: 16.0093\n",
      "Epoch 173/200, Train Loss: 11.2110, Val Loss: 16.1185\n",
      "Epoch 174/200, Train Loss: 11.2328, Val Loss: 16.2679\n",
      "Epoch 175/200, Train Loss: 11.3007, Val Loss: 16.0819\n",
      "Epoch 176/200, Train Loss: 11.3113, Val Loss: 16.0628\n",
      "Epoch 177/200, Train Loss: 11.3035, Val Loss: 16.0737\n",
      "Epoch 178/200, Train Loss: 11.3019, Val Loss: 16.1442\n",
      "Epoch 179/200, Train Loss: 11.2931, Val Loss: 16.2305\n",
      "Epoch 180/200, Train Loss: 11.2943, Val Loss: 15.9755\n",
      "Epoch 181/200, Train Loss: 11.2224, Val Loss: 16.2109\n",
      "Epoch 182/200, Train Loss: 11.2133, Val Loss: 16.0086\n",
      "Epoch 183/200, Train Loss: 11.1722, Val Loss: 16.0573\n",
      "Epoch 184/200, Train Loss: 11.1594, Val Loss: 16.0490\n",
      "Epoch 185/200, Train Loss: 11.1605, Val Loss: 16.0069\n",
      "Epoch 186/200, Train Loss: 11.1607, Val Loss: 16.1230\n",
      "Epoch 187/200, Train Loss: 11.1332, Val Loss: 16.3055\n",
      "Epoch 188/200, Train Loss: 11.1244, Val Loss: 16.0135\n",
      "Epoch 189/200, Train Loss: 11.1151, Val Loss: 16.1816\n",
      "Epoch 190/200, Train Loss: 11.0878, Val Loss: 16.1114\n",
      "Epoch 191/200, Train Loss: 11.0484, Val Loss: 16.2136\n",
      "Epoch 192/200, Train Loss: 11.0553, Val Loss: 16.1225\n",
      "Epoch 193/200, Train Loss: 11.0483, Val Loss: 16.2528\n",
      "Epoch 194/200, Train Loss: 11.0734, Val Loss: 16.2490\n",
      "Epoch 195/200, Train Loss: 11.1127, Val Loss: 16.4188\n",
      "Epoch 196/200, Train Loss: 11.1437, Val Loss: 16.1451\n",
      "Epoch 197/200, Train Loss: 11.1350, Val Loss: 16.2509\n",
      "Epoch 198/200, Train Loss: 11.1371, Val Loss: 16.2211\n",
      "Epoch 199/200, Train Loss: 11.1373, Val Loss: 16.1835\n",
      "Epoch 200/200, Train Loss: 11.1089, Val Loss: 16.3135\n",
      "\n",
      "Loaded best model (Val Loss: 14.3265) for final hidden state extraction.\n",
      "Saved best model for ComplexOscillatorNet (samples=320) to results_data_size_sweep/20250514_045146/samples_320/ComplexOscillatorNet_samples_320_best.pt\n",
      "\n",
      "--- Performing Decodability Analysis for ComplexOscillatorNet (samples=320, k=15) ---\n",
      "  Analyzing decodability for ComplexOscillatorNet...\n",
      "  Hidden states shape: torch.Size([160, 200, 128])\n",
      "  Coefficients shape: torch.Size([160, 15])\n",
      "  Processed hidden states shape for decoder: torch.Size([160, 256])\n",
      "  RidgeCV Decoder for ComplexOscillatorNet - Test MSE: 1.1736, Test R2: 0.4113 (best alpha: 100.0000)\n",
      "  Decodability plot saved to results_data_size_sweep/20250514_045146/samples_320/decodability_ComplexOscillatorNet_coeff1.png\n",
      "Decodability (R2 score) for ComplexOscillatorNet (samples=320): 0.4113\n",
      "\n",
      "--- Training RNN_GRU (samples=320, k=15) ---\n",
      "Number of parameters: 12993\n",
      "Epoch 1/200, Train Loss: 17.1567, Val Loss: 15.8317\n",
      "  New best validation loss: 15.8317\n",
      "Epoch 2/200, Train Loss: 17.1422, Val Loss: 15.8006\n",
      "  New best validation loss: 15.8006\n",
      "Epoch 3/200, Train Loss: 17.1283, Val Loss: 15.8007\n",
      "Epoch 4/200, Train Loss: 17.1187, Val Loss: 15.7871\n",
      "  New best validation loss: 15.7871\n",
      "Epoch 5/200, Train Loss: 17.1084, Val Loss: 15.7904\n",
      "Epoch 6/200, Train Loss: 17.0972, Val Loss: 15.7651\n",
      "  New best validation loss: 15.7651\n",
      "Epoch 7/200, Train Loss: 17.0836, Val Loss: 15.7604\n",
      "  New best validation loss: 15.7604\n",
      "Epoch 8/200, Train Loss: 17.0747, Val Loss: 15.7488\n",
      "  New best validation loss: 15.7488\n",
      "Epoch 9/200, Train Loss: 17.0670, Val Loss: 15.7395\n",
      "  New best validation loss: 15.7395\n",
      "Epoch 10/200, Train Loss: 17.0545, Val Loss: 15.7546\n",
      "Epoch 11/200, Train Loss: 17.0522, Val Loss: 15.7320\n",
      "  New best validation loss: 15.7320\n",
      "Epoch 12/200, Train Loss: 17.0380, Val Loss: 15.7414\n",
      "Epoch 13/200, Train Loss: 17.0322, Val Loss: 15.7377\n",
      "Epoch 14/200, Train Loss: 17.0355, Val Loss: 15.7559\n",
      "Epoch 15/200, Train Loss: 17.0243, Val Loss: 15.7347\n",
      "Epoch 16/200, Train Loss: 17.0243, Val Loss: 15.7225\n",
      "  New best validation loss: 15.7225\n",
      "Epoch 17/200, Train Loss: 17.0319, Val Loss: 15.7631\n",
      "Epoch 18/200, Train Loss: 17.0165, Val Loss: 15.7369\n",
      "Epoch 19/200, Train Loss: 17.0146, Val Loss: 15.7251\n",
      "Epoch 20/200, Train Loss: 17.0117, Val Loss: 15.7350\n",
      "Epoch 21/200, Train Loss: 17.0134, Val Loss: 15.7263\n",
      "Epoch 22/200, Train Loss: 17.0063, Val Loss: 15.7438\n",
      "Epoch 23/200, Train Loss: 17.0094, Val Loss: 15.7345\n",
      "Epoch 24/200, Train Loss: 17.0065, Val Loss: 15.7528\n",
      "Epoch 25/200, Train Loss: 17.0026, Val Loss: 15.7456\n",
      "Epoch 26/200, Train Loss: 16.9990, Val Loss: 15.7164\n",
      "  New best validation loss: 15.7164\n",
      "Epoch 27/200, Train Loss: 17.0014, Val Loss: 15.7232\n",
      "Epoch 28/200, Train Loss: 16.9976, Val Loss: 15.7311\n",
      "Epoch 29/200, Train Loss: 16.9957, Val Loss: 15.7396\n",
      "Epoch 30/200, Train Loss: 16.9946, Val Loss: 15.7329\n",
      "Epoch 31/200, Train Loss: 16.9905, Val Loss: 15.7182\n",
      "Epoch 32/200, Train Loss: 16.9978, Val Loss: 15.7318\n",
      "Epoch 33/200, Train Loss: 16.9863, Val Loss: 15.7167\n",
      "Epoch 34/200, Train Loss: 16.9899, Val Loss: 15.7255\n",
      "Epoch 35/200, Train Loss: 16.9838, Val Loss: 15.7212\n",
      "Epoch 36/200, Train Loss: 16.9803, Val Loss: 15.7139\n",
      "  New best validation loss: 15.7139\n",
      "Epoch 37/200, Train Loss: 16.9771, Val Loss: 15.7212\n",
      "Epoch 38/200, Train Loss: 16.9748, Val Loss: 15.7246\n",
      "Epoch 39/200, Train Loss: 16.9739, Val Loss: 15.7286\n",
      "Epoch 40/200, Train Loss: 16.9724, Val Loss: 15.7250\n",
      "Epoch 41/200, Train Loss: 16.9733, Val Loss: 15.7005\n",
      "  New best validation loss: 15.7005\n",
      "Epoch 42/200, Train Loss: 16.9673, Val Loss: 15.7085\n",
      "Epoch 43/200, Train Loss: 16.9634, Val Loss: 15.7252\n",
      "Epoch 44/200, Train Loss: 16.9660, Val Loss: 15.7328\n",
      "Epoch 45/200, Train Loss: 16.9582, Val Loss: 15.7057\n",
      "Epoch 46/200, Train Loss: 16.9558, Val Loss: 15.6942\n",
      "  New best validation loss: 15.6942\n",
      "Epoch 47/200, Train Loss: 16.9571, Val Loss: 15.6965\n",
      "Epoch 48/200, Train Loss: 16.9523, Val Loss: 15.7263\n",
      "Epoch 49/200, Train Loss: 16.9500, Val Loss: 15.7020\n",
      "Epoch 50/200, Train Loss: 16.9445, Val Loss: 15.7037\n",
      "Epoch 51/200, Train Loss: 16.9413, Val Loss: 15.6894\n",
      "  New best validation loss: 15.6894\n",
      "Epoch 52/200, Train Loss: 16.9404, Val Loss: 15.7055\n",
      "Epoch 53/200, Train Loss: 16.9327, Val Loss: 15.6876\n",
      "  New best validation loss: 15.6876\n",
      "Epoch 54/200, Train Loss: 16.9303, Val Loss: 15.6856\n",
      "  New best validation loss: 15.6856\n",
      "Epoch 55/200, Train Loss: 16.9287, Val Loss: 15.6731\n",
      "  New best validation loss: 15.6731\n",
      "Epoch 56/200, Train Loss: 16.9237, Val Loss: 15.6740\n",
      "Epoch 57/200, Train Loss: 16.9169, Val Loss: 15.6825\n",
      "Epoch 58/200, Train Loss: 16.9113, Val Loss: 15.6666\n",
      "  New best validation loss: 15.6666\n",
      "Epoch 59/200, Train Loss: 16.9060, Val Loss: 15.6716\n",
      "Epoch 60/200, Train Loss: 16.9020, Val Loss: 15.6769\n",
      "Epoch 61/200, Train Loss: 16.8962, Val Loss: 15.6544\n",
      "  New best validation loss: 15.6544\n",
      "Epoch 62/200, Train Loss: 16.8877, Val Loss: 15.6360\n",
      "  New best validation loss: 15.6360\n",
      "Epoch 63/200, Train Loss: 16.8809, Val Loss: 15.6427\n",
      "Epoch 64/200, Train Loss: 16.8743, Val Loss: 15.6362\n",
      "Epoch 65/200, Train Loss: 16.8650, Val Loss: 15.6321\n",
      "  New best validation loss: 15.6321\n",
      "Epoch 66/200, Train Loss: 16.8596, Val Loss: 15.6411\n",
      "Epoch 67/200, Train Loss: 16.8482, Val Loss: 15.6050\n",
      "  New best validation loss: 15.6050\n",
      "Epoch 68/200, Train Loss: 16.8447, Val Loss: 15.5924\n",
      "  New best validation loss: 15.5924\n",
      "Epoch 69/200, Train Loss: 16.8335, Val Loss: 15.6239\n",
      "Epoch 70/200, Train Loss: 16.8436, Val Loss: 15.6446\n",
      "Epoch 71/200, Train Loss: 16.8194, Val Loss: 15.5688\n",
      "  New best validation loss: 15.5688\n",
      "Epoch 72/200, Train Loss: 16.8179, Val Loss: 15.6155\n",
      "Epoch 73/200, Train Loss: 16.8194, Val Loss: 15.5935\n",
      "Epoch 74/200, Train Loss: 16.8219, Val Loss: 15.6496\n",
      "Epoch 75/200, Train Loss: 16.8013, Val Loss: 15.5737\n",
      "Epoch 76/200, Train Loss: 16.7911, Val Loss: 15.5863\n",
      "Epoch 77/200, Train Loss: 16.7835, Val Loss: 15.5937\n",
      "Epoch 78/200, Train Loss: 16.7748, Val Loss: 15.5852\n",
      "Epoch 79/200, Train Loss: 16.7693, Val Loss: 15.5626\n",
      "  New best validation loss: 15.5626\n",
      "Epoch 80/200, Train Loss: 16.7533, Val Loss: 15.5845\n",
      "Epoch 81/200, Train Loss: 16.7422, Val Loss: 15.5842\n",
      "Epoch 82/200, Train Loss: 16.7414, Val Loss: 15.5518\n",
      "  New best validation loss: 15.5518\n",
      "Epoch 83/200, Train Loss: 16.7263, Val Loss: 15.5529\n",
      "Epoch 84/200, Train Loss: 16.7124, Val Loss: 15.5569\n",
      "Epoch 85/200, Train Loss: 16.7152, Val Loss: 15.6369\n",
      "Epoch 86/200, Train Loss: 16.7070, Val Loss: 15.5485\n",
      "  New best validation loss: 15.5485\n",
      "Epoch 87/200, Train Loss: 16.6858, Val Loss: 15.6137\n",
      "Epoch 88/200, Train Loss: 16.7023, Val Loss: 15.5768\n",
      "Epoch 89/200, Train Loss: 16.6831, Val Loss: 15.6060\n",
      "Epoch 90/200, Train Loss: 16.6652, Val Loss: 15.5672\n",
      "Epoch 91/200, Train Loss: 16.6561, Val Loss: 15.5935\n",
      "Epoch 92/200, Train Loss: 16.6824, Val Loss: 15.5513\n",
      "Epoch 93/200, Train Loss: 16.6566, Val Loss: 15.5858\n",
      "Epoch 94/200, Train Loss: 16.6390, Val Loss: 15.5626\n",
      "Epoch 95/200, Train Loss: 16.6274, Val Loss: 15.5667\n",
      "Epoch 96/200, Train Loss: 16.6010, Val Loss: 15.5729\n",
      "Epoch 97/200, Train Loss: 16.5840, Val Loss: 15.5971\n",
      "Epoch 98/200, Train Loss: 16.5708, Val Loss: 15.5428\n",
      "  New best validation loss: 15.5428\n",
      "Epoch 99/200, Train Loss: 16.5386, Val Loss: 15.5999\n",
      "Epoch 100/200, Train Loss: 16.5195, Val Loss: 15.5649\n",
      "Epoch 101/200, Train Loss: 16.5084, Val Loss: 15.5535\n",
      "Epoch 102/200, Train Loss: 16.5043, Val Loss: 15.5698\n",
      "Epoch 103/200, Train Loss: 16.4617, Val Loss: 15.5897\n",
      "Epoch 104/200, Train Loss: 16.4858, Val Loss: 15.6295\n",
      "Epoch 105/200, Train Loss: 16.4375, Val Loss: 15.5497\n",
      "Epoch 106/200, Train Loss: 16.4317, Val Loss: 15.6081\n",
      "Epoch 107/200, Train Loss: 16.3906, Val Loss: 15.5488\n",
      "Epoch 108/200, Train Loss: 16.3779, Val Loss: 15.5692\n",
      "Epoch 109/200, Train Loss: 16.3632, Val Loss: 15.5989\n",
      "Epoch 110/200, Train Loss: 16.3297, Val Loss: 15.5585\n",
      "Epoch 111/200, Train Loss: 16.3557, Val Loss: 15.7017\n",
      "Epoch 112/200, Train Loss: 16.3731, Val Loss: 15.5243\n",
      "  New best validation loss: 15.5243\n",
      "Epoch 113/200, Train Loss: 16.4082, Val Loss: 15.5871\n",
      "Epoch 114/200, Train Loss: 16.4279, Val Loss: 15.5589\n",
      "Epoch 115/200, Train Loss: 16.2811, Val Loss: 15.5794\n",
      "Epoch 116/200, Train Loss: 16.2992, Val Loss: 15.5606\n",
      "Epoch 117/200, Train Loss: 16.2501, Val Loss: 15.5874\n",
      "Epoch 118/200, Train Loss: 16.2412, Val Loss: 15.5540\n",
      "Epoch 119/200, Train Loss: 16.2526, Val Loss: 15.6682\n",
      "Epoch 120/200, Train Loss: 16.2165, Val Loss: 15.6005\n",
      "Epoch 121/200, Train Loss: 16.2256, Val Loss: 15.5986\n",
      "Epoch 122/200, Train Loss: 16.2039, Val Loss: 15.6052\n",
      "Epoch 123/200, Train Loss: 16.1963, Val Loss: 15.6444\n",
      "Epoch 124/200, Train Loss: 16.1977, Val Loss: 15.6391\n",
      "Epoch 125/200, Train Loss: 16.2065, Val Loss: 15.5980\n",
      "Epoch 126/200, Train Loss: 16.1719, Val Loss: 15.5921\n",
      "Epoch 127/200, Train Loss: 16.1745, Val Loss: 15.6592\n",
      "Epoch 128/200, Train Loss: 16.1639, Val Loss: 15.6399\n",
      "Epoch 129/200, Train Loss: 16.1751, Val Loss: 15.5794\n",
      "Epoch 130/200, Train Loss: 16.1419, Val Loss: 15.6150\n",
      "Epoch 131/200, Train Loss: 16.1219, Val Loss: 15.6406\n",
      "Epoch 132/200, Train Loss: 16.1307, Val Loss: 15.5712\n",
      "Epoch 133/200, Train Loss: 16.2025, Val Loss: 15.6693\n",
      "Epoch 134/200, Train Loss: 16.1975, Val Loss: 15.5683\n",
      "Epoch 135/200, Train Loss: 16.1081, Val Loss: 15.5582\n",
      "Epoch 136/200, Train Loss: 16.1043, Val Loss: 15.6192\n",
      "Epoch 137/200, Train Loss: 16.0834, Val Loss: 15.5446\n",
      "Epoch 138/200, Train Loss: 16.1116, Val Loss: 15.5695\n",
      "Epoch 139/200, Train Loss: 16.0799, Val Loss: 15.6307\n",
      "Epoch 140/200, Train Loss: 16.0818, Val Loss: 15.6201\n",
      "Epoch 141/200, Train Loss: 16.0807, Val Loss: 15.6517\n",
      "Epoch 142/200, Train Loss: 16.0950, Val Loss: 15.5315\n",
      "Epoch 143/200, Train Loss: 16.0763, Val Loss: 15.5130\n",
      "  New best validation loss: 15.5130\n",
      "Epoch 144/200, Train Loss: 16.1583, Val Loss: 15.4900\n",
      "  New best validation loss: 15.4900\n",
      "Epoch 145/200, Train Loss: 16.0600, Val Loss: 15.5937\n",
      "Epoch 146/200, Train Loss: 16.0545, Val Loss: 15.4981\n",
      "Epoch 147/200, Train Loss: 16.0018, Val Loss: 15.5146\n",
      "Epoch 148/200, Train Loss: 16.0163, Val Loss: 15.5104\n",
      "Epoch 149/200, Train Loss: 16.0004, Val Loss: 15.5286\n",
      "Epoch 150/200, Train Loss: 16.0125, Val Loss: 15.5400\n",
      "Epoch 151/200, Train Loss: 15.9845, Val Loss: 15.4764\n",
      "  New best validation loss: 15.4764\n",
      "Epoch 152/200, Train Loss: 15.9453, Val Loss: 15.5336\n",
      "Epoch 153/200, Train Loss: 15.9684, Val Loss: 15.5123\n",
      "Epoch 154/200, Train Loss: 16.0120, Val Loss: 15.5262\n",
      "Epoch 155/200, Train Loss: 15.9668, Val Loss: 15.5321\n",
      "Epoch 156/200, Train Loss: 15.9636, Val Loss: 15.4804\n",
      "Epoch 157/200, Train Loss: 15.9459, Val Loss: 15.4051\n",
      "  New best validation loss: 15.4051\n",
      "Epoch 158/200, Train Loss: 15.9280, Val Loss: 15.5458\n",
      "Epoch 159/200, Train Loss: 15.9090, Val Loss: 15.4489\n",
      "Epoch 160/200, Train Loss: 15.8853, Val Loss: 15.6563\n",
      "Epoch 161/200, Train Loss: 15.9260, Val Loss: 15.4038\n",
      "  New best validation loss: 15.4038\n",
      "Epoch 162/200, Train Loss: 15.9063, Val Loss: 15.3913\n",
      "  New best validation loss: 15.3913\n",
      "Epoch 163/200, Train Loss: 15.8919, Val Loss: 15.4594\n",
      "Epoch 164/200, Train Loss: 15.8992, Val Loss: 15.4645\n",
      "Epoch 165/200, Train Loss: 15.9178, Val Loss: 15.4220\n",
      "Epoch 166/200, Train Loss: 15.8491, Val Loss: 15.3041\n",
      "  New best validation loss: 15.3041\n",
      "Epoch 167/200, Train Loss: 15.8608, Val Loss: 15.4321\n",
      "Epoch 168/200, Train Loss: 15.8034, Val Loss: 15.3946\n",
      "Epoch 169/200, Train Loss: 15.7962, Val Loss: 15.3699\n",
      "Epoch 170/200, Train Loss: 15.7885, Val Loss: 15.4913\n",
      "Epoch 171/200, Train Loss: 15.8795, Val Loss: 15.3864\n",
      "Epoch 172/200, Train Loss: 15.7789, Val Loss: 15.2399\n",
      "  New best validation loss: 15.2399\n",
      "Epoch 173/200, Train Loss: 15.7653, Val Loss: 15.3404\n",
      "Epoch 174/200, Train Loss: 15.7642, Val Loss: 15.3660\n",
      "Epoch 175/200, Train Loss: 15.7240, Val Loss: 15.3087\n",
      "Epoch 176/200, Train Loss: 15.7445, Val Loss: 15.3056\n",
      "Epoch 177/200, Train Loss: 15.7691, Val Loss: 15.2370\n",
      "  New best validation loss: 15.2370\n",
      "Epoch 178/200, Train Loss: 15.7740, Val Loss: 15.2739\n",
      "Epoch 179/200, Train Loss: 15.7000, Val Loss: 15.3087\n",
      "Epoch 180/200, Train Loss: 15.6644, Val Loss: 15.2276\n",
      "  New best validation loss: 15.2276\n",
      "Epoch 181/200, Train Loss: 15.6723, Val Loss: 15.2864\n",
      "Epoch 182/200, Train Loss: 15.6707, Val Loss: 15.1919\n",
      "  New best validation loss: 15.1919\n",
      "Epoch 183/200, Train Loss: 15.6097, Val Loss: 15.1890\n",
      "  New best validation loss: 15.1890\n",
      "Epoch 184/200, Train Loss: 15.6122, Val Loss: 15.2400\n",
      "Epoch 185/200, Train Loss: 15.7147, Val Loss: 15.1372\n",
      "  New best validation loss: 15.1372\n",
      "Epoch 186/200, Train Loss: 15.6725, Val Loss: 15.1172\n",
      "  New best validation loss: 15.1172\n",
      "Epoch 187/200, Train Loss: 15.6221, Val Loss: 15.0160\n",
      "  New best validation loss: 15.0160\n",
      "Epoch 188/200, Train Loss: 15.6607, Val Loss: 15.1021\n",
      "Epoch 189/200, Train Loss: 15.6159, Val Loss: 15.2009\n",
      "Epoch 190/200, Train Loss: 15.6345, Val Loss: 15.0479\n",
      "Epoch 191/200, Train Loss: 15.5633, Val Loss: 15.0702\n",
      "Epoch 192/200, Train Loss: 15.5400, Val Loss: 14.9932\n",
      "  New best validation loss: 14.9932\n",
      "Epoch 193/200, Train Loss: 15.5450, Val Loss: 14.9923\n",
      "  New best validation loss: 14.9923\n",
      "Epoch 194/200, Train Loss: 15.4650, Val Loss: 15.0329\n",
      "Epoch 195/200, Train Loss: 15.4630, Val Loss: 14.9368\n",
      "  New best validation loss: 14.9368\n",
      "Epoch 196/200, Train Loss: 15.4575, Val Loss: 14.9494\n",
      "Epoch 197/200, Train Loss: 15.4605, Val Loss: 14.8989\n",
      "  New best validation loss: 14.8989\n",
      "Epoch 198/200, Train Loss: 15.4198, Val Loss: 15.1222\n",
      "Epoch 199/200, Train Loss: 15.4420, Val Loss: 14.9066\n",
      "Epoch 200/200, Train Loss: 15.4220, Val Loss: 14.9112\n",
      "\n",
      "Loaded best model (Val Loss: 14.8989) for final hidden state extraction.\n",
      "Saved best model for RNN_GRU (samples=320) to results_data_size_sweep/20250514_045146/samples_320/RNN_GRU_samples_320_best.pt\n",
      "\n",
      "--- Performing Decodability Analysis for RNN_GRU (samples=320, k=15) ---\n",
      "  Analyzing decodability for RNN_GRU...\n",
      "  Hidden states shape: torch.Size([160, 200, 64])\n",
      "  Coefficients shape: torch.Size([160, 15])\n",
      "  Processed hidden states shape for decoder: torch.Size([160, 64])\n",
      "  RidgeCV Decoder for RNN_GRU - Test MSE: 1.5736, Test R2: 0.2023 (best alpha: 2.6367)\n",
      "  Decodability plot saved to results_data_size_sweep/20250514_045146/samples_320/decodability_RNN_GRU_coeff1.png\n",
      "Decodability (R2 score) for RNN_GRU (samples=320): 0.2023\n",
      "\n",
      "--- Training Transformer (samples=320, k=15) ---\n",
      "Number of parameters: 85809\n",
      "Epoch 1/200, Train Loss: 18.5351, Val Loss: 15.9602\n",
      "  New best validation loss: 15.9602\n",
      "Epoch 2/200, Train Loss: 17.3238, Val Loss: 15.9295\n",
      "  New best validation loss: 15.9295\n",
      "Epoch 3/200, Train Loss: 17.2533, Val Loss: 16.0087\n",
      "Epoch 4/200, Train Loss: 17.1779, Val Loss: 15.9116\n",
      "  New best validation loss: 15.9116\n",
      "Epoch 5/200, Train Loss: 17.1800, Val Loss: 15.9587\n",
      "Epoch 6/200, Train Loss: 17.1765, Val Loss: 15.9281\n",
      "Epoch 7/200, Train Loss: 17.1618, Val Loss: 15.9350\n",
      "Epoch 8/200, Train Loss: 17.1480, Val Loss: 15.9106\n",
      "  New best validation loss: 15.9106\n",
      "Epoch 9/200, Train Loss: 17.1697, Val Loss: 15.8894\n",
      "  New best validation loss: 15.8894\n",
      "Epoch 10/200, Train Loss: 17.1398, Val Loss: 15.8878\n",
      "  New best validation loss: 15.8878\n",
      "Epoch 11/200, Train Loss: 17.1703, Val Loss: 15.8662\n",
      "  New best validation loss: 15.8662\n",
      "Epoch 12/200, Train Loss: 17.1434, Val Loss: 15.8965\n",
      "Epoch 13/200, Train Loss: 17.1471, Val Loss: 15.8538\n",
      "  New best validation loss: 15.8538\n",
      "Epoch 14/200, Train Loss: 17.1584, Val Loss: 15.9363\n",
      "Epoch 15/200, Train Loss: 17.1898, Val Loss: 15.9799\n",
      "Epoch 16/200, Train Loss: 17.1396, Val Loss: 15.9020\n",
      "Epoch 17/200, Train Loss: 17.1313, Val Loss: 15.9147\n",
      "Epoch 18/200, Train Loss: 17.1357, Val Loss: 15.8758\n",
      "Epoch 19/200, Train Loss: 17.1232, Val Loss: 15.8414\n",
      "  New best validation loss: 15.8414\n",
      "Epoch 20/200, Train Loss: 17.1242, Val Loss: 15.8634\n",
      "Epoch 21/200, Train Loss: 17.1374, Val Loss: 15.8902\n",
      "Epoch 22/200, Train Loss: 17.1362, Val Loss: 15.8308\n",
      "  New best validation loss: 15.8308\n",
      "Epoch 23/200, Train Loss: 17.1330, Val Loss: 15.8870\n",
      "Epoch 24/200, Train Loss: 17.1232, Val Loss: 15.8454\n",
      "Epoch 25/200, Train Loss: 17.1115, Val Loss: 15.8295\n",
      "  New best validation loss: 15.8295\n",
      "Epoch 26/200, Train Loss: 17.1145, Val Loss: 15.8792\n",
      "Epoch 27/200, Train Loss: 17.0851, Val Loss: 15.8379\n",
      "Epoch 28/200, Train Loss: 17.1110, Val Loss: 15.8632\n",
      "Epoch 29/200, Train Loss: 17.1193, Val Loss: 15.9079\n",
      "Epoch 30/200, Train Loss: 17.0961, Val Loss: 15.8207\n",
      "  New best validation loss: 15.8207\n",
      "Epoch 31/200, Train Loss: 17.0962, Val Loss: 15.9055\n",
      "Epoch 32/200, Train Loss: 17.0946, Val Loss: 15.8758\n",
      "Epoch 33/200, Train Loss: 17.0880, Val Loss: 15.8597\n",
      "Epoch 34/200, Train Loss: 17.0974, Val Loss: 15.8379\n",
      "Epoch 35/200, Train Loss: 17.1152, Val Loss: 15.8010\n",
      "  New best validation loss: 15.8010\n",
      "Epoch 36/200, Train Loss: 17.1125, Val Loss: 15.8328\n",
      "Epoch 37/200, Train Loss: 17.1127, Val Loss: 15.9498\n",
      "Epoch 38/200, Train Loss: 17.1400, Val Loss: 15.7284\n",
      "  New best validation loss: 15.7284\n",
      "Epoch 39/200, Train Loss: 17.1702, Val Loss: 16.0827\n",
      "Epoch 40/200, Train Loss: 17.1352, Val Loss: 15.7782\n",
      "Epoch 41/200, Train Loss: 17.0653, Val Loss: 15.8883\n",
      "Epoch 42/200, Train Loss: 17.0893, Val Loss: 15.8751\n",
      "Epoch 43/200, Train Loss: 17.0983, Val Loss: 15.8007\n",
      "Epoch 44/200, Train Loss: 17.1002, Val Loss: 15.8145\n",
      "Epoch 45/200, Train Loss: 17.0863, Val Loss: 15.8274\n",
      "Epoch 46/200, Train Loss: 17.0748, Val Loss: 15.7839\n",
      "Epoch 47/200, Train Loss: 17.1058, Val Loss: 15.9118\n",
      "Epoch 48/200, Train Loss: 17.0608, Val Loss: 15.8787\n",
      "Epoch 49/200, Train Loss: 17.0856, Val Loss: 15.7519\n",
      "Epoch 50/200, Train Loss: 17.0861, Val Loss: 15.8327\n",
      "Epoch 51/200, Train Loss: 17.0764, Val Loss: 15.9012\n",
      "Epoch 52/200, Train Loss: 17.0950, Val Loss: 15.7971\n",
      "Epoch 53/200, Train Loss: 17.0731, Val Loss: 15.7797\n",
      "Epoch 54/200, Train Loss: 17.0504, Val Loss: 15.7975\n",
      "Epoch 55/200, Train Loss: 17.0697, Val Loss: 15.8031\n",
      "Epoch 56/200, Train Loss: 17.0724, Val Loss: 15.8380\n",
      "Epoch 57/200, Train Loss: 17.0466, Val Loss: 15.8284\n",
      "Epoch 58/200, Train Loss: 17.0532, Val Loss: 15.8215\n",
      "Epoch 59/200, Train Loss: 17.0355, Val Loss: 15.7946\n",
      "Epoch 60/200, Train Loss: 17.0514, Val Loss: 15.7526\n",
      "Epoch 61/200, Train Loss: 17.0511, Val Loss: 15.8388\n",
      "Epoch 62/200, Train Loss: 17.0510, Val Loss: 15.7626\n",
      "Epoch 63/200, Train Loss: 17.0520, Val Loss: 15.7817\n",
      "Epoch 64/200, Train Loss: 17.0681, Val Loss: 15.8671\n",
      "Epoch 65/200, Train Loss: 17.0489, Val Loss: 15.7394\n",
      "Epoch 66/200, Train Loss: 17.0735, Val Loss: 15.9051\n",
      "Epoch 67/200, Train Loss: 17.0326, Val Loss: 15.7263\n",
      "  New best validation loss: 15.7263\n",
      "Epoch 68/200, Train Loss: 17.0048, Val Loss: 15.8206\n",
      "Epoch 69/200, Train Loss: 17.0071, Val Loss: 15.7352\n",
      "Epoch 70/200, Train Loss: 16.9978, Val Loss: 15.8025\n",
      "Epoch 71/200, Train Loss: 16.9859, Val Loss: 15.7535\n",
      "Epoch 72/200, Train Loss: 17.0109, Val Loss: 15.7878\n",
      "Epoch 73/200, Train Loss: 17.0082, Val Loss: 15.7094\n",
      "  New best validation loss: 15.7094\n",
      "Epoch 74/200, Train Loss: 16.9838, Val Loss: 15.8299\n",
      "Epoch 75/200, Train Loss: 16.9758, Val Loss: 15.6808\n",
      "  New best validation loss: 15.6808\n",
      "Epoch 76/200, Train Loss: 16.9817, Val Loss: 15.8927\n",
      "Epoch 77/200, Train Loss: 17.0420, Val Loss: 15.6268\n",
      "  New best validation loss: 15.6268\n",
      "Epoch 78/200, Train Loss: 16.9952, Val Loss: 15.7729\n",
      "Epoch 79/200, Train Loss: 16.9920, Val Loss: 15.7117\n",
      "Epoch 80/200, Train Loss: 16.9854, Val Loss: 15.7012\n",
      "Epoch 81/200, Train Loss: 16.9598, Val Loss: 15.7745\n",
      "Epoch 82/200, Train Loss: 16.9611, Val Loss: 15.7199\n",
      "Epoch 83/200, Train Loss: 16.9725, Val Loss: 15.8356\n",
      "Epoch 84/200, Train Loss: 16.9336, Val Loss: 15.6861\n",
      "Epoch 85/200, Train Loss: 16.9716, Val Loss: 15.6774\n",
      "Epoch 86/200, Train Loss: 16.9514, Val Loss: 15.7097\n",
      "Epoch 87/200, Train Loss: 16.9497, Val Loss: 15.7143\n",
      "Epoch 88/200, Train Loss: 16.9337, Val Loss: 15.7769\n",
      "Epoch 89/200, Train Loss: 16.9432, Val Loss: 15.6488\n",
      "Epoch 90/200, Train Loss: 16.9626, Val Loss: 15.8463\n",
      "Epoch 91/200, Train Loss: 16.9391, Val Loss: 15.8064\n",
      "Epoch 92/200, Train Loss: 16.9775, Val Loss: 15.6356\n",
      "Epoch 93/200, Train Loss: 16.9169, Val Loss: 15.8734\n",
      "Epoch 94/200, Train Loss: 16.8859, Val Loss: 15.6687\n",
      "Epoch 95/200, Train Loss: 16.8770, Val Loss: 15.5671\n",
      "  New best validation loss: 15.5671\n",
      "Epoch 96/200, Train Loss: 16.9133, Val Loss: 15.7721\n",
      "Epoch 97/200, Train Loss: 16.8786, Val Loss: 15.7182\n",
      "Epoch 98/200, Train Loss: 16.8624, Val Loss: 15.6161\n",
      "Epoch 99/200, Train Loss: 16.8702, Val Loss: 15.9976\n",
      "Epoch 100/200, Train Loss: 16.9148, Val Loss: 15.6538\n",
      "Epoch 101/200, Train Loss: 16.8452, Val Loss: 15.6151\n",
      "Epoch 102/200, Train Loss: 16.8321, Val Loss: 15.6848\n",
      "Epoch 103/200, Train Loss: 16.8416, Val Loss: 15.6968\n",
      "Epoch 104/200, Train Loss: 16.8467, Val Loss: 15.7208\n",
      "Epoch 105/200, Train Loss: 16.7842, Val Loss: 15.5804\n",
      "Epoch 106/200, Train Loss: 16.8010, Val Loss: 15.5277\n",
      "  New best validation loss: 15.5277\n",
      "Epoch 107/200, Train Loss: 16.7927, Val Loss: 15.6157\n",
      "Epoch 108/200, Train Loss: 16.8423, Val Loss: 15.6529\n",
      "Epoch 109/200, Train Loss: 16.8679, Val Loss: 15.7961\n",
      "Epoch 110/200, Train Loss: 16.8293, Val Loss: 15.4860\n",
      "  New best validation loss: 15.4860\n",
      "Epoch 111/200, Train Loss: 16.7896, Val Loss: 15.7065\n",
      "Epoch 112/200, Train Loss: 16.8456, Val Loss: 15.7402\n",
      "Epoch 113/200, Train Loss: 16.7998, Val Loss: 15.5122\n",
      "Epoch 114/200, Train Loss: 16.7449, Val Loss: 15.5713\n",
      "Epoch 115/200, Train Loss: 16.7143, Val Loss: 15.4221\n",
      "  New best validation loss: 15.4221\n",
      "Epoch 116/200, Train Loss: 16.7124, Val Loss: 15.6316\n",
      "Epoch 117/200, Train Loss: 16.7284, Val Loss: 15.5427\n",
      "Epoch 118/200, Train Loss: 16.6978, Val Loss: 15.4569\n",
      "Epoch 119/200, Train Loss: 16.7027, Val Loss: 15.6891\n",
      "Epoch 120/200, Train Loss: 16.6950, Val Loss: 15.7558\n",
      "Epoch 121/200, Train Loss: 16.6908, Val Loss: 15.5356\n",
      "Epoch 122/200, Train Loss: 16.6885, Val Loss: 15.4993\n",
      "Epoch 123/200, Train Loss: 16.6467, Val Loss: 15.5589\n",
      "Epoch 124/200, Train Loss: 16.6555, Val Loss: 15.3895\n",
      "  New best validation loss: 15.3895\n",
      "Epoch 125/200, Train Loss: 16.6280, Val Loss: 15.3330\n",
      "  New best validation loss: 15.3330\n",
      "Epoch 126/200, Train Loss: 16.6192, Val Loss: 15.3904\n",
      "Epoch 127/200, Train Loss: 16.6202, Val Loss: 15.4609\n",
      "Epoch 128/200, Train Loss: 16.5644, Val Loss: 15.4128\n",
      "Epoch 129/200, Train Loss: 16.5030, Val Loss: 15.2314\n",
      "  New best validation loss: 15.2314\n",
      "Epoch 130/200, Train Loss: 16.6169, Val Loss: 15.2776\n",
      "Epoch 131/200, Train Loss: 16.5538, Val Loss: 15.3404\n",
      "Epoch 132/200, Train Loss: 16.5191, Val Loss: 15.1313\n",
      "  New best validation loss: 15.1313\n",
      "Epoch 133/200, Train Loss: 16.4151, Val Loss: 15.7583\n",
      "Epoch 134/200, Train Loss: 16.4788, Val Loss: 15.1725\n",
      "Epoch 135/200, Train Loss: 16.5257, Val Loss: 15.0965\n",
      "  New best validation loss: 15.0965\n",
      "Epoch 136/200, Train Loss: 16.4125, Val Loss: 15.3254\n",
      "Epoch 137/200, Train Loss: 16.3672, Val Loss: 15.3218\n",
      "Epoch 138/200, Train Loss: 16.3781, Val Loss: 15.0156\n",
      "  New best validation loss: 15.0156\n",
      "Epoch 139/200, Train Loss: 16.4439, Val Loss: 14.9265\n",
      "  New best validation loss: 14.9265\n",
      "Epoch 140/200, Train Loss: 16.3575, Val Loss: 15.2439\n",
      "Epoch 141/200, Train Loss: 16.3569, Val Loss: 15.3393\n",
      "Epoch 142/200, Train Loss: 16.3393, Val Loss: 15.2157\n",
      "Epoch 143/200, Train Loss: 16.2458, Val Loss: 14.8870\n",
      "  New best validation loss: 14.8870\n",
      "Epoch 144/200, Train Loss: 16.2632, Val Loss: 14.9835\n",
      "Epoch 145/200, Train Loss: 16.3152, Val Loss: 14.9475\n",
      "Epoch 146/200, Train Loss: 16.2949, Val Loss: 15.2448\n",
      "Epoch 147/200, Train Loss: 16.2886, Val Loss: 15.2025\n",
      "Epoch 148/200, Train Loss: 16.2441, Val Loss: 14.7676\n",
      "  New best validation loss: 14.7676\n",
      "Epoch 149/200, Train Loss: 16.2056, Val Loss: 15.1978\n",
      "Epoch 150/200, Train Loss: 16.1252, Val Loss: 14.8800\n",
      "Epoch 151/200, Train Loss: 16.0780, Val Loss: 14.7976\n",
      "Epoch 152/200, Train Loss: 15.9791, Val Loss: 14.6642\n",
      "  New best validation loss: 14.6642\n",
      "Epoch 153/200, Train Loss: 16.0192, Val Loss: 15.1245\n",
      "Epoch 154/200, Train Loss: 16.0035, Val Loss: 14.8246\n",
      "Epoch 155/200, Train Loss: 15.9554, Val Loss: 14.6750\n",
      "Epoch 156/200, Train Loss: 15.9242, Val Loss: 14.5730\n",
      "  New best validation loss: 14.5730\n",
      "Epoch 157/200, Train Loss: 15.8366, Val Loss: 14.5733\n",
      "Epoch 158/200, Train Loss: 15.7853, Val Loss: 14.5007\n",
      "  New best validation loss: 14.5007\n",
      "Epoch 159/200, Train Loss: 15.8811, Val Loss: 14.4843\n",
      "  New best validation loss: 14.4843\n",
      "Epoch 160/200, Train Loss: 15.8774, Val Loss: 14.3728\n",
      "  New best validation loss: 14.3728\n",
      "Epoch 161/200, Train Loss: 15.8077, Val Loss: 14.3847\n",
      "Epoch 162/200, Train Loss: 15.6600, Val Loss: 14.2097\n",
      "  New best validation loss: 14.2097\n",
      "Epoch 163/200, Train Loss: 15.6359, Val Loss: 14.6446\n",
      "Epoch 164/200, Train Loss: 15.6910, Val Loss: 14.5366\n",
      "Epoch 165/200, Train Loss: 15.5577, Val Loss: 14.4669\n",
      "Epoch 166/200, Train Loss: 15.5876, Val Loss: 14.4051\n",
      "Epoch 167/200, Train Loss: 15.5692, Val Loss: 13.9852\n",
      "  New best validation loss: 13.9852\n",
      "Epoch 168/200, Train Loss: 15.5748, Val Loss: 13.9431\n",
      "  New best validation loss: 13.9431\n",
      "Epoch 169/200, Train Loss: 15.4113, Val Loss: 14.0462\n",
      "Epoch 170/200, Train Loss: 15.4142, Val Loss: 13.9288\n",
      "  New best validation loss: 13.9288\n",
      "Epoch 171/200, Train Loss: 15.2743, Val Loss: 13.8792\n",
      "  New best validation loss: 13.8792\n",
      "Epoch 172/200, Train Loss: 15.2294, Val Loss: 13.9338\n",
      "Epoch 173/200, Train Loss: 15.2473, Val Loss: 13.9508\n",
      "Epoch 174/200, Train Loss: 15.2923, Val Loss: 13.8675\n",
      "  New best validation loss: 13.8675\n",
      "Epoch 175/200, Train Loss: 15.2058, Val Loss: 13.8689\n",
      "Epoch 176/200, Train Loss: 15.2031, Val Loss: 13.7107\n",
      "  New best validation loss: 13.7107\n",
      "Epoch 177/200, Train Loss: 15.0707, Val Loss: 13.6150\n",
      "  New best validation loss: 13.6150\n",
      "Epoch 178/200, Train Loss: 15.0314, Val Loss: 13.7480\n",
      "Epoch 179/200, Train Loss: 15.1015, Val Loss: 13.7713\n",
      "Epoch 180/200, Train Loss: 15.0761, Val Loss: 13.6950\n",
      "Epoch 181/200, Train Loss: 14.9447, Val Loss: 13.4124\n",
      "  New best validation loss: 13.4124\n",
      "Epoch 182/200, Train Loss: 15.0164, Val Loss: 13.5005\n",
      "Epoch 183/200, Train Loss: 15.1117, Val Loss: 13.4831\n",
      "Epoch 184/200, Train Loss: 14.7317, Val Loss: 13.4089\n",
      "  New best validation loss: 13.4089\n",
      "Epoch 185/200, Train Loss: 14.8313, Val Loss: 13.5205\n",
      "Epoch 186/200, Train Loss: 14.7364, Val Loss: 13.2779\n",
      "  New best validation loss: 13.2779\n",
      "Epoch 187/200, Train Loss: 14.6785, Val Loss: 13.3727\n",
      "Epoch 188/200, Train Loss: 14.7528, Val Loss: 13.2386\n",
      "  New best validation loss: 13.2386\n",
      "Epoch 189/200, Train Loss: 14.7978, Val Loss: 13.4951\n",
      "Epoch 190/200, Train Loss: 14.6493, Val Loss: 13.2472\n",
      "Epoch 191/200, Train Loss: 14.5350, Val Loss: 13.0899\n",
      "  New best validation loss: 13.0899\n",
      "Epoch 192/200, Train Loss: 14.5244, Val Loss: 13.1721\n",
      "Epoch 193/200, Train Loss: 14.5490, Val Loss: 13.3333\n",
      "Epoch 194/200, Train Loss: 14.5191, Val Loss: 13.0288\n",
      "  New best validation loss: 13.0288\n",
      "Epoch 195/200, Train Loss: 14.4331, Val Loss: 12.8966\n",
      "  New best validation loss: 12.8966\n",
      "Epoch 196/200, Train Loss: 14.3074, Val Loss: 12.9109\n",
      "Epoch 197/200, Train Loss: 14.3111, Val Loss: 12.9276\n",
      "Epoch 198/200, Train Loss: 14.3244, Val Loss: 13.0883\n",
      "Epoch 199/200, Train Loss: 14.3116, Val Loss: 12.7961\n",
      "  New best validation loss: 12.7961\n",
      "Epoch 200/200, Train Loss: 14.2290, Val Loss: 13.1898\n",
      "\n",
      "Loaded best model (Val Loss: 12.7961) for final hidden state extraction.\n",
      "Saved best model for Transformer (samples=320) to results_data_size_sweep/20250514_045146/samples_320/Transformer_samples_320_best.pt\n",
      "\n",
      "--- Performing Decodability Analysis for Transformer (samples=320, k=15) ---\n",
      "  Analyzing decodability for Transformer...\n",
      "  Hidden states shape: torch.Size([160, 200, 20])\n",
      "  Coefficients shape: torch.Size([160, 15])\n",
      "  Processed hidden states shape for decoder: torch.Size([160, 20])\n",
      "  RidgeCV Decoder for Transformer - Test MSE: 1.5602, Test R2: 0.2175 (best alpha: 1.2743)\n",
      "  Decodability plot saved to results_data_size_sweep/20250514_045146/samples_320/decodability_Transformer_coeff1.png\n",
      "Decodability (R2 score) for Transformer (samples=320): 0.2175\n",
      "\n",
      "--- Training TransformerCausal (samples=320, k=15) ---\n",
      "Number of parameters: 85809\n",
      "Epoch 1/200, Train Loss: 18.9936, Val Loss: 16.3294\n",
      "  New best validation loss: 16.3294\n",
      "Epoch 2/200, Train Loss: 17.3658, Val Loss: 15.8123\n",
      "  New best validation loss: 15.8123\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/conda/lib/python3.10/site-packages/torch/nn/modules/activation.py:1160: UserWarning: Converting mask without torch.bool dtype to bool; this will negatively affect performance. Prefer to use a boolean mask directly. (Triggered internally at /opt/conda/conda-bld/pytorch_1682343995026/work/aten/src/ATen/native/transformers/attention.cpp:150.)\n",
      "  return torch._native_multi_head_attention(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3/200, Train Loss: 17.1854, Val Loss: 16.0153\n",
      "Epoch 4/200, Train Loss: 17.1712, Val Loss: 15.9824\n",
      "Epoch 5/200, Train Loss: 17.1288, Val Loss: 15.8665\n",
      "Epoch 6/200, Train Loss: 17.1227, Val Loss: 15.9278\n",
      "Epoch 7/200, Train Loss: 17.0894, Val Loss: 15.9212\n",
      "Epoch 8/200, Train Loss: 17.0838, Val Loss: 15.8930\n",
      "Epoch 9/200, Train Loss: 17.0911, Val Loss: 15.8808\n",
      "Epoch 10/200, Train Loss: 17.0642, Val Loss: 15.8972\n",
      "Epoch 11/200, Train Loss: 17.0718, Val Loss: 15.8922\n",
      "Epoch 12/200, Train Loss: 17.0762, Val Loss: 15.8656\n",
      "Epoch 13/200, Train Loss: 17.0493, Val Loss: 15.8641\n",
      "Epoch 14/200, Train Loss: 17.0731, Val Loss: 15.8587\n",
      "Epoch 15/200, Train Loss: 17.0389, Val Loss: 15.8153\n",
      "Epoch 16/200, Train Loss: 17.0434, Val Loss: 15.8973\n",
      "Epoch 17/200, Train Loss: 17.0405, Val Loss: 15.8587\n",
      "Epoch 18/200, Train Loss: 17.0106, Val Loss: 15.8673\n",
      "Epoch 19/200, Train Loss: 17.0256, Val Loss: 15.9333\n",
      "Epoch 20/200, Train Loss: 17.0212, Val Loss: 15.8728\n",
      "Epoch 21/200, Train Loss: 17.0507, Val Loss: 15.9177\n",
      "Epoch 22/200, Train Loss: 17.0328, Val Loss: 15.9154\n",
      "Epoch 23/200, Train Loss: 17.0027, Val Loss: 15.8498\n",
      "Epoch 24/200, Train Loss: 17.0151, Val Loss: 15.8524\n",
      "Epoch 25/200, Train Loss: 17.0166, Val Loss: 15.8222\n",
      "Epoch 26/200, Train Loss: 17.0296, Val Loss: 15.9072\n",
      "Epoch 27/200, Train Loss: 17.0070, Val Loss: 15.8766\n",
      "Epoch 28/200, Train Loss: 17.0047, Val Loss: 15.8946\n",
      "Epoch 29/200, Train Loss: 16.9996, Val Loss: 15.8267\n",
      "Epoch 30/200, Train Loss: 16.9846, Val Loss: 15.8697\n",
      "Epoch 31/200, Train Loss: 16.9630, Val Loss: 15.8577\n",
      "Epoch 32/200, Train Loss: 17.0118, Val Loss: 15.9520\n",
      "Epoch 33/200, Train Loss: 16.9931, Val Loss: 15.7990\n",
      "  New best validation loss: 15.7990\n",
      "Epoch 34/200, Train Loss: 16.9805, Val Loss: 15.9935\n",
      "Epoch 35/200, Train Loss: 17.0145, Val Loss: 15.7120\n",
      "  New best validation loss: 15.7120\n",
      "Epoch 36/200, Train Loss: 17.0510, Val Loss: 16.0729\n",
      "Epoch 37/200, Train Loss: 16.9843, Val Loss: 15.7829\n",
      "Epoch 38/200, Train Loss: 16.9377, Val Loss: 15.9477\n",
      "Epoch 39/200, Train Loss: 16.9549, Val Loss: 15.7805\n",
      "Epoch 40/200, Train Loss: 16.9633, Val Loss: 15.7955\n",
      "Epoch 41/200, Train Loss: 16.9535, Val Loss: 15.9137\n",
      "Epoch 42/200, Train Loss: 16.9463, Val Loss: 15.8160\n",
      "Epoch 43/200, Train Loss: 16.9461, Val Loss: 15.9263\n",
      "Epoch 44/200, Train Loss: 16.9727, Val Loss: 15.7506\n",
      "Epoch 45/200, Train Loss: 16.9173, Val Loss: 15.9377\n",
      "Epoch 46/200, Train Loss: 16.9323, Val Loss: 15.7177\n",
      "Epoch 47/200, Train Loss: 16.9224, Val Loss: 15.9391\n",
      "Epoch 48/200, Train Loss: 16.9430, Val Loss: 15.7553\n",
      "Epoch 49/200, Train Loss: 16.9840, Val Loss: 16.0852\n",
      "Epoch 50/200, Train Loss: 16.9739, Val Loss: 15.7445\n",
      "Epoch 51/200, Train Loss: 16.9276, Val Loss: 15.8814\n",
      "Epoch 52/200, Train Loss: 16.9435, Val Loss: 15.8768\n",
      "Epoch 53/200, Train Loss: 16.9071, Val Loss: 15.8338\n",
      "Epoch 54/200, Train Loss: 16.8761, Val Loss: 15.8348\n",
      "Epoch 55/200, Train Loss: 16.9168, Val Loss: 15.7545\n",
      "Epoch 56/200, Train Loss: 16.9151, Val Loss: 15.8858\n",
      "Epoch 57/200, Train Loss: 16.8999, Val Loss: 15.9595\n",
      "Epoch 58/200, Train Loss: 16.8838, Val Loss: 15.7300\n",
      "Epoch 59/200, Train Loss: 16.8991, Val Loss: 15.9926\n",
      "Epoch 60/200, Train Loss: 16.8877, Val Loss: 15.7907\n",
      "Epoch 61/200, Train Loss: 16.9035, Val Loss: 15.9439\n",
      "Epoch 62/200, Train Loss: 16.9063, Val Loss: 15.7198\n",
      "Epoch 63/200, Train Loss: 16.8922, Val Loss: 15.8321\n",
      "Epoch 64/200, Train Loss: 16.8720, Val Loss: 15.7917\n",
      "Epoch 65/200, Train Loss: 16.8772, Val Loss: 15.7857\n",
      "Epoch 66/200, Train Loss: 16.8434, Val Loss: 15.8720\n",
      "Epoch 67/200, Train Loss: 16.8736, Val Loss: 15.7713\n",
      "Epoch 68/200, Train Loss: 16.8711, Val Loss: 16.0215\n",
      "Epoch 69/200, Train Loss: 16.8262, Val Loss: 15.7667\n",
      "Epoch 70/200, Train Loss: 16.8519, Val Loss: 15.8142\n",
      "Epoch 71/200, Train Loss: 16.8321, Val Loss: 15.8328\n",
      "Epoch 72/200, Train Loss: 16.8446, Val Loss: 15.7934\n",
      "Epoch 73/200, Train Loss: 16.8200, Val Loss: 15.8925\n",
      "Epoch 74/200, Train Loss: 16.8261, Val Loss: 15.7865\n",
      "Epoch 75/200, Train Loss: 16.8055, Val Loss: 15.8326\n",
      "Epoch 76/200, Train Loss: 16.8603, Val Loss: 16.0173\n",
      "Epoch 77/200, Train Loss: 16.8889, Val Loss: 15.6915\n",
      "  New best validation loss: 15.6915\n",
      "Epoch 78/200, Train Loss: 16.8333, Val Loss: 15.7550\n",
      "Epoch 79/200, Train Loss: 16.8038, Val Loss: 15.7780\n",
      "Epoch 80/200, Train Loss: 16.7904, Val Loss: 15.7594\n",
      "Epoch 81/200, Train Loss: 16.8272, Val Loss: 15.8369\n",
      "Epoch 82/200, Train Loss: 16.8063, Val Loss: 15.8383\n",
      "Epoch 83/200, Train Loss: 16.8075, Val Loss: 15.7831\n",
      "Epoch 84/200, Train Loss: 16.7985, Val Loss: 15.7720\n",
      "Epoch 85/200, Train Loss: 16.7684, Val Loss: 16.0147\n",
      "Epoch 86/200, Train Loss: 16.8332, Val Loss: 15.6813\n",
      "  New best validation loss: 15.6813\n",
      "Epoch 87/200, Train Loss: 16.7696, Val Loss: 15.9322\n",
      "Epoch 88/200, Train Loss: 16.7890, Val Loss: 15.7820\n",
      "Epoch 89/200, Train Loss: 16.7737, Val Loss: 15.8287\n",
      "Epoch 90/200, Train Loss: 16.7645, Val Loss: 15.6521\n",
      "  New best validation loss: 15.6521\n",
      "Epoch 91/200, Train Loss: 16.7885, Val Loss: 15.7720\n",
      "Epoch 92/200, Train Loss: 16.7715, Val Loss: 15.8074\n",
      "Epoch 93/200, Train Loss: 16.7565, Val Loss: 15.7633\n",
      "Epoch 94/200, Train Loss: 16.7285, Val Loss: 15.6815\n",
      "Epoch 95/200, Train Loss: 16.7691, Val Loss: 15.6200\n",
      "  New best validation loss: 15.6200\n",
      "Epoch 96/200, Train Loss: 16.7497, Val Loss: 15.7969\n",
      "Epoch 97/200, Train Loss: 16.7658, Val Loss: 15.6342\n",
      "Epoch 98/200, Train Loss: 16.7587, Val Loss: 15.8152\n",
      "Epoch 99/200, Train Loss: 16.7247, Val Loss: 15.6193\n",
      "  New best validation loss: 15.6193\n",
      "Epoch 100/200, Train Loss: 16.7444, Val Loss: 15.7685\n",
      "Epoch 101/200, Train Loss: 16.6939, Val Loss: 15.6744\n",
      "Epoch 102/200, Train Loss: 16.7348, Val Loss: 15.6008\n",
      "  New best validation loss: 15.6008\n",
      "Epoch 103/200, Train Loss: 16.7239, Val Loss: 15.6239\n",
      "Epoch 104/200, Train Loss: 16.7058, Val Loss: 15.5954\n",
      "  New best validation loss: 15.5954\n",
      "Epoch 105/200, Train Loss: 16.6901, Val Loss: 15.8287\n",
      "Epoch 106/200, Train Loss: 16.7191, Val Loss: 15.5318\n",
      "  New best validation loss: 15.5318\n",
      "Epoch 107/200, Train Loss: 16.7024, Val Loss: 15.8780\n",
      "Epoch 108/200, Train Loss: 16.6776, Val Loss: 15.5878\n",
      "Epoch 109/200, Train Loss: 16.7296, Val Loss: 15.7121\n",
      "Epoch 110/200, Train Loss: 16.7164, Val Loss: 15.6597\n",
      "Epoch 111/200, Train Loss: 16.6927, Val Loss: 15.7937\n",
      "Epoch 112/200, Train Loss: 16.6959, Val Loss: 15.5850\n",
      "Epoch 113/200, Train Loss: 16.6704, Val Loss: 15.5975\n",
      "Epoch 114/200, Train Loss: 16.6800, Val Loss: 15.6643\n",
      "Epoch 115/200, Train Loss: 16.7276, Val Loss: 15.8091\n",
      "Epoch 116/200, Train Loss: 16.6695, Val Loss: 15.5093\n",
      "  New best validation loss: 15.5093\n",
      "Epoch 117/200, Train Loss: 16.6767, Val Loss: 15.8034\n",
      "Epoch 118/200, Train Loss: 16.7047, Val Loss: 15.5866\n",
      "Epoch 119/200, Train Loss: 16.6549, Val Loss: 15.6370\n",
      "Epoch 120/200, Train Loss: 16.6430, Val Loss: 15.5544\n",
      "Epoch 121/200, Train Loss: 16.6951, Val Loss: 15.6924\n",
      "Epoch 122/200, Train Loss: 16.6302, Val Loss: 15.4997\n",
      "  New best validation loss: 15.4997\n",
      "Epoch 123/200, Train Loss: 16.6260, Val Loss: 15.7153\n",
      "Epoch 124/200, Train Loss: 16.6667, Val Loss: 15.6088\n",
      "Epoch 125/200, Train Loss: 16.6539, Val Loss: 15.5599\n",
      "Epoch 126/200, Train Loss: 16.6645, Val Loss: 15.5755\n",
      "Epoch 127/200, Train Loss: 16.6746, Val Loss: 15.4742\n",
      "  New best validation loss: 15.4742\n",
      "Epoch 128/200, Train Loss: 16.6150, Val Loss: 15.6869\n",
      "Epoch 129/200, Train Loss: 16.5956, Val Loss: 15.5540\n",
      "Epoch 130/200, Train Loss: 16.5923, Val Loss: 15.5879\n",
      "Epoch 131/200, Train Loss: 16.6002, Val Loss: 15.5983\n",
      "Epoch 132/200, Train Loss: 16.5943, Val Loss: 15.5388\n",
      "Epoch 133/200, Train Loss: 16.5817, Val Loss: 15.5503\n",
      "Epoch 134/200, Train Loss: 16.5568, Val Loss: 15.6430\n",
      "Epoch 135/200, Train Loss: 16.6279, Val Loss: 15.4399\n",
      "  New best validation loss: 15.4399\n",
      "Epoch 136/200, Train Loss: 16.5667, Val Loss: 15.6008\n",
      "Epoch 137/200, Train Loss: 16.6494, Val Loss: 15.6703\n",
      "Epoch 138/200, Train Loss: 16.5831, Val Loss: 15.4821\n",
      "Epoch 139/200, Train Loss: 16.5543, Val Loss: 15.5017\n",
      "Epoch 140/200, Train Loss: 16.5795, Val Loss: 15.6772\n",
      "Epoch 141/200, Train Loss: 16.6026, Val Loss: 15.4940\n",
      "Epoch 142/200, Train Loss: 16.5389, Val Loss: 15.6516\n",
      "Epoch 143/200, Train Loss: 16.5292, Val Loss: 15.5026\n",
      "Epoch 144/200, Train Loss: 16.5051, Val Loss: 15.6533\n",
      "Epoch 145/200, Train Loss: 16.6006, Val Loss: 15.4262\n",
      "  New best validation loss: 15.4262\n",
      "Epoch 146/200, Train Loss: 16.5202, Val Loss: 15.4988\n",
      "Epoch 147/200, Train Loss: 16.5496, Val Loss: 15.5532\n",
      "Epoch 148/200, Train Loss: 16.4983, Val Loss: 15.3913\n",
      "  New best validation loss: 15.3913\n",
      "Epoch 149/200, Train Loss: 16.5371, Val Loss: 15.5011\n",
      "Epoch 150/200, Train Loss: 16.5154, Val Loss: 15.4248\n",
      "Epoch 151/200, Train Loss: 16.5128, Val Loss: 15.4001\n",
      "Epoch 152/200, Train Loss: 16.5440, Val Loss: 15.4824\n",
      "Epoch 153/200, Train Loss: 16.4971, Val Loss: 15.3858\n",
      "  New best validation loss: 15.3858\n",
      "Epoch 154/200, Train Loss: 16.4834, Val Loss: 15.4181\n",
      "Epoch 155/200, Train Loss: 16.4941, Val Loss: 15.4352\n",
      "Epoch 156/200, Train Loss: 16.5082, Val Loss: 15.4026\n",
      "Epoch 157/200, Train Loss: 16.4801, Val Loss: 15.4062\n",
      "Epoch 158/200, Train Loss: 16.4517, Val Loss: 15.3603\n",
      "  New best validation loss: 15.3603\n",
      "Epoch 159/200, Train Loss: 16.4209, Val Loss: 15.3955\n",
      "Epoch 160/200, Train Loss: 16.4642, Val Loss: 15.5138\n",
      "Epoch 161/200, Train Loss: 16.4758, Val Loss: 15.4111\n",
      "Epoch 162/200, Train Loss: 16.4623, Val Loss: 15.6266\n",
      "Epoch 163/200, Train Loss: 16.4577, Val Loss: 15.3533\n",
      "  New best validation loss: 15.3533\n",
      "Epoch 164/200, Train Loss: 16.4144, Val Loss: 15.3568\n",
      "Epoch 165/200, Train Loss: 16.5509, Val Loss: 15.6715\n",
      "Epoch 166/200, Train Loss: 16.4922, Val Loss: 15.3979\n",
      "Epoch 167/200, Train Loss: 16.4287, Val Loss: 15.3504\n",
      "  New best validation loss: 15.3504\n",
      "Epoch 168/200, Train Loss: 16.4081, Val Loss: 15.3433\n",
      "  New best validation loss: 15.3433\n",
      "Epoch 169/200, Train Loss: 16.4160, Val Loss: 15.3982\n",
      "Epoch 170/200, Train Loss: 16.4142, Val Loss: 15.4593\n",
      "Epoch 171/200, Train Loss: 16.4356, Val Loss: 15.5568\n",
      "Epoch 172/200, Train Loss: 16.4584, Val Loss: 15.2978\n",
      "  New best validation loss: 15.2978\n",
      "Epoch 173/200, Train Loss: 16.3726, Val Loss: 15.3399\n",
      "Epoch 174/200, Train Loss: 16.3756, Val Loss: 15.5154\n",
      "Epoch 175/200, Train Loss: 16.3798, Val Loss: 15.3676\n",
      "Epoch 176/200, Train Loss: 16.3019, Val Loss: 15.3380\n",
      "Epoch 177/200, Train Loss: 16.3812, Val Loss: 15.4315\n",
      "Epoch 178/200, Train Loss: 16.3175, Val Loss: 15.3279\n",
      "Epoch 179/200, Train Loss: 16.2973, Val Loss: 15.5448\n",
      "Epoch 180/200, Train Loss: 16.3418, Val Loss: 15.2893\n",
      "  New best validation loss: 15.2893\n",
      "Epoch 181/200, Train Loss: 16.3166, Val Loss: 15.3054\n",
      "Epoch 182/200, Train Loss: 16.2926, Val Loss: 15.3763\n",
      "Epoch 183/200, Train Loss: 16.3651, Val Loss: 15.3534\n",
      "Epoch 184/200, Train Loss: 16.3438, Val Loss: 15.4041\n",
      "Epoch 185/200, Train Loss: 16.3632, Val Loss: 15.2486\n",
      "  New best validation loss: 15.2486\n",
      "Epoch 186/200, Train Loss: 16.3153, Val Loss: 15.4205\n",
      "Epoch 187/200, Train Loss: 16.3292, Val Loss: 15.3446\n",
      "Epoch 188/200, Train Loss: 16.3736, Val Loss: 15.2451\n",
      "  New best validation loss: 15.2451\n",
      "Epoch 189/200, Train Loss: 16.3418, Val Loss: 15.4763\n",
      "Epoch 190/200, Train Loss: 16.2338, Val Loss: 15.2694\n",
      "Epoch 191/200, Train Loss: 16.2547, Val Loss: 15.3437\n",
      "Epoch 192/200, Train Loss: 16.2553, Val Loss: 15.3331\n",
      "Epoch 193/200, Train Loss: 16.2439, Val Loss: 15.1939\n",
      "  New best validation loss: 15.1939\n",
      "Epoch 194/200, Train Loss: 16.2734, Val Loss: 15.1988\n",
      "Epoch 195/200, Train Loss: 16.2744, Val Loss: 15.2176\n",
      "Epoch 196/200, Train Loss: 16.2182, Val Loss: 15.2835\n",
      "Epoch 197/200, Train Loss: 16.1977, Val Loss: 15.1721\n",
      "  New best validation loss: 15.1721\n",
      "Epoch 198/200, Train Loss: 16.2349, Val Loss: 15.1333\n",
      "  New best validation loss: 15.1333\n",
      "Epoch 199/200, Train Loss: 16.2514, Val Loss: 15.3748\n",
      "Epoch 200/200, Train Loss: 16.2148, Val Loss: 15.1332\n",
      "  New best validation loss: 15.1332\n",
      "\n",
      "Loaded best model (Val Loss: 15.1332) for final hidden state extraction.\n",
      "Saved best model for TransformerCausal (samples=320) to results_data_size_sweep/20250514_045146/samples_320/TransformerCausal_samples_320_best.pt\n",
      "\n",
      "--- Performing Decodability Analysis for TransformerCausal (samples=320, k=15) ---\n",
      "  Analyzing decodability for TransformerCausal...\n",
      "  Hidden states shape: torch.Size([160, 200, 20])\n",
      "  Coefficients shape: torch.Size([160, 15])\n",
      "  Processed hidden states shape for decoder: torch.Size([160, 20])\n",
      "  RidgeCV Decoder for TransformerCausal - Test MSE: 1.5286, Test R2: 0.2256 (best alpha: 0.1438)\n",
      "  Decodability plot saved to results_data_size_sweep/20250514_045146/samples_320/decodability_TransformerCausal_coeff1.png\n",
      "Decodability (R2 score) for TransformerCausal (samples=320): 0.2256\n",
      "\n",
      "--- Training HIPPORNN_LegT (samples=320, k=15) ---\n",
      "Number of parameters: 4029\n",
      "Epoch 1/200, Train Loss: 17.4429, Val Loss: 15.8518\n",
      "  New best validation loss: 15.8518\n",
      "Epoch 2/200, Train Loss: 17.4399, Val Loss: 15.8495\n",
      "  New best validation loss: 15.8495\n",
      "Epoch 3/200, Train Loss: 17.4366, Val Loss: 15.8477\n",
      "  New best validation loss: 15.8477\n",
      "Epoch 4/200, Train Loss: 17.4328, Val Loss: 15.8457\n",
      "  New best validation loss: 15.8457\n",
      "Epoch 5/200, Train Loss: 17.4282, Val Loss: 15.8433\n",
      "  New best validation loss: 15.8433\n",
      "Epoch 6/200, Train Loss: 17.4225, Val Loss: 15.8402\n",
      "  New best validation loss: 15.8402\n",
      "Epoch 7/200, Train Loss: 17.4143, Val Loss: 15.8359\n",
      "  New best validation loss: 15.8359\n",
      "Epoch 8/200, Train Loss: 17.4047, Val Loss: 15.8309\n",
      "  New best validation loss: 15.8309\n",
      "Epoch 9/200, Train Loss: 17.3929, Val Loss: 15.8242\n",
      "  New best validation loss: 15.8242\n",
      "Epoch 10/200, Train Loss: 17.3763, Val Loss: 15.8148\n",
      "  New best validation loss: 15.8148\n",
      "Epoch 11/200, Train Loss: 17.3510, Val Loss: 15.8011\n",
      "  New best validation loss: 15.8011\n",
      "Epoch 12/200, Train Loss: 17.3138, Val Loss: 15.7799\n",
      "  New best validation loss: 15.7799\n",
      "Epoch 13/200, Train Loss: 17.2521, Val Loss: 15.7502\n",
      "  New best validation loss: 15.7502\n",
      "Epoch 14/200, Train Loss: 17.1657, Val Loss: 15.7157\n",
      "  New best validation loss: 15.7157\n",
      "Epoch 15/200, Train Loss: 17.0503, Val Loss: 15.7076\n",
      "  New best validation loss: 15.7076\n",
      "Epoch 16/200, Train Loss: 16.9087, Val Loss: 15.7569\n",
      "Epoch 17/200, Train Loss: 16.8750, Val Loss: 15.8346\n",
      "Epoch 18/200, Train Loss: 16.8501, Val Loss: 15.7339\n",
      "Epoch 19/200, Train Loss: 16.8274, Val Loss: 15.7041\n",
      "  New best validation loss: 15.7041\n",
      "Epoch 20/200, Train Loss: 16.8160, Val Loss: 15.7195\n",
      "Epoch 21/200, Train Loss: 16.8064, Val Loss: 15.7407\n",
      "Epoch 22/200, Train Loss: 16.7936, Val Loss: 15.7497\n",
      "Epoch 23/200, Train Loss: 16.7883, Val Loss: 15.7525\n",
      "Epoch 24/200, Train Loss: 16.7786, Val Loss: 15.7071\n",
      "Epoch 25/200, Train Loss: 16.7702, Val Loss: 15.7127\n",
      "Epoch 26/200, Train Loss: 16.7625, Val Loss: 15.7140\n",
      "Epoch 27/200, Train Loss: 16.7547, Val Loss: 15.7143\n",
      "Epoch 28/200, Train Loss: 16.7526, Val Loss: 15.6967\n",
      "  New best validation loss: 15.6967\n",
      "Epoch 29/200, Train Loss: 16.7431, Val Loss: 15.7075\n",
      "Epoch 30/200, Train Loss: 16.7394, Val Loss: 15.7382\n",
      "Epoch 31/200, Train Loss: 16.7300, Val Loss: 15.7169\n",
      "Epoch 32/200, Train Loss: 16.7217, Val Loss: 15.6997\n",
      "Epoch 33/200, Train Loss: 16.7152, Val Loss: 15.6851\n",
      "  New best validation loss: 15.6851\n",
      "Epoch 34/200, Train Loss: 16.7093, Val Loss: 15.6869\n",
      "Epoch 35/200, Train Loss: 16.7013, Val Loss: 15.6791\n",
      "  New best validation loss: 15.6791\n",
      "Epoch 36/200, Train Loss: 16.6941, Val Loss: 15.6924\n",
      "Epoch 37/200, Train Loss: 16.6875, Val Loss: 15.7002\n",
      "Epoch 38/200, Train Loss: 16.6842, Val Loss: 15.7071\n",
      "Epoch 39/200, Train Loss: 16.6785, Val Loss: 15.6615\n",
      "  New best validation loss: 15.6615\n",
      "Epoch 40/200, Train Loss: 16.6662, Val Loss: 15.6682\n",
      "Epoch 41/200, Train Loss: 16.6587, Val Loss: 15.6700\n",
      "Epoch 42/200, Train Loss: 16.6521, Val Loss: 15.6725\n",
      "Epoch 43/200, Train Loss: 16.6447, Val Loss: 15.6476\n",
      "  New best validation loss: 15.6476\n",
      "Epoch 44/200, Train Loss: 16.6341, Val Loss: 15.6520\n",
      "Epoch 45/200, Train Loss: 16.6230, Val Loss: 15.6698\n",
      "Epoch 46/200, Train Loss: 16.6155, Val Loss: 15.6764\n",
      "Epoch 47/200, Train Loss: 16.6035, Val Loss: 15.6610\n",
      "Epoch 48/200, Train Loss: 16.5955, Val Loss: 15.6441\n",
      "  New best validation loss: 15.6441\n",
      "Epoch 49/200, Train Loss: 16.5836, Val Loss: 15.6399\n",
      "  New best validation loss: 15.6399\n",
      "Epoch 50/200, Train Loss: 16.5733, Val Loss: 15.6382\n",
      "  New best validation loss: 15.6382\n",
      "Epoch 51/200, Train Loss: 16.5603, Val Loss: 15.6251\n",
      "  New best validation loss: 15.6251\n",
      "Epoch 52/200, Train Loss: 16.5440, Val Loss: 15.6177\n",
      "  New best validation loss: 15.6177\n",
      "Epoch 53/200, Train Loss: 16.5290, Val Loss: 15.6164\n",
      "  New best validation loss: 15.6164\n",
      "Epoch 54/200, Train Loss: 16.5106, Val Loss: 15.6142\n",
      "  New best validation loss: 15.6142\n",
      "Epoch 55/200, Train Loss: 16.4931, Val Loss: 15.6065\n",
      "  New best validation loss: 15.6065\n",
      "Epoch 56/200, Train Loss: 16.4712, Val Loss: 15.5683\n",
      "  New best validation loss: 15.5683\n",
      "Epoch 57/200, Train Loss: 16.4503, Val Loss: 15.5689\n",
      "Epoch 58/200, Train Loss: 16.4235, Val Loss: 15.5577\n",
      "  New best validation loss: 15.5577\n",
      "Epoch 59/200, Train Loss: 16.3973, Val Loss: 15.5578\n",
      "Epoch 60/200, Train Loss: 16.3682, Val Loss: 15.5229\n",
      "  New best validation loss: 15.5229\n",
      "Epoch 61/200, Train Loss: 16.3371, Val Loss: 15.5122\n",
      "  New best validation loss: 15.5122\n",
      "Epoch 62/200, Train Loss: 16.3013, Val Loss: 15.4960\n",
      "  New best validation loss: 15.4960\n",
      "Epoch 63/200, Train Loss: 16.2668, Val Loss: 15.4868\n",
      "  New best validation loss: 15.4868\n",
      "Epoch 64/200, Train Loss: 16.2312, Val Loss: 15.4712\n",
      "  New best validation loss: 15.4712\n",
      "Epoch 65/200, Train Loss: 16.1928, Val Loss: 15.4017\n",
      "  New best validation loss: 15.4017\n",
      "Epoch 66/200, Train Loss: 16.1532, Val Loss: 15.3765\n",
      "  New best validation loss: 15.3765\n",
      "Epoch 67/200, Train Loss: 16.1089, Val Loss: 15.3914\n",
      "Epoch 68/200, Train Loss: 16.0686, Val Loss: 15.3647\n",
      "  New best validation loss: 15.3647\n",
      "Epoch 69/200, Train Loss: 16.0252, Val Loss: 15.3359\n",
      "  New best validation loss: 15.3359\n",
      "Epoch 70/200, Train Loss: 15.9782, Val Loss: 15.3164\n",
      "  New best validation loss: 15.3164\n",
      "Epoch 71/200, Train Loss: 15.9412, Val Loss: 15.2833\n",
      "  New best validation loss: 15.2833\n",
      "Epoch 72/200, Train Loss: 15.9008, Val Loss: 15.2470\n",
      "  New best validation loss: 15.2470\n",
      "Epoch 73/200, Train Loss: 15.8651, Val Loss: 15.2716\n",
      "Epoch 74/200, Train Loss: 15.8135, Val Loss: 15.2560\n",
      "Epoch 75/200, Train Loss: 15.7745, Val Loss: 15.2148\n",
      "  New best validation loss: 15.2148\n",
      "Epoch 76/200, Train Loss: 15.7401, Val Loss: 15.2058\n",
      "  New best validation loss: 15.2058\n",
      "Epoch 77/200, Train Loss: 15.7109, Val Loss: 15.1932\n",
      "  New best validation loss: 15.1932\n",
      "Epoch 78/200, Train Loss: 15.6711, Val Loss: 15.1468\n",
      "  New best validation loss: 15.1468\n",
      "Epoch 79/200, Train Loss: 15.6371, Val Loss: 15.1919\n",
      "Epoch 80/200, Train Loss: 15.5938, Val Loss: 15.1649\n",
      "Epoch 81/200, Train Loss: 15.5592, Val Loss: 15.1596\n",
      "Epoch 82/200, Train Loss: 15.5304, Val Loss: 15.1045\n",
      "  New best validation loss: 15.1045\n",
      "Epoch 83/200, Train Loss: 15.4875, Val Loss: 15.1053\n",
      "Epoch 84/200, Train Loss: 15.4565, Val Loss: 15.1142\n",
      "Epoch 85/200, Train Loss: 15.4310, Val Loss: 15.1439\n",
      "Epoch 86/200, Train Loss: 15.3871, Val Loss: 15.0900\n",
      "  New best validation loss: 15.0900\n",
      "Epoch 87/200, Train Loss: 15.3602, Val Loss: 15.0417\n",
      "  New best validation loss: 15.0417\n",
      "Epoch 88/200, Train Loss: 15.3272, Val Loss: 15.0334\n",
      "  New best validation loss: 15.0334\n",
      "Epoch 89/200, Train Loss: 15.2893, Val Loss: 15.0490\n",
      "Epoch 90/200, Train Loss: 15.2566, Val Loss: 15.0393\n",
      "Epoch 91/200, Train Loss: 15.2249, Val Loss: 15.0254\n",
      "  New best validation loss: 15.0254\n",
      "Epoch 92/200, Train Loss: 15.1938, Val Loss: 14.9932\n",
      "  New best validation loss: 14.9932\n",
      "Epoch 93/200, Train Loss: 15.1627, Val Loss: 14.9795\n",
      "  New best validation loss: 14.9795\n",
      "Epoch 94/200, Train Loss: 15.1395, Val Loss: 15.0105\n",
      "Epoch 95/200, Train Loss: 15.1044, Val Loss: 14.9431\n",
      "  New best validation loss: 14.9431\n",
      "Epoch 96/200, Train Loss: 15.0741, Val Loss: 14.9270\n",
      "  New best validation loss: 14.9270\n",
      "Epoch 97/200, Train Loss: 15.0384, Val Loss: 14.9498\n",
      "Epoch 98/200, Train Loss: 15.0062, Val Loss: 14.9177\n",
      "  New best validation loss: 14.9177\n",
      "Epoch 99/200, Train Loss: 14.9803, Val Loss: 14.8788\n",
      "  New best validation loss: 14.8788\n",
      "Epoch 100/200, Train Loss: 14.9513, Val Loss: 14.9073\n",
      "Epoch 101/200, Train Loss: 14.9158, Val Loss: 14.8654\n",
      "  New best validation loss: 14.8654\n",
      "Epoch 102/200, Train Loss: 14.8919, Val Loss: 14.8653\n",
      "  New best validation loss: 14.8653\n",
      "Epoch 103/200, Train Loss: 14.8606, Val Loss: 14.8468\n",
      "  New best validation loss: 14.8468\n",
      "Epoch 104/200, Train Loss: 14.8327, Val Loss: 14.8199\n",
      "  New best validation loss: 14.8199\n",
      "Epoch 105/200, Train Loss: 14.8076, Val Loss: 14.8253\n",
      "Epoch 106/200, Train Loss: 14.7802, Val Loss: 14.7965\n",
      "  New best validation loss: 14.7965\n",
      "Epoch 107/200, Train Loss: 14.7498, Val Loss: 14.7905\n",
      "  New best validation loss: 14.7905\n",
      "Epoch 108/200, Train Loss: 14.7181, Val Loss: 14.7896\n",
      "  New best validation loss: 14.7896\n",
      "Epoch 109/200, Train Loss: 14.6939, Val Loss: 14.7807\n",
      "  New best validation loss: 14.7807\n",
      "Epoch 110/200, Train Loss: 14.6661, Val Loss: 14.7514\n",
      "  New best validation loss: 14.7514\n",
      "Epoch 111/200, Train Loss: 14.6445, Val Loss: 14.7029\n",
      "  New best validation loss: 14.7029\n",
      "Epoch 112/200, Train Loss: 14.6234, Val Loss: 14.7481\n",
      "Epoch 113/200, Train Loss: 14.5869, Val Loss: 14.6986\n",
      "  New best validation loss: 14.6986\n",
      "Epoch 114/200, Train Loss: 14.5611, Val Loss: 14.6895\n",
      "  New best validation loss: 14.6895\n",
      "Epoch 115/200, Train Loss: 14.5469, Val Loss: 14.7473\n",
      "Epoch 116/200, Train Loss: 14.5104, Val Loss: 14.6813\n",
      "  New best validation loss: 14.6813\n",
      "Epoch 117/200, Train Loss: 14.4883, Val Loss: 14.6710\n",
      "  New best validation loss: 14.6710\n",
      "Epoch 118/200, Train Loss: 14.4651, Val Loss: 14.6698\n",
      "  New best validation loss: 14.6698\n",
      "Epoch 119/200, Train Loss: 14.4395, Val Loss: 14.6583\n",
      "  New best validation loss: 14.6583\n",
      "Epoch 120/200, Train Loss: 14.4086, Val Loss: 14.6066\n",
      "  New best validation loss: 14.6066\n",
      "Epoch 121/200, Train Loss: 14.3899, Val Loss: 14.5986\n",
      "  New best validation loss: 14.5986\n",
      "Epoch 122/200, Train Loss: 14.3828, Val Loss: 14.6889\n",
      "Epoch 123/200, Train Loss: 14.3349, Val Loss: 14.5777\n",
      "  New best validation loss: 14.5777\n",
      "Epoch 124/200, Train Loss: 14.3104, Val Loss: 14.5997\n",
      "Epoch 125/200, Train Loss: 14.3032, Val Loss: 14.6222\n",
      "Epoch 126/200, Train Loss: 14.2784, Val Loss: 14.5662\n",
      "  New best validation loss: 14.5662\n",
      "Epoch 127/200, Train Loss: 14.2429, Val Loss: 14.6173\n",
      "Epoch 128/200, Train Loss: 14.2128, Val Loss: 14.5662\n",
      "  New best validation loss: 14.5662\n",
      "Epoch 129/200, Train Loss: 14.1922, Val Loss: 14.5512\n",
      "  New best validation loss: 14.5512\n",
      "Epoch 130/200, Train Loss: 14.1713, Val Loss: 14.5267\n",
      "  New best validation loss: 14.5267\n",
      "Epoch 131/200, Train Loss: 14.1486, Val Loss: 14.5495\n",
      "Epoch 132/200, Train Loss: 14.1245, Val Loss: 14.5498\n",
      "Epoch 133/200, Train Loss: 14.0948, Val Loss: 14.5170\n",
      "  New best validation loss: 14.5170\n",
      "Epoch 134/200, Train Loss: 14.0808, Val Loss: 14.4910\n",
      "  New best validation loss: 14.4910\n",
      "Epoch 135/200, Train Loss: 14.0693, Val Loss: 14.5399\n",
      "Epoch 136/200, Train Loss: 14.0331, Val Loss: 14.4592\n",
      "  New best validation loss: 14.4592\n",
      "Epoch 137/200, Train Loss: 14.0079, Val Loss: 14.4913\n",
      "Epoch 138/200, Train Loss: 13.9902, Val Loss: 14.4564\n",
      "  New best validation loss: 14.4564\n",
      "Epoch 139/200, Train Loss: 13.9637, Val Loss: 14.4635\n",
      "Epoch 140/200, Train Loss: 13.9456, Val Loss: 14.4903\n",
      "Epoch 141/200, Train Loss: 13.9298, Val Loss: 14.4689\n",
      "Epoch 142/200, Train Loss: 13.9030, Val Loss: 14.4489\n",
      "  New best validation loss: 14.4489\n",
      "Epoch 143/200, Train Loss: 13.8904, Val Loss: 14.4373\n",
      "  New best validation loss: 14.4373\n",
      "Epoch 144/200, Train Loss: 13.8565, Val Loss: 14.4235\n",
      "  New best validation loss: 14.4235\n",
      "Epoch 145/200, Train Loss: 13.8438, Val Loss: 14.4319\n",
      "Epoch 146/200, Train Loss: 13.8312, Val Loss: 14.4128\n",
      "  New best validation loss: 14.4128\n",
      "Epoch 147/200, Train Loss: 13.8105, Val Loss: 14.4256\n",
      "Epoch 148/200, Train Loss: 13.7775, Val Loss: 14.3850\n",
      "  New best validation loss: 14.3850\n",
      "Epoch 149/200, Train Loss: 13.7687, Val Loss: 14.3999\n",
      "Epoch 150/200, Train Loss: 13.7482, Val Loss: 14.3543\n",
      "  New best validation loss: 14.3543\n",
      "Epoch 151/200, Train Loss: 13.7222, Val Loss: 14.3701\n",
      "Epoch 152/200, Train Loss: 13.7103, Val Loss: 14.4101\n",
      "Epoch 153/200, Train Loss: 13.6920, Val Loss: 14.3650\n",
      "Epoch 154/200, Train Loss: 13.6608, Val Loss: 14.3636\n",
      "Epoch 155/200, Train Loss: 13.6548, Val Loss: 14.3846\n",
      "Epoch 156/200, Train Loss: 13.6356, Val Loss: 14.3238\n",
      "  New best validation loss: 14.3238\n",
      "Epoch 157/200, Train Loss: 13.6412, Val Loss: 14.3614\n",
      "Epoch 158/200, Train Loss: 13.6466, Val Loss: 14.3131\n",
      "  New best validation loss: 14.3131\n",
      "Epoch 159/200, Train Loss: 13.5805, Val Loss: 14.3793\n",
      "Epoch 160/200, Train Loss: 13.5689, Val Loss: 14.2994\n",
      "  New best validation loss: 14.2994\n",
      "Epoch 161/200, Train Loss: 13.5523, Val Loss: 14.3400\n",
      "Epoch 162/200, Train Loss: 13.5244, Val Loss: 14.3282\n",
      "Epoch 163/200, Train Loss: 13.5241, Val Loss: 14.2603\n",
      "  New best validation loss: 14.2603\n",
      "Epoch 164/200, Train Loss: 13.4983, Val Loss: 14.3348\n",
      "Epoch 165/200, Train Loss: 13.4781, Val Loss: 14.3185\n",
      "Epoch 166/200, Train Loss: 13.4581, Val Loss: 14.2725\n",
      "Epoch 167/200, Train Loss: 13.4525, Val Loss: 14.2836\n",
      "Epoch 168/200, Train Loss: 13.4439, Val Loss: 14.2224\n",
      "  New best validation loss: 14.2224\n",
      "Epoch 169/200, Train Loss: 13.4242, Val Loss: 14.3046\n",
      "Epoch 170/200, Train Loss: 13.4145, Val Loss: 14.2686\n",
      "Epoch 171/200, Train Loss: 13.3790, Val Loss: 14.2680\n",
      "Epoch 172/200, Train Loss: 13.3617, Val Loss: 14.2153\n",
      "  New best validation loss: 14.2153\n",
      "Epoch 173/200, Train Loss: 13.3516, Val Loss: 14.2757\n",
      "Epoch 174/200, Train Loss: 13.3210, Val Loss: 14.2164\n",
      "Epoch 175/200, Train Loss: 13.3130, Val Loss: 14.2169\n",
      "Epoch 176/200, Train Loss: 13.2924, Val Loss: 14.2395\n",
      "Epoch 177/200, Train Loss: 13.2769, Val Loss: 14.2491\n",
      "Epoch 178/200, Train Loss: 13.2681, Val Loss: 14.1994\n",
      "  New best validation loss: 14.1994\n",
      "Epoch 179/200, Train Loss: 13.2450, Val Loss: 14.2016\n",
      "Epoch 180/200, Train Loss: 13.2292, Val Loss: 14.2238\n",
      "Epoch 181/200, Train Loss: 13.2220, Val Loss: 14.2039\n",
      "Epoch 182/200, Train Loss: 13.1993, Val Loss: 14.2175\n",
      "Epoch 183/200, Train Loss: 13.1930, Val Loss: 14.1671\n",
      "  New best validation loss: 14.1671\n",
      "Epoch 184/200, Train Loss: 13.1716, Val Loss: 14.1335\n",
      "  New best validation loss: 14.1335\n",
      "Epoch 185/200, Train Loss: 13.1543, Val Loss: 14.1802\n",
      "Epoch 186/200, Train Loss: 13.1482, Val Loss: 14.1631\n",
      "Epoch 187/200, Train Loss: 13.1431, Val Loss: 14.1803\n",
      "Epoch 188/200, Train Loss: 13.1292, Val Loss: 14.1529\n",
      "Epoch 189/200, Train Loss: 13.1025, Val Loss: 14.1469\n",
      "Epoch 190/200, Train Loss: 13.0804, Val Loss: 14.1622\n",
      "Epoch 191/200, Train Loss: 13.0593, Val Loss: 14.1069\n",
      "  New best validation loss: 14.1069\n",
      "Epoch 192/200, Train Loss: 13.0412, Val Loss: 14.1029\n",
      "  New best validation loss: 14.1029\n",
      "Epoch 193/200, Train Loss: 13.0352, Val Loss: 14.1201\n",
      "Epoch 194/200, Train Loss: 13.0188, Val Loss: 14.0841\n",
      "  New best validation loss: 14.0841\n",
      "Epoch 195/200, Train Loss: 12.9965, Val Loss: 14.1055\n",
      "Epoch 196/200, Train Loss: 12.9933, Val Loss: 14.0642\n",
      "  New best validation loss: 14.0642\n",
      "Epoch 197/200, Train Loss: 12.9745, Val Loss: 14.1012\n",
      "Epoch 198/200, Train Loss: 12.9597, Val Loss: 14.0966\n",
      "Epoch 199/200, Train Loss: 12.9492, Val Loss: 14.0823\n",
      "Epoch 200/200, Train Loss: 12.9350, Val Loss: 14.0333\n",
      "  New best validation loss: 14.0333\n",
      "\n",
      "Loaded best model (Val Loss: 14.0333) for final hidden state extraction.\n",
      "Saved best model for HIPPORNN_LegT (samples=320) to results_data_size_sweep/20250514_045146/samples_320/HIPPORNN_LegT_samples_320_best.pt\n",
      "\n",
      "--- Performing Decodability Analysis for HIPPORNN_LegT (samples=320, k=15) ---\n",
      "  Analyzing decodability for HIPPORNN_LegT...\n",
      "  Hidden states shape: torch.Size([160, 200, 25])\n",
      "  Coefficients shape: torch.Size([160, 15])\n",
      "  Processed hidden states shape for decoder: torch.Size([160, 25])\n",
      "  RidgeCV Decoder for HIPPORNN_LegT - Test MSE: 1.5988, Test R2: 0.1991 (best alpha: 23.3572)\n",
      "  Decodability plot saved to results_data_size_sweep/20250514_045146/samples_320/decodability_HIPPORNN_LegT_coeff1.png\n",
      "Decodability (R2 score) for HIPPORNN_LegT (samples=320): 0.1991\n",
      "\n",
      "--- Training NMRNN_Spatial_ModReadout (samples=320, k=15) ---\n",
      "Number of parameters: 66832\n",
      "Epoch 1/200, Train Loss: 17.3870, Val Loss: 15.7491\n",
      "  New best validation loss: 15.7491\n",
      "Epoch 2/200, Train Loss: 17.2469, Val Loss: 15.7201\n",
      "  New best validation loss: 15.7201\n",
      "Epoch 3/200, Train Loss: 17.1777, Val Loss: 15.7306\n",
      "Epoch 4/200, Train Loss: 17.0750, Val Loss: 15.7755\n",
      "Epoch 5/200, Train Loss: 17.0016, Val Loss: 15.8608\n",
      "Epoch 6/200, Train Loss: 16.9490, Val Loss: 15.8735\n",
      "Epoch 7/200, Train Loss: 16.9170, Val Loss: 15.8602\n",
      "Epoch 8/200, Train Loss: 16.8654, Val Loss: 15.8810\n",
      "Epoch 9/200, Train Loss: 16.8513, Val Loss: 15.8451\n",
      "Epoch 10/200, Train Loss: 16.8180, Val Loss: 15.9215\n",
      "Epoch 11/200, Train Loss: 16.7794, Val Loss: 15.8892\n",
      "Epoch 12/200, Train Loss: 16.7791, Val Loss: 15.9372\n",
      "Epoch 13/200, Train Loss: 16.7021, Val Loss: 15.9007\n",
      "Epoch 14/200, Train Loss: 16.6663, Val Loss: 15.9069\n",
      "Epoch 15/200, Train Loss: 16.6142, Val Loss: 15.8791\n",
      "Epoch 16/200, Train Loss: 16.5973, Val Loss: 15.9165\n",
      "Epoch 17/200, Train Loss: 16.5404, Val Loss: 15.9006\n",
      "Epoch 18/200, Train Loss: 16.4994, Val Loss: 15.9602\n",
      "Epoch 19/200, Train Loss: 16.4951, Val Loss: 16.0150\n",
      "Epoch 20/200, Train Loss: 16.4473, Val Loss: 15.8912\n",
      "Epoch 21/200, Train Loss: 16.4161, Val Loss: 15.9609\n",
      "Epoch 22/200, Train Loss: 16.3508, Val Loss: 15.9228\n",
      "Epoch 23/200, Train Loss: 16.2987, Val Loss: 15.9261\n",
      "Epoch 24/200, Train Loss: 16.2669, Val Loss: 15.9514\n",
      "Epoch 25/200, Train Loss: 16.1847, Val Loss: 15.8950\n",
      "Epoch 26/200, Train Loss: 16.1706, Val Loss: 16.0644\n",
      "Epoch 27/200, Train Loss: 16.1420, Val Loss: 15.9571\n",
      "Epoch 28/200, Train Loss: 16.0621, Val Loss: 15.8867\n",
      "Epoch 29/200, Train Loss: 16.0644, Val Loss: 15.9844\n",
      "Epoch 30/200, Train Loss: 16.0121, Val Loss: 15.8844\n",
      "Epoch 31/200, Train Loss: 15.9185, Val Loss: 15.9947\n",
      "Epoch 32/200, Train Loss: 15.8872, Val Loss: 15.9493\n",
      "Epoch 33/200, Train Loss: 15.8190, Val Loss: 16.0552\n",
      "Epoch 34/200, Train Loss: 15.7886, Val Loss: 15.9092\n",
      "Epoch 35/200, Train Loss: 15.7062, Val Loss: 16.0437\n",
      "Epoch 36/200, Train Loss: 15.6234, Val Loss: 16.0536\n",
      "Epoch 37/200, Train Loss: 15.6193, Val Loss: 16.0219\n",
      "Epoch 38/200, Train Loss: 15.5857, Val Loss: 16.0691\n",
      "Epoch 39/200, Train Loss: 15.5022, Val Loss: 16.2094\n",
      "Epoch 40/200, Train Loss: 15.4379, Val Loss: 16.0960\n",
      "Epoch 41/200, Train Loss: 15.3521, Val Loss: 16.1378\n",
      "Epoch 42/200, Train Loss: 15.3354, Val Loss: 16.2186\n",
      "Epoch 43/200, Train Loss: 15.3172, Val Loss: 16.3907\n",
      "Epoch 44/200, Train Loss: 15.2634, Val Loss: 16.0811\n",
      "Epoch 45/200, Train Loss: 15.1464, Val Loss: 16.3323\n",
      "Epoch 46/200, Train Loss: 15.1538, Val Loss: 16.2967\n",
      "Epoch 47/200, Train Loss: 15.1165, Val Loss: 16.2831\n",
      "Epoch 48/200, Train Loss: 15.2787, Val Loss: 16.2122\n",
      "Epoch 49/200, Train Loss: 15.2492, Val Loss: 16.4065\n",
      "Epoch 50/200, Train Loss: 15.1267, Val Loss: 16.2619\n",
      "Epoch 51/200, Train Loss: 15.0167, Val Loss: 16.2441\n",
      "Epoch 52/200, Train Loss: 14.8831, Val Loss: 16.2913\n",
      "Epoch 53/200, Train Loss: 14.8106, Val Loss: 16.4494\n",
      "Epoch 54/200, Train Loss: 14.7518, Val Loss: 16.5433\n",
      "Epoch 55/200, Train Loss: 14.7650, Val Loss: 16.2995\n",
      "Epoch 56/200, Train Loss: 14.8374, Val Loss: 16.1975\n",
      "Epoch 57/200, Train Loss: 14.6802, Val Loss: 16.7475\n",
      "Epoch 58/200, Train Loss: 14.7981, Val Loss: 16.2419\n",
      "Epoch 59/200, Train Loss: 14.6952, Val Loss: 16.4525\n",
      "Epoch 60/200, Train Loss: 14.5777, Val Loss: 16.2109\n",
      "Epoch 61/200, Train Loss: 14.5438, Val Loss: 16.5334\n",
      "Epoch 62/200, Train Loss: 14.4855, Val Loss: 16.1595\n",
      "Epoch 63/200, Train Loss: 14.3997, Val Loss: 16.5995\n",
      "Epoch 64/200, Train Loss: 14.4376, Val Loss: 16.5757\n",
      "Epoch 65/200, Train Loss: 14.4478, Val Loss: 16.2416\n",
      "Epoch 66/200, Train Loss: 14.2933, Val Loss: 16.3026\n",
      "Epoch 67/200, Train Loss: 14.3380, Val Loss: 16.4197\n",
      "Epoch 68/200, Train Loss: 14.2899, Val Loss: 16.4242\n",
      "Epoch 69/200, Train Loss: 14.1729, Val Loss: 16.6854\n",
      "Epoch 70/200, Train Loss: 14.1593, Val Loss: 16.4225\n",
      "Epoch 71/200, Train Loss: 14.0174, Val Loss: 16.5948\n",
      "Epoch 72/200, Train Loss: 13.9657, Val Loss: 16.6030\n",
      "Epoch 73/200, Train Loss: 13.9853, Val Loss: 16.5966\n",
      "Epoch 74/200, Train Loss: 13.8948, Val Loss: 16.6172\n",
      "Epoch 75/200, Train Loss: 13.8778, Val Loss: 16.9171\n",
      "Epoch 76/200, Train Loss: 13.8957, Val Loss: 16.8955\n",
      "Epoch 77/200, Train Loss: 13.6895, Val Loss: 17.0125\n",
      "Epoch 78/200, Train Loss: 13.6841, Val Loss: 16.7355\n",
      "Epoch 79/200, Train Loss: 13.6404, Val Loss: 17.0965\n",
      "Epoch 80/200, Train Loss: 13.6733, Val Loss: 16.7667\n",
      "Epoch 81/200, Train Loss: 13.6503, Val Loss: 16.6950\n",
      "Epoch 82/200, Train Loss: 13.6579, Val Loss: 16.7628\n",
      "Epoch 83/200, Train Loss: 13.6924, Val Loss: 17.1313\n",
      "Epoch 84/200, Train Loss: 13.6829, Val Loss: 16.5268\n",
      "Epoch 85/200, Train Loss: 13.4567, Val Loss: 16.6924\n",
      "Epoch 86/200, Train Loss: 13.5280, Val Loss: 17.2274\n",
      "Epoch 87/200, Train Loss: 13.5951, Val Loss: 16.8049\n",
      "Epoch 88/200, Train Loss: 13.4615, Val Loss: 17.0266\n",
      "Epoch 89/200, Train Loss: 13.3007, Val Loss: 16.7447\n",
      "Epoch 90/200, Train Loss: 13.4262, Val Loss: 16.9306\n",
      "Epoch 91/200, Train Loss: 13.3873, Val Loss: 16.9809\n",
      "Epoch 92/200, Train Loss: 13.2945, Val Loss: 17.0945\n",
      "Epoch 93/200, Train Loss: 13.2560, Val Loss: 16.9526\n",
      "Epoch 94/200, Train Loss: 13.2546, Val Loss: 17.4632\n",
      "Epoch 95/200, Train Loss: 13.1132, Val Loss: 17.0603\n",
      "Epoch 96/200, Train Loss: 13.1799, Val Loss: 17.0833\n",
      "Epoch 97/200, Train Loss: 13.0054, Val Loss: 17.1228\n",
      "Epoch 98/200, Train Loss: 12.9478, Val Loss: 17.2113\n",
      "Epoch 99/200, Train Loss: 12.9000, Val Loss: 17.3283\n",
      "Epoch 100/200, Train Loss: 12.9117, Val Loss: 17.4355\n",
      "Epoch 101/200, Train Loss: 12.8747, Val Loss: 17.1990\n",
      "Epoch 102/200, Train Loss: 12.8284, Val Loss: 17.5017\n",
      "Epoch 103/200, Train Loss: 12.8688, Val Loss: 17.2857\n",
      "Epoch 104/200, Train Loss: 12.8543, Val Loss: 17.4277\n",
      "Epoch 105/200, Train Loss: 12.7745, Val Loss: 17.5548\n",
      "Epoch 106/200, Train Loss: 12.8694, Val Loss: 17.7390\n",
      "Epoch 107/200, Train Loss: 12.7703, Val Loss: 17.2487\n",
      "Epoch 108/200, Train Loss: 12.7413, Val Loss: 17.4041\n",
      "Epoch 109/200, Train Loss: 12.6808, Val Loss: 17.3526\n",
      "Epoch 110/200, Train Loss: 12.5173, Val Loss: 17.4612\n",
      "Epoch 111/200, Train Loss: 12.5223, Val Loss: 17.7125\n",
      "Epoch 112/200, Train Loss: 12.4860, Val Loss: 17.6142\n",
      "Epoch 113/200, Train Loss: 12.4343, Val Loss: 17.2652\n",
      "Epoch 114/200, Train Loss: 12.3485, Val Loss: 17.7994\n",
      "Epoch 115/200, Train Loss: 12.2968, Val Loss: 17.2199\n",
      "Epoch 116/200, Train Loss: 12.2848, Val Loss: 17.6629\n",
      "Epoch 117/200, Train Loss: 12.1733, Val Loss: 17.7485\n",
      "Epoch 118/200, Train Loss: 12.2344, Val Loss: 17.8931\n",
      "Epoch 119/200, Train Loss: 12.3833, Val Loss: 18.1268\n",
      "Epoch 120/200, Train Loss: 12.2223, Val Loss: 17.8295\n",
      "Epoch 121/200, Train Loss: 12.2454, Val Loss: 18.0826\n",
      "Epoch 122/200, Train Loss: 12.2492, Val Loss: 17.5319\n",
      "Epoch 123/200, Train Loss: 12.2444, Val Loss: 17.7987\n",
      "Epoch 124/200, Train Loss: 12.1491, Val Loss: 18.0941\n",
      "Epoch 125/200, Train Loss: 12.1120, Val Loss: 18.1246\n",
      "Epoch 126/200, Train Loss: 11.9700, Val Loss: 18.0941\n",
      "Epoch 127/200, Train Loss: 12.0543, Val Loss: 18.0569\n",
      "Epoch 128/200, Train Loss: 11.9678, Val Loss: 18.0142\n",
      "Epoch 129/200, Train Loss: 11.8400, Val Loss: 18.4683\n",
      "Epoch 130/200, Train Loss: 11.8230, Val Loss: 18.1084\n",
      "Epoch 131/200, Train Loss: 11.8439, Val Loss: 18.1610\n",
      "Epoch 132/200, Train Loss: 11.7826, Val Loss: 18.2535\n",
      "Epoch 133/200, Train Loss: 11.7446, Val Loss: 18.2047\n",
      "Epoch 134/200, Train Loss: 11.7003, Val Loss: 18.6020\n",
      "Epoch 135/200, Train Loss: 11.7293, Val Loss: 18.2962\n",
      "Epoch 136/200, Train Loss: 11.8242, Val Loss: 18.4376\n",
      "Epoch 137/200, Train Loss: 11.7771, Val Loss: 18.4164\n",
      "Epoch 138/200, Train Loss: 11.6768, Val Loss: 18.6681\n",
      "Epoch 139/200, Train Loss: 11.6465, Val Loss: 18.4527\n",
      "Epoch 140/200, Train Loss: 11.5653, Val Loss: 18.5509\n",
      "Epoch 141/200, Train Loss: 11.5642, Val Loss: 18.9060\n",
      "Epoch 142/200, Train Loss: 11.4930, Val Loss: 18.4329\n",
      "Epoch 143/200, Train Loss: 11.3964, Val Loss: 18.6340\n",
      "Epoch 144/200, Train Loss: 11.3902, Val Loss: 18.4936\n",
      "Epoch 145/200, Train Loss: 11.4217, Val Loss: 18.6966\n",
      "Epoch 146/200, Train Loss: 11.4995, Val Loss: 18.6241\n",
      "Epoch 147/200, Train Loss: 11.3148, Val Loss: 18.7006\n",
      "Epoch 148/200, Train Loss: 11.1840, Val Loss: 19.0824\n",
      "Epoch 149/200, Train Loss: 11.1982, Val Loss: 18.6380\n",
      "Epoch 150/200, Train Loss: 11.1703, Val Loss: 18.7381\n",
      "Epoch 151/200, Train Loss: 11.2262, Val Loss: 18.5028\n",
      "Epoch 152/200, Train Loss: 11.1559, Val Loss: 18.7413\n",
      "Epoch 153/200, Train Loss: 11.1652, Val Loss: 18.7560\n",
      "Epoch 154/200, Train Loss: 11.1619, Val Loss: 19.2758\n",
      "Epoch 155/200, Train Loss: 11.1622, Val Loss: 19.0034\n",
      "Epoch 156/200, Train Loss: 11.1340, Val Loss: 18.8768\n",
      "Epoch 157/200, Train Loss: 10.9892, Val Loss: 19.0489\n",
      "Epoch 158/200, Train Loss: 10.9629, Val Loss: 18.8887\n",
      "Epoch 159/200, Train Loss: 10.9444, Val Loss: 18.8333\n",
      "Epoch 160/200, Train Loss: 10.8770, Val Loss: 19.3551\n",
      "Epoch 161/200, Train Loss: 10.8486, Val Loss: 18.9922\n",
      "Epoch 162/200, Train Loss: 10.8559, Val Loss: 19.1584\n",
      "Epoch 163/200, Train Loss: 10.8904, Val Loss: 19.2072\n",
      "Epoch 164/200, Train Loss: 10.9230, Val Loss: 19.2727\n",
      "Epoch 165/200, Train Loss: 10.7602, Val Loss: 19.4813\n",
      "Epoch 166/200, Train Loss: 10.7369, Val Loss: 18.9951\n",
      "Epoch 167/200, Train Loss: 10.6080, Val Loss: 19.7348\n",
      "Epoch 168/200, Train Loss: 10.5339, Val Loss: 19.2815\n",
      "Epoch 169/200, Train Loss: 10.5090, Val Loss: 19.6596\n",
      "Epoch 170/200, Train Loss: 10.5153, Val Loss: 19.4732\n",
      "Epoch 171/200, Train Loss: 10.4805, Val Loss: 19.2734\n",
      "Epoch 172/200, Train Loss: 10.4034, Val Loss: 19.4458\n",
      "Epoch 173/200, Train Loss: 10.4592, Val Loss: 19.4313\n",
      "Epoch 174/200, Train Loss: 10.3559, Val Loss: 19.4931\n",
      "Epoch 175/200, Train Loss: 10.5481, Val Loss: 19.6567\n",
      "Epoch 176/200, Train Loss: 10.3401, Val Loss: 19.6507\n",
      "Epoch 177/200, Train Loss: 10.1627, Val Loss: 19.9495\n",
      "Epoch 178/200, Train Loss: 10.2697, Val Loss: 19.4335\n",
      "Epoch 179/200, Train Loss: 10.1517, Val Loss: 20.0788\n",
      "Epoch 180/200, Train Loss: 10.2046, Val Loss: 19.4974\n",
      "Epoch 181/200, Train Loss: 10.1758, Val Loss: 20.0390\n",
      "Epoch 182/200, Train Loss: 10.2791, Val Loss: 19.7305\n",
      "Epoch 183/200, Train Loss: 10.2871, Val Loss: 20.0457\n",
      "Epoch 184/200, Train Loss: 10.1902, Val Loss: 19.9121\n",
      "Epoch 185/200, Train Loss: 10.1507, Val Loss: 20.0187\n",
      "Epoch 186/200, Train Loss: 10.1134, Val Loss: 20.3111\n",
      "Epoch 187/200, Train Loss: 10.0442, Val Loss: 19.8913\n",
      "Epoch 188/200, Train Loss: 9.9195, Val Loss: 19.8978\n",
      "Epoch 189/200, Train Loss: 9.9781, Val Loss: 19.7251\n",
      "Epoch 190/200, Train Loss: 9.9056, Val Loss: 19.4468\n",
      "Epoch 191/200, Train Loss: 9.8331, Val Loss: 19.9849\n",
      "Epoch 192/200, Train Loss: 9.8535, Val Loss: 20.0436\n",
      "Epoch 193/200, Train Loss: 9.8162, Val Loss: 19.6904\n",
      "Epoch 194/200, Train Loss: 10.0385, Val Loss: 20.1824\n",
      "Epoch 195/200, Train Loss: 9.9232, Val Loss: 20.1091\n",
      "Epoch 196/200, Train Loss: 9.9720, Val Loss: 19.6381\n",
      "Epoch 197/200, Train Loss: 9.8044, Val Loss: 20.0939\n",
      "Epoch 198/200, Train Loss: 9.7528, Val Loss: 20.3146\n",
      "Epoch 199/200, Train Loss: 9.8367, Val Loss: 20.0087\n",
      "Epoch 200/200, Train Loss: 9.7536, Val Loss: 20.3813\n",
      "\n",
      "Loaded best model (Val Loss: 15.7201) for final hidden state extraction.\n",
      "Saved best model for NMRNN_Spatial_ModReadout (samples=320) to results_data_size_sweep/20250514_045146/samples_320/NMRNN_Spatial_ModReadout_samples_320_best.pt\n",
      "\n",
      "--- Performing Decodability Analysis for NMRNN_Spatial_ModReadout (samples=320, k=15) ---\n",
      "  Analyzing decodability for NMRNN_Spatial_ModReadout...\n",
      "  Hidden states shape: torch.Size([160, 200, 128])\n",
      "  Coefficients shape: torch.Size([160, 15])\n",
      "  Processed hidden states shape for decoder: torch.Size([160, 128])\n",
      "  RidgeCV Decoder for NMRNN_Spatial_ModReadout - Test MSE: 1.8879, Test R2: 0.0410 (best alpha: 100.0000)\n",
      "  Decodability plot saved to results_data_size_sweep/20250514_045146/samples_320/decodability_NMRNN_Spatial_ModReadout_coeff1.png\n",
      "Decodability (R2 score) for NMRNN_Spatial_ModReadout (samples=320): 0.0410\n",
      "\n",
      "--- Training NMRNN_NoSpatial_ModReadout (samples=320, k=15) ---\n",
      "Number of parameters: 66832\n",
      "Epoch 1/200, Train Loss: 17.3402, Val Loss: 15.8426\n",
      "  New best validation loss: 15.8426\n",
      "Epoch 2/200, Train Loss: 17.2390, Val Loss: 15.7259\n",
      "  New best validation loss: 15.7259\n",
      "Epoch 3/200, Train Loss: 17.2109, Val Loss: 15.7454\n",
      "Epoch 4/200, Train Loss: 17.1083, Val Loss: 15.7855\n",
      "Epoch 5/200, Train Loss: 17.0302, Val Loss: 15.7777\n",
      "Epoch 6/200, Train Loss: 16.9944, Val Loss: 15.8380\n",
      "Epoch 7/200, Train Loss: 16.9482, Val Loss: 15.8231\n",
      "Epoch 8/200, Train Loss: 16.9232, Val Loss: 15.8454\n",
      "Epoch 9/200, Train Loss: 16.8707, Val Loss: 15.8300\n",
      "Epoch 10/200, Train Loss: 16.8433, Val Loss: 15.8086\n",
      "Epoch 11/200, Train Loss: 16.8142, Val Loss: 15.8315\n",
      "Epoch 12/200, Train Loss: 16.8199, Val Loss: 15.8999\n",
      "Epoch 13/200, Train Loss: 16.7309, Val Loss: 15.9028\n",
      "Epoch 14/200, Train Loss: 16.7335, Val Loss: 15.8743\n",
      "Epoch 15/200, Train Loss: 16.7050, Val Loss: 15.8540\n",
      "Epoch 16/200, Train Loss: 16.6604, Val Loss: 15.8854\n",
      "Epoch 17/200, Train Loss: 16.6079, Val Loss: 15.8653\n",
      "Epoch 18/200, Train Loss: 16.5883, Val Loss: 15.8919\n",
      "Epoch 19/200, Train Loss: 16.5431, Val Loss: 15.8587\n",
      "Epoch 20/200, Train Loss: 16.5140, Val Loss: 15.9211\n",
      "Epoch 21/200, Train Loss: 16.5433, Val Loss: 15.9447\n",
      "Epoch 22/200, Train Loss: 16.4842, Val Loss: 15.8680\n",
      "Epoch 23/200, Train Loss: 16.4143, Val Loss: 16.0485\n",
      "Epoch 24/200, Train Loss: 16.3666, Val Loss: 15.9119\n",
      "Epoch 25/200, Train Loss: 16.3385, Val Loss: 15.9732\n",
      "Epoch 26/200, Train Loss: 16.3329, Val Loss: 15.8518\n",
      "Epoch 27/200, Train Loss: 16.2578, Val Loss: 15.9793\n",
      "Epoch 28/200, Train Loss: 16.2389, Val Loss: 15.8946\n",
      "Epoch 29/200, Train Loss: 16.1488, Val Loss: 15.9433\n",
      "Epoch 30/200, Train Loss: 16.2485, Val Loss: 15.7872\n",
      "Epoch 31/200, Train Loss: 16.1598, Val Loss: 15.9792\n",
      "Epoch 32/200, Train Loss: 16.1025, Val Loss: 15.8961\n",
      "Epoch 33/200, Train Loss: 16.0648, Val Loss: 15.9769\n",
      "Epoch 34/200, Train Loss: 16.1376, Val Loss: 15.9311\n",
      "Epoch 35/200, Train Loss: 16.0188, Val Loss: 15.8804\n",
      "Epoch 36/200, Train Loss: 16.0017, Val Loss: 15.8756\n",
      "Epoch 37/200, Train Loss: 15.8967, Val Loss: 15.9465\n",
      "Epoch 38/200, Train Loss: 15.9092, Val Loss: 15.9221\n",
      "Epoch 39/200, Train Loss: 15.8207, Val Loss: 16.1072\n",
      "Epoch 40/200, Train Loss: 15.7922, Val Loss: 15.8340\n",
      "Epoch 41/200, Train Loss: 15.7968, Val Loss: 16.0732\n",
      "Epoch 42/200, Train Loss: 15.7044, Val Loss: 15.9151\n",
      "Epoch 43/200, Train Loss: 15.6949, Val Loss: 16.1031\n",
      "Epoch 44/200, Train Loss: 15.6607, Val Loss: 15.9407\n",
      "Epoch 45/200, Train Loss: 15.6253, Val Loss: 15.9638\n",
      "Epoch 46/200, Train Loss: 15.5631, Val Loss: 16.0435\n",
      "Epoch 47/200, Train Loss: 15.4871, Val Loss: 16.0358\n",
      "Epoch 48/200, Train Loss: 15.4892, Val Loss: 16.2013\n",
      "Epoch 49/200, Train Loss: 15.3835, Val Loss: 15.9220\n",
      "Epoch 50/200, Train Loss: 15.3598, Val Loss: 16.2085\n",
      "Epoch 51/200, Train Loss: 15.4003, Val Loss: 16.0930\n",
      "Epoch 52/200, Train Loss: 15.2672, Val Loss: 15.9600\n",
      "Epoch 53/200, Train Loss: 15.3006, Val Loss: 15.9633\n",
      "Epoch 54/200, Train Loss: 15.3167, Val Loss: 16.1676\n",
      "Epoch 55/200, Train Loss: 15.1708, Val Loss: 16.1705\n",
      "Epoch 56/200, Train Loss: 15.1064, Val Loss: 16.2456\n",
      "Epoch 57/200, Train Loss: 15.1949, Val Loss: 15.9976\n",
      "Epoch 58/200, Train Loss: 15.0537, Val Loss: 16.1809\n",
      "Epoch 59/200, Train Loss: 14.9985, Val Loss: 16.3945\n",
      "Epoch 60/200, Train Loss: 15.0350, Val Loss: 15.9175\n",
      "Epoch 61/200, Train Loss: 14.9644, Val Loss: 16.1146\n",
      "Epoch 62/200, Train Loss: 15.0259, Val Loss: 16.3415\n",
      "Epoch 63/200, Train Loss: 14.9297, Val Loss: 16.2285\n",
      "Epoch 64/200, Train Loss: 14.9100, Val Loss: 16.1260\n",
      "Epoch 65/200, Train Loss: 14.8622, Val Loss: 16.2774\n",
      "Epoch 66/200, Train Loss: 14.6943, Val Loss: 16.1140\n",
      "Epoch 67/200, Train Loss: 14.6457, Val Loss: 16.5402\n",
      "Epoch 68/200, Train Loss: 14.5780, Val Loss: 16.3678\n",
      "Epoch 69/200, Train Loss: 14.5487, Val Loss: 16.4568\n",
      "Epoch 70/200, Train Loss: 14.4582, Val Loss: 16.3305\n",
      "Epoch 71/200, Train Loss: 14.4129, Val Loss: 16.8411\n",
      "Epoch 72/200, Train Loss: 14.4570, Val Loss: 16.3350\n",
      "Epoch 73/200, Train Loss: 14.2938, Val Loss: 16.4662\n",
      "Epoch 74/200, Train Loss: 14.3217, Val Loss: 16.3176\n",
      "Epoch 75/200, Train Loss: 14.3886, Val Loss: 16.6877\n",
      "Epoch 76/200, Train Loss: 14.2974, Val Loss: 16.3240\n",
      "Epoch 77/200, Train Loss: 14.1172, Val Loss: 16.6380\n",
      "Epoch 78/200, Train Loss: 14.1435, Val Loss: 16.3617\n",
      "Epoch 79/200, Train Loss: 14.0093, Val Loss: 16.4619\n",
      "Epoch 80/200, Train Loss: 14.0371, Val Loss: 16.4204\n",
      "Epoch 81/200, Train Loss: 13.9334, Val Loss: 16.5194\n",
      "Epoch 82/200, Train Loss: 13.8841, Val Loss: 16.3641\n",
      "Epoch 83/200, Train Loss: 13.8114, Val Loss: 16.8380\n",
      "Epoch 84/200, Train Loss: 13.8114, Val Loss: 17.1020\n",
      "Epoch 85/200, Train Loss: 13.7641, Val Loss: 16.9866\n",
      "Epoch 86/200, Train Loss: 13.7713, Val Loss: 16.6369\n",
      "Epoch 87/200, Train Loss: 13.6674, Val Loss: 16.8568\n",
      "Epoch 88/200, Train Loss: 13.7129, Val Loss: 16.7996\n",
      "Epoch 89/200, Train Loss: 13.6916, Val Loss: 16.6546\n",
      "Epoch 90/200, Train Loss: 13.5634, Val Loss: 16.4246\n",
      "Epoch 91/200, Train Loss: 13.5807, Val Loss: 16.5854\n",
      "Epoch 92/200, Train Loss: 13.5298, Val Loss: 17.2171\n",
      "Epoch 93/200, Train Loss: 13.4697, Val Loss: 16.7994\n",
      "Epoch 94/200, Train Loss: 13.2783, Val Loss: 17.0212\n",
      "Epoch 95/200, Train Loss: 13.3508, Val Loss: 16.6774\n",
      "Epoch 96/200, Train Loss: 13.2831, Val Loss: 16.4750\n",
      "Epoch 97/200, Train Loss: 13.3614, Val Loss: 16.9745\n",
      "Epoch 98/200, Train Loss: 13.1662, Val Loss: 16.7848\n",
      "Epoch 99/200, Train Loss: 13.0521, Val Loss: 16.7791\n",
      "Epoch 100/200, Train Loss: 13.0209, Val Loss: 16.7667\n",
      "Epoch 101/200, Train Loss: 13.0036, Val Loss: 16.6486\n",
      "Epoch 102/200, Train Loss: 13.1063, Val Loss: 17.0744\n",
      "Epoch 103/200, Train Loss: 13.0839, Val Loss: 16.7597\n",
      "Epoch 104/200, Train Loss: 13.0018, Val Loss: 17.1857\n",
      "Epoch 105/200, Train Loss: 12.7519, Val Loss: 16.7229\n",
      "Epoch 106/200, Train Loss: 12.7956, Val Loss: 16.8830\n",
      "Epoch 107/200, Train Loss: 12.7250, Val Loss: 16.9353\n",
      "Epoch 108/200, Train Loss: 12.7237, Val Loss: 17.4823\n",
      "Epoch 109/200, Train Loss: 12.6355, Val Loss: 17.1242\n",
      "Epoch 110/200, Train Loss: 12.6173, Val Loss: 17.0648\n",
      "Epoch 111/200, Train Loss: 12.4527, Val Loss: 17.1929\n",
      "Epoch 112/200, Train Loss: 12.4320, Val Loss: 17.2605\n",
      "Epoch 113/200, Train Loss: 12.3509, Val Loss: 17.1919\n",
      "Epoch 114/200, Train Loss: 12.3339, Val Loss: 17.5066\n",
      "Epoch 115/200, Train Loss: 12.3500, Val Loss: 17.4674\n",
      "Epoch 116/200, Train Loss: 12.2415, Val Loss: 17.1391\n",
      "Epoch 117/200, Train Loss: 12.2354, Val Loss: 17.4669\n",
      "Epoch 118/200, Train Loss: 12.1055, Val Loss: 17.4466\n",
      "Epoch 119/200, Train Loss: 12.1101, Val Loss: 17.7905\n",
      "Epoch 120/200, Train Loss: 12.1326, Val Loss: 17.5326\n",
      "Epoch 121/200, Train Loss: 12.0418, Val Loss: 17.4128\n",
      "Epoch 122/200, Train Loss: 11.9137, Val Loss: 17.4175\n",
      "Epoch 123/200, Train Loss: 11.9100, Val Loss: 17.8095\n",
      "Epoch 124/200, Train Loss: 11.9074, Val Loss: 17.6161\n",
      "Epoch 125/200, Train Loss: 11.8206, Val Loss: 17.8046\n",
      "Epoch 126/200, Train Loss: 11.8276, Val Loss: 17.4475\n",
      "Epoch 127/200, Train Loss: 11.7519, Val Loss: 17.8678\n",
      "Epoch 128/200, Train Loss: 11.7292, Val Loss: 17.6542\n",
      "Epoch 129/200, Train Loss: 11.6645, Val Loss: 17.8831\n",
      "Epoch 130/200, Train Loss: 11.5565, Val Loss: 17.9383\n",
      "Epoch 131/200, Train Loss: 11.5102, Val Loss: 17.6895\n",
      "Epoch 132/200, Train Loss: 11.5232, Val Loss: 18.1415\n",
      "Epoch 133/200, Train Loss: 11.4840, Val Loss: 17.9530\n",
      "Epoch 134/200, Train Loss: 11.4325, Val Loss: 17.8456\n",
      "Epoch 135/200, Train Loss: 11.3651, Val Loss: 18.1467\n",
      "Epoch 136/200, Train Loss: 11.4611, Val Loss: 17.5915\n",
      "Epoch 137/200, Train Loss: 11.3606, Val Loss: 17.8216\n",
      "Epoch 138/200, Train Loss: 11.2676, Val Loss: 17.8373\n",
      "Epoch 139/200, Train Loss: 11.2159, Val Loss: 18.3475\n",
      "Epoch 140/200, Train Loss: 11.2698, Val Loss: 18.3980\n",
      "Epoch 141/200, Train Loss: 11.1479, Val Loss: 18.0206\n",
      "Epoch 142/200, Train Loss: 11.0976, Val Loss: 17.7800\n",
      "Epoch 143/200, Train Loss: 10.9788, Val Loss: 18.2884\n",
      "Epoch 144/200, Train Loss: 10.9201, Val Loss: 17.9573\n",
      "Epoch 145/200, Train Loss: 10.9236, Val Loss: 18.1588\n",
      "Epoch 146/200, Train Loss: 10.9108, Val Loss: 17.9374\n",
      "Epoch 147/200, Train Loss: 10.9822, Val Loss: 18.3653\n",
      "Epoch 148/200, Train Loss: 10.9162, Val Loss: 18.2187\n",
      "Epoch 149/200, Train Loss: 10.8609, Val Loss: 18.2755\n",
      "Epoch 150/200, Train Loss: 10.8945, Val Loss: 18.0209\n",
      "Epoch 151/200, Train Loss: 10.9982, Val Loss: 17.9186\n",
      "Epoch 152/200, Train Loss: 10.8866, Val Loss: 18.0843\n",
      "Epoch 153/200, Train Loss: 10.5903, Val Loss: 18.0441\n",
      "Epoch 154/200, Train Loss: 10.6829, Val Loss: 18.2704\n",
      "Epoch 155/200, Train Loss: 10.6044, Val Loss: 18.6683\n",
      "Epoch 156/200, Train Loss: 10.5556, Val Loss: 18.3075\n",
      "Epoch 157/200, Train Loss: 10.4983, Val Loss: 18.3216\n",
      "Epoch 158/200, Train Loss: 10.4463, Val Loss: 18.5956\n",
      "Epoch 159/200, Train Loss: 10.5875, Val Loss: 18.2332\n",
      "Epoch 160/200, Train Loss: 10.5037, Val Loss: 18.1085\n",
      "Epoch 161/200, Train Loss: 10.3859, Val Loss: 18.3068\n",
      "Epoch 162/200, Train Loss: 10.3886, Val Loss: 18.0098\n",
      "Epoch 163/200, Train Loss: 10.3669, Val Loss: 18.1271\n",
      "Epoch 164/200, Train Loss: 10.2785, Val Loss: 18.4240\n",
      "Epoch 165/200, Train Loss: 10.2845, Val Loss: 18.1703\n",
      "Epoch 166/200, Train Loss: 10.2132, Val Loss: 17.8197\n",
      "Epoch 167/200, Train Loss: 10.1825, Val Loss: 18.1704\n",
      "Epoch 168/200, Train Loss: 10.2054, Val Loss: 18.3956\n",
      "Epoch 169/200, Train Loss: 10.2929, Val Loss: 18.3049\n",
      "Epoch 170/200, Train Loss: 10.1512, Val Loss: 18.4291\n",
      "Epoch 171/200, Train Loss: 10.0159, Val Loss: 18.6322\n",
      "Epoch 172/200, Train Loss: 10.1493, Val Loss: 18.6625\n",
      "Epoch 173/200, Train Loss: 10.0669, Val Loss: 18.2404\n",
      "Epoch 174/200, Train Loss: 9.9967, Val Loss: 18.1137\n",
      "Epoch 175/200, Train Loss: 9.9210, Val Loss: 18.6533\n",
      "Epoch 176/200, Train Loss: 10.0571, Val Loss: 18.0079\n",
      "Epoch 177/200, Train Loss: 9.8931, Val Loss: 18.3643\n",
      "Epoch 178/200, Train Loss: 9.8113, Val Loss: 17.7952\n",
      "Epoch 179/200, Train Loss: 9.8079, Val Loss: 18.2882\n",
      "Epoch 180/200, Train Loss: 9.6987, Val Loss: 18.2582\n",
      "Epoch 181/200, Train Loss: 9.6065, Val Loss: 18.4645\n",
      "Epoch 182/200, Train Loss: 9.6580, Val Loss: 18.9783\n",
      "Epoch 183/200, Train Loss: 9.5828, Val Loss: 18.3930\n",
      "Epoch 184/200, Train Loss: 9.6735, Val Loss: 18.2362\n",
      "Epoch 185/200, Train Loss: 9.6100, Val Loss: 18.3681\n",
      "Epoch 186/200, Train Loss: 9.7715, Val Loss: 18.3892\n",
      "Epoch 187/200, Train Loss: 9.6903, Val Loss: 18.6067\n",
      "Epoch 188/200, Train Loss: 9.5101, Val Loss: 17.8915\n",
      "Epoch 189/200, Train Loss: 9.4117, Val Loss: 18.5963\n",
      "Epoch 190/200, Train Loss: 9.3870, Val Loss: 18.7701\n",
      "Epoch 191/200, Train Loss: 9.4792, Val Loss: 18.3894\n",
      "Epoch 192/200, Train Loss: 9.3652, Val Loss: 18.5119\n",
      "Epoch 193/200, Train Loss: 9.4384, Val Loss: 18.5487\n",
      "Epoch 194/200, Train Loss: 9.4202, Val Loss: 17.9585\n",
      "Epoch 195/200, Train Loss: 9.3100, Val Loss: 18.8494\n",
      "Epoch 196/200, Train Loss: 9.3022, Val Loss: 17.9805\n",
      "Epoch 197/200, Train Loss: 9.3846, Val Loss: 18.5861\n",
      "Epoch 198/200, Train Loss: 9.2530, Val Loss: 18.9928\n",
      "Epoch 199/200, Train Loss: 9.2384, Val Loss: 18.4571\n",
      "Epoch 200/200, Train Loss: 9.1801, Val Loss: 18.3893\n",
      "\n",
      "Loaded best model (Val Loss: 15.7259) for final hidden state extraction.\n",
      "Saved best model for NMRNN_NoSpatial_ModReadout (samples=320) to results_data_size_sweep/20250514_045146/samples_320/NMRNN_NoSpatial_ModReadout_samples_320_best.pt\n",
      "\n",
      "--- Performing Decodability Analysis for NMRNN_NoSpatial_ModReadout (samples=320, k=15) ---\n",
      "  Analyzing decodability for NMRNN_NoSpatial_ModReadout...\n",
      "  Hidden states shape: torch.Size([160, 200, 128])\n",
      "  Coefficients shape: torch.Size([160, 15])\n",
      "  Processed hidden states shape for decoder: torch.Size([160, 128])\n",
      "  RidgeCV Decoder for NMRNN_NoSpatial_ModReadout - Test MSE: 1.8078, Test R2: 0.0854 (best alpha: 100.0000)\n",
      "  Decodability plot saved to results_data_size_sweep/20250514_045146/samples_320/decodability_NMRNN_NoSpatial_ModReadout_coeff1.png\n",
      "Decodability (R2 score) for NMRNN_NoSpatial_ModReadout (samples=320): 0.0854\n",
      "\n",
      "--- Training NMRNN_Spatial_FixedReadout (samples=320, k=15) ---\n",
      "Number of parameters: 66449\n",
      "Epoch 1/200, Train Loss: 17.4673, Val Loss: 15.8083\n",
      "  New best validation loss: 15.8083\n",
      "Epoch 2/200, Train Loss: 17.2664, Val Loss: 15.7923\n",
      "  New best validation loss: 15.7923\n",
      "Epoch 3/200, Train Loss: 17.1945, Val Loss: 15.8579\n",
      "Epoch 4/200, Train Loss: 17.0915, Val Loss: 15.8257\n",
      "Epoch 5/200, Train Loss: 17.0237, Val Loss: 15.8451\n",
      "Epoch 6/200, Train Loss: 16.9911, Val Loss: 15.8554\n",
      "Epoch 7/200, Train Loss: 16.9410, Val Loss: 15.8371\n",
      "Epoch 8/200, Train Loss: 16.8977, Val Loss: 15.8561\n",
      "Epoch 9/200, Train Loss: 16.8493, Val Loss: 15.8568\n",
      "Epoch 10/200, Train Loss: 16.8197, Val Loss: 15.8888\n",
      "Epoch 11/200, Train Loss: 16.7603, Val Loss: 15.8916\n",
      "Epoch 12/200, Train Loss: 16.6984, Val Loss: 15.8353\n",
      "Epoch 13/200, Train Loss: 16.6154, Val Loss: 15.8715\n",
      "Epoch 14/200, Train Loss: 16.5569, Val Loss: 15.8368\n",
      "Epoch 15/200, Train Loss: 16.4536, Val Loss: 15.8163\n",
      "Epoch 16/200, Train Loss: 16.3784, Val Loss: 15.8083\n",
      "Epoch 17/200, Train Loss: 16.2908, Val Loss: 15.7692\n",
      "  New best validation loss: 15.7692\n",
      "Epoch 18/200, Train Loss: 16.2136, Val Loss: 15.8236\n",
      "Epoch 19/200, Train Loss: 16.2537, Val Loss: 15.9146\n",
      "Epoch 20/200, Train Loss: 16.1656, Val Loss: 15.8970\n",
      "Epoch 21/200, Train Loss: 16.1510, Val Loss: 15.7402\n",
      "  New best validation loss: 15.7402\n",
      "Epoch 22/200, Train Loss: 16.0815, Val Loss: 15.8433\n",
      "Epoch 23/200, Train Loss: 15.9625, Val Loss: 15.8232\n",
      "Epoch 24/200, Train Loss: 15.9192, Val Loss: 15.9163\n",
      "Epoch 25/200, Train Loss: 15.8048, Val Loss: 15.8056\n",
      "Epoch 26/200, Train Loss: 15.7470, Val Loss: 15.9024\n",
      "Epoch 27/200, Train Loss: 15.6614, Val Loss: 15.9274\n",
      "Epoch 28/200, Train Loss: 15.7074, Val Loss: 15.7164\n",
      "  New best validation loss: 15.7164\n",
      "Epoch 29/200, Train Loss: 15.6554, Val Loss: 15.8825\n",
      "Epoch 30/200, Train Loss: 15.5112, Val Loss: 16.0452\n",
      "Epoch 31/200, Train Loss: 15.4802, Val Loss: 15.9440\n",
      "Epoch 32/200, Train Loss: 15.4037, Val Loss: 15.8844\n",
      "Epoch 33/200, Train Loss: 15.3690, Val Loss: 16.0449\n",
      "Epoch 34/200, Train Loss: 15.2643, Val Loss: 15.9903\n",
      "Epoch 35/200, Train Loss: 15.2135, Val Loss: 15.8775\n",
      "Epoch 36/200, Train Loss: 15.0718, Val Loss: 15.9987\n",
      "Epoch 37/200, Train Loss: 14.9972, Val Loss: 16.1790\n",
      "Epoch 38/200, Train Loss: 14.8871, Val Loss: 15.9364\n",
      "Epoch 39/200, Train Loss: 14.8113, Val Loss: 16.1713\n",
      "Epoch 40/200, Train Loss: 14.8014, Val Loss: 15.9798\n",
      "Epoch 41/200, Train Loss: 14.6953, Val Loss: 16.1560\n",
      "Epoch 42/200, Train Loss: 14.5456, Val Loss: 16.0829\n",
      "Epoch 43/200, Train Loss: 14.4979, Val Loss: 16.1369\n",
      "Epoch 44/200, Train Loss: 14.4550, Val Loss: 16.0226\n",
      "Epoch 45/200, Train Loss: 14.3863, Val Loss: 16.1717\n",
      "Epoch 46/200, Train Loss: 14.2692, Val Loss: 16.0443\n",
      "Epoch 47/200, Train Loss: 14.3293, Val Loss: 16.2931\n",
      "Epoch 48/200, Train Loss: 14.3221, Val Loss: 16.2558\n",
      "Epoch 49/200, Train Loss: 14.2048, Val Loss: 15.9957\n",
      "Epoch 50/200, Train Loss: 14.2040, Val Loss: 16.2750\n",
      "Epoch 51/200, Train Loss: 13.9976, Val Loss: 16.2947\n",
      "Epoch 52/200, Train Loss: 13.9077, Val Loss: 16.0414\n",
      "Epoch 53/200, Train Loss: 13.8761, Val Loss: 15.9851\n",
      "Epoch 54/200, Train Loss: 13.7828, Val Loss: 16.3006\n",
      "Epoch 55/200, Train Loss: 13.6698, Val Loss: 16.3097\n",
      "Epoch 56/200, Train Loss: 13.5790, Val Loss: 16.0497\n",
      "Epoch 57/200, Train Loss: 13.4975, Val Loss: 16.1497\n",
      "Epoch 58/200, Train Loss: 13.4732, Val Loss: 16.3532\n",
      "Epoch 59/200, Train Loss: 13.4204, Val Loss: 16.2531\n",
      "Epoch 60/200, Train Loss: 13.4741, Val Loss: 15.8858\n",
      "Epoch 61/200, Train Loss: 13.2971, Val Loss: 16.4569\n",
      "Epoch 62/200, Train Loss: 13.2913, Val Loss: 16.1959\n",
      "Epoch 63/200, Train Loss: 13.2852, Val Loss: 16.1372\n",
      "Epoch 64/200, Train Loss: 13.1886, Val Loss: 15.7946\n",
      "Epoch 65/200, Train Loss: 12.9902, Val Loss: 16.1092\n",
      "Epoch 66/200, Train Loss: 12.8330, Val Loss: 16.1221\n",
      "Epoch 67/200, Train Loss: 12.7925, Val Loss: 16.0256\n",
      "Epoch 68/200, Train Loss: 12.8128, Val Loss: 16.5663\n",
      "Epoch 69/200, Train Loss: 12.6691, Val Loss: 16.0052\n",
      "Epoch 70/200, Train Loss: 12.5479, Val Loss: 16.0710\n",
      "Epoch 71/200, Train Loss: 12.5482, Val Loss: 16.0935\n",
      "Epoch 72/200, Train Loss: 12.4139, Val Loss: 15.8597\n",
      "Epoch 73/200, Train Loss: 12.4474, Val Loss: 16.2554\n",
      "Epoch 74/200, Train Loss: 12.4326, Val Loss: 15.8921\n",
      "Epoch 75/200, Train Loss: 12.2524, Val Loss: 16.3104\n",
      "Epoch 76/200, Train Loss: 12.1719, Val Loss: 16.4571\n",
      "Epoch 77/200, Train Loss: 12.1260, Val Loss: 16.1707\n",
      "Epoch 78/200, Train Loss: 12.1799, Val Loss: 16.5155\n",
      "Epoch 79/200, Train Loss: 12.0513, Val Loss: 16.3296\n",
      "Epoch 80/200, Train Loss: 11.8995, Val Loss: 16.4121\n",
      "Epoch 81/200, Train Loss: 11.8702, Val Loss: 16.1701\n",
      "Epoch 82/200, Train Loss: 11.8203, Val Loss: 16.3988\n",
      "Epoch 83/200, Train Loss: 11.8106, Val Loss: 16.2739\n",
      "Epoch 84/200, Train Loss: 11.7417, Val Loss: 16.3785\n",
      "Epoch 85/200, Train Loss: 11.5508, Val Loss: 16.3417\n",
      "Epoch 86/200, Train Loss: 11.6320, Val Loss: 16.2408\n",
      "Epoch 87/200, Train Loss: 11.6751, Val Loss: 16.6465\n",
      "Epoch 88/200, Train Loss: 11.7483, Val Loss: 16.5027\n",
      "Epoch 89/200, Train Loss: 11.4869, Val Loss: 16.6716\n",
      "Epoch 90/200, Train Loss: 11.4975, Val Loss: 16.6406\n",
      "Epoch 91/200, Train Loss: 11.3693, Val Loss: 16.7572\n",
      "Epoch 92/200, Train Loss: 11.4507, Val Loss: 16.3630\n",
      "Epoch 93/200, Train Loss: 11.5055, Val Loss: 16.7944\n",
      "Epoch 94/200, Train Loss: 11.2479, Val Loss: 16.8276\n",
      "Epoch 95/200, Train Loss: 11.3441, Val Loss: 16.6204\n",
      "Epoch 96/200, Train Loss: 11.1489, Val Loss: 16.4335\n",
      "Epoch 97/200, Train Loss: 11.0969, Val Loss: 16.9452\n",
      "Epoch 98/200, Train Loss: 11.0722, Val Loss: 17.2765\n",
      "Epoch 99/200, Train Loss: 11.3508, Val Loss: 16.8212\n",
      "Epoch 100/200, Train Loss: 11.2122, Val Loss: 16.5164\n",
      "Epoch 101/200, Train Loss: 10.9730, Val Loss: 16.5956\n",
      "Epoch 102/200, Train Loss: 10.8240, Val Loss: 16.5189\n",
      "Epoch 103/200, Train Loss: 10.7550, Val Loss: 16.9562\n",
      "Epoch 104/200, Train Loss: 10.8614, Val Loss: 16.8511\n",
      "Epoch 105/200, Train Loss: 10.9510, Val Loss: 16.8422\n",
      "Epoch 106/200, Train Loss: 10.8860, Val Loss: 16.8715\n",
      "Epoch 107/200, Train Loss: 10.9622, Val Loss: 16.9132\n",
      "Epoch 108/200, Train Loss: 10.8706, Val Loss: 16.4127\n",
      "Epoch 109/200, Train Loss: 10.7187, Val Loss: 16.5515\n",
      "Epoch 110/200, Train Loss: 10.6467, Val Loss: 16.3947\n",
      "Epoch 111/200, Train Loss: 10.5762, Val Loss: 16.9068\n",
      "Epoch 112/200, Train Loss: 10.6145, Val Loss: 16.5913\n",
      "Epoch 113/200, Train Loss: 10.4074, Val Loss: 16.6910\n",
      "Epoch 114/200, Train Loss: 10.3654, Val Loss: 16.8917\n",
      "Epoch 115/200, Train Loss: 10.3455, Val Loss: 16.7035\n",
      "Epoch 116/200, Train Loss: 10.3508, Val Loss: 16.7514\n",
      "Epoch 117/200, Train Loss: 10.3759, Val Loss: 16.9832\n",
      "Epoch 118/200, Train Loss: 10.2741, Val Loss: 16.9345\n",
      "Epoch 119/200, Train Loss: 10.2425, Val Loss: 16.7750\n",
      "Epoch 120/200, Train Loss: 10.2087, Val Loss: 16.9388\n",
      "Epoch 121/200, Train Loss: 10.1641, Val Loss: 16.9126\n",
      "Epoch 122/200, Train Loss: 10.1372, Val Loss: 16.9495\n",
      "Epoch 123/200, Train Loss: 10.0896, Val Loss: 16.5959\n",
      "Epoch 124/200, Train Loss: 10.1344, Val Loss: 17.3703\n",
      "Epoch 125/200, Train Loss: 10.0394, Val Loss: 16.5152\n",
      "Epoch 126/200, Train Loss: 10.0122, Val Loss: 16.8178\n",
      "Epoch 127/200, Train Loss: 9.9550, Val Loss: 17.0863\n",
      "Epoch 128/200, Train Loss: 9.9308, Val Loss: 17.3535\n",
      "Epoch 129/200, Train Loss: 9.9351, Val Loss: 17.2107\n",
      "Epoch 130/200, Train Loss: 9.9492, Val Loss: 16.5771\n",
      "Epoch 131/200, Train Loss: 9.9747, Val Loss: 17.1401\n",
      "Epoch 132/200, Train Loss: 9.8204, Val Loss: 16.9327\n",
      "Epoch 133/200, Train Loss: 9.8110, Val Loss: 17.0183\n",
      "Epoch 134/200, Train Loss: 9.9131, Val Loss: 16.8082\n",
      "Epoch 135/200, Train Loss: 9.6813, Val Loss: 17.1675\n",
      "Epoch 136/200, Train Loss: 9.6577, Val Loss: 17.3982\n",
      "Epoch 137/200, Train Loss: 9.6333, Val Loss: 17.0457\n",
      "Epoch 138/200, Train Loss: 9.5687, Val Loss: 16.6967\n",
      "Epoch 139/200, Train Loss: 9.5029, Val Loss: 17.2995\n",
      "Epoch 140/200, Train Loss: 9.4947, Val Loss: 16.7590\n",
      "Epoch 141/200, Train Loss: 9.5268, Val Loss: 17.3335\n",
      "Epoch 142/200, Train Loss: 9.7067, Val Loss: 17.0778\n",
      "Epoch 143/200, Train Loss: 9.5519, Val Loss: 17.2538\n",
      "Epoch 144/200, Train Loss: 9.5644, Val Loss: 17.1928\n",
      "Epoch 145/200, Train Loss: 9.5370, Val Loss: 17.2645\n",
      "Epoch 146/200, Train Loss: 9.3893, Val Loss: 16.6848\n",
      "Epoch 147/200, Train Loss: 9.4021, Val Loss: 17.0110\n",
      "Epoch 148/200, Train Loss: 9.2121, Val Loss: 17.0196\n",
      "Epoch 149/200, Train Loss: 9.3887, Val Loss: 17.0789\n",
      "Epoch 150/200, Train Loss: 9.2328, Val Loss: 17.2257\n",
      "Epoch 151/200, Train Loss: 9.2717, Val Loss: 16.8093\n",
      "Epoch 152/200, Train Loss: 9.2379, Val Loss: 17.4140\n",
      "Epoch 153/200, Train Loss: 9.1361, Val Loss: 16.6631\n",
      "Epoch 154/200, Train Loss: 9.1464, Val Loss: 16.9820\n",
      "Epoch 155/200, Train Loss: 9.1521, Val Loss: 17.2788\n",
      "Epoch 156/200, Train Loss: 9.0485, Val Loss: 17.1351\n",
      "Epoch 157/200, Train Loss: 9.0148, Val Loss: 17.1270\n",
      "Epoch 158/200, Train Loss: 9.1129, Val Loss: 17.3063\n",
      "Epoch 159/200, Train Loss: 9.0977, Val Loss: 16.6932\n",
      "Epoch 160/200, Train Loss: 9.0291, Val Loss: 17.4823\n",
      "Epoch 161/200, Train Loss: 9.0202, Val Loss: 17.0901\n",
      "Epoch 162/200, Train Loss: 9.2347, Val Loss: 17.2331\n",
      "Epoch 163/200, Train Loss: 9.0264, Val Loss: 17.0811\n",
      "Epoch 164/200, Train Loss: 8.8126, Val Loss: 16.8992\n",
      "Epoch 165/200, Train Loss: 8.8348, Val Loss: 16.9504\n",
      "Epoch 166/200, Train Loss: 8.9588, Val Loss: 16.5577\n",
      "Epoch 167/200, Train Loss: 8.8088, Val Loss: 17.0095\n",
      "Epoch 168/200, Train Loss: 8.7884, Val Loss: 16.9969\n",
      "Epoch 169/200, Train Loss: 8.8187, Val Loss: 17.3585\n",
      "Epoch 170/200, Train Loss: 8.8697, Val Loss: 17.3507\n",
      "Epoch 171/200, Train Loss: 8.9154, Val Loss: 17.0635\n",
      "Epoch 172/200, Train Loss: 8.8494, Val Loss: 17.0475\n",
      "Epoch 173/200, Train Loss: 8.9439, Val Loss: 17.2780\n",
      "Epoch 174/200, Train Loss: 8.8711, Val Loss: 16.6736\n",
      "Epoch 175/200, Train Loss: 8.7841, Val Loss: 16.9212\n",
      "Epoch 176/200, Train Loss: 8.6157, Val Loss: 17.1834\n",
      "Epoch 177/200, Train Loss: 8.6862, Val Loss: 17.2488\n",
      "Epoch 178/200, Train Loss: 8.5855, Val Loss: 16.9724\n",
      "Epoch 179/200, Train Loss: 8.5473, Val Loss: 17.1089\n",
      "Epoch 180/200, Train Loss: 8.7110, Val Loss: 16.9089\n",
      "Epoch 181/200, Train Loss: 8.6151, Val Loss: 17.1707\n",
      "Epoch 182/200, Train Loss: 8.4465, Val Loss: 17.1684\n",
      "Epoch 183/200, Train Loss: 8.4076, Val Loss: 17.3973\n",
      "Epoch 184/200, Train Loss: 8.4122, Val Loss: 16.8129\n",
      "Epoch 185/200, Train Loss: 8.3124, Val Loss: 16.8210\n",
      "Epoch 186/200, Train Loss: 8.3278, Val Loss: 17.4092\n",
      "Epoch 187/200, Train Loss: 8.3314, Val Loss: 17.4128\n",
      "Epoch 188/200, Train Loss: 8.3221, Val Loss: 17.1571\n",
      "Epoch 189/200, Train Loss: 8.2927, Val Loss: 17.1778\n",
      "Epoch 190/200, Train Loss: 8.3976, Val Loss: 17.5298\n",
      "Epoch 191/200, Train Loss: 8.4953, Val Loss: 17.0660\n",
      "Epoch 192/200, Train Loss: 8.4935, Val Loss: 17.2072\n",
      "Epoch 193/200, Train Loss: 8.3139, Val Loss: 17.3415\n",
      "Epoch 194/200, Train Loss: 8.1721, Val Loss: 17.3299\n",
      "Epoch 195/200, Train Loss: 8.2067, Val Loss: 17.1293\n",
      "Epoch 196/200, Train Loss: 8.2513, Val Loss: 17.3831\n",
      "Epoch 197/200, Train Loss: 8.1302, Val Loss: 17.0476\n",
      "Epoch 198/200, Train Loss: 8.2628, Val Loss: 17.2337\n",
      "Epoch 199/200, Train Loss: 8.2861, Val Loss: 17.1196\n",
      "Epoch 200/200, Train Loss: 8.2291, Val Loss: 17.5012\n",
      "\n",
      "Loaded best model (Val Loss: 15.7164) for final hidden state extraction.\n",
      "Saved best model for NMRNN_Spatial_FixedReadout (samples=320) to results_data_size_sweep/20250514_045146/samples_320/NMRNN_Spatial_FixedReadout_samples_320_best.pt\n",
      "\n",
      "--- Performing Decodability Analysis for NMRNN_Spatial_FixedReadout (samples=320, k=15) ---\n",
      "  Analyzing decodability for NMRNN_Spatial_FixedReadout...\n",
      "  Hidden states shape: torch.Size([160, 200, 128])\n",
      "  Coefficients shape: torch.Size([160, 15])\n",
      "  Processed hidden states shape for decoder: torch.Size([160, 128])\n",
      "  RidgeCV Decoder for NMRNN_Spatial_FixedReadout - Test MSE: 1.8041, Test R2: 0.0825 (best alpha: 100.0000)\n",
      "  Decodability plot saved to results_data_size_sweep/20250514_045146/samples_320/decodability_NMRNN_Spatial_FixedReadout_coeff1.png\n",
      "Decodability (R2 score) for NMRNN_Spatial_FixedReadout (samples=320): 0.0825\n",
      "Learning curves saved to results_data_size_sweep/20250514_045146/samples_320/learning_curves_validation.png\n",
      "\n",
      "Validation learning curves for samples=320 plotted.\n",
      "Learning curves saved to results_data_size_sweep/20250514_045146/samples_320/learning_curves_training.png\n",
      "\n",
      "Training learning curves for samples=320 plotted.\n",
      "Decodability summary for samples=320 saved to results_data_size_sweep/20250514_045146/samples_320/decodability_summary.txt\n",
      "\n",
      "========================= Running for train_samples: 640, k: 15 =========================\n",
      "Results for train_samples=640 will be saved in: results_data_size_sweep/20250514_045146/samples_640\n",
      "Loading dataset...\n",
      "Dataset loaded.\n",
      "Warning: Modulated readout requested but N_nm is 0. Using fixed readout.\n",
      "\n",
      "--- Training RNN_Vanillia (samples=640, k=15) ---\n",
      "Number of parameters: 51301\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/conda/lib/python3.10/site-packages/torch/nn/init.py:405: UserWarning: Initializing zero-element tensors is a no-op\n",
      "  warnings.warn(\"Initializing zero-element tensors is a no-op\")\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/200, Train Loss: 16.9974, Val Loss: 15.7786\n",
      "  New best validation loss: 15.7786\n",
      "Epoch 2/200, Train Loss: 16.7597, Val Loss: 15.7373\n",
      "  New best validation loss: 15.7373\n",
      "Epoch 3/200, Train Loss: 16.6888, Val Loss: 15.8003\n",
      "Epoch 4/200, Train Loss: 16.6779, Val Loss: 15.7319\n",
      "  New best validation loss: 15.7319\n",
      "Epoch 5/200, Train Loss: 16.6515, Val Loss: 15.7488\n",
      "Epoch 6/200, Train Loss: 16.6264, Val Loss: 15.7518\n",
      "Epoch 7/200, Train Loss: 16.6266, Val Loss: 15.7637\n",
      "Epoch 8/200, Train Loss: 16.6101, Val Loss: 15.7816\n",
      "Epoch 9/200, Train Loss: 16.6070, Val Loss: 15.7697\n",
      "Epoch 10/200, Train Loss: 16.5964, Val Loss: 15.7368\n",
      "Epoch 11/200, Train Loss: 16.5915, Val Loss: 15.7590\n",
      "Epoch 12/200, Train Loss: 16.5913, Val Loss: 15.7494\n",
      "Epoch 13/200, Train Loss: 16.5787, Val Loss: 15.7554\n",
      "Epoch 14/200, Train Loss: 16.5748, Val Loss: 15.7412\n",
      "Epoch 15/200, Train Loss: 16.5774, Val Loss: 15.7624\n",
      "Epoch 16/200, Train Loss: 16.5778, Val Loss: 15.7639\n",
      "Epoch 17/200, Train Loss: 16.5610, Val Loss: 15.7503\n",
      "Epoch 18/200, Train Loss: 16.5651, Val Loss: 15.7616\n",
      "Epoch 19/200, Train Loss: 16.5543, Val Loss: 15.7670\n",
      "Epoch 20/200, Train Loss: 16.5463, Val Loss: 15.7590\n",
      "Epoch 21/200, Train Loss: 16.5431, Val Loss: 15.7570\n",
      "Epoch 22/200, Train Loss: 16.5350, Val Loss: 15.7521\n",
      "Epoch 23/200, Train Loss: 16.5498, Val Loss: 15.7392\n",
      "Epoch 24/200, Train Loss: 16.5463, Val Loss: 15.7199\n",
      "  New best validation loss: 15.7199\n",
      "Epoch 25/200, Train Loss: 16.5303, Val Loss: 15.7267\n",
      "Epoch 26/200, Train Loss: 16.5224, Val Loss: 15.7668\n",
      "Epoch 27/200, Train Loss: 16.5182, Val Loss: 15.7614\n",
      "Epoch 28/200, Train Loss: 16.5352, Val Loss: 15.7675\n",
      "Epoch 29/200, Train Loss: 16.5023, Val Loss: 15.7409\n",
      "Epoch 30/200, Train Loss: 16.4977, Val Loss: 15.7212\n",
      "Epoch 31/200, Train Loss: 16.4940, Val Loss: 15.7316\n",
      "Epoch 32/200, Train Loss: 16.4858, Val Loss: 15.7624\n",
      "Epoch 33/200, Train Loss: 16.4788, Val Loss: 15.8048\n",
      "Epoch 34/200, Train Loss: 16.4851, Val Loss: 15.7327\n",
      "Epoch 35/200, Train Loss: 16.4710, Val Loss: 15.7483\n",
      "Epoch 36/200, Train Loss: 16.4670, Val Loss: 15.7646\n",
      "Epoch 37/200, Train Loss: 16.4604, Val Loss: 15.7423\n",
      "Epoch 38/200, Train Loss: 16.4520, Val Loss: 15.7345\n",
      "Epoch 39/200, Train Loss: 16.4443, Val Loss: 15.7682\n",
      "Epoch 40/200, Train Loss: 16.4378, Val Loss: 15.7269\n",
      "Epoch 41/200, Train Loss: 16.4383, Val Loss: 15.7729\n",
      "Epoch 42/200, Train Loss: 16.4207, Val Loss: 15.7573\n",
      "Epoch 43/200, Train Loss: 16.4222, Val Loss: 15.7197\n",
      "  New best validation loss: 15.7197\n",
      "Epoch 44/200, Train Loss: 16.4154, Val Loss: 15.7300\n",
      "Epoch 45/200, Train Loss: 16.4094, Val Loss: 15.7088\n",
      "  New best validation loss: 15.7088\n",
      "Epoch 46/200, Train Loss: 16.4061, Val Loss: 15.7613\n",
      "Epoch 47/200, Train Loss: 16.3996, Val Loss: 15.7588\n",
      "Epoch 48/200, Train Loss: 16.3894, Val Loss: 15.7386\n",
      "Epoch 49/200, Train Loss: 16.3826, Val Loss: 15.7233\n",
      "Epoch 50/200, Train Loss: 16.3780, Val Loss: 15.7441\n",
      "Epoch 51/200, Train Loss: 16.3746, Val Loss: 15.7383\n",
      "Epoch 52/200, Train Loss: 16.3757, Val Loss: 15.7203\n",
      "Epoch 53/200, Train Loss: 16.3655, Val Loss: 15.7542\n",
      "Epoch 54/200, Train Loss: 16.3550, Val Loss: 15.7509\n",
      "Epoch 55/200, Train Loss: 16.3498, Val Loss: 15.7668\n",
      "Epoch 56/200, Train Loss: 16.3508, Val Loss: 15.7446\n",
      "Epoch 57/200, Train Loss: 16.3442, Val Loss: 15.7186\n",
      "Epoch 58/200, Train Loss: 16.3347, Val Loss: 15.7384\n",
      "Epoch 59/200, Train Loss: 16.3252, Val Loss: 15.7278\n",
      "Epoch 60/200, Train Loss: 16.3236, Val Loss: 15.7623\n",
      "Epoch 61/200, Train Loss: 16.3206, Val Loss: 15.7240\n",
      "Epoch 62/200, Train Loss: 16.3160, Val Loss: 15.7366\n",
      "Epoch 63/200, Train Loss: 16.3068, Val Loss: 15.7452\n",
      "Epoch 64/200, Train Loss: 16.3041, Val Loss: 15.7692\n",
      "Epoch 65/200, Train Loss: 16.2957, Val Loss: 15.7063\n",
      "  New best validation loss: 15.7063\n",
      "Epoch 66/200, Train Loss: 16.2888, Val Loss: 15.7670\n",
      "Epoch 67/200, Train Loss: 16.2872, Val Loss: 15.7256\n",
      "Epoch 68/200, Train Loss: 16.2817, Val Loss: 15.7013\n",
      "  New best validation loss: 15.7013\n",
      "Epoch 69/200, Train Loss: 16.2665, Val Loss: 15.7660\n",
      "Epoch 70/200, Train Loss: 16.2835, Val Loss: 15.7000\n",
      "  New best validation loss: 15.7000\n",
      "Epoch 71/200, Train Loss: 16.2630, Val Loss: 15.7204\n",
      "Epoch 72/200, Train Loss: 16.2638, Val Loss: 15.6908\n",
      "  New best validation loss: 15.6908\n",
      "Epoch 73/200, Train Loss: 16.2577, Val Loss: 15.7741\n",
      "Epoch 74/200, Train Loss: 16.2398, Val Loss: 15.7326\n",
      "Epoch 75/200, Train Loss: 16.2351, Val Loss: 15.7562\n",
      "Epoch 76/200, Train Loss: 16.2544, Val Loss: 15.7071\n",
      "Epoch 77/200, Train Loss: 16.2344, Val Loss: 15.7243\n",
      "Epoch 78/200, Train Loss: 16.2073, Val Loss: 15.6990\n",
      "Epoch 79/200, Train Loss: 16.2086, Val Loss: 15.7282\n",
      "Epoch 80/200, Train Loss: 16.2042, Val Loss: 15.7122\n",
      "Epoch 81/200, Train Loss: 16.1824, Val Loss: 15.7623\n",
      "Epoch 82/200, Train Loss: 16.2006, Val Loss: 15.7505\n",
      "Epoch 83/200, Train Loss: 16.1866, Val Loss: 15.6508\n",
      "  New best validation loss: 15.6508\n",
      "Epoch 84/200, Train Loss: 16.1957, Val Loss: 15.7344\n",
      "Epoch 85/200, Train Loss: 16.1604, Val Loss: 15.6545\n",
      "Epoch 86/200, Train Loss: 16.1544, Val Loss: 15.7175\n",
      "Epoch 87/200, Train Loss: 16.1508, Val Loss: 15.6765\n",
      "Epoch 88/200, Train Loss: 16.1391, Val Loss: 15.6534\n",
      "Epoch 89/200, Train Loss: 16.1639, Val Loss: 15.6813\n",
      "Epoch 90/200, Train Loss: 16.1324, Val Loss: 15.6496\n",
      "  New best validation loss: 15.6496\n",
      "Epoch 91/200, Train Loss: 16.1129, Val Loss: 15.7236\n",
      "Epoch 92/200, Train Loss: 16.1151, Val Loss: 15.6684\n",
      "Epoch 93/200, Train Loss: 16.1022, Val Loss: 15.7139\n",
      "Epoch 94/200, Train Loss: 16.0844, Val Loss: 15.6824\n",
      "Epoch 95/200, Train Loss: 16.0832, Val Loss: 15.6480\n",
      "  New best validation loss: 15.6480\n",
      "Epoch 96/200, Train Loss: 16.0571, Val Loss: 15.6220\n",
      "  New best validation loss: 15.6220\n",
      "Epoch 97/200, Train Loss: 16.0416, Val Loss: 15.6951\n",
      "Epoch 98/200, Train Loss: 16.0323, Val Loss: 15.5940\n",
      "  New best validation loss: 15.5940\n",
      "Epoch 99/200, Train Loss: 16.0426, Val Loss: 15.6721\n",
      "Epoch 100/200, Train Loss: 16.0212, Val Loss: 15.5921\n",
      "  New best validation loss: 15.5921\n",
      "Epoch 101/200, Train Loss: 16.0019, Val Loss: 15.5560\n",
      "  New best validation loss: 15.5560\n",
      "Epoch 102/200, Train Loss: 16.0160, Val Loss: 15.5302\n",
      "  New best validation loss: 15.5302\n",
      "Epoch 103/200, Train Loss: 15.9638, Val Loss: 15.6058\n",
      "Epoch 104/200, Train Loss: 15.9467, Val Loss: 15.5402\n",
      "Epoch 105/200, Train Loss: 15.9554, Val Loss: 15.5288\n",
      "  New best validation loss: 15.5288\n",
      "Epoch 106/200, Train Loss: 15.9091, Val Loss: 15.6926\n",
      "Epoch 107/200, Train Loss: 15.9159, Val Loss: 15.4383\n",
      "  New best validation loss: 15.4383\n",
      "Epoch 108/200, Train Loss: 15.8929, Val Loss: 15.4661\n",
      "Epoch 109/200, Train Loss: 15.8637, Val Loss: 15.5521\n",
      "Epoch 110/200, Train Loss: 15.8488, Val Loss: 15.4292\n",
      "  New best validation loss: 15.4292\n",
      "Epoch 111/200, Train Loss: 15.7929, Val Loss: 15.6054\n",
      "Epoch 112/200, Train Loss: 15.8226, Val Loss: 15.4533\n",
      "Epoch 113/200, Train Loss: 15.7841, Val Loss: 15.3957\n",
      "  New best validation loss: 15.3957\n",
      "Epoch 114/200, Train Loss: 15.7566, Val Loss: 15.4821\n",
      "Epoch 115/200, Train Loss: 15.7439, Val Loss: 15.4715\n",
      "Epoch 116/200, Train Loss: 15.7065, Val Loss: 15.3572\n",
      "  New best validation loss: 15.3572\n",
      "Epoch 117/200, Train Loss: 15.7061, Val Loss: 15.4405\n",
      "Epoch 118/200, Train Loss: 15.6706, Val Loss: 15.3521\n",
      "  New best validation loss: 15.3521\n",
      "Epoch 119/200, Train Loss: 15.6236, Val Loss: 15.4493\n",
      "Epoch 120/200, Train Loss: 15.6036, Val Loss: 15.4619\n",
      "Epoch 121/200, Train Loss: 15.5851, Val Loss: 15.3624\n",
      "Epoch 122/200, Train Loss: 15.5663, Val Loss: 15.3703\n",
      "Epoch 123/200, Train Loss: 15.5478, Val Loss: 15.3161\n",
      "  New best validation loss: 15.3161\n",
      "Epoch 124/200, Train Loss: 15.5137, Val Loss: 15.2674\n",
      "  New best validation loss: 15.2674\n",
      "Epoch 125/200, Train Loss: 15.5303, Val Loss: 15.1650\n",
      "  New best validation loss: 15.1650\n",
      "Epoch 126/200, Train Loss: 15.4586, Val Loss: 15.1787\n",
      "Epoch 127/200, Train Loss: 15.4392, Val Loss: 15.2168\n",
      "Epoch 128/200, Train Loss: 15.4256, Val Loss: 15.2995\n",
      "Epoch 129/200, Train Loss: 15.4148, Val Loss: 15.1977\n",
      "Epoch 130/200, Train Loss: 15.3857, Val Loss: 15.1839\n",
      "Epoch 131/200, Train Loss: 15.3444, Val Loss: 15.1879\n",
      "Epoch 132/200, Train Loss: 15.3008, Val Loss: 15.1165\n",
      "  New best validation loss: 15.1165\n",
      "Epoch 133/200, Train Loss: 15.3004, Val Loss: 15.1300\n",
      "Epoch 134/200, Train Loss: 15.2964, Val Loss: 15.1850\n",
      "Epoch 135/200, Train Loss: 15.3411, Val Loss: 15.1514\n",
      "Epoch 136/200, Train Loss: 15.2591, Val Loss: 15.1675\n",
      "Epoch 137/200, Train Loss: 15.2181, Val Loss: 15.0267\n",
      "  New best validation loss: 15.0267\n",
      "Epoch 138/200, Train Loss: 15.1979, Val Loss: 15.0818\n",
      "Epoch 139/200, Train Loss: 15.1882, Val Loss: 15.0543\n",
      "Epoch 140/200, Train Loss: 15.1448, Val Loss: 15.0722\n",
      "Epoch 141/200, Train Loss: 15.1061, Val Loss: 15.1074\n",
      "Epoch 142/200, Train Loss: 15.1124, Val Loss: 15.0910\n",
      "Epoch 143/200, Train Loss: 15.0467, Val Loss: 14.9943\n",
      "  New best validation loss: 14.9943\n",
      "Epoch 144/200, Train Loss: 15.0442, Val Loss: 15.0151\n",
      "Epoch 145/200, Train Loss: 15.0075, Val Loss: 14.9329\n",
      "  New best validation loss: 14.9329\n",
      "Epoch 146/200, Train Loss: 15.0256, Val Loss: 14.9259\n",
      "  New best validation loss: 14.9259\n",
      "Epoch 147/200, Train Loss: 14.9383, Val Loss: 15.2136\n",
      "Epoch 148/200, Train Loss: 14.9384, Val Loss: 14.8985\n",
      "  New best validation loss: 14.8985\n",
      "Epoch 149/200, Train Loss: 14.9221, Val Loss: 14.8800\n",
      "  New best validation loss: 14.8800\n",
      "Epoch 150/200, Train Loss: 14.8937, Val Loss: 15.0254\n",
      "Epoch 151/200, Train Loss: 14.9258, Val Loss: 15.0382\n",
      "Epoch 152/200, Train Loss: 14.8584, Val Loss: 15.0160\n",
      "Epoch 153/200, Train Loss: 14.9016, Val Loss: 15.0187\n",
      "Epoch 154/200, Train Loss: 14.8235, Val Loss: 14.9402\n",
      "Epoch 155/200, Train Loss: 14.7846, Val Loss: 14.8790\n",
      "  New best validation loss: 14.8790\n",
      "Epoch 156/200, Train Loss: 14.7588, Val Loss: 14.8441\n",
      "  New best validation loss: 14.8441\n",
      "Epoch 157/200, Train Loss: 14.7091, Val Loss: 14.8817\n",
      "Epoch 158/200, Train Loss: 14.6910, Val Loss: 14.8064\n",
      "  New best validation loss: 14.8064\n",
      "Epoch 159/200, Train Loss: 14.6548, Val Loss: 14.8544\n",
      "Epoch 160/200, Train Loss: 14.6519, Val Loss: 14.8295\n",
      "Epoch 161/200, Train Loss: 14.6530, Val Loss: 14.8212\n",
      "Epoch 162/200, Train Loss: 14.6089, Val Loss: 14.6163\n",
      "  New best validation loss: 14.6163\n",
      "Epoch 163/200, Train Loss: 14.5784, Val Loss: 14.7266\n",
      "Epoch 164/200, Train Loss: 14.5527, Val Loss: 14.6546\n",
      "Epoch 165/200, Train Loss: 14.5251, Val Loss: 14.6033\n",
      "  New best validation loss: 14.6033\n",
      "Epoch 166/200, Train Loss: 14.4884, Val Loss: 14.5400\n",
      "  New best validation loss: 14.5400\n",
      "Epoch 167/200, Train Loss: 14.4998, Val Loss: 14.6179\n",
      "Epoch 168/200, Train Loss: 14.4814, Val Loss: 14.5593\n",
      "Epoch 169/200, Train Loss: 14.4343, Val Loss: 14.7501\n",
      "Epoch 170/200, Train Loss: 14.4400, Val Loss: 14.6449\n",
      "Epoch 171/200, Train Loss: 14.3728, Val Loss: 14.5806\n",
      "Epoch 172/200, Train Loss: 14.3522, Val Loss: 14.4182\n",
      "  New best validation loss: 14.4182\n",
      "Epoch 173/200, Train Loss: 14.3325, Val Loss: 14.4949\n",
      "Epoch 174/200, Train Loss: 14.2877, Val Loss: 14.4707\n",
      "Epoch 175/200, Train Loss: 14.2772, Val Loss: 14.6224\n",
      "Epoch 176/200, Train Loss: 14.2717, Val Loss: 14.4913\n",
      "Epoch 177/200, Train Loss: 14.1959, Val Loss: 14.3837\n",
      "  New best validation loss: 14.3837\n",
      "Epoch 178/200, Train Loss: 14.1961, Val Loss: 14.3734\n",
      "  New best validation loss: 14.3734\n",
      "Epoch 179/200, Train Loss: 14.1956, Val Loss: 14.4464\n",
      "Epoch 180/200, Train Loss: 14.1613, Val Loss: 14.4036\n",
      "Epoch 181/200, Train Loss: 14.1269, Val Loss: 14.2836\n",
      "  New best validation loss: 14.2836\n",
      "Epoch 182/200, Train Loss: 14.1072, Val Loss: 14.2509\n",
      "  New best validation loss: 14.2509\n",
      "Epoch 183/200, Train Loss: 14.0667, Val Loss: 14.3901\n",
      "Epoch 184/200, Train Loss: 14.0580, Val Loss: 14.1577\n",
      "  New best validation loss: 14.1577\n",
      "Epoch 185/200, Train Loss: 14.0191, Val Loss: 14.2575\n",
      "Epoch 186/200, Train Loss: 13.9947, Val Loss: 14.1619\n",
      "Epoch 187/200, Train Loss: 13.9830, Val Loss: 14.4743\n",
      "Epoch 188/200, Train Loss: 13.9711, Val Loss: 14.2992\n",
      "Epoch 189/200, Train Loss: 13.9441, Val Loss: 14.3775\n",
      "Epoch 190/200, Train Loss: 13.8897, Val Loss: 14.1997\n",
      "Epoch 191/200, Train Loss: 13.8681, Val Loss: 14.0830\n",
      "  New best validation loss: 14.0830\n",
      "Epoch 192/200, Train Loss: 13.8935, Val Loss: 14.2142\n",
      "Epoch 193/200, Train Loss: 13.9147, Val Loss: 14.2191\n",
      "Epoch 194/200, Train Loss: 13.8010, Val Loss: 14.1386\n",
      "Epoch 195/200, Train Loss: 13.7525, Val Loss: 14.3479\n",
      "Epoch 196/200, Train Loss: 13.7432, Val Loss: 14.0725\n",
      "  New best validation loss: 14.0725\n",
      "Epoch 197/200, Train Loss: 13.6991, Val Loss: 14.0204\n",
      "  New best validation loss: 14.0204\n",
      "Epoch 198/200, Train Loss: 13.7125, Val Loss: 14.1033\n",
      "Epoch 199/200, Train Loss: 13.6951, Val Loss: 14.0139\n",
      "  New best validation loss: 14.0139\n",
      "Epoch 200/200, Train Loss: 13.7405, Val Loss: 13.9637\n",
      "  New best validation loss: 13.9637\n",
      "\n",
      "Loaded best model (Val Loss: 13.9637) for final hidden state extraction.\n",
      "Saved best model for RNN_Vanillia (samples=640) to results_data_size_sweep/20250514_045146/samples_640/RNN_Vanillia_samples_640_best.pt\n",
      "\n",
      "--- Performing Decodability Analysis for RNN_Vanillia (samples=640, k=15) ---\n",
      "  Analyzing decodability for RNN_Vanillia...\n",
      "  Hidden states shape: torch.Size([160, 200, 225])\n",
      "  Coefficients shape: torch.Size([160, 15])\n",
      "  Processed hidden states shape for decoder: torch.Size([160, 225])\n",
      "  RidgeCV Decoder for RNN_Vanillia - Test MSE: 1.5592, Test R2: 0.2139 (best alpha: 48.3293)\n",
      "  Decodability plot saved to results_data_size_sweep/20250514_045146/samples_640/decodability_RNN_Vanillia_coeff1.png\n",
      "Decodability (R2 score) for RNN_Vanillia (samples=640): 0.2139\n",
      "\n",
      "--- Training ComplexOscillatorNet (samples=640, k=15) ---\n",
      "Number of parameters: 17152\n",
      "Epoch 1/200, Train Loss: 16.6034, Val Loss: 14.9627\n",
      "  New best validation loss: 14.9627\n",
      "Epoch 2/200, Train Loss: 15.7495, Val Loss: 14.5547\n",
      "  New best validation loss: 14.5547\n",
      "Epoch 3/200, Train Loss: 15.3806, Val Loss: 14.4907\n",
      "  New best validation loss: 14.4907\n",
      "Epoch 4/200, Train Loss: 15.1515, Val Loss: 14.2315\n",
      "  New best validation loss: 14.2315\n",
      "Epoch 5/200, Train Loss: 14.9582, Val Loss: 14.2654\n",
      "Epoch 6/200, Train Loss: 14.8689, Val Loss: 14.0761\n",
      "  New best validation loss: 14.0761\n",
      "Epoch 7/200, Train Loss: 14.7007, Val Loss: 14.0841\n",
      "Epoch 8/200, Train Loss: 14.6038, Val Loss: 14.0137\n",
      "  New best validation loss: 14.0137\n",
      "Epoch 9/200, Train Loss: 14.4844, Val Loss: 13.9639\n",
      "  New best validation loss: 13.9639\n",
      "Epoch 10/200, Train Loss: 14.4019, Val Loss: 14.0361\n",
      "Epoch 11/200, Train Loss: 14.2861, Val Loss: 14.0538\n",
      "Epoch 12/200, Train Loss: 14.2464, Val Loss: 13.8627\n",
      "  New best validation loss: 13.8627\n",
      "Epoch 13/200, Train Loss: 14.1369, Val Loss: 13.9236\n",
      "Epoch 14/200, Train Loss: 14.0615, Val Loss: 13.8779\n",
      "Epoch 15/200, Train Loss: 14.0342, Val Loss: 14.0391\n",
      "Epoch 16/200, Train Loss: 13.9822, Val Loss: 14.0384\n",
      "Epoch 17/200, Train Loss: 13.8817, Val Loss: 13.9142\n",
      "Epoch 18/200, Train Loss: 13.8276, Val Loss: 13.8807\n",
      "Epoch 19/200, Train Loss: 13.7323, Val Loss: 13.8904\n",
      "Epoch 20/200, Train Loss: 13.7100, Val Loss: 14.0007\n",
      "Epoch 21/200, Train Loss: 13.6990, Val Loss: 13.8662\n",
      "Epoch 22/200, Train Loss: 13.5959, Val Loss: 14.0093\n",
      "Epoch 23/200, Train Loss: 13.5038, Val Loss: 13.9104\n",
      "Epoch 24/200, Train Loss: 13.4566, Val Loss: 13.8681\n",
      "Epoch 25/200, Train Loss: 13.3955, Val Loss: 14.0231\n",
      "Epoch 26/200, Train Loss: 13.3808, Val Loss: 13.9425\n",
      "Epoch 27/200, Train Loss: 13.3445, Val Loss: 14.1108\n",
      "Epoch 28/200, Train Loss: 13.3017, Val Loss: 14.0524\n",
      "Epoch 29/200, Train Loss: 13.2649, Val Loss: 13.9633\n",
      "Epoch 30/200, Train Loss: 13.2275, Val Loss: 13.9918\n",
      "Epoch 31/200, Train Loss: 13.1818, Val Loss: 14.0637\n",
      "Epoch 32/200, Train Loss: 13.1010, Val Loss: 13.9877\n",
      "Epoch 33/200, Train Loss: 13.1029, Val Loss: 14.0683\n",
      "Epoch 34/200, Train Loss: 13.0950, Val Loss: 14.1487\n",
      "Epoch 35/200, Train Loss: 13.0954, Val Loss: 14.1390\n",
      "Epoch 36/200, Train Loss: 13.0701, Val Loss: 14.1575\n",
      "Epoch 37/200, Train Loss: 12.9769, Val Loss: 14.1247\n",
      "Epoch 38/200, Train Loss: 12.9251, Val Loss: 14.0828\n",
      "Epoch 39/200, Train Loss: 12.8486, Val Loss: 14.1179\n",
      "Epoch 40/200, Train Loss: 12.8202, Val Loss: 14.0604\n",
      "Epoch 41/200, Train Loss: 12.7766, Val Loss: 14.1223\n",
      "Epoch 42/200, Train Loss: 12.7714, Val Loss: 14.2083\n",
      "Epoch 43/200, Train Loss: 12.7432, Val Loss: 14.1436\n",
      "Epoch 44/200, Train Loss: 12.7128, Val Loss: 14.0513\n",
      "Epoch 45/200, Train Loss: 12.7082, Val Loss: 14.1756\n",
      "Epoch 46/200, Train Loss: 12.6759, Val Loss: 14.3100\n",
      "Epoch 47/200, Train Loss: 12.6616, Val Loss: 14.2742\n",
      "Epoch 48/200, Train Loss: 12.6638, Val Loss: 14.2508\n",
      "Epoch 49/200, Train Loss: 12.6299, Val Loss: 14.3031\n",
      "Epoch 50/200, Train Loss: 12.5630, Val Loss: 14.2083\n",
      "Epoch 51/200, Train Loss: 12.5258, Val Loss: 14.3235\n",
      "Epoch 52/200, Train Loss: 12.5287, Val Loss: 14.3538\n",
      "Epoch 53/200, Train Loss: 12.5133, Val Loss: 14.3275\n",
      "Epoch 54/200, Train Loss: 12.5194, Val Loss: 14.3022\n",
      "Epoch 55/200, Train Loss: 12.4642, Val Loss: 14.3011\n",
      "Epoch 56/200, Train Loss: 12.4191, Val Loss: 14.3173\n",
      "Epoch 57/200, Train Loss: 12.4038, Val Loss: 14.4253\n",
      "Epoch 58/200, Train Loss: 12.3738, Val Loss: 14.3732\n",
      "Epoch 59/200, Train Loss: 12.3485, Val Loss: 14.3384\n",
      "Epoch 60/200, Train Loss: 12.3571, Val Loss: 14.3723\n",
      "Epoch 61/200, Train Loss: 12.3226, Val Loss: 14.4106\n",
      "Epoch 62/200, Train Loss: 12.2846, Val Loss: 14.4196\n",
      "Epoch 63/200, Train Loss: 12.2924, Val Loss: 14.3977\n",
      "Epoch 64/200, Train Loss: 12.3100, Val Loss: 14.4295\n",
      "Epoch 65/200, Train Loss: 12.2977, Val Loss: 14.3805\n",
      "Epoch 66/200, Train Loss: 12.2393, Val Loss: 14.4697\n",
      "Epoch 67/200, Train Loss: 12.2012, Val Loss: 14.4600\n",
      "Epoch 68/200, Train Loss: 12.1856, Val Loss: 14.5210\n",
      "Epoch 69/200, Train Loss: 12.2206, Val Loss: 14.5398\n",
      "Epoch 70/200, Train Loss: 12.1967, Val Loss: 14.6153\n",
      "Epoch 71/200, Train Loss: 12.2008, Val Loss: 14.7379\n",
      "Epoch 72/200, Train Loss: 12.1815, Val Loss: 14.5356\n",
      "Epoch 73/200, Train Loss: 12.1665, Val Loss: 14.4573\n",
      "Epoch 74/200, Train Loss: 12.1368, Val Loss: 14.5440\n",
      "Epoch 75/200, Train Loss: 12.1228, Val Loss: 14.5115\n",
      "Epoch 76/200, Train Loss: 12.1519, Val Loss: 14.6194\n",
      "Epoch 77/200, Train Loss: 12.1641, Val Loss: 14.5500\n",
      "Epoch 78/200, Train Loss: 12.1596, Val Loss: 14.5063\n",
      "Epoch 79/200, Train Loss: 12.1012, Val Loss: 14.6944\n",
      "Epoch 80/200, Train Loss: 12.0648, Val Loss: 14.6500\n",
      "Epoch 81/200, Train Loss: 12.0068, Val Loss: 14.7454\n",
      "Epoch 82/200, Train Loss: 11.9826, Val Loss: 14.7178\n",
      "Epoch 83/200, Train Loss: 11.9834, Val Loss: 14.6904\n",
      "Epoch 84/200, Train Loss: 11.9592, Val Loss: 14.6877\n",
      "Epoch 85/200, Train Loss: 11.9417, Val Loss: 14.6999\n",
      "Epoch 86/200, Train Loss: 11.9490, Val Loss: 14.7434\n",
      "Epoch 87/200, Train Loss: 11.9634, Val Loss: 14.6204\n",
      "Epoch 88/200, Train Loss: 11.9384, Val Loss: 14.6727\n",
      "Epoch 89/200, Train Loss: 11.9131, Val Loss: 14.7529\n",
      "Epoch 90/200, Train Loss: 11.8809, Val Loss: 14.8444\n",
      "Epoch 91/200, Train Loss: 11.8680, Val Loss: 14.8234\n",
      "Epoch 92/200, Train Loss: 11.8867, Val Loss: 14.7178\n",
      "Epoch 93/200, Train Loss: 11.8833, Val Loss: 14.7037\n",
      "Epoch 94/200, Train Loss: 11.8308, Val Loss: 14.6707\n",
      "Epoch 95/200, Train Loss: 11.8403, Val Loss: 14.8932\n",
      "Epoch 96/200, Train Loss: 11.8328, Val Loss: 14.7731\n",
      "Epoch 97/200, Train Loss: 11.8140, Val Loss: 14.8623\n",
      "Epoch 98/200, Train Loss: 11.7874, Val Loss: 14.8016\n",
      "Epoch 99/200, Train Loss: 11.7664, Val Loss: 14.8696\n",
      "Epoch 100/200, Train Loss: 11.7677, Val Loss: 14.8226\n",
      "Epoch 101/200, Train Loss: 11.7592, Val Loss: 14.8839\n",
      "Epoch 102/200, Train Loss: 11.7495, Val Loss: 14.8552\n",
      "Epoch 103/200, Train Loss: 11.7890, Val Loss: 14.8485\n",
      "Epoch 104/200, Train Loss: 11.7477, Val Loss: 14.8154\n",
      "Epoch 105/200, Train Loss: 11.7236, Val Loss: 14.9634\n",
      "Epoch 106/200, Train Loss: 11.7173, Val Loss: 14.9243\n",
      "Epoch 107/200, Train Loss: 11.7130, Val Loss: 14.8311\n",
      "Epoch 108/200, Train Loss: 11.7142, Val Loss: 15.0279\n",
      "Epoch 109/200, Train Loss: 11.7295, Val Loss: 14.9599\n",
      "Epoch 110/200, Train Loss: 11.7061, Val Loss: 15.0464\n",
      "Epoch 111/200, Train Loss: 11.9893, Val Loss: 15.1166\n",
      "Epoch 112/200, Train Loss: 11.9650, Val Loss: 14.8805\n",
      "Epoch 113/200, Train Loss: 11.8910, Val Loss: 15.0650\n",
      "Epoch 114/200, Train Loss: 11.8476, Val Loss: 14.9882\n",
      "Epoch 115/200, Train Loss: 11.9487, Val Loss: 14.9681\n",
      "Epoch 116/200, Train Loss: 11.8750, Val Loss: 15.1088\n",
      "Epoch 117/200, Train Loss: 11.8183, Val Loss: 14.8965\n",
      "Epoch 118/200, Train Loss: 11.7781, Val Loss: 15.0452\n",
      "Epoch 119/200, Train Loss: 11.7342, Val Loss: 15.0289\n",
      "Epoch 120/200, Train Loss: 11.6951, Val Loss: 15.0772\n",
      "Epoch 121/200, Train Loss: 11.6388, Val Loss: 14.8608\n",
      "Epoch 122/200, Train Loss: 11.6186, Val Loss: 15.0599\n",
      "Epoch 123/200, Train Loss: 11.5911, Val Loss: 15.0309\n",
      "Epoch 124/200, Train Loss: 11.5915, Val Loss: 15.0954\n",
      "Epoch 125/200, Train Loss: 11.5644, Val Loss: 15.0123\n",
      "Epoch 126/200, Train Loss: 11.5837, Val Loss: 14.9567\n",
      "Epoch 127/200, Train Loss: 11.5869, Val Loss: 15.2036\n",
      "Epoch 128/200, Train Loss: 11.5980, Val Loss: 15.0141\n",
      "Epoch 129/200, Train Loss: 11.5694, Val Loss: 15.0211\n",
      "Epoch 130/200, Train Loss: 11.5308, Val Loss: 15.0431\n",
      "Epoch 131/200, Train Loss: 11.5213, Val Loss: 14.9938\n",
      "Epoch 132/200, Train Loss: 11.5324, Val Loss: 14.9370\n",
      "Epoch 133/200, Train Loss: 11.5566, Val Loss: 15.1079\n",
      "Epoch 134/200, Train Loss: 11.5502, Val Loss: 15.0046\n",
      "Epoch 135/200, Train Loss: 11.5306, Val Loss: 15.1048\n",
      "Epoch 136/200, Train Loss: 11.5375, Val Loss: 15.1759\n",
      "Epoch 137/200, Train Loss: 11.5774, Val Loss: 15.0916\n",
      "Epoch 138/200, Train Loss: 11.5179, Val Loss: 15.2115\n",
      "Epoch 139/200, Train Loss: 11.4925, Val Loss: 15.0833\n",
      "Epoch 140/200, Train Loss: 11.4794, Val Loss: 15.1496\n",
      "Epoch 141/200, Train Loss: 11.5144, Val Loss: 15.1318\n",
      "Epoch 142/200, Train Loss: 11.5071, Val Loss: 15.0751\n",
      "Epoch 143/200, Train Loss: 11.4920, Val Loss: 15.1058\n",
      "Epoch 144/200, Train Loss: 11.4740, Val Loss: 15.0655\n",
      "Epoch 145/200, Train Loss: 11.4763, Val Loss: 15.1465\n",
      "Epoch 146/200, Train Loss: 11.4584, Val Loss: 15.1192\n",
      "Epoch 147/200, Train Loss: 11.4712, Val Loss: 15.1596\n",
      "Epoch 148/200, Train Loss: 11.4460, Val Loss: 15.1257\n",
      "Epoch 149/200, Train Loss: 11.4155, Val Loss: 15.1960\n",
      "Epoch 150/200, Train Loss: 11.4630, Val Loss: 15.1688\n",
      "Epoch 151/200, Train Loss: 11.5328, Val Loss: 15.2140\n",
      "Epoch 152/200, Train Loss: 11.4859, Val Loss: 15.0877\n",
      "Epoch 153/200, Train Loss: 11.4517, Val Loss: 15.1645\n",
      "Epoch 154/200, Train Loss: 11.4094, Val Loss: 15.2137\n",
      "Epoch 155/200, Train Loss: 11.4248, Val Loss: 15.2571\n",
      "Epoch 156/200, Train Loss: 11.4083, Val Loss: 15.2613\n",
      "Epoch 157/200, Train Loss: 11.4003, Val Loss: 15.2493\n",
      "Epoch 158/200, Train Loss: 11.3717, Val Loss: 15.1497\n",
      "Epoch 159/200, Train Loss: 11.3438, Val Loss: 15.2595\n",
      "Epoch 160/200, Train Loss: 11.3573, Val Loss: 15.1443\n",
      "Epoch 161/200, Train Loss: 11.3496, Val Loss: 15.2707\n",
      "Epoch 162/200, Train Loss: 11.3537, Val Loss: 15.2132\n",
      "Epoch 163/200, Train Loss: 11.3743, Val Loss: 15.0986\n",
      "Epoch 164/200, Train Loss: 11.3875, Val Loss: 15.1648\n",
      "Epoch 165/200, Train Loss: 11.4058, Val Loss: 15.3095\n",
      "Epoch 166/200, Train Loss: 11.3977, Val Loss: 15.2032\n",
      "Epoch 167/200, Train Loss: 11.3956, Val Loss: 15.2283\n",
      "Epoch 168/200, Train Loss: 11.3785, Val Loss: 15.2606\n",
      "Epoch 169/200, Train Loss: 11.3783, Val Loss: 15.2346\n",
      "Epoch 170/200, Train Loss: 11.3521, Val Loss: 15.2475\n",
      "Epoch 171/200, Train Loss: 11.3094, Val Loss: 15.2426\n",
      "Epoch 172/200, Train Loss: 11.2687, Val Loss: 15.2797\n",
      "Epoch 173/200, Train Loss: 11.2756, Val Loss: 15.2294\n",
      "Epoch 174/200, Train Loss: 11.2659, Val Loss: 15.2454\n",
      "Epoch 175/200, Train Loss: 11.2757, Val Loss: 15.2746\n",
      "Epoch 176/200, Train Loss: 11.2905, Val Loss: 15.2687\n",
      "Epoch 177/200, Train Loss: 11.2678, Val Loss: 15.3841\n",
      "Epoch 178/200, Train Loss: 11.2428, Val Loss: 15.2914\n",
      "Epoch 179/200, Train Loss: 11.2533, Val Loss: 15.3531\n",
      "Epoch 180/200, Train Loss: 11.2661, Val Loss: 15.3939\n",
      "Epoch 181/200, Train Loss: 11.2262, Val Loss: 15.2827\n",
      "Epoch 182/200, Train Loss: 11.2279, Val Loss: 15.3961\n",
      "Epoch 183/200, Train Loss: 11.2262, Val Loss: 15.3673\n",
      "Epoch 184/200, Train Loss: 11.2371, Val Loss: 15.5529\n",
      "Epoch 185/200, Train Loss: 11.2410, Val Loss: 15.5302\n",
      "Epoch 186/200, Train Loss: 11.2599, Val Loss: 15.4145\n",
      "Epoch 187/200, Train Loss: 11.2527, Val Loss: 15.3608\n",
      "Epoch 188/200, Train Loss: 11.2517, Val Loss: 15.4047\n",
      "Epoch 189/200, Train Loss: 11.2353, Val Loss: 15.3661\n",
      "Epoch 190/200, Train Loss: 11.2531, Val Loss: 15.3459\n",
      "Epoch 191/200, Train Loss: 11.2494, Val Loss: 15.4357\n",
      "Epoch 192/200, Train Loss: 11.2452, Val Loss: 15.3416\n",
      "Epoch 193/200, Train Loss: 11.2268, Val Loss: 15.3074\n",
      "Epoch 194/200, Train Loss: 11.2551, Val Loss: 15.3973\n",
      "Epoch 195/200, Train Loss: 11.2746, Val Loss: 15.2127\n",
      "Epoch 196/200, Train Loss: 11.2802, Val Loss: 15.3499\n",
      "Epoch 197/200, Train Loss: 11.3191, Val Loss: 15.3140\n",
      "Epoch 198/200, Train Loss: 11.3472, Val Loss: 15.3697\n",
      "Epoch 199/200, Train Loss: 11.3168, Val Loss: 15.3433\n",
      "Epoch 200/200, Train Loss: 11.2532, Val Loss: 15.4287\n",
      "\n",
      "Loaded best model (Val Loss: 13.8627) for final hidden state extraction.\n",
      "Saved best model for ComplexOscillatorNet (samples=640) to results_data_size_sweep/20250514_045146/samples_640/ComplexOscillatorNet_samples_640_best.pt\n",
      "\n",
      "--- Performing Decodability Analysis for ComplexOscillatorNet (samples=640, k=15) ---\n",
      "  Analyzing decodability for ComplexOscillatorNet...\n",
      "  Hidden states shape: torch.Size([160, 200, 128])\n",
      "  Coefficients shape: torch.Size([160, 15])\n",
      "  Processed hidden states shape for decoder: torch.Size([160, 256])\n",
      "  RidgeCV Decoder for ComplexOscillatorNet - Test MSE: 1.2306, Test R2: 0.3828 (best alpha: 100.0000)\n",
      "  Decodability plot saved to results_data_size_sweep/20250514_045146/samples_640/decodability_ComplexOscillatorNet_coeff1.png\n",
      "Decodability (R2 score) for ComplexOscillatorNet (samples=640): 0.3828\n",
      "\n",
      "--- Training RNN_GRU (samples=640, k=15) ---\n",
      "Number of parameters: 12993\n",
      "Epoch 1/200, Train Loss: 16.7910, Val Loss: 15.7777\n",
      "  New best validation loss: 15.7777\n",
      "Epoch 2/200, Train Loss: 16.7651, Val Loss: 15.7611\n",
      "  New best validation loss: 15.7611\n",
      "Epoch 3/200, Train Loss: 16.7438, Val Loss: 15.7420\n",
      "  New best validation loss: 15.7420\n",
      "Epoch 4/200, Train Loss: 16.7184, Val Loss: 15.7171\n",
      "  New best validation loss: 15.7171\n",
      "Epoch 5/200, Train Loss: 16.6956, Val Loss: 15.7224\n",
      "Epoch 6/200, Train Loss: 16.6837, Val Loss: 15.7032\n",
      "  New best validation loss: 15.7032\n",
      "Epoch 7/200, Train Loss: 16.6756, Val Loss: 15.7379\n",
      "Epoch 8/200, Train Loss: 16.6716, Val Loss: 15.7229\n",
      "Epoch 9/200, Train Loss: 16.6739, Val Loss: 15.7148\n",
      "Epoch 10/200, Train Loss: 16.6668, Val Loss: 15.7312\n",
      "Epoch 11/200, Train Loss: 16.6575, Val Loss: 15.7123\n",
      "Epoch 12/200, Train Loss: 16.6614, Val Loss: 15.7040\n",
      "Epoch 13/200, Train Loss: 16.6572, Val Loss: 15.7039\n",
      "Epoch 14/200, Train Loss: 16.6557, Val Loss: 15.7111\n",
      "Epoch 15/200, Train Loss: 16.6488, Val Loss: 15.7033\n",
      "Epoch 16/200, Train Loss: 16.6504, Val Loss: 15.6994\n",
      "  New best validation loss: 15.6994\n",
      "Epoch 17/200, Train Loss: 16.6472, Val Loss: 15.7244\n",
      "Epoch 18/200, Train Loss: 16.6408, Val Loss: 15.7053\n",
      "Epoch 19/200, Train Loss: 16.6395, Val Loss: 15.6962\n",
      "  New best validation loss: 15.6962\n",
      "Epoch 20/200, Train Loss: 16.6333, Val Loss: 15.7035\n",
      "Epoch 21/200, Train Loss: 16.6316, Val Loss: 15.6917\n",
      "  New best validation loss: 15.6917\n",
      "Epoch 22/200, Train Loss: 16.6283, Val Loss: 15.6881\n",
      "  New best validation loss: 15.6881\n",
      "Epoch 23/200, Train Loss: 16.6250, Val Loss: 15.6856\n",
      "  New best validation loss: 15.6856\n",
      "Epoch 24/200, Train Loss: 16.6185, Val Loss: 15.6814\n",
      "  New best validation loss: 15.6814\n",
      "Epoch 25/200, Train Loss: 16.6147, Val Loss: 15.6935\n",
      "Epoch 26/200, Train Loss: 16.6147, Val Loss: 15.6819\n",
      "Epoch 27/200, Train Loss: 16.6049, Val Loss: 15.6749\n",
      "  New best validation loss: 15.6749\n",
      "Epoch 28/200, Train Loss: 16.5989, Val Loss: 15.6570\n",
      "  New best validation loss: 15.6570\n",
      "Epoch 29/200, Train Loss: 16.5951, Val Loss: 15.6423\n",
      "  New best validation loss: 15.6423\n",
      "Epoch 30/200, Train Loss: 16.5911, Val Loss: 15.6492\n",
      "Epoch 31/200, Train Loss: 16.5809, Val Loss: 15.6422\n",
      "  New best validation loss: 15.6422\n",
      "Epoch 32/200, Train Loss: 16.5746, Val Loss: 15.6263\n",
      "  New best validation loss: 15.6263\n",
      "Epoch 33/200, Train Loss: 16.5732, Val Loss: 15.6318\n",
      "Epoch 34/200, Train Loss: 16.5572, Val Loss: 15.6025\n",
      "  New best validation loss: 15.6025\n",
      "Epoch 35/200, Train Loss: 16.5501, Val Loss: 15.6010\n",
      "  New best validation loss: 15.6010\n",
      "Epoch 36/200, Train Loss: 16.5425, Val Loss: 15.6048\n",
      "Epoch 37/200, Train Loss: 16.5310, Val Loss: 15.5864\n",
      "  New best validation loss: 15.5864\n",
      "Epoch 38/200, Train Loss: 16.5221, Val Loss: 15.6006\n",
      "Epoch 39/200, Train Loss: 16.5139, Val Loss: 15.5739\n",
      "  New best validation loss: 15.5739\n",
      "Epoch 40/200, Train Loss: 16.5044, Val Loss: 15.5704\n",
      "  New best validation loss: 15.5704\n",
      "Epoch 41/200, Train Loss: 16.5009, Val Loss: 15.5878\n",
      "Epoch 42/200, Train Loss: 16.4831, Val Loss: 15.5708\n",
      "Epoch 43/200, Train Loss: 16.4720, Val Loss: 15.5465\n",
      "  New best validation loss: 15.5465\n",
      "Epoch 44/200, Train Loss: 16.4617, Val Loss: 15.5657\n",
      "Epoch 45/200, Train Loss: 16.4513, Val Loss: 15.5347\n",
      "  New best validation loss: 15.5347\n",
      "Epoch 46/200, Train Loss: 16.4399, Val Loss: 15.5062\n",
      "  New best validation loss: 15.5062\n",
      "Epoch 47/200, Train Loss: 16.4352, Val Loss: 15.5679\n",
      "Epoch 48/200, Train Loss: 16.4204, Val Loss: 15.5242\n",
      "Epoch 49/200, Train Loss: 16.4050, Val Loss: 15.5248\n",
      "Epoch 50/200, Train Loss: 16.3994, Val Loss: 15.5607\n",
      "Epoch 51/200, Train Loss: 16.3834, Val Loss: 15.5320\n",
      "Epoch 52/200, Train Loss: 16.3803, Val Loss: 15.5211\n",
      "Epoch 53/200, Train Loss: 16.3661, Val Loss: 15.5122\n",
      "Epoch 54/200, Train Loss: 16.3631, Val Loss: 15.5225\n",
      "Epoch 55/200, Train Loss: 16.3561, Val Loss: 15.5251\n",
      "Epoch 56/200, Train Loss: 16.3506, Val Loss: 15.5120\n",
      "Epoch 57/200, Train Loss: 16.3539, Val Loss: 15.5236\n",
      "Epoch 58/200, Train Loss: 16.3366, Val Loss: 15.5119\n",
      "Epoch 59/200, Train Loss: 16.3196, Val Loss: 15.4914\n",
      "  New best validation loss: 15.4914\n",
      "Epoch 60/200, Train Loss: 16.3182, Val Loss: 15.4551\n",
      "  New best validation loss: 15.4551\n",
      "Epoch 61/200, Train Loss: 16.3045, Val Loss: 15.4654\n",
      "Epoch 62/200, Train Loss: 16.3031, Val Loss: 15.4435\n",
      "  New best validation loss: 15.4435\n",
      "Epoch 63/200, Train Loss: 16.2767, Val Loss: 15.5407\n",
      "Epoch 64/200, Train Loss: 16.3057, Val Loss: 15.4734\n",
      "Epoch 65/200, Train Loss: 16.2789, Val Loss: 15.4245\n",
      "  New best validation loss: 15.4245\n",
      "Epoch 66/200, Train Loss: 16.2147, Val Loss: 15.3464\n",
      "  New best validation loss: 15.3464\n",
      "Epoch 67/200, Train Loss: 16.1768, Val Loss: 15.3520\n",
      "Epoch 68/200, Train Loss: 16.1358, Val Loss: 15.3182\n",
      "  New best validation loss: 15.3182\n",
      "Epoch 69/200, Train Loss: 16.0665, Val Loss: 15.2957\n",
      "  New best validation loss: 15.2957\n",
      "Epoch 70/200, Train Loss: 16.0032, Val Loss: 15.2693\n",
      "  New best validation loss: 15.2693\n",
      "Epoch 71/200, Train Loss: 15.9454, Val Loss: 15.2636\n",
      "  New best validation loss: 15.2636\n",
      "Epoch 72/200, Train Loss: 15.8848, Val Loss: 15.2225\n",
      "  New best validation loss: 15.2225\n",
      "Epoch 73/200, Train Loss: 15.8724, Val Loss: 15.2697\n",
      "Epoch 74/200, Train Loss: 15.8649, Val Loss: 15.0584\n",
      "  New best validation loss: 15.0584\n",
      "Epoch 75/200, Train Loss: 15.6568, Val Loss: 15.2176\n",
      "Epoch 76/200, Train Loss: 15.7413, Val Loss: 15.0320\n",
      "  New best validation loss: 15.0320\n",
      "Epoch 77/200, Train Loss: 15.6249, Val Loss: 15.0335\n",
      "Epoch 78/200, Train Loss: 15.6650, Val Loss: 15.0975\n",
      "Epoch 79/200, Train Loss: 15.6754, Val Loss: 14.8607\n",
      "  New best validation loss: 14.8607\n",
      "Epoch 80/200, Train Loss: 15.4689, Val Loss: 14.7893\n",
      "  New best validation loss: 14.7893\n",
      "Epoch 81/200, Train Loss: 15.3576, Val Loss: 14.8439\n",
      "Epoch 82/200, Train Loss: 15.3417, Val Loss: 14.6766\n",
      "  New best validation loss: 14.6766\n",
      "Epoch 83/200, Train Loss: 15.3937, Val Loss: 14.7952\n",
      "Epoch 84/200, Train Loss: 15.2572, Val Loss: 15.0596\n",
      "Epoch 85/200, Train Loss: 15.5280, Val Loss: 14.9400\n",
      "Epoch 86/200, Train Loss: 15.3749, Val Loss: 14.7170\n",
      "Epoch 87/200, Train Loss: 15.2575, Val Loss: 14.7170\n",
      "Epoch 88/200, Train Loss: 15.0964, Val Loss: 14.7134\n",
      "Epoch 89/200, Train Loss: 15.0504, Val Loss: 14.5308\n",
      "  New best validation loss: 14.5308\n",
      "Epoch 90/200, Train Loss: 15.1498, Val Loss: 14.8267\n",
      "Epoch 91/200, Train Loss: 15.0937, Val Loss: 14.4625\n",
      "  New best validation loss: 14.4625\n",
      "Epoch 92/200, Train Loss: 15.0502, Val Loss: 14.5466\n",
      "Epoch 93/200, Train Loss: 14.9204, Val Loss: 14.3124\n",
      "  New best validation loss: 14.3124\n",
      "Epoch 94/200, Train Loss: 14.9522, Val Loss: 14.5525\n",
      "Epoch 95/200, Train Loss: 14.9070, Val Loss: 14.5267\n",
      "Epoch 96/200, Train Loss: 14.9906, Val Loss: 14.2324\n",
      "  New best validation loss: 14.2324\n",
      "Epoch 97/200, Train Loss: 14.8235, Val Loss: 14.4067\n",
      "Epoch 98/200, Train Loss: 14.8431, Val Loss: 14.4348\n",
      "Epoch 99/200, Train Loss: 14.7547, Val Loss: 14.3344\n",
      "Epoch 100/200, Train Loss: 14.8258, Val Loss: 14.1470\n",
      "  New best validation loss: 14.1470\n",
      "Epoch 101/200, Train Loss: 14.7697, Val Loss: 14.3304\n",
      "Epoch 102/200, Train Loss: 14.7138, Val Loss: 14.1307\n",
      "  New best validation loss: 14.1307\n",
      "Epoch 103/200, Train Loss: 14.6716, Val Loss: 14.2281\n",
      "Epoch 104/200, Train Loss: 14.7177, Val Loss: 14.4785\n",
      "Epoch 105/200, Train Loss: 14.6596, Val Loss: 14.3060\n",
      "Epoch 106/200, Train Loss: 14.6253, Val Loss: 14.1573\n",
      "Epoch 107/200, Train Loss: 14.6928, Val Loss: 14.2895\n",
      "Epoch 108/200, Train Loss: 14.7974, Val Loss: 14.2414\n",
      "Epoch 109/200, Train Loss: 14.7160, Val Loss: 14.4440\n",
      "Epoch 110/200, Train Loss: 14.7159, Val Loss: 14.0705\n",
      "  New best validation loss: 14.0705\n",
      "Epoch 111/200, Train Loss: 14.6374, Val Loss: 14.2204\n",
      "Epoch 112/200, Train Loss: 14.5896, Val Loss: 14.0686\n",
      "  New best validation loss: 14.0686\n",
      "Epoch 113/200, Train Loss: 14.5625, Val Loss: 14.0208\n",
      "  New best validation loss: 14.0208\n",
      "Epoch 114/200, Train Loss: 14.5545, Val Loss: 14.0792\n",
      "Epoch 115/200, Train Loss: 14.5508, Val Loss: 14.0804\n",
      "Epoch 116/200, Train Loss: 14.5362, Val Loss: 13.9805\n",
      "  New best validation loss: 13.9805\n",
      "Epoch 117/200, Train Loss: 14.4661, Val Loss: 14.1331\n",
      "Epoch 118/200, Train Loss: 14.5691, Val Loss: 14.1860\n",
      "Epoch 119/200, Train Loss: 14.6275, Val Loss: 14.0275\n",
      "Epoch 120/200, Train Loss: 14.5483, Val Loss: 14.0535\n",
      "Epoch 121/200, Train Loss: 14.4743, Val Loss: 14.1821\n",
      "Epoch 122/200, Train Loss: 14.4945, Val Loss: 14.1089\n",
      "Epoch 123/200, Train Loss: 14.4295, Val Loss: 14.1021\n",
      "Epoch 124/200, Train Loss: 14.4532, Val Loss: 14.1620\n",
      "Epoch 125/200, Train Loss: 14.4913, Val Loss: 14.0654\n",
      "Epoch 126/200, Train Loss: 14.4613, Val Loss: 14.0652\n",
      "Epoch 127/200, Train Loss: 14.4597, Val Loss: 13.9129\n",
      "  New best validation loss: 13.9129\n",
      "Epoch 128/200, Train Loss: 14.4545, Val Loss: 14.0148\n",
      "Epoch 129/200, Train Loss: 14.4017, Val Loss: 13.9690\n",
      "Epoch 130/200, Train Loss: 14.4195, Val Loss: 14.1207\n",
      "Epoch 131/200, Train Loss: 14.3928, Val Loss: 14.1090\n",
      "Epoch 132/200, Train Loss: 14.3129, Val Loss: 14.0671\n",
      "Epoch 133/200, Train Loss: 14.4546, Val Loss: 14.0967\n",
      "Epoch 134/200, Train Loss: 14.4116, Val Loss: 13.9742\n",
      "Epoch 135/200, Train Loss: 14.3397, Val Loss: 14.0096\n",
      "Epoch 136/200, Train Loss: 14.4556, Val Loss: 14.0589\n",
      "Epoch 137/200, Train Loss: 14.3442, Val Loss: 13.9118\n",
      "  New best validation loss: 13.9118\n",
      "Epoch 138/200, Train Loss: 14.4032, Val Loss: 13.9142\n",
      "Epoch 139/200, Train Loss: 14.3599, Val Loss: 13.9039\n",
      "  New best validation loss: 13.9039\n",
      "Epoch 140/200, Train Loss: 14.2709, Val Loss: 13.9362\n",
      "Epoch 141/200, Train Loss: 14.3159, Val Loss: 14.1369\n",
      "Epoch 142/200, Train Loss: 14.3177, Val Loss: 14.0541\n",
      "Epoch 143/200, Train Loss: 14.4039, Val Loss: 13.9025\n",
      "  New best validation loss: 13.9025\n",
      "Epoch 144/200, Train Loss: 14.2636, Val Loss: 13.8638\n",
      "  New best validation loss: 13.8638\n",
      "Epoch 145/200, Train Loss: 14.2527, Val Loss: 14.0191\n",
      "Epoch 146/200, Train Loss: 14.2893, Val Loss: 13.8468\n",
      "  New best validation loss: 13.8468\n",
      "Epoch 147/200, Train Loss: 14.2220, Val Loss: 14.0441\n",
      "Epoch 148/200, Train Loss: 14.3246, Val Loss: 14.0173\n",
      "Epoch 149/200, Train Loss: 14.2254, Val Loss: 13.8866\n",
      "Epoch 150/200, Train Loss: 14.1950, Val Loss: 13.8725\n",
      "Epoch 151/200, Train Loss: 14.1904, Val Loss: 13.8439\n",
      "  New best validation loss: 13.8439\n",
      "Epoch 152/200, Train Loss: 14.2302, Val Loss: 13.8721\n",
      "Epoch 153/200, Train Loss: 14.2440, Val Loss: 13.9948\n",
      "Epoch 154/200, Train Loss: 14.2175, Val Loss: 13.9447\n",
      "Epoch 155/200, Train Loss: 14.1524, Val Loss: 13.8611\n",
      "Epoch 156/200, Train Loss: 14.1428, Val Loss: 13.9874\n",
      "Epoch 157/200, Train Loss: 14.1807, Val Loss: 13.9700\n",
      "Epoch 158/200, Train Loss: 14.1562, Val Loss: 13.9171\n",
      "Epoch 159/200, Train Loss: 14.1297, Val Loss: 13.7951\n",
      "  New best validation loss: 13.7951\n",
      "Epoch 160/200, Train Loss: 14.1186, Val Loss: 13.8951\n",
      "Epoch 161/200, Train Loss: 14.1276, Val Loss: 13.7162\n",
      "  New best validation loss: 13.7162\n",
      "Epoch 162/200, Train Loss: 14.0851, Val Loss: 13.9871\n",
      "Epoch 163/200, Train Loss: 14.1724, Val Loss: 13.8688\n",
      "Epoch 164/200, Train Loss: 14.2329, Val Loss: 13.8372\n",
      "Epoch 165/200, Train Loss: 14.1070, Val Loss: 14.0613\n",
      "Epoch 166/200, Train Loss: 14.1716, Val Loss: 13.7635\n",
      "Epoch 167/200, Train Loss: 14.2445, Val Loss: 13.8864\n",
      "Epoch 168/200, Train Loss: 14.2074, Val Loss: 13.8505\n",
      "Epoch 169/200, Train Loss: 14.1983, Val Loss: 13.9677\n",
      "Epoch 170/200, Train Loss: 14.1576, Val Loss: 13.8232\n",
      "Epoch 171/200, Train Loss: 14.0323, Val Loss: 13.6919\n",
      "  New best validation loss: 13.6919\n",
      "Epoch 172/200, Train Loss: 14.0130, Val Loss: 13.7008\n",
      "Epoch 173/200, Train Loss: 14.0102, Val Loss: 13.6530\n",
      "  New best validation loss: 13.6530\n",
      "Epoch 174/200, Train Loss: 14.0740, Val Loss: 13.7178\n",
      "Epoch 175/200, Train Loss: 14.0068, Val Loss: 13.7026\n",
      "Epoch 176/200, Train Loss: 14.0224, Val Loss: 13.6963\n",
      "Epoch 177/200, Train Loss: 14.0527, Val Loss: 13.7779\n",
      "Epoch 178/200, Train Loss: 14.0746, Val Loss: 13.8114\n",
      "Epoch 179/200, Train Loss: 14.0636, Val Loss: 13.5960\n",
      "  New best validation loss: 13.5960\n",
      "Epoch 180/200, Train Loss: 14.0765, Val Loss: 13.7552\n",
      "Epoch 181/200, Train Loss: 13.9828, Val Loss: 13.8749\n",
      "Epoch 182/200, Train Loss: 13.9833, Val Loss: 13.5781\n",
      "  New best validation loss: 13.5781\n",
      "Epoch 183/200, Train Loss: 13.8557, Val Loss: 13.7321\n",
      "Epoch 184/200, Train Loss: 13.8948, Val Loss: 13.7050\n",
      "Epoch 185/200, Train Loss: 13.8917, Val Loss: 13.7135\n",
      "Epoch 186/200, Train Loss: 13.8871, Val Loss: 13.7356\n",
      "Epoch 187/200, Train Loss: 13.8998, Val Loss: 13.7563\n",
      "Epoch 188/200, Train Loss: 13.9177, Val Loss: 13.6731\n",
      "Epoch 189/200, Train Loss: 13.9057, Val Loss: 13.5445\n",
      "  New best validation loss: 13.5445\n",
      "Epoch 190/200, Train Loss: 13.8778, Val Loss: 13.7488\n",
      "Epoch 191/200, Train Loss: 13.9470, Val Loss: 13.6782\n",
      "Epoch 192/200, Train Loss: 13.8399, Val Loss: 13.5429\n",
      "  New best validation loss: 13.5429\n",
      "Epoch 193/200, Train Loss: 13.8267, Val Loss: 13.5316\n",
      "  New best validation loss: 13.5316\n",
      "Epoch 194/200, Train Loss: 13.8252, Val Loss: 13.6932\n",
      "Epoch 195/200, Train Loss: 13.7837, Val Loss: 13.5515\n",
      "Epoch 196/200, Train Loss: 13.7704, Val Loss: 13.5655\n",
      "Epoch 197/200, Train Loss: 13.7588, Val Loss: 13.4904\n",
      "  New best validation loss: 13.4904\n",
      "Epoch 198/200, Train Loss: 13.7758, Val Loss: 13.6422\n",
      "Epoch 199/200, Train Loss: 13.7386, Val Loss: 13.5653\n",
      "Epoch 200/200, Train Loss: 13.7005, Val Loss: 13.6299\n",
      "\n",
      "Loaded best model (Val Loss: 13.4904) for final hidden state extraction.\n",
      "Saved best model for RNN_GRU (samples=640) to results_data_size_sweep/20250514_045146/samples_640/RNN_GRU_samples_640_best.pt\n",
      "\n",
      "--- Performing Decodability Analysis for RNN_GRU (samples=640, k=15) ---\n",
      "  Analyzing decodability for RNN_GRU...\n",
      "  Hidden states shape: torch.Size([160, 200, 64])\n",
      "  Coefficients shape: torch.Size([160, 15])\n",
      "  Processed hidden states shape for decoder: torch.Size([160, 64])\n",
      "  RidgeCV Decoder for RNN_GRU - Test MSE: 1.3711, Test R2: 0.3045 (best alpha: 5.4556)\n",
      "  Decodability plot saved to results_data_size_sweep/20250514_045146/samples_640/decodability_RNN_GRU_coeff1.png\n",
      "Decodability (R2 score) for RNN_GRU (samples=640): 0.3045\n",
      "\n",
      "--- Training Transformer (samples=640, k=15) ---\n",
      "Number of parameters: 85809\n",
      "Epoch 1/200, Train Loss: 17.5998, Val Loss: 15.8865\n",
      "  New best validation loss: 15.8865\n",
      "Epoch 2/200, Train Loss: 16.8498, Val Loss: 15.8516\n",
      "  New best validation loss: 15.8516\n",
      "Epoch 3/200, Train Loss: 16.8236, Val Loss: 15.9707\n",
      "Epoch 4/200, Train Loss: 16.8205, Val Loss: 15.8608\n",
      "Epoch 5/200, Train Loss: 16.8096, Val Loss: 15.9031\n",
      "Epoch 6/200, Train Loss: 16.8305, Val Loss: 15.9018\n",
      "Epoch 7/200, Train Loss: 16.8218, Val Loss: 15.8040\n",
      "  New best validation loss: 15.8040\n",
      "Epoch 8/200, Train Loss: 16.8170, Val Loss: 15.8470\n",
      "Epoch 9/200, Train Loss: 16.8015, Val Loss: 15.8769\n",
      "Epoch 10/200, Train Loss: 16.7942, Val Loss: 15.8461\n",
      "Epoch 11/200, Train Loss: 16.8161, Val Loss: 15.8723\n",
      "Epoch 12/200, Train Loss: 16.7806, Val Loss: 15.9717\n",
      "Epoch 13/200, Train Loss: 16.8294, Val Loss: 15.9936\n",
      "Epoch 14/200, Train Loss: 16.8139, Val Loss: 16.0000\n",
      "Epoch 15/200, Train Loss: 16.7919, Val Loss: 15.9335\n",
      "Epoch 16/200, Train Loss: 16.7773, Val Loss: 15.7590\n",
      "  New best validation loss: 15.7590\n",
      "Epoch 17/200, Train Loss: 16.7604, Val Loss: 15.8561\n",
      "Epoch 18/200, Train Loss: 16.7706, Val Loss: 15.8821\n",
      "Epoch 19/200, Train Loss: 16.7759, Val Loss: 15.7573\n",
      "  New best validation loss: 15.7573\n",
      "Epoch 20/200, Train Loss: 16.7553, Val Loss: 15.7656\n",
      "Epoch 21/200, Train Loss: 16.7446, Val Loss: 15.8030\n",
      "Epoch 22/200, Train Loss: 16.7458, Val Loss: 15.7774\n",
      "Epoch 23/200, Train Loss: 16.7522, Val Loss: 15.7909\n",
      "Epoch 24/200, Train Loss: 16.7482, Val Loss: 15.7290\n",
      "  New best validation loss: 15.7290\n",
      "Epoch 25/200, Train Loss: 16.7462, Val Loss: 15.7200\n",
      "  New best validation loss: 15.7200\n",
      "Epoch 26/200, Train Loss: 16.7432, Val Loss: 15.7901\n",
      "Epoch 27/200, Train Loss: 16.7239, Val Loss: 15.8800\n",
      "Epoch 28/200, Train Loss: 16.7527, Val Loss: 15.7783\n",
      "Epoch 29/200, Train Loss: 16.7435, Val Loss: 15.8055\n",
      "Epoch 30/200, Train Loss: 16.7161, Val Loss: 15.7042\n",
      "  New best validation loss: 15.7042\n",
      "Epoch 31/200, Train Loss: 16.7343, Val Loss: 15.6870\n",
      "  New best validation loss: 15.6870\n",
      "Epoch 32/200, Train Loss: 16.7209, Val Loss: 15.7561\n",
      "Epoch 33/200, Train Loss: 16.7012, Val Loss: 15.6857\n",
      "  New best validation loss: 15.6857\n",
      "Epoch 34/200, Train Loss: 16.7113, Val Loss: 15.8107\n",
      "Epoch 35/200, Train Loss: 16.7072, Val Loss: 15.7327\n",
      "Epoch 36/200, Train Loss: 16.6916, Val Loss: 15.7526\n",
      "Epoch 37/200, Train Loss: 16.6881, Val Loss: 15.6374\n",
      "  New best validation loss: 15.6374\n",
      "Epoch 38/200, Train Loss: 16.6849, Val Loss: 15.8784\n",
      "Epoch 39/200, Train Loss: 16.7016, Val Loss: 15.7075\n",
      "Epoch 40/200, Train Loss: 16.6777, Val Loss: 15.7584\n",
      "Epoch 41/200, Train Loss: 16.7167, Val Loss: 15.8271\n",
      "Epoch 42/200, Train Loss: 16.6991, Val Loss: 15.8583\n",
      "Epoch 43/200, Train Loss: 16.6462, Val Loss: 15.6232\n",
      "  New best validation loss: 15.6232\n",
      "Epoch 44/200, Train Loss: 16.6878, Val Loss: 15.6646\n",
      "Epoch 45/200, Train Loss: 16.6807, Val Loss: 15.7299\n",
      "Epoch 46/200, Train Loss: 16.6437, Val Loss: 15.6463\n",
      "Epoch 47/200, Train Loss: 16.6273, Val Loss: 15.5942\n",
      "  New best validation loss: 15.5942\n",
      "Epoch 48/200, Train Loss: 16.6675, Val Loss: 15.5500\n",
      "  New best validation loss: 15.5500\n",
      "Epoch 49/200, Train Loss: 16.6494, Val Loss: 15.6169\n",
      "Epoch 50/200, Train Loss: 16.6379, Val Loss: 15.5971\n",
      "Epoch 51/200, Train Loss: 16.6186, Val Loss: 15.5783\n",
      "Epoch 52/200, Train Loss: 16.5965, Val Loss: 15.6789\n",
      "Epoch 53/200, Train Loss: 16.5797, Val Loss: 15.6391\n",
      "Epoch 54/200, Train Loss: 16.5530, Val Loss: 15.4953\n",
      "  New best validation loss: 15.4953\n",
      "Epoch 55/200, Train Loss: 16.5433, Val Loss: 15.4644\n",
      "  New best validation loss: 15.4644\n",
      "Epoch 56/200, Train Loss: 16.5007, Val Loss: 15.8226\n",
      "Epoch 57/200, Train Loss: 16.5770, Val Loss: 15.4496\n",
      "  New best validation loss: 15.4496\n",
      "Epoch 58/200, Train Loss: 16.5332, Val Loss: 15.5773\n",
      "Epoch 59/200, Train Loss: 16.5373, Val Loss: 15.7360\n",
      "Epoch 60/200, Train Loss: 16.4802, Val Loss: 15.3583\n",
      "  New best validation loss: 15.3583\n",
      "Epoch 61/200, Train Loss: 16.4026, Val Loss: 15.2782\n",
      "  New best validation loss: 15.2782\n",
      "Epoch 62/200, Train Loss: 16.3754, Val Loss: 15.2649\n",
      "  New best validation loss: 15.2649\n",
      "Epoch 63/200, Train Loss: 16.3860, Val Loss: 15.3159\n",
      "Epoch 64/200, Train Loss: 16.3159, Val Loss: 15.1302\n",
      "  New best validation loss: 15.1302\n",
      "Epoch 65/200, Train Loss: 16.3455, Val Loss: 15.3931\n",
      "Epoch 66/200, Train Loss: 16.2221, Val Loss: 15.0273\n",
      "  New best validation loss: 15.0273\n",
      "Epoch 67/200, Train Loss: 16.2507, Val Loss: 15.2334\n",
      "Epoch 68/200, Train Loss: 16.1920, Val Loss: 15.0184\n",
      "  New best validation loss: 15.0184\n",
      "Epoch 69/200, Train Loss: 16.1354, Val Loss: 14.9908\n",
      "  New best validation loss: 14.9908\n",
      "Epoch 70/200, Train Loss: 16.0315, Val Loss: 14.7727\n",
      "  New best validation loss: 14.7727\n",
      "Epoch 71/200, Train Loss: 15.9392, Val Loss: 14.9448\n",
      "Epoch 72/200, Train Loss: 15.8692, Val Loss: 14.4521\n",
      "  New best validation loss: 14.4521\n",
      "Epoch 73/200, Train Loss: 15.8315, Val Loss: 14.3162\n",
      "  New best validation loss: 14.3162\n",
      "Epoch 74/200, Train Loss: 15.7486, Val Loss: 14.6851\n",
      "Epoch 75/200, Train Loss: 15.6411, Val Loss: 14.0723\n",
      "  New best validation loss: 14.0723\n",
      "Epoch 76/200, Train Loss: 15.5219, Val Loss: 14.1129\n",
      "Epoch 77/200, Train Loss: 15.4109, Val Loss: 13.9027\n",
      "  New best validation loss: 13.9027\n",
      "Epoch 78/200, Train Loss: 15.4278, Val Loss: 14.0566\n",
      "Epoch 79/200, Train Loss: 15.2863, Val Loss: 13.6031\n",
      "  New best validation loss: 13.6031\n",
      "Epoch 80/200, Train Loss: 15.2449, Val Loss: 13.9916\n",
      "Epoch 81/200, Train Loss: 15.0829, Val Loss: 13.5485\n",
      "  New best validation loss: 13.5485\n",
      "Epoch 82/200, Train Loss: 15.0380, Val Loss: 13.5828\n",
      "Epoch 83/200, Train Loss: 14.9492, Val Loss: 13.5391\n",
      "  New best validation loss: 13.5391\n",
      "Epoch 84/200, Train Loss: 14.9305, Val Loss: 13.1968\n",
      "  New best validation loss: 13.1968\n",
      "Epoch 85/200, Train Loss: 14.7898, Val Loss: 13.3278\n",
      "Epoch 86/200, Train Loss: 14.8235, Val Loss: 13.1678\n",
      "  New best validation loss: 13.1678\n",
      "Epoch 87/200, Train Loss: 14.6241, Val Loss: 13.2025\n",
      "Epoch 88/200, Train Loss: 14.6321, Val Loss: 13.0803\n",
      "  New best validation loss: 13.0803\n",
      "Epoch 89/200, Train Loss: 14.5191, Val Loss: 13.0660\n",
      "  New best validation loss: 13.0660\n",
      "Epoch 90/200, Train Loss: 14.4734, Val Loss: 12.9274\n",
      "  New best validation loss: 12.9274\n",
      "Epoch 91/200, Train Loss: 14.3685, Val Loss: 12.7743\n",
      "  New best validation loss: 12.7743\n",
      "Epoch 92/200, Train Loss: 14.2869, Val Loss: 12.6399\n",
      "  New best validation loss: 12.6399\n",
      "Epoch 93/200, Train Loss: 14.2408, Val Loss: 12.7184\n",
      "Epoch 94/200, Train Loss: 14.1346, Val Loss: 12.6371\n",
      "  New best validation loss: 12.6371\n",
      "Epoch 95/200, Train Loss: 14.1503, Val Loss: 12.4326\n",
      "  New best validation loss: 12.4326\n",
      "Epoch 96/200, Train Loss: 14.0366, Val Loss: 12.4257\n",
      "  New best validation loss: 12.4257\n",
      "Epoch 97/200, Train Loss: 13.9019, Val Loss: 12.1585\n",
      "  New best validation loss: 12.1585\n",
      "Epoch 98/200, Train Loss: 13.7556, Val Loss: 12.3207\n",
      "Epoch 99/200, Train Loss: 13.8289, Val Loss: 12.4744\n",
      "Epoch 100/200, Train Loss: 13.7288, Val Loss: 12.3258\n",
      "Epoch 101/200, Train Loss: 13.5884, Val Loss: 12.5487\n",
      "Epoch 102/200, Train Loss: 13.6468, Val Loss: 12.3865\n",
      "Epoch 103/200, Train Loss: 13.4623, Val Loss: 11.9932\n",
      "  New best validation loss: 11.9932\n",
      "Epoch 104/200, Train Loss: 13.3867, Val Loss: 11.8422\n",
      "  New best validation loss: 11.8422\n",
      "Epoch 105/200, Train Loss: 13.3052, Val Loss: 11.8347\n",
      "  New best validation loss: 11.8347\n",
      "Epoch 106/200, Train Loss: 13.4260, Val Loss: 11.9064\n",
      "Epoch 107/200, Train Loss: 13.2281, Val Loss: 11.9638\n",
      "Epoch 108/200, Train Loss: 13.2488, Val Loss: 12.0222\n",
      "Epoch 109/200, Train Loss: 13.1534, Val Loss: 11.8066\n",
      "  New best validation loss: 11.8066\n",
      "Epoch 110/200, Train Loss: 13.0838, Val Loss: 11.7925\n",
      "  New best validation loss: 11.7925\n",
      "Epoch 111/200, Train Loss: 13.0357, Val Loss: 11.5755\n",
      "  New best validation loss: 11.5755\n",
      "Epoch 112/200, Train Loss: 13.0622, Val Loss: 11.4572\n",
      "  New best validation loss: 11.4572\n",
      "Epoch 113/200, Train Loss: 12.9054, Val Loss: 11.5892\n",
      "Epoch 114/200, Train Loss: 12.8770, Val Loss: 11.3622\n",
      "  New best validation loss: 11.3622\n",
      "Epoch 115/200, Train Loss: 12.8197, Val Loss: 11.4753\n",
      "Epoch 116/200, Train Loss: 12.7319, Val Loss: 11.4260\n",
      "Epoch 117/200, Train Loss: 12.8136, Val Loss: 11.3533\n",
      "  New best validation loss: 11.3533\n",
      "Epoch 118/200, Train Loss: 12.8591, Val Loss: 11.4420\n",
      "Epoch 119/200, Train Loss: 12.7480, Val Loss: 11.2701\n",
      "  New best validation loss: 11.2701\n",
      "Epoch 120/200, Train Loss: 12.6613, Val Loss: 11.0923\n",
      "  New best validation loss: 11.0923\n",
      "Epoch 121/200, Train Loss: 12.6231, Val Loss: 11.2666\n",
      "Epoch 122/200, Train Loss: 12.7120, Val Loss: 11.4989\n",
      "Epoch 123/200, Train Loss: 12.7538, Val Loss: 11.5338\n",
      "Epoch 124/200, Train Loss: 12.5880, Val Loss: 11.4105\n",
      "Epoch 125/200, Train Loss: 12.6746, Val Loss: 11.2579\n",
      "Epoch 126/200, Train Loss: 12.6662, Val Loss: 11.2318\n",
      "Epoch 127/200, Train Loss: 12.5599, Val Loss: 11.3954\n",
      "Epoch 128/200, Train Loss: 12.5524, Val Loss: 11.3101\n",
      "Epoch 129/200, Train Loss: 12.5654, Val Loss: 11.0312\n",
      "  New best validation loss: 11.0312\n",
      "Epoch 130/200, Train Loss: 12.5232, Val Loss: 10.9841\n",
      "  New best validation loss: 10.9841\n",
      "Epoch 131/200, Train Loss: 12.5537, Val Loss: 11.1113\n",
      "Epoch 132/200, Train Loss: 12.5451, Val Loss: 11.0945\n",
      "Epoch 133/200, Train Loss: 12.4627, Val Loss: 10.9928\n",
      "Epoch 134/200, Train Loss: 12.4793, Val Loss: 11.0597\n",
      "Epoch 135/200, Train Loss: 12.4402, Val Loss: 11.4437\n",
      "Epoch 136/200, Train Loss: 12.3294, Val Loss: 11.2263\n",
      "Epoch 137/200, Train Loss: 12.2531, Val Loss: 11.1368\n",
      "Epoch 138/200, Train Loss: 12.3518, Val Loss: 11.0464\n",
      "Epoch 139/200, Train Loss: 12.2699, Val Loss: 10.8119\n",
      "  New best validation loss: 10.8119\n",
      "Epoch 140/200, Train Loss: 12.2733, Val Loss: 11.1876\n",
      "Epoch 141/200, Train Loss: 12.2892, Val Loss: 10.9570\n",
      "Epoch 142/200, Train Loss: 12.2456, Val Loss: 10.9854\n",
      "Epoch 143/200, Train Loss: 12.2359, Val Loss: 10.8789\n",
      "Epoch 144/200, Train Loss: 12.2117, Val Loss: 10.9844\n",
      "Epoch 145/200, Train Loss: 12.1655, Val Loss: 10.7669\n",
      "  New best validation loss: 10.7669\n",
      "Epoch 146/200, Train Loss: 12.2029, Val Loss: 11.0755\n",
      "Epoch 147/200, Train Loss: 12.1270, Val Loss: 10.9386\n",
      "Epoch 148/200, Train Loss: 12.0386, Val Loss: 10.8363\n",
      "Epoch 149/200, Train Loss: 12.1628, Val Loss: 11.0488\n",
      "Epoch 150/200, Train Loss: 12.2945, Val Loss: 10.7603\n",
      "  New best validation loss: 10.7603\n",
      "Epoch 151/200, Train Loss: 12.1504, Val Loss: 10.7750\n",
      "Epoch 152/200, Train Loss: 12.0548, Val Loss: 10.9307\n",
      "Epoch 153/200, Train Loss: 12.1591, Val Loss: 10.9267\n",
      "Epoch 154/200, Train Loss: 12.0870, Val Loss: 10.9206\n",
      "Epoch 155/200, Train Loss: 12.0294, Val Loss: 10.8211\n",
      "Epoch 156/200, Train Loss: 12.0825, Val Loss: 10.7959\n",
      "Epoch 157/200, Train Loss: 12.1014, Val Loss: 10.8055\n",
      "Epoch 158/200, Train Loss: 12.0626, Val Loss: 10.8467\n",
      "Epoch 159/200, Train Loss: 12.1286, Val Loss: 11.1737\n",
      "Epoch 160/200, Train Loss: 11.9666, Val Loss: 10.8493\n",
      "Epoch 161/200, Train Loss: 12.0061, Val Loss: 10.8394\n",
      "Epoch 162/200, Train Loss: 12.0741, Val Loss: 10.6590\n",
      "  New best validation loss: 10.6590\n",
      "Epoch 163/200, Train Loss: 12.0642, Val Loss: 10.6951\n",
      "Epoch 164/200, Train Loss: 12.1015, Val Loss: 10.6973\n",
      "Epoch 165/200, Train Loss: 12.0094, Val Loss: 10.7199\n",
      "Epoch 166/200, Train Loss: 12.0505, Val Loss: 10.7921\n",
      "Epoch 167/200, Train Loss: 11.9088, Val Loss: 10.6577\n",
      "  New best validation loss: 10.6577\n",
      "Epoch 168/200, Train Loss: 12.0284, Val Loss: 10.6674\n",
      "Epoch 169/200, Train Loss: 12.1065, Val Loss: 10.7745\n",
      "Epoch 170/200, Train Loss: 12.1275, Val Loss: 10.8835\n",
      "Epoch 171/200, Train Loss: 11.9892, Val Loss: 10.7169\n",
      "Epoch 172/200, Train Loss: 11.9952, Val Loss: 10.7096\n",
      "Epoch 173/200, Train Loss: 11.8682, Val Loss: 10.5622\n",
      "  New best validation loss: 10.5622\n",
      "Epoch 174/200, Train Loss: 11.8726, Val Loss: 10.7557\n",
      "Epoch 175/200, Train Loss: 11.7976, Val Loss: 10.6121\n",
      "Epoch 176/200, Train Loss: 11.8283, Val Loss: 10.5253\n",
      "  New best validation loss: 10.5253\n",
      "Epoch 177/200, Train Loss: 11.8517, Val Loss: 10.7670\n",
      "Epoch 178/200, Train Loss: 11.7707, Val Loss: 10.5087\n",
      "  New best validation loss: 10.5087\n",
      "Epoch 179/200, Train Loss: 11.7970, Val Loss: 10.3925\n",
      "  New best validation loss: 10.3925\n",
      "Epoch 180/200, Train Loss: 11.7442, Val Loss: 10.6199\n",
      "Epoch 181/200, Train Loss: 11.8461, Val Loss: 10.6323\n",
      "Epoch 182/200, Train Loss: 11.7990, Val Loss: 10.5748\n",
      "Epoch 183/200, Train Loss: 11.6983, Val Loss: 10.3518\n",
      "  New best validation loss: 10.3518\n",
      "Epoch 184/200, Train Loss: 11.7984, Val Loss: 10.2889\n",
      "  New best validation loss: 10.2889\n",
      "Epoch 185/200, Train Loss: 11.7437, Val Loss: 10.8422\n",
      "Epoch 186/200, Train Loss: 11.7720, Val Loss: 11.0105\n",
      "Epoch 187/200, Train Loss: 11.7251, Val Loss: 10.6346\n",
      "Epoch 188/200, Train Loss: 11.7388, Val Loss: 10.5159\n",
      "Epoch 189/200, Train Loss: 11.7574, Val Loss: 10.3343\n",
      "Epoch 190/200, Train Loss: 11.6618, Val Loss: 10.5159\n",
      "Epoch 191/200, Train Loss: 11.6343, Val Loss: 10.5930\n",
      "Epoch 192/200, Train Loss: 11.7196, Val Loss: 10.5572\n",
      "Epoch 193/200, Train Loss: 11.6850, Val Loss: 10.4205\n",
      "Epoch 194/200, Train Loss: 11.6327, Val Loss: 10.3418\n",
      "Epoch 195/200, Train Loss: 11.6851, Val Loss: 10.2905\n",
      "Epoch 196/200, Train Loss: 11.5207, Val Loss: 10.5123\n",
      "Epoch 197/200, Train Loss: 11.5499, Val Loss: 10.3955\n",
      "Epoch 198/200, Train Loss: 11.5537, Val Loss: 10.6597\n",
      "Epoch 199/200, Train Loss: 11.6581, Val Loss: 10.4484\n",
      "Epoch 200/200, Train Loss: 11.5873, Val Loss: 10.4953\n",
      "\n",
      "Loaded best model (Val Loss: 10.2889) for final hidden state extraction.\n",
      "Saved best model for Transformer (samples=640) to results_data_size_sweep/20250514_045146/samples_640/Transformer_samples_640_best.pt\n",
      "\n",
      "--- Performing Decodability Analysis for Transformer (samples=640, k=15) ---\n",
      "  Analyzing decodability for Transformer...\n",
      "  Hidden states shape: torch.Size([160, 200, 20])\n",
      "  Coefficients shape: torch.Size([160, 15])\n",
      "  Processed hidden states shape for decoder: torch.Size([160, 20])\n",
      "  RidgeCV Decoder for Transformer - Test MSE: 1.1989, Test R2: 0.4019 (best alpha: 0.1438)\n",
      "  Decodability plot saved to results_data_size_sweep/20250514_045146/samples_640/decodability_Transformer_coeff1.png\n",
      "Decodability (R2 score) for Transformer (samples=640): 0.4019\n",
      "\n",
      "--- Training TransformerCausal (samples=640, k=15) ---\n",
      "Number of parameters: 85809\n",
      "Epoch 1/200, Train Loss: 17.6903, Val Loss: 15.8240\n",
      "  New best validation loss: 15.8240\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/conda/lib/python3.10/site-packages/torch/nn/modules/activation.py:1160: UserWarning: Converting mask without torch.bool dtype to bool; this will negatively affect performance. Prefer to use a boolean mask directly. (Triggered internally at /opt/conda/conda-bld/pytorch_1682343995026/work/aten/src/ATen/native/transformers/attention.cpp:150.)\n",
      "  return torch._native_multi_head_attention(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/200, Train Loss: 16.8088, Val Loss: 15.8433\n",
      "Epoch 3/200, Train Loss: 16.7826, Val Loss: 15.8479\n",
      "Epoch 4/200, Train Loss: 16.7566, Val Loss: 15.7843\n",
      "  New best validation loss: 15.7843\n",
      "Epoch 5/200, Train Loss: 16.7542, Val Loss: 15.8352\n",
      "Epoch 6/200, Train Loss: 16.7285, Val Loss: 15.9025\n",
      "Epoch 7/200, Train Loss: 16.7168, Val Loss: 15.7568\n",
      "  New best validation loss: 15.7568\n",
      "Epoch 8/200, Train Loss: 16.7225, Val Loss: 15.7713\n",
      "Epoch 9/200, Train Loss: 16.6955, Val Loss: 15.8956\n",
      "Epoch 10/200, Train Loss: 16.7100, Val Loss: 15.8706\n",
      "Epoch 11/200, Train Loss: 16.6923, Val Loss: 15.9465\n",
      "Epoch 12/200, Train Loss: 16.6864, Val Loss: 15.9018\n",
      "Epoch 13/200, Train Loss: 16.6866, Val Loss: 15.7567\n",
      "  New best validation loss: 15.7567\n",
      "Epoch 14/200, Train Loss: 16.6938, Val Loss: 15.7657\n",
      "Epoch 15/200, Train Loss: 16.6553, Val Loss: 15.8397\n",
      "Epoch 16/200, Train Loss: 16.6668, Val Loss: 15.8658\n",
      "Epoch 17/200, Train Loss: 16.6547, Val Loss: 15.7642\n",
      "Epoch 18/200, Train Loss: 16.6348, Val Loss: 15.9408\n",
      "Epoch 19/200, Train Loss: 16.6423, Val Loss: 15.7401\n",
      "  New best validation loss: 15.7401\n",
      "Epoch 20/200, Train Loss: 16.6402, Val Loss: 15.7658\n",
      "Epoch 21/200, Train Loss: 16.6432, Val Loss: 15.7530\n",
      "Epoch 22/200, Train Loss: 16.6321, Val Loss: 15.7670\n",
      "Epoch 23/200, Train Loss: 16.5994, Val Loss: 15.8597\n",
      "Epoch 24/200, Train Loss: 16.6263, Val Loss: 15.7670\n",
      "Epoch 25/200, Train Loss: 16.5731, Val Loss: 15.7101\n",
      "  New best validation loss: 15.7101\n",
      "Epoch 26/200, Train Loss: 16.6008, Val Loss: 15.7851\n",
      "Epoch 27/200, Train Loss: 16.5947, Val Loss: 16.0326\n",
      "Epoch 28/200, Train Loss: 16.6291, Val Loss: 15.8912\n",
      "Epoch 29/200, Train Loss: 16.6000, Val Loss: 16.0939\n",
      "Epoch 30/200, Train Loss: 16.6453, Val Loss: 16.1437\n",
      "Epoch 31/200, Train Loss: 16.6275, Val Loss: 15.7825\n",
      "Epoch 32/200, Train Loss: 16.5737, Val Loss: 15.7577\n",
      "Epoch 33/200, Train Loss: 16.5390, Val Loss: 15.7947\n",
      "Epoch 34/200, Train Loss: 16.5559, Val Loss: 15.9664\n",
      "Epoch 35/200, Train Loss: 16.6093, Val Loss: 15.7512\n",
      "Epoch 36/200, Train Loss: 16.5357, Val Loss: 15.7288\n",
      "Epoch 37/200, Train Loss: 16.5561, Val Loss: 15.8998\n",
      "Epoch 38/200, Train Loss: 16.6111, Val Loss: 15.9456\n",
      "Epoch 39/200, Train Loss: 16.5222, Val Loss: 15.6742\n",
      "  New best validation loss: 15.6742\n",
      "Epoch 40/200, Train Loss: 16.5222, Val Loss: 15.7237\n",
      "Epoch 41/200, Train Loss: 16.5196, Val Loss: 15.8042\n",
      "Epoch 42/200, Train Loss: 16.5058, Val Loss: 15.6995\n",
      "Epoch 43/200, Train Loss: 16.5127, Val Loss: 15.6263\n",
      "  New best validation loss: 15.6263\n",
      "Epoch 44/200, Train Loss: 16.5003, Val Loss: 15.5832\n",
      "  New best validation loss: 15.5832\n",
      "Epoch 45/200, Train Loss: 16.5158, Val Loss: 15.6795\n",
      "Epoch 46/200, Train Loss: 16.5022, Val Loss: 15.6755\n",
      "Epoch 47/200, Train Loss: 16.4722, Val Loss: 15.6292\n",
      "Epoch 48/200, Train Loss: 16.4636, Val Loss: 15.6545\n",
      "Epoch 49/200, Train Loss: 16.4611, Val Loss: 15.6182\n",
      "Epoch 50/200, Train Loss: 16.4484, Val Loss: 15.5404\n",
      "  New best validation loss: 15.5404\n",
      "Epoch 51/200, Train Loss: 16.4987, Val Loss: 15.6181\n",
      "Epoch 52/200, Train Loss: 16.4289, Val Loss: 15.5375\n",
      "  New best validation loss: 15.5375\n",
      "Epoch 53/200, Train Loss: 16.4416, Val Loss: 15.5240\n",
      "  New best validation loss: 15.5240\n",
      "Epoch 54/200, Train Loss: 16.4357, Val Loss: 15.5553\n",
      "Epoch 55/200, Train Loss: 16.4420, Val Loss: 15.4600\n",
      "  New best validation loss: 15.4600\n",
      "Epoch 56/200, Train Loss: 16.4084, Val Loss: 15.6057\n",
      "Epoch 57/200, Train Loss: 16.3876, Val Loss: 15.4581\n",
      "  New best validation loss: 15.4581\n",
      "Epoch 58/200, Train Loss: 16.4781, Val Loss: 15.4719\n",
      "Epoch 59/200, Train Loss: 16.4165, Val Loss: 15.4353\n",
      "  New best validation loss: 15.4353\n",
      "Epoch 60/200, Train Loss: 16.3883, Val Loss: 15.4321\n",
      "  New best validation loss: 15.4321\n",
      "Epoch 61/200, Train Loss: 16.3491, Val Loss: 15.4322\n",
      "Epoch 62/200, Train Loss: 16.3417, Val Loss: 15.4102\n",
      "  New best validation loss: 15.4102\n",
      "Epoch 63/200, Train Loss: 16.3800, Val Loss: 15.4055\n",
      "  New best validation loss: 15.4055\n",
      "Epoch 64/200, Train Loss: 16.3010, Val Loss: 15.4853\n",
      "Epoch 65/200, Train Loss: 16.4386, Val Loss: 15.3709\n",
      "  New best validation loss: 15.3709\n",
      "Epoch 66/200, Train Loss: 16.3426, Val Loss: 15.4044\n",
      "Epoch 67/200, Train Loss: 16.3156, Val Loss: 15.3492\n",
      "  New best validation loss: 15.3492\n",
      "Epoch 68/200, Train Loss: 16.3208, Val Loss: 15.2784\n",
      "  New best validation loss: 15.2784\n",
      "Epoch 69/200, Train Loss: 16.3020, Val Loss: 15.3147\n",
      "Epoch 70/200, Train Loss: 16.2881, Val Loss: 15.3357\n",
      "Epoch 71/200, Train Loss: 16.2503, Val Loss: 15.2707\n",
      "  New best validation loss: 15.2707\n",
      "Epoch 72/200, Train Loss: 16.2781, Val Loss: 15.2754\n",
      "Epoch 73/200, Train Loss: 16.2698, Val Loss: 15.2891\n",
      "Epoch 74/200, Train Loss: 16.2488, Val Loss: 15.3931\n",
      "Epoch 75/200, Train Loss: 16.2494, Val Loss: 15.4873\n",
      "Epoch 76/200, Train Loss: 16.3110, Val Loss: 15.3728\n",
      "Epoch 77/200, Train Loss: 16.2219, Val Loss: 15.2052\n",
      "  New best validation loss: 15.2052\n",
      "Epoch 78/200, Train Loss: 16.2171, Val Loss: 15.1989\n",
      "  New best validation loss: 15.1989\n",
      "Epoch 79/200, Train Loss: 16.1730, Val Loss: 15.2067\n",
      "Epoch 80/200, Train Loss: 16.2070, Val Loss: 15.4296\n",
      "Epoch 81/200, Train Loss: 16.2114, Val Loss: 15.4160\n",
      "Epoch 82/200, Train Loss: 16.1617, Val Loss: 15.2645\n",
      "Epoch 83/200, Train Loss: 16.1692, Val Loss: 15.2288\n",
      "Epoch 84/200, Train Loss: 16.1207, Val Loss: 15.3154\n",
      "Epoch 85/200, Train Loss: 16.1724, Val Loss: 15.2078\n",
      "Epoch 86/200, Train Loss: 16.0962, Val Loss: 15.0524\n",
      "  New best validation loss: 15.0524\n",
      "Epoch 87/200, Train Loss: 16.1163, Val Loss: 15.1619\n",
      "Epoch 88/200, Train Loss: 16.0820, Val Loss: 15.0371\n",
      "  New best validation loss: 15.0371\n",
      "Epoch 89/200, Train Loss: 16.0340, Val Loss: 15.2595\n",
      "Epoch 90/200, Train Loss: 16.0734, Val Loss: 15.0573\n",
      "Epoch 91/200, Train Loss: 16.0746, Val Loss: 15.0475\n",
      "Epoch 92/200, Train Loss: 16.0353, Val Loss: 15.1203\n",
      "Epoch 93/200, Train Loss: 16.0330, Val Loss: 15.1175\n",
      "Epoch 94/200, Train Loss: 16.0254, Val Loss: 15.0374\n",
      "Epoch 95/200, Train Loss: 15.9885, Val Loss: 15.1169\n",
      "Epoch 96/200, Train Loss: 16.0182, Val Loss: 15.4091\n",
      "Epoch 97/200, Train Loss: 15.9122, Val Loss: 14.9978\n",
      "  New best validation loss: 14.9978\n",
      "Epoch 98/200, Train Loss: 15.9475, Val Loss: 14.9844\n",
      "  New best validation loss: 14.9844\n",
      "Epoch 99/200, Train Loss: 15.8919, Val Loss: 15.0468\n",
      "Epoch 100/200, Train Loss: 15.9352, Val Loss: 14.9804\n",
      "  New best validation loss: 14.9804\n",
      "Epoch 101/200, Train Loss: 15.8848, Val Loss: 15.0909\n",
      "Epoch 102/200, Train Loss: 15.8345, Val Loss: 15.0124\n",
      "Epoch 103/200, Train Loss: 15.8330, Val Loss: 14.9482\n",
      "  New best validation loss: 14.9482\n",
      "Epoch 104/200, Train Loss: 15.7729, Val Loss: 14.8882\n",
      "  New best validation loss: 14.8882\n",
      "Epoch 105/200, Train Loss: 15.7624, Val Loss: 14.8904\n",
      "Epoch 106/200, Train Loss: 15.7611, Val Loss: 14.8641\n",
      "  New best validation loss: 14.8641\n",
      "Epoch 107/200, Train Loss: 15.7110, Val Loss: 14.8339\n",
      "  New best validation loss: 14.8339\n",
      "Epoch 108/200, Train Loss: 15.6916, Val Loss: 14.7886\n",
      "  New best validation loss: 14.7886\n",
      "Epoch 109/200, Train Loss: 15.6476, Val Loss: 14.7717\n",
      "  New best validation loss: 14.7717\n",
      "Epoch 110/200, Train Loss: 15.6279, Val Loss: 14.9071\n",
      "Epoch 111/200, Train Loss: 15.6647, Val Loss: 14.7219\n",
      "  New best validation loss: 14.7219\n",
      "Epoch 112/200, Train Loss: 15.5691, Val Loss: 14.7022\n",
      "  New best validation loss: 14.7022\n",
      "Epoch 113/200, Train Loss: 15.6077, Val Loss: 15.1168\n",
      "Epoch 114/200, Train Loss: 15.5904, Val Loss: 14.7192\n",
      "Epoch 115/200, Train Loss: 15.5156, Val Loss: 14.6607\n",
      "  New best validation loss: 14.6607\n",
      "Epoch 116/200, Train Loss: 15.4895, Val Loss: 14.5391\n",
      "  New best validation loss: 14.5391\n",
      "Epoch 117/200, Train Loss: 15.4650, Val Loss: 14.7459\n",
      "Epoch 118/200, Train Loss: 15.4720, Val Loss: 14.5090\n",
      "  New best validation loss: 14.5090\n",
      "Epoch 119/200, Train Loss: 15.4339, Val Loss: 14.5553\n",
      "Epoch 120/200, Train Loss: 15.3569, Val Loss: 14.5494\n",
      "Epoch 121/200, Train Loss: 15.3302, Val Loss: 14.5801\n",
      "Epoch 122/200, Train Loss: 15.3114, Val Loss: 14.7916\n",
      "Epoch 123/200, Train Loss: 15.3399, Val Loss: 14.5703\n",
      "Epoch 124/200, Train Loss: 15.2953, Val Loss: 14.3824\n",
      "  New best validation loss: 14.3824\n",
      "Epoch 125/200, Train Loss: 15.2726, Val Loss: 14.3379\n",
      "  New best validation loss: 14.3379\n",
      "Epoch 126/200, Train Loss: 15.1432, Val Loss: 14.3056\n",
      "  New best validation loss: 14.3056\n",
      "Epoch 127/200, Train Loss: 15.1326, Val Loss: 14.2957\n",
      "  New best validation loss: 14.2957\n",
      "Epoch 128/200, Train Loss: 15.1023, Val Loss: 14.2795\n",
      "  New best validation loss: 14.2795\n",
      "Epoch 129/200, Train Loss: 15.1189, Val Loss: 14.5763\n",
      "Epoch 130/200, Train Loss: 15.1238, Val Loss: 14.2276\n",
      "  New best validation loss: 14.2276\n",
      "Epoch 131/200, Train Loss: 15.0253, Val Loss: 14.0794\n",
      "  New best validation loss: 14.0794\n",
      "Epoch 132/200, Train Loss: 14.9345, Val Loss: 14.1053\n",
      "Epoch 133/200, Train Loss: 14.9082, Val Loss: 14.1249\n",
      "Epoch 134/200, Train Loss: 14.8727, Val Loss: 13.9799\n",
      "  New best validation loss: 13.9799\n",
      "Epoch 135/200, Train Loss: 14.9063, Val Loss: 13.9057\n",
      "  New best validation loss: 13.9057\n",
      "Epoch 136/200, Train Loss: 14.8672, Val Loss: 13.9732\n",
      "Epoch 137/200, Train Loss: 14.8039, Val Loss: 13.8886\n",
      "  New best validation loss: 13.8886\n",
      "Epoch 138/200, Train Loss: 14.7279, Val Loss: 13.7624\n",
      "  New best validation loss: 13.7624\n",
      "Epoch 139/200, Train Loss: 14.6987, Val Loss: 13.7099\n",
      "  New best validation loss: 13.7099\n",
      "Epoch 140/200, Train Loss: 14.6857, Val Loss: 13.8725\n",
      "Epoch 141/200, Train Loss: 14.6669, Val Loss: 13.7756\n",
      "Epoch 142/200, Train Loss: 14.6902, Val Loss: 13.7074\n",
      "  New best validation loss: 13.7074\n",
      "Epoch 143/200, Train Loss: 14.6048, Val Loss: 13.5473\n",
      "  New best validation loss: 13.5473\n",
      "Epoch 144/200, Train Loss: 14.6366, Val Loss: 13.6081\n",
      "Epoch 145/200, Train Loss: 14.4566, Val Loss: 13.5937\n",
      "Epoch 146/200, Train Loss: 14.5180, Val Loss: 13.5899\n",
      "Epoch 147/200, Train Loss: 14.4903, Val Loss: 13.5679\n",
      "Epoch 148/200, Train Loss: 14.4193, Val Loss: 13.3655\n",
      "  New best validation loss: 13.3655\n",
      "Epoch 149/200, Train Loss: 14.4157, Val Loss: 13.4141\n",
      "Epoch 150/200, Train Loss: 14.3475, Val Loss: 13.3497\n",
      "  New best validation loss: 13.3497\n",
      "Epoch 151/200, Train Loss: 14.3356, Val Loss: 13.3839\n",
      "Epoch 152/200, Train Loss: 14.3371, Val Loss: 13.3336\n",
      "  New best validation loss: 13.3336\n",
      "Epoch 153/200, Train Loss: 14.3863, Val Loss: 13.2982\n",
      "  New best validation loss: 13.2982\n",
      "Epoch 154/200, Train Loss: 14.2966, Val Loss: 13.4856\n",
      "Epoch 155/200, Train Loss: 14.2674, Val Loss: 13.2632\n",
      "  New best validation loss: 13.2632\n",
      "Epoch 156/200, Train Loss: 14.2533, Val Loss: 13.4997\n",
      "Epoch 157/200, Train Loss: 14.2588, Val Loss: 13.3082\n",
      "Epoch 158/200, Train Loss: 14.2047, Val Loss: 13.1973\n",
      "  New best validation loss: 13.1973\n",
      "Epoch 159/200, Train Loss: 14.1133, Val Loss: 13.2052\n",
      "Epoch 160/200, Train Loss: 14.1458, Val Loss: 13.2685\n",
      "Epoch 161/200, Train Loss: 14.0991, Val Loss: 13.3028\n",
      "Epoch 162/200, Train Loss: 14.1916, Val Loss: 13.1720\n",
      "  New best validation loss: 13.1720\n",
      "Epoch 163/200, Train Loss: 14.0915, Val Loss: 13.2908\n",
      "Epoch 164/200, Train Loss: 14.1556, Val Loss: 13.2454\n",
      "Epoch 165/200, Train Loss: 14.1682, Val Loss: 13.1920\n",
      "Epoch 166/200, Train Loss: 14.1214, Val Loss: 13.2247\n",
      "Epoch 167/200, Train Loss: 14.0612, Val Loss: 13.1667\n",
      "  New best validation loss: 13.1667\n",
      "Epoch 168/200, Train Loss: 14.0808, Val Loss: 13.2824\n",
      "Epoch 169/200, Train Loss: 14.0406, Val Loss: 13.0567\n",
      "  New best validation loss: 13.0567\n",
      "Epoch 170/200, Train Loss: 14.0264, Val Loss: 13.0711\n",
      "Epoch 171/200, Train Loss: 14.0258, Val Loss: 13.1142\n",
      "Epoch 172/200, Train Loss: 13.9839, Val Loss: 13.0980\n",
      "Epoch 173/200, Train Loss: 14.0232, Val Loss: 13.0355\n",
      "  New best validation loss: 13.0355\n",
      "Epoch 174/200, Train Loss: 13.9615, Val Loss: 13.0886\n",
      "Epoch 175/200, Train Loss: 13.9552, Val Loss: 13.1457\n",
      "Epoch 176/200, Train Loss: 13.9095, Val Loss: 13.1191\n",
      "Epoch 177/200, Train Loss: 13.9533, Val Loss: 13.1124\n",
      "Epoch 178/200, Train Loss: 13.8989, Val Loss: 13.0217\n",
      "  New best validation loss: 13.0217\n",
      "Epoch 179/200, Train Loss: 13.9103, Val Loss: 13.0248\n",
      "Epoch 180/200, Train Loss: 13.8591, Val Loss: 12.9494\n",
      "  New best validation loss: 12.9494\n",
      "Epoch 181/200, Train Loss: 13.8345, Val Loss: 13.0432\n",
      "Epoch 182/200, Train Loss: 13.8921, Val Loss: 12.8834\n",
      "  New best validation loss: 12.8834\n",
      "Epoch 183/200, Train Loss: 13.8745, Val Loss: 13.1676\n",
      "Epoch 184/200, Train Loss: 13.9314, Val Loss: 13.0705\n",
      "Epoch 185/200, Train Loss: 13.9074, Val Loss: 12.8578\n",
      "  New best validation loss: 12.8578\n",
      "Epoch 186/200, Train Loss: 13.8427, Val Loss: 13.0017\n",
      "Epoch 187/200, Train Loss: 13.8849, Val Loss: 12.9579\n",
      "Epoch 188/200, Train Loss: 13.8076, Val Loss: 12.9036\n",
      "Epoch 189/200, Train Loss: 13.8358, Val Loss: 12.9131\n",
      "Epoch 190/200, Train Loss: 13.8958, Val Loss: 12.8729\n",
      "Epoch 191/200, Train Loss: 13.7846, Val Loss: 13.0866\n",
      "Epoch 192/200, Train Loss: 13.7743, Val Loss: 12.9055\n",
      "Epoch 193/200, Train Loss: 13.8008, Val Loss: 12.9316\n",
      "Epoch 194/200, Train Loss: 13.7686, Val Loss: 12.9068\n",
      "Epoch 195/200, Train Loss: 13.8598, Val Loss: 12.9708\n",
      "Epoch 196/200, Train Loss: 13.8069, Val Loss: 12.8365\n",
      "  New best validation loss: 12.8365\n",
      "Epoch 197/200, Train Loss: 13.6788, Val Loss: 12.9190\n",
      "Epoch 198/200, Train Loss: 13.7213, Val Loss: 12.9399\n",
      "Epoch 199/200, Train Loss: 13.7797, Val Loss: 12.8276\n",
      "  New best validation loss: 12.8276\n",
      "Epoch 200/200, Train Loss: 13.7413, Val Loss: 12.8750\n",
      "\n",
      "Loaded best model (Val Loss: 12.8276) for final hidden state extraction.\n",
      "Saved best model for TransformerCausal (samples=640) to results_data_size_sweep/20250514_045146/samples_640/TransformerCausal_samples_640_best.pt\n",
      "\n",
      "--- Performing Decodability Analysis for TransformerCausal (samples=640, k=15) ---\n",
      "  Analyzing decodability for TransformerCausal...\n",
      "  Hidden states shape: torch.Size([160, 200, 20])\n",
      "  Coefficients shape: torch.Size([160, 15])\n",
      "  Processed hidden states shape for decoder: torch.Size([160, 20])\n",
      "  RidgeCV Decoder for TransformerCausal - Test MSE: 0.9774, Test R2: 0.5107 (best alpha: 0.0336)\n",
      "  Decodability plot saved to results_data_size_sweep/20250514_045146/samples_640/decodability_TransformerCausal_coeff1.png\n",
      "Decodability (R2 score) for TransformerCausal (samples=640): 0.5107\n",
      "\n",
      "--- Training HIPPORNN_LegT (samples=640, k=15) ---\n",
      "Number of parameters: 4029\n",
      "Epoch 1/200, Train Loss: 17.0358, Val Loss: 15.8494\n",
      "  New best validation loss: 15.8494\n",
      "Epoch 2/200, Train Loss: 17.0307, Val Loss: 15.8451\n",
      "  New best validation loss: 15.8451\n",
      "Epoch 3/200, Train Loss: 17.0239, Val Loss: 15.8405\n",
      "  New best validation loss: 15.8405\n",
      "Epoch 4/200, Train Loss: 17.0130, Val Loss: 15.8329\n",
      "  New best validation loss: 15.8329\n",
      "Epoch 5/200, Train Loss: 16.9966, Val Loss: 15.8206\n",
      "  New best validation loss: 15.8206\n",
      "Epoch 6/200, Train Loss: 16.9693, Val Loss: 15.7988\n",
      "  New best validation loss: 15.7988\n",
      "Epoch 7/200, Train Loss: 16.9142, Val Loss: 15.7510\n",
      "  New best validation loss: 15.7510\n",
      "Epoch 8/200, Train Loss: 16.7844, Val Loss: 15.6540\n",
      "  New best validation loss: 15.6540\n",
      "Epoch 9/200, Train Loss: 16.5991, Val Loss: 15.6927\n",
      "Epoch 10/200, Train Loss: 16.5276, Val Loss: 15.7318\n",
      "Epoch 11/200, Train Loss: 16.5075, Val Loss: 15.6342\n",
      "  New best validation loss: 15.6342\n",
      "Epoch 12/200, Train Loss: 16.4822, Val Loss: 15.6513\n",
      "Epoch 13/200, Train Loss: 16.4843, Val Loss: 15.6808\n",
      "Epoch 14/200, Train Loss: 16.4478, Val Loss: 15.6308\n",
      "  New best validation loss: 15.6308\n",
      "Epoch 15/200, Train Loss: 16.4415, Val Loss: 15.6096\n",
      "  New best validation loss: 15.6096\n",
      "Epoch 16/200, Train Loss: 16.4347, Val Loss: 15.6375\n",
      "Epoch 17/200, Train Loss: 16.4239, Val Loss: 15.6361\n",
      "Epoch 18/200, Train Loss: 16.4025, Val Loss: 15.6054\n",
      "  New best validation loss: 15.6054\n",
      "Epoch 19/200, Train Loss: 16.4016, Val Loss: 15.5940\n",
      "  New best validation loss: 15.5940\n",
      "Epoch 20/200, Train Loss: 16.3809, Val Loss: 15.6022\n",
      "Epoch 21/200, Train Loss: 16.3659, Val Loss: 15.5951\n",
      "Epoch 22/200, Train Loss: 16.3489, Val Loss: 15.5747\n",
      "  New best validation loss: 15.5747\n",
      "Epoch 23/200, Train Loss: 16.3315, Val Loss: 15.5638\n",
      "  New best validation loss: 15.5638\n",
      "Epoch 24/200, Train Loss: 16.3190, Val Loss: 15.5717\n",
      "Epoch 25/200, Train Loss: 16.2946, Val Loss: 15.5204\n",
      "  New best validation loss: 15.5204\n",
      "Epoch 26/200, Train Loss: 16.2682, Val Loss: 15.5064\n",
      "  New best validation loss: 15.5064\n",
      "Epoch 27/200, Train Loss: 16.2405, Val Loss: 15.5057\n",
      "  New best validation loss: 15.5057\n",
      "Epoch 28/200, Train Loss: 16.2033, Val Loss: 15.4707\n",
      "  New best validation loss: 15.4707\n",
      "Epoch 29/200, Train Loss: 16.1574, Val Loss: 15.4317\n",
      "  New best validation loss: 15.4317\n",
      "Epoch 30/200, Train Loss: 16.1062, Val Loss: 15.4060\n",
      "  New best validation loss: 15.4060\n",
      "Epoch 31/200, Train Loss: 16.0450, Val Loss: 15.3468\n",
      "  New best validation loss: 15.3468\n",
      "Epoch 32/200, Train Loss: 15.9694, Val Loss: 15.3016\n",
      "  New best validation loss: 15.3016\n",
      "Epoch 33/200, Train Loss: 15.8964, Val Loss: 15.2638\n",
      "  New best validation loss: 15.2638\n",
      "Epoch 34/200, Train Loss: 15.8269, Val Loss: 15.2082\n",
      "  New best validation loss: 15.2082\n",
      "Epoch 35/200, Train Loss: 15.7562, Val Loss: 15.1440\n",
      "  New best validation loss: 15.1440\n",
      "Epoch 36/200, Train Loss: 15.6787, Val Loss: 15.1175\n",
      "  New best validation loss: 15.1175\n",
      "Epoch 37/200, Train Loss: 15.6111, Val Loss: 15.0869\n",
      "  New best validation loss: 15.0869\n",
      "Epoch 38/200, Train Loss: 15.5518, Val Loss: 15.0433\n",
      "  New best validation loss: 15.0433\n",
      "Epoch 39/200, Train Loss: 15.4962, Val Loss: 15.0245\n",
      "  New best validation loss: 15.0245\n",
      "Epoch 40/200, Train Loss: 15.4378, Val Loss: 14.9834\n",
      "  New best validation loss: 14.9834\n",
      "Epoch 41/200, Train Loss: 15.3784, Val Loss: 14.9583\n",
      "  New best validation loss: 14.9583\n",
      "Epoch 42/200, Train Loss: 15.3274, Val Loss: 14.9345\n",
      "  New best validation loss: 14.9345\n",
      "Epoch 43/200, Train Loss: 15.2652, Val Loss: 14.8708\n",
      "  New best validation loss: 14.8708\n",
      "Epoch 44/200, Train Loss: 15.2108, Val Loss: 14.8332\n",
      "  New best validation loss: 14.8332\n",
      "Epoch 45/200, Train Loss: 15.1459, Val Loss: 14.8152\n",
      "  New best validation loss: 14.8152\n",
      "Epoch 46/200, Train Loss: 15.0895, Val Loss: 14.7696\n",
      "  New best validation loss: 14.7696\n",
      "Epoch 47/200, Train Loss: 15.0578, Val Loss: 14.7640\n",
      "  New best validation loss: 14.7640\n",
      "Epoch 48/200, Train Loss: 14.9971, Val Loss: 14.6766\n",
      "  New best validation loss: 14.6766\n",
      "Epoch 49/200, Train Loss: 14.9414, Val Loss: 14.6805\n",
      "Epoch 50/200, Train Loss: 14.8932, Val Loss: 14.6492\n",
      "  New best validation loss: 14.6492\n",
      "Epoch 51/200, Train Loss: 14.8389, Val Loss: 14.6307\n",
      "  New best validation loss: 14.6307\n",
      "Epoch 52/200, Train Loss: 14.7971, Val Loss: 14.5887\n",
      "  New best validation loss: 14.5887\n",
      "Epoch 53/200, Train Loss: 14.7550, Val Loss: 14.5972\n",
      "Epoch 54/200, Train Loss: 14.7163, Val Loss: 14.5412\n",
      "  New best validation loss: 14.5412\n",
      "Epoch 55/200, Train Loss: 14.6633, Val Loss: 14.5428\n",
      "Epoch 56/200, Train Loss: 14.6277, Val Loss: 14.5010\n",
      "  New best validation loss: 14.5010\n",
      "Epoch 57/200, Train Loss: 14.5956, Val Loss: 14.4818\n",
      "  New best validation loss: 14.4818\n",
      "Epoch 58/200, Train Loss: 14.5514, Val Loss: 14.4526\n",
      "  New best validation loss: 14.4526\n",
      "Epoch 59/200, Train Loss: 14.5023, Val Loss: 14.4340\n",
      "  New best validation loss: 14.4340\n",
      "Epoch 60/200, Train Loss: 14.4811, Val Loss: 14.3977\n",
      "  New best validation loss: 14.3977\n",
      "Epoch 61/200, Train Loss: 14.4296, Val Loss: 14.4046\n",
      "Epoch 62/200, Train Loss: 14.4002, Val Loss: 14.4029\n",
      "Epoch 63/200, Train Loss: 14.3581, Val Loss: 14.3339\n",
      "  New best validation loss: 14.3339\n",
      "Epoch 64/200, Train Loss: 14.3214, Val Loss: 14.3525\n",
      "Epoch 65/200, Train Loss: 14.2834, Val Loss: 14.3273\n",
      "  New best validation loss: 14.3273\n",
      "Epoch 66/200, Train Loss: 14.2426, Val Loss: 14.3209\n",
      "  New best validation loss: 14.3209\n",
      "Epoch 67/200, Train Loss: 14.2020, Val Loss: 14.2689\n",
      "  New best validation loss: 14.2689\n",
      "Epoch 68/200, Train Loss: 14.1641, Val Loss: 14.2587\n",
      "  New best validation loss: 14.2587\n",
      "Epoch 69/200, Train Loss: 14.1273, Val Loss: 14.2566\n",
      "  New best validation loss: 14.2566\n",
      "Epoch 70/200, Train Loss: 14.0944, Val Loss: 14.2368\n",
      "  New best validation loss: 14.2368\n",
      "Epoch 71/200, Train Loss: 14.0571, Val Loss: 14.2658\n",
      "Epoch 72/200, Train Loss: 14.0302, Val Loss: 14.1802\n",
      "  New best validation loss: 14.1802\n",
      "Epoch 73/200, Train Loss: 13.9964, Val Loss: 14.1332\n",
      "  New best validation loss: 14.1332\n",
      "Epoch 74/200, Train Loss: 13.9677, Val Loss: 14.1600\n",
      "Epoch 75/200, Train Loss: 13.9215, Val Loss: 14.1209\n",
      "  New best validation loss: 14.1209\n",
      "Epoch 76/200, Train Loss: 13.8907, Val Loss: 14.1287\n",
      "Epoch 77/200, Train Loss: 13.8599, Val Loss: 14.2383\n",
      "Epoch 78/200, Train Loss: 13.8667, Val Loss: 14.0596\n",
      "  New best validation loss: 14.0596\n",
      "Epoch 79/200, Train Loss: 13.8265, Val Loss: 14.0792\n",
      "Epoch 80/200, Train Loss: 13.8501, Val Loss: 14.0468\n",
      "  New best validation loss: 14.0468\n",
      "Epoch 81/200, Train Loss: 13.7798, Val Loss: 14.1325\n",
      "Epoch 82/200, Train Loss: 13.7293, Val Loss: 14.0273\n",
      "  New best validation loss: 14.0273\n",
      "Epoch 83/200, Train Loss: 13.6929, Val Loss: 13.9831\n",
      "  New best validation loss: 13.9831\n",
      "Epoch 84/200, Train Loss: 13.6719, Val Loss: 13.9666\n",
      "  New best validation loss: 13.9666\n",
      "Epoch 85/200, Train Loss: 13.6273, Val Loss: 13.9945\n",
      "Epoch 86/200, Train Loss: 13.6081, Val Loss: 13.9583\n",
      "  New best validation loss: 13.9583\n",
      "Epoch 87/200, Train Loss: 13.5655, Val Loss: 13.9576\n",
      "  New best validation loss: 13.9576\n",
      "Epoch 88/200, Train Loss: 13.5398, Val Loss: 13.9216\n",
      "  New best validation loss: 13.9216\n",
      "Epoch 89/200, Train Loss: 13.5210, Val Loss: 13.8981\n",
      "  New best validation loss: 13.8981\n",
      "Epoch 90/200, Train Loss: 13.4895, Val Loss: 13.8582\n",
      "  New best validation loss: 13.8582\n",
      "Epoch 91/200, Train Loss: 13.4719, Val Loss: 13.8542\n",
      "  New best validation loss: 13.8542\n",
      "Epoch 92/200, Train Loss: 13.4461, Val Loss: 13.8347\n",
      "  New best validation loss: 13.8347\n",
      "Epoch 93/200, Train Loss: 13.3996, Val Loss: 13.8812\n",
      "Epoch 94/200, Train Loss: 13.3925, Val Loss: 13.8378\n",
      "Epoch 95/200, Train Loss: 13.3707, Val Loss: 13.7972\n",
      "  New best validation loss: 13.7972\n",
      "Epoch 96/200, Train Loss: 13.3575, Val Loss: 13.8051\n",
      "Epoch 97/200, Train Loss: 13.3375, Val Loss: 13.8205\n",
      "Epoch 98/200, Train Loss: 13.2879, Val Loss: 13.7461\n",
      "  New best validation loss: 13.7461\n",
      "Epoch 99/200, Train Loss: 13.2673, Val Loss: 13.7396\n",
      "  New best validation loss: 13.7396\n",
      "Epoch 100/200, Train Loss: 13.2838, Val Loss: 13.7455\n",
      "Epoch 101/200, Train Loss: 13.2359, Val Loss: 13.6992\n",
      "  New best validation loss: 13.6992\n",
      "Epoch 102/200, Train Loss: 13.2004, Val Loss: 13.7005\n",
      "Epoch 103/200, Train Loss: 13.1780, Val Loss: 13.6847\n",
      "  New best validation loss: 13.6847\n",
      "Epoch 104/200, Train Loss: 13.1729, Val Loss: 13.7074\n",
      "Epoch 105/200, Train Loss: 13.1380, Val Loss: 13.6368\n",
      "  New best validation loss: 13.6368\n",
      "Epoch 106/200, Train Loss: 13.1255, Val Loss: 13.6769\n",
      "Epoch 107/200, Train Loss: 13.0949, Val Loss: 13.6595\n",
      "Epoch 108/200, Train Loss: 13.0875, Val Loss: 13.5915\n",
      "  New best validation loss: 13.5915\n",
      "Epoch 109/200, Train Loss: 13.0516, Val Loss: 13.6154\n",
      "Epoch 110/200, Train Loss: 13.0415, Val Loss: 13.5829\n",
      "  New best validation loss: 13.5829\n",
      "Epoch 111/200, Train Loss: 13.0222, Val Loss: 13.5808\n",
      "  New best validation loss: 13.5808\n",
      "Epoch 112/200, Train Loss: 13.0056, Val Loss: 13.6633\n",
      "Epoch 113/200, Train Loss: 12.9895, Val Loss: 13.5711\n",
      "  New best validation loss: 13.5711\n",
      "Epoch 114/200, Train Loss: 12.9851, Val Loss: 13.5240\n",
      "  New best validation loss: 13.5240\n",
      "Epoch 115/200, Train Loss: 12.9385, Val Loss: 13.5026\n",
      "  New best validation loss: 13.5026\n",
      "Epoch 116/200, Train Loss: 12.9174, Val Loss: 13.4972\n",
      "  New best validation loss: 13.4972\n",
      "Epoch 117/200, Train Loss: 12.9183, Val Loss: 13.5616\n",
      "Epoch 118/200, Train Loss: 12.8804, Val Loss: 13.5538\n",
      "Epoch 119/200, Train Loss: 12.8674, Val Loss: 13.4665\n",
      "  New best validation loss: 13.4665\n",
      "Epoch 120/200, Train Loss: 12.8579, Val Loss: 13.4533\n",
      "  New best validation loss: 13.4533\n",
      "Epoch 121/200, Train Loss: 12.8233, Val Loss: 13.5239\n",
      "Epoch 122/200, Train Loss: 12.8238, Val Loss: 13.4396\n",
      "  New best validation loss: 13.4396\n",
      "Epoch 123/200, Train Loss: 12.7968, Val Loss: 13.4333\n",
      "  New best validation loss: 13.4333\n",
      "Epoch 124/200, Train Loss: 12.7682, Val Loss: 13.4491\n",
      "Epoch 125/200, Train Loss: 12.7660, Val Loss: 13.4017\n",
      "  New best validation loss: 13.4017\n",
      "Epoch 126/200, Train Loss: 12.7420, Val Loss: 13.4237\n",
      "Epoch 127/200, Train Loss: 12.7373, Val Loss: 13.4062\n",
      "Epoch 128/200, Train Loss: 12.7209, Val Loss: 13.3554\n",
      "  New best validation loss: 13.3554\n",
      "Epoch 129/200, Train Loss: 12.6986, Val Loss: 13.4617\n",
      "Epoch 130/200, Train Loss: 12.6681, Val Loss: 13.3750\n",
      "Epoch 131/200, Train Loss: 12.6556, Val Loss: 13.4349\n",
      "Epoch 132/200, Train Loss: 12.6535, Val Loss: 13.3508\n",
      "  New best validation loss: 13.3508\n",
      "Epoch 133/200, Train Loss: 12.6439, Val Loss: 13.3317\n",
      "  New best validation loss: 13.3317\n",
      "Epoch 134/200, Train Loss: 12.6070, Val Loss: 13.3688\n",
      "Epoch 135/200, Train Loss: 12.6109, Val Loss: 13.3615\n",
      "Epoch 136/200, Train Loss: 12.5877, Val Loss: 13.2915\n",
      "  New best validation loss: 13.2915\n",
      "Epoch 137/200, Train Loss: 12.5699, Val Loss: 13.2929\n",
      "Epoch 138/200, Train Loss: 12.5543, Val Loss: 13.3070\n",
      "Epoch 139/200, Train Loss: 12.5658, Val Loss: 13.2167\n",
      "  New best validation loss: 13.2167\n",
      "Epoch 140/200, Train Loss: 12.5669, Val Loss: 13.2673\n",
      "Epoch 141/200, Train Loss: 12.5106, Val Loss: 13.2817\n",
      "Epoch 142/200, Train Loss: 12.4827, Val Loss: 13.3026\n",
      "Epoch 143/200, Train Loss: 12.4829, Val Loss: 13.2709\n",
      "Epoch 144/200, Train Loss: 12.4706, Val Loss: 13.2669\n",
      "Epoch 145/200, Train Loss: 12.4624, Val Loss: 13.2605\n",
      "Epoch 146/200, Train Loss: 12.4406, Val Loss: 13.1929\n",
      "  New best validation loss: 13.1929\n",
      "Epoch 147/200, Train Loss: 12.4381, Val Loss: 13.2338\n",
      "Epoch 148/200, Train Loss: 12.4478, Val Loss: 13.2606\n",
      "Epoch 149/200, Train Loss: 12.4045, Val Loss: 13.1931\n",
      "Epoch 150/200, Train Loss: 12.3951, Val Loss: 13.2608\n",
      "Epoch 151/200, Train Loss: 12.4005, Val Loss: 13.1648\n",
      "  New best validation loss: 13.1648\n",
      "Epoch 152/200, Train Loss: 12.3737, Val Loss: 13.1829\n",
      "Epoch 153/200, Train Loss: 12.3718, Val Loss: 13.2473\n",
      "Epoch 154/200, Train Loss: 12.3574, Val Loss: 13.1600\n",
      "  New best validation loss: 13.1600\n",
      "Epoch 155/200, Train Loss: 12.3312, Val Loss: 13.1324\n",
      "  New best validation loss: 13.1324\n",
      "Epoch 156/200, Train Loss: 12.3100, Val Loss: 13.1710\n",
      "Epoch 157/200, Train Loss: 12.2990, Val Loss: 13.0737\n",
      "  New best validation loss: 13.0737\n",
      "Epoch 158/200, Train Loss: 12.3276, Val Loss: 13.0836\n",
      "Epoch 159/200, Train Loss: 12.3001, Val Loss: 13.1701\n",
      "Epoch 160/200, Train Loss: 12.2662, Val Loss: 13.1071\n",
      "Epoch 161/200, Train Loss: 12.2763, Val Loss: 13.0440\n",
      "  New best validation loss: 13.0440\n",
      "Epoch 162/200, Train Loss: 12.2545, Val Loss: 13.0686\n",
      "Epoch 163/200, Train Loss: 12.2375, Val Loss: 13.1126\n",
      "Epoch 164/200, Train Loss: 12.2453, Val Loss: 13.0506\n",
      "Epoch 165/200, Train Loss: 12.2252, Val Loss: 13.0818\n",
      "Epoch 166/200, Train Loss: 12.2089, Val Loss: 13.0638\n",
      "Epoch 167/200, Train Loss: 12.1879, Val Loss: 12.9954\n",
      "  New best validation loss: 12.9954\n",
      "Epoch 168/200, Train Loss: 12.1899, Val Loss: 12.9963\n",
      "Epoch 169/200, Train Loss: 12.1758, Val Loss: 13.0556\n",
      "Epoch 170/200, Train Loss: 12.1599, Val Loss: 13.0972\n",
      "Epoch 171/200, Train Loss: 12.1381, Val Loss: 12.9714\n",
      "  New best validation loss: 12.9714\n",
      "Epoch 172/200, Train Loss: 12.1499, Val Loss: 12.9859\n",
      "Epoch 173/200, Train Loss: 12.1533, Val Loss: 12.9842\n",
      "Epoch 174/200, Train Loss: 12.1276, Val Loss: 13.0329\n",
      "Epoch 175/200, Train Loss: 12.1077, Val Loss: 13.0120\n",
      "Epoch 176/200, Train Loss: 12.1444, Val Loss: 13.0239\n",
      "Epoch 177/200, Train Loss: 12.0961, Val Loss: 12.9318\n",
      "  New best validation loss: 12.9318\n",
      "Epoch 178/200, Train Loss: 12.0772, Val Loss: 12.9267\n",
      "  New best validation loss: 12.9267\n",
      "Epoch 179/200, Train Loss: 12.1043, Val Loss: 12.9642\n",
      "Epoch 180/200, Train Loss: 12.0672, Val Loss: 12.9951\n",
      "Epoch 181/200, Train Loss: 12.0381, Val Loss: 12.9438\n",
      "Epoch 182/200, Train Loss: 12.0375, Val Loss: 12.9474\n",
      "Epoch 183/200, Train Loss: 12.0458, Val Loss: 13.0039\n",
      "Epoch 184/200, Train Loss: 12.0297, Val Loss: 12.9731\n",
      "Epoch 185/200, Train Loss: 12.0169, Val Loss: 13.0472\n",
      "Epoch 186/200, Train Loss: 12.0034, Val Loss: 12.9513\n",
      "Epoch 187/200, Train Loss: 11.9828, Val Loss: 12.9227\n",
      "  New best validation loss: 12.9227\n",
      "Epoch 188/200, Train Loss: 11.9988, Val Loss: 12.9429\n",
      "Epoch 189/200, Train Loss: 11.9723, Val Loss: 12.8441\n",
      "  New best validation loss: 12.8441\n",
      "Epoch 190/200, Train Loss: 11.9775, Val Loss: 12.9146\n",
      "Epoch 191/200, Train Loss: 11.9660, Val Loss: 12.9018\n",
      "Epoch 192/200, Train Loss: 11.9436, Val Loss: 12.9543\n",
      "Epoch 193/200, Train Loss: 11.9265, Val Loss: 12.9441\n",
      "Epoch 194/200, Train Loss: 11.9209, Val Loss: 12.9305\n",
      "Epoch 195/200, Train Loss: 11.9173, Val Loss: 12.8493\n",
      "Epoch 196/200, Train Loss: 11.9353, Val Loss: 12.8849\n",
      "Epoch 197/200, Train Loss: 11.9226, Val Loss: 12.9270\n",
      "Epoch 198/200, Train Loss: 11.9122, Val Loss: 12.8920\n",
      "Epoch 199/200, Train Loss: 11.8972, Val Loss: 12.9313\n",
      "Epoch 200/200, Train Loss: 11.8768, Val Loss: 12.8509\n",
      "\n",
      "Loaded best model (Val Loss: 12.8441) for final hidden state extraction.\n",
      "Saved best model for HIPPORNN_LegT (samples=640) to results_data_size_sweep/20250514_045146/samples_640/HIPPORNN_LegT_samples_640_best.pt\n",
      "\n",
      "--- Performing Decodability Analysis for HIPPORNN_LegT (samples=640, k=15) ---\n",
      "  Analyzing decodability for HIPPORNN_LegT...\n",
      "  Hidden states shape: torch.Size([160, 200, 25])\n",
      "  Coefficients shape: torch.Size([160, 15])\n",
      "  Processed hidden states shape for decoder: torch.Size([160, 25])\n",
      "  RidgeCV Decoder for HIPPORNN_LegT - Test MSE: 1.5290, Test R2: 0.2310 (best alpha: 23.3572)\n",
      "  Decodability plot saved to results_data_size_sweep/20250514_045146/samples_640/decodability_HIPPORNN_LegT_coeff1.png\n",
      "Decodability (R2 score) for HIPPORNN_LegT (samples=640): 0.2310\n",
      "\n",
      "--- Training NMRNN_Spatial_ModReadout (samples=640, k=15) ---\n",
      "Number of parameters: 66832\n",
      "Epoch 1/200, Train Loss: 16.8836, Val Loss: 15.7345\n",
      "  New best validation loss: 15.7345\n",
      "Epoch 2/200, Train Loss: 16.7765, Val Loss: 15.7119\n",
      "  New best validation loss: 15.7119\n",
      "Epoch 3/200, Train Loss: 16.6587, Val Loss: 15.7517\n",
      "Epoch 4/200, Train Loss: 16.6491, Val Loss: 15.7743\n",
      "Epoch 5/200, Train Loss: 16.5897, Val Loss: 15.8303\n",
      "Epoch 6/200, Train Loss: 16.5675, Val Loss: 15.8051\n",
      "Epoch 7/200, Train Loss: 16.5270, Val Loss: 15.7899\n",
      "Epoch 8/200, Train Loss: 16.5044, Val Loss: 15.8534\n",
      "Epoch 9/200, Train Loss: 16.4995, Val Loss: 15.7826\n",
      "Epoch 10/200, Train Loss: 16.4547, Val Loss: 15.7965\n",
      "Epoch 11/200, Train Loss: 16.4649, Val Loss: 15.7783\n",
      "Epoch 12/200, Train Loss: 16.4102, Val Loss: 15.7694\n",
      "Epoch 13/200, Train Loss: 16.3839, Val Loss: 15.7516\n",
      "Epoch 14/200, Train Loss: 16.3550, Val Loss: 15.7407\n",
      "Epoch 15/200, Train Loss: 16.3403, Val Loss: 15.7086\n",
      "  New best validation loss: 15.7086\n",
      "Epoch 16/200, Train Loss: 16.3195, Val Loss: 15.6999\n",
      "  New best validation loss: 15.6999\n",
      "Epoch 17/200, Train Loss: 16.2557, Val Loss: 15.6422\n",
      "  New best validation loss: 15.6422\n",
      "Epoch 18/200, Train Loss: 16.2386, Val Loss: 15.6157\n",
      "  New best validation loss: 15.6157\n",
      "Epoch 19/200, Train Loss: 16.1754, Val Loss: 15.5806\n",
      "  New best validation loss: 15.5806\n",
      "Epoch 20/200, Train Loss: 16.1451, Val Loss: 15.5510\n",
      "  New best validation loss: 15.5510\n",
      "Epoch 21/200, Train Loss: 16.0916, Val Loss: 15.5981\n",
      "Epoch 22/200, Train Loss: 16.0713, Val Loss: 15.5348\n",
      "  New best validation loss: 15.5348\n",
      "Epoch 23/200, Train Loss: 16.0915, Val Loss: 15.4681\n",
      "  New best validation loss: 15.4681\n",
      "Epoch 24/200, Train Loss: 16.0369, Val Loss: 15.4242\n",
      "  New best validation loss: 15.4242\n",
      "Epoch 25/200, Train Loss: 15.9641, Val Loss: 15.4742\n",
      "Epoch 26/200, Train Loss: 15.9434, Val Loss: 15.3159\n",
      "  New best validation loss: 15.3159\n",
      "Epoch 27/200, Train Loss: 15.9480, Val Loss: 15.1987\n",
      "  New best validation loss: 15.1987\n",
      "Epoch 28/200, Train Loss: 15.8766, Val Loss: 15.4403\n",
      "Epoch 29/200, Train Loss: 15.7318, Val Loss: 15.0719\n",
      "  New best validation loss: 15.0719\n",
      "Epoch 30/200, Train Loss: 15.6270, Val Loss: 15.1526\n",
      "Epoch 31/200, Train Loss: 15.6103, Val Loss: 14.9609\n",
      "  New best validation loss: 14.9609\n",
      "Epoch 32/200, Train Loss: 15.5117, Val Loss: 15.0735\n",
      "Epoch 33/200, Train Loss: 15.3978, Val Loss: 14.9314\n",
      "  New best validation loss: 14.9314\n",
      "Epoch 34/200, Train Loss: 15.2932, Val Loss: 14.9725\n",
      "Epoch 35/200, Train Loss: 15.2119, Val Loss: 14.9555\n",
      "Epoch 36/200, Train Loss: 15.0499, Val Loss: 15.1321\n",
      "Epoch 37/200, Train Loss: 15.0712, Val Loss: 14.8026\n",
      "  New best validation loss: 14.8026\n",
      "Epoch 38/200, Train Loss: 15.0656, Val Loss: 15.2917\n",
      "Epoch 39/200, Train Loss: 14.9384, Val Loss: 14.9485\n",
      "Epoch 40/200, Train Loss: 14.9516, Val Loss: 14.9217\n",
      "Epoch 41/200, Train Loss: 14.8846, Val Loss: 14.9274\n",
      "Epoch 42/200, Train Loss: 14.6805, Val Loss: 15.2422\n",
      "Epoch 43/200, Train Loss: 14.7278, Val Loss: 14.7683\n",
      "  New best validation loss: 14.7683\n",
      "Epoch 44/200, Train Loss: 14.6240, Val Loss: 14.8892\n",
      "Epoch 45/200, Train Loss: 14.5453, Val Loss: 14.7378\n",
      "  New best validation loss: 14.7378\n",
      "Epoch 46/200, Train Loss: 14.5170, Val Loss: 14.7555\n",
      "Epoch 47/200, Train Loss: 14.3974, Val Loss: 14.6373\n",
      "  New best validation loss: 14.6373\n",
      "Epoch 48/200, Train Loss: 14.2830, Val Loss: 14.8854\n",
      "Epoch 49/200, Train Loss: 14.1584, Val Loss: 14.9556\n",
      "Epoch 50/200, Train Loss: 14.0886, Val Loss: 14.9283\n",
      "Epoch 51/200, Train Loss: 14.0402, Val Loss: 14.7853\n",
      "Epoch 52/200, Train Loss: 13.9964, Val Loss: 14.7149\n",
      "Epoch 53/200, Train Loss: 13.9341, Val Loss: 14.5342\n",
      "  New best validation loss: 14.5342\n",
      "Epoch 54/200, Train Loss: 13.8670, Val Loss: 14.6726\n",
      "Epoch 55/200, Train Loss: 13.8692, Val Loss: 14.7123\n",
      "Epoch 56/200, Train Loss: 13.6927, Val Loss: 14.5953\n",
      "Epoch 57/200, Train Loss: 13.6129, Val Loss: 14.4237\n",
      "  New best validation loss: 14.4237\n",
      "Epoch 58/200, Train Loss: 13.6495, Val Loss: 14.5645\n",
      "Epoch 59/200, Train Loss: 13.5001, Val Loss: 14.4114\n",
      "  New best validation loss: 14.4114\n",
      "Epoch 60/200, Train Loss: 13.4036, Val Loss: 14.6839\n",
      "Epoch 61/200, Train Loss: 13.4616, Val Loss: 14.5250\n",
      "Epoch 62/200, Train Loss: 13.2517, Val Loss: 14.4809\n",
      "Epoch 63/200, Train Loss: 13.1990, Val Loss: 14.5358\n",
      "Epoch 64/200, Train Loss: 13.1267, Val Loss: 14.5539\n",
      "Epoch 65/200, Train Loss: 13.0023, Val Loss: 14.5851\n",
      "Epoch 66/200, Train Loss: 12.9556, Val Loss: 14.7108\n",
      "Epoch 67/200, Train Loss: 12.8941, Val Loss: 14.8006\n",
      "Epoch 68/200, Train Loss: 12.9024, Val Loss: 14.8812\n",
      "Epoch 69/200, Train Loss: 12.7468, Val Loss: 14.5755\n",
      "Epoch 70/200, Train Loss: 12.6817, Val Loss: 14.4831\n",
      "Epoch 71/200, Train Loss: 12.6801, Val Loss: 14.3243\n",
      "  New best validation loss: 14.3243\n",
      "Epoch 72/200, Train Loss: 12.6225, Val Loss: 14.4026\n",
      "Epoch 73/200, Train Loss: 12.5167, Val Loss: 14.2131\n",
      "  New best validation loss: 14.2131\n",
      "Epoch 74/200, Train Loss: 12.5406, Val Loss: 14.5507\n",
      "Epoch 75/200, Train Loss: 12.4469, Val Loss: 14.6440\n",
      "Epoch 76/200, Train Loss: 12.4325, Val Loss: 14.1150\n",
      "  New best validation loss: 14.1150\n",
      "Epoch 77/200, Train Loss: 12.4073, Val Loss: 14.4993\n",
      "Epoch 78/200, Train Loss: 12.3823, Val Loss: 14.3773\n",
      "Epoch 79/200, Train Loss: 12.2082, Val Loss: 14.3901\n",
      "Epoch 80/200, Train Loss: 12.1998, Val Loss: 14.4883\n",
      "Epoch 81/200, Train Loss: 12.0916, Val Loss: 14.9556\n",
      "Epoch 82/200, Train Loss: 12.0648, Val Loss: 14.2446\n",
      "Epoch 83/200, Train Loss: 12.0186, Val Loss: 14.3751\n",
      "Epoch 84/200, Train Loss: 12.0236, Val Loss: 14.4479\n",
      "Epoch 85/200, Train Loss: 11.9092, Val Loss: 14.5585\n",
      "Epoch 86/200, Train Loss: 11.9104, Val Loss: 14.1270\n",
      "Epoch 87/200, Train Loss: 11.7559, Val Loss: 14.4659\n",
      "Epoch 88/200, Train Loss: 11.6893, Val Loss: 14.4130\n",
      "Epoch 89/200, Train Loss: 11.6913, Val Loss: 14.3503\n",
      "Epoch 90/200, Train Loss: 11.6753, Val Loss: 14.7062\n",
      "Epoch 91/200, Train Loss: 11.6198, Val Loss: 14.4784\n",
      "Epoch 92/200, Train Loss: 11.5192, Val Loss: 14.4847\n",
      "Epoch 93/200, Train Loss: 11.5697, Val Loss: 14.3699\n",
      "Epoch 94/200, Train Loss: 11.4742, Val Loss: 14.9054\n",
      "Epoch 95/200, Train Loss: 11.3925, Val Loss: 14.3025\n",
      "Epoch 96/200, Train Loss: 11.3207, Val Loss: 14.5309\n",
      "Epoch 97/200, Train Loss: 11.4510, Val Loss: 14.8222\n",
      "Epoch 98/200, Train Loss: 11.2997, Val Loss: 13.8318\n",
      "  New best validation loss: 13.8318\n",
      "Epoch 99/200, Train Loss: 11.2122, Val Loss: 14.7567\n",
      "Epoch 100/200, Train Loss: 11.1229, Val Loss: 14.2479\n",
      "Epoch 101/200, Train Loss: 11.1326, Val Loss: 14.7056\n",
      "Epoch 102/200, Train Loss: 11.1145, Val Loss: 14.3076\n",
      "Epoch 103/200, Train Loss: 11.0748, Val Loss: 14.3328\n",
      "Epoch 104/200, Train Loss: 10.9566, Val Loss: 14.4006\n",
      "Epoch 105/200, Train Loss: 10.9144, Val Loss: 14.2594\n",
      "Epoch 106/200, Train Loss: 10.8395, Val Loss: 14.3612\n",
      "Epoch 107/200, Train Loss: 10.8258, Val Loss: 14.2830\n",
      "Epoch 108/200, Train Loss: 10.7733, Val Loss: 14.3985\n",
      "Epoch 109/200, Train Loss: 10.7159, Val Loss: 14.3383\n",
      "Epoch 110/200, Train Loss: 10.7201, Val Loss: 14.2561\n",
      "Epoch 111/200, Train Loss: 10.6197, Val Loss: 14.1257\n",
      "Epoch 112/200, Train Loss: 10.7827, Val Loss: 14.8785\n",
      "Epoch 113/200, Train Loss: 10.7160, Val Loss: 14.7434\n",
      "Epoch 114/200, Train Loss: 10.5383, Val Loss: 14.8486\n",
      "Epoch 115/200, Train Loss: 10.5659, Val Loss: 14.2526\n",
      "Epoch 116/200, Train Loss: 10.4385, Val Loss: 14.4378\n",
      "Epoch 117/200, Train Loss: 10.3873, Val Loss: 14.5225\n",
      "Epoch 118/200, Train Loss: 10.2751, Val Loss: 14.2917\n",
      "Epoch 119/200, Train Loss: 10.2068, Val Loss: 14.2118\n",
      "Epoch 120/200, Train Loss: 10.2408, Val Loss: 15.1260\n",
      "Epoch 121/200, Train Loss: 10.2227, Val Loss: 14.4666\n",
      "Epoch 122/200, Train Loss: 10.2017, Val Loss: 14.6526\n",
      "Epoch 123/200, Train Loss: 10.0235, Val Loss: 14.5684\n",
      "Epoch 124/200, Train Loss: 10.0565, Val Loss: 14.8441\n",
      "Epoch 125/200, Train Loss: 9.9740, Val Loss: 15.1858\n",
      "Epoch 126/200, Train Loss: 9.9974, Val Loss: 14.6946\n",
      "Epoch 127/200, Train Loss: 9.8659, Val Loss: 14.6697\n",
      "Epoch 128/200, Train Loss: 9.9696, Val Loss: 14.8551\n",
      "Epoch 129/200, Train Loss: 9.9030, Val Loss: 14.8295\n",
      "Epoch 130/200, Train Loss: 9.9460, Val Loss: 14.6736\n",
      "Epoch 131/200, Train Loss: 9.7906, Val Loss: 14.7120\n",
      "Epoch 132/200, Train Loss: 9.7598, Val Loss: 14.6118\n",
      "Epoch 133/200, Train Loss: 9.7581, Val Loss: 14.6897\n",
      "Epoch 134/200, Train Loss: 9.7563, Val Loss: 14.7103\n",
      "Epoch 135/200, Train Loss: 9.7021, Val Loss: 14.9696\n",
      "Epoch 136/200, Train Loss: 9.5437, Val Loss: 14.6312\n",
      "Epoch 137/200, Train Loss: 9.5515, Val Loss: 14.5059\n",
      "Epoch 138/200, Train Loss: 9.5549, Val Loss: 14.8752\n",
      "Epoch 139/200, Train Loss: 9.4926, Val Loss: 15.1886\n",
      "Epoch 140/200, Train Loss: 9.4193, Val Loss: 14.9063\n",
      "Epoch 141/200, Train Loss: 9.3754, Val Loss: 14.9770\n",
      "Epoch 142/200, Train Loss: 9.3834, Val Loss: 14.8539\n",
      "Epoch 143/200, Train Loss: 9.4504, Val Loss: 14.9508\n",
      "Epoch 144/200, Train Loss: 9.4511, Val Loss: 14.6606\n",
      "Epoch 145/200, Train Loss: 9.2748, Val Loss: 14.7535\n",
      "Epoch 146/200, Train Loss: 9.2482, Val Loss: 14.7371\n",
      "Epoch 147/200, Train Loss: 9.2267, Val Loss: 14.7317\n",
      "Epoch 148/200, Train Loss: 9.1858, Val Loss: 14.7490\n",
      "Epoch 149/200, Train Loss: 9.2492, Val Loss: 15.0605\n",
      "Epoch 150/200, Train Loss: 9.1072, Val Loss: 15.1195\n",
      "Epoch 151/200, Train Loss: 9.0808, Val Loss: 15.1900\n",
      "Epoch 152/200, Train Loss: 9.1064, Val Loss: 15.3585\n",
      "Epoch 153/200, Train Loss: 9.2382, Val Loss: 14.9607\n",
      "Epoch 154/200, Train Loss: 9.1996, Val Loss: 14.9411\n",
      "Epoch 155/200, Train Loss: 9.0399, Val Loss: 15.0733\n",
      "Epoch 156/200, Train Loss: 9.0238, Val Loss: 15.1684\n",
      "Epoch 157/200, Train Loss: 8.8939, Val Loss: 14.9549\n",
      "Epoch 158/200, Train Loss: 8.9012, Val Loss: 14.7814\n",
      "Epoch 159/200, Train Loss: 8.7955, Val Loss: 15.1145\n",
      "Epoch 160/200, Train Loss: 8.8269, Val Loss: 15.5125\n",
      "Epoch 161/200, Train Loss: 8.8100, Val Loss: 14.6071\n",
      "Epoch 162/200, Train Loss: 8.8044, Val Loss: 15.1084\n",
      "Epoch 163/200, Train Loss: 8.8425, Val Loss: 14.7384\n",
      "Epoch 164/200, Train Loss: 8.7129, Val Loss: 15.1961\n",
      "Epoch 165/200, Train Loss: 8.7186, Val Loss: 15.0250\n",
      "Epoch 166/200, Train Loss: 8.7486, Val Loss: 14.8740\n",
      "Epoch 167/200, Train Loss: 8.6112, Val Loss: 15.1201\n",
      "Epoch 168/200, Train Loss: 8.6394, Val Loss: 14.9241\n",
      "Epoch 169/200, Train Loss: 8.6728, Val Loss: 14.9370\n",
      "Epoch 170/200, Train Loss: 8.6744, Val Loss: 14.9338\n",
      "Epoch 171/200, Train Loss: 8.5579, Val Loss: 14.9160\n",
      "Epoch 172/200, Train Loss: 8.5232, Val Loss: 15.3532\n",
      "Epoch 173/200, Train Loss: 8.4963, Val Loss: 15.3008\n",
      "Epoch 174/200, Train Loss: 8.3563, Val Loss: 14.9679\n",
      "Epoch 175/200, Train Loss: 8.4591, Val Loss: 15.2551\n",
      "Epoch 176/200, Train Loss: 8.4251, Val Loss: 15.2457\n",
      "Epoch 177/200, Train Loss: 8.3214, Val Loss: 15.1101\n",
      "Epoch 178/200, Train Loss: 8.3224, Val Loss: 14.9062\n",
      "Epoch 179/200, Train Loss: 8.3964, Val Loss: 15.4751\n",
      "Epoch 180/200, Train Loss: 8.2861, Val Loss: 15.1856\n",
      "Epoch 181/200, Train Loss: 8.2869, Val Loss: 14.8984\n",
      "Epoch 182/200, Train Loss: 8.1963, Val Loss: 15.2037\n",
      "Epoch 183/200, Train Loss: 8.1832, Val Loss: 15.0351\n",
      "Epoch 184/200, Train Loss: 8.1634, Val Loss: 15.0346\n",
      "Epoch 185/200, Train Loss: 8.1503, Val Loss: 15.6107\n",
      "Epoch 186/200, Train Loss: 8.0631, Val Loss: 15.1749\n",
      "Epoch 187/200, Train Loss: 8.0559, Val Loss: 15.2022\n",
      "Epoch 188/200, Train Loss: 8.0985, Val Loss: 15.6322\n",
      "Epoch 189/200, Train Loss: 8.2033, Val Loss: 15.1072\n",
      "Epoch 190/200, Train Loss: 8.0340, Val Loss: 14.9419\n",
      "Epoch 191/200, Train Loss: 8.0918, Val Loss: 15.1922\n",
      "Epoch 192/200, Train Loss: 7.9629, Val Loss: 15.5183\n",
      "Epoch 193/200, Train Loss: 7.9593, Val Loss: 15.5044\n",
      "Epoch 194/200, Train Loss: 7.9414, Val Loss: 15.2427\n",
      "Epoch 195/200, Train Loss: 7.7637, Val Loss: 15.3341\n",
      "Epoch 196/200, Train Loss: 7.7693, Val Loss: 15.2525\n",
      "Epoch 197/200, Train Loss: 7.8506, Val Loss: 15.1386\n",
      "Epoch 198/200, Train Loss: 7.8220, Val Loss: 15.2464\n",
      "Epoch 199/200, Train Loss: 7.7713, Val Loss: 15.8599\n",
      "Epoch 200/200, Train Loss: 7.7581, Val Loss: 15.7469\n",
      "\n",
      "Loaded best model (Val Loss: 13.8318) for final hidden state extraction.\n",
      "Saved best model for NMRNN_Spatial_ModReadout (samples=640) to results_data_size_sweep/20250514_045146/samples_640/NMRNN_Spatial_ModReadout_samples_640_best.pt\n",
      "\n",
      "--- Performing Decodability Analysis for NMRNN_Spatial_ModReadout (samples=640, k=15) ---\n",
      "  Analyzing decodability for NMRNN_Spatial_ModReadout...\n",
      "  Hidden states shape: torch.Size([160, 200, 128])\n",
      "  Coefficients shape: torch.Size([160, 15])\n",
      "  Processed hidden states shape for decoder: torch.Size([160, 128])\n",
      "  RidgeCV Decoder for NMRNN_Spatial_ModReadout - Test MSE: 1.6064, Test R2: 0.1970 (best alpha: 100.0000)\n",
      "  Decodability plot saved to results_data_size_sweep/20250514_045146/samples_640/decodability_NMRNN_Spatial_ModReadout_coeff1.png\n",
      "Decodability (R2 score) for NMRNN_Spatial_ModReadout (samples=640): 0.1970\n",
      "\n",
      "--- Training NMRNN_NoSpatial_ModReadout (samples=640, k=15) ---\n",
      "Number of parameters: 66832\n",
      "Epoch 1/200, Train Loss: 16.8492, Val Loss: 15.7507\n",
      "  New best validation loss: 15.7507\n",
      "Epoch 2/200, Train Loss: 16.7220, Val Loss: 15.7322\n",
      "  New best validation loss: 15.7322\n",
      "Epoch 3/200, Train Loss: 16.6567, Val Loss: 15.8489\n",
      "Epoch 4/200, Train Loss: 16.6204, Val Loss: 15.7830\n",
      "Epoch 5/200, Train Loss: 16.5970, Val Loss: 15.7875\n",
      "Epoch 6/200, Train Loss: 16.5599, Val Loss: 15.7730\n",
      "Epoch 7/200, Train Loss: 16.5646, Val Loss: 15.8506\n",
      "Epoch 8/200, Train Loss: 16.5017, Val Loss: 15.7610\n",
      "Epoch 9/200, Train Loss: 16.4896, Val Loss: 15.8081\n",
      "Epoch 10/200, Train Loss: 16.4139, Val Loss: 15.7316\n",
      "  New best validation loss: 15.7316\n",
      "Epoch 11/200, Train Loss: 16.3698, Val Loss: 15.7338\n",
      "Epoch 12/200, Train Loss: 16.3982, Val Loss: 15.6924\n",
      "  New best validation loss: 15.6924\n",
      "Epoch 13/200, Train Loss: 16.3371, Val Loss: 15.6917\n",
      "  New best validation loss: 15.6917\n",
      "Epoch 14/200, Train Loss: 16.2960, Val Loss: 15.7354\n",
      "Epoch 15/200, Train Loss: 16.2615, Val Loss: 15.6429\n",
      "  New best validation loss: 15.6429\n",
      "Epoch 16/200, Train Loss: 16.2645, Val Loss: 15.6606\n",
      "Epoch 17/200, Train Loss: 16.2118, Val Loss: 15.6062\n",
      "  New best validation loss: 15.6062\n",
      "Epoch 18/200, Train Loss: 16.1286, Val Loss: 15.5911\n",
      "  New best validation loss: 15.5911\n",
      "Epoch 19/200, Train Loss: 16.1363, Val Loss: 15.6055\n",
      "Epoch 20/200, Train Loss: 16.0808, Val Loss: 15.5215\n",
      "  New best validation loss: 15.5215\n",
      "Epoch 21/200, Train Loss: 15.9645, Val Loss: 15.3940\n",
      "  New best validation loss: 15.3940\n",
      "Epoch 22/200, Train Loss: 16.0062, Val Loss: 15.5006\n",
      "Epoch 23/200, Train Loss: 15.9492, Val Loss: 15.4597\n",
      "Epoch 24/200, Train Loss: 15.9428, Val Loss: 15.4355\n",
      "Epoch 25/200, Train Loss: 15.7869, Val Loss: 15.2166\n",
      "  New best validation loss: 15.2166\n",
      "Epoch 26/200, Train Loss: 15.7519, Val Loss: 15.2396\n",
      "Epoch 27/200, Train Loss: 15.6778, Val Loss: 15.2539\n",
      "Epoch 28/200, Train Loss: 15.8168, Val Loss: 15.0862\n",
      "  New best validation loss: 15.0862\n",
      "Epoch 29/200, Train Loss: 15.6901, Val Loss: 15.1098\n",
      "Epoch 30/200, Train Loss: 15.6334, Val Loss: 15.2278\n",
      "Epoch 31/200, Train Loss: 15.5110, Val Loss: 14.9580\n",
      "  New best validation loss: 14.9580\n",
      "Epoch 32/200, Train Loss: 15.4488, Val Loss: 15.1403\n",
      "Epoch 33/200, Train Loss: 15.4265, Val Loss: 15.0244\n",
      "Epoch 34/200, Train Loss: 15.3332, Val Loss: 15.1096\n",
      "Epoch 35/200, Train Loss: 15.1940, Val Loss: 14.9731\n",
      "Epoch 36/200, Train Loss: 15.1505, Val Loss: 14.6516\n",
      "  New best validation loss: 14.6516\n",
      "Epoch 37/200, Train Loss: 15.1347, Val Loss: 14.9212\n",
      "Epoch 38/200, Train Loss: 15.0142, Val Loss: 14.8465\n",
      "Epoch 39/200, Train Loss: 14.8199, Val Loss: 14.6112\n",
      "  New best validation loss: 14.6112\n",
      "Epoch 40/200, Train Loss: 14.8324, Val Loss: 14.6465\n",
      "Epoch 41/200, Train Loss: 14.8809, Val Loss: 14.5578\n",
      "  New best validation loss: 14.5578\n",
      "Epoch 42/200, Train Loss: 14.8177, Val Loss: 14.7307\n",
      "Epoch 43/200, Train Loss: 14.7426, Val Loss: 14.5803\n",
      "Epoch 44/200, Train Loss: 14.5795, Val Loss: 14.4892\n",
      "  New best validation loss: 14.4892\n",
      "Epoch 45/200, Train Loss: 14.5318, Val Loss: 14.5327\n",
      "Epoch 46/200, Train Loss: 14.4000, Val Loss: 14.5808\n",
      "Epoch 47/200, Train Loss: 14.2752, Val Loss: 14.7916\n",
      "Epoch 48/200, Train Loss: 14.1880, Val Loss: 14.5213\n",
      "Epoch 49/200, Train Loss: 14.1475, Val Loss: 14.6531\n",
      "Epoch 50/200, Train Loss: 14.0006, Val Loss: 14.5641\n",
      "Epoch 51/200, Train Loss: 13.8941, Val Loss: 14.6478\n",
      "Epoch 52/200, Train Loss: 13.8592, Val Loss: 14.4813\n",
      "  New best validation loss: 14.4813\n",
      "Epoch 53/200, Train Loss: 13.7855, Val Loss: 14.7094\n",
      "Epoch 54/200, Train Loss: 13.8467, Val Loss: 14.3366\n",
      "  New best validation loss: 14.3366\n",
      "Epoch 55/200, Train Loss: 13.7097, Val Loss: 14.3864\n",
      "Epoch 56/200, Train Loss: 13.5807, Val Loss: 14.2446\n",
      "  New best validation loss: 14.2446\n",
      "Epoch 57/200, Train Loss: 13.5819, Val Loss: 14.4314\n",
      "Epoch 58/200, Train Loss: 13.4740, Val Loss: 14.5416\n",
      "Epoch 59/200, Train Loss: 13.3993, Val Loss: 14.5074\n",
      "Epoch 60/200, Train Loss: 13.2671, Val Loss: 14.7584\n",
      "Epoch 61/200, Train Loss: 13.2045, Val Loss: 14.7740\n",
      "Epoch 62/200, Train Loss: 13.2036, Val Loss: 14.3248\n",
      "Epoch 63/200, Train Loss: 13.1158, Val Loss: 14.4416\n",
      "Epoch 64/200, Train Loss: 13.1855, Val Loss: 14.2907\n",
      "Epoch 65/200, Train Loss: 13.0500, Val Loss: 14.6480\n",
      "Epoch 66/200, Train Loss: 12.8650, Val Loss: 14.5127\n",
      "Epoch 67/200, Train Loss: 13.0862, Val Loss: 14.5820\n",
      "Epoch 68/200, Train Loss: 12.7502, Val Loss: 14.4595\n",
      "Epoch 69/200, Train Loss: 12.7911, Val Loss: 14.5494\n",
      "Epoch 70/200, Train Loss: 12.7482, Val Loss: 14.5374\n",
      "Epoch 71/200, Train Loss: 12.6233, Val Loss: 14.6519\n",
      "Epoch 72/200, Train Loss: 12.4524, Val Loss: 14.1349\n",
      "  New best validation loss: 14.1349\n",
      "Epoch 73/200, Train Loss: 12.4884, Val Loss: 14.2823\n",
      "Epoch 74/200, Train Loss: 12.5318, Val Loss: 14.6080\n",
      "Epoch 75/200, Train Loss: 12.3867, Val Loss: 14.9526\n",
      "Epoch 76/200, Train Loss: 12.3696, Val Loss: 14.7705\n",
      "Epoch 77/200, Train Loss: 12.3194, Val Loss: 14.6401\n",
      "Epoch 78/200, Train Loss: 12.1666, Val Loss: 14.5942\n",
      "Epoch 79/200, Train Loss: 12.0713, Val Loss: 14.3667\n",
      "Epoch 80/200, Train Loss: 11.9643, Val Loss: 14.3152\n",
      "Epoch 81/200, Train Loss: 12.0088, Val Loss: 14.5392\n",
      "Epoch 82/200, Train Loss: 11.8526, Val Loss: 14.3649\n",
      "Epoch 83/200, Train Loss: 11.9384, Val Loss: 14.2647\n",
      "Epoch 84/200, Train Loss: 11.9333, Val Loss: 14.4082\n",
      "Epoch 85/200, Train Loss: 11.7252, Val Loss: 14.7363\n",
      "Epoch 86/200, Train Loss: 11.5881, Val Loss: 14.2795\n",
      "Epoch 87/200, Train Loss: 11.4809, Val Loss: 14.7136\n",
      "Epoch 88/200, Train Loss: 11.4961, Val Loss: 14.5031\n",
      "Epoch 89/200, Train Loss: 11.4508, Val Loss: 14.4679\n",
      "Epoch 90/200, Train Loss: 11.3243, Val Loss: 14.5362\n",
      "Epoch 91/200, Train Loss: 11.4019, Val Loss: 13.9726\n",
      "  New best validation loss: 13.9726\n",
      "Epoch 92/200, Train Loss: 11.3228, Val Loss: 14.4736\n",
      "Epoch 93/200, Train Loss: 11.2456, Val Loss: 14.4294\n",
      "Epoch 94/200, Train Loss: 11.3071, Val Loss: 14.2643\n",
      "Epoch 95/200, Train Loss: 11.1914, Val Loss: 14.4951\n",
      "Epoch 96/200, Train Loss: 11.1711, Val Loss: 15.0360\n",
      "Epoch 97/200, Train Loss: 10.9800, Val Loss: 14.5257\n",
      "Epoch 98/200, Train Loss: 10.9801, Val Loss: 14.5761\n",
      "Epoch 99/200, Train Loss: 10.9270, Val Loss: 14.7717\n",
      "Epoch 100/200, Train Loss: 11.0076, Val Loss: 14.8886\n",
      "Epoch 101/200, Train Loss: 10.8799, Val Loss: 14.4543\n",
      "Epoch 102/200, Train Loss: 10.6959, Val Loss: 14.4718\n",
      "Epoch 103/200, Train Loss: 10.7673, Val Loss: 14.1917\n",
      "Epoch 104/200, Train Loss: 10.7182, Val Loss: 14.4304\n",
      "Epoch 105/200, Train Loss: 10.6384, Val Loss: 14.4787\n",
      "Epoch 106/200, Train Loss: 10.8876, Val Loss: 14.1966\n",
      "Epoch 107/200, Train Loss: 10.5366, Val Loss: 14.3603\n",
      "Epoch 108/200, Train Loss: 10.5884, Val Loss: 14.6819\n",
      "Epoch 109/200, Train Loss: 10.6658, Val Loss: 14.1803\n",
      "Epoch 110/200, Train Loss: 10.3244, Val Loss: 14.5965\n",
      "Epoch 111/200, Train Loss: 10.4406, Val Loss: 14.6672\n",
      "Epoch 112/200, Train Loss: 10.2192, Val Loss: 14.3801\n",
      "Epoch 113/200, Train Loss: 10.4402, Val Loss: 14.4372\n",
      "Epoch 114/200, Train Loss: 10.2376, Val Loss: 14.6044\n",
      "Epoch 115/200, Train Loss: 10.1917, Val Loss: 14.4745\n",
      "Epoch 116/200, Train Loss: 10.0640, Val Loss: 14.3262\n",
      "Epoch 117/200, Train Loss: 9.9626, Val Loss: 14.1029\n",
      "Epoch 118/200, Train Loss: 10.0693, Val Loss: 14.2832\n",
      "Epoch 119/200, Train Loss: 10.0260, Val Loss: 14.7311\n",
      "Epoch 120/200, Train Loss: 9.8940, Val Loss: 14.3207\n",
      "Epoch 121/200, Train Loss: 9.8836, Val Loss: 14.5821\n",
      "Epoch 122/200, Train Loss: 9.7672, Val Loss: 14.3641\n",
      "Epoch 123/200, Train Loss: 9.6672, Val Loss: 14.7854\n",
      "Epoch 124/200, Train Loss: 9.7885, Val Loss: 14.8819\n",
      "Epoch 125/200, Train Loss: 9.7331, Val Loss: 14.4394\n",
      "Epoch 126/200, Train Loss: 9.4904, Val Loss: 14.2084\n",
      "Epoch 127/200, Train Loss: 9.4979, Val Loss: 14.2161\n",
      "Epoch 128/200, Train Loss: 9.4447, Val Loss: 14.7232\n",
      "Epoch 129/200, Train Loss: 9.5426, Val Loss: 14.6527\n",
      "Epoch 130/200, Train Loss: 9.5594, Val Loss: 14.5773\n",
      "Epoch 131/200, Train Loss: 9.3606, Val Loss: 14.2862\n",
      "Epoch 132/200, Train Loss: 9.3599, Val Loss: 15.1158\n",
      "Epoch 133/200, Train Loss: 9.4648, Val Loss: 15.1323\n",
      "Epoch 134/200, Train Loss: 9.4525, Val Loss: 14.4483\n",
      "Epoch 135/200, Train Loss: 9.2642, Val Loss: 14.5751\n",
      "Epoch 136/200, Train Loss: 9.1439, Val Loss: 14.4403\n",
      "Epoch 137/200, Train Loss: 9.2158, Val Loss: 14.6201\n",
      "Epoch 138/200, Train Loss: 9.0991, Val Loss: 14.5000\n",
      "Epoch 139/200, Train Loss: 9.1280, Val Loss: 14.5471\n",
      "Epoch 140/200, Train Loss: 9.0941, Val Loss: 14.3872\n",
      "Epoch 141/200, Train Loss: 9.1784, Val Loss: 14.6978\n",
      "Epoch 142/200, Train Loss: 8.9652, Val Loss: 14.4087\n",
      "Epoch 143/200, Train Loss: 8.9546, Val Loss: 15.1148\n",
      "Epoch 144/200, Train Loss: 8.9862, Val Loss: 14.7192\n",
      "Epoch 145/200, Train Loss: 8.7777, Val Loss: 14.8529\n",
      "Epoch 146/200, Train Loss: 8.7585, Val Loss: 15.0736\n",
      "Epoch 147/200, Train Loss: 8.7836, Val Loss: 14.8727\n",
      "Epoch 148/200, Train Loss: 8.7779, Val Loss: 14.8018\n",
      "Epoch 149/200, Train Loss: 8.7108, Val Loss: 14.6571\n",
      "Epoch 150/200, Train Loss: 8.6263, Val Loss: 14.7263\n",
      "Epoch 151/200, Train Loss: 8.5607, Val Loss: 14.7764\n",
      "Epoch 152/200, Train Loss: 8.5829, Val Loss: 14.8513\n",
      "Epoch 153/200, Train Loss: 8.5278, Val Loss: 14.9049\n",
      "Epoch 154/200, Train Loss: 8.5038, Val Loss: 14.9375\n",
      "Epoch 155/200, Train Loss: 8.5470, Val Loss: 14.2853\n",
      "Epoch 156/200, Train Loss: 8.5057, Val Loss: 15.0014\n",
      "Epoch 157/200, Train Loss: 8.4318, Val Loss: 14.6827\n",
      "Epoch 158/200, Train Loss: 8.4338, Val Loss: 14.8276\n",
      "Epoch 159/200, Train Loss: 8.4573, Val Loss: 15.0494\n",
      "Epoch 160/200, Train Loss: 8.4511, Val Loss: 14.8184\n",
      "Epoch 161/200, Train Loss: 8.4752, Val Loss: 14.7045\n",
      "Epoch 162/200, Train Loss: 8.4288, Val Loss: 14.7936\n",
      "Epoch 163/200, Train Loss: 8.2394, Val Loss: 14.6209\n",
      "Epoch 164/200, Train Loss: 8.1761, Val Loss: 14.7148\n",
      "Epoch 165/200, Train Loss: 8.1871, Val Loss: 14.7050\n",
      "Epoch 166/200, Train Loss: 8.2371, Val Loss: 15.0330\n",
      "Epoch 167/200, Train Loss: 8.1759, Val Loss: 14.7880\n",
      "Epoch 168/200, Train Loss: 8.0956, Val Loss: 14.7092\n",
      "Epoch 169/200, Train Loss: 8.0170, Val Loss: 15.0618\n",
      "Epoch 170/200, Train Loss: 8.0836, Val Loss: 15.5815\n",
      "Epoch 171/200, Train Loss: 8.0585, Val Loss: 15.0564\n",
      "Epoch 172/200, Train Loss: 8.0787, Val Loss: 14.8580\n",
      "Epoch 173/200, Train Loss: 7.9971, Val Loss: 15.1211\n",
      "Epoch 174/200, Train Loss: 7.9413, Val Loss: 15.1435\n",
      "Epoch 175/200, Train Loss: 7.9469, Val Loss: 14.9258\n",
      "Epoch 176/200, Train Loss: 7.8900, Val Loss: 15.3745\n",
      "Epoch 177/200, Train Loss: 7.8339, Val Loss: 14.7023\n",
      "Epoch 178/200, Train Loss: 7.8510, Val Loss: 14.7429\n",
      "Epoch 179/200, Train Loss: 7.8200, Val Loss: 15.1810\n",
      "Epoch 180/200, Train Loss: 7.7895, Val Loss: 15.5203\n",
      "Epoch 181/200, Train Loss: 7.7206, Val Loss: 15.0614\n",
      "Epoch 182/200, Train Loss: 7.7023, Val Loss: 15.4295\n",
      "Epoch 183/200, Train Loss: 7.6286, Val Loss: 15.1356\n",
      "Epoch 184/200, Train Loss: 7.6601, Val Loss: 15.3487\n",
      "Epoch 185/200, Train Loss: 7.5793, Val Loss: 14.9739\n",
      "Epoch 186/200, Train Loss: 7.4851, Val Loss: 15.5177\n",
      "Epoch 187/200, Train Loss: 7.6024, Val Loss: 15.2335\n",
      "Epoch 188/200, Train Loss: 7.5139, Val Loss: 15.3197\n",
      "Epoch 189/200, Train Loss: 7.5154, Val Loss: 15.3963\n",
      "Epoch 190/200, Train Loss: 7.4372, Val Loss: 15.8509\n",
      "Epoch 191/200, Train Loss: 7.3988, Val Loss: 15.5894\n",
      "Epoch 192/200, Train Loss: 7.4692, Val Loss: 15.1017\n",
      "Epoch 193/200, Train Loss: 7.3976, Val Loss: 15.8410\n",
      "Epoch 194/200, Train Loss: 7.6079, Val Loss: 15.2962\n",
      "Epoch 195/200, Train Loss: 7.5157, Val Loss: 15.2305\n",
      "Epoch 196/200, Train Loss: 7.3824, Val Loss: 15.1289\n",
      "Epoch 197/200, Train Loss: 7.3270, Val Loss: 15.3632\n",
      "Epoch 198/200, Train Loss: 7.3397, Val Loss: 15.3212\n",
      "Epoch 199/200, Train Loss: 7.4210, Val Loss: 15.5626\n",
      "Epoch 200/200, Train Loss: 7.5415, Val Loss: 15.7567\n",
      "\n",
      "Loaded best model (Val Loss: 13.9726) for final hidden state extraction.\n",
      "Saved best model for NMRNN_NoSpatial_ModReadout (samples=640) to results_data_size_sweep/20250514_045146/samples_640/NMRNN_NoSpatial_ModReadout_samples_640_best.pt\n",
      "\n",
      "--- Performing Decodability Analysis for NMRNN_NoSpatial_ModReadout (samples=640, k=15) ---\n",
      "  Analyzing decodability for NMRNN_NoSpatial_ModReadout...\n",
      "  Hidden states shape: torch.Size([160, 200, 128])\n",
      "  Coefficients shape: torch.Size([160, 15])\n",
      "  Processed hidden states shape for decoder: torch.Size([160, 128])\n",
      "  RidgeCV Decoder for NMRNN_NoSpatial_ModReadout - Test MSE: 1.6114, Test R2: 0.1872 (best alpha: 100.0000)\n",
      "  Decodability plot saved to results_data_size_sweep/20250514_045146/samples_640/decodability_NMRNN_NoSpatial_ModReadout_coeff1.png\n",
      "Decodability (R2 score) for NMRNN_NoSpatial_ModReadout (samples=640): 0.1872\n",
      "\n",
      "--- Training NMRNN_Spatial_FixedReadout (samples=640, k=15) ---\n",
      "Number of parameters: 66449\n",
      "Epoch 1/200, Train Loss: 16.9361, Val Loss: 15.7391\n",
      "  New best validation loss: 15.7391\n",
      "Epoch 2/200, Train Loss: 16.7520, Val Loss: 15.7921\n",
      "Epoch 3/200, Train Loss: 16.6883, Val Loss: 15.8333\n",
      "Epoch 4/200, Train Loss: 16.6514, Val Loss: 15.8488\n",
      "Epoch 5/200, Train Loss: 16.6115, Val Loss: 15.8514\n",
      "Epoch 6/200, Train Loss: 16.6041, Val Loss: 15.8569\n",
      "Epoch 7/200, Train Loss: 16.5802, Val Loss: 15.8414\n",
      "Epoch 8/200, Train Loss: 16.5289, Val Loss: 15.8552\n",
      "Epoch 9/200, Train Loss: 16.5162, Val Loss: 15.8251\n",
      "Epoch 10/200, Train Loss: 16.4701, Val Loss: 15.8337\n",
      "Epoch 11/200, Train Loss: 16.4470, Val Loss: 15.8312\n",
      "Epoch 12/200, Train Loss: 16.4239, Val Loss: 15.8122\n",
      "Epoch 13/200, Train Loss: 16.3615, Val Loss: 15.8311\n",
      "Epoch 14/200, Train Loss: 16.3229, Val Loss: 15.8025\n",
      "Epoch 15/200, Train Loss: 16.2754, Val Loss: 15.7580\n",
      "Epoch 16/200, Train Loss: 16.2316, Val Loss: 15.7542\n",
      "Epoch 17/200, Train Loss: 16.1368, Val Loss: 15.7243\n",
      "  New best validation loss: 15.7243\n",
      "Epoch 18/200, Train Loss: 16.0755, Val Loss: 15.7769\n",
      "Epoch 19/200, Train Loss: 15.9883, Val Loss: 15.5313\n",
      "  New best validation loss: 15.5313\n",
      "Epoch 20/200, Train Loss: 15.9061, Val Loss: 15.6025\n",
      "Epoch 21/200, Train Loss: 15.7916, Val Loss: 15.5788\n",
      "Epoch 22/200, Train Loss: 15.7163, Val Loss: 15.6013\n",
      "Epoch 23/200, Train Loss: 15.5920, Val Loss: 15.3318\n",
      "  New best validation loss: 15.3318\n",
      "Epoch 24/200, Train Loss: 15.5224, Val Loss: 15.3691\n",
      "Epoch 25/200, Train Loss: 15.3170, Val Loss: 15.3532\n",
      "Epoch 26/200, Train Loss: 15.1961, Val Loss: 15.3999\n",
      "Epoch 27/200, Train Loss: 15.0952, Val Loss: 15.1506\n",
      "  New best validation loss: 15.1506\n",
      "Epoch 28/200, Train Loss: 14.9566, Val Loss: 15.1419\n",
      "  New best validation loss: 15.1419\n",
      "Epoch 29/200, Train Loss: 14.8191, Val Loss: 15.0714\n",
      "  New best validation loss: 15.0714\n",
      "Epoch 30/200, Train Loss: 14.6474, Val Loss: 14.9252\n",
      "  New best validation loss: 14.9252\n",
      "Epoch 31/200, Train Loss: 14.4398, Val Loss: 14.9091\n",
      "  New best validation loss: 14.9091\n",
      "Epoch 32/200, Train Loss: 14.3041, Val Loss: 14.6202\n",
      "  New best validation loss: 14.6202\n",
      "Epoch 33/200, Train Loss: 14.1336, Val Loss: 14.9785\n",
      "Epoch 34/200, Train Loss: 14.1283, Val Loss: 14.5860\n",
      "  New best validation loss: 14.5860\n",
      "Epoch 35/200, Train Loss: 14.0150, Val Loss: 14.8221\n",
      "Epoch 36/200, Train Loss: 13.9318, Val Loss: 14.9118\n",
      "Epoch 37/200, Train Loss: 13.7616, Val Loss: 14.9185\n",
      "Epoch 38/200, Train Loss: 13.6341, Val Loss: 14.5637\n",
      "  New best validation loss: 14.5637\n",
      "Epoch 39/200, Train Loss: 13.4600, Val Loss: 14.5979\n",
      "Epoch 40/200, Train Loss: 13.5461, Val Loss: 14.5569\n",
      "  New best validation loss: 14.5569\n",
      "Epoch 41/200, Train Loss: 13.4164, Val Loss: 14.4274\n",
      "  New best validation loss: 14.4274\n",
      "Epoch 42/200, Train Loss: 13.2349, Val Loss: 14.5410\n",
      "Epoch 43/200, Train Loss: 13.1122, Val Loss: 14.7652\n",
      "Epoch 44/200, Train Loss: 13.0735, Val Loss: 14.8656\n",
      "Epoch 45/200, Train Loss: 13.0324, Val Loss: 14.8271\n",
      "Epoch 46/200, Train Loss: 12.9318, Val Loss: 14.4129\n",
      "  New best validation loss: 14.4129\n",
      "Epoch 47/200, Train Loss: 12.6710, Val Loss: 14.5764\n",
      "Epoch 48/200, Train Loss: 12.6259, Val Loss: 14.3178\n",
      "  New best validation loss: 14.3178\n",
      "Epoch 49/200, Train Loss: 12.6159, Val Loss: 14.7307\n",
      "Epoch 50/200, Train Loss: 12.3878, Val Loss: 14.6045\n",
      "Epoch 51/200, Train Loss: 12.3309, Val Loss: 14.5190\n",
      "Epoch 52/200, Train Loss: 12.2647, Val Loss: 14.5477\n",
      "Epoch 53/200, Train Loss: 12.2706, Val Loss: 14.6488\n",
      "Epoch 54/200, Train Loss: 12.1355, Val Loss: 14.5349\n",
      "Epoch 55/200, Train Loss: 12.0780, Val Loss: 14.8664\n",
      "Epoch 56/200, Train Loss: 11.9961, Val Loss: 14.5088\n",
      "Epoch 57/200, Train Loss: 11.8452, Val Loss: 14.4330\n",
      "Epoch 58/200, Train Loss: 11.7821, Val Loss: 14.5264\n",
      "Epoch 59/200, Train Loss: 11.7886, Val Loss: 14.5706\n",
      "Epoch 60/200, Train Loss: 11.6809, Val Loss: 14.4131\n",
      "Epoch 61/200, Train Loss: 11.7555, Val Loss: 14.3303\n",
      "Epoch 62/200, Train Loss: 11.6875, Val Loss: 15.0779\n",
      "Epoch 63/200, Train Loss: 11.5158, Val Loss: 14.4755\n",
      "Epoch 64/200, Train Loss: 11.3900, Val Loss: 14.3241\n",
      "Epoch 65/200, Train Loss: 11.3075, Val Loss: 14.7224\n",
      "Epoch 66/200, Train Loss: 11.3134, Val Loss: 14.6415\n",
      "Epoch 67/200, Train Loss: 11.2303, Val Loss: 14.7410\n",
      "Epoch 68/200, Train Loss: 11.1170, Val Loss: 14.6192\n",
      "Epoch 69/200, Train Loss: 11.3073, Val Loss: 14.8382\n",
      "Epoch 70/200, Train Loss: 11.1013, Val Loss: 14.6115\n",
      "Epoch 71/200, Train Loss: 10.9960, Val Loss: 14.6289\n",
      "Epoch 72/200, Train Loss: 11.1176, Val Loss: 14.8824\n",
      "Epoch 73/200, Train Loss: 11.0018, Val Loss: 14.7636\n",
      "Epoch 74/200, Train Loss: 11.0196, Val Loss: 14.5823\n",
      "Epoch 75/200, Train Loss: 11.0389, Val Loss: 14.6813\n",
      "Epoch 76/200, Train Loss: 10.9234, Val Loss: 14.7852\n",
      "Epoch 77/200, Train Loss: 10.7367, Val Loss: 14.8729\n",
      "Epoch 78/200, Train Loss: 10.7967, Val Loss: 14.6003\n",
      "Epoch 79/200, Train Loss: 10.7837, Val Loss: 14.7624\n",
      "Epoch 80/200, Train Loss: 10.5697, Val Loss: 14.6364\n",
      "Epoch 81/200, Train Loss: 10.5741, Val Loss: 14.7493\n",
      "Epoch 82/200, Train Loss: 10.5101, Val Loss: 14.7721\n",
      "Epoch 83/200, Train Loss: 10.6015, Val Loss: 14.7480\n",
      "Epoch 84/200, Train Loss: 10.4418, Val Loss: 14.5192\n",
      "Epoch 85/200, Train Loss: 10.3105, Val Loss: 14.7884\n",
      "Epoch 86/200, Train Loss: 10.3420, Val Loss: 14.6199\n",
      "Epoch 87/200, Train Loss: 10.3510, Val Loss: 14.7253\n",
      "Epoch 88/200, Train Loss: 10.2349, Val Loss: 14.9515\n",
      "Epoch 89/200, Train Loss: 10.1402, Val Loss: 14.6929\n",
      "Epoch 90/200, Train Loss: 10.0629, Val Loss: 15.2441\n",
      "Epoch 91/200, Train Loss: 9.9840, Val Loss: 15.0071\n",
      "Epoch 92/200, Train Loss: 10.0678, Val Loss: 14.8515\n",
      "Epoch 93/200, Train Loss: 9.9989, Val Loss: 15.2307\n",
      "Epoch 94/200, Train Loss: 10.0145, Val Loss: 15.1732\n",
      "Epoch 95/200, Train Loss: 10.0458, Val Loss: 15.0642\n",
      "Epoch 96/200, Train Loss: 10.0546, Val Loss: 15.0001\n",
      "Epoch 97/200, Train Loss: 9.9364, Val Loss: 14.9535\n",
      "Epoch 98/200, Train Loss: 9.9048, Val Loss: 15.0744\n",
      "Epoch 99/200, Train Loss: 9.9538, Val Loss: 14.8420\n",
      "Epoch 100/200, Train Loss: 9.8806, Val Loss: 15.4820\n",
      "Epoch 101/200, Train Loss: 9.8937, Val Loss: 14.9458\n",
      "Epoch 102/200, Train Loss: 9.7180, Val Loss: 14.8438\n",
      "Epoch 103/200, Train Loss: 9.5704, Val Loss: 15.3186\n",
      "Epoch 104/200, Train Loss: 9.5678, Val Loss: 15.2134\n",
      "Epoch 105/200, Train Loss: 9.4919, Val Loss: 15.2120\n",
      "Epoch 106/200, Train Loss: 9.4275, Val Loss: 15.1444\n",
      "Epoch 107/200, Train Loss: 9.4948, Val Loss: 15.1121\n",
      "Epoch 108/200, Train Loss: 9.4825, Val Loss: 15.0183\n",
      "Epoch 109/200, Train Loss: 9.4540, Val Loss: 15.1994\n",
      "Epoch 110/200, Train Loss: 9.4347, Val Loss: 14.9089\n",
      "Epoch 111/200, Train Loss: 9.4478, Val Loss: 15.2362\n",
      "Epoch 112/200, Train Loss: 9.3724, Val Loss: 15.2188\n",
      "Epoch 113/200, Train Loss: 9.3645, Val Loss: 15.2044\n",
      "Epoch 114/200, Train Loss: 9.3600, Val Loss: 15.5684\n",
      "Epoch 115/200, Train Loss: 9.2394, Val Loss: 15.5788\n",
      "Epoch 116/200, Train Loss: 9.1981, Val Loss: 15.7260\n",
      "Epoch 117/200, Train Loss: 9.2680, Val Loss: 15.6580\n",
      "Epoch 118/200, Train Loss: 9.1918, Val Loss: 15.4992\n",
      "Epoch 119/200, Train Loss: 9.2373, Val Loss: 15.4445\n",
      "Epoch 120/200, Train Loss: 9.1185, Val Loss: 15.2715\n",
      "Epoch 121/200, Train Loss: 9.1886, Val Loss: 15.4194\n",
      "Epoch 122/200, Train Loss: 8.9766, Val Loss: 15.5306\n",
      "Epoch 123/200, Train Loss: 9.1334, Val Loss: 15.5264\n",
      "Epoch 124/200, Train Loss: 8.9711, Val Loss: 15.6184\n",
      "Epoch 125/200, Train Loss: 9.1232, Val Loss: 15.4856\n",
      "Epoch 126/200, Train Loss: 8.9084, Val Loss: 15.6319\n",
      "Epoch 127/200, Train Loss: 8.9367, Val Loss: 15.0676\n",
      "Epoch 128/200, Train Loss: 8.8242, Val Loss: 15.2041\n",
      "Epoch 129/200, Train Loss: 8.8668, Val Loss: 15.5217\n",
      "Epoch 130/200, Train Loss: 8.9243, Val Loss: 15.4036\n",
      "Epoch 131/200, Train Loss: 8.7316, Val Loss: 15.5362\n",
      "Epoch 132/200, Train Loss: 8.8204, Val Loss: 15.5566\n",
      "Epoch 133/200, Train Loss: 8.7682, Val Loss: 15.6211\n",
      "Epoch 134/200, Train Loss: 8.7204, Val Loss: 15.7504\n",
      "Epoch 135/200, Train Loss: 8.6960, Val Loss: 15.5328\n",
      "Epoch 136/200, Train Loss: 8.7059, Val Loss: 16.0332\n",
      "Epoch 137/200, Train Loss: 8.6134, Val Loss: 15.3740\n",
      "Epoch 138/200, Train Loss: 8.5888, Val Loss: 15.4720\n",
      "Epoch 139/200, Train Loss: 8.6629, Val Loss: 15.5972\n",
      "Epoch 140/200, Train Loss: 8.7375, Val Loss: 15.6118\n",
      "Epoch 141/200, Train Loss: 8.6137, Val Loss: 15.7916\n",
      "Epoch 142/200, Train Loss: 8.4965, Val Loss: 15.8679\n",
      "Epoch 143/200, Train Loss: 8.5523, Val Loss: 15.7034\n",
      "Epoch 144/200, Train Loss: 8.5469, Val Loss: 15.9284\n",
      "Epoch 145/200, Train Loss: 8.5737, Val Loss: 15.5477\n",
      "Epoch 146/200, Train Loss: 8.6004, Val Loss: 15.9116\n",
      "Epoch 147/200, Train Loss: 8.5070, Val Loss: 15.8402\n",
      "Epoch 148/200, Train Loss: 8.4013, Val Loss: 16.1089\n",
      "Epoch 149/200, Train Loss: 8.3643, Val Loss: 15.9980\n",
      "Epoch 150/200, Train Loss: 8.3421, Val Loss: 15.5654\n",
      "Epoch 151/200, Train Loss: 8.3522, Val Loss: 15.8843\n",
      "Epoch 152/200, Train Loss: 8.3144, Val Loss: 15.8822\n",
      "Epoch 153/200, Train Loss: 8.2087, Val Loss: 15.9872\n",
      "Epoch 154/200, Train Loss: 8.2286, Val Loss: 16.0990\n",
      "Epoch 155/200, Train Loss: 8.3501, Val Loss: 15.6630\n",
      "Epoch 156/200, Train Loss: 8.3902, Val Loss: 16.3795\n",
      "Epoch 157/200, Train Loss: 8.3831, Val Loss: 15.9389\n",
      "Epoch 158/200, Train Loss: 8.1462, Val Loss: 16.2591\n",
      "Epoch 159/200, Train Loss: 8.0930, Val Loss: 16.1346\n",
      "Epoch 160/200, Train Loss: 8.2188, Val Loss: 16.1062\n",
      "Epoch 161/200, Train Loss: 8.1551, Val Loss: 16.0140\n",
      "Epoch 162/200, Train Loss: 8.0715, Val Loss: 16.3785\n",
      "Epoch 163/200, Train Loss: 8.1226, Val Loss: 16.2941\n",
      "Epoch 164/200, Train Loss: 8.1842, Val Loss: 16.1060\n",
      "Epoch 165/200, Train Loss: 8.1459, Val Loss: 15.7729\n",
      "Epoch 166/200, Train Loss: 8.1451, Val Loss: 16.4337\n",
      "Epoch 167/200, Train Loss: 8.0700, Val Loss: 16.3598\n",
      "Epoch 168/200, Train Loss: 8.0800, Val Loss: 16.8748\n",
      "Epoch 169/200, Train Loss: 8.0244, Val Loss: 16.1886\n",
      "Epoch 170/200, Train Loss: 8.0224, Val Loss: 16.2275\n",
      "Epoch 171/200, Train Loss: 7.9886, Val Loss: 15.9261\n",
      "Epoch 172/200, Train Loss: 7.9841, Val Loss: 16.4466\n",
      "Epoch 173/200, Train Loss: 7.8989, Val Loss: 16.5381\n",
      "Epoch 174/200, Train Loss: 7.8216, Val Loss: 16.4241\n",
      "Epoch 175/200, Train Loss: 7.8696, Val Loss: 16.1073\n",
      "Epoch 176/200, Train Loss: 7.6952, Val Loss: 16.3895\n",
      "Epoch 177/200, Train Loss: 7.7071, Val Loss: 16.2093\n",
      "Epoch 178/200, Train Loss: 7.7821, Val Loss: 16.3313\n",
      "Epoch 179/200, Train Loss: 7.7126, Val Loss: 16.4294\n",
      "Epoch 180/200, Train Loss: 7.7473, Val Loss: 16.5777\n",
      "Epoch 181/200, Train Loss: 7.6764, Val Loss: 16.4964\n",
      "Epoch 182/200, Train Loss: 7.5932, Val Loss: 16.6485\n",
      "Epoch 183/200, Train Loss: 7.5287, Val Loss: 16.5866\n",
      "Epoch 184/200, Train Loss: 7.5889, Val Loss: 16.7921\n",
      "Epoch 185/200, Train Loss: 7.6797, Val Loss: 16.7528\n",
      "Epoch 186/200, Train Loss: 7.5905, Val Loss: 16.7181\n",
      "Epoch 187/200, Train Loss: 7.5757, Val Loss: 16.8923\n",
      "Epoch 188/200, Train Loss: 7.4928, Val Loss: 16.7067\n",
      "Epoch 189/200, Train Loss: 7.6487, Val Loss: 16.8204\n",
      "Epoch 190/200, Train Loss: 7.4801, Val Loss: 16.6176\n",
      "Epoch 191/200, Train Loss: 7.4748, Val Loss: 16.5241\n",
      "Epoch 192/200, Train Loss: 7.4711, Val Loss: 16.5451\n",
      "Epoch 193/200, Train Loss: 7.6050, Val Loss: 16.6889\n",
      "Epoch 194/200, Train Loss: 7.5005, Val Loss: 16.7261\n",
      "Epoch 195/200, Train Loss: 7.4092, Val Loss: 16.9407\n",
      "Epoch 196/200, Train Loss: 7.4165, Val Loss: 16.8078\n",
      "Epoch 197/200, Train Loss: 7.3722, Val Loss: 17.0370\n",
      "Epoch 198/200, Train Loss: 7.2853, Val Loss: 16.8812\n",
      "Epoch 199/200, Train Loss: 7.2560, Val Loss: 17.1358\n",
      "Epoch 200/200, Train Loss: 7.2646, Val Loss: 17.2831\n",
      "\n",
      "Loaded best model (Val Loss: 14.3178) for final hidden state extraction.\n",
      "Saved best model for NMRNN_Spatial_FixedReadout (samples=640) to results_data_size_sweep/20250514_045146/samples_640/NMRNN_Spatial_FixedReadout_samples_640_best.pt\n",
      "\n",
      "--- Performing Decodability Analysis for NMRNN_Spatial_FixedReadout (samples=640, k=15) ---\n",
      "  Analyzing decodability for NMRNN_Spatial_FixedReadout...\n",
      "  Hidden states shape: torch.Size([160, 200, 128])\n",
      "  Coefficients shape: torch.Size([160, 15])\n",
      "  Processed hidden states shape for decoder: torch.Size([160, 128])\n",
      "  RidgeCV Decoder for NMRNN_Spatial_FixedReadout - Test MSE: 1.7102, Test R2: 0.1389 (best alpha: 100.0000)\n",
      "  Decodability plot saved to results_data_size_sweep/20250514_045146/samples_640/decodability_NMRNN_Spatial_FixedReadout_coeff1.png\n",
      "Decodability (R2 score) for NMRNN_Spatial_FixedReadout (samples=640): 0.1389\n",
      "Learning curves saved to results_data_size_sweep/20250514_045146/samples_640/learning_curves_validation.png\n",
      "\n",
      "Validation learning curves for samples=640 plotted.\n",
      "Learning curves saved to results_data_size_sweep/20250514_045146/samples_640/learning_curves_training.png\n",
      "\n",
      "Training learning curves for samples=640 plotted.\n",
      "Decodability summary for samples=640 saved to results_data_size_sweep/20250514_045146/samples_640/decodability_summary.txt\n",
      "\n",
      "========================= Running for train_samples: 960, k: 15 =========================\n",
      "Results for train_samples=960 will be saved in: results_data_size_sweep/20250514_045146/samples_960\n",
      "Loading dataset...\n",
      "Dataset loaded.\n",
      "Warning: Modulated readout requested but N_nm is 0. Using fixed readout.\n",
      "\n",
      "--- Training RNN_Vanillia (samples=960, k=15) ---\n",
      "Number of parameters: 51301\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/conda/lib/python3.10/site-packages/torch/nn/init.py:405: UserWarning: Initializing zero-element tensors is a no-op\n",
      "  warnings.warn(\"Initializing zero-element tensors is a no-op\")\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/200, Train Loss: 17.0217, Val Loss: 15.7720\n",
      "  New best validation loss: 15.7720\n",
      "Epoch 2/200, Train Loss: 16.8297, Val Loss: 15.7671\n",
      "  New best validation loss: 15.7671\n",
      "Epoch 3/200, Train Loss: 16.7655, Val Loss: 15.7625\n",
      "  New best validation loss: 15.7625\n",
      "Epoch 4/200, Train Loss: 16.7694, Val Loss: 15.7265\n",
      "  New best validation loss: 15.7265\n",
      "Epoch 5/200, Train Loss: 16.7257, Val Loss: 15.7118\n",
      "  New best validation loss: 15.7118\n",
      "Epoch 6/200, Train Loss: 16.7132, Val Loss: 15.7540\n",
      "Epoch 7/200, Train Loss: 16.7062, Val Loss: 15.7268\n",
      "Epoch 8/200, Train Loss: 16.7043, Val Loss: 15.7111\n",
      "  New best validation loss: 15.7111\n",
      "Epoch 9/200, Train Loss: 16.6959, Val Loss: 15.7505\n",
      "Epoch 10/200, Train Loss: 16.6897, Val Loss: 15.7747\n",
      "Epoch 11/200, Train Loss: 16.6762, Val Loss: 15.7167\n",
      "Epoch 12/200, Train Loss: 16.6649, Val Loss: 15.7104\n",
      "  New best validation loss: 15.7104\n",
      "Epoch 13/200, Train Loss: 16.6674, Val Loss: 15.7743\n",
      "Epoch 14/200, Train Loss: 16.6571, Val Loss: 15.7114\n",
      "Epoch 15/200, Train Loss: 16.6490, Val Loss: 15.7891\n",
      "Epoch 16/200, Train Loss: 16.6518, Val Loss: 15.7465\n",
      "Epoch 17/200, Train Loss: 16.6451, Val Loss: 15.7083\n",
      "  New best validation loss: 15.7083\n",
      "Epoch 18/200, Train Loss: 16.6301, Val Loss: 15.6988\n",
      "  New best validation loss: 15.6988\n",
      "Epoch 19/200, Train Loss: 16.6201, Val Loss: 15.7051\n",
      "Epoch 20/200, Train Loss: 16.6130, Val Loss: 15.7035\n",
      "Epoch 21/200, Train Loss: 16.6104, Val Loss: 15.7049\n",
      "Epoch 22/200, Train Loss: 16.6022, Val Loss: 15.7089\n",
      "Epoch 23/200, Train Loss: 16.5922, Val Loss: 15.7053\n",
      "Epoch 24/200, Train Loss: 16.5891, Val Loss: 15.6876\n",
      "  New best validation loss: 15.6876\n",
      "Epoch 25/200, Train Loss: 16.5816, Val Loss: 15.7389\n",
      "Epoch 26/200, Train Loss: 16.5794, Val Loss: 15.7012\n",
      "Epoch 27/200, Train Loss: 16.5671, Val Loss: 15.7288\n",
      "Epoch 28/200, Train Loss: 16.5596, Val Loss: 15.6765\n",
      "  New best validation loss: 15.6765\n",
      "Epoch 29/200, Train Loss: 16.5697, Val Loss: 15.6656\n",
      "  New best validation loss: 15.6656\n",
      "Epoch 30/200, Train Loss: 16.5623, Val Loss: 15.7052\n",
      "Epoch 31/200, Train Loss: 16.5469, Val Loss: 15.6652\n",
      "  New best validation loss: 15.6652\n",
      "Epoch 32/200, Train Loss: 16.5593, Val Loss: 15.7055\n",
      "Epoch 33/200, Train Loss: 16.5575, Val Loss: 15.6590\n",
      "  New best validation loss: 15.6590\n",
      "Epoch 34/200, Train Loss: 16.5329, Val Loss: 15.6783\n",
      "Epoch 35/200, Train Loss: 16.5443, Val Loss: 15.7205\n",
      "Epoch 36/200, Train Loss: 16.5275, Val Loss: 15.6526\n",
      "  New best validation loss: 15.6526\n",
      "Epoch 37/200, Train Loss: 16.5175, Val Loss: 15.6938\n",
      "Epoch 38/200, Train Loss: 16.5129, Val Loss: 15.6575\n",
      "Epoch 39/200, Train Loss: 16.5101, Val Loss: 15.6403\n",
      "  New best validation loss: 15.6403\n",
      "Epoch 40/200, Train Loss: 16.5048, Val Loss: 15.6302\n",
      "  New best validation loss: 15.6302\n",
      "Epoch 41/200, Train Loss: 16.5065, Val Loss: 15.6703\n",
      "Epoch 42/200, Train Loss: 16.4982, Val Loss: 15.6250\n",
      "  New best validation loss: 15.6250\n",
      "Epoch 43/200, Train Loss: 16.4912, Val Loss: 15.6287\n",
      "Epoch 44/200, Train Loss: 16.4778, Val Loss: 15.6603\n",
      "Epoch 45/200, Train Loss: 16.4683, Val Loss: 15.6101\n",
      "  New best validation loss: 15.6101\n",
      "Epoch 46/200, Train Loss: 16.4655, Val Loss: 15.6054\n",
      "  New best validation loss: 15.6054\n",
      "Epoch 47/200, Train Loss: 16.4646, Val Loss: 15.5932\n",
      "  New best validation loss: 15.5932\n",
      "Epoch 48/200, Train Loss: 16.4628, Val Loss: 15.6712\n",
      "Epoch 49/200, Train Loss: 16.4541, Val Loss: 15.6786\n",
      "Epoch 50/200, Train Loss: 16.4536, Val Loss: 15.7280\n",
      "Epoch 51/200, Train Loss: 16.4358, Val Loss: 15.6298\n",
      "Epoch 52/200, Train Loss: 16.4256, Val Loss: 15.6126\n",
      "Epoch 53/200, Train Loss: 16.4175, Val Loss: 15.5730\n",
      "  New best validation loss: 15.5730\n",
      "Epoch 54/200, Train Loss: 16.4092, Val Loss: 15.5579\n",
      "  New best validation loss: 15.5579\n",
      "Epoch 55/200, Train Loss: 16.3998, Val Loss: 15.6078\n",
      "Epoch 56/200, Train Loss: 16.4125, Val Loss: 15.5351\n",
      "  New best validation loss: 15.5351\n",
      "Epoch 57/200, Train Loss: 16.3810, Val Loss: 15.5981\n",
      "Epoch 58/200, Train Loss: 16.3779, Val Loss: 15.5487\n",
      "Epoch 59/200, Train Loss: 16.3675, Val Loss: 15.5466\n",
      "Epoch 60/200, Train Loss: 16.3428, Val Loss: 15.5348\n",
      "  New best validation loss: 15.5348\n",
      "Epoch 61/200, Train Loss: 16.3293, Val Loss: 15.5296\n",
      "  New best validation loss: 15.5296\n",
      "Epoch 62/200, Train Loss: 16.3289, Val Loss: 15.6917\n",
      "Epoch 63/200, Train Loss: 16.3279, Val Loss: 15.4931\n",
      "  New best validation loss: 15.4931\n",
      "Epoch 64/200, Train Loss: 16.3167, Val Loss: 15.4872\n",
      "  New best validation loss: 15.4872\n",
      "Epoch 65/200, Train Loss: 16.2915, Val Loss: 15.4400\n",
      "  New best validation loss: 15.4400\n",
      "Epoch 66/200, Train Loss: 16.2747, Val Loss: 15.4816\n",
      "Epoch 67/200, Train Loss: 16.2779, Val Loss: 15.4637\n",
      "Epoch 68/200, Train Loss: 16.2387, Val Loss: 15.4411\n",
      "Epoch 69/200, Train Loss: 16.2436, Val Loss: 15.4717\n",
      "Epoch 70/200, Train Loss: 16.2341, Val Loss: 15.4422\n",
      "Epoch 71/200, Train Loss: 16.1971, Val Loss: 15.4596\n",
      "Epoch 72/200, Train Loss: 16.1697, Val Loss: 15.3870\n",
      "  New best validation loss: 15.3870\n",
      "Epoch 73/200, Train Loss: 16.1556, Val Loss: 15.3793\n",
      "  New best validation loss: 15.3793\n",
      "Epoch 74/200, Train Loss: 16.1228, Val Loss: 15.2362\n",
      "  New best validation loss: 15.2362\n",
      "Epoch 75/200, Train Loss: 16.1027, Val Loss: 15.2369\n",
      "Epoch 76/200, Train Loss: 16.0707, Val Loss: 15.3631\n",
      "Epoch 77/200, Train Loss: 16.0555, Val Loss: 15.3088\n",
      "Epoch 78/200, Train Loss: 16.0135, Val Loss: 15.0999\n",
      "  New best validation loss: 15.0999\n",
      "Epoch 79/200, Train Loss: 15.9922, Val Loss: 15.0688\n",
      "  New best validation loss: 15.0688\n",
      "Epoch 80/200, Train Loss: 15.9432, Val Loss: 15.0509\n",
      "  New best validation loss: 15.0509\n",
      "Epoch 81/200, Train Loss: 15.9209, Val Loss: 15.0188\n",
      "  New best validation loss: 15.0188\n",
      "Epoch 82/200, Train Loss: 15.8961, Val Loss: 15.0867\n",
      "Epoch 83/200, Train Loss: 15.8565, Val Loss: 15.0064\n",
      "  New best validation loss: 15.0064\n",
      "Epoch 84/200, Train Loss: 15.8552, Val Loss: 14.9440\n",
      "  New best validation loss: 14.9440\n",
      "Epoch 85/200, Train Loss: 15.8163, Val Loss: 15.0828\n",
      "Epoch 86/200, Train Loss: 15.7855, Val Loss: 15.0494\n",
      "Epoch 87/200, Train Loss: 15.7467, Val Loss: 15.0245\n",
      "Epoch 88/200, Train Loss: 15.6990, Val Loss: 14.8943\n",
      "  New best validation loss: 14.8943\n",
      "Epoch 89/200, Train Loss: 15.6742, Val Loss: 15.0714\n",
      "Epoch 90/200, Train Loss: 15.6043, Val Loss: 14.9166\n",
      "Epoch 91/200, Train Loss: 15.5864, Val Loss: 14.7857\n",
      "  New best validation loss: 14.7857\n",
      "Epoch 92/200, Train Loss: 15.5416, Val Loss: 14.7303\n",
      "  New best validation loss: 14.7303\n",
      "Epoch 93/200, Train Loss: 15.5140, Val Loss: 14.7094\n",
      "  New best validation loss: 14.7094\n",
      "Epoch 94/200, Train Loss: 15.4769, Val Loss: 14.7696\n",
      "Epoch 95/200, Train Loss: 15.4263, Val Loss: 14.8459\n",
      "Epoch 96/200, Train Loss: 15.3976, Val Loss: 14.6744\n",
      "  New best validation loss: 14.6744\n",
      "Epoch 97/200, Train Loss: 15.3595, Val Loss: 14.7150\n",
      "Epoch 98/200, Train Loss: 15.3356, Val Loss: 14.5654\n",
      "  New best validation loss: 14.5654\n",
      "Epoch 99/200, Train Loss: 15.2864, Val Loss: 14.6158\n",
      "Epoch 100/200, Train Loss: 15.2477, Val Loss: 14.5456\n",
      "  New best validation loss: 14.5456\n",
      "Epoch 101/200, Train Loss: 15.2322, Val Loss: 14.4925\n",
      "  New best validation loss: 14.4925\n",
      "Epoch 102/200, Train Loss: 15.1886, Val Loss: 14.5457\n",
      "Epoch 103/200, Train Loss: 15.1474, Val Loss: 14.5413\n",
      "Epoch 104/200, Train Loss: 15.0824, Val Loss: 14.4822\n",
      "  New best validation loss: 14.4822\n",
      "Epoch 105/200, Train Loss: 15.0531, Val Loss: 14.7522\n",
      "Epoch 106/200, Train Loss: 15.0252, Val Loss: 14.3511\n",
      "  New best validation loss: 14.3511\n",
      "Epoch 107/200, Train Loss: 15.0096, Val Loss: 14.3645\n",
      "Epoch 108/200, Train Loss: 14.9213, Val Loss: 14.2881\n",
      "  New best validation loss: 14.2881\n",
      "Epoch 109/200, Train Loss: 14.9156, Val Loss: 14.3833\n",
      "Epoch 110/200, Train Loss: 14.8786, Val Loss: 14.3308\n",
      "Epoch 111/200, Train Loss: 14.8358, Val Loss: 14.2234\n",
      "  New best validation loss: 14.2234\n",
      "Epoch 112/200, Train Loss: 14.8063, Val Loss: 14.1395\n",
      "  New best validation loss: 14.1395\n",
      "Epoch 113/200, Train Loss: 14.7713, Val Loss: 14.0526\n",
      "  New best validation loss: 14.0526\n",
      "Epoch 114/200, Train Loss: 14.7256, Val Loss: 14.0529\n",
      "Epoch 115/200, Train Loss: 14.6760, Val Loss: 14.0641\n",
      "Epoch 116/200, Train Loss: 14.6691, Val Loss: 13.9442\n",
      "  New best validation loss: 13.9442\n",
      "Epoch 117/200, Train Loss: 14.6438, Val Loss: 14.0411\n",
      "Epoch 118/200, Train Loss: 14.5768, Val Loss: 14.0566\n",
      "Epoch 119/200, Train Loss: 14.5614, Val Loss: 13.9324\n",
      "  New best validation loss: 13.9324\n",
      "Epoch 120/200, Train Loss: 14.5038, Val Loss: 13.8701\n",
      "  New best validation loss: 13.8701\n",
      "Epoch 121/200, Train Loss: 14.4606, Val Loss: 13.7887\n",
      "  New best validation loss: 13.7887\n",
      "Epoch 122/200, Train Loss: 14.4527, Val Loss: 13.8174\n",
      "Epoch 123/200, Train Loss: 14.4096, Val Loss: 13.8834\n",
      "Epoch 124/200, Train Loss: 14.3811, Val Loss: 13.7093\n",
      "  New best validation loss: 13.7093\n",
      "Epoch 125/200, Train Loss: 14.3433, Val Loss: 13.6556\n",
      "  New best validation loss: 13.6556\n",
      "Epoch 126/200, Train Loss: 14.3190, Val Loss: 13.6647\n",
      "Epoch 127/200, Train Loss: 14.2546, Val Loss: 13.6835\n",
      "Epoch 128/200, Train Loss: 14.2296, Val Loss: 13.6845\n",
      "Epoch 129/200, Train Loss: 14.2282, Val Loss: 13.8417\n",
      "Epoch 130/200, Train Loss: 14.1697, Val Loss: 13.6377\n",
      "  New best validation loss: 13.6377\n",
      "Epoch 131/200, Train Loss: 14.1452, Val Loss: 13.4982\n",
      "  New best validation loss: 13.4982\n",
      "Epoch 132/200, Train Loss: 14.1148, Val Loss: 13.3957\n",
      "  New best validation loss: 13.3957\n",
      "Epoch 133/200, Train Loss: 14.0874, Val Loss: 13.5200\n",
      "Epoch 134/200, Train Loss: 14.0226, Val Loss: 13.3938\n",
      "  New best validation loss: 13.3938\n",
      "Epoch 135/200, Train Loss: 14.0266, Val Loss: 13.4624\n",
      "Epoch 136/200, Train Loss: 13.9725, Val Loss: 13.5609\n",
      "Epoch 137/200, Train Loss: 13.9429, Val Loss: 13.3329\n",
      "  New best validation loss: 13.3329\n",
      "Epoch 138/200, Train Loss: 13.9442, Val Loss: 13.4008\n",
      "Epoch 139/200, Train Loss: 13.8946, Val Loss: 13.3328\n",
      "  New best validation loss: 13.3328\n",
      "Epoch 140/200, Train Loss: 13.8799, Val Loss: 13.4059\n",
      "Epoch 141/200, Train Loss: 13.8871, Val Loss: 13.2824\n",
      "  New best validation loss: 13.2824\n",
      "Epoch 142/200, Train Loss: 13.8160, Val Loss: 13.2931\n",
      "Epoch 143/200, Train Loss: 13.7640, Val Loss: 13.3067\n",
      "Epoch 144/200, Train Loss: 13.8048, Val Loss: 13.5889\n",
      "Epoch 145/200, Train Loss: 13.7448, Val Loss: 13.1975\n",
      "  New best validation loss: 13.1975\n",
      "Epoch 146/200, Train Loss: 13.7163, Val Loss: 13.2125\n",
      "Epoch 147/200, Train Loss: 13.6764, Val Loss: 13.3124\n",
      "Epoch 148/200, Train Loss: 13.6562, Val Loss: 13.2255\n",
      "Epoch 149/200, Train Loss: 13.6444, Val Loss: 13.1871\n",
      "  New best validation loss: 13.1871\n",
      "Epoch 150/200, Train Loss: 13.5625, Val Loss: 13.3007\n",
      "Epoch 151/200, Train Loss: 13.5704, Val Loss: 13.3538\n",
      "Epoch 152/200, Train Loss: 13.5832, Val Loss: 13.2294\n",
      "Epoch 153/200, Train Loss: 13.5529, Val Loss: 13.2638\n",
      "Epoch 154/200, Train Loss: 13.5077, Val Loss: 13.1398\n",
      "  New best validation loss: 13.1398\n",
      "Epoch 155/200, Train Loss: 13.4487, Val Loss: 13.1360\n",
      "  New best validation loss: 13.1360\n",
      "Epoch 156/200, Train Loss: 13.4368, Val Loss: 13.1441\n",
      "Epoch 157/200, Train Loss: 13.4245, Val Loss: 13.1407\n",
      "Epoch 158/200, Train Loss: 13.4159, Val Loss: 13.1705\n",
      "Epoch 159/200, Train Loss: 13.3569, Val Loss: 13.1119\n",
      "  New best validation loss: 13.1119\n",
      "Epoch 160/200, Train Loss: 13.4208, Val Loss: 13.5705\n",
      "Epoch 161/200, Train Loss: 13.3398, Val Loss: 12.9918\n",
      "  New best validation loss: 12.9918\n",
      "Epoch 162/200, Train Loss: 13.2661, Val Loss: 13.2709\n",
      "Epoch 163/200, Train Loss: 13.3055, Val Loss: 13.0078\n",
      "Epoch 164/200, Train Loss: 13.2725, Val Loss: 13.1027\n",
      "Epoch 165/200, Train Loss: 13.2036, Val Loss: 13.0417\n",
      "Epoch 166/200, Train Loss: 13.1892, Val Loss: 13.0814\n",
      "Epoch 167/200, Train Loss: 13.1709, Val Loss: 13.1454\n",
      "Epoch 168/200, Train Loss: 13.1683, Val Loss: 12.9585\n",
      "  New best validation loss: 12.9585\n",
      "Epoch 169/200, Train Loss: 13.1558, Val Loss: 13.1623\n",
      "Epoch 170/200, Train Loss: 13.1263, Val Loss: 13.2598\n",
      "Epoch 171/200, Train Loss: 13.0699, Val Loss: 12.9899\n",
      "Epoch 172/200, Train Loss: 13.0424, Val Loss: 13.1710\n",
      "Epoch 173/200, Train Loss: 13.0070, Val Loss: 12.9779\n",
      "Epoch 174/200, Train Loss: 13.0065, Val Loss: 12.9022\n",
      "  New best validation loss: 12.9022\n",
      "Epoch 175/200, Train Loss: 13.0040, Val Loss: 12.8995\n",
      "  New best validation loss: 12.8995\n",
      "Epoch 176/200, Train Loss: 12.9764, Val Loss: 12.8542\n",
      "  New best validation loss: 12.8542\n",
      "Epoch 177/200, Train Loss: 12.9848, Val Loss: 12.8811\n",
      "Epoch 178/200, Train Loss: 12.9567, Val Loss: 13.2558\n",
      "Epoch 179/200, Train Loss: 12.9425, Val Loss: 12.9568\n",
      "Epoch 180/200, Train Loss: 12.9021, Val Loss: 13.2662\n",
      "Epoch 181/200, Train Loss: 12.9196, Val Loss: 12.8539\n",
      "  New best validation loss: 12.8539\n",
      "Epoch 182/200, Train Loss: 12.8537, Val Loss: 12.7907\n",
      "  New best validation loss: 12.7907\n",
      "Epoch 183/200, Train Loss: 12.8372, Val Loss: 12.9086\n",
      "Epoch 184/200, Train Loss: 12.7918, Val Loss: 12.8850\n",
      "Epoch 185/200, Train Loss: 12.8110, Val Loss: 13.1733\n",
      "Epoch 186/200, Train Loss: 12.7893, Val Loss: 12.6634\n",
      "  New best validation loss: 12.6634\n",
      "Epoch 187/200, Train Loss: 12.7251, Val Loss: 12.7554\n",
      "Epoch 188/200, Train Loss: 12.7565, Val Loss: 12.8333\n",
      "Epoch 189/200, Train Loss: 12.7496, Val Loss: 12.7390\n",
      "Epoch 190/200, Train Loss: 12.6936, Val Loss: 12.9558\n",
      "Epoch 191/200, Train Loss: 12.6819, Val Loss: 13.1674\n",
      "Epoch 192/200, Train Loss: 12.6515, Val Loss: 12.7104\n",
      "Epoch 193/200, Train Loss: 12.6261, Val Loss: 12.7993\n",
      "Epoch 194/200, Train Loss: 12.6182, Val Loss: 12.9535\n",
      "Epoch 195/200, Train Loss: 12.6235, Val Loss: 12.6431\n",
      "  New best validation loss: 12.6431\n",
      "Epoch 196/200, Train Loss: 12.6468, Val Loss: 12.7135\n",
      "Epoch 197/200, Train Loss: 12.5549, Val Loss: 12.6125\n",
      "  New best validation loss: 12.6125\n",
      "Epoch 198/200, Train Loss: 12.5291, Val Loss: 12.7218\n",
      "Epoch 199/200, Train Loss: 12.5043, Val Loss: 12.6074\n",
      "  New best validation loss: 12.6074\n",
      "Epoch 200/200, Train Loss: 12.5077, Val Loss: 12.8233\n",
      "\n",
      "Loaded best model (Val Loss: 12.6074) for final hidden state extraction.\n",
      "Saved best model for RNN_Vanillia (samples=960) to results_data_size_sweep/20250514_045146/samples_960/RNN_Vanillia_samples_960_best.pt\n",
      "\n",
      "--- Performing Decodability Analysis for RNN_Vanillia (samples=960, k=15) ---\n",
      "  Analyzing decodability for RNN_Vanillia...\n",
      "  Hidden states shape: torch.Size([160, 200, 225])\n",
      "  Coefficients shape: torch.Size([160, 15])\n",
      "  Processed hidden states shape for decoder: torch.Size([160, 225])\n",
      "  RidgeCV Decoder for RNN_Vanillia - Test MSE: 1.3034, Test R2: 0.3376 (best alpha: 23.3572)\n",
      "  Decodability plot saved to results_data_size_sweep/20250514_045146/samples_960/decodability_RNN_Vanillia_coeff1.png\n",
      "Decodability (R2 score) for RNN_Vanillia (samples=960): 0.3376\n",
      "\n",
      "--- Training ComplexOscillatorNet (samples=960, k=15) ---\n",
      "Number of parameters: 17152\n",
      "Epoch 1/200, Train Loss: 16.4316, Val Loss: 14.8083\n",
      "  New best validation loss: 14.8083\n",
      "Epoch 2/200, Train Loss: 15.6158, Val Loss: 14.3127\n",
      "  New best validation loss: 14.3127\n",
      "Epoch 3/200, Train Loss: 15.3181, Val Loss: 14.1841\n",
      "  New best validation loss: 14.1841\n",
      "Epoch 4/200, Train Loss: 15.1226, Val Loss: 14.0357\n",
      "  New best validation loss: 14.0357\n",
      "Epoch 5/200, Train Loss: 14.9847, Val Loss: 14.1133\n",
      "Epoch 6/200, Train Loss: 14.8454, Val Loss: 14.0100\n",
      "  New best validation loss: 14.0100\n",
      "Epoch 7/200, Train Loss: 14.7645, Val Loss: 14.0584\n",
      "Epoch 8/200, Train Loss: 14.6530, Val Loss: 13.9151\n",
      "  New best validation loss: 13.9151\n",
      "Epoch 9/200, Train Loss: 14.5483, Val Loss: 13.8838\n",
      "  New best validation loss: 13.8838\n",
      "Epoch 10/200, Train Loss: 14.4620, Val Loss: 13.8635\n",
      "  New best validation loss: 13.8635\n",
      "Epoch 11/200, Train Loss: 14.4157, Val Loss: 13.8079\n",
      "  New best validation loss: 13.8079\n",
      "Epoch 12/200, Train Loss: 14.3152, Val Loss: 13.7769\n",
      "  New best validation loss: 13.7769\n",
      "Epoch 13/200, Train Loss: 14.2892, Val Loss: 13.9827\n",
      "Epoch 14/200, Train Loss: 14.1932, Val Loss: 13.7106\n",
      "  New best validation loss: 13.7106\n",
      "Epoch 15/200, Train Loss: 14.0969, Val Loss: 13.7345\n",
      "Epoch 16/200, Train Loss: 14.0417, Val Loss: 13.7651\n",
      "Epoch 17/200, Train Loss: 13.9890, Val Loss: 13.7863\n",
      "Epoch 18/200, Train Loss: 13.9798, Val Loss: 13.7951\n",
      "Epoch 19/200, Train Loss: 13.9197, Val Loss: 13.7553\n",
      "Epoch 20/200, Train Loss: 13.8497, Val Loss: 13.8177\n",
      "Epoch 21/200, Train Loss: 13.8132, Val Loss: 13.7794\n",
      "Epoch 22/200, Train Loss: 13.8168, Val Loss: 13.8072\n",
      "Epoch 23/200, Train Loss: 13.7559, Val Loss: 13.7611\n",
      "Epoch 24/200, Train Loss: 13.6967, Val Loss: 13.7872\n",
      "Epoch 25/200, Train Loss: 13.6496, Val Loss: 13.7317\n",
      "Epoch 26/200, Train Loss: 13.5983, Val Loss: 13.7403\n",
      "Epoch 27/200, Train Loss: 13.5710, Val Loss: 13.7055\n",
      "  New best validation loss: 13.7055\n",
      "Epoch 28/200, Train Loss: 13.5179, Val Loss: 13.7562\n",
      "Epoch 29/200, Train Loss: 13.4684, Val Loss: 13.6696\n",
      "  New best validation loss: 13.6696\n",
      "Epoch 30/200, Train Loss: 13.4326, Val Loss: 13.7814\n",
      "Epoch 31/200, Train Loss: 13.4355, Val Loss: 13.7759\n",
      "Epoch 32/200, Train Loss: 13.4040, Val Loss: 13.7463\n",
      "Epoch 33/200, Train Loss: 13.3692, Val Loss: 13.7951\n",
      "Epoch 34/200, Train Loss: 13.3537, Val Loss: 13.8131\n",
      "Epoch 35/200, Train Loss: 13.2819, Val Loss: 13.8442\n",
      "Epoch 36/200, Train Loss: 13.2920, Val Loss: 13.7668\n",
      "Epoch 37/200, Train Loss: 13.2102, Val Loss: 13.8513\n",
      "Epoch 38/200, Train Loss: 13.2016, Val Loss: 13.9368\n",
      "Epoch 39/200, Train Loss: 13.1756, Val Loss: 14.0269\n",
      "Epoch 40/200, Train Loss: 13.1739, Val Loss: 13.9620\n",
      "Epoch 41/200, Train Loss: 13.1359, Val Loss: 13.7805\n",
      "Epoch 42/200, Train Loss: 13.0913, Val Loss: 13.8983\n",
      "Epoch 43/200, Train Loss: 13.0751, Val Loss: 13.8782\n",
      "Epoch 44/200, Train Loss: 13.0443, Val Loss: 13.8440\n",
      "Epoch 45/200, Train Loss: 13.0074, Val Loss: 13.8932\n",
      "Epoch 46/200, Train Loss: 12.9698, Val Loss: 13.9611\n",
      "Epoch 47/200, Train Loss: 12.9348, Val Loss: 14.0429\n",
      "Epoch 48/200, Train Loss: 12.9474, Val Loss: 14.0795\n",
      "Epoch 49/200, Train Loss: 12.9653, Val Loss: 13.9630\n",
      "Epoch 50/200, Train Loss: 12.9039, Val Loss: 14.0135\n",
      "Epoch 51/200, Train Loss: 12.8743, Val Loss: 13.9252\n",
      "Epoch 52/200, Train Loss: 12.8791, Val Loss: 14.1076\n",
      "Epoch 53/200, Train Loss: 12.8519, Val Loss: 13.9451\n",
      "Epoch 54/200, Train Loss: 12.8100, Val Loss: 14.0762\n",
      "Epoch 55/200, Train Loss: 12.8013, Val Loss: 13.9914\n",
      "Epoch 56/200, Train Loss: 12.7733, Val Loss: 13.9737\n",
      "Epoch 57/200, Train Loss: 12.7346, Val Loss: 14.0754\n",
      "Epoch 58/200, Train Loss: 12.7253, Val Loss: 14.0127\n",
      "Epoch 59/200, Train Loss: 12.7014, Val Loss: 14.2259\n",
      "Epoch 60/200, Train Loss: 12.7096, Val Loss: 14.2857\n",
      "Epoch 61/200, Train Loss: 12.6863, Val Loss: 14.1346\n",
      "Epoch 62/200, Train Loss: 12.6647, Val Loss: 14.1991\n",
      "Epoch 63/200, Train Loss: 12.6479, Val Loss: 14.2627\n",
      "Epoch 64/200, Train Loss: 12.6418, Val Loss: 14.2664\n",
      "Epoch 65/200, Train Loss: 12.6136, Val Loss: 14.1636\n",
      "Epoch 66/200, Train Loss: 12.6224, Val Loss: 14.0670\n",
      "Epoch 67/200, Train Loss: 12.5644, Val Loss: 14.2631\n",
      "Epoch 68/200, Train Loss: 12.5455, Val Loss: 14.1763\n",
      "Epoch 69/200, Train Loss: 12.5802, Val Loss: 14.1597\n",
      "Epoch 70/200, Train Loss: 12.5123, Val Loss: 14.3169\n",
      "Epoch 71/200, Train Loss: 12.5758, Val Loss: 14.2843\n",
      "Epoch 72/200, Train Loss: 12.5835, Val Loss: 14.3568\n",
      "Epoch 73/200, Train Loss: 12.5020, Val Loss: 14.2536\n",
      "Epoch 74/200, Train Loss: 12.4553, Val Loss: 14.3499\n",
      "Epoch 75/200, Train Loss: 12.4421, Val Loss: 14.2549\n",
      "Epoch 76/200, Train Loss: 12.4586, Val Loss: 14.3613\n",
      "Epoch 77/200, Train Loss: 12.4003, Val Loss: 14.4144\n",
      "Epoch 78/200, Train Loss: 12.3571, Val Loss: 14.4000\n",
      "Epoch 79/200, Train Loss: 12.3426, Val Loss: 14.4458\n",
      "Epoch 80/200, Train Loss: 12.3498, Val Loss: 14.4641\n",
      "Epoch 81/200, Train Loss: 12.3293, Val Loss: 14.5983\n",
      "Epoch 82/200, Train Loss: 12.3032, Val Loss: 14.4748\n",
      "Epoch 83/200, Train Loss: 12.3077, Val Loss: 14.4646\n",
      "Epoch 84/200, Train Loss: 12.2928, Val Loss: 14.4529\n",
      "Epoch 85/200, Train Loss: 12.2818, Val Loss: 14.4982\n",
      "Epoch 86/200, Train Loss: 12.2753, Val Loss: 14.4953\n",
      "Epoch 87/200, Train Loss: 12.2658, Val Loss: 14.4480\n",
      "Epoch 88/200, Train Loss: 12.2177, Val Loss: 14.4781\n",
      "Epoch 89/200, Train Loss: 12.2299, Val Loss: 14.5332\n",
      "Epoch 90/200, Train Loss: 12.2565, Val Loss: 14.5605\n",
      "Epoch 91/200, Train Loss: 12.2384, Val Loss: 14.5734\n",
      "Epoch 92/200, Train Loss: 12.2277, Val Loss: 14.4858\n",
      "Epoch 93/200, Train Loss: 12.1622, Val Loss: 14.6294\n",
      "Epoch 94/200, Train Loss: 12.1879, Val Loss: 14.6253\n",
      "Epoch 95/200, Train Loss: 12.2122, Val Loss: 14.6808\n",
      "Epoch 96/200, Train Loss: 12.2219, Val Loss: 14.6229\n",
      "Epoch 97/200, Train Loss: 12.1968, Val Loss: 14.6751\n",
      "Epoch 98/200, Train Loss: 12.1333, Val Loss: 14.5925\n",
      "Epoch 99/200, Train Loss: 12.1421, Val Loss: 14.5586\n",
      "Epoch 100/200, Train Loss: 12.1449, Val Loss: 14.6743\n",
      "Epoch 101/200, Train Loss: 12.1409, Val Loss: 14.7052\n",
      "Epoch 102/200, Train Loss: 12.1240, Val Loss: 14.5944\n",
      "Epoch 103/200, Train Loss: 12.0965, Val Loss: 14.6416\n",
      "Epoch 104/200, Train Loss: 12.0948, Val Loss: 14.7178\n",
      "Epoch 105/200, Train Loss: 12.0693, Val Loss: 14.7394\n",
      "Epoch 106/200, Train Loss: 12.0934, Val Loss: 14.6711\n",
      "Epoch 107/200, Train Loss: 12.0694, Val Loss: 14.8061\n",
      "Epoch 108/200, Train Loss: 12.0913, Val Loss: 14.7310\n",
      "Epoch 109/200, Train Loss: 12.0949, Val Loss: 14.8014\n",
      "Epoch 110/200, Train Loss: 12.0936, Val Loss: 14.7550\n",
      "Epoch 111/200, Train Loss: 12.0235, Val Loss: 14.7497\n",
      "Epoch 112/200, Train Loss: 12.0428, Val Loss: 14.7875\n",
      "Epoch 113/200, Train Loss: 12.0374, Val Loss: 14.6776\n",
      "Epoch 114/200, Train Loss: 12.0082, Val Loss: 14.7243\n",
      "Epoch 115/200, Train Loss: 12.0467, Val Loss: 14.8571\n",
      "Epoch 116/200, Train Loss: 12.0205, Val Loss: 14.8140\n",
      "Epoch 117/200, Train Loss: 11.9703, Val Loss: 14.7819\n",
      "Epoch 118/200, Train Loss: 11.9626, Val Loss: 14.9171\n",
      "Epoch 119/200, Train Loss: 12.0038, Val Loss: 14.8568\n",
      "Epoch 120/200, Train Loss: 11.9862, Val Loss: 14.8159\n",
      "Epoch 121/200, Train Loss: 11.9688, Val Loss: 14.9436\n",
      "Epoch 122/200, Train Loss: 11.9954, Val Loss: 14.7086\n",
      "Epoch 123/200, Train Loss: 11.9600, Val Loss: 14.7415\n",
      "Epoch 124/200, Train Loss: 11.9447, Val Loss: 14.8157\n",
      "Epoch 125/200, Train Loss: 11.9332, Val Loss: 14.8369\n",
      "Epoch 126/200, Train Loss: 11.9219, Val Loss: 14.6871\n",
      "Epoch 127/200, Train Loss: 11.9235, Val Loss: 14.8465\n",
      "Epoch 128/200, Train Loss: 11.9077, Val Loss: 14.9178\n",
      "Epoch 129/200, Train Loss: 11.9030, Val Loss: 14.8162\n",
      "Epoch 130/200, Train Loss: 11.9148, Val Loss: 14.8277\n",
      "Epoch 131/200, Train Loss: 11.9300, Val Loss: 14.8180\n",
      "Epoch 132/200, Train Loss: 11.9083, Val Loss: 14.9687\n",
      "Epoch 133/200, Train Loss: 11.8921, Val Loss: 14.9424\n",
      "Epoch 134/200, Train Loss: 11.8955, Val Loss: 14.8275\n",
      "Epoch 135/200, Train Loss: 11.8900, Val Loss: 14.8691\n",
      "Epoch 136/200, Train Loss: 11.8732, Val Loss: 14.9192\n",
      "Epoch 137/200, Train Loss: 11.8623, Val Loss: 14.8527\n",
      "Epoch 138/200, Train Loss: 11.8226, Val Loss: 14.9101\n",
      "Epoch 139/200, Train Loss: 11.8264, Val Loss: 14.9825\n",
      "Epoch 140/200, Train Loss: 11.8514, Val Loss: 14.8565\n",
      "Epoch 141/200, Train Loss: 11.8542, Val Loss: 15.0647\n",
      "Epoch 142/200, Train Loss: 11.8894, Val Loss: 14.9704\n",
      "Epoch 143/200, Train Loss: 11.9727, Val Loss: 14.9105\n",
      "Epoch 144/200, Train Loss: 11.9486, Val Loss: 15.0470\n",
      "Epoch 145/200, Train Loss: 11.8651, Val Loss: 14.8948\n",
      "Epoch 146/200, Train Loss: 11.8481, Val Loss: 14.8099\n",
      "Epoch 147/200, Train Loss: 11.8165, Val Loss: 14.9925\n",
      "Epoch 148/200, Train Loss: 11.8054, Val Loss: 14.9573\n",
      "Epoch 149/200, Train Loss: 11.7574, Val Loss: 14.9673\n",
      "Epoch 150/200, Train Loss: 11.7453, Val Loss: 14.9082\n",
      "Epoch 151/200, Train Loss: 11.7493, Val Loss: 14.9114\n",
      "Epoch 152/200, Train Loss: 11.7388, Val Loss: 14.9702\n",
      "Epoch 153/200, Train Loss: 11.7391, Val Loss: 15.0411\n",
      "Epoch 154/200, Train Loss: 11.7577, Val Loss: 14.9633\n",
      "Epoch 155/200, Train Loss: 11.7650, Val Loss: 14.9928\n",
      "Epoch 156/200, Train Loss: 11.7519, Val Loss: 15.0476\n",
      "Epoch 157/200, Train Loss: 11.8771, Val Loss: 14.9657\n",
      "Epoch 158/200, Train Loss: 11.9432, Val Loss: 14.8788\n",
      "Epoch 159/200, Train Loss: 11.8462, Val Loss: 14.9778\n",
      "Epoch 160/200, Train Loss: 11.7932, Val Loss: 14.9442\n",
      "Epoch 161/200, Train Loss: 11.7776, Val Loss: 14.9978\n",
      "Epoch 162/200, Train Loss: 11.7369, Val Loss: 15.0189\n",
      "Epoch 163/200, Train Loss: 11.7407, Val Loss: 14.8320\n",
      "Epoch 164/200, Train Loss: 11.7398, Val Loss: 14.8348\n",
      "Epoch 165/200, Train Loss: 11.7036, Val Loss: 14.8677\n",
      "Epoch 166/200, Train Loss: 11.6760, Val Loss: 14.9515\n",
      "Epoch 167/200, Train Loss: 11.6905, Val Loss: 14.9927\n",
      "Epoch 168/200, Train Loss: 11.7111, Val Loss: 15.0375\n",
      "Epoch 169/200, Train Loss: 11.6889, Val Loss: 14.9023\n",
      "Epoch 170/200, Train Loss: 11.6813, Val Loss: 15.0316\n",
      "Epoch 171/200, Train Loss: 11.6810, Val Loss: 15.0764\n",
      "Epoch 172/200, Train Loss: 11.6709, Val Loss: 15.0195\n",
      "Epoch 173/200, Train Loss: 11.6989, Val Loss: 14.9605\n",
      "Epoch 174/200, Train Loss: 11.6682, Val Loss: 15.0262\n",
      "Epoch 175/200, Train Loss: 11.6638, Val Loss: 15.0656\n",
      "Epoch 176/200, Train Loss: 11.6615, Val Loss: 14.9466\n",
      "Epoch 177/200, Train Loss: 11.6455, Val Loss: 15.0251\n",
      "Epoch 178/200, Train Loss: 11.6651, Val Loss: 14.9426\n",
      "Epoch 179/200, Train Loss: 11.6999, Val Loss: 14.9996\n",
      "Epoch 180/200, Train Loss: 11.7027, Val Loss: 15.0430\n",
      "Epoch 181/200, Train Loss: 11.6765, Val Loss: 15.0057\n",
      "Epoch 182/200, Train Loss: 11.6636, Val Loss: 15.1584\n",
      "Epoch 183/200, Train Loss: 11.6860, Val Loss: 14.9874\n",
      "Epoch 184/200, Train Loss: 11.6355, Val Loss: 15.0661\n",
      "Epoch 185/200, Train Loss: 11.5845, Val Loss: 15.0560\n",
      "Epoch 186/200, Train Loss: 11.5903, Val Loss: 15.0528\n",
      "Epoch 187/200, Train Loss: 11.6053, Val Loss: 14.9860\n",
      "Epoch 188/200, Train Loss: 11.5684, Val Loss: 15.2179\n",
      "Epoch 189/200, Train Loss: 11.5900, Val Loss: 15.0616\n",
      "Epoch 190/200, Train Loss: 11.6131, Val Loss: 15.0128\n",
      "Epoch 191/200, Train Loss: 11.6332, Val Loss: 15.0949\n",
      "Epoch 192/200, Train Loss: 11.8250, Val Loss: 15.0630\n",
      "Epoch 193/200, Train Loss: 11.7827, Val Loss: 15.1119\n",
      "Epoch 194/200, Train Loss: 11.6509, Val Loss: 14.9471\n",
      "Epoch 195/200, Train Loss: 11.5979, Val Loss: 15.2070\n",
      "Epoch 196/200, Train Loss: 11.5940, Val Loss: 15.1205\n",
      "Epoch 197/200, Train Loss: 11.5875, Val Loss: 15.0457\n",
      "Epoch 198/200, Train Loss: 11.5719, Val Loss: 15.0390\n",
      "Epoch 199/200, Train Loss: 11.5636, Val Loss: 15.2093\n",
      "Epoch 200/200, Train Loss: 11.6208, Val Loss: 15.0626\n",
      "\n",
      "Loaded best model (Val Loss: 13.6696) for final hidden state extraction.\n",
      "Saved best model for ComplexOscillatorNet (samples=960) to results_data_size_sweep/20250514_045146/samples_960/ComplexOscillatorNet_samples_960_best.pt\n",
      "\n",
      "--- Performing Decodability Analysis for ComplexOscillatorNet (samples=960, k=15) ---\n",
      "  Analyzing decodability for ComplexOscillatorNet...\n",
      "  Hidden states shape: torch.Size([160, 200, 128])\n",
      "  Coefficients shape: torch.Size([160, 15])\n",
      "  Processed hidden states shape for decoder: torch.Size([160, 256])\n",
      "  RidgeCV Decoder for ComplexOscillatorNet - Test MSE: 1.2838, Test R2: 0.3555 (best alpha: 100.0000)\n",
      "  Decodability plot saved to results_data_size_sweep/20250514_045146/samples_960/decodability_ComplexOscillatorNet_coeff1.png\n",
      "Decodability (R2 score) for ComplexOscillatorNet (samples=960): 0.3555\n",
      "\n",
      "--- Training RNN_GRU (samples=960, k=15) ---\n",
      "Number of parameters: 12993\n",
      "Epoch 1/200, Train Loss: 16.9046, Val Loss: 15.7556\n",
      "  New best validation loss: 15.7556\n",
      "Epoch 2/200, Train Loss: 16.8627, Val Loss: 15.7283\n",
      "  New best validation loss: 15.7283\n",
      "Epoch 3/200, Train Loss: 16.8201, Val Loss: 15.6988\n",
      "  New best validation loss: 15.6988\n",
      "Epoch 4/200, Train Loss: 16.7902, Val Loss: 15.7030\n",
      "Epoch 5/200, Train Loss: 16.7746, Val Loss: 15.6921\n",
      "  New best validation loss: 15.6921\n",
      "Epoch 6/200, Train Loss: 16.7712, Val Loss: 15.7328\n",
      "Epoch 7/200, Train Loss: 16.7689, Val Loss: 15.6991\n",
      "Epoch 8/200, Train Loss: 16.7573, Val Loss: 15.6866\n",
      "  New best validation loss: 15.6866\n",
      "Epoch 9/200, Train Loss: 16.7566, Val Loss: 15.7197\n",
      "Epoch 10/200, Train Loss: 16.7540, Val Loss: 15.6910\n",
      "Epoch 11/200, Train Loss: 16.7468, Val Loss: 15.6922\n",
      "Epoch 12/200, Train Loss: 16.7414, Val Loss: 15.6806\n",
      "  New best validation loss: 15.6806\n",
      "Epoch 13/200, Train Loss: 16.7360, Val Loss: 15.6793\n",
      "  New best validation loss: 15.6793\n",
      "Epoch 14/200, Train Loss: 16.7328, Val Loss: 15.6693\n",
      "  New best validation loss: 15.6693\n",
      "Epoch 15/200, Train Loss: 16.7277, Val Loss: 15.6803\n",
      "Epoch 16/200, Train Loss: 16.7245, Val Loss: 15.6603\n",
      "  New best validation loss: 15.6603\n",
      "Epoch 17/200, Train Loss: 16.7174, Val Loss: 15.6619\n",
      "Epoch 18/200, Train Loss: 16.7111, Val Loss: 15.6592\n",
      "  New best validation loss: 15.6592\n",
      "Epoch 19/200, Train Loss: 16.7040, Val Loss: 15.6339\n",
      "  New best validation loss: 15.6339\n",
      "Epoch 20/200, Train Loss: 16.6987, Val Loss: 15.6309\n",
      "  New best validation loss: 15.6309\n",
      "Epoch 21/200, Train Loss: 16.6917, Val Loss: 15.6257\n",
      "  New best validation loss: 15.6257\n",
      "Epoch 22/200, Train Loss: 16.6812, Val Loss: 15.6147\n",
      "  New best validation loss: 15.6147\n",
      "Epoch 23/200, Train Loss: 16.6687, Val Loss: 15.6209\n",
      "Epoch 24/200, Train Loss: 16.6527, Val Loss: 15.5911\n",
      "  New best validation loss: 15.5911\n",
      "Epoch 25/200, Train Loss: 16.6422, Val Loss: 15.5824\n",
      "  New best validation loss: 15.5824\n",
      "Epoch 26/200, Train Loss: 16.6322, Val Loss: 15.5897\n",
      "Epoch 27/200, Train Loss: 16.6258, Val Loss: 15.5306\n",
      "  New best validation loss: 15.5306\n",
      "Epoch 28/200, Train Loss: 16.6209, Val Loss: 15.5530\n",
      "Epoch 29/200, Train Loss: 16.6031, Val Loss: 15.5357\n",
      "Epoch 30/200, Train Loss: 16.5988, Val Loss: 15.5719\n",
      "Epoch 31/200, Train Loss: 16.5955, Val Loss: 15.5643\n",
      "Epoch 32/200, Train Loss: 16.5947, Val Loss: 15.5609\n",
      "Epoch 33/200, Train Loss: 16.5818, Val Loss: 15.5647\n",
      "Epoch 34/200, Train Loss: 16.5809, Val Loss: 15.5406\n",
      "Epoch 35/200, Train Loss: 16.5809, Val Loss: 15.5944\n",
      "Epoch 36/200, Train Loss: 16.5669, Val Loss: 15.4929\n",
      "  New best validation loss: 15.4929\n",
      "Epoch 37/200, Train Loss: 16.5660, Val Loss: 15.4878\n",
      "  New best validation loss: 15.4878\n",
      "Epoch 38/200, Train Loss: 16.5552, Val Loss: 15.4669\n",
      "  New best validation loss: 15.4669\n",
      "Epoch 39/200, Train Loss: 16.5439, Val Loss: 15.4843\n",
      "Epoch 40/200, Train Loss: 16.5281, Val Loss: 15.4890\n",
      "Epoch 41/200, Train Loss: 16.5312, Val Loss: 15.4751\n",
      "Epoch 42/200, Train Loss: 16.5227, Val Loss: 15.5085\n",
      "Epoch 43/200, Train Loss: 16.5121, Val Loss: 15.4508\n",
      "  New best validation loss: 15.4508\n",
      "Epoch 44/200, Train Loss: 16.5168, Val Loss: 15.4854\n",
      "Epoch 45/200, Train Loss: 16.4929, Val Loss: 15.4663\n",
      "Epoch 46/200, Train Loss: 16.4815, Val Loss: 15.5370\n",
      "Epoch 47/200, Train Loss: 16.4572, Val Loss: 15.4680\n",
      "Epoch 48/200, Train Loss: 16.4422, Val Loss: 15.4595\n",
      "Epoch 49/200, Train Loss: 16.4164, Val Loss: 15.4698\n",
      "Epoch 50/200, Train Loss: 16.4104, Val Loss: 15.4613\n",
      "Epoch 51/200, Train Loss: 16.4033, Val Loss: 15.4880\n",
      "Epoch 52/200, Train Loss: 16.3812, Val Loss: 15.4246\n",
      "  New best validation loss: 15.4246\n",
      "Epoch 53/200, Train Loss: 16.4028, Val Loss: 15.5114\n",
      "Epoch 54/200, Train Loss: 16.3731, Val Loss: 15.4599\n",
      "Epoch 55/200, Train Loss: 16.3729, Val Loss: 15.4304\n",
      "Epoch 56/200, Train Loss: 16.3614, Val Loss: 15.4299\n",
      "Epoch 57/200, Train Loss: 16.3432, Val Loss: 15.4388\n",
      "Epoch 58/200, Train Loss: 16.3431, Val Loss: 15.4101\n",
      "  New best validation loss: 15.4101\n",
      "Epoch 59/200, Train Loss: 16.3111, Val Loss: 15.3894\n",
      "  New best validation loss: 15.3894\n",
      "Epoch 60/200, Train Loss: 16.3034, Val Loss: 15.3649\n",
      "  New best validation loss: 15.3649\n",
      "Epoch 61/200, Train Loss: 16.3106, Val Loss: 15.3837\n",
      "Epoch 62/200, Train Loss: 16.2764, Val Loss: 15.3316\n",
      "  New best validation loss: 15.3316\n",
      "Epoch 63/200, Train Loss: 16.2775, Val Loss: 15.2890\n",
      "  New best validation loss: 15.2890\n",
      "Epoch 64/200, Train Loss: 16.2464, Val Loss: 15.2797\n",
      "  New best validation loss: 15.2797\n",
      "Epoch 65/200, Train Loss: 16.1670, Val Loss: 15.1994\n",
      "  New best validation loss: 15.1994\n",
      "Epoch 66/200, Train Loss: 16.1245, Val Loss: 15.2007\n",
      "Epoch 67/200, Train Loss: 16.0988, Val Loss: 15.1536\n",
      "  New best validation loss: 15.1536\n",
      "Epoch 68/200, Train Loss: 16.0848, Val Loss: 15.2026\n",
      "Epoch 69/200, Train Loss: 16.1248, Val Loss: 15.2331\n",
      "Epoch 70/200, Train Loss: 16.0375, Val Loss: 15.1287\n",
      "  New best validation loss: 15.1287\n",
      "Epoch 71/200, Train Loss: 15.9846, Val Loss: 15.0914\n",
      "  New best validation loss: 15.0914\n",
      "Epoch 72/200, Train Loss: 15.9427, Val Loss: 15.2354\n",
      "Epoch 73/200, Train Loss: 15.8991, Val Loss: 15.0510\n",
      "  New best validation loss: 15.0510\n",
      "Epoch 74/200, Train Loss: 15.8938, Val Loss: 14.9104\n",
      "  New best validation loss: 14.9104\n",
      "Epoch 75/200, Train Loss: 15.8049, Val Loss: 14.9122\n",
      "Epoch 76/200, Train Loss: 15.8097, Val Loss: 14.8709\n",
      "  New best validation loss: 14.8709\n",
      "Epoch 77/200, Train Loss: 15.7737, Val Loss: 14.9178\n",
      "Epoch 78/200, Train Loss: 15.7857, Val Loss: 14.8311\n",
      "  New best validation loss: 14.8311\n",
      "Epoch 79/200, Train Loss: 15.7265, Val Loss: 14.8472\n",
      "Epoch 80/200, Train Loss: 15.7567, Val Loss: 14.8343\n",
      "Epoch 81/200, Train Loss: 15.7441, Val Loss: 15.0440\n",
      "Epoch 82/200, Train Loss: 15.7671, Val Loss: 14.7968\n",
      "  New best validation loss: 14.7968\n",
      "Epoch 83/200, Train Loss: 15.6408, Val Loss: 14.8201\n",
      "Epoch 84/200, Train Loss: 15.6330, Val Loss: 14.7215\n",
      "  New best validation loss: 14.7215\n",
      "Epoch 85/200, Train Loss: 15.5710, Val Loss: 14.6936\n",
      "  New best validation loss: 14.6936\n",
      "Epoch 86/200, Train Loss: 15.5487, Val Loss: 14.6825\n",
      "  New best validation loss: 14.6825\n",
      "Epoch 87/200, Train Loss: 15.5462, Val Loss: 14.7252\n",
      "Epoch 88/200, Train Loss: 15.5506, Val Loss: 15.0678\n",
      "Epoch 89/200, Train Loss: 15.5642, Val Loss: 14.6517\n",
      "  New best validation loss: 14.6517\n",
      "Epoch 90/200, Train Loss: 15.4467, Val Loss: 14.6856\n",
      "Epoch 91/200, Train Loss: 15.3823, Val Loss: 14.6433\n",
      "  New best validation loss: 14.6433\n",
      "Epoch 92/200, Train Loss: 15.5089, Val Loss: 14.6249\n",
      "  New best validation loss: 14.6249\n",
      "Epoch 93/200, Train Loss: 15.4049, Val Loss: 14.5380\n",
      "  New best validation loss: 14.5380\n",
      "Epoch 94/200, Train Loss: 15.3570, Val Loss: 14.6078\n",
      "Epoch 95/200, Train Loss: 15.2919, Val Loss: 14.8952\n",
      "Epoch 96/200, Train Loss: 15.4472, Val Loss: 14.6139\n",
      "Epoch 97/200, Train Loss: 15.1987, Val Loss: 14.5836\n",
      "Epoch 98/200, Train Loss: 15.1927, Val Loss: 14.4224\n",
      "  New best validation loss: 14.4224\n",
      "Epoch 99/200, Train Loss: 15.2552, Val Loss: 14.4322\n",
      "Epoch 100/200, Train Loss: 15.0937, Val Loss: 14.4003\n",
      "  New best validation loss: 14.4003\n",
      "Epoch 101/200, Train Loss: 15.0132, Val Loss: 14.3587\n",
      "  New best validation loss: 14.3587\n",
      "Epoch 102/200, Train Loss: 15.0047, Val Loss: 14.5049\n",
      "Epoch 103/200, Train Loss: 14.9522, Val Loss: 14.3446\n",
      "  New best validation loss: 14.3446\n",
      "Epoch 104/200, Train Loss: 14.8850, Val Loss: 14.3294\n",
      "  New best validation loss: 14.3294\n",
      "Epoch 105/200, Train Loss: 14.8938, Val Loss: 14.3208\n",
      "  New best validation loss: 14.3208\n",
      "Epoch 106/200, Train Loss: 14.9008, Val Loss: 14.3550\n",
      "Epoch 107/200, Train Loss: 14.8779, Val Loss: 14.2677\n",
      "  New best validation loss: 14.2677\n",
      "Epoch 108/200, Train Loss: 14.7650, Val Loss: 14.2426\n",
      "  New best validation loss: 14.2426\n",
      "Epoch 109/200, Train Loss: 14.9102, Val Loss: 14.2235\n",
      "  New best validation loss: 14.2235\n",
      "Epoch 110/200, Train Loss: 14.7593, Val Loss: 14.2431\n",
      "Epoch 111/200, Train Loss: 14.6565, Val Loss: 14.1868\n",
      "  New best validation loss: 14.1868\n",
      "Epoch 112/200, Train Loss: 14.6125, Val Loss: 14.1830\n",
      "  New best validation loss: 14.1830\n",
      "Epoch 113/200, Train Loss: 14.5830, Val Loss: 14.2503\n",
      "Epoch 114/200, Train Loss: 14.6720, Val Loss: 14.1038\n",
      "  New best validation loss: 14.1038\n",
      "Epoch 115/200, Train Loss: 14.7221, Val Loss: 14.0725\n",
      "  New best validation loss: 14.0725\n",
      "Epoch 116/200, Train Loss: 14.5574, Val Loss: 14.3967\n",
      "Epoch 117/200, Train Loss: 14.5718, Val Loss: 14.1718\n",
      "Epoch 118/200, Train Loss: 14.5307, Val Loss: 14.0456\n",
      "  New best validation loss: 14.0456\n",
      "Epoch 119/200, Train Loss: 14.5077, Val Loss: 14.0558\n",
      "Epoch 120/200, Train Loss: 14.5382, Val Loss: 14.0929\n",
      "Epoch 121/200, Train Loss: 14.6127, Val Loss: 14.0082\n",
      "  New best validation loss: 14.0082\n",
      "Epoch 122/200, Train Loss: 14.6421, Val Loss: 13.9907\n",
      "  New best validation loss: 13.9907\n",
      "Epoch 123/200, Train Loss: 14.4455, Val Loss: 14.0162\n",
      "Epoch 124/200, Train Loss: 14.4192, Val Loss: 14.0167\n",
      "Epoch 125/200, Train Loss: 14.5024, Val Loss: 14.0762\n",
      "Epoch 126/200, Train Loss: 14.5552, Val Loss: 14.4922\n",
      "Epoch 127/200, Train Loss: 14.5629, Val Loss: 14.8404\n",
      "Epoch 128/200, Train Loss: 14.5846, Val Loss: 13.8878\n",
      "  New best validation loss: 13.8878\n",
      "Epoch 129/200, Train Loss: 14.4030, Val Loss: 13.9309\n",
      "Epoch 130/200, Train Loss: 14.3057, Val Loss: 13.8390\n",
      "  New best validation loss: 13.8390\n",
      "Epoch 131/200, Train Loss: 14.2789, Val Loss: 13.8735\n",
      "Epoch 132/200, Train Loss: 14.2363, Val Loss: 14.0424\n",
      "Epoch 133/200, Train Loss: 14.2766, Val Loss: 13.7787\n",
      "  New best validation loss: 13.7787\n",
      "Epoch 134/200, Train Loss: 14.2426, Val Loss: 13.9464\n",
      "Epoch 135/200, Train Loss: 14.3369, Val Loss: 13.8263\n",
      "Epoch 136/200, Train Loss: 14.1826, Val Loss: 13.8426\n",
      "Epoch 137/200, Train Loss: 14.1406, Val Loss: 13.7802\n",
      "Epoch 138/200, Train Loss: 14.1710, Val Loss: 13.9589\n",
      "Epoch 139/200, Train Loss: 14.2263, Val Loss: 13.6101\n",
      "  New best validation loss: 13.6101\n",
      "Epoch 140/200, Train Loss: 14.0806, Val Loss: 13.8351\n",
      "Epoch 141/200, Train Loss: 14.2286, Val Loss: 13.8300\n",
      "Epoch 142/200, Train Loss: 14.0761, Val Loss: 13.6307\n",
      "Epoch 143/200, Train Loss: 14.0558, Val Loss: 13.6652\n",
      "Epoch 144/200, Train Loss: 14.0340, Val Loss: 13.6941\n",
      "Epoch 145/200, Train Loss: 13.9797, Val Loss: 13.6523\n",
      "Epoch 146/200, Train Loss: 14.0403, Val Loss: 14.1658\n",
      "Epoch 147/200, Train Loss: 14.1961, Val Loss: 13.8179\n",
      "Epoch 148/200, Train Loss: 14.0689, Val Loss: 13.6249\n",
      "Epoch 149/200, Train Loss: 14.0899, Val Loss: 13.6489\n",
      "Epoch 150/200, Train Loss: 13.9881, Val Loss: 13.6463\n",
      "Epoch 151/200, Train Loss: 13.9326, Val Loss: 14.0636\n",
      "Epoch 152/200, Train Loss: 13.9500, Val Loss: 13.6617\n",
      "Epoch 153/200, Train Loss: 13.9150, Val Loss: 13.5382\n",
      "  New best validation loss: 13.5382\n",
      "Epoch 154/200, Train Loss: 13.8770, Val Loss: 13.6029\n",
      "Epoch 155/200, Train Loss: 13.9164, Val Loss: 13.4949\n",
      "  New best validation loss: 13.4949\n",
      "Epoch 156/200, Train Loss: 13.8803, Val Loss: 13.7505\n",
      "Epoch 157/200, Train Loss: 13.8741, Val Loss: 13.5098\n",
      "Epoch 158/200, Train Loss: 13.8604, Val Loss: 13.5326\n",
      "Epoch 159/200, Train Loss: 13.8462, Val Loss: 13.6161\n",
      "Epoch 160/200, Train Loss: 13.8517, Val Loss: 13.6832\n",
      "Epoch 161/200, Train Loss: 13.9638, Val Loss: 13.7566\n",
      "Epoch 162/200, Train Loss: 13.8924, Val Loss: 13.6174\n",
      "Epoch 163/200, Train Loss: 13.8197, Val Loss: 13.4474\n",
      "  New best validation loss: 13.4474\n",
      "Epoch 164/200, Train Loss: 13.8104, Val Loss: 13.4767\n",
      "Epoch 165/200, Train Loss: 13.8464, Val Loss: 13.3838\n",
      "  New best validation loss: 13.3838\n",
      "Epoch 166/200, Train Loss: 13.7877, Val Loss: 13.5769\n",
      "Epoch 167/200, Train Loss: 13.8132, Val Loss: 13.2928\n",
      "  New best validation loss: 13.2928\n",
      "Epoch 168/200, Train Loss: 13.8043, Val Loss: 13.3743\n",
      "Epoch 169/200, Train Loss: 13.8586, Val Loss: 13.5918\n",
      "Epoch 170/200, Train Loss: 13.7895, Val Loss: 13.4471\n",
      "Epoch 171/200, Train Loss: 13.6970, Val Loss: 13.4160\n",
      "Epoch 172/200, Train Loss: 13.8297, Val Loss: 13.3038\n",
      "Epoch 173/200, Train Loss: 13.7091, Val Loss: 13.5936\n",
      "Epoch 174/200, Train Loss: 13.7653, Val Loss: 13.9924\n",
      "Epoch 175/200, Train Loss: 13.6992, Val Loss: 13.6468\n",
      "Epoch 176/200, Train Loss: 13.6777, Val Loss: 13.4644\n",
      "Epoch 177/200, Train Loss: 13.6260, Val Loss: 13.5032\n",
      "Epoch 178/200, Train Loss: 13.6389, Val Loss: 13.2980\n",
      "Epoch 179/200, Train Loss: 13.7636, Val Loss: 13.4941\n",
      "Epoch 180/200, Train Loss: 13.7503, Val Loss: 13.5721\n",
      "Epoch 181/200, Train Loss: 13.7585, Val Loss: 13.4277\n",
      "Epoch 182/200, Train Loss: 13.6565, Val Loss: 13.4015\n",
      "Epoch 183/200, Train Loss: 13.6012, Val Loss: 13.2831\n",
      "  New best validation loss: 13.2831\n",
      "Epoch 184/200, Train Loss: 13.6192, Val Loss: 13.2959\n",
      "Epoch 185/200, Train Loss: 13.5979, Val Loss: 13.3611\n",
      "Epoch 186/200, Train Loss: 13.5547, Val Loss: 13.2866\n",
      "Epoch 187/200, Train Loss: 13.5496, Val Loss: 13.4205\n",
      "Epoch 188/200, Train Loss: 13.5806, Val Loss: 13.2704\n",
      "  New best validation loss: 13.2704\n",
      "Epoch 189/200, Train Loss: 13.6111, Val Loss: 13.2619\n",
      "  New best validation loss: 13.2619\n",
      "Epoch 190/200, Train Loss: 13.4856, Val Loss: 13.2649\n",
      "Epoch 191/200, Train Loss: 13.5604, Val Loss: 13.5046\n",
      "Epoch 192/200, Train Loss: 13.5353, Val Loss: 13.3383\n",
      "Epoch 193/200, Train Loss: 13.5269, Val Loss: 13.5273\n",
      "Epoch 194/200, Train Loss: 13.5047, Val Loss: 13.1609\n",
      "  New best validation loss: 13.1609\n",
      "Epoch 195/200, Train Loss: 13.4589, Val Loss: 13.2334\n",
      "Epoch 196/200, Train Loss: 13.4899, Val Loss: 13.2318\n",
      "Epoch 197/200, Train Loss: 13.5280, Val Loss: 13.1169\n",
      "  New best validation loss: 13.1169\n",
      "Epoch 198/200, Train Loss: 13.4088, Val Loss: 13.2437\n",
      "Epoch 199/200, Train Loss: 13.4945, Val Loss: 13.1177\n",
      "Epoch 200/200, Train Loss: 13.3966, Val Loss: 13.1201\n",
      "\n",
      "Loaded best model (Val Loss: 13.1169) for final hidden state extraction.\n",
      "Saved best model for RNN_GRU (samples=960) to results_data_size_sweep/20250514_045146/samples_960/RNN_GRU_samples_960_best.pt\n",
      "\n",
      "--- Performing Decodability Analysis for RNN_GRU (samples=960, k=15) ---\n",
      "  Analyzing decodability for RNN_GRU...\n",
      "  Hidden states shape: torch.Size([160, 200, 64])\n",
      "  Coefficients shape: torch.Size([160, 15])\n",
      "  Processed hidden states shape for decoder: torch.Size([160, 64])\n",
      "  RidgeCV Decoder for RNN_GRU - Test MSE: 1.2907, Test R2: 0.3434 (best alpha: 5.4556)\n",
      "  Decodability plot saved to results_data_size_sweep/20250514_045146/samples_960/decodability_RNN_GRU_coeff1.png\n",
      "Decodability (R2 score) for RNN_GRU (samples=960): 0.3434\n",
      "\n",
      "--- Training Transformer (samples=960, k=15) ---\n",
      "Number of parameters: 85809\n",
      "Epoch 1/200, Train Loss: 17.6075, Val Loss: 16.1047\n",
      "  New best validation loss: 16.1047\n",
      "Epoch 2/200, Train Loss: 16.9867, Val Loss: 15.8541\n",
      "  New best validation loss: 15.8541\n",
      "Epoch 3/200, Train Loss: 16.9434, Val Loss: 15.8479\n",
      "  New best validation loss: 15.8479\n",
      "Epoch 4/200, Train Loss: 16.9279, Val Loss: 15.8530\n",
      "Epoch 5/200, Train Loss: 16.9333, Val Loss: 15.9366\n",
      "Epoch 6/200, Train Loss: 16.9347, Val Loss: 15.8015\n",
      "  New best validation loss: 15.8015\n",
      "Epoch 7/200, Train Loss: 16.9288, Val Loss: 15.9003\n",
      "Epoch 8/200, Train Loss: 16.9328, Val Loss: 15.8237\n",
      "Epoch 9/200, Train Loss: 16.9108, Val Loss: 15.7979\n",
      "  New best validation loss: 15.7979\n",
      "Epoch 10/200, Train Loss: 16.8925, Val Loss: 15.8509\n",
      "Epoch 11/200, Train Loss: 16.9049, Val Loss: 15.8039\n",
      "Epoch 12/200, Train Loss: 16.8920, Val Loss: 15.8369\n",
      "Epoch 13/200, Train Loss: 16.9300, Val Loss: 15.8071\n",
      "Epoch 14/200, Train Loss: 16.8982, Val Loss: 15.8207\n",
      "Epoch 15/200, Train Loss: 16.8973, Val Loss: 15.7571\n",
      "  New best validation loss: 15.7571\n",
      "Epoch 16/200, Train Loss: 16.9104, Val Loss: 15.8947\n",
      "Epoch 17/200, Train Loss: 16.9386, Val Loss: 15.7309\n",
      "  New best validation loss: 15.7309\n",
      "Epoch 18/200, Train Loss: 16.8834, Val Loss: 15.7764\n",
      "Epoch 19/200, Train Loss: 16.8992, Val Loss: 15.9535\n",
      "Epoch 20/200, Train Loss: 16.8862, Val Loss: 15.8149\n",
      "Epoch 21/200, Train Loss: 16.8739, Val Loss: 15.7288\n",
      "  New best validation loss: 15.7288\n",
      "Epoch 22/200, Train Loss: 16.8595, Val Loss: 15.7534\n",
      "Epoch 23/200, Train Loss: 16.8618, Val Loss: 15.7044\n",
      "  New best validation loss: 15.7044\n",
      "Epoch 24/200, Train Loss: 16.8442, Val Loss: 15.7685\n",
      "Epoch 25/200, Train Loss: 16.8351, Val Loss: 15.6809\n",
      "  New best validation loss: 15.6809\n",
      "Epoch 26/200, Train Loss: 16.8396, Val Loss: 15.6877\n",
      "Epoch 27/200, Train Loss: 16.8392, Val Loss: 15.6587\n",
      "  New best validation loss: 15.6587\n",
      "Epoch 28/200, Train Loss: 16.8670, Val Loss: 15.6815\n",
      "Epoch 29/200, Train Loss: 16.8226, Val Loss: 15.6685\n",
      "Epoch 30/200, Train Loss: 16.8732, Val Loss: 15.8450\n",
      "Epoch 31/200, Train Loss: 16.8297, Val Loss: 15.6556\n",
      "  New best validation loss: 15.6556\n",
      "Epoch 32/200, Train Loss: 16.8070, Val Loss: 15.6806\n",
      "Epoch 33/200, Train Loss: 16.7978, Val Loss: 15.6705\n",
      "Epoch 34/200, Train Loss: 16.7936, Val Loss: 15.5929\n",
      "  New best validation loss: 15.5929\n",
      "Epoch 35/200, Train Loss: 16.7999, Val Loss: 15.5874\n",
      "  New best validation loss: 15.5874\n",
      "Epoch 36/200, Train Loss: 16.7818, Val Loss: 15.6581\n",
      "Epoch 37/200, Train Loss: 16.7685, Val Loss: 15.6278\n",
      "Epoch 38/200, Train Loss: 16.7417, Val Loss: 15.6645\n",
      "Epoch 39/200, Train Loss: 16.7859, Val Loss: 15.5150\n",
      "  New best validation loss: 15.5150\n",
      "Epoch 40/200, Train Loss: 16.7330, Val Loss: 15.6106\n",
      "Epoch 41/200, Train Loss: 16.7292, Val Loss: 15.4600\n",
      "  New best validation loss: 15.4600\n",
      "Epoch 42/200, Train Loss: 16.6989, Val Loss: 15.3966\n",
      "  New best validation loss: 15.3966\n",
      "Epoch 43/200, Train Loss: 16.6194, Val Loss: 15.3421\n",
      "  New best validation loss: 15.3421\n",
      "Epoch 44/200, Train Loss: 16.6516, Val Loss: 15.4206\n",
      "Epoch 45/200, Train Loss: 16.6104, Val Loss: 15.3884\n",
      "Epoch 46/200, Train Loss: 16.5539, Val Loss: 15.3422\n",
      "Epoch 47/200, Train Loss: 16.4989, Val Loss: 15.1279\n",
      "  New best validation loss: 15.1279\n",
      "Epoch 48/200, Train Loss: 16.3857, Val Loss: 15.0146\n",
      "  New best validation loss: 15.0146\n",
      "Epoch 49/200, Train Loss: 16.2827, Val Loss: 14.7531\n",
      "  New best validation loss: 14.7531\n",
      "Epoch 50/200, Train Loss: 16.2243, Val Loss: 15.0683\n",
      "Epoch 51/200, Train Loss: 16.0947, Val Loss: 14.2470\n",
      "  New best validation loss: 14.2470\n",
      "Epoch 52/200, Train Loss: 15.9212, Val Loss: 14.3272\n",
      "Epoch 53/200, Train Loss: 15.7837, Val Loss: 13.7938\n",
      "  New best validation loss: 13.7938\n",
      "Epoch 54/200, Train Loss: 15.6016, Val Loss: 14.0160\n",
      "Epoch 55/200, Train Loss: 15.5124, Val Loss: 13.7063\n",
      "  New best validation loss: 13.7063\n",
      "Epoch 56/200, Train Loss: 15.4735, Val Loss: 13.5766\n",
      "  New best validation loss: 13.5766\n",
      "Epoch 57/200, Train Loss: 15.2499, Val Loss: 13.5505\n",
      "  New best validation loss: 13.5505\n",
      "Epoch 58/200, Train Loss: 15.2262, Val Loss: 13.3708\n",
      "  New best validation loss: 13.3708\n",
      "Epoch 59/200, Train Loss: 15.0931, Val Loss: 13.3798\n",
      "Epoch 60/200, Train Loss: 14.9427, Val Loss: 13.0506\n",
      "  New best validation loss: 13.0506\n",
      "Epoch 61/200, Train Loss: 14.8106, Val Loss: 13.0891\n",
      "Epoch 62/200, Train Loss: 14.7343, Val Loss: 12.8876\n",
      "  New best validation loss: 12.8876\n",
      "Epoch 63/200, Train Loss: 14.7138, Val Loss: 12.7862\n",
      "  New best validation loss: 12.7862\n",
      "Epoch 64/200, Train Loss: 14.4957, Val Loss: 12.8189\n",
      "Epoch 65/200, Train Loss: 14.3466, Val Loss: 12.3142\n",
      "  New best validation loss: 12.3142\n",
      "Epoch 66/200, Train Loss: 14.2837, Val Loss: 12.2511\n",
      "  New best validation loss: 12.2511\n",
      "Epoch 67/200, Train Loss: 14.1178, Val Loss: 12.4784\n",
      "Epoch 68/200, Train Loss: 13.8667, Val Loss: 11.8836\n",
      "  New best validation loss: 11.8836\n",
      "Epoch 69/200, Train Loss: 13.7312, Val Loss: 11.8852\n",
      "Epoch 70/200, Train Loss: 13.5944, Val Loss: 11.6297\n",
      "  New best validation loss: 11.6297\n",
      "Epoch 71/200, Train Loss: 13.4337, Val Loss: 11.8994\n",
      "Epoch 72/200, Train Loss: 13.2583, Val Loss: 11.5949\n",
      "  New best validation loss: 11.5949\n",
      "Epoch 73/200, Train Loss: 13.1727, Val Loss: 11.5633\n",
      "  New best validation loss: 11.5633\n",
      "Epoch 74/200, Train Loss: 13.0107, Val Loss: 11.4919\n",
      "  New best validation loss: 11.4919\n",
      "Epoch 75/200, Train Loss: 12.8917, Val Loss: 11.2673\n",
      "  New best validation loss: 11.2673\n",
      "Epoch 76/200, Train Loss: 12.7901, Val Loss: 11.1690\n",
      "  New best validation loss: 11.1690\n",
      "Epoch 77/200, Train Loss: 12.7125, Val Loss: 11.1495\n",
      "  New best validation loss: 11.1495\n",
      "Epoch 78/200, Train Loss: 12.6453, Val Loss: 11.3055\n",
      "Epoch 79/200, Train Loss: 12.5657, Val Loss: 10.9427\n",
      "  New best validation loss: 10.9427\n",
      "Epoch 80/200, Train Loss: 12.4623, Val Loss: 11.2075\n",
      "Epoch 81/200, Train Loss: 12.5038, Val Loss: 10.8664\n",
      "  New best validation loss: 10.8664\n",
      "Epoch 82/200, Train Loss: 12.4831, Val Loss: 11.0046\n",
      "Epoch 83/200, Train Loss: 12.3860, Val Loss: 11.1822\n",
      "Epoch 84/200, Train Loss: 12.4649, Val Loss: 11.1217\n",
      "Epoch 85/200, Train Loss: 12.2887, Val Loss: 10.8122\n",
      "  New best validation loss: 10.8122\n",
      "Epoch 86/200, Train Loss: 12.1952, Val Loss: 10.8028\n",
      "  New best validation loss: 10.8028\n",
      "Epoch 87/200, Train Loss: 12.2818, Val Loss: 10.8538\n",
      "Epoch 88/200, Train Loss: 12.1926, Val Loss: 10.7791\n",
      "  New best validation loss: 10.7791\n",
      "Epoch 89/200, Train Loss: 12.1915, Val Loss: 11.0099\n",
      "Epoch 90/200, Train Loss: 12.1713, Val Loss: 10.7657\n",
      "  New best validation loss: 10.7657\n",
      "Epoch 91/200, Train Loss: 12.0983, Val Loss: 10.7135\n",
      "  New best validation loss: 10.7135\n",
      "Epoch 92/200, Train Loss: 12.0586, Val Loss: 10.8319\n",
      "Epoch 93/200, Train Loss: 12.1051, Val Loss: 10.8743\n",
      "Epoch 94/200, Train Loss: 12.1194, Val Loss: 11.1346\n",
      "Epoch 95/200, Train Loss: 12.1347, Val Loss: 10.7651\n",
      "Epoch 96/200, Train Loss: 12.0117, Val Loss: 10.7011\n",
      "  New best validation loss: 10.7011\n",
      "Epoch 97/200, Train Loss: 11.9760, Val Loss: 10.5009\n",
      "  New best validation loss: 10.5009\n",
      "Epoch 98/200, Train Loss: 11.9147, Val Loss: 10.5751\n",
      "Epoch 99/200, Train Loss: 11.9269, Val Loss: 10.6794\n",
      "Epoch 100/200, Train Loss: 11.8242, Val Loss: 10.4157\n",
      "  New best validation loss: 10.4157\n",
      "Epoch 101/200, Train Loss: 11.8680, Val Loss: 10.7176\n",
      "Epoch 102/200, Train Loss: 11.8689, Val Loss: 10.4333\n",
      "Epoch 103/200, Train Loss: 11.7838, Val Loss: 10.7195\n",
      "Epoch 104/200, Train Loss: 11.7907, Val Loss: 10.6550\n",
      "Epoch 105/200, Train Loss: 11.7523, Val Loss: 10.5925\n",
      "Epoch 106/200, Train Loss: 11.7219, Val Loss: 10.4689\n",
      "Epoch 107/200, Train Loss: 11.7023, Val Loss: 10.3996\n",
      "  New best validation loss: 10.3996\n",
      "Epoch 108/200, Train Loss: 11.6503, Val Loss: 10.4525\n",
      "Epoch 109/200, Train Loss: 11.6945, Val Loss: 10.4252\n",
      "Epoch 110/200, Train Loss: 11.7638, Val Loss: 10.4599\n",
      "Epoch 111/200, Train Loss: 11.7687, Val Loss: 10.4364\n",
      "Epoch 112/200, Train Loss: 11.7307, Val Loss: 10.5274\n",
      "Epoch 113/200, Train Loss: 11.6448, Val Loss: 10.3895\n",
      "  New best validation loss: 10.3895\n",
      "Epoch 114/200, Train Loss: 11.6513, Val Loss: 10.6316\n",
      "Epoch 115/200, Train Loss: 11.5908, Val Loss: 10.4289\n",
      "Epoch 116/200, Train Loss: 11.5647, Val Loss: 10.4081\n",
      "Epoch 117/200, Train Loss: 11.5509, Val Loss: 10.3053\n",
      "  New best validation loss: 10.3053\n",
      "Epoch 118/200, Train Loss: 11.6176, Val Loss: 10.3809\n",
      "Epoch 119/200, Train Loss: 11.5106, Val Loss: 10.6046\n",
      "Epoch 120/200, Train Loss: 11.5698, Val Loss: 10.4799\n",
      "Epoch 121/200, Train Loss: 11.5423, Val Loss: 10.5082\n",
      "Epoch 122/200, Train Loss: 11.5062, Val Loss: 10.3945\n",
      "Epoch 123/200, Train Loss: 11.5486, Val Loss: 10.4961\n",
      "Epoch 124/200, Train Loss: 11.4903, Val Loss: 10.4576\n",
      "Epoch 125/200, Train Loss: 11.4589, Val Loss: 10.3532\n",
      "Epoch 126/200, Train Loss: 11.4453, Val Loss: 10.4792\n",
      "Epoch 127/200, Train Loss: 11.4814, Val Loss: 10.3035\n",
      "  New best validation loss: 10.3035\n",
      "Epoch 128/200, Train Loss: 11.4144, Val Loss: 10.3897\n",
      "Epoch 129/200, Train Loss: 11.4146, Val Loss: 10.5684\n",
      "Epoch 130/200, Train Loss: 11.4400, Val Loss: 10.5608\n",
      "Epoch 131/200, Train Loss: 11.4157, Val Loss: 10.1967\n",
      "  New best validation loss: 10.1967\n",
      "Epoch 132/200, Train Loss: 11.4159, Val Loss: 10.5165\n",
      "Epoch 133/200, Train Loss: 11.3755, Val Loss: 10.2798\n",
      "Epoch 134/200, Train Loss: 11.3925, Val Loss: 10.3104\n",
      "Epoch 135/200, Train Loss: 11.4201, Val Loss: 10.3919\n",
      "Epoch 136/200, Train Loss: 11.3949, Val Loss: 10.4933\n",
      "Epoch 137/200, Train Loss: 11.4284, Val Loss: 10.3502\n",
      "Epoch 138/200, Train Loss: 11.4250, Val Loss: 10.2508\n",
      "Epoch 139/200, Train Loss: 11.3076, Val Loss: 10.3224\n",
      "Epoch 140/200, Train Loss: 11.3274, Val Loss: 10.2571\n",
      "Epoch 141/200, Train Loss: 11.2966, Val Loss: 10.2631\n",
      "Epoch 142/200, Train Loss: 11.3845, Val Loss: 10.5619\n",
      "Epoch 143/200, Train Loss: 11.4138, Val Loss: 10.3814\n",
      "Epoch 144/200, Train Loss: 11.2648, Val Loss: 10.1671\n",
      "  New best validation loss: 10.1671\n",
      "Epoch 145/200, Train Loss: 11.2316, Val Loss: 10.5025\n",
      "Epoch 146/200, Train Loss: 11.2852, Val Loss: 10.4647\n",
      "Epoch 147/200, Train Loss: 11.3295, Val Loss: 10.4949\n",
      "Epoch 148/200, Train Loss: 11.2311, Val Loss: 10.1930\n",
      "Epoch 149/200, Train Loss: 11.2239, Val Loss: 10.2902\n",
      "Epoch 150/200, Train Loss: 11.2458, Val Loss: 10.2124\n",
      "Epoch 151/200, Train Loss: 11.2242, Val Loss: 10.2767\n",
      "Epoch 152/200, Train Loss: 11.2054, Val Loss: 10.3460\n",
      "Epoch 153/200, Train Loss: 11.3426, Val Loss: 10.2984\n",
      "Epoch 154/200, Train Loss: 11.2844, Val Loss: 10.3721\n",
      "Epoch 155/200, Train Loss: 11.2032, Val Loss: 10.2296\n",
      "Epoch 156/200, Train Loss: 11.2106, Val Loss: 10.3351\n",
      "Epoch 157/200, Train Loss: 11.2188, Val Loss: 10.3149\n",
      "Epoch 158/200, Train Loss: 11.2747, Val Loss: 10.3354\n",
      "Epoch 159/200, Train Loss: 11.1482, Val Loss: 10.2389\n",
      "Epoch 160/200, Train Loss: 11.2070, Val Loss: 10.3438\n",
      "Epoch 161/200, Train Loss: 11.2011, Val Loss: 10.3431\n",
      "Epoch 162/200, Train Loss: 11.1931, Val Loss: 10.1469\n",
      "  New best validation loss: 10.1469\n",
      "Epoch 163/200, Train Loss: 11.1317, Val Loss: 10.2060\n",
      "Epoch 164/200, Train Loss: 11.1442, Val Loss: 10.3298\n",
      "Epoch 165/200, Train Loss: 11.1935, Val Loss: 10.2403\n",
      "Epoch 166/200, Train Loss: 11.1750, Val Loss: 10.0506\n",
      "  New best validation loss: 10.0506\n",
      "Epoch 167/200, Train Loss: 11.1146, Val Loss: 10.2465\n",
      "Epoch 168/200, Train Loss: 11.1872, Val Loss: 10.1695\n",
      "Epoch 169/200, Train Loss: 11.1837, Val Loss: 10.1257\n",
      "Epoch 170/200, Train Loss: 11.1433, Val Loss: 10.2435\n",
      "Epoch 171/200, Train Loss: 11.2495, Val Loss: 10.2002\n",
      "Epoch 172/200, Train Loss: 11.1731, Val Loss: 10.1214\n",
      "Epoch 173/200, Train Loss: 11.1568, Val Loss: 10.0909\n",
      "Epoch 174/200, Train Loss: 11.1364, Val Loss: 10.2074\n",
      "Epoch 175/200, Train Loss: 11.1622, Val Loss: 10.1429\n",
      "Epoch 176/200, Train Loss: 11.1003, Val Loss: 10.1854\n",
      "Epoch 177/200, Train Loss: 11.1445, Val Loss: 10.0680\n",
      "Epoch 178/200, Train Loss: 11.1182, Val Loss: 10.2901\n",
      "Epoch 179/200, Train Loss: 11.0343, Val Loss: 10.0974\n",
      "Epoch 180/200, Train Loss: 11.0290, Val Loss: 9.9843\n",
      "  New best validation loss: 9.9843\n",
      "Epoch 181/200, Train Loss: 11.1039, Val Loss: 10.1170\n",
      "Epoch 182/200, Train Loss: 11.1236, Val Loss: 10.0534\n",
      "Epoch 183/200, Train Loss: 11.1125, Val Loss: 10.2672\n",
      "Epoch 184/200, Train Loss: 11.0504, Val Loss: 10.1223\n",
      "Epoch 185/200, Train Loss: 11.0473, Val Loss: 10.3995\n",
      "Epoch 186/200, Train Loss: 11.0840, Val Loss: 10.1631\n",
      "Epoch 187/200, Train Loss: 11.1165, Val Loss: 10.0357\n",
      "Epoch 188/200, Train Loss: 11.0691, Val Loss: 9.9769\n",
      "  New best validation loss: 9.9769\n",
      "Epoch 189/200, Train Loss: 11.0212, Val Loss: 10.1775\n",
      "Epoch 190/200, Train Loss: 11.0481, Val Loss: 10.1365\n",
      "Epoch 191/200, Train Loss: 11.0033, Val Loss: 10.0613\n",
      "Epoch 192/200, Train Loss: 11.0057, Val Loss: 10.0320\n",
      "Epoch 193/200, Train Loss: 11.1293, Val Loss: 10.2217\n",
      "Epoch 194/200, Train Loss: 11.0703, Val Loss: 10.0117\n",
      "Epoch 195/200, Train Loss: 11.0478, Val Loss: 10.1285\n",
      "Epoch 196/200, Train Loss: 11.1017, Val Loss: 10.6554\n",
      "Epoch 197/200, Train Loss: 11.1135, Val Loss: 10.2358\n",
      "Epoch 198/200, Train Loss: 11.0185, Val Loss: 10.0525\n",
      "Epoch 199/200, Train Loss: 10.9644, Val Loss: 9.9783\n",
      "Epoch 200/200, Train Loss: 11.0116, Val Loss: 10.0549\n",
      "\n",
      "Loaded best model (Val Loss: 9.9769) for final hidden state extraction.\n",
      "Saved best model for Transformer (samples=960) to results_data_size_sweep/20250514_045146/samples_960/Transformer_samples_960_best.pt\n",
      "\n",
      "--- Performing Decodability Analysis for Transformer (samples=960, k=15) ---\n",
      "  Analyzing decodability for Transformer...\n",
      "  Hidden states shape: torch.Size([160, 200, 20])\n",
      "  Coefficients shape: torch.Size([160, 15])\n",
      "  Processed hidden states shape for decoder: torch.Size([160, 20])\n",
      "  RidgeCV Decoder for Transformer - Test MSE: 1.1629, Test R2: 0.4126 (best alpha: 0.0695)\n",
      "  Decodability plot saved to results_data_size_sweep/20250514_045146/samples_960/decodability_Transformer_coeff1.png\n",
      "Decodability (R2 score) for Transformer (samples=960): 0.4126\n",
      "\n",
      "--- Training TransformerCausal (samples=960, k=15) ---\n",
      "Number of parameters: 85809\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/conda/lib/python3.10/site-packages/torch/nn/modules/activation.py:1160: UserWarning: Converting mask without torch.bool dtype to bool; this will negatively affect performance. Prefer to use a boolean mask directly. (Triggered internally at /opt/conda/conda-bld/pytorch_1682343995026/work/aten/src/ATen/native/transformers/attention.cpp:150.)\n",
      "  return torch._native_multi_head_attention(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/200, Train Loss: 17.4988, Val Loss: 15.8470\n",
      "  New best validation loss: 15.8470\n",
      "Epoch 2/200, Train Loss: 16.9067, Val Loss: 16.0043\n",
      "Epoch 3/200, Train Loss: 16.8903, Val Loss: 15.8103\n",
      "  New best validation loss: 15.8103\n",
      "Epoch 4/200, Train Loss: 16.8993, Val Loss: 15.8555\n",
      "Epoch 5/200, Train Loss: 16.8764, Val Loss: 15.7707\n",
      "  New best validation loss: 15.7707\n",
      "Epoch 6/200, Train Loss: 16.8679, Val Loss: 15.8441\n",
      "Epoch 7/200, Train Loss: 16.8536, Val Loss: 15.8548\n",
      "Epoch 8/200, Train Loss: 16.8495, Val Loss: 15.8400\n",
      "Epoch 9/200, Train Loss: 16.8271, Val Loss: 15.7375\n",
      "  New best validation loss: 15.7375\n",
      "Epoch 10/200, Train Loss: 16.8216, Val Loss: 15.6948\n",
      "  New best validation loss: 15.6948\n",
      "Epoch 11/200, Train Loss: 16.8251, Val Loss: 15.8299\n",
      "Epoch 12/200, Train Loss: 16.7991, Val Loss: 15.8434\n",
      "Epoch 13/200, Train Loss: 16.7997, Val Loss: 15.9512\n",
      "Epoch 14/200, Train Loss: 16.7874, Val Loss: 15.7064\n",
      "Epoch 15/200, Train Loss: 16.8060, Val Loss: 15.7737\n",
      "Epoch 16/200, Train Loss: 16.7676, Val Loss: 15.7164\n",
      "Epoch 17/200, Train Loss: 16.7859, Val Loss: 15.7443\n",
      "Epoch 18/200, Train Loss: 16.7793, Val Loss: 15.7842\n",
      "Epoch 19/200, Train Loss: 16.7396, Val Loss: 15.7559\n",
      "Epoch 20/200, Train Loss: 16.7525, Val Loss: 15.7966\n",
      "Epoch 21/200, Train Loss: 16.7417, Val Loss: 15.8243\n",
      "Epoch 22/200, Train Loss: 16.7585, Val Loss: 15.8147\n",
      "Epoch 23/200, Train Loss: 16.7417, Val Loss: 15.6709\n",
      "  New best validation loss: 15.6709\n",
      "Epoch 24/200, Train Loss: 16.7399, Val Loss: 15.8487\n",
      "Epoch 25/200, Train Loss: 16.7209, Val Loss: 15.7117\n",
      "Epoch 26/200, Train Loss: 16.7339, Val Loss: 15.6463\n",
      "  New best validation loss: 15.6463\n",
      "Epoch 27/200, Train Loss: 16.6932, Val Loss: 15.7019\n",
      "Epoch 28/200, Train Loss: 16.6916, Val Loss: 15.8410\n",
      "Epoch 29/200, Train Loss: 16.7266, Val Loss: 15.6999\n",
      "Epoch 30/200, Train Loss: 16.6978, Val Loss: 15.6868\n",
      "Epoch 31/200, Train Loss: 16.6760, Val Loss: 15.6500\n",
      "Epoch 32/200, Train Loss: 16.6805, Val Loss: 15.6750\n",
      "Epoch 33/200, Train Loss: 16.7073, Val Loss: 15.7101\n",
      "Epoch 34/200, Train Loss: 16.7093, Val Loss: 15.6000\n",
      "  New best validation loss: 15.6000\n",
      "Epoch 35/200, Train Loss: 16.6548, Val Loss: 15.8153\n",
      "Epoch 36/200, Train Loss: 16.7056, Val Loss: 15.7187\n",
      "Epoch 37/200, Train Loss: 16.6500, Val Loss: 15.6158\n",
      "Epoch 38/200, Train Loss: 16.6383, Val Loss: 15.6843\n",
      "Epoch 39/200, Train Loss: 16.6328, Val Loss: 15.6182\n",
      "Epoch 40/200, Train Loss: 16.6372, Val Loss: 15.6019\n",
      "Epoch 41/200, Train Loss: 16.6277, Val Loss: 15.6365\n",
      "Epoch 42/200, Train Loss: 16.6010, Val Loss: 15.5133\n",
      "  New best validation loss: 15.5133\n",
      "Epoch 43/200, Train Loss: 16.6305, Val Loss: 15.5931\n",
      "Epoch 44/200, Train Loss: 16.5839, Val Loss: 15.4592\n",
      "  New best validation loss: 15.4592\n",
      "Epoch 45/200, Train Loss: 16.5626, Val Loss: 15.4217\n",
      "  New best validation loss: 15.4217\n",
      "Epoch 46/200, Train Loss: 16.5451, Val Loss: 15.5245\n",
      "Epoch 47/200, Train Loss: 16.5738, Val Loss: 15.4750\n",
      "Epoch 48/200, Train Loss: 16.5478, Val Loss: 15.3948\n",
      "  New best validation loss: 15.3948\n",
      "Epoch 49/200, Train Loss: 16.5496, Val Loss: 15.4186\n",
      "Epoch 50/200, Train Loss: 16.5077, Val Loss: 15.3936\n",
      "  New best validation loss: 15.3936\n",
      "Epoch 51/200, Train Loss: 16.5164, Val Loss: 15.3116\n",
      "  New best validation loss: 15.3116\n",
      "Epoch 52/200, Train Loss: 16.4775, Val Loss: 15.3394\n",
      "Epoch 53/200, Train Loss: 16.4723, Val Loss: 15.3410\n",
      "Epoch 54/200, Train Loss: 16.4965, Val Loss: 15.4334\n",
      "Epoch 55/200, Train Loss: 16.4304, Val Loss: 15.2898\n",
      "  New best validation loss: 15.2898\n",
      "Epoch 56/200, Train Loss: 16.4278, Val Loss: 15.3230\n",
      "Epoch 57/200, Train Loss: 16.4419, Val Loss: 15.2309\n",
      "  New best validation loss: 15.2309\n",
      "Epoch 58/200, Train Loss: 16.4382, Val Loss: 15.3349\n",
      "Epoch 59/200, Train Loss: 16.4344, Val Loss: 15.2147\n",
      "  New best validation loss: 15.2147\n",
      "Epoch 60/200, Train Loss: 16.3790, Val Loss: 15.1955\n",
      "  New best validation loss: 15.1955\n",
      "Epoch 61/200, Train Loss: 16.3460, Val Loss: 15.1938\n",
      "  New best validation loss: 15.1938\n",
      "Epoch 62/200, Train Loss: 16.3211, Val Loss: 15.1208\n",
      "  New best validation loss: 15.1208\n",
      "Epoch 63/200, Train Loss: 16.2849, Val Loss: 15.1049\n",
      "  New best validation loss: 15.1049\n",
      "Epoch 64/200, Train Loss: 16.2502, Val Loss: 15.2592\n",
      "Epoch 65/200, Train Loss: 16.3054, Val Loss: 15.1593\n",
      "Epoch 66/200, Train Loss: 16.2215, Val Loss: 15.0445\n",
      "  New best validation loss: 15.0445\n",
      "Epoch 67/200, Train Loss: 16.2335, Val Loss: 15.0360\n",
      "  New best validation loss: 15.0360\n",
      "Epoch 68/200, Train Loss: 16.2026, Val Loss: 15.0614\n",
      "Epoch 69/200, Train Loss: 16.1402, Val Loss: 15.0883\n",
      "Epoch 70/200, Train Loss: 16.1636, Val Loss: 15.0283\n",
      "  New best validation loss: 15.0283\n",
      "Epoch 71/200, Train Loss: 16.0949, Val Loss: 15.0680\n",
      "Epoch 72/200, Train Loss: 16.1319, Val Loss: 14.9223\n",
      "  New best validation loss: 14.9223\n",
      "Epoch 73/200, Train Loss: 16.0435, Val Loss: 14.9071\n",
      "  New best validation loss: 14.9071\n",
      "Epoch 74/200, Train Loss: 15.9600, Val Loss: 14.8250\n",
      "  New best validation loss: 14.8250\n",
      "Epoch 75/200, Train Loss: 15.9240, Val Loss: 14.7918\n",
      "  New best validation loss: 14.7918\n",
      "Epoch 76/200, Train Loss: 15.9292, Val Loss: 14.8115\n",
      "Epoch 77/200, Train Loss: 15.7936, Val Loss: 15.0471\n",
      "Epoch 78/200, Train Loss: 15.8805, Val Loss: 14.8628\n",
      "Epoch 79/200, Train Loss: 15.7695, Val Loss: 14.6282\n",
      "  New best validation loss: 14.6282\n",
      "Epoch 80/200, Train Loss: 15.6880, Val Loss: 14.5844\n",
      "  New best validation loss: 14.5844\n",
      "Epoch 81/200, Train Loss: 15.6477, Val Loss: 14.5752\n",
      "  New best validation loss: 14.5752\n",
      "Epoch 82/200, Train Loss: 15.5515, Val Loss: 14.5726\n",
      "  New best validation loss: 14.5726\n",
      "Epoch 83/200, Train Loss: 15.5237, Val Loss: 14.7499\n",
      "Epoch 84/200, Train Loss: 15.4897, Val Loss: 14.4874\n",
      "  New best validation loss: 14.4874\n",
      "Epoch 85/200, Train Loss: 15.4918, Val Loss: 14.4913\n",
      "Epoch 86/200, Train Loss: 15.4245, Val Loss: 14.3407\n",
      "  New best validation loss: 14.3407\n",
      "Epoch 87/200, Train Loss: 15.3103, Val Loss: 14.1886\n",
      "  New best validation loss: 14.1886\n",
      "Epoch 88/200, Train Loss: 15.2830, Val Loss: 14.0986\n",
      "  New best validation loss: 14.0986\n",
      "Epoch 89/200, Train Loss: 15.1795, Val Loss: 14.1311\n",
      "Epoch 90/200, Train Loss: 15.1228, Val Loss: 14.2590\n",
      "Epoch 91/200, Train Loss: 15.1148, Val Loss: 13.9494\n",
      "  New best validation loss: 13.9494\n",
      "Epoch 92/200, Train Loss: 14.9732, Val Loss: 13.8031\n",
      "  New best validation loss: 13.8031\n",
      "Epoch 93/200, Train Loss: 14.9441, Val Loss: 13.8460\n",
      "Epoch 94/200, Train Loss: 14.9092, Val Loss: 13.8650\n",
      "Epoch 95/200, Train Loss: 14.8890, Val Loss: 13.7656\n",
      "  New best validation loss: 13.7656\n",
      "Epoch 96/200, Train Loss: 14.7539, Val Loss: 13.8355\n",
      "Epoch 97/200, Train Loss: 14.7672, Val Loss: 13.8051\n",
      "Epoch 98/200, Train Loss: 14.7780, Val Loss: 13.6429\n",
      "  New best validation loss: 13.6429\n",
      "Epoch 99/200, Train Loss: 14.7283, Val Loss: 13.6068\n",
      "  New best validation loss: 13.6068\n",
      "Epoch 100/200, Train Loss: 14.6208, Val Loss: 13.4958\n",
      "  New best validation loss: 13.4958\n",
      "Epoch 101/200, Train Loss: 14.5548, Val Loss: 13.6095\n",
      "Epoch 102/200, Train Loss: 14.5387, Val Loss: 13.4008\n",
      "  New best validation loss: 13.4008\n",
      "Epoch 103/200, Train Loss: 14.5103, Val Loss: 13.3397\n",
      "  New best validation loss: 13.3397\n",
      "Epoch 104/200, Train Loss: 14.5175, Val Loss: 13.3050\n",
      "  New best validation loss: 13.3050\n",
      "Epoch 105/200, Train Loss: 14.4466, Val Loss: 13.3600\n",
      "Epoch 106/200, Train Loss: 14.3948, Val Loss: 13.3440\n",
      "Epoch 107/200, Train Loss: 14.3627, Val Loss: 13.3565\n",
      "Epoch 108/200, Train Loss: 14.3771, Val Loss: 13.1140\n",
      "  New best validation loss: 13.1140\n",
      "Epoch 109/200, Train Loss: 14.2507, Val Loss: 13.2578\n",
      "Epoch 110/200, Train Loss: 14.3048, Val Loss: 13.2046\n",
      "Epoch 111/200, Train Loss: 14.1986, Val Loss: 13.0534\n",
      "  New best validation loss: 13.0534\n",
      "Epoch 112/200, Train Loss: 14.2469, Val Loss: 13.0358\n",
      "  New best validation loss: 13.0358\n",
      "Epoch 113/200, Train Loss: 14.2620, Val Loss: 13.1337\n",
      "Epoch 114/200, Train Loss: 14.2288, Val Loss: 13.0083\n",
      "  New best validation loss: 13.0083\n",
      "Epoch 115/200, Train Loss: 14.1635, Val Loss: 12.9923\n",
      "  New best validation loss: 12.9923\n",
      "Epoch 116/200, Train Loss: 14.1745, Val Loss: 12.9646\n",
      "  New best validation loss: 12.9646\n",
      "Epoch 117/200, Train Loss: 14.1124, Val Loss: 12.9586\n",
      "  New best validation loss: 12.9586\n",
      "Epoch 118/200, Train Loss: 14.1071, Val Loss: 13.0171\n",
      "Epoch 119/200, Train Loss: 14.2387, Val Loss: 13.1466\n",
      "Epoch 120/200, Train Loss: 14.1509, Val Loss: 12.8781\n",
      "  New best validation loss: 12.8781\n",
      "Epoch 121/200, Train Loss: 14.0691, Val Loss: 12.8598\n",
      "  New best validation loss: 12.8598\n",
      "Epoch 122/200, Train Loss: 14.0439, Val Loss: 12.8580\n",
      "  New best validation loss: 12.8580\n",
      "Epoch 123/200, Train Loss: 14.0555, Val Loss: 12.9690\n",
      "Epoch 124/200, Train Loss: 14.0117, Val Loss: 12.9486\n",
      "Epoch 125/200, Train Loss: 14.0185, Val Loss: 12.9028\n",
      "Epoch 126/200, Train Loss: 14.0557, Val Loss: 12.8784\n",
      "Epoch 127/200, Train Loss: 13.9518, Val Loss: 12.8440\n",
      "  New best validation loss: 12.8440\n",
      "Epoch 128/200, Train Loss: 13.9945, Val Loss: 12.9030\n",
      "Epoch 129/200, Train Loss: 13.9403, Val Loss: 12.8143\n",
      "  New best validation loss: 12.8143\n",
      "Epoch 130/200, Train Loss: 13.9446, Val Loss: 12.8059\n",
      "  New best validation loss: 12.8059\n",
      "Epoch 131/200, Train Loss: 13.9221, Val Loss: 12.8032\n",
      "  New best validation loss: 12.8032\n",
      "Epoch 132/200, Train Loss: 13.9224, Val Loss: 12.8802\n",
      "Epoch 133/200, Train Loss: 13.9270, Val Loss: 12.8687\n",
      "Epoch 134/200, Train Loss: 13.9051, Val Loss: 12.8161\n",
      "Epoch 135/200, Train Loss: 13.8869, Val Loss: 12.8819\n",
      "Epoch 136/200, Train Loss: 13.8739, Val Loss: 12.7420\n",
      "  New best validation loss: 12.7420\n",
      "Epoch 137/200, Train Loss: 13.8925, Val Loss: 12.9262\n",
      "Epoch 138/200, Train Loss: 13.9227, Val Loss: 12.7840\n",
      "Epoch 139/200, Train Loss: 13.8428, Val Loss: 12.7297\n",
      "  New best validation loss: 12.7297\n",
      "Epoch 140/200, Train Loss: 13.8223, Val Loss: 12.7937\n",
      "Epoch 141/200, Train Loss: 13.8167, Val Loss: 12.8589\n",
      "Epoch 142/200, Train Loss: 13.8560, Val Loss: 12.7229\n",
      "  New best validation loss: 12.7229\n",
      "Epoch 143/200, Train Loss: 13.8312, Val Loss: 12.7895\n",
      "Epoch 144/200, Train Loss: 13.8695, Val Loss: 12.6686\n",
      "  New best validation loss: 12.6686\n",
      "Epoch 145/200, Train Loss: 13.8154, Val Loss: 12.6772\n",
      "Epoch 146/200, Train Loss: 13.7845, Val Loss: 12.7924\n",
      "Epoch 147/200, Train Loss: 13.7872, Val Loss: 12.6286\n",
      "  New best validation loss: 12.6286\n",
      "Epoch 148/200, Train Loss: 13.8164, Val Loss: 12.6729\n",
      "Epoch 149/200, Train Loss: 13.8339, Val Loss: 12.6302\n",
      "Epoch 150/200, Train Loss: 13.8039, Val Loss: 12.6742\n",
      "Epoch 151/200, Train Loss: 13.7716, Val Loss: 12.6915\n",
      "Epoch 152/200, Train Loss: 13.7687, Val Loss: 12.6979\n",
      "Epoch 153/200, Train Loss: 13.8379, Val Loss: 12.6529\n",
      "Epoch 154/200, Train Loss: 13.7767, Val Loss: 12.7894\n",
      "Epoch 155/200, Train Loss: 13.7887, Val Loss: 12.6513\n",
      "Epoch 156/200, Train Loss: 13.7466, Val Loss: 12.6077\n",
      "  New best validation loss: 12.6077\n",
      "Epoch 157/200, Train Loss: 13.7662, Val Loss: 12.6819\n",
      "Epoch 158/200, Train Loss: 13.7679, Val Loss: 12.7025\n",
      "Epoch 159/200, Train Loss: 13.7778, Val Loss: 12.5768\n",
      "  New best validation loss: 12.5768\n",
      "Epoch 160/200, Train Loss: 13.7731, Val Loss: 12.6502\n",
      "Epoch 161/200, Train Loss: 13.7674, Val Loss: 12.6981\n",
      "Epoch 162/200, Train Loss: 13.7327, Val Loss: 12.6448\n",
      "Epoch 163/200, Train Loss: 13.7719, Val Loss: 12.7043\n",
      "Epoch 164/200, Train Loss: 13.7364, Val Loss: 12.6728\n",
      "Epoch 165/200, Train Loss: 13.7320, Val Loss: 12.6294\n",
      "Epoch 166/200, Train Loss: 13.6902, Val Loss: 12.5908\n",
      "Epoch 167/200, Train Loss: 13.7051, Val Loss: 12.6452\n",
      "Epoch 168/200, Train Loss: 13.7535, Val Loss: 12.6646\n",
      "Epoch 169/200, Train Loss: 13.7485, Val Loss: 12.6327\n",
      "Epoch 170/200, Train Loss: 13.7355, Val Loss: 12.8120\n",
      "Epoch 171/200, Train Loss: 13.6656, Val Loss: 12.7249\n",
      "Epoch 172/200, Train Loss: 13.7360, Val Loss: 12.7031\n",
      "Epoch 173/200, Train Loss: 13.7082, Val Loss: 12.5925\n",
      "Epoch 174/200, Train Loss: 13.6749, Val Loss: 12.5784\n",
      "Epoch 175/200, Train Loss: 13.7209, Val Loss: 12.6532\n",
      "Epoch 176/200, Train Loss: 13.7322, Val Loss: 12.6414\n",
      "Epoch 177/200, Train Loss: 13.6478, Val Loss: 12.7262\n",
      "Epoch 178/200, Train Loss: 13.7342, Val Loss: 12.5736\n",
      "  New best validation loss: 12.5736\n",
      "Epoch 179/200, Train Loss: 13.7709, Val Loss: 12.6023\n",
      "Epoch 180/200, Train Loss: 13.7046, Val Loss: 12.6097\n",
      "Epoch 181/200, Train Loss: 13.7542, Val Loss: 12.5444\n",
      "  New best validation loss: 12.5444\n",
      "Epoch 182/200, Train Loss: 13.6637, Val Loss: 12.6620\n",
      "Epoch 183/200, Train Loss: 13.6517, Val Loss: 12.6453\n",
      "Epoch 184/200, Train Loss: 13.6740, Val Loss: 12.7406\n",
      "Epoch 185/200, Train Loss: 13.6465, Val Loss: 12.6531\n",
      "Epoch 186/200, Train Loss: 13.6283, Val Loss: 12.6300\n",
      "Epoch 187/200, Train Loss: 13.6692, Val Loss: 12.6259\n",
      "Epoch 188/200, Train Loss: 13.6418, Val Loss: 12.6362\n",
      "Epoch 189/200, Train Loss: 13.6178, Val Loss: 12.6196\n",
      "Epoch 190/200, Train Loss: 13.6753, Val Loss: 12.5887\n",
      "Epoch 191/200, Train Loss: 13.6921, Val Loss: 12.5267\n",
      "  New best validation loss: 12.5267\n",
      "Epoch 192/200, Train Loss: 13.6951, Val Loss: 12.5983\n",
      "Epoch 193/200, Train Loss: 13.6979, Val Loss: 12.5414\n",
      "Epoch 194/200, Train Loss: 13.6502, Val Loss: 12.5652\n",
      "Epoch 195/200, Train Loss: 13.6288, Val Loss: 12.6142\n",
      "Epoch 196/200, Train Loss: 13.6002, Val Loss: 12.6042\n",
      "Epoch 197/200, Train Loss: 13.6143, Val Loss: 12.6319\n",
      "Epoch 198/200, Train Loss: 13.7069, Val Loss: 12.8071\n",
      "Epoch 199/200, Train Loss: 13.6598, Val Loss: 12.6217\n",
      "Epoch 200/200, Train Loss: 13.6658, Val Loss: 12.5916\n",
      "\n",
      "Loaded best model (Val Loss: 12.5267) for final hidden state extraction.\n",
      "Saved best model for TransformerCausal (samples=960) to results_data_size_sweep/20250514_045146/samples_960/TransformerCausal_samples_960_best.pt\n",
      "\n",
      "--- Performing Decodability Analysis for TransformerCausal (samples=960, k=15) ---\n",
      "  Analyzing decodability for TransformerCausal...\n",
      "  Hidden states shape: torch.Size([160, 200, 20])\n",
      "  Coefficients shape: torch.Size([160, 15])\n",
      "  Processed hidden states shape for decoder: torch.Size([160, 20])\n",
      "  RidgeCV Decoder for TransformerCausal - Test MSE: 0.9741, Test R2: 0.5178 (best alpha: 0.2976)\n",
      "  Decodability plot saved to results_data_size_sweep/20250514_045146/samples_960/decodability_TransformerCausal_coeff1.png\n",
      "Decodability (R2 score) for TransformerCausal (samples=960): 0.5178\n",
      "\n",
      "--- Training HIPPORNN_LegT (samples=960, k=15) ---\n",
      "Number of parameters: 4029\n",
      "Epoch 1/200, Train Loss: 17.1220, Val Loss: 15.8470\n",
      "  New best validation loss: 15.8470\n",
      "Epoch 2/200, Train Loss: 17.1128, Val Loss: 15.8398\n",
      "  New best validation loss: 15.8398\n",
      "Epoch 3/200, Train Loss: 17.0964, Val Loss: 15.8258\n",
      "  New best validation loss: 15.8258\n",
      "Epoch 4/200, Train Loss: 17.0609, Val Loss: 15.7942\n",
      "  New best validation loss: 15.7942\n",
      "Epoch 5/200, Train Loss: 16.9601, Val Loss: 15.6806\n",
      "  New best validation loss: 15.6806\n",
      "Epoch 6/200, Train Loss: 16.7190, Val Loss: 15.6890\n",
      "Epoch 7/200, Train Loss: 16.6478, Val Loss: 15.6536\n",
      "  New best validation loss: 15.6536\n",
      "Epoch 8/200, Train Loss: 16.6205, Val Loss: 15.6407\n",
      "  New best validation loss: 15.6407\n",
      "Epoch 9/200, Train Loss: 16.5871, Val Loss: 15.6351\n",
      "  New best validation loss: 15.6351\n",
      "Epoch 10/200, Train Loss: 16.5678, Val Loss: 15.6103\n",
      "  New best validation loss: 15.6103\n",
      "Epoch 11/200, Train Loss: 16.5473, Val Loss: 15.6181\n",
      "Epoch 12/200, Train Loss: 16.5288, Val Loss: 15.6091\n",
      "  New best validation loss: 15.6091\n",
      "Epoch 13/200, Train Loss: 16.5118, Val Loss: 15.5907\n",
      "  New best validation loss: 15.5907\n",
      "Epoch 14/200, Train Loss: 16.4929, Val Loss: 15.5699\n",
      "  New best validation loss: 15.5699\n",
      "Epoch 15/200, Train Loss: 16.4626, Val Loss: 15.5699\n",
      "  New best validation loss: 15.5699\n",
      "Epoch 16/200, Train Loss: 16.4399, Val Loss: 15.5469\n",
      "  New best validation loss: 15.5469\n",
      "Epoch 17/200, Train Loss: 16.4104, Val Loss: 15.5381\n",
      "  New best validation loss: 15.5381\n",
      "Epoch 18/200, Train Loss: 16.3800, Val Loss: 15.5314\n",
      "  New best validation loss: 15.5314\n",
      "Epoch 19/200, Train Loss: 16.3361, Val Loss: 15.4952\n",
      "  New best validation loss: 15.4952\n",
      "Epoch 20/200, Train Loss: 16.2940, Val Loss: 15.4916\n",
      "  New best validation loss: 15.4916\n",
      "Epoch 21/200, Train Loss: 16.2466, Val Loss: 15.4639\n",
      "  New best validation loss: 15.4639\n",
      "Epoch 22/200, Train Loss: 16.1872, Val Loss: 15.4295\n",
      "  New best validation loss: 15.4295\n",
      "Epoch 23/200, Train Loss: 16.1245, Val Loss: 15.3963\n",
      "  New best validation loss: 15.3963\n",
      "Epoch 24/200, Train Loss: 16.0371, Val Loss: 15.3561\n",
      "  New best validation loss: 15.3561\n",
      "Epoch 25/200, Train Loss: 15.9529, Val Loss: 15.2995\n",
      "  New best validation loss: 15.2995\n",
      "Epoch 26/200, Train Loss: 15.8765, Val Loss: 15.2313\n",
      "  New best validation loss: 15.2313\n",
      "Epoch 27/200, Train Loss: 15.7995, Val Loss: 15.2069\n",
      "  New best validation loss: 15.2069\n",
      "Epoch 28/200, Train Loss: 15.7301, Val Loss: 15.1500\n",
      "  New best validation loss: 15.1500\n",
      "Epoch 29/200, Train Loss: 15.6611, Val Loss: 15.1437\n",
      "  New best validation loss: 15.1437\n",
      "Epoch 30/200, Train Loss: 15.5988, Val Loss: 15.1024\n",
      "  New best validation loss: 15.1024\n",
      "Epoch 31/200, Train Loss: 15.5296, Val Loss: 15.0454\n",
      "  New best validation loss: 15.0454\n",
      "Epoch 32/200, Train Loss: 15.4609, Val Loss: 15.0510\n",
      "Epoch 33/200, Train Loss: 15.4069, Val Loss: 14.9678\n",
      "  New best validation loss: 14.9678\n",
      "Epoch 34/200, Train Loss: 15.3413, Val Loss: 14.9258\n",
      "  New best validation loss: 14.9258\n",
      "Epoch 35/200, Train Loss: 15.2883, Val Loss: 14.9016\n",
      "  New best validation loss: 14.9016\n",
      "Epoch 36/200, Train Loss: 15.2341, Val Loss: 14.8566\n",
      "  New best validation loss: 14.8566\n",
      "Epoch 37/200, Train Loss: 15.1731, Val Loss: 14.8235\n",
      "  New best validation loss: 14.8235\n",
      "Epoch 38/200, Train Loss: 15.1222, Val Loss: 14.8258\n",
      "Epoch 39/200, Train Loss: 15.0685, Val Loss: 14.7419\n",
      "  New best validation loss: 14.7419\n",
      "Epoch 40/200, Train Loss: 15.0108, Val Loss: 14.7285\n",
      "  New best validation loss: 14.7285\n",
      "Epoch 41/200, Train Loss: 14.9638, Val Loss: 14.6779\n",
      "  New best validation loss: 14.6779\n",
      "Epoch 42/200, Train Loss: 14.9127, Val Loss: 14.6776\n",
      "  New best validation loss: 14.6776\n",
      "Epoch 43/200, Train Loss: 14.8528, Val Loss: 14.6171\n",
      "  New best validation loss: 14.6171\n",
      "Epoch 44/200, Train Loss: 14.8265, Val Loss: 14.5748\n",
      "  New best validation loss: 14.5748\n",
      "Epoch 45/200, Train Loss: 14.7732, Val Loss: 14.5796\n",
      "Epoch 46/200, Train Loss: 14.7157, Val Loss: 14.5200\n",
      "  New best validation loss: 14.5200\n",
      "Epoch 47/200, Train Loss: 14.6725, Val Loss: 14.4995\n",
      "  New best validation loss: 14.4995\n",
      "Epoch 48/200, Train Loss: 14.6187, Val Loss: 14.4670\n",
      "  New best validation loss: 14.4670\n",
      "Epoch 49/200, Train Loss: 14.5714, Val Loss: 14.4465\n",
      "  New best validation loss: 14.4465\n",
      "Epoch 50/200, Train Loss: 14.5227, Val Loss: 14.3902\n",
      "  New best validation loss: 14.3902\n",
      "Epoch 51/200, Train Loss: 14.4753, Val Loss: 14.3762\n",
      "  New best validation loss: 14.3762\n",
      "Epoch 52/200, Train Loss: 14.4336, Val Loss: 14.3660\n",
      "  New best validation loss: 14.3660\n",
      "Epoch 53/200, Train Loss: 14.3963, Val Loss: 14.3023\n",
      "  New best validation loss: 14.3023\n",
      "Epoch 54/200, Train Loss: 14.3337, Val Loss: 14.3019\n",
      "  New best validation loss: 14.3019\n",
      "Epoch 55/200, Train Loss: 14.2910, Val Loss: 14.2651\n",
      "  New best validation loss: 14.2651\n",
      "Epoch 56/200, Train Loss: 14.2356, Val Loss: 14.2390\n",
      "  New best validation loss: 14.2390\n",
      "Epoch 57/200, Train Loss: 14.1885, Val Loss: 14.1647\n",
      "  New best validation loss: 14.1647\n",
      "Epoch 58/200, Train Loss: 14.1508, Val Loss: 14.1376\n",
      "  New best validation loss: 14.1376\n",
      "Epoch 59/200, Train Loss: 14.0915, Val Loss: 14.1215\n",
      "  New best validation loss: 14.1215\n",
      "Epoch 60/200, Train Loss: 14.0641, Val Loss: 14.1291\n",
      "Epoch 61/200, Train Loss: 14.0302, Val Loss: 14.0806\n",
      "  New best validation loss: 14.0806\n",
      "Epoch 62/200, Train Loss: 13.9728, Val Loss: 13.9989\n",
      "  New best validation loss: 13.9989\n",
      "Epoch 63/200, Train Loss: 13.9273, Val Loss: 13.9970\n",
      "  New best validation loss: 13.9970\n",
      "Epoch 64/200, Train Loss: 13.8792, Val Loss: 13.9742\n",
      "  New best validation loss: 13.9742\n",
      "Epoch 65/200, Train Loss: 13.8424, Val Loss: 13.9404\n",
      "  New best validation loss: 13.9404\n",
      "Epoch 66/200, Train Loss: 13.7967, Val Loss: 13.8836\n",
      "  New best validation loss: 13.8836\n",
      "Epoch 67/200, Train Loss: 13.7690, Val Loss: 13.8323\n",
      "  New best validation loss: 13.8323\n",
      "Epoch 68/200, Train Loss: 13.7215, Val Loss: 13.7793\n",
      "  New best validation loss: 13.7793\n",
      "Epoch 69/200, Train Loss: 13.7017, Val Loss: 13.8404\n",
      "Epoch 70/200, Train Loss: 13.6312, Val Loss: 13.7130\n",
      "  New best validation loss: 13.7130\n",
      "Epoch 71/200, Train Loss: 13.6084, Val Loss: 13.6946\n",
      "  New best validation loss: 13.6946\n",
      "Epoch 72/200, Train Loss: 13.5562, Val Loss: 13.7421\n",
      "Epoch 73/200, Train Loss: 13.5272, Val Loss: 13.6432\n",
      "  New best validation loss: 13.6432\n",
      "Epoch 74/200, Train Loss: 13.4781, Val Loss: 13.5871\n",
      "  New best validation loss: 13.5871\n",
      "Epoch 75/200, Train Loss: 13.4606, Val Loss: 13.5195\n",
      "  New best validation loss: 13.5195\n",
      "Epoch 76/200, Train Loss: 13.4315, Val Loss: 13.5878\n",
      "Epoch 77/200, Train Loss: 13.3914, Val Loss: 13.5517\n",
      "Epoch 78/200, Train Loss: 13.3639, Val Loss: 13.5242\n",
      "Epoch 79/200, Train Loss: 13.3366, Val Loss: 13.5689\n",
      "Epoch 80/200, Train Loss: 13.3275, Val Loss: 13.4859\n",
      "  New best validation loss: 13.4859\n",
      "Epoch 81/200, Train Loss: 13.2711, Val Loss: 13.4613\n",
      "  New best validation loss: 13.4613\n",
      "Epoch 82/200, Train Loss: 13.2682, Val Loss: 13.4712\n",
      "Epoch 83/200, Train Loss: 13.2262, Val Loss: 13.3773\n",
      "  New best validation loss: 13.3773\n",
      "Epoch 84/200, Train Loss: 13.1785, Val Loss: 13.2803\n",
      "  New best validation loss: 13.2803\n",
      "Epoch 85/200, Train Loss: 13.1540, Val Loss: 13.3502\n",
      "Epoch 86/200, Train Loss: 13.1248, Val Loss: 13.3402\n",
      "Epoch 87/200, Train Loss: 13.1049, Val Loss: 13.4230\n",
      "Epoch 88/200, Train Loss: 13.1029, Val Loss: 13.3789\n",
      "Epoch 89/200, Train Loss: 13.0472, Val Loss: 13.2422\n",
      "  New best validation loss: 13.2422\n",
      "Epoch 90/200, Train Loss: 13.0530, Val Loss: 13.2573\n",
      "Epoch 91/200, Train Loss: 13.0074, Val Loss: 13.2124\n",
      "  New best validation loss: 13.2124\n",
      "Epoch 92/200, Train Loss: 12.9956, Val Loss: 13.1982\n",
      "  New best validation loss: 13.1982\n",
      "Epoch 93/200, Train Loss: 12.9763, Val Loss: 13.2577\n",
      "Epoch 94/200, Train Loss: 12.9460, Val Loss: 13.2350\n",
      "Epoch 95/200, Train Loss: 12.9044, Val Loss: 13.1726\n",
      "  New best validation loss: 13.1726\n",
      "Epoch 96/200, Train Loss: 12.9166, Val Loss: 13.2209\n",
      "Epoch 97/200, Train Loss: 12.8815, Val Loss: 13.2934\n",
      "Epoch 98/200, Train Loss: 12.8656, Val Loss: 13.1870\n",
      "Epoch 99/200, Train Loss: 12.8453, Val Loss: 13.0876\n",
      "  New best validation loss: 13.0876\n",
      "Epoch 100/200, Train Loss: 12.8229, Val Loss: 13.0822\n",
      "  New best validation loss: 13.0822\n",
      "Epoch 101/200, Train Loss: 12.8010, Val Loss: 13.1287\n",
      "Epoch 102/200, Train Loss: 12.7971, Val Loss: 13.0801\n",
      "  New best validation loss: 13.0801\n",
      "Epoch 103/200, Train Loss: 12.7609, Val Loss: 13.0110\n",
      "  New best validation loss: 13.0110\n",
      "Epoch 104/200, Train Loss: 12.7640, Val Loss: 13.0769\n",
      "Epoch 105/200, Train Loss: 12.7261, Val Loss: 13.0750\n",
      "Epoch 106/200, Train Loss: 12.7158, Val Loss: 13.0551\n",
      "Epoch 107/200, Train Loss: 12.6772, Val Loss: 13.0650\n",
      "Epoch 108/200, Train Loss: 12.6888, Val Loss: 12.9659\n",
      "  New best validation loss: 12.9659\n",
      "Epoch 109/200, Train Loss: 12.6654, Val Loss: 13.0917\n",
      "Epoch 110/200, Train Loss: 12.6458, Val Loss: 13.0205\n",
      "Epoch 111/200, Train Loss: 12.6132, Val Loss: 12.9530\n",
      "  New best validation loss: 12.9530\n",
      "Epoch 112/200, Train Loss: 12.6298, Val Loss: 13.0004\n",
      "Epoch 113/200, Train Loss: 12.6070, Val Loss: 13.0279\n",
      "Epoch 114/200, Train Loss: 12.5633, Val Loss: 12.9668\n",
      "Epoch 115/200, Train Loss: 12.5525, Val Loss: 13.0227\n",
      "Epoch 116/200, Train Loss: 12.5376, Val Loss: 12.9726\n",
      "Epoch 117/200, Train Loss: 12.5285, Val Loss: 12.8883\n",
      "  New best validation loss: 12.8883\n",
      "Epoch 118/200, Train Loss: 12.5074, Val Loss: 12.9585\n",
      "Epoch 119/200, Train Loss: 12.4896, Val Loss: 12.9614\n",
      "Epoch 120/200, Train Loss: 12.4808, Val Loss: 13.0281\n",
      "Epoch 121/200, Train Loss: 12.4687, Val Loss: 12.9085\n",
      "Epoch 122/200, Train Loss: 12.4703, Val Loss: 12.9284\n",
      "Epoch 123/200, Train Loss: 12.4438, Val Loss: 12.8095\n",
      "  New best validation loss: 12.8095\n",
      "Epoch 124/200, Train Loss: 12.4258, Val Loss: 12.8907\n",
      "Epoch 125/200, Train Loss: 12.4056, Val Loss: 12.8711\n",
      "Epoch 126/200, Train Loss: 12.3918, Val Loss: 12.9759\n",
      "Epoch 127/200, Train Loss: 12.4020, Val Loss: 13.0837\n",
      "Epoch 128/200, Train Loss: 12.3937, Val Loss: 12.8895\n",
      "Epoch 129/200, Train Loss: 12.3616, Val Loss: 12.9735\n",
      "Epoch 130/200, Train Loss: 12.3602, Val Loss: 12.9496\n",
      "Epoch 131/200, Train Loss: 12.3352, Val Loss: 12.7472\n",
      "  New best validation loss: 12.7472\n",
      "Epoch 132/200, Train Loss: 12.3130, Val Loss: 12.9241\n",
      "Epoch 133/200, Train Loss: 12.2963, Val Loss: 12.7872\n",
      "Epoch 134/200, Train Loss: 12.3209, Val Loss: 12.8730\n",
      "Epoch 135/200, Train Loss: 12.2749, Val Loss: 12.7808\n",
      "Epoch 136/200, Train Loss: 12.2655, Val Loss: 12.8341\n",
      "Epoch 137/200, Train Loss: 12.2617, Val Loss: 12.7679\n",
      "Epoch 138/200, Train Loss: 12.2540, Val Loss: 12.8786\n",
      "Epoch 139/200, Train Loss: 12.2251, Val Loss: 12.7616\n",
      "Epoch 140/200, Train Loss: 12.2951, Val Loss: 12.7817\n",
      "Epoch 141/200, Train Loss: 12.2107, Val Loss: 12.8608\n",
      "Epoch 142/200, Train Loss: 12.2139, Val Loss: 12.8553\n",
      "Epoch 143/200, Train Loss: 12.2088, Val Loss: 12.7820\n",
      "Epoch 144/200, Train Loss: 12.1799, Val Loss: 12.9162\n",
      "Epoch 145/200, Train Loss: 12.1803, Val Loss: 12.8820\n",
      "Epoch 146/200, Train Loss: 12.1782, Val Loss: 12.8014\n",
      "Epoch 147/200, Train Loss: 12.1302, Val Loss: 12.7256\n",
      "  New best validation loss: 12.7256\n",
      "Epoch 148/200, Train Loss: 12.1159, Val Loss: 12.7279\n",
      "Epoch 149/200, Train Loss: 12.1223, Val Loss: 12.7791\n",
      "Epoch 150/200, Train Loss: 12.1489, Val Loss: 12.7885\n",
      "Epoch 151/200, Train Loss: 12.0819, Val Loss: 12.7739\n",
      "Epoch 152/200, Train Loss: 12.0901, Val Loss: 12.7543\n",
      "Epoch 153/200, Train Loss: 12.0639, Val Loss: 12.7590\n",
      "Epoch 154/200, Train Loss: 12.0647, Val Loss: 12.7764\n",
      "Epoch 155/200, Train Loss: 12.0502, Val Loss: 12.6905\n",
      "  New best validation loss: 12.6905\n",
      "Epoch 156/200, Train Loss: 12.0627, Val Loss: 12.7969\n",
      "Epoch 157/200, Train Loss: 12.0552, Val Loss: 12.7319\n",
      "Epoch 158/200, Train Loss: 12.0503, Val Loss: 12.7689\n",
      "Epoch 159/200, Train Loss: 11.9950, Val Loss: 12.6967\n",
      "Epoch 160/200, Train Loss: 11.9863, Val Loss: 12.7182\n",
      "Epoch 161/200, Train Loss: 12.0051, Val Loss: 12.6312\n",
      "  New best validation loss: 12.6312\n",
      "Epoch 162/200, Train Loss: 12.0328, Val Loss: 12.6280\n",
      "  New best validation loss: 12.6280\n",
      "Epoch 163/200, Train Loss: 12.0088, Val Loss: 12.6258\n",
      "  New best validation loss: 12.6258\n",
      "Epoch 164/200, Train Loss: 11.9887, Val Loss: 12.6448\n",
      "Epoch 165/200, Train Loss: 11.9571, Val Loss: 12.6058\n",
      "  New best validation loss: 12.6058\n",
      "Epoch 166/200, Train Loss: 11.9440, Val Loss: 12.6099\n",
      "Epoch 167/200, Train Loss: 11.9370, Val Loss: 12.4490\n",
      "  New best validation loss: 12.4490\n",
      "Epoch 168/200, Train Loss: 11.9015, Val Loss: 12.6331\n",
      "Epoch 169/200, Train Loss: 11.9073, Val Loss: 12.5764\n",
      "Epoch 170/200, Train Loss: 11.9055, Val Loss: 12.4603\n",
      "Epoch 171/200, Train Loss: 11.9178, Val Loss: 12.6601\n",
      "Epoch 172/200, Train Loss: 11.9191, Val Loss: 12.5893\n",
      "Epoch 173/200, Train Loss: 11.8941, Val Loss: 12.4551\n",
      "Epoch 174/200, Train Loss: 11.8556, Val Loss: 12.5653\n",
      "Epoch 175/200, Train Loss: 11.8461, Val Loss: 12.6227\n",
      "Epoch 176/200, Train Loss: 11.8473, Val Loss: 12.6339\n",
      "Epoch 177/200, Train Loss: 11.8284, Val Loss: 12.3902\n",
      "  New best validation loss: 12.3902\n",
      "Epoch 178/200, Train Loss: 11.8085, Val Loss: 12.5799\n",
      "Epoch 179/200, Train Loss: 11.8438, Val Loss: 12.6871\n",
      "Epoch 180/200, Train Loss: 11.7886, Val Loss: 12.5259\n",
      "Epoch 181/200, Train Loss: 11.7860, Val Loss: 12.5373\n",
      "Epoch 182/200, Train Loss: 11.8022, Val Loss: 12.5172\n",
      "Epoch 183/200, Train Loss: 11.7616, Val Loss: 12.4615\n",
      "Epoch 184/200, Train Loss: 11.7645, Val Loss: 12.5010\n",
      "Epoch 185/200, Train Loss: 11.7375, Val Loss: 12.5007\n",
      "Epoch 186/200, Train Loss: 11.7689, Val Loss: 12.7624\n",
      "Epoch 187/200, Train Loss: 11.7602, Val Loss: 12.6201\n",
      "Epoch 188/200, Train Loss: 11.8052, Val Loss: 12.2873\n",
      "  New best validation loss: 12.2873\n",
      "Epoch 189/200, Train Loss: 11.8247, Val Loss: 12.3865\n",
      "Epoch 190/200, Train Loss: 11.7396, Val Loss: 12.6132\n",
      "Epoch 191/200, Train Loss: 11.7110, Val Loss: 12.5415\n",
      "Epoch 192/200, Train Loss: 11.6887, Val Loss: 12.6024\n",
      "Epoch 193/200, Train Loss: 11.6921, Val Loss: 12.4500\n",
      "Epoch 194/200, Train Loss: 11.6786, Val Loss: 12.4848\n",
      "Epoch 195/200, Train Loss: 11.7730, Val Loss: 12.1668\n",
      "  New best validation loss: 12.1668\n",
      "Epoch 196/200, Train Loss: 11.8483, Val Loss: 12.1702\n",
      "Epoch 197/200, Train Loss: 11.7172, Val Loss: 12.2912\n",
      "Epoch 198/200, Train Loss: 11.6604, Val Loss: 12.4882\n",
      "Epoch 199/200, Train Loss: 11.6568, Val Loss: 12.4027\n",
      "Epoch 200/200, Train Loss: 11.6481, Val Loss: 12.4747\n",
      "\n",
      "Loaded best model (Val Loss: 12.1668) for final hidden state extraction.\n",
      "Saved best model for HIPPORNN_LegT (samples=960) to results_data_size_sweep/20250514_045146/samples_960/HIPPORNN_LegT_samples_960_best.pt\n",
      "\n",
      "--- Performing Decodability Analysis for HIPPORNN_LegT (samples=960, k=15) ---\n",
      "  Analyzing decodability for HIPPORNN_LegT...\n",
      "  Hidden states shape: torch.Size([160, 200, 25])\n",
      "  Coefficients shape: torch.Size([160, 15])\n",
      "  Processed hidden states shape for decoder: torch.Size([160, 25])\n",
      "  RidgeCV Decoder for HIPPORNN_LegT - Test MSE: 1.4859, Test R2: 0.2683 (best alpha: 48.3293)\n",
      "  Decodability plot saved to results_data_size_sweep/20250514_045146/samples_960/decodability_HIPPORNN_LegT_coeff1.png\n",
      "Decodability (R2 score) for HIPPORNN_LegT (samples=960): 0.2683\n",
      "\n",
      "--- Training NMRNN_Spatial_ModReadout (samples=960, k=15) ---\n",
      "Number of parameters: 66832\n",
      "Epoch 1/200, Train Loss: 16.9598, Val Loss: 15.7701\n",
      "  New best validation loss: 15.7701\n",
      "Epoch 2/200, Train Loss: 16.8332, Val Loss: 15.7823\n",
      "Epoch 3/200, Train Loss: 16.7484, Val Loss: 15.8072\n",
      "Epoch 4/200, Train Loss: 16.6610, Val Loss: 15.8092\n",
      "Epoch 5/200, Train Loss: 16.6350, Val Loss: 15.8432\n",
      "Epoch 6/200, Train Loss: 16.6036, Val Loss: 15.8173\n",
      "Epoch 7/200, Train Loss: 16.5776, Val Loss: 15.7653\n",
      "  New best validation loss: 15.7653\n",
      "Epoch 8/200, Train Loss: 16.5292, Val Loss: 15.7663\n",
      "Epoch 9/200, Train Loss: 16.4882, Val Loss: 15.7654\n",
      "Epoch 10/200, Train Loss: 16.4749, Val Loss: 15.5920\n",
      "  New best validation loss: 15.5920\n",
      "Epoch 11/200, Train Loss: 16.3708, Val Loss: 15.5392\n",
      "  New best validation loss: 15.5392\n",
      "Epoch 12/200, Train Loss: 16.2886, Val Loss: 15.3974\n",
      "  New best validation loss: 15.3974\n",
      "Epoch 13/200, Train Loss: 16.2293, Val Loss: 15.3344\n",
      "  New best validation loss: 15.3344\n",
      "Epoch 14/200, Train Loss: 16.1361, Val Loss: 15.3405\n",
      "Epoch 15/200, Train Loss: 16.0245, Val Loss: 15.1570\n",
      "  New best validation loss: 15.1570\n",
      "Epoch 16/200, Train Loss: 15.9079, Val Loss: 15.1483\n",
      "  New best validation loss: 15.1483\n",
      "Epoch 17/200, Train Loss: 15.7909, Val Loss: 14.9746\n",
      "  New best validation loss: 14.9746\n",
      "Epoch 18/200, Train Loss: 15.6608, Val Loss: 14.8306\n",
      "  New best validation loss: 14.8306\n",
      "Epoch 19/200, Train Loss: 15.5181, Val Loss: 14.7702\n",
      "  New best validation loss: 14.7702\n",
      "Epoch 20/200, Train Loss: 15.3699, Val Loss: 14.6228\n",
      "  New best validation loss: 14.6228\n",
      "Epoch 21/200, Train Loss: 15.2726, Val Loss: 14.5697\n",
      "  New best validation loss: 14.5697\n",
      "Epoch 22/200, Train Loss: 15.1392, Val Loss: 14.6376\n",
      "Epoch 23/200, Train Loss: 14.9531, Val Loss: 14.5558\n",
      "  New best validation loss: 14.5558\n",
      "Epoch 24/200, Train Loss: 14.8382, Val Loss: 14.5035\n",
      "  New best validation loss: 14.5035\n",
      "Epoch 25/200, Train Loss: 14.6358, Val Loss: 14.4757\n",
      "  New best validation loss: 14.4757\n",
      "Epoch 26/200, Train Loss: 14.6150, Val Loss: 14.4021\n",
      "  New best validation loss: 14.4021\n",
      "Epoch 27/200, Train Loss: 14.5144, Val Loss: 14.3988\n",
      "  New best validation loss: 14.3988\n",
      "Epoch 28/200, Train Loss: 14.3602, Val Loss: 14.2782\n",
      "  New best validation loss: 14.2782\n",
      "Epoch 29/200, Train Loss: 14.3397, Val Loss: 14.2366\n",
      "  New best validation loss: 14.2366\n",
      "Epoch 30/200, Train Loss: 14.2745, Val Loss: 14.2101\n",
      "  New best validation loss: 14.2101\n",
      "Epoch 31/200, Train Loss: 14.0256, Val Loss: 14.1091\n",
      "  New best validation loss: 14.1091\n",
      "Epoch 32/200, Train Loss: 13.9915, Val Loss: 14.3706\n",
      "Epoch 33/200, Train Loss: 13.8067, Val Loss: 14.0406\n",
      "  New best validation loss: 14.0406\n",
      "Epoch 34/200, Train Loss: 13.6752, Val Loss: 14.1812\n",
      "Epoch 35/200, Train Loss: 13.6732, Val Loss: 14.2733\n",
      "Epoch 36/200, Train Loss: 13.6232, Val Loss: 13.9350\n",
      "  New best validation loss: 13.9350\n",
      "Epoch 37/200, Train Loss: 13.5674, Val Loss: 14.3186\n",
      "Epoch 38/200, Train Loss: 13.3650, Val Loss: 14.1313\n",
      "Epoch 39/200, Train Loss: 13.2996, Val Loss: 14.2161\n",
      "Epoch 40/200, Train Loss: 13.2920, Val Loss: 14.1748\n",
      "Epoch 41/200, Train Loss: 13.1814, Val Loss: 14.0933\n",
      "Epoch 42/200, Train Loss: 13.0845, Val Loss: 13.8422\n",
      "  New best validation loss: 13.8422\n",
      "Epoch 43/200, Train Loss: 13.0102, Val Loss: 13.8330\n",
      "  New best validation loss: 13.8330\n",
      "Epoch 44/200, Train Loss: 12.8982, Val Loss: 14.0504\n",
      "Epoch 45/200, Train Loss: 12.7803, Val Loss: 13.8708\n",
      "Epoch 46/200, Train Loss: 12.7320, Val Loss: 13.5226\n",
      "  New best validation loss: 13.5226\n",
      "Epoch 47/200, Train Loss: 12.7384, Val Loss: 13.6620\n",
      "Epoch 48/200, Train Loss: 12.5319, Val Loss: 13.8878\n",
      "Epoch 49/200, Train Loss: 12.4376, Val Loss: 13.8106\n",
      "Epoch 50/200, Train Loss: 12.4611, Val Loss: 13.5643\n",
      "Epoch 51/200, Train Loss: 12.5126, Val Loss: 13.6434\n",
      "Epoch 52/200, Train Loss: 12.4000, Val Loss: 13.7760\n",
      "Epoch 53/200, Train Loss: 12.2445, Val Loss: 13.6554\n",
      "Epoch 54/200, Train Loss: 12.0751, Val Loss: 13.4059\n",
      "  New best validation loss: 13.4059\n",
      "Epoch 55/200, Train Loss: 11.9777, Val Loss: 13.4975\n",
      "Epoch 56/200, Train Loss: 11.9500, Val Loss: 13.4286\n",
      "Epoch 57/200, Train Loss: 11.9521, Val Loss: 13.4632\n",
      "Epoch 58/200, Train Loss: 11.7964, Val Loss: 13.4606\n",
      "Epoch 59/200, Train Loss: 11.7388, Val Loss: 13.7520\n",
      "Epoch 60/200, Train Loss: 11.6769, Val Loss: 13.5788\n",
      "Epoch 61/200, Train Loss: 11.6456, Val Loss: 13.7051\n",
      "Epoch 62/200, Train Loss: 11.6602, Val Loss: 13.5937\n",
      "Epoch 63/200, Train Loss: 11.5094, Val Loss: 13.5161\n",
      "Epoch 64/200, Train Loss: 11.4627, Val Loss: 13.5424\n",
      "Epoch 65/200, Train Loss: 11.3284, Val Loss: 13.4501\n",
      "Epoch 66/200, Train Loss: 11.2805, Val Loss: 13.9169\n",
      "Epoch 67/200, Train Loss: 11.3822, Val Loss: 13.7921\n",
      "Epoch 68/200, Train Loss: 11.2361, Val Loss: 13.6821\n",
      "Epoch 69/200, Train Loss: 11.1631, Val Loss: 13.6536\n",
      "Epoch 70/200, Train Loss: 11.1464, Val Loss: 13.6483\n",
      "Epoch 71/200, Train Loss: 11.1229, Val Loss: 13.9015\n",
      "Epoch 72/200, Train Loss: 11.0500, Val Loss: 13.7698\n",
      "Epoch 73/200, Train Loss: 10.9909, Val Loss: 13.6199\n",
      "Epoch 74/200, Train Loss: 10.9467, Val Loss: 13.7351\n",
      "Epoch 75/200, Train Loss: 10.9150, Val Loss: 13.6155\n",
      "Epoch 76/200, Train Loss: 10.8219, Val Loss: 13.5922\n",
      "Epoch 77/200, Train Loss: 10.7485, Val Loss: 13.7973\n",
      "Epoch 78/200, Train Loss: 10.6918, Val Loss: 13.8423\n",
      "Epoch 79/200, Train Loss: 10.6592, Val Loss: 13.8106\n",
      "Epoch 80/200, Train Loss: 10.5695, Val Loss: 13.7236\n",
      "Epoch 81/200, Train Loss: 10.5011, Val Loss: 13.7684\n",
      "Epoch 82/200, Train Loss: 10.4752, Val Loss: 13.7347\n",
      "Epoch 83/200, Train Loss: 10.4568, Val Loss: 13.6990\n",
      "Epoch 84/200, Train Loss: 10.4339, Val Loss: 14.0570\n",
      "Epoch 85/200, Train Loss: 10.3154, Val Loss: 13.7625\n",
      "Epoch 86/200, Train Loss: 10.3210, Val Loss: 13.9100\n",
      "Epoch 87/200, Train Loss: 10.1994, Val Loss: 13.7796\n",
      "Epoch 88/200, Train Loss: 10.1979, Val Loss: 13.9257\n",
      "Epoch 89/200, Train Loss: 10.1527, Val Loss: 13.7851\n",
      "Epoch 90/200, Train Loss: 10.1717, Val Loss: 13.9016\n",
      "Epoch 91/200, Train Loss: 10.0637, Val Loss: 14.1199\n",
      "Epoch 92/200, Train Loss: 10.0245, Val Loss: 13.9859\n",
      "Epoch 93/200, Train Loss: 10.0533, Val Loss: 13.8843\n",
      "Epoch 94/200, Train Loss: 9.9280, Val Loss: 13.8888\n",
      "Epoch 95/200, Train Loss: 9.8567, Val Loss: 14.1027\n",
      "Epoch 96/200, Train Loss: 9.7990, Val Loss: 14.0198\n",
      "Epoch 97/200, Train Loss: 9.8476, Val Loss: 13.8985\n",
      "Epoch 98/200, Train Loss: 9.7741, Val Loss: 13.9851\n",
      "Epoch 99/200, Train Loss: 9.7292, Val Loss: 14.2282\n",
      "Epoch 100/200, Train Loss: 9.6638, Val Loss: 14.2515\n",
      "Epoch 101/200, Train Loss: 9.6159, Val Loss: 14.0387\n",
      "Epoch 102/200, Train Loss: 9.5275, Val Loss: 14.4233\n",
      "Epoch 103/200, Train Loss: 9.4903, Val Loss: 14.2025\n",
      "Epoch 104/200, Train Loss: 9.5071, Val Loss: 14.1193\n",
      "Epoch 105/200, Train Loss: 9.5198, Val Loss: 14.1867\n",
      "Epoch 106/200, Train Loss: 9.5496, Val Loss: 13.9954\n",
      "Epoch 107/200, Train Loss: 9.4162, Val Loss: 14.3889\n",
      "Epoch 108/200, Train Loss: 9.3066, Val Loss: 14.1279\n",
      "Epoch 109/200, Train Loss: 9.2911, Val Loss: 14.4868\n",
      "Epoch 110/200, Train Loss: 9.3009, Val Loss: 14.1047\n",
      "Epoch 111/200, Train Loss: 9.2630, Val Loss: 14.3322\n",
      "Epoch 112/200, Train Loss: 9.2653, Val Loss: 14.1943\n",
      "Epoch 113/200, Train Loss: 9.1591, Val Loss: 14.5934\n",
      "Epoch 114/200, Train Loss: 9.1435, Val Loss: 14.5521\n",
      "Epoch 115/200, Train Loss: 9.1825, Val Loss: 14.6742\n",
      "Epoch 116/200, Train Loss: 9.0461, Val Loss: 14.4652\n",
      "Epoch 117/200, Train Loss: 9.0101, Val Loss: 14.5589\n",
      "Epoch 118/200, Train Loss: 8.9924, Val Loss: 14.7579\n",
      "Epoch 119/200, Train Loss: 9.0497, Val Loss: 14.6719\n",
      "Epoch 120/200, Train Loss: 9.0261, Val Loss: 14.4929\n",
      "Epoch 121/200, Train Loss: 9.0549, Val Loss: 14.8649\n",
      "Epoch 122/200, Train Loss: 9.0410, Val Loss: 14.6089\n",
      "Epoch 123/200, Train Loss: 8.8874, Val Loss: 14.3370\n",
      "Epoch 124/200, Train Loss: 8.7815, Val Loss: 14.7699\n",
      "Epoch 125/200, Train Loss: 8.8935, Val Loss: 14.4275\n",
      "Epoch 126/200, Train Loss: 8.8094, Val Loss: 14.6818\n",
      "Epoch 127/200, Train Loss: 8.7225, Val Loss: 14.5882\n",
      "Epoch 128/200, Train Loss: 8.6763, Val Loss: 14.6163\n",
      "Epoch 129/200, Train Loss: 8.6240, Val Loss: 14.7376\n",
      "Epoch 130/200, Train Loss: 8.6640, Val Loss: 14.7529\n",
      "Epoch 131/200, Train Loss: 8.5582, Val Loss: 14.5940\n",
      "Epoch 132/200, Train Loss: 8.6181, Val Loss: 14.8204\n",
      "Epoch 133/200, Train Loss: 8.5307, Val Loss: 14.9118\n",
      "Epoch 134/200, Train Loss: 8.6089, Val Loss: 14.6662\n",
      "Epoch 135/200, Train Loss: 8.5619, Val Loss: 15.0089\n",
      "Epoch 136/200, Train Loss: 8.5527, Val Loss: 14.9216\n",
      "Epoch 137/200, Train Loss: 8.4740, Val Loss: 15.3182\n",
      "Epoch 138/200, Train Loss: 8.4060, Val Loss: 15.1642\n",
      "Epoch 139/200, Train Loss: 8.4249, Val Loss: 14.6016\n",
      "Epoch 140/200, Train Loss: 8.3741, Val Loss: 14.8687\n",
      "Epoch 141/200, Train Loss: 8.4277, Val Loss: 14.6586\n",
      "Epoch 142/200, Train Loss: 8.2389, Val Loss: 14.8497\n",
      "Epoch 143/200, Train Loss: 8.2256, Val Loss: 14.6834\n",
      "Epoch 144/200, Train Loss: 8.3666, Val Loss: 14.6380\n",
      "Epoch 145/200, Train Loss: 8.3454, Val Loss: 14.9466\n",
      "Epoch 146/200, Train Loss: 8.3303, Val Loss: 14.7773\n",
      "Epoch 147/200, Train Loss: 8.2236, Val Loss: 14.7711\n",
      "Epoch 148/200, Train Loss: 8.1639, Val Loss: 14.8004\n",
      "Epoch 149/200, Train Loss: 8.0189, Val Loss: 15.1382\n",
      "Epoch 150/200, Train Loss: 8.2364, Val Loss: 14.9284\n",
      "Epoch 151/200, Train Loss: 8.0655, Val Loss: 15.1397\n",
      "Epoch 152/200, Train Loss: 8.0136, Val Loss: 14.8869\n",
      "Epoch 153/200, Train Loss: 7.9884, Val Loss: 15.1997\n",
      "Epoch 154/200, Train Loss: 7.9734, Val Loss: 15.1103\n",
      "Epoch 155/200, Train Loss: 7.9531, Val Loss: 15.4793\n",
      "Epoch 156/200, Train Loss: 7.9369, Val Loss: 15.1749\n",
      "Epoch 157/200, Train Loss: 7.9586, Val Loss: 15.2284\n",
      "Epoch 158/200, Train Loss: 7.8789, Val Loss: 15.2044\n",
      "Epoch 159/200, Train Loss: 7.8512, Val Loss: 14.9556\n",
      "Epoch 160/200, Train Loss: 7.9187, Val Loss: 15.1906\n",
      "Epoch 161/200, Train Loss: 7.8512, Val Loss: 14.8880\n",
      "Epoch 162/200, Train Loss: 7.8087, Val Loss: 15.1785\n",
      "Epoch 163/200, Train Loss: 7.8026, Val Loss: 14.9216\n",
      "Epoch 164/200, Train Loss: 7.7466, Val Loss: 15.1531\n",
      "Epoch 165/200, Train Loss: 7.6901, Val Loss: 15.3770\n",
      "Epoch 166/200, Train Loss: 7.7356, Val Loss: 15.1195\n",
      "Epoch 167/200, Train Loss: 7.6933, Val Loss: 15.0054\n",
      "Epoch 168/200, Train Loss: 7.6919, Val Loss: 15.2605\n",
      "Epoch 169/200, Train Loss: 7.7479, Val Loss: 15.3559\n",
      "Epoch 170/200, Train Loss: 7.6868, Val Loss: 15.3039\n",
      "Epoch 171/200, Train Loss: 7.6786, Val Loss: 15.2012\n",
      "Epoch 172/200, Train Loss: 7.7005, Val Loss: 15.0200\n",
      "Epoch 173/200, Train Loss: 7.6060, Val Loss: 15.2432\n",
      "Epoch 174/200, Train Loss: 7.6173, Val Loss: 15.3327\n",
      "Epoch 175/200, Train Loss: 7.6022, Val Loss: 15.1288\n",
      "Epoch 176/200, Train Loss: 7.4820, Val Loss: 15.3167\n",
      "Epoch 177/200, Train Loss: 7.5118, Val Loss: 15.3942\n",
      "Epoch 178/200, Train Loss: 7.5816, Val Loss: 14.8885\n",
      "Epoch 179/200, Train Loss: 7.4546, Val Loss: 15.1956\n",
      "Epoch 180/200, Train Loss: 7.4223, Val Loss: 15.6828\n",
      "Epoch 181/200, Train Loss: 7.4076, Val Loss: 15.5352\n",
      "Epoch 182/200, Train Loss: 7.3977, Val Loss: 15.5349\n",
      "Epoch 183/200, Train Loss: 7.4075, Val Loss: 15.3999\n",
      "Epoch 184/200, Train Loss: 7.3088, Val Loss: 15.0221\n",
      "Epoch 185/200, Train Loss: 7.2999, Val Loss: 15.7034\n",
      "Epoch 186/200, Train Loss: 7.3855, Val Loss: 15.3310\n",
      "Epoch 187/200, Train Loss: 7.3475, Val Loss: 15.5652\n",
      "Epoch 188/200, Train Loss: 7.3294, Val Loss: 15.4047\n",
      "Epoch 189/200, Train Loss: 7.2981, Val Loss: 15.8805\n",
      "Epoch 190/200, Train Loss: 7.1934, Val Loss: 15.7951\n",
      "Epoch 191/200, Train Loss: 7.2136, Val Loss: 15.6903\n",
      "Epoch 192/200, Train Loss: 7.2538, Val Loss: 16.0384\n",
      "Epoch 193/200, Train Loss: 7.2277, Val Loss: 15.9119\n",
      "Epoch 194/200, Train Loss: 7.2385, Val Loss: 15.3880\n",
      "Epoch 195/200, Train Loss: 7.2482, Val Loss: 16.2660\n",
      "Epoch 196/200, Train Loss: 7.2078, Val Loss: 15.9635\n",
      "Epoch 197/200, Train Loss: 7.1561, Val Loss: 15.7959\n",
      "Epoch 198/200, Train Loss: 7.1984, Val Loss: 15.6336\n",
      "Epoch 199/200, Train Loss: 7.1316, Val Loss: 15.7221\n",
      "Epoch 200/200, Train Loss: 7.0569, Val Loss: 15.5368\n",
      "\n",
      "Loaded best model (Val Loss: 13.4059) for final hidden state extraction.\n",
      "Saved best model for NMRNN_Spatial_ModReadout (samples=960) to results_data_size_sweep/20250514_045146/samples_960/NMRNN_Spatial_ModReadout_samples_960_best.pt\n",
      "\n",
      "--- Performing Decodability Analysis for NMRNN_Spatial_ModReadout (samples=960, k=15) ---\n",
      "  Analyzing decodability for NMRNN_Spatial_ModReadout...\n",
      "  Hidden states shape: torch.Size([160, 200, 128])\n",
      "  Coefficients shape: torch.Size([160, 15])\n",
      "  Processed hidden states shape for decoder: torch.Size([160, 128])\n",
      "  RidgeCV Decoder for NMRNN_Spatial_ModReadout - Test MSE: 1.5859, Test R2: 0.1976 (best alpha: 100.0000)\n",
      "  Decodability plot saved to results_data_size_sweep/20250514_045146/samples_960/decodability_NMRNN_Spatial_ModReadout_coeff1.png\n",
      "Decodability (R2 score) for NMRNN_Spatial_ModReadout (samples=960): 0.1976\n",
      "\n",
      "--- Training NMRNN_NoSpatial_ModReadout (samples=960, k=15) ---\n",
      "Number of parameters: 66832\n",
      "Epoch 1/200, Train Loss: 16.9664, Val Loss: 15.7148\n",
      "  New best validation loss: 15.7148\n",
      "Epoch 2/200, Train Loss: 16.7902, Val Loss: 15.8025\n",
      "Epoch 3/200, Train Loss: 16.7097, Val Loss: 15.8132\n",
      "Epoch 4/200, Train Loss: 16.6813, Val Loss: 15.7742\n",
      "Epoch 5/200, Train Loss: 16.6214, Val Loss: 15.8174\n",
      "Epoch 6/200, Train Loss: 16.6134, Val Loss: 15.7765\n",
      "Epoch 7/200, Train Loss: 16.5569, Val Loss: 15.8048\n",
      "Epoch 8/200, Train Loss: 16.5548, Val Loss: 15.7600\n",
      "Epoch 9/200, Train Loss: 16.5125, Val Loss: 15.6594\n",
      "  New best validation loss: 15.6594\n",
      "Epoch 10/200, Train Loss: 16.4916, Val Loss: 15.6366\n",
      "  New best validation loss: 15.6366\n",
      "Epoch 11/200, Train Loss: 16.4131, Val Loss: 15.7172\n",
      "Epoch 12/200, Train Loss: 16.3329, Val Loss: 15.4281\n",
      "  New best validation loss: 15.4281\n",
      "Epoch 13/200, Train Loss: 16.2584, Val Loss: 15.3059\n",
      "  New best validation loss: 15.3059\n",
      "Epoch 14/200, Train Loss: 16.1951, Val Loss: 15.2184\n",
      "  New best validation loss: 15.2184\n",
      "Epoch 15/200, Train Loss: 15.9833, Val Loss: 14.9214\n",
      "  New best validation loss: 14.9214\n",
      "Epoch 16/200, Train Loss: 15.7932, Val Loss: 14.6311\n",
      "  New best validation loss: 14.6311\n",
      "Epoch 17/200, Train Loss: 15.7053, Val Loss: 14.6861\n",
      "Epoch 18/200, Train Loss: 15.5393, Val Loss: 14.4640\n",
      "  New best validation loss: 14.4640\n",
      "Epoch 19/200, Train Loss: 15.3621, Val Loss: 14.5872\n",
      "Epoch 20/200, Train Loss: 15.2409, Val Loss: 14.3854\n",
      "  New best validation loss: 14.3854\n",
      "Epoch 21/200, Train Loss: 15.1431, Val Loss: 14.4551\n",
      "Epoch 22/200, Train Loss: 14.9328, Val Loss: 14.1306\n",
      "  New best validation loss: 14.1306\n",
      "Epoch 23/200, Train Loss: 14.8508, Val Loss: 14.2379\n",
      "Epoch 24/200, Train Loss: 14.7196, Val Loss: 14.0268\n",
      "  New best validation loss: 14.0268\n",
      "Epoch 25/200, Train Loss: 14.5606, Val Loss: 13.9763\n",
      "  New best validation loss: 13.9763\n",
      "Epoch 26/200, Train Loss: 14.4289, Val Loss: 13.9763\n",
      "  New best validation loss: 13.9763\n",
      "Epoch 27/200, Train Loss: 14.3261, Val Loss: 13.6202\n",
      "  New best validation loss: 13.6202\n",
      "Epoch 28/200, Train Loss: 14.1685, Val Loss: 13.6135\n",
      "  New best validation loss: 13.6135\n",
      "Epoch 29/200, Train Loss: 14.0960, Val Loss: 13.5475\n",
      "  New best validation loss: 13.5475\n",
      "Epoch 30/200, Train Loss: 14.0138, Val Loss: 13.7832\n",
      "Epoch 31/200, Train Loss: 13.9493, Val Loss: 13.6371\n",
      "Epoch 32/200, Train Loss: 13.7395, Val Loss: 13.4520\n",
      "  New best validation loss: 13.4520\n",
      "Epoch 33/200, Train Loss: 13.7337, Val Loss: 13.5981\n",
      "Epoch 34/200, Train Loss: 13.6866, Val Loss: 13.3231\n",
      "  New best validation loss: 13.3231\n",
      "Epoch 35/200, Train Loss: 13.5200, Val Loss: 13.2693\n",
      "  New best validation loss: 13.2693\n",
      "Epoch 36/200, Train Loss: 13.3168, Val Loss: 13.1651\n",
      "  New best validation loss: 13.1651\n",
      "Epoch 37/200, Train Loss: 13.2862, Val Loss: 13.0311\n",
      "  New best validation loss: 13.0311\n",
      "Epoch 38/200, Train Loss: 13.1050, Val Loss: 12.9134\n",
      "  New best validation loss: 12.9134\n",
      "Epoch 39/200, Train Loss: 13.0708, Val Loss: 13.1250\n",
      "Epoch 40/200, Train Loss: 13.1269, Val Loss: 12.9546\n",
      "Epoch 41/200, Train Loss: 12.9947, Val Loss: 12.9737\n",
      "Epoch 42/200, Train Loss: 12.7761, Val Loss: 12.6286\n",
      "  New best validation loss: 12.6286\n",
      "Epoch 43/200, Train Loss: 12.6130, Val Loss: 12.7618\n",
      "Epoch 44/200, Train Loss: 12.7176, Val Loss: 12.6729\n",
      "Epoch 45/200, Train Loss: 12.6001, Val Loss: 12.9246\n",
      "Epoch 46/200, Train Loss: 12.5140, Val Loss: 12.6647\n",
      "Epoch 47/200, Train Loss: 12.3839, Val Loss: 12.6585\n",
      "Epoch 48/200, Train Loss: 12.2432, Val Loss: 12.5978\n",
      "  New best validation loss: 12.5978\n",
      "Epoch 49/200, Train Loss: 12.2125, Val Loss: 12.5303\n",
      "  New best validation loss: 12.5303\n",
      "Epoch 50/200, Train Loss: 12.1360, Val Loss: 13.1009\n",
      "Epoch 51/200, Train Loss: 12.2461, Val Loss: 12.4955\n",
      "  New best validation loss: 12.4955\n",
      "Epoch 52/200, Train Loss: 12.1165, Val Loss: 12.5237\n",
      "Epoch 53/200, Train Loss: 11.9815, Val Loss: 12.3306\n",
      "  New best validation loss: 12.3306\n",
      "Epoch 54/200, Train Loss: 11.7779, Val Loss: 12.2562\n",
      "  New best validation loss: 12.2562\n",
      "Epoch 55/200, Train Loss: 11.8376, Val Loss: 12.6134\n",
      "Epoch 56/200, Train Loss: 11.8102, Val Loss: 12.3857\n",
      "Epoch 57/200, Train Loss: 11.8120, Val Loss: 12.6250\n",
      "Epoch 58/200, Train Loss: 11.7202, Val Loss: 12.5025\n",
      "Epoch 59/200, Train Loss: 11.6295, Val Loss: 12.3282\n",
      "Epoch 60/200, Train Loss: 11.6039, Val Loss: 12.3687\n",
      "Epoch 61/200, Train Loss: 11.4353, Val Loss: 12.1621\n",
      "  New best validation loss: 12.1621\n",
      "Epoch 62/200, Train Loss: 11.3483, Val Loss: 12.6834\n",
      "Epoch 63/200, Train Loss: 11.3671, Val Loss: 12.6651\n",
      "Epoch 64/200, Train Loss: 11.3722, Val Loss: 12.4506\n",
      "Epoch 65/200, Train Loss: 11.2080, Val Loss: 12.2564\n",
      "Epoch 66/200, Train Loss: 11.1651, Val Loss: 12.4135\n",
      "Epoch 67/200, Train Loss: 11.1355, Val Loss: 12.4212\n",
      "Epoch 68/200, Train Loss: 11.0347, Val Loss: 12.1939\n",
      "Epoch 69/200, Train Loss: 10.9681, Val Loss: 12.1502\n",
      "  New best validation loss: 12.1502\n",
      "Epoch 70/200, Train Loss: 10.8874, Val Loss: 12.4443\n",
      "Epoch 71/200, Train Loss: 10.8030, Val Loss: 12.3214\n",
      "Epoch 72/200, Train Loss: 10.7822, Val Loss: 12.2871\n",
      "Epoch 73/200, Train Loss: 10.7826, Val Loss: 12.4218\n",
      "Epoch 74/200, Train Loss: 10.7084, Val Loss: 12.4314\n",
      "Epoch 75/200, Train Loss: 10.6656, Val Loss: 12.3533\n",
      "Epoch 76/200, Train Loss: 10.6955, Val Loss: 12.6334\n",
      "Epoch 77/200, Train Loss: 10.4867, Val Loss: 12.0955\n",
      "  New best validation loss: 12.0955\n",
      "Epoch 78/200, Train Loss: 10.5296, Val Loss: 12.4649\n",
      "Epoch 79/200, Train Loss: 10.5402, Val Loss: 12.4362\n",
      "Epoch 80/200, Train Loss: 10.3592, Val Loss: 12.5619\n",
      "Epoch 81/200, Train Loss: 10.4422, Val Loss: 12.3597\n",
      "Epoch 82/200, Train Loss: 10.3842, Val Loss: 12.1880\n",
      "Epoch 83/200, Train Loss: 10.2651, Val Loss: 12.5901\n",
      "Epoch 84/200, Train Loss: 10.2864, Val Loss: 12.6006\n",
      "Epoch 85/200, Train Loss: 10.2727, Val Loss: 12.3581\n",
      "Epoch 86/200, Train Loss: 10.0841, Val Loss: 12.7650\n",
      "Epoch 87/200, Train Loss: 10.0614, Val Loss: 12.3226\n",
      "Epoch 88/200, Train Loss: 10.0795, Val Loss: 12.7813\n",
      "Epoch 89/200, Train Loss: 10.0823, Val Loss: 12.7764\n",
      "Epoch 90/200, Train Loss: 10.0924, Val Loss: 12.5236\n",
      "Epoch 91/200, Train Loss: 9.9826, Val Loss: 13.1256\n",
      "Epoch 92/200, Train Loss: 9.8945, Val Loss: 12.4909\n",
      "Epoch 93/200, Train Loss: 9.8790, Val Loss: 12.5569\n",
      "Epoch 94/200, Train Loss: 9.7601, Val Loss: 12.1951\n",
      "Epoch 95/200, Train Loss: 9.8005, Val Loss: 12.1839\n",
      "Epoch 96/200, Train Loss: 9.8299, Val Loss: 12.7160\n",
      "Epoch 97/200, Train Loss: 9.7363, Val Loss: 12.4044\n",
      "Epoch 98/200, Train Loss: 9.6315, Val Loss: 12.1154\n",
      "Epoch 99/200, Train Loss: 9.6912, Val Loss: 12.2112\n",
      "Epoch 100/200, Train Loss: 9.5323, Val Loss: 12.6596\n",
      "Epoch 101/200, Train Loss: 9.5448, Val Loss: 12.5607\n",
      "Epoch 102/200, Train Loss: 9.4735, Val Loss: 12.5000\n",
      "Epoch 103/200, Train Loss: 9.5951, Val Loss: 12.3192\n",
      "Epoch 104/200, Train Loss: 9.3456, Val Loss: 12.3212\n",
      "Epoch 105/200, Train Loss: 9.3553, Val Loss: 12.8450\n",
      "Epoch 106/200, Train Loss: 9.3223, Val Loss: 12.3901\n",
      "Epoch 107/200, Train Loss: 9.3072, Val Loss: 12.5968\n",
      "Epoch 108/200, Train Loss: 9.4174, Val Loss: 12.3034\n",
      "Epoch 109/200, Train Loss: 9.2078, Val Loss: 12.7315\n",
      "Epoch 110/200, Train Loss: 9.1404, Val Loss: 12.5775\n",
      "Epoch 111/200, Train Loss: 9.2259, Val Loss: 12.4175\n",
      "Epoch 112/200, Train Loss: 9.1067, Val Loss: 12.6356\n",
      "Epoch 113/200, Train Loss: 9.0520, Val Loss: 12.6090\n",
      "Epoch 114/200, Train Loss: 9.0505, Val Loss: 12.8026\n",
      "Epoch 115/200, Train Loss: 9.0057, Val Loss: 12.6636\n",
      "Epoch 116/200, Train Loss: 8.9698, Val Loss: 12.6717\n",
      "Epoch 117/200, Train Loss: 8.9265, Val Loss: 12.5203\n",
      "Epoch 118/200, Train Loss: 8.8311, Val Loss: 12.8645\n",
      "Epoch 119/200, Train Loss: 8.8454, Val Loss: 12.7233\n",
      "Epoch 120/200, Train Loss: 8.7785, Val Loss: 12.8483\n",
      "Epoch 121/200, Train Loss: 8.7950, Val Loss: 12.6384\n",
      "Epoch 122/200, Train Loss: 8.8359, Val Loss: 12.8239\n",
      "Epoch 123/200, Train Loss: 8.8107, Val Loss: 12.6551\n",
      "Epoch 124/200, Train Loss: 8.7652, Val Loss: 12.5660\n",
      "Epoch 125/200, Train Loss: 8.8380, Val Loss: 12.9834\n",
      "Epoch 126/200, Train Loss: 8.7031, Val Loss: 13.0789\n",
      "Epoch 127/200, Train Loss: 8.6486, Val Loss: 12.8888\n",
      "Epoch 128/200, Train Loss: 8.5622, Val Loss: 13.1408\n",
      "Epoch 129/200, Train Loss: 8.4838, Val Loss: 12.9045\n",
      "Epoch 130/200, Train Loss: 8.5939, Val Loss: 12.8808\n",
      "Epoch 131/200, Train Loss: 8.5271, Val Loss: 13.1445\n",
      "Epoch 132/200, Train Loss: 8.4985, Val Loss: 13.1905\n",
      "Epoch 133/200, Train Loss: 8.6440, Val Loss: 13.0410\n",
      "Epoch 134/200, Train Loss: 8.3754, Val Loss: 13.1942\n",
      "Epoch 135/200, Train Loss: 8.2545, Val Loss: 13.1907\n",
      "Epoch 136/200, Train Loss: 8.2907, Val Loss: 12.9419\n",
      "Epoch 137/200, Train Loss: 8.3128, Val Loss: 13.0912\n",
      "Epoch 138/200, Train Loss: 8.3600, Val Loss: 13.0733\n",
      "Epoch 139/200, Train Loss: 8.2482, Val Loss: 12.8862\n",
      "Epoch 140/200, Train Loss: 8.3026, Val Loss: 13.0457\n",
      "Epoch 141/200, Train Loss: 8.4165, Val Loss: 13.2032\n",
      "Epoch 142/200, Train Loss: 8.2302, Val Loss: 13.0488\n",
      "Epoch 143/200, Train Loss: 8.1886, Val Loss: 12.9908\n",
      "Epoch 144/200, Train Loss: 8.1771, Val Loss: 13.3639\n",
      "Epoch 145/200, Train Loss: 8.1065, Val Loss: 13.0522\n",
      "Epoch 146/200, Train Loss: 8.0682, Val Loss: 13.3904\n",
      "Epoch 147/200, Train Loss: 8.0913, Val Loss: 13.2829\n",
      "Epoch 148/200, Train Loss: 8.0525, Val Loss: 13.1682\n",
      "Epoch 149/200, Train Loss: 8.0783, Val Loss: 13.2962\n",
      "Epoch 150/200, Train Loss: 8.0092, Val Loss: 13.1472\n",
      "Epoch 151/200, Train Loss: 7.9249, Val Loss: 13.2701\n",
      "Epoch 152/200, Train Loss: 7.8646, Val Loss: 13.5468\n",
      "Epoch 153/200, Train Loss: 7.9431, Val Loss: 13.4781\n",
      "Epoch 154/200, Train Loss: 7.9569, Val Loss: 13.4032\n",
      "Epoch 155/200, Train Loss: 7.9381, Val Loss: 13.3719\n",
      "Epoch 156/200, Train Loss: 7.7978, Val Loss: 13.5195\n",
      "Epoch 157/200, Train Loss: 7.8949, Val Loss: 13.7639\n",
      "Epoch 158/200, Train Loss: 7.8066, Val Loss: 13.7929\n",
      "Epoch 159/200, Train Loss: 7.8580, Val Loss: 13.5361\n",
      "Epoch 160/200, Train Loss: 7.7420, Val Loss: 13.6016\n",
      "Epoch 161/200, Train Loss: 7.6377, Val Loss: 13.6235\n",
      "Epoch 162/200, Train Loss: 7.6465, Val Loss: 13.3271\n",
      "Epoch 163/200, Train Loss: 7.6662, Val Loss: 13.4640\n",
      "Epoch 164/200, Train Loss: 7.7172, Val Loss: 13.4687\n",
      "Epoch 165/200, Train Loss: 7.5756, Val Loss: 13.7175\n",
      "Epoch 166/200, Train Loss: 7.5926, Val Loss: 14.0337\n",
      "Epoch 167/200, Train Loss: 7.6779, Val Loss: 13.6183\n",
      "Epoch 168/200, Train Loss: 7.5847, Val Loss: 13.7823\n",
      "Epoch 169/200, Train Loss: 7.5765, Val Loss: 13.5944\n",
      "Epoch 170/200, Train Loss: 7.5266, Val Loss: 13.9327\n",
      "Epoch 171/200, Train Loss: 7.5368, Val Loss: 13.5736\n",
      "Epoch 172/200, Train Loss: 7.4791, Val Loss: 13.7504\n",
      "Epoch 173/200, Train Loss: 7.4385, Val Loss: 13.9591\n",
      "Epoch 174/200, Train Loss: 7.3997, Val Loss: 13.5729\n",
      "Epoch 175/200, Train Loss: 7.4482, Val Loss: 13.4781\n",
      "Epoch 176/200, Train Loss: 7.3732, Val Loss: 13.7176\n",
      "Epoch 177/200, Train Loss: 7.3911, Val Loss: 13.8133\n",
      "Epoch 178/200, Train Loss: 7.2900, Val Loss: 13.7340\n",
      "Epoch 179/200, Train Loss: 7.3579, Val Loss: 13.6688\n",
      "Epoch 180/200, Train Loss: 7.3334, Val Loss: 13.7446\n",
      "Epoch 181/200, Train Loss: 7.3392, Val Loss: 13.9879\n",
      "Epoch 182/200, Train Loss: 7.3402, Val Loss: 13.8080\n",
      "Epoch 183/200, Train Loss: 7.2496, Val Loss: 13.8444\n",
      "Epoch 184/200, Train Loss: 7.2087, Val Loss: 13.7071\n",
      "Epoch 185/200, Train Loss: 7.2935, Val Loss: 14.0082\n",
      "Epoch 186/200, Train Loss: 7.2736, Val Loss: 14.1124\n",
      "Epoch 187/200, Train Loss: 7.1479, Val Loss: 14.0697\n",
      "Epoch 188/200, Train Loss: 7.0939, Val Loss: 14.2107\n",
      "Epoch 189/200, Train Loss: 7.1391, Val Loss: 14.0859\n",
      "Epoch 190/200, Train Loss: 7.2753, Val Loss: 13.8963\n",
      "Epoch 191/200, Train Loss: 7.2393, Val Loss: 14.1172\n",
      "Epoch 192/200, Train Loss: 7.1507, Val Loss: 14.0267\n",
      "Epoch 193/200, Train Loss: 7.0591, Val Loss: 13.9754\n",
      "Epoch 194/200, Train Loss: 7.0897, Val Loss: 13.9760\n",
      "Epoch 195/200, Train Loss: 7.0022, Val Loss: 13.8299\n",
      "Epoch 196/200, Train Loss: 7.0242, Val Loss: 14.4730\n",
      "Epoch 197/200, Train Loss: 6.9953, Val Loss: 13.9205\n",
      "Epoch 198/200, Train Loss: 6.9426, Val Loss: 14.2717\n",
      "Epoch 199/200, Train Loss: 6.9825, Val Loss: 13.8779\n",
      "Epoch 200/200, Train Loss: 6.8869, Val Loss: 14.2584\n",
      "\n",
      "Loaded best model (Val Loss: 12.0955) for final hidden state extraction.\n",
      "Saved best model for NMRNN_NoSpatial_ModReadout (samples=960) to results_data_size_sweep/20250514_045146/samples_960/NMRNN_NoSpatial_ModReadout_samples_960_best.pt\n",
      "\n",
      "--- Performing Decodability Analysis for NMRNN_NoSpatial_ModReadout (samples=960, k=15) ---\n",
      "  Analyzing decodability for NMRNN_NoSpatial_ModReadout...\n",
      "  Hidden states shape: torch.Size([160, 200, 128])\n",
      "  Coefficients shape: torch.Size([160, 15])\n",
      "  Processed hidden states shape for decoder: torch.Size([160, 128])\n",
      "  RidgeCV Decoder for NMRNN_NoSpatial_ModReadout - Test MSE: 1.3026, Test R2: 0.3511 (best alpha: 100.0000)\n",
      "  Decodability plot saved to results_data_size_sweep/20250514_045146/samples_960/decodability_NMRNN_NoSpatial_ModReadout_coeff1.png\n",
      "Decodability (R2 score) for NMRNN_NoSpatial_ModReadout (samples=960): 0.3511\n",
      "\n",
      "--- Training NMRNN_Spatial_FixedReadout (samples=960, k=15) ---\n",
      "Number of parameters: 66449\n",
      "Epoch 1/200, Train Loss: 17.0236, Val Loss: 15.7350\n",
      "  New best validation loss: 15.7350\n",
      "Epoch 2/200, Train Loss: 16.8147, Val Loss: 15.8786\n",
      "Epoch 3/200, Train Loss: 16.7540, Val Loss: 15.7504\n",
      "Epoch 4/200, Train Loss: 16.6848, Val Loss: 15.7757\n",
      "Epoch 5/200, Train Loss: 16.6243, Val Loss: 15.6973\n",
      "  New best validation loss: 15.6973\n",
      "Epoch 6/200, Train Loss: 16.5721, Val Loss: 15.5969\n",
      "  New best validation loss: 15.5969\n",
      "Epoch 7/200, Train Loss: 16.5045, Val Loss: 15.5949\n",
      "  New best validation loss: 15.5949\n",
      "Epoch 8/200, Train Loss: 16.4223, Val Loss: 15.4034\n",
      "  New best validation loss: 15.4034\n",
      "Epoch 9/200, Train Loss: 16.2790, Val Loss: 15.2949\n",
      "  New best validation loss: 15.2949\n",
      "Epoch 10/200, Train Loss: 16.2256, Val Loss: 15.1218\n",
      "  New best validation loss: 15.1218\n",
      "Epoch 11/200, Train Loss: 16.0662, Val Loss: 15.0463\n",
      "  New best validation loss: 15.0463\n",
      "Epoch 12/200, Train Loss: 15.9759, Val Loss: 14.9004\n",
      "  New best validation loss: 14.9004\n",
      "Epoch 13/200, Train Loss: 15.7859, Val Loss: 14.6117\n",
      "  New best validation loss: 14.6117\n",
      "Epoch 14/200, Train Loss: 15.6880, Val Loss: 14.7772\n",
      "Epoch 15/200, Train Loss: 15.6217, Val Loss: 14.7530\n",
      "Epoch 16/200, Train Loss: 15.4760, Val Loss: 14.6724\n",
      "Epoch 17/200, Train Loss: 15.3968, Val Loss: 14.7032\n",
      "Epoch 18/200, Train Loss: 15.2692, Val Loss: 14.6675\n",
      "Epoch 19/200, Train Loss: 15.1454, Val Loss: 14.3738\n",
      "  New best validation loss: 14.3738\n",
      "Epoch 20/200, Train Loss: 15.1491, Val Loss: 14.5174\n",
      "Epoch 21/200, Train Loss: 15.0302, Val Loss: 14.3748\n",
      "Epoch 22/200, Train Loss: 14.8689, Val Loss: 14.2360\n",
      "  New best validation loss: 14.2360\n",
      "Epoch 23/200, Train Loss: 14.6659, Val Loss: 14.2618\n",
      "Epoch 24/200, Train Loss: 14.6962, Val Loss: 14.4446\n",
      "Epoch 25/200, Train Loss: 14.6058, Val Loss: 14.4291\n",
      "Epoch 26/200, Train Loss: 14.4772, Val Loss: 14.2687\n",
      "Epoch 27/200, Train Loss: 14.3656, Val Loss: 14.2209\n",
      "  New best validation loss: 14.2209\n",
      "Epoch 28/200, Train Loss: 14.2912, Val Loss: 14.3340\n",
      "Epoch 29/200, Train Loss: 14.3593, Val Loss: 14.2718\n",
      "Epoch 30/200, Train Loss: 14.2178, Val Loss: 13.8864\n",
      "  New best validation loss: 13.8864\n",
      "Epoch 31/200, Train Loss: 14.1182, Val Loss: 14.2496\n",
      "Epoch 32/200, Train Loss: 13.9950, Val Loss: 14.1517\n",
      "Epoch 33/200, Train Loss: 13.9180, Val Loss: 13.9462\n",
      "Epoch 34/200, Train Loss: 13.7716, Val Loss: 14.0556\n",
      "Epoch 35/200, Train Loss: 13.7863, Val Loss: 13.7311\n",
      "  New best validation loss: 13.7311\n",
      "Epoch 36/200, Train Loss: 13.5547, Val Loss: 14.0760\n",
      "Epoch 37/200, Train Loss: 13.4050, Val Loss: 14.2727\n",
      "Epoch 38/200, Train Loss: 13.4712, Val Loss: 13.8102\n",
      "Epoch 39/200, Train Loss: 13.4761, Val Loss: 13.6994\n",
      "  New best validation loss: 13.6994\n",
      "Epoch 40/200, Train Loss: 13.4671, Val Loss: 13.5585\n",
      "  New best validation loss: 13.5585\n",
      "Epoch 41/200, Train Loss: 13.1177, Val Loss: 13.5024\n",
      "  New best validation loss: 13.5024\n",
      "Epoch 42/200, Train Loss: 13.0575, Val Loss: 13.3182\n",
      "  New best validation loss: 13.3182\n",
      "Epoch 43/200, Train Loss: 12.9246, Val Loss: 13.5226\n",
      "Epoch 44/200, Train Loss: 12.8159, Val Loss: 13.4800\n",
      "Epoch 45/200, Train Loss: 12.6882, Val Loss: 13.3982\n",
      "Epoch 46/200, Train Loss: 12.6965, Val Loss: 13.6793\n",
      "Epoch 47/200, Train Loss: 12.8398, Val Loss: 13.6483\n",
      "Epoch 48/200, Train Loss: 12.6693, Val Loss: 13.5115\n",
      "Epoch 49/200, Train Loss: 12.4826, Val Loss: 13.4884\n",
      "Epoch 50/200, Train Loss: 12.5290, Val Loss: 13.7885\n",
      "Epoch 51/200, Train Loss: 12.6753, Val Loss: 13.5480\n",
      "Epoch 52/200, Train Loss: 12.3505, Val Loss: 13.4510\n",
      "Epoch 53/200, Train Loss: 12.3632, Val Loss: 13.3622\n",
      "Epoch 54/200, Train Loss: 12.1709, Val Loss: 13.4791\n",
      "Epoch 55/200, Train Loss: 12.1192, Val Loss: 13.5067\n",
      "Epoch 56/200, Train Loss: 12.2326, Val Loss: 13.5245\n",
      "Epoch 57/200, Train Loss: 12.0565, Val Loss: 13.1595\n",
      "  New best validation loss: 13.1595\n",
      "Epoch 58/200, Train Loss: 12.0103, Val Loss: 13.1783\n",
      "Epoch 59/200, Train Loss: 11.8591, Val Loss: 13.2884\n",
      "Epoch 60/200, Train Loss: 11.6542, Val Loss: 13.4220\n",
      "Epoch 61/200, Train Loss: 11.7058, Val Loss: 13.2561\n",
      "Epoch 62/200, Train Loss: 11.7649, Val Loss: 13.1391\n",
      "  New best validation loss: 13.1391\n",
      "Epoch 63/200, Train Loss: 11.7383, Val Loss: 13.3671\n",
      "Epoch 64/200, Train Loss: 11.6805, Val Loss: 13.2515\n",
      "Epoch 65/200, Train Loss: 11.6257, Val Loss: 13.2127\n",
      "Epoch 66/200, Train Loss: 11.5433, Val Loss: 12.9244\n",
      "  New best validation loss: 12.9244\n",
      "Epoch 67/200, Train Loss: 11.5156, Val Loss: 13.3505\n",
      "Epoch 68/200, Train Loss: 11.4804, Val Loss: 13.2870\n",
      "Epoch 69/200, Train Loss: 11.2754, Val Loss: 13.2210\n",
      "Epoch 70/200, Train Loss: 11.2759, Val Loss: 13.3757\n",
      "Epoch 71/200, Train Loss: 11.2053, Val Loss: 13.2106\n",
      "Epoch 72/200, Train Loss: 11.1518, Val Loss: 13.5640\n",
      "Epoch 73/200, Train Loss: 11.1074, Val Loss: 13.3094\n",
      "Epoch 74/200, Train Loss: 11.2723, Val Loss: 13.0610\n",
      "Epoch 75/200, Train Loss: 11.5047, Val Loss: 13.2432\n",
      "Epoch 76/200, Train Loss: 11.1429, Val Loss: 13.2555\n",
      "Epoch 77/200, Train Loss: 10.9013, Val Loss: 13.2606\n",
      "Epoch 78/200, Train Loss: 11.0005, Val Loss: 13.4303\n",
      "Epoch 79/200, Train Loss: 11.0548, Val Loss: 13.1504\n",
      "Epoch 80/200, Train Loss: 10.7922, Val Loss: 13.0920\n",
      "Epoch 81/200, Train Loss: 10.7442, Val Loss: 13.0770\n",
      "Epoch 82/200, Train Loss: 10.6816, Val Loss: 13.2547\n",
      "Epoch 83/200, Train Loss: 10.6665, Val Loss: 13.2638\n",
      "Epoch 84/200, Train Loss: 10.6588, Val Loss: 13.1803\n",
      "Epoch 85/200, Train Loss: 10.5483, Val Loss: 13.0787\n",
      "Epoch 86/200, Train Loss: 10.5759, Val Loss: 12.9360\n",
      "Epoch 87/200, Train Loss: 10.4511, Val Loss: 13.4969\n",
      "Epoch 88/200, Train Loss: 10.5616, Val Loss: 13.5714\n",
      "Epoch 89/200, Train Loss: 10.5086, Val Loss: 13.2179\n",
      "Epoch 90/200, Train Loss: 10.3585, Val Loss: 13.2787\n",
      "Epoch 91/200, Train Loss: 10.3402, Val Loss: 13.0616\n",
      "Epoch 92/200, Train Loss: 10.3676, Val Loss: 13.0653\n",
      "Epoch 93/200, Train Loss: 10.2779, Val Loss: 13.0394\n",
      "Epoch 94/200, Train Loss: 10.2723, Val Loss: 13.1411\n",
      "Epoch 95/200, Train Loss: 10.2393, Val Loss: 12.9792\n",
      "Epoch 96/200, Train Loss: 10.2008, Val Loss: 12.9297\n",
      "Epoch 97/200, Train Loss: 10.1327, Val Loss: 13.2283\n",
      "Epoch 98/200, Train Loss: 10.0894, Val Loss: 13.0366\n",
      "Epoch 99/200, Train Loss: 10.0540, Val Loss: 13.1790\n",
      "Epoch 100/200, Train Loss: 10.0186, Val Loss: 13.1335\n",
      "Epoch 101/200, Train Loss: 9.9597, Val Loss: 13.2974\n",
      "Epoch 102/200, Train Loss: 9.9616, Val Loss: 13.5438\n",
      "Epoch 103/200, Train Loss: 9.8885, Val Loss: 13.1167\n",
      "Epoch 104/200, Train Loss: 9.8252, Val Loss: 13.0186\n",
      "Epoch 105/200, Train Loss: 9.8393, Val Loss: 13.1714\n",
      "Epoch 106/200, Train Loss: 9.7269, Val Loss: 13.3032\n",
      "Epoch 107/200, Train Loss: 9.7589, Val Loss: 13.2926\n",
      "Epoch 108/200, Train Loss: 9.7848, Val Loss: 13.3425\n",
      "Epoch 109/200, Train Loss: 9.7100, Val Loss: 13.2675\n",
      "Epoch 110/200, Train Loss: 9.7228, Val Loss: 13.2772\n",
      "Epoch 111/200, Train Loss: 9.7133, Val Loss: 13.7582\n",
      "Epoch 112/200, Train Loss: 9.6074, Val Loss: 13.4737\n",
      "Epoch 113/200, Train Loss: 9.5976, Val Loss: 13.7654\n",
      "Epoch 114/200, Train Loss: 9.7750, Val Loss: 13.4116\n",
      "Epoch 115/200, Train Loss: 9.5071, Val Loss: 13.1854\n",
      "Epoch 116/200, Train Loss: 9.4604, Val Loss: 13.4292\n",
      "Epoch 117/200, Train Loss: 9.3918, Val Loss: 13.3421\n",
      "Epoch 118/200, Train Loss: 9.4041, Val Loss: 13.3361\n",
      "Epoch 119/200, Train Loss: 9.4830, Val Loss: 13.3538\n",
      "Epoch 120/200, Train Loss: 9.2954, Val Loss: 13.3247\n",
      "Epoch 121/200, Train Loss: 9.3131, Val Loss: 13.2396\n",
      "Epoch 122/200, Train Loss: 9.3196, Val Loss: 13.3273\n",
      "Epoch 123/200, Train Loss: 9.3486, Val Loss: 13.7691\n",
      "Epoch 124/200, Train Loss: 9.2840, Val Loss: 13.4068\n",
      "Epoch 125/200, Train Loss: 9.3004, Val Loss: 13.6818\n",
      "Epoch 126/200, Train Loss: 9.3689, Val Loss: 13.8994\n",
      "Epoch 127/200, Train Loss: 9.2733, Val Loss: 13.6926\n",
      "Epoch 128/200, Train Loss: 9.1775, Val Loss: 13.6005\n",
      "Epoch 129/200, Train Loss: 9.1157, Val Loss: 13.3301\n",
      "Epoch 130/200, Train Loss: 9.1223, Val Loss: 13.7453\n",
      "Epoch 131/200, Train Loss: 9.2225, Val Loss: 13.1711\n",
      "Epoch 132/200, Train Loss: 9.0213, Val Loss: 13.4536\n",
      "Epoch 133/200, Train Loss: 9.0366, Val Loss: 13.8709\n",
      "Epoch 134/200, Train Loss: 8.9643, Val Loss: 13.7370\n",
      "Epoch 135/200, Train Loss: 9.0586, Val Loss: 13.5988\n",
      "Epoch 136/200, Train Loss: 9.0561, Val Loss: 13.6372\n",
      "Epoch 137/200, Train Loss: 9.0576, Val Loss: 13.3408\n",
      "Epoch 138/200, Train Loss: 8.9858, Val Loss: 13.5066\n",
      "Epoch 139/200, Train Loss: 8.8340, Val Loss: 13.8055\n",
      "Epoch 140/200, Train Loss: 8.8371, Val Loss: 13.2687\n",
      "Epoch 141/200, Train Loss: 8.8052, Val Loss: 13.6606\n",
      "Epoch 142/200, Train Loss: 8.8658, Val Loss: 13.6079\n",
      "Epoch 143/200, Train Loss: 8.8412, Val Loss: 13.3341\n",
      "Epoch 144/200, Train Loss: 8.7240, Val Loss: 13.5681\n",
      "Epoch 145/200, Train Loss: 8.7444, Val Loss: 13.6194\n",
      "Epoch 146/200, Train Loss: 8.7602, Val Loss: 13.6869\n",
      "Epoch 147/200, Train Loss: 8.7173, Val Loss: 13.4672\n",
      "Epoch 148/200, Train Loss: 8.7806, Val Loss: 13.4962\n",
      "Epoch 149/200, Train Loss: 8.6033, Val Loss: 13.3823\n",
      "Epoch 150/200, Train Loss: 8.6322, Val Loss: 13.5615\n",
      "Epoch 151/200, Train Loss: 8.6980, Val Loss: 13.6587\n",
      "Epoch 152/200, Train Loss: 8.6300, Val Loss: 13.5902\n",
      "Epoch 153/200, Train Loss: 8.6517, Val Loss: 13.5988\n",
      "Epoch 154/200, Train Loss: 8.6294, Val Loss: 13.7801\n",
      "Epoch 155/200, Train Loss: 8.5432, Val Loss: 13.8667\n",
      "Epoch 156/200, Train Loss: 8.5603, Val Loss: 14.0664\n",
      "Epoch 157/200, Train Loss: 8.5458, Val Loss: 13.7313\n",
      "Epoch 158/200, Train Loss: 8.5999, Val Loss: 13.9312\n",
      "Epoch 159/200, Train Loss: 8.5510, Val Loss: 13.5020\n",
      "Epoch 160/200, Train Loss: 8.5221, Val Loss: 13.4349\n",
      "Epoch 161/200, Train Loss: 8.4201, Val Loss: 13.7333\n",
      "Epoch 162/200, Train Loss: 8.4520, Val Loss: 13.8744\n",
      "Epoch 163/200, Train Loss: 8.3815, Val Loss: 13.7762\n",
      "Epoch 164/200, Train Loss: 8.4950, Val Loss: 13.8871\n",
      "Epoch 165/200, Train Loss: 8.4344, Val Loss: 13.5969\n",
      "Epoch 166/200, Train Loss: 8.3674, Val Loss: 13.7683\n",
      "Epoch 167/200, Train Loss: 8.4233, Val Loss: 13.5648\n",
      "Epoch 168/200, Train Loss: 8.3933, Val Loss: 13.6002\n",
      "Epoch 169/200, Train Loss: 8.2918, Val Loss: 14.0587\n",
      "Epoch 170/200, Train Loss: 8.3130, Val Loss: 13.8259\n",
      "Epoch 171/200, Train Loss: 8.2792, Val Loss: 13.8522\n",
      "Epoch 172/200, Train Loss: 8.1636, Val Loss: 13.6650\n",
      "Epoch 173/200, Train Loss: 8.1321, Val Loss: 14.0923\n",
      "Epoch 174/200, Train Loss: 8.1362, Val Loss: 13.6363\n",
      "Epoch 175/200, Train Loss: 8.1664, Val Loss: 13.8069\n",
      "Epoch 176/200, Train Loss: 8.3259, Val Loss: 14.1049\n",
      "Epoch 177/200, Train Loss: 8.2127, Val Loss: 14.0873\n",
      "Epoch 178/200, Train Loss: 8.1615, Val Loss: 14.1575\n",
      "Epoch 179/200, Train Loss: 8.1679, Val Loss: 13.5808\n",
      "Epoch 180/200, Train Loss: 8.1480, Val Loss: 13.9702\n",
      "Epoch 181/200, Train Loss: 8.0051, Val Loss: 14.0468\n",
      "Epoch 182/200, Train Loss: 8.0954, Val Loss: 13.9083\n",
      "Epoch 183/200, Train Loss: 8.0811, Val Loss: 13.9311\n",
      "Epoch 184/200, Train Loss: 8.0614, Val Loss: 13.9454\n",
      "Epoch 185/200, Train Loss: 7.9819, Val Loss: 14.1630\n",
      "Epoch 186/200, Train Loss: 8.0050, Val Loss: 13.9310\n",
      "Epoch 187/200, Train Loss: 8.0904, Val Loss: 13.9207\n",
      "Epoch 188/200, Train Loss: 8.1326, Val Loss: 13.9766\n",
      "Epoch 189/200, Train Loss: 8.0681, Val Loss: 14.2211\n",
      "Epoch 190/200, Train Loss: 7.9426, Val Loss: 14.0891\n",
      "Epoch 191/200, Train Loss: 7.9682, Val Loss: 14.0114\n",
      "Epoch 192/200, Train Loss: 7.9145, Val Loss: 13.8320\n",
      "Epoch 193/200, Train Loss: 8.1102, Val Loss: 14.1683\n",
      "Epoch 194/200, Train Loss: 7.8840, Val Loss: 14.0844\n",
      "Epoch 195/200, Train Loss: 7.8416, Val Loss: 13.8859\n",
      "Epoch 196/200, Train Loss: 7.9167, Val Loss: 14.0225\n",
      "Epoch 197/200, Train Loss: 7.8850, Val Loss: 14.1378\n",
      "Epoch 198/200, Train Loss: 7.8753, Val Loss: 14.5058\n",
      "Epoch 199/200, Train Loss: 7.8306, Val Loss: 13.8983\n",
      "Epoch 200/200, Train Loss: 7.7832, Val Loss: 14.3588\n",
      "\n",
      "Loaded best model (Val Loss: 12.9244) for final hidden state extraction.\n",
      "Saved best model for NMRNN_Spatial_FixedReadout (samples=960) to results_data_size_sweep/20250514_045146/samples_960/NMRNN_Spatial_FixedReadout_samples_960_best.pt\n",
      "\n",
      "--- Performing Decodability Analysis for NMRNN_Spatial_FixedReadout (samples=960, k=15) ---\n",
      "  Analyzing decodability for NMRNN_Spatial_FixedReadout...\n",
      "  Hidden states shape: torch.Size([160, 200, 128])\n",
      "  Coefficients shape: torch.Size([160, 15])\n",
      "  Processed hidden states shape for decoder: torch.Size([160, 128])\n",
      "  RidgeCV Decoder for NMRNN_Spatial_FixedReadout - Test MSE: 1.5294, Test R2: 0.2370 (best alpha: 100.0000)\n",
      "  Decodability plot saved to results_data_size_sweep/20250514_045146/samples_960/decodability_NMRNN_Spatial_FixedReadout_coeff1.png\n",
      "Decodability (R2 score) for NMRNN_Spatial_FixedReadout (samples=960): 0.2370\n",
      "Learning curves saved to results_data_size_sweep/20250514_045146/samples_960/learning_curves_validation.png\n",
      "\n",
      "Validation learning curves for samples=960 plotted.\n",
      "Learning curves saved to results_data_size_sweep/20250514_045146/samples_960/learning_curves_training.png\n",
      "\n",
      "Training learning curves for samples=960 plotted.\n",
      "Decodability summary for samples=960 saved to results_data_size_sweep/20250514_045146/samples_960/decodability_summary.txt\n",
      "\n",
      "========================= Running for train_samples: 1280, k: 15 =========================\n",
      "Results for train_samples=1280 will be saved in: results_data_size_sweep/20250514_045146/samples_1280\n",
      "Loading dataset...\n",
      "Dataset loaded.\n",
      "Warning: Modulated readout requested but N_nm is 0. Using fixed readout.\n",
      "\n",
      "--- Training RNN_Vanillia (samples=1280, k=15) ---\n",
      "Number of parameters: 51301\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/conda/lib/python3.10/site-packages/torch/nn/init.py:405: UserWarning: Initializing zero-element tensors is a no-op\n",
      "  warnings.warn(\"Initializing zero-element tensors is a no-op\")\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/200, Train Loss: 16.8985, Val Loss: 15.7331\n",
      "  New best validation loss: 15.7331\n",
      "Epoch 2/200, Train Loss: 16.7043, Val Loss: 15.7352\n",
      "Epoch 3/200, Train Loss: 16.6631, Val Loss: 15.7560\n",
      "Epoch 4/200, Train Loss: 16.6392, Val Loss: 15.7313\n",
      "  New best validation loss: 15.7313\n",
      "Epoch 5/200, Train Loss: 16.6234, Val Loss: 15.7508\n",
      "Epoch 6/200, Train Loss: 16.6130, Val Loss: 15.7456\n",
      "Epoch 7/200, Train Loss: 16.6019, Val Loss: 15.7370\n",
      "Epoch 8/200, Train Loss: 16.5926, Val Loss: 15.7184\n",
      "  New best validation loss: 15.7184\n",
      "Epoch 9/200, Train Loss: 16.5842, Val Loss: 15.6960\n",
      "  New best validation loss: 15.6960\n",
      "Epoch 10/200, Train Loss: 16.5692, Val Loss: 15.7725\n",
      "Epoch 11/200, Train Loss: 16.5694, Val Loss: 15.6966\n",
      "Epoch 12/200, Train Loss: 16.5512, Val Loss: 15.6890\n",
      "  New best validation loss: 15.6890\n",
      "Epoch 13/200, Train Loss: 16.5369, Val Loss: 15.6993\n",
      "Epoch 14/200, Train Loss: 16.5267, Val Loss: 15.6690\n",
      "  New best validation loss: 15.6690\n",
      "Epoch 15/200, Train Loss: 16.5228, Val Loss: 15.6890\n",
      "Epoch 16/200, Train Loss: 16.5052, Val Loss: 15.7485\n",
      "Epoch 17/200, Train Loss: 16.5057, Val Loss: 15.7556\n",
      "Epoch 18/200, Train Loss: 16.4864, Val Loss: 15.6861\n",
      "Epoch 19/200, Train Loss: 16.4808, Val Loss: 15.7016\n",
      "Epoch 20/200, Train Loss: 16.4804, Val Loss: 15.6771\n",
      "Epoch 21/200, Train Loss: 16.4806, Val Loss: 15.7324\n",
      "Epoch 22/200, Train Loss: 16.4667, Val Loss: 15.6640\n",
      "  New best validation loss: 15.6640\n",
      "Epoch 23/200, Train Loss: 16.4594, Val Loss: 15.6820\n",
      "Epoch 24/200, Train Loss: 16.4525, Val Loss: 15.6663\n",
      "Epoch 25/200, Train Loss: 16.4480, Val Loss: 15.6767\n",
      "Epoch 26/200, Train Loss: 16.4431, Val Loss: 15.6596\n",
      "  New best validation loss: 15.6596\n",
      "Epoch 27/200, Train Loss: 16.4349, Val Loss: 15.6868\n",
      "Epoch 28/200, Train Loss: 16.4271, Val Loss: 15.6606\n",
      "Epoch 29/200, Train Loss: 16.4363, Val Loss: 15.6476\n",
      "  New best validation loss: 15.6476\n",
      "Epoch 30/200, Train Loss: 16.4188, Val Loss: 15.6400\n",
      "  New best validation loss: 15.6400\n",
      "Epoch 31/200, Train Loss: 16.4205, Val Loss: 15.6402\n",
      "Epoch 32/200, Train Loss: 16.3980, Val Loss: 15.6374\n",
      "  New best validation loss: 15.6374\n",
      "Epoch 33/200, Train Loss: 16.3916, Val Loss: 15.6134\n",
      "  New best validation loss: 15.6134\n",
      "Epoch 34/200, Train Loss: 16.3864, Val Loss: 15.6684\n",
      "Epoch 35/200, Train Loss: 16.3780, Val Loss: 15.6076\n",
      "  New best validation loss: 15.6076\n",
      "Epoch 36/200, Train Loss: 16.3819, Val Loss: 15.6010\n",
      "  New best validation loss: 15.6010\n",
      "Epoch 37/200, Train Loss: 16.3616, Val Loss: 15.6422\n",
      "Epoch 38/200, Train Loss: 16.3662, Val Loss: 15.6174\n",
      "Epoch 39/200, Train Loss: 16.3605, Val Loss: 15.6277\n",
      "Epoch 40/200, Train Loss: 16.3583, Val Loss: 15.6121\n",
      "Epoch 41/200, Train Loss: 16.3329, Val Loss: 15.5559\n",
      "  New best validation loss: 15.5559\n",
      "Epoch 42/200, Train Loss: 16.3302, Val Loss: 15.5750\n",
      "Epoch 43/200, Train Loss: 16.3205, Val Loss: 15.5450\n",
      "  New best validation loss: 15.5450\n",
      "Epoch 44/200, Train Loss: 16.3004, Val Loss: 15.5112\n",
      "  New best validation loss: 15.5112\n",
      "Epoch 45/200, Train Loss: 16.2933, Val Loss: 15.5300\n",
      "Epoch 46/200, Train Loss: 16.2778, Val Loss: 15.5660\n",
      "Epoch 47/200, Train Loss: 16.2844, Val Loss: 15.5146\n",
      "Epoch 48/200, Train Loss: 16.2709, Val Loss: 15.4891\n",
      "  New best validation loss: 15.4891\n",
      "Epoch 49/200, Train Loss: 16.2591, Val Loss: 15.5070\n",
      "Epoch 50/200, Train Loss: 16.2441, Val Loss: 15.4812\n",
      "  New best validation loss: 15.4812\n",
      "Epoch 51/200, Train Loss: 16.2321, Val Loss: 15.4597\n",
      "  New best validation loss: 15.4597\n",
      "Epoch 52/200, Train Loss: 16.2233, Val Loss: 15.3888\n",
      "  New best validation loss: 15.3888\n",
      "Epoch 53/200, Train Loss: 16.1926, Val Loss: 15.4694\n",
      "Epoch 54/200, Train Loss: 16.1883, Val Loss: 15.4411\n",
      "Epoch 55/200, Train Loss: 16.1681, Val Loss: 15.4361\n",
      "Epoch 56/200, Train Loss: 16.1515, Val Loss: 15.3368\n",
      "  New best validation loss: 15.3368\n",
      "Epoch 57/200, Train Loss: 16.1428, Val Loss: 15.3426\n",
      "Epoch 58/200, Train Loss: 16.1163, Val Loss: 15.2914\n",
      "  New best validation loss: 15.2914\n",
      "Epoch 59/200, Train Loss: 16.1177, Val Loss: 15.3336\n",
      "Epoch 60/200, Train Loss: 16.0751, Val Loss: 15.2372\n",
      "  New best validation loss: 15.2372\n",
      "Epoch 61/200, Train Loss: 16.0571, Val Loss: 15.2379\n",
      "Epoch 62/200, Train Loss: 16.0362, Val Loss: 15.2132\n",
      "  New best validation loss: 15.2132\n",
      "Epoch 63/200, Train Loss: 16.0310, Val Loss: 15.1247\n",
      "  New best validation loss: 15.1247\n",
      "Epoch 64/200, Train Loss: 15.9778, Val Loss: 15.0944\n",
      "  New best validation loss: 15.0944\n",
      "Epoch 65/200, Train Loss: 15.9383, Val Loss: 15.0496\n",
      "  New best validation loss: 15.0496\n",
      "Epoch 66/200, Train Loss: 15.9038, Val Loss: 14.9878\n",
      "  New best validation loss: 14.9878\n",
      "Epoch 67/200, Train Loss: 15.8450, Val Loss: 14.9050\n",
      "  New best validation loss: 14.9050\n",
      "Epoch 68/200, Train Loss: 15.7704, Val Loss: 14.9296\n",
      "Epoch 69/200, Train Loss: 15.7007, Val Loss: 14.7166\n",
      "  New best validation loss: 14.7166\n",
      "Epoch 70/200, Train Loss: 15.6460, Val Loss: 15.0775\n",
      "Epoch 71/200, Train Loss: 15.5823, Val Loss: 14.5911\n",
      "  New best validation loss: 14.5911\n",
      "Epoch 72/200, Train Loss: 15.5128, Val Loss: 14.4897\n",
      "  New best validation loss: 14.4897\n",
      "Epoch 73/200, Train Loss: 15.4268, Val Loss: 14.5318\n",
      "Epoch 74/200, Train Loss: 15.3051, Val Loss: 14.6707\n",
      "Epoch 75/200, Train Loss: 15.2784, Val Loss: 14.4136\n",
      "  New best validation loss: 14.4136\n",
      "Epoch 76/200, Train Loss: 15.2398, Val Loss: 14.3131\n",
      "  New best validation loss: 14.3131\n",
      "Epoch 77/200, Train Loss: 15.1364, Val Loss: 14.1916\n",
      "  New best validation loss: 14.1916\n",
      "Epoch 78/200, Train Loss: 15.0597, Val Loss: 14.2870\n",
      "Epoch 79/200, Train Loss: 14.9407, Val Loss: 14.3480\n",
      "Epoch 80/200, Train Loss: 14.8869, Val Loss: 14.0221\n",
      "  New best validation loss: 14.0221\n",
      "Epoch 81/200, Train Loss: 14.7911, Val Loss: 14.1354\n",
      "Epoch 82/200, Train Loss: 14.7491, Val Loss: 13.9658\n",
      "  New best validation loss: 13.9658\n",
      "Epoch 83/200, Train Loss: 14.6474, Val Loss: 13.8129\n",
      "  New best validation loss: 13.8129\n",
      "Epoch 84/200, Train Loss: 14.6095, Val Loss: 13.8523\n",
      "Epoch 85/200, Train Loss: 14.5265, Val Loss: 13.7364\n",
      "  New best validation loss: 13.7364\n",
      "Epoch 86/200, Train Loss: 14.4731, Val Loss: 13.8100\n",
      "Epoch 87/200, Train Loss: 14.3977, Val Loss: 13.6436\n",
      "  New best validation loss: 13.6436\n",
      "Epoch 88/200, Train Loss: 14.3443, Val Loss: 14.0018\n",
      "Epoch 89/200, Train Loss: 14.3253, Val Loss: 13.5345\n",
      "  New best validation loss: 13.5345\n",
      "Epoch 90/200, Train Loss: 14.2720, Val Loss: 13.6184\n",
      "Epoch 91/200, Train Loss: 14.2344, Val Loss: 13.6764\n",
      "Epoch 92/200, Train Loss: 14.2199, Val Loss: 13.4775\n",
      "  New best validation loss: 13.4775\n",
      "Epoch 93/200, Train Loss: 14.1204, Val Loss: 13.7332\n",
      "Epoch 94/200, Train Loss: 14.0677, Val Loss: 13.4062\n",
      "  New best validation loss: 13.4062\n",
      "Epoch 95/200, Train Loss: 14.0563, Val Loss: 14.0237\n",
      "Epoch 96/200, Train Loss: 14.0604, Val Loss: 13.5494\n",
      "Epoch 97/200, Train Loss: 14.0050, Val Loss: 13.3227\n",
      "  New best validation loss: 13.3227\n",
      "Epoch 98/200, Train Loss: 13.9364, Val Loss: 13.5446\n",
      "Epoch 99/200, Train Loss: 13.8919, Val Loss: 13.3208\n",
      "  New best validation loss: 13.3208\n",
      "Epoch 100/200, Train Loss: 13.8329, Val Loss: 13.3547\n",
      "Epoch 101/200, Train Loss: 13.8040, Val Loss: 13.2873\n",
      "  New best validation loss: 13.2873\n",
      "Epoch 102/200, Train Loss: 13.8002, Val Loss: 13.2423\n",
      "  New best validation loss: 13.2423\n",
      "Epoch 103/200, Train Loss: 13.7652, Val Loss: 13.4086\n",
      "Epoch 104/200, Train Loss: 13.6957, Val Loss: 13.2011\n",
      "  New best validation loss: 13.2011\n",
      "Epoch 105/200, Train Loss: 13.6813, Val Loss: 13.2209\n",
      "Epoch 106/200, Train Loss: 13.6710, Val Loss: 13.2708\n",
      "Epoch 107/200, Train Loss: 13.5996, Val Loss: 13.2086\n",
      "Epoch 108/200, Train Loss: 13.5419, Val Loss: 13.2028\n",
      "Epoch 109/200, Train Loss: 13.5432, Val Loss: 13.1224\n",
      "  New best validation loss: 13.1224\n",
      "Epoch 110/200, Train Loss: 13.5099, Val Loss: 13.1273\n",
      "Epoch 111/200, Train Loss: 13.4847, Val Loss: 13.1192\n",
      "  New best validation loss: 13.1192\n",
      "Epoch 112/200, Train Loss: 13.4409, Val Loss: 12.9717\n",
      "  New best validation loss: 12.9717\n",
      "Epoch 113/200, Train Loss: 13.4457, Val Loss: 13.4551\n",
      "Epoch 114/200, Train Loss: 13.4660, Val Loss: 13.0749\n",
      "Epoch 115/200, Train Loss: 13.3759, Val Loss: 12.9707\n",
      "  New best validation loss: 12.9707\n",
      "Epoch 116/200, Train Loss: 13.3777, Val Loss: 13.0005\n",
      "Epoch 117/200, Train Loss: 13.2958, Val Loss: 13.0544\n",
      "Epoch 118/200, Train Loss: 13.2686, Val Loss: 13.1191\n",
      "Epoch 119/200, Train Loss: 13.2952, Val Loss: 13.1032\n",
      "Epoch 120/200, Train Loss: 13.2300, Val Loss: 12.9301\n",
      "  New best validation loss: 12.9301\n",
      "Epoch 121/200, Train Loss: 13.2208, Val Loss: 12.9015\n",
      "  New best validation loss: 12.9015\n",
      "Epoch 122/200, Train Loss: 13.1634, Val Loss: 12.8752\n",
      "  New best validation loss: 12.8752\n",
      "Epoch 123/200, Train Loss: 13.1521, Val Loss: 13.0183\n",
      "Epoch 124/200, Train Loss: 13.1062, Val Loss: 12.8729\n",
      "  New best validation loss: 12.8729\n",
      "Epoch 125/200, Train Loss: 13.0977, Val Loss: 12.8283\n",
      "  New best validation loss: 12.8283\n",
      "Epoch 126/200, Train Loss: 13.0902, Val Loss: 12.8116\n",
      "  New best validation loss: 12.8116\n",
      "Epoch 127/200, Train Loss: 13.0447, Val Loss: 12.8689\n",
      "Epoch 128/200, Train Loss: 13.0090, Val Loss: 12.9117\n",
      "Epoch 129/200, Train Loss: 13.0237, Val Loss: 12.8251\n",
      "Epoch 130/200, Train Loss: 12.9717, Val Loss: 12.6965\n",
      "  New best validation loss: 12.6965\n",
      "Epoch 131/200, Train Loss: 12.9539, Val Loss: 12.7089\n",
      "Epoch 132/200, Train Loss: 12.9187, Val Loss: 12.7781\n",
      "Epoch 133/200, Train Loss: 12.9156, Val Loss: 12.6593\n",
      "  New best validation loss: 12.6593\n",
      "Epoch 134/200, Train Loss: 12.8518, Val Loss: 12.8194\n",
      "Epoch 135/200, Train Loss: 12.8878, Val Loss: 12.9265\n",
      "Epoch 136/200, Train Loss: 12.8828, Val Loss: 12.6903\n",
      "Epoch 137/200, Train Loss: 12.8167, Val Loss: 12.8110\n",
      "Epoch 138/200, Train Loss: 12.8339, Val Loss: 12.6008\n",
      "  New best validation loss: 12.6008\n",
      "Epoch 139/200, Train Loss: 12.7466, Val Loss: 12.7220\n",
      "Epoch 140/200, Train Loss: 12.7369, Val Loss: 12.5843\n",
      "  New best validation loss: 12.5843\n",
      "Epoch 141/200, Train Loss: 12.7169, Val Loss: 12.5507\n",
      "  New best validation loss: 12.5507\n",
      "Epoch 142/200, Train Loss: 12.6797, Val Loss: 12.5519\n",
      "Epoch 143/200, Train Loss: 12.6521, Val Loss: 12.5029\n",
      "  New best validation loss: 12.5029\n",
      "Epoch 144/200, Train Loss: 12.7162, Val Loss: 12.5358\n",
      "Epoch 145/200, Train Loss: 12.6128, Val Loss: 12.4456\n",
      "  New best validation loss: 12.4456\n",
      "Epoch 146/200, Train Loss: 12.6064, Val Loss: 12.7635\n",
      "Epoch 147/200, Train Loss: 12.5768, Val Loss: 12.7438\n",
      "Epoch 148/200, Train Loss: 12.6081, Val Loss: 12.4084\n",
      "  New best validation loss: 12.4084\n",
      "Epoch 149/200, Train Loss: 12.5140, Val Loss: 12.3702\n",
      "  New best validation loss: 12.3702\n",
      "Epoch 150/200, Train Loss: 12.5044, Val Loss: 12.6567\n",
      "Epoch 151/200, Train Loss: 12.5082, Val Loss: 12.3462\n",
      "  New best validation loss: 12.3462\n",
      "Epoch 152/200, Train Loss: 12.4704, Val Loss: 12.7107\n",
      "Epoch 153/200, Train Loss: 12.4825, Val Loss: 12.4536\n",
      "Epoch 154/200, Train Loss: 12.4149, Val Loss: 12.2866\n",
      "  New best validation loss: 12.2866\n",
      "Epoch 155/200, Train Loss: 12.3837, Val Loss: 12.3349\n",
      "Epoch 156/200, Train Loss: 12.3878, Val Loss: 12.3681\n",
      "Epoch 157/200, Train Loss: 12.3711, Val Loss: 12.1469\n",
      "  New best validation loss: 12.1469\n",
      "Epoch 158/200, Train Loss: 12.3481, Val Loss: 12.2183\n",
      "Epoch 159/200, Train Loss: 12.3473, Val Loss: 12.2808\n",
      "Epoch 160/200, Train Loss: 12.2987, Val Loss: 12.1621\n",
      "Epoch 161/200, Train Loss: 12.2574, Val Loss: 12.1536\n",
      "Epoch 162/200, Train Loss: 12.2299, Val Loss: 12.0788\n",
      "  New best validation loss: 12.0788\n",
      "Epoch 163/200, Train Loss: 12.2277, Val Loss: 12.2972\n",
      "Epoch 164/200, Train Loss: 12.2177, Val Loss: 12.1711\n",
      "Epoch 165/200, Train Loss: 12.2052, Val Loss: 12.2039\n",
      "Epoch 166/200, Train Loss: 12.2156, Val Loss: 12.1412\n",
      "Epoch 167/200, Train Loss: 12.1163, Val Loss: 12.0735\n",
      "  New best validation loss: 12.0735\n",
      "Epoch 168/200, Train Loss: 12.1310, Val Loss: 12.3519\n",
      "Epoch 169/200, Train Loss: 12.1018, Val Loss: 12.2543\n",
      "Epoch 170/200, Train Loss: 12.0696, Val Loss: 12.0242\n",
      "  New best validation loss: 12.0242\n",
      "Epoch 171/200, Train Loss: 12.0665, Val Loss: 12.0516\n",
      "Epoch 172/200, Train Loss: 12.0856, Val Loss: 12.0400\n",
      "Epoch 173/200, Train Loss: 12.0608, Val Loss: 12.0099\n",
      "  New best validation loss: 12.0099\n",
      "Epoch 174/200, Train Loss: 12.0376, Val Loss: 11.9241\n",
      "  New best validation loss: 11.9241\n",
      "Epoch 175/200, Train Loss: 11.9720, Val Loss: 12.0721\n",
      "Epoch 176/200, Train Loss: 11.9688, Val Loss: 11.8918\n",
      "  New best validation loss: 11.8918\n",
      "Epoch 177/200, Train Loss: 11.9617, Val Loss: 11.9258\n",
      "Epoch 178/200, Train Loss: 11.9352, Val Loss: 11.9498\n",
      "Epoch 179/200, Train Loss: 11.8987, Val Loss: 11.9163\n",
      "Epoch 180/200, Train Loss: 11.8931, Val Loss: 12.1321\n",
      "Epoch 181/200, Train Loss: 11.8656, Val Loss: 12.0492\n",
      "Epoch 182/200, Train Loss: 11.8240, Val Loss: 11.9797\n",
      "Epoch 183/200, Train Loss: 11.8713, Val Loss: 11.9444\n",
      "Epoch 184/200, Train Loss: 11.8161, Val Loss: 12.1335\n",
      "Epoch 185/200, Train Loss: 11.8667, Val Loss: 11.7909\n",
      "  New best validation loss: 11.7909\n",
      "Epoch 186/200, Train Loss: 11.8185, Val Loss: 11.8422\n",
      "Epoch 187/200, Train Loss: 11.8290, Val Loss: 11.8550\n",
      "Epoch 188/200, Train Loss: 11.7658, Val Loss: 12.1811\n",
      "Epoch 189/200, Train Loss: 11.7455, Val Loss: 11.7821\n",
      "  New best validation loss: 11.7821\n",
      "Epoch 190/200, Train Loss: 11.7060, Val Loss: 11.9313\n",
      "Epoch 191/200, Train Loss: 11.7022, Val Loss: 11.8699\n",
      "Epoch 192/200, Train Loss: 11.7095, Val Loss: 11.9950\n",
      "Epoch 193/200, Train Loss: 11.6697, Val Loss: 11.8124\n",
      "Epoch 194/200, Train Loss: 11.6976, Val Loss: 11.8401\n",
      "Epoch 195/200, Train Loss: 11.6465, Val Loss: 11.8757\n",
      "Epoch 196/200, Train Loss: 11.6245, Val Loss: 11.9865\n",
      "Epoch 197/200, Train Loss: 11.6199, Val Loss: 11.7707\n",
      "  New best validation loss: 11.7707\n",
      "Epoch 198/200, Train Loss: 11.5997, Val Loss: 12.0162\n",
      "Epoch 199/200, Train Loss: 11.5868, Val Loss: 11.7075\n",
      "  New best validation loss: 11.7075\n",
      "Epoch 200/200, Train Loss: 11.5550, Val Loss: 11.7444\n",
      "\n",
      "Loaded best model (Val Loss: 11.7075) for final hidden state extraction.\n",
      "Saved best model for RNN_Vanillia (samples=1280) to results_data_size_sweep/20250514_045146/samples_1280/RNN_Vanillia_samples_1280_best.pt\n",
      "\n",
      "--- Performing Decodability Analysis for RNN_Vanillia (samples=1280, k=15) ---\n",
      "  Analyzing decodability for RNN_Vanillia...\n",
      "  Hidden states shape: torch.Size([160, 200, 225])\n",
      "  Coefficients shape: torch.Size([160, 15])\n",
      "  Processed hidden states shape for decoder: torch.Size([160, 225])\n",
      "  RidgeCV Decoder for RNN_Vanillia - Test MSE: 1.1759, Test R2: 0.4033 (best alpha: 23.3572)\n",
      "  Decodability plot saved to results_data_size_sweep/20250514_045146/samples_1280/decodability_RNN_Vanillia_coeff1.png\n",
      "Decodability (R2 score) for RNN_Vanillia (samples=1280): 0.4033\n",
      "\n",
      "--- Training ComplexOscillatorNet (samples=1280, k=15) ---\n",
      "Number of parameters: 17152\n",
      "Epoch 1/200, Train Loss: 16.3060, Val Loss: 14.6172\n",
      "  New best validation loss: 14.6172\n",
      "Epoch 2/200, Train Loss: 15.4719, Val Loss: 14.2024\n",
      "  New best validation loss: 14.2024\n",
      "Epoch 3/200, Train Loss: 15.1662, Val Loss: 14.2307\n",
      "Epoch 4/200, Train Loss: 14.9887, Val Loss: 13.9107\n",
      "  New best validation loss: 13.9107\n",
      "Epoch 5/200, Train Loss: 14.8299, Val Loss: 13.9242\n",
      "Epoch 6/200, Train Loss: 14.6755, Val Loss: 13.9173\n",
      "Epoch 7/200, Train Loss: 14.6226, Val Loss: 13.8035\n",
      "  New best validation loss: 13.8035\n",
      "Epoch 8/200, Train Loss: 14.5209, Val Loss: 13.7320\n",
      "  New best validation loss: 13.7320\n",
      "Epoch 9/200, Train Loss: 14.4497, Val Loss: 13.6844\n",
      "  New best validation loss: 13.6844\n",
      "Epoch 10/200, Train Loss: 14.3504, Val Loss: 13.6904\n",
      "Epoch 11/200, Train Loss: 14.2739, Val Loss: 13.7036\n",
      "Epoch 12/200, Train Loss: 14.1912, Val Loss: 13.7149\n",
      "Epoch 13/200, Train Loss: 14.1502, Val Loss: 13.6631\n",
      "  New best validation loss: 13.6631\n",
      "Epoch 14/200, Train Loss: 14.0842, Val Loss: 13.6535\n",
      "  New best validation loss: 13.6535\n",
      "Epoch 15/200, Train Loss: 14.0354, Val Loss: 13.5951\n",
      "  New best validation loss: 13.5951\n",
      "Epoch 16/200, Train Loss: 13.9664, Val Loss: 13.7275\n",
      "Epoch 17/200, Train Loss: 13.9401, Val Loss: 13.6126\n",
      "Epoch 18/200, Train Loss: 13.9106, Val Loss: 13.6448\n",
      "Epoch 19/200, Train Loss: 13.8074, Val Loss: 13.6535\n",
      "Epoch 20/200, Train Loss: 13.8071, Val Loss: 13.6563\n",
      "Epoch 21/200, Train Loss: 13.7953, Val Loss: 13.6205\n",
      "Epoch 22/200, Train Loss: 13.7069, Val Loss: 13.6425\n",
      "Epoch 23/200, Train Loss: 13.6682, Val Loss: 13.6691\n",
      "Epoch 24/200, Train Loss: 13.6528, Val Loss: 13.6846\n",
      "Epoch 25/200, Train Loss: 13.6124, Val Loss: 13.8057\n",
      "Epoch 26/200, Train Loss: 13.6007, Val Loss: 13.7176\n",
      "Epoch 27/200, Train Loss: 13.5406, Val Loss: 13.7001\n",
      "Epoch 28/200, Train Loss: 13.5348, Val Loss: 13.7322\n",
      "Epoch 29/200, Train Loss: 13.4917, Val Loss: 13.7298\n",
      "Epoch 30/200, Train Loss: 13.4148, Val Loss: 13.7891\n",
      "Epoch 31/200, Train Loss: 13.4152, Val Loss: 13.7996\n",
      "Epoch 32/200, Train Loss: 13.4077, Val Loss: 13.7501\n",
      "Epoch 33/200, Train Loss: 13.3550, Val Loss: 13.8188\n",
      "Epoch 34/200, Train Loss: 13.3205, Val Loss: 13.7426\n",
      "Epoch 35/200, Train Loss: 13.3655, Val Loss: 13.7800\n",
      "Epoch 36/200, Train Loss: 13.2624, Val Loss: 13.8394\n",
      "Epoch 37/200, Train Loss: 13.2930, Val Loss: 13.8803\n",
      "Epoch 38/200, Train Loss: 13.2738, Val Loss: 13.8140\n",
      "Epoch 39/200, Train Loss: 13.2484, Val Loss: 13.7437\n",
      "Epoch 40/200, Train Loss: 13.1962, Val Loss: 13.8823\n",
      "Epoch 41/200, Train Loss: 13.1357, Val Loss: 13.8186\n",
      "Epoch 42/200, Train Loss: 13.1511, Val Loss: 13.8934\n",
      "Epoch 43/200, Train Loss: 13.1154, Val Loss: 13.9140\n",
      "Epoch 44/200, Train Loss: 13.1075, Val Loss: 13.8234\n",
      "Epoch 45/200, Train Loss: 13.0905, Val Loss: 13.9548\n",
      "Epoch 46/200, Train Loss: 13.0468, Val Loss: 13.7994\n",
      "Epoch 47/200, Train Loss: 13.0570, Val Loss: 14.0591\n",
      "Epoch 48/200, Train Loss: 13.0306, Val Loss: 13.8643\n",
      "Epoch 49/200, Train Loss: 12.9944, Val Loss: 14.0477\n",
      "Epoch 50/200, Train Loss: 12.9704, Val Loss: 14.0324\n",
      "Epoch 51/200, Train Loss: 12.9650, Val Loss: 14.0153\n",
      "Epoch 52/200, Train Loss: 12.9363, Val Loss: 13.9623\n",
      "Epoch 53/200, Train Loss: 12.8999, Val Loss: 14.1646\n",
      "Epoch 54/200, Train Loss: 12.8893, Val Loss: 14.0731\n",
      "Epoch 55/200, Train Loss: 12.8793, Val Loss: 14.1287\n",
      "Epoch 56/200, Train Loss: 12.8850, Val Loss: 14.1653\n",
      "Epoch 57/200, Train Loss: 12.9044, Val Loss: 14.0418\n",
      "Epoch 58/200, Train Loss: 12.8335, Val Loss: 14.1957\n",
      "Epoch 59/200, Train Loss: 12.8057, Val Loss: 14.1111\n",
      "Epoch 60/200, Train Loss: 12.7852, Val Loss: 13.9902\n",
      "Epoch 61/200, Train Loss: 12.7626, Val Loss: 14.1680\n",
      "Epoch 62/200, Train Loss: 12.7514, Val Loss: 14.2210\n",
      "Epoch 63/200, Train Loss: 12.7490, Val Loss: 14.1151\n",
      "Epoch 64/200, Train Loss: 12.7488, Val Loss: 14.2412\n",
      "Epoch 65/200, Train Loss: 12.7153, Val Loss: 14.1748\n",
      "Epoch 66/200, Train Loss: 12.6807, Val Loss: 14.1852\n",
      "Epoch 67/200, Train Loss: 12.6828, Val Loss: 14.2966\n",
      "Epoch 68/200, Train Loss: 12.6961, Val Loss: 14.2305\n",
      "Epoch 69/200, Train Loss: 12.6950, Val Loss: 14.2472\n",
      "Epoch 70/200, Train Loss: 12.6458, Val Loss: 14.2992\n",
      "Epoch 71/200, Train Loss: 12.6047, Val Loss: 14.5240\n",
      "Epoch 72/200, Train Loss: 12.6022, Val Loss: 14.2779\n",
      "Epoch 73/200, Train Loss: 12.6175, Val Loss: 14.2913\n",
      "Epoch 74/200, Train Loss: 12.5783, Val Loss: 14.3620\n",
      "Epoch 75/200, Train Loss: 12.5672, Val Loss: 14.2599\n",
      "Epoch 76/200, Train Loss: 12.5219, Val Loss: 14.3186\n",
      "Epoch 77/200, Train Loss: 12.5353, Val Loss: 14.2378\n",
      "Epoch 78/200, Train Loss: 12.5045, Val Loss: 14.4360\n",
      "Epoch 79/200, Train Loss: 12.5447, Val Loss: 14.4872\n",
      "Epoch 80/200, Train Loss: 12.5583, Val Loss: 14.3924\n",
      "Epoch 81/200, Train Loss: 12.4582, Val Loss: 14.4245\n",
      "Epoch 82/200, Train Loss: 12.4280, Val Loss: 14.4657\n",
      "Epoch 83/200, Train Loss: 12.4402, Val Loss: 14.3579\n",
      "Epoch 84/200, Train Loss: 12.4253, Val Loss: 14.4452\n",
      "Epoch 85/200, Train Loss: 12.4465, Val Loss: 14.3578\n",
      "Epoch 86/200, Train Loss: 12.4370, Val Loss: 14.6377\n",
      "Epoch 87/200, Train Loss: 12.3911, Val Loss: 14.4703\n",
      "Epoch 88/200, Train Loss: 12.3614, Val Loss: 14.5713\n",
      "Epoch 89/200, Train Loss: 12.3629, Val Loss: 14.3410\n",
      "Epoch 90/200, Train Loss: 12.3641, Val Loss: 14.5374\n",
      "Epoch 91/200, Train Loss: 12.3589, Val Loss: 14.4278\n",
      "Epoch 92/200, Train Loss: 12.3204, Val Loss: 14.6869\n",
      "Epoch 93/200, Train Loss: 12.3785, Val Loss: 14.5647\n",
      "Epoch 94/200, Train Loss: 12.3733, Val Loss: 14.6198\n",
      "Epoch 95/200, Train Loss: 12.3305, Val Loss: 14.6110\n",
      "Epoch 96/200, Train Loss: 12.2889, Val Loss: 14.5356\n",
      "Epoch 97/200, Train Loss: 12.2546, Val Loss: 14.6915\n",
      "Epoch 98/200, Train Loss: 12.2649, Val Loss: 14.6722\n",
      "Epoch 99/200, Train Loss: 12.2731, Val Loss: 14.6441\n",
      "Epoch 100/200, Train Loss: 12.2752, Val Loss: 14.6267\n",
      "Epoch 101/200, Train Loss: 12.2575, Val Loss: 14.6770\n",
      "Epoch 102/200, Train Loss: 12.2082, Val Loss: 14.6048\n",
      "Epoch 103/200, Train Loss: 12.2305, Val Loss: 14.7644\n",
      "Epoch 104/200, Train Loss: 12.2621, Val Loss: 14.6653\n",
      "Epoch 105/200, Train Loss: 12.2498, Val Loss: 14.5838\n",
      "Epoch 106/200, Train Loss: 12.1965, Val Loss: 14.6914\n",
      "Epoch 107/200, Train Loss: 12.1849, Val Loss: 14.7504\n",
      "Epoch 108/200, Train Loss: 12.1583, Val Loss: 14.6557\n",
      "Epoch 109/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 110/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 111/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 112/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 113/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 114/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 115/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 116/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 117/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 118/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 119/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 120/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 121/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 122/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 123/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 124/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 125/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 126/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 127/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 128/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 129/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 130/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 131/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 132/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 133/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 134/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 135/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 136/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 137/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 138/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 139/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 140/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 141/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 142/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 143/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 144/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 145/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 146/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 147/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 148/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 149/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 150/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 151/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 152/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 153/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 154/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 155/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 156/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 157/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 158/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 159/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 160/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 161/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 162/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 163/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 164/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 165/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 166/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 167/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 168/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 169/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 170/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 171/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 172/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 173/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 174/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 175/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 176/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 177/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 178/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 179/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 180/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 181/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 182/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 183/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 184/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 185/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 186/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 187/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 188/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 189/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 190/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 191/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 192/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 193/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 194/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 195/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 196/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 197/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 198/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 199/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 200/200, Train Loss: nan, Val Loss: nan\n",
      "\n",
      "Loaded best model (Val Loss: 13.5951) for final hidden state extraction.\n",
      "Saved best model for ComplexOscillatorNet (samples=1280) to results_data_size_sweep/20250514_045146/samples_1280/ComplexOscillatorNet_samples_1280_best.pt\n",
      "\n",
      "--- Performing Decodability Analysis for ComplexOscillatorNet (samples=1280, k=15) ---\n",
      "  Analyzing decodability for ComplexOscillatorNet...\n",
      "  Hidden states shape: torch.Size([160, 200, 128])\n",
      "  Coefficients shape: torch.Size([160, 15])\n",
      "  Processed hidden states shape for decoder: torch.Size([160, 256])\n",
      "  Error during RidgeCV for ComplexOscillatorNet: Input X contains NaN.\n",
      "_RidgeGCV does not accept missing values encoded as NaN natively. For supervised learning, you might want to consider sklearn.ensemble.HistGradientBoostingClassifier and Regressor which accept missing values encoded as NaNs natively. Alternatively, it is possible to preprocess the data, for instance by using an imputer transformer in a pipeline or drop samples with missing values. See https://scikit-learn.org/stable/modules/impute.html You can find a list of all estimators that handle NaN values at the following page: https://scikit-learn.org/stable/modules/impute.html#estimators-that-handle-nan-values\n",
      "Decodability (R2 score) for ComplexOscillatorNet (samples=1280): nan\n",
      "\n",
      "--- Training RNN_GRU (samples=1280, k=15) ---\n",
      "Number of parameters: 12993\n",
      "Epoch 1/200, Train Loss: 16.8415, Val Loss: 15.7297\n",
      "  New best validation loss: 15.7297\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/conda/lib/python3.10/site-packages/sklearn/utils/extmath.py:1101: RuntimeWarning: invalid value encountered in divide\n",
      "  updated_mean = (last_sum + new_sum) / updated_sample_count\n",
      "/opt/conda/lib/python3.10/site-packages/sklearn/utils/extmath.py:1106: RuntimeWarning: invalid value encountered in divide\n",
      "  T = new_sum / new_sample_count\n",
      "/opt/conda/lib/python3.10/site-packages/sklearn/utils/extmath.py:1126: RuntimeWarning: invalid value encountered in divide\n",
      "  new_unnormalized_variance -= correction**2 / new_sample_count\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/200, Train Loss: 16.7970, Val Loss: 15.7457\n",
      "Epoch 3/200, Train Loss: 16.7435, Val Loss: 15.6934\n",
      "  New best validation loss: 15.6934\n",
      "Epoch 4/200, Train Loss: 16.7200, Val Loss: 15.6898\n",
      "  New best validation loss: 15.6898\n",
      "Epoch 5/200, Train Loss: 16.7168, Val Loss: 15.7034\n",
      "Epoch 6/200, Train Loss: 16.7055, Val Loss: 15.7276\n",
      "Epoch 7/200, Train Loss: 16.6931, Val Loss: 15.6858\n",
      "  New best validation loss: 15.6858\n",
      "Epoch 8/200, Train Loss: 16.7002, Val Loss: 15.6870\n",
      "Epoch 9/200, Train Loss: 16.6902, Val Loss: 15.6767\n",
      "  New best validation loss: 15.6767\n",
      "Epoch 10/200, Train Loss: 16.6827, Val Loss: 15.6847\n",
      "Epoch 11/200, Train Loss: 16.6715, Val Loss: 15.7000\n",
      "Epoch 12/200, Train Loss: 16.6680, Val Loss: 15.6926\n",
      "Epoch 13/200, Train Loss: 16.6624, Val Loss: 15.6913\n",
      "Epoch 14/200, Train Loss: 16.6149, Val Loss: 15.6870\n",
      "Epoch 15/200, Train Loss: 16.5734, Val Loss: 15.6677\n",
      "  New best validation loss: 15.6677\n",
      "Epoch 16/200, Train Loss: 16.5661, Val Loss: 15.6570\n",
      "  New best validation loss: 15.6570\n",
      "Epoch 17/200, Train Loss: 16.5426, Val Loss: 15.6210\n",
      "  New best validation loss: 15.6210\n",
      "Epoch 18/200, Train Loss: 16.5334, Val Loss: 15.6048\n",
      "  New best validation loss: 15.6048\n",
      "Epoch 19/200, Train Loss: 16.5201, Val Loss: 15.6562\n",
      "Epoch 20/200, Train Loss: 16.4980, Val Loss: 15.6532\n",
      "Epoch 21/200, Train Loss: 16.4936, Val Loss: 15.6130\n",
      "Epoch 22/200, Train Loss: 16.4710, Val Loss: 15.5833\n",
      "  New best validation loss: 15.5833\n",
      "Epoch 23/200, Train Loss: 16.4612, Val Loss: 15.5893\n",
      "Epoch 24/200, Train Loss: 16.4429, Val Loss: 15.6121\n",
      "Epoch 25/200, Train Loss: 16.4143, Val Loss: 15.5718\n",
      "  New best validation loss: 15.5718\n",
      "Epoch 26/200, Train Loss: 16.4102, Val Loss: 15.5320\n",
      "  New best validation loss: 15.5320\n",
      "Epoch 27/200, Train Loss: 16.3877, Val Loss: 15.5786\n",
      "Epoch 28/200, Train Loss: 16.3770, Val Loss: 15.5415\n",
      "Epoch 29/200, Train Loss: 16.3542, Val Loss: 15.5298\n",
      "  New best validation loss: 15.5298\n",
      "Epoch 30/200, Train Loss: 16.3401, Val Loss: 15.4543\n",
      "  New best validation loss: 15.4543\n",
      "Epoch 31/200, Train Loss: 16.3067, Val Loss: 15.5315\n",
      "Epoch 32/200, Train Loss: 16.2883, Val Loss: 15.4062\n",
      "  New best validation loss: 15.4062\n",
      "Epoch 33/200, Train Loss: 16.2691, Val Loss: 15.3012\n",
      "  New best validation loss: 15.3012\n",
      "Epoch 34/200, Train Loss: 16.1698, Val Loss: 15.2958\n",
      "  New best validation loss: 15.2958\n",
      "Epoch 35/200, Train Loss: 16.0825, Val Loss: 15.0460\n",
      "  New best validation loss: 15.0460\n",
      "Epoch 36/200, Train Loss: 15.9303, Val Loss: 15.0054\n",
      "  New best validation loss: 15.0054\n",
      "Epoch 37/200, Train Loss: 15.7885, Val Loss: 14.8532\n",
      "  New best validation loss: 14.8532\n",
      "Epoch 38/200, Train Loss: 15.6226, Val Loss: 14.6649\n",
      "  New best validation loss: 14.6649\n",
      "Epoch 39/200, Train Loss: 15.5702, Val Loss: 14.7146\n",
      "Epoch 40/200, Train Loss: 15.5812, Val Loss: 14.7293\n",
      "Epoch 41/200, Train Loss: 15.4675, Val Loss: 14.6823\n",
      "Epoch 42/200, Train Loss: 15.3847, Val Loss: 14.5676\n",
      "  New best validation loss: 14.5676\n",
      "Epoch 43/200, Train Loss: 15.2675, Val Loss: 14.5966\n",
      "Epoch 44/200, Train Loss: 15.2432, Val Loss: 14.6988\n",
      "Epoch 45/200, Train Loss: 15.1726, Val Loss: 14.4471\n",
      "  New best validation loss: 14.4471\n",
      "Epoch 46/200, Train Loss: 15.1418, Val Loss: 14.4319\n",
      "  New best validation loss: 14.4319\n",
      "Epoch 47/200, Train Loss: 15.0592, Val Loss: 14.5539\n",
      "Epoch 48/200, Train Loss: 15.1406, Val Loss: 14.3728\n",
      "  New best validation loss: 14.3728\n",
      "Epoch 49/200, Train Loss: 14.9893, Val Loss: 14.3760\n",
      "Epoch 50/200, Train Loss: 15.0093, Val Loss: 14.3044\n",
      "  New best validation loss: 14.3044\n",
      "Epoch 51/200, Train Loss: 14.9880, Val Loss: 14.4841\n",
      "Epoch 52/200, Train Loss: 14.8460, Val Loss: 14.2103\n",
      "  New best validation loss: 14.2103\n",
      "Epoch 53/200, Train Loss: 14.7400, Val Loss: 14.1698\n",
      "  New best validation loss: 14.1698\n",
      "Epoch 54/200, Train Loss: 14.7096, Val Loss: 14.1449\n",
      "  New best validation loss: 14.1449\n",
      "Epoch 55/200, Train Loss: 14.7226, Val Loss: 14.0493\n",
      "  New best validation loss: 14.0493\n",
      "Epoch 56/200, Train Loss: 14.8460, Val Loss: 14.1391\n",
      "Epoch 57/200, Train Loss: 14.7392, Val Loss: 14.2525\n",
      "Epoch 58/200, Train Loss: 14.6440, Val Loss: 13.9603\n",
      "  New best validation loss: 13.9603\n",
      "Epoch 59/200, Train Loss: 14.6179, Val Loss: 14.1976\n",
      "Epoch 60/200, Train Loss: 14.5961, Val Loss: 14.0078\n",
      "Epoch 61/200, Train Loss: 14.5904, Val Loss: 14.0126\n",
      "Epoch 62/200, Train Loss: 14.5661, Val Loss: 13.9587\n",
      "  New best validation loss: 13.9587\n",
      "Epoch 63/200, Train Loss: 14.5728, Val Loss: 13.8763\n",
      "  New best validation loss: 13.8763\n",
      "Epoch 64/200, Train Loss: 14.5731, Val Loss: 14.0442\n",
      "Epoch 65/200, Train Loss: 14.6847, Val Loss: 13.8331\n",
      "  New best validation loss: 13.8331\n",
      "Epoch 66/200, Train Loss: 14.4275, Val Loss: 13.7962\n",
      "  New best validation loss: 13.7962\n",
      "Epoch 67/200, Train Loss: 14.4585, Val Loss: 13.9900\n",
      "Epoch 68/200, Train Loss: 14.3475, Val Loss: 13.8303\n",
      "Epoch 69/200, Train Loss: 14.3028, Val Loss: 13.6984\n",
      "  New best validation loss: 13.6984\n",
      "Epoch 70/200, Train Loss: 14.2218, Val Loss: 13.6150\n",
      "  New best validation loss: 13.6150\n",
      "Epoch 71/200, Train Loss: 14.2679, Val Loss: 13.5829\n",
      "  New best validation loss: 13.5829\n",
      "Epoch 72/200, Train Loss: 14.2987, Val Loss: 13.6700\n",
      "Epoch 73/200, Train Loss: 14.1861, Val Loss: 13.6007\n",
      "Epoch 74/200, Train Loss: 14.1659, Val Loss: 13.5819\n",
      "  New best validation loss: 13.5819\n",
      "Epoch 75/200, Train Loss: 14.1895, Val Loss: 13.6469\n",
      "Epoch 76/200, Train Loss: 14.1372, Val Loss: 13.4625\n",
      "  New best validation loss: 13.4625\n",
      "Epoch 77/200, Train Loss: 14.1099, Val Loss: 13.6492\n",
      "Epoch 78/200, Train Loss: 14.0447, Val Loss: 13.4291\n",
      "  New best validation loss: 13.4291\n",
      "Epoch 79/200, Train Loss: 14.0246, Val Loss: 13.3391\n",
      "  New best validation loss: 13.3391\n",
      "Epoch 80/200, Train Loss: 13.9815, Val Loss: 13.3525\n",
      "Epoch 81/200, Train Loss: 14.0694, Val Loss: 13.3281\n",
      "  New best validation loss: 13.3281\n",
      "Epoch 82/200, Train Loss: 14.0170, Val Loss: 13.3625\n",
      "Epoch 83/200, Train Loss: 13.9675, Val Loss: 13.2855\n",
      "  New best validation loss: 13.2855\n",
      "Epoch 84/200, Train Loss: 13.9333, Val Loss: 13.2284\n",
      "  New best validation loss: 13.2284\n",
      "Epoch 85/200, Train Loss: 13.8889, Val Loss: 13.3394\n",
      "Epoch 86/200, Train Loss: 13.8695, Val Loss: 13.3539\n",
      "Epoch 87/200, Train Loss: 13.8421, Val Loss: 13.2255\n",
      "  New best validation loss: 13.2255\n",
      "Epoch 88/200, Train Loss: 13.8885, Val Loss: 13.2604\n",
      "Epoch 89/200, Train Loss: 13.8404, Val Loss: 13.3207\n",
      "Epoch 90/200, Train Loss: 13.7940, Val Loss: 13.1422\n",
      "  New best validation loss: 13.1422\n",
      "Epoch 91/200, Train Loss: 13.7814, Val Loss: 13.0746\n",
      "  New best validation loss: 13.0746\n",
      "Epoch 92/200, Train Loss: 13.7827, Val Loss: 13.2732\n",
      "Epoch 93/200, Train Loss: 13.8112, Val Loss: 13.0487\n",
      "  New best validation loss: 13.0487\n",
      "Epoch 94/200, Train Loss: 13.7390, Val Loss: 13.1133\n",
      "Epoch 95/200, Train Loss: 13.7878, Val Loss: 13.2076\n",
      "Epoch 96/200, Train Loss: 13.6575, Val Loss: 13.0436\n",
      "  New best validation loss: 13.0436\n",
      "Epoch 97/200, Train Loss: 13.7198, Val Loss: 13.0588\n",
      "Epoch 98/200, Train Loss: 13.6656, Val Loss: 12.9295\n",
      "  New best validation loss: 12.9295\n",
      "Epoch 99/200, Train Loss: 13.6155, Val Loss: 12.9296\n",
      "Epoch 100/200, Train Loss: 13.6499, Val Loss: 12.8906\n",
      "  New best validation loss: 12.8906\n",
      "Epoch 101/200, Train Loss: 13.5759, Val Loss: 13.2192\n",
      "Epoch 102/200, Train Loss: 13.5601, Val Loss: 12.8770\n",
      "  New best validation loss: 12.8770\n",
      "Epoch 103/200, Train Loss: 13.5611, Val Loss: 12.8806\n",
      "Epoch 104/200, Train Loss: 13.5589, Val Loss: 12.7839\n",
      "  New best validation loss: 12.7839\n",
      "Epoch 105/200, Train Loss: 13.5034, Val Loss: 12.9346\n",
      "Epoch 106/200, Train Loss: 13.5687, Val Loss: 13.0056\n",
      "Epoch 107/200, Train Loss: 13.5160, Val Loss: 13.0254\n",
      "Epoch 108/200, Train Loss: 13.4722, Val Loss: 12.7665\n",
      "  New best validation loss: 12.7665\n",
      "Epoch 109/200, Train Loss: 13.4428, Val Loss: 12.7063\n",
      "  New best validation loss: 12.7063\n",
      "Epoch 110/200, Train Loss: 13.4346, Val Loss: 12.9768\n",
      "Epoch 111/200, Train Loss: 13.3963, Val Loss: 12.8494\n",
      "Epoch 112/200, Train Loss: 13.4117, Val Loss: 12.6899\n",
      "  New best validation loss: 12.6899\n",
      "Epoch 113/200, Train Loss: 13.4582, Val Loss: 12.8337\n",
      "Epoch 114/200, Train Loss: 13.3737, Val Loss: 12.6658\n",
      "  New best validation loss: 12.6658\n",
      "Epoch 115/200, Train Loss: 13.3416, Val Loss: 12.5935\n",
      "  New best validation loss: 12.5935\n",
      "Epoch 116/200, Train Loss: 13.3041, Val Loss: 12.8900\n",
      "Epoch 117/200, Train Loss: 13.3435, Val Loss: 12.6940\n",
      "Epoch 118/200, Train Loss: 13.2933, Val Loss: 12.7208\n",
      "Epoch 119/200, Train Loss: 13.2794, Val Loss: 12.5017\n",
      "  New best validation loss: 12.5017\n",
      "Epoch 120/200, Train Loss: 13.3203, Val Loss: 12.6180\n",
      "Epoch 121/200, Train Loss: 13.3109, Val Loss: 12.5123\n",
      "Epoch 122/200, Train Loss: 13.3428, Val Loss: 12.4919\n",
      "  New best validation loss: 12.4919\n",
      "Epoch 123/200, Train Loss: 13.2261, Val Loss: 12.5665\n",
      "Epoch 124/200, Train Loss: 13.2135, Val Loss: 12.4947\n",
      "Epoch 125/200, Train Loss: 13.1921, Val Loss: 12.7839\n",
      "Epoch 126/200, Train Loss: 13.3048, Val Loss: 12.7100\n",
      "Epoch 127/200, Train Loss: 13.2812, Val Loss: 12.7628\n",
      "Epoch 128/200, Train Loss: 13.2044, Val Loss: 12.4751\n",
      "  New best validation loss: 12.4751\n",
      "Epoch 129/200, Train Loss: 13.2627, Val Loss: 12.6494\n",
      "Epoch 130/200, Train Loss: 13.2674, Val Loss: 12.7584\n",
      "Epoch 131/200, Train Loss: 13.1586, Val Loss: 12.6074\n",
      "Epoch 132/200, Train Loss: 13.1464, Val Loss: 12.6003\n",
      "Epoch 133/200, Train Loss: 13.1674, Val Loss: 12.3931\n",
      "  New best validation loss: 12.3931\n",
      "Epoch 134/200, Train Loss: 13.1114, Val Loss: 12.9390\n",
      "Epoch 135/200, Train Loss: 13.0899, Val Loss: 12.3874\n",
      "  New best validation loss: 12.3874\n",
      "Epoch 136/200, Train Loss: 13.0926, Val Loss: 12.6752\n",
      "Epoch 137/200, Train Loss: 13.0391, Val Loss: 12.5607\n",
      "Epoch 138/200, Train Loss: 12.9861, Val Loss: 12.3523\n",
      "  New best validation loss: 12.3523\n",
      "Epoch 139/200, Train Loss: 13.0396, Val Loss: 12.5710\n",
      "Epoch 140/200, Train Loss: 13.0492, Val Loss: 12.5797\n",
      "Epoch 141/200, Train Loss: 13.0246, Val Loss: 12.3559\n",
      "Epoch 142/200, Train Loss: 12.9629, Val Loss: 12.5544\n",
      "Epoch 143/200, Train Loss: 12.9874, Val Loss: 12.6176\n",
      "Epoch 144/200, Train Loss: 12.9896, Val Loss: 12.3152\n",
      "  New best validation loss: 12.3152\n",
      "Epoch 145/200, Train Loss: 12.9582, Val Loss: 12.3366\n",
      "Epoch 146/200, Train Loss: 13.0003, Val Loss: 12.4238\n",
      "Epoch 147/200, Train Loss: 12.9999, Val Loss: 12.3763\n",
      "Epoch 148/200, Train Loss: 12.8970, Val Loss: 12.3226\n",
      "Epoch 149/200, Train Loss: 12.9274, Val Loss: 12.5710\n",
      "Epoch 150/200, Train Loss: 12.9202, Val Loss: 12.3105\n",
      "  New best validation loss: 12.3105\n",
      "Epoch 151/200, Train Loss: 12.8730, Val Loss: 12.4491\n",
      "Epoch 152/200, Train Loss: 12.8653, Val Loss: 12.2964\n",
      "  New best validation loss: 12.2964\n",
      "Epoch 153/200, Train Loss: 12.8736, Val Loss: 12.3271\n",
      "Epoch 154/200, Train Loss: 12.8766, Val Loss: 12.3385\n",
      "Epoch 155/200, Train Loss: 12.9670, Val Loss: 12.2607\n",
      "  New best validation loss: 12.2607\n",
      "Epoch 156/200, Train Loss: 12.9192, Val Loss: 12.5373\n",
      "Epoch 157/200, Train Loss: 12.8632, Val Loss: 12.3584\n",
      "Epoch 158/200, Train Loss: 12.8253, Val Loss: 12.6784\n",
      "Epoch 159/200, Train Loss: 12.7775, Val Loss: 12.5684\n",
      "Epoch 160/200, Train Loss: 12.8797, Val Loss: 12.2574\n",
      "  New best validation loss: 12.2574\n",
      "Epoch 161/200, Train Loss: 12.8205, Val Loss: 12.1883\n",
      "  New best validation loss: 12.1883\n",
      "Epoch 162/200, Train Loss: 12.6872, Val Loss: 12.2020\n",
      "Epoch 163/200, Train Loss: 12.7369, Val Loss: 12.2111\n",
      "Epoch 164/200, Train Loss: 12.7180, Val Loss: 12.3619\n",
      "Epoch 165/200, Train Loss: 12.8008, Val Loss: 12.5685\n",
      "Epoch 166/200, Train Loss: 12.7507, Val Loss: 12.8997\n",
      "Epoch 167/200, Train Loss: 12.7956, Val Loss: 12.4245\n",
      "Epoch 168/200, Train Loss: 12.6586, Val Loss: 12.2152\n",
      "Epoch 169/200, Train Loss: 12.7684, Val Loss: 12.2132\n",
      "Epoch 170/200, Train Loss: 12.6955, Val Loss: 12.3760\n",
      "Epoch 171/200, Train Loss: 12.6520, Val Loss: 12.3432\n",
      "Epoch 172/200, Train Loss: 12.6210, Val Loss: 12.2268\n",
      "Epoch 173/200, Train Loss: 12.6101, Val Loss: 12.2621\n",
      "Epoch 174/200, Train Loss: 12.6829, Val Loss: 12.4748\n",
      "Epoch 175/200, Train Loss: 12.5801, Val Loss: 12.1034\n",
      "  New best validation loss: 12.1034\n",
      "Epoch 176/200, Train Loss: 12.5560, Val Loss: 12.2594\n",
      "Epoch 177/200, Train Loss: 12.4956, Val Loss: 12.3398\n",
      "Epoch 178/200, Train Loss: 12.5962, Val Loss: 12.2225\n",
      "Epoch 179/200, Train Loss: 12.6451, Val Loss: 12.1599\n",
      "Epoch 180/200, Train Loss: 12.6055, Val Loss: 12.1746\n",
      "Epoch 181/200, Train Loss: 12.5053, Val Loss: 12.3817\n",
      "Epoch 182/200, Train Loss: 12.6023, Val Loss: 12.1699\n",
      "Epoch 183/200, Train Loss: 12.4454, Val Loss: 12.1072\n",
      "Epoch 184/200, Train Loss: 12.4591, Val Loss: 12.1397\n",
      "Epoch 185/200, Train Loss: 12.4706, Val Loss: 12.1987\n",
      "Epoch 186/200, Train Loss: 12.4008, Val Loss: 12.2050\n",
      "Epoch 187/200, Train Loss: 12.5674, Val Loss: 12.1914\n",
      "Epoch 188/200, Train Loss: 12.4509, Val Loss: 12.1971\n",
      "Epoch 189/200, Train Loss: 12.4767, Val Loss: 12.1657\n",
      "Epoch 190/200, Train Loss: 12.3483, Val Loss: 12.2339\n",
      "Epoch 191/200, Train Loss: 12.4693, Val Loss: 12.3718\n",
      "Epoch 192/200, Train Loss: 12.4640, Val Loss: 12.0718\n",
      "  New best validation loss: 12.0718\n",
      "Epoch 193/200, Train Loss: 12.3701, Val Loss: 12.2284\n",
      "Epoch 194/200, Train Loss: 12.3740, Val Loss: 12.3430\n",
      "Epoch 195/200, Train Loss: 12.2952, Val Loss: 12.0533\n",
      "  New best validation loss: 12.0533\n",
      "Epoch 196/200, Train Loss: 12.2507, Val Loss: 12.2149\n",
      "Epoch 197/200, Train Loss: 12.3232, Val Loss: 12.1233\n",
      "Epoch 198/200, Train Loss: 12.2916, Val Loss: 12.1764\n",
      "Epoch 199/200, Train Loss: 12.2588, Val Loss: 12.1413\n",
      "Epoch 200/200, Train Loss: 12.2346, Val Loss: 12.2253\n",
      "\n",
      "Loaded best model (Val Loss: 12.0533) for final hidden state extraction.\n",
      "Saved best model for RNN_GRU (samples=1280) to results_data_size_sweep/20250514_045146/samples_1280/RNN_GRU_samples_1280_best.pt\n",
      "\n",
      "--- Performing Decodability Analysis for RNN_GRU (samples=1280, k=15) ---\n",
      "  Analyzing decodability for RNN_GRU...\n",
      "  Hidden states shape: torch.Size([160, 200, 64])\n",
      "  Coefficients shape: torch.Size([160, 15])\n",
      "  Processed hidden states shape for decoder: torch.Size([160, 64])\n",
      "  RidgeCV Decoder for RNN_GRU - Test MSE: 0.9924, Test R2: 0.4977 (best alpha: 2.6367)\n",
      "  Decodability plot saved to results_data_size_sweep/20250514_045146/samples_1280/decodability_RNN_GRU_coeff1.png\n",
      "Decodability (R2 score) for RNN_GRU (samples=1280): 0.4977\n",
      "\n",
      "--- Training Transformer (samples=1280, k=15) ---\n",
      "Number of parameters: 85809\n",
      "Epoch 1/200, Train Loss: 17.2156, Val Loss: 15.9319\n",
      "  New best validation loss: 15.9319\n",
      "Epoch 2/200, Train Loss: 16.8876, Val Loss: 15.8377\n",
      "  New best validation loss: 15.8377\n",
      "Epoch 3/200, Train Loss: 16.9006, Val Loss: 15.7763\n",
      "  New best validation loss: 15.7763\n",
      "Epoch 4/200, Train Loss: 16.8833, Val Loss: 15.7797\n",
      "Epoch 5/200, Train Loss: 16.8713, Val Loss: 15.7723\n",
      "  New best validation loss: 15.7723\n",
      "Epoch 6/200, Train Loss: 16.8555, Val Loss: 15.7822\n",
      "Epoch 7/200, Train Loss: 16.8732, Val Loss: 15.8057\n",
      "Epoch 8/200, Train Loss: 16.8731, Val Loss: 15.7749\n",
      "Epoch 9/200, Train Loss: 16.8419, Val Loss: 15.8292\n",
      "Epoch 10/200, Train Loss: 16.8573, Val Loss: 15.7284\n",
      "  New best validation loss: 15.7284\n",
      "Epoch 11/200, Train Loss: 16.8477, Val Loss: 15.7170\n",
      "  New best validation loss: 15.7170\n",
      "Epoch 12/200, Train Loss: 16.8302, Val Loss: 15.8235\n",
      "Epoch 13/200, Train Loss: 16.8291, Val Loss: 15.7774\n",
      "Epoch 14/200, Train Loss: 16.8202, Val Loss: 15.9054\n",
      "Epoch 15/200, Train Loss: 16.8233, Val Loss: 15.7215\n",
      "Epoch 16/200, Train Loss: 16.8249, Val Loss: 15.7646\n",
      "Epoch 17/200, Train Loss: 16.8081, Val Loss: 15.7671\n",
      "Epoch 18/200, Train Loss: 16.7911, Val Loss: 15.8221\n",
      "Epoch 19/200, Train Loss: 16.7946, Val Loss: 15.7102\n",
      "  New best validation loss: 15.7102\n",
      "Epoch 20/200, Train Loss: 16.7867, Val Loss: 15.7187\n",
      "Epoch 21/200, Train Loss: 16.7690, Val Loss: 15.6361\n",
      "  New best validation loss: 15.6361\n",
      "Epoch 22/200, Train Loss: 16.7670, Val Loss: 15.6179\n",
      "  New best validation loss: 15.6179\n",
      "Epoch 23/200, Train Loss: 16.7505, Val Loss: 15.6656\n",
      "Epoch 24/200, Train Loss: 16.7806, Val Loss: 15.5886\n",
      "  New best validation loss: 15.5886\n",
      "Epoch 25/200, Train Loss: 16.7432, Val Loss: 15.5880\n",
      "  New best validation loss: 15.5880\n",
      "Epoch 26/200, Train Loss: 16.7221, Val Loss: 15.5153\n",
      "  New best validation loss: 15.5153\n",
      "Epoch 27/200, Train Loss: 16.7194, Val Loss: 15.5183\n",
      "Epoch 28/200, Train Loss: 16.6937, Val Loss: 15.4898\n",
      "  New best validation loss: 15.4898\n",
      "Epoch 29/200, Train Loss: 16.6699, Val Loss: 15.5192\n",
      "Epoch 30/200, Train Loss: 16.6781, Val Loss: 15.4370\n",
      "  New best validation loss: 15.4370\n",
      "Epoch 31/200, Train Loss: 16.6489, Val Loss: 15.7050\n",
      "Epoch 32/200, Train Loss: 16.6386, Val Loss: 15.3185\n",
      "  New best validation loss: 15.3185\n",
      "Epoch 33/200, Train Loss: 16.5665, Val Loss: 15.3678\n",
      "Epoch 34/200, Train Loss: 16.5894, Val Loss: 15.2721\n",
      "  New best validation loss: 15.2721\n",
      "Epoch 35/200, Train Loss: 16.6229, Val Loss: 15.2512\n",
      "  New best validation loss: 15.2512\n",
      "Epoch 36/200, Train Loss: 16.4696, Val Loss: 15.1928\n",
      "  New best validation loss: 15.1928\n",
      "Epoch 37/200, Train Loss: 16.3748, Val Loss: 15.0265\n",
      "  New best validation loss: 15.0265\n",
      "Epoch 38/200, Train Loss: 16.3310, Val Loss: 14.8718\n",
      "  New best validation loss: 14.8718\n",
      "Epoch 39/200, Train Loss: 16.1453, Val Loss: 14.5409\n",
      "  New best validation loss: 14.5409\n",
      "Epoch 40/200, Train Loss: 15.9866, Val Loss: 14.4061\n",
      "  New best validation loss: 14.4061\n",
      "Epoch 41/200, Train Loss: 15.7136, Val Loss: 13.7969\n",
      "  New best validation loss: 13.7969\n",
      "Epoch 42/200, Train Loss: 15.4894, Val Loss: 13.7638\n",
      "  New best validation loss: 13.7638\n",
      "Epoch 43/200, Train Loss: 15.2772, Val Loss: 13.5764\n",
      "  New best validation loss: 13.5764\n",
      "Epoch 44/200, Train Loss: 15.0945, Val Loss: 12.9994\n",
      "  New best validation loss: 12.9994\n",
      "Epoch 45/200, Train Loss: 14.7525, Val Loss: 12.4915\n",
      "  New best validation loss: 12.4915\n",
      "Epoch 46/200, Train Loss: 14.4664, Val Loss: 12.4709\n",
      "  New best validation loss: 12.4709\n",
      "Epoch 47/200, Train Loss: 14.1227, Val Loss: 11.9481\n",
      "  New best validation loss: 11.9481\n",
      "Epoch 48/200, Train Loss: 13.9341, Val Loss: 11.7129\n",
      "  New best validation loss: 11.7129\n",
      "Epoch 49/200, Train Loss: 13.7843, Val Loss: 11.6688\n",
      "  New best validation loss: 11.6688\n",
      "Epoch 50/200, Train Loss: 13.5950, Val Loss: 11.7731\n",
      "Epoch 51/200, Train Loss: 13.4122, Val Loss: 11.6777\n",
      "Epoch 52/200, Train Loss: 13.2696, Val Loss: 11.2167\n",
      "  New best validation loss: 11.2167\n",
      "Epoch 53/200, Train Loss: 13.2226, Val Loss: 11.4839\n",
      "Epoch 54/200, Train Loss: 13.1162, Val Loss: 11.4133\n",
      "Epoch 55/200, Train Loss: 12.9975, Val Loss: 11.0614\n",
      "  New best validation loss: 11.0614\n",
      "Epoch 56/200, Train Loss: 12.8317, Val Loss: 11.5963\n",
      "Epoch 57/200, Train Loss: 12.8054, Val Loss: 11.0058\n",
      "  New best validation loss: 11.0058\n",
      "Epoch 58/200, Train Loss: 12.6589, Val Loss: 11.0648\n",
      "Epoch 59/200, Train Loss: 12.5153, Val Loss: 10.9208\n",
      "  New best validation loss: 10.9208\n",
      "Epoch 60/200, Train Loss: 12.5268, Val Loss: 10.8068\n",
      "  New best validation loss: 10.8068\n",
      "Epoch 61/200, Train Loss: 12.4365, Val Loss: 10.8785\n",
      "Epoch 62/200, Train Loss: 12.3348, Val Loss: 10.8476\n",
      "Epoch 63/200, Train Loss: 12.2996, Val Loss: 10.6961\n",
      "  New best validation loss: 10.6961\n",
      "Epoch 64/200, Train Loss: 12.2687, Val Loss: 10.8098\n",
      "Epoch 65/200, Train Loss: 12.1794, Val Loss: 10.9214\n",
      "Epoch 66/200, Train Loss: 12.1572, Val Loss: 11.0068\n",
      "Epoch 67/200, Train Loss: 12.0950, Val Loss: 10.7824\n",
      "Epoch 68/200, Train Loss: 12.0317, Val Loss: 10.6926\n",
      "  New best validation loss: 10.6926\n",
      "Epoch 69/200, Train Loss: 12.1398, Val Loss: 10.5757\n",
      "  New best validation loss: 10.5757\n",
      "Epoch 70/200, Train Loss: 12.0259, Val Loss: 10.5210\n",
      "  New best validation loss: 10.5210\n",
      "Epoch 71/200, Train Loss: 11.9698, Val Loss: 10.4858\n",
      "  New best validation loss: 10.4858\n",
      "Epoch 72/200, Train Loss: 11.9469, Val Loss: 10.4440\n",
      "  New best validation loss: 10.4440\n",
      "Epoch 73/200, Train Loss: 11.9127, Val Loss: 10.6497\n",
      "Epoch 74/200, Train Loss: 11.8285, Val Loss: 10.4798\n",
      "Epoch 75/200, Train Loss: 11.8708, Val Loss: 10.6792\n",
      "Epoch 76/200, Train Loss: 11.7808, Val Loss: 10.5827\n",
      "Epoch 77/200, Train Loss: 11.7809, Val Loss: 10.5878\n",
      "Epoch 78/200, Train Loss: 11.8162, Val Loss: 10.4177\n",
      "  New best validation loss: 10.4177\n",
      "Epoch 79/200, Train Loss: 11.6880, Val Loss: 10.3294\n",
      "  New best validation loss: 10.3294\n",
      "Epoch 80/200, Train Loss: 11.7493, Val Loss: 10.4639\n",
      "Epoch 81/200, Train Loss: 11.6605, Val Loss: 10.3719\n",
      "Epoch 82/200, Train Loss: 11.6092, Val Loss: 10.3879\n",
      "Epoch 83/200, Train Loss: 11.6994, Val Loss: 10.5048\n",
      "Epoch 84/200, Train Loss: 11.6422, Val Loss: 10.3198\n",
      "  New best validation loss: 10.3198\n",
      "Epoch 85/200, Train Loss: 11.5590, Val Loss: 10.3586\n",
      "Epoch 86/200, Train Loss: 11.5042, Val Loss: 10.2845\n",
      "  New best validation loss: 10.2845\n",
      "Epoch 87/200, Train Loss: 11.4853, Val Loss: 10.3556\n",
      "Epoch 88/200, Train Loss: 11.5055, Val Loss: 10.3509\n",
      "Epoch 89/200, Train Loss: 11.4761, Val Loss: 10.2442\n",
      "  New best validation loss: 10.2442\n",
      "Epoch 90/200, Train Loss: 11.3846, Val Loss: 10.3630\n",
      "Epoch 91/200, Train Loss: 11.5257, Val Loss: 10.3802\n",
      "Epoch 92/200, Train Loss: 11.4676, Val Loss: 10.2507\n",
      "Epoch 93/200, Train Loss: 11.4170, Val Loss: 10.2529\n",
      "Epoch 94/200, Train Loss: 11.4680, Val Loss: 10.1282\n",
      "  New best validation loss: 10.1282\n",
      "Epoch 95/200, Train Loss: 11.3619, Val Loss: 10.2380\n",
      "Epoch 96/200, Train Loss: 11.5053, Val Loss: 10.2842\n",
      "Epoch 97/200, Train Loss: 11.4368, Val Loss: 10.1513\n",
      "Epoch 98/200, Train Loss: 11.3860, Val Loss: 10.3847\n",
      "Epoch 99/200, Train Loss: 11.3157, Val Loss: 10.2437\n",
      "Epoch 100/200, Train Loss: 11.2827, Val Loss: 10.2648\n",
      "Epoch 101/200, Train Loss: 11.2560, Val Loss: 10.2242\n",
      "Epoch 102/200, Train Loss: 11.3107, Val Loss: 10.2100\n",
      "Epoch 103/200, Train Loss: 11.2547, Val Loss: 10.1584\n",
      "Epoch 104/200, Train Loss: 11.3080, Val Loss: 10.1744\n",
      "Epoch 105/200, Train Loss: 11.2536, Val Loss: 10.1868\n",
      "Epoch 106/200, Train Loss: 11.2555, Val Loss: 10.3115\n",
      "Epoch 107/200, Train Loss: 11.3476, Val Loss: 10.1779\n",
      "Epoch 108/200, Train Loss: 11.2142, Val Loss: 10.2498\n",
      "Epoch 109/200, Train Loss: 11.2271, Val Loss: 10.0180\n",
      "  New best validation loss: 10.0180\n",
      "Epoch 110/200, Train Loss: 11.3543, Val Loss: 10.1491\n",
      "Epoch 111/200, Train Loss: 11.2083, Val Loss: 10.0439\n",
      "Epoch 112/200, Train Loss: 11.2064, Val Loss: 10.1239\n",
      "Epoch 113/200, Train Loss: 11.2284, Val Loss: 10.1988\n",
      "Epoch 114/200, Train Loss: 11.1836, Val Loss: 10.1347\n",
      "Epoch 115/200, Train Loss: 11.2251, Val Loss: 10.1505\n",
      "Epoch 116/200, Train Loss: 11.2111, Val Loss: 10.1911\n",
      "Epoch 117/200, Train Loss: 11.1935, Val Loss: 10.0791\n",
      "Epoch 118/200, Train Loss: 11.1565, Val Loss: 10.1271\n",
      "Epoch 119/200, Train Loss: 11.2226, Val Loss: 10.0296\n",
      "Epoch 120/200, Train Loss: 11.1826, Val Loss: 10.1894\n",
      "Epoch 121/200, Train Loss: 11.1283, Val Loss: 10.0460\n",
      "Epoch 122/200, Train Loss: 11.1367, Val Loss: 10.1599\n",
      "Epoch 123/200, Train Loss: 11.2012, Val Loss: 10.1461\n",
      "Epoch 124/200, Train Loss: 11.1441, Val Loss: 10.0977\n",
      "Epoch 125/200, Train Loss: 11.1080, Val Loss: 10.1578\n",
      "Epoch 126/200, Train Loss: 11.1272, Val Loss: 10.3240\n",
      "Epoch 127/200, Train Loss: 11.1642, Val Loss: 10.1187\n",
      "Epoch 128/200, Train Loss: 11.2059, Val Loss: 10.0843\n",
      "Epoch 129/200, Train Loss: 11.0730, Val Loss: 10.0397\n",
      "Epoch 130/200, Train Loss: 11.1603, Val Loss: 10.3070\n",
      "Epoch 131/200, Train Loss: 11.1077, Val Loss: 10.0924\n",
      "Epoch 132/200, Train Loss: 11.0977, Val Loss: 10.0398\n",
      "Epoch 133/200, Train Loss: 11.1518, Val Loss: 10.0108\n",
      "  New best validation loss: 10.0108\n",
      "Epoch 134/200, Train Loss: 11.0654, Val Loss: 10.0635\n",
      "Epoch 135/200, Train Loss: 11.1056, Val Loss: 9.9715\n",
      "  New best validation loss: 9.9715\n",
      "Epoch 136/200, Train Loss: 11.0916, Val Loss: 10.0198\n",
      "Epoch 137/200, Train Loss: 11.1237, Val Loss: 9.8611\n",
      "  New best validation loss: 9.8611\n",
      "Epoch 138/200, Train Loss: 11.0670, Val Loss: 10.0471\n",
      "Epoch 139/200, Train Loss: 11.0326, Val Loss: 9.9008\n",
      "Epoch 140/200, Train Loss: 11.0259, Val Loss: 10.0400\n",
      "Epoch 141/200, Train Loss: 11.1102, Val Loss: 10.0466\n",
      "Epoch 142/200, Train Loss: 10.9885, Val Loss: 10.0446\n",
      "Epoch 143/200, Train Loss: 11.0729, Val Loss: 10.2427\n",
      "Epoch 144/200, Train Loss: 11.0287, Val Loss: 10.0348\n",
      "Epoch 145/200, Train Loss: 11.0592, Val Loss: 9.8555\n",
      "  New best validation loss: 9.8555\n",
      "Epoch 146/200, Train Loss: 11.0874, Val Loss: 10.0643\n",
      "Epoch 147/200, Train Loss: 11.0087, Val Loss: 10.0988\n",
      "Epoch 148/200, Train Loss: 11.0462, Val Loss: 9.9171\n",
      "Epoch 149/200, Train Loss: 11.0236, Val Loss: 9.9830\n",
      "Epoch 150/200, Train Loss: 11.0107, Val Loss: 9.9765\n",
      "Epoch 151/200, Train Loss: 10.9820, Val Loss: 9.9260\n",
      "Epoch 152/200, Train Loss: 11.0182, Val Loss: 9.9259\n",
      "Epoch 153/200, Train Loss: 10.9988, Val Loss: 9.9353\n",
      "Epoch 154/200, Train Loss: 11.0170, Val Loss: 10.0232\n",
      "Epoch 155/200, Train Loss: 10.9956, Val Loss: 10.0729\n",
      "Epoch 156/200, Train Loss: 10.9974, Val Loss: 9.9598\n",
      "Epoch 157/200, Train Loss: 10.9477, Val Loss: 10.0269\n",
      "Epoch 158/200, Train Loss: 11.0044, Val Loss: 9.9921\n",
      "Epoch 159/200, Train Loss: 11.0476, Val Loss: 9.8886\n",
      "Epoch 160/200, Train Loss: 11.0399, Val Loss: 10.0756\n",
      "Epoch 161/200, Train Loss: 10.9683, Val Loss: 9.9890\n",
      "Epoch 162/200, Train Loss: 10.9029, Val Loss: 9.8990\n",
      "Epoch 163/200, Train Loss: 10.9550, Val Loss: 10.0137\n",
      "Epoch 164/200, Train Loss: 10.9363, Val Loss: 10.0329\n",
      "Epoch 165/200, Train Loss: 10.9807, Val Loss: 9.8270\n",
      "  New best validation loss: 9.8270\n",
      "Epoch 166/200, Train Loss: 10.9653, Val Loss: 10.0214\n",
      "Epoch 167/200, Train Loss: 10.9665, Val Loss: 9.8182\n",
      "  New best validation loss: 9.8182\n",
      "Epoch 168/200, Train Loss: 10.9384, Val Loss: 9.9566\n",
      "Epoch 169/200, Train Loss: 10.9330, Val Loss: 10.0572\n",
      "Epoch 170/200, Train Loss: 10.9536, Val Loss: 10.0024\n",
      "Epoch 171/200, Train Loss: 10.9260, Val Loss: 9.8252\n",
      "Epoch 172/200, Train Loss: 11.0007, Val Loss: 9.9151\n",
      "Epoch 173/200, Train Loss: 10.9054, Val Loss: 9.8583\n",
      "Epoch 174/200, Train Loss: 10.9268, Val Loss: 9.9312\n",
      "Epoch 175/200, Train Loss: 10.8989, Val Loss: 9.9191\n",
      "Epoch 176/200, Train Loss: 10.8987, Val Loss: 9.7678\n",
      "  New best validation loss: 9.7678\n",
      "Epoch 177/200, Train Loss: 11.0017, Val Loss: 10.0423\n",
      "Epoch 178/200, Train Loss: 10.9829, Val Loss: 9.9279\n",
      "Epoch 179/200, Train Loss: 10.9195, Val Loss: 9.8681\n",
      "Epoch 180/200, Train Loss: 10.8866, Val Loss: 9.8548\n",
      "Epoch 181/200, Train Loss: 10.9313, Val Loss: 9.9917\n",
      "Epoch 182/200, Train Loss: 10.9465, Val Loss: 9.8226\n",
      "Epoch 183/200, Train Loss: 10.8938, Val Loss: 9.8136\n",
      "Epoch 184/200, Train Loss: 10.8696, Val Loss: 9.7909\n",
      "Epoch 185/200, Train Loss: 10.8896, Val Loss: 9.9447\n",
      "Epoch 186/200, Train Loss: 10.9350, Val Loss: 9.8113\n",
      "Epoch 187/200, Train Loss: 10.9823, Val Loss: 9.8926\n",
      "Epoch 188/200, Train Loss: 10.9163, Val Loss: 9.8381\n",
      "Epoch 189/200, Train Loss: 10.8346, Val Loss: 9.8020\n",
      "Epoch 190/200, Train Loss: 10.8521, Val Loss: 9.8979\n",
      "Epoch 191/200, Train Loss: 10.9316, Val Loss: 9.7903\n",
      "Epoch 192/200, Train Loss: 10.8464, Val Loss: 9.9144\n",
      "Epoch 193/200, Train Loss: 10.9267, Val Loss: 9.9215\n",
      "Epoch 194/200, Train Loss: 10.8373, Val Loss: 9.9481\n",
      "Epoch 195/200, Train Loss: 10.9004, Val Loss: 9.7968\n",
      "Epoch 196/200, Train Loss: 10.8758, Val Loss: 9.7586\n",
      "  New best validation loss: 9.7586\n",
      "Epoch 197/200, Train Loss: 10.8281, Val Loss: 9.8799\n",
      "Epoch 198/200, Train Loss: 10.8600, Val Loss: 9.8629\n",
      "Epoch 199/200, Train Loss: 10.8677, Val Loss: 9.9297\n",
      "Epoch 200/200, Train Loss: 10.8541, Val Loss: 9.7893\n",
      "\n",
      "Loaded best model (Val Loss: 9.7586) for final hidden state extraction.\n",
      "Saved best model for Transformer (samples=1280) to results_data_size_sweep/20250514_045146/samples_1280/Transformer_samples_1280_best.pt\n",
      "\n",
      "--- Performing Decodability Analysis for Transformer (samples=1280, k=15) ---\n",
      "  Analyzing decodability for Transformer...\n",
      "  Hidden states shape: torch.Size([160, 200, 20])\n",
      "  Coefficients shape: torch.Size([160, 15])\n",
      "  Processed hidden states shape for decoder: torch.Size([160, 20])\n",
      "  RidgeCV Decoder for Transformer - Test MSE: 1.2594, Test R2: 0.3740 (best alpha: 0.0695)\n",
      "  Decodability plot saved to results_data_size_sweep/20250514_045146/samples_1280/decodability_Transformer_coeff1.png\n",
      "Decodability (R2 score) for Transformer (samples=1280): 0.3740\n",
      "\n",
      "--- Training TransformerCausal (samples=1280, k=15) ---\n",
      "Number of parameters: 85809\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/conda/lib/python3.10/site-packages/torch/nn/modules/activation.py:1160: UserWarning: Converting mask without torch.bool dtype to bool; this will negatively affect performance. Prefer to use a boolean mask directly. (Triggered internally at /opt/conda/conda-bld/pytorch_1682343995026/work/aten/src/ATen/native/transformers/attention.cpp:150.)\n",
      "  return torch._native_multi_head_attention(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/200, Train Loss: 17.3301, Val Loss: 15.8982\n",
      "  New best validation loss: 15.8982\n",
      "Epoch 2/200, Train Loss: 16.8569, Val Loss: 15.8719\n",
      "  New best validation loss: 15.8719\n",
      "Epoch 3/200, Train Loss: 16.8339, Val Loss: 15.7793\n",
      "  New best validation loss: 15.7793\n",
      "Epoch 4/200, Train Loss: 16.8185, Val Loss: 15.8350\n",
      "Epoch 5/200, Train Loss: 16.8111, Val Loss: 15.8183\n",
      "Epoch 6/200, Train Loss: 16.7914, Val Loss: 15.8136\n",
      "Epoch 7/200, Train Loss: 16.7886, Val Loss: 15.7115\n",
      "  New best validation loss: 15.7115\n",
      "Epoch 8/200, Train Loss: 16.7867, Val Loss: 15.7421\n",
      "Epoch 9/200, Train Loss: 16.7706, Val Loss: 15.7252\n",
      "Epoch 10/200, Train Loss: 16.7641, Val Loss: 15.8230\n",
      "Epoch 11/200, Train Loss: 16.7608, Val Loss: 15.8230\n",
      "Epoch 12/200, Train Loss: 16.7355, Val Loss: 15.7277\n",
      "Epoch 13/200, Train Loss: 16.7259, Val Loss: 15.7672\n",
      "Epoch 14/200, Train Loss: 16.7231, Val Loss: 15.6857\n",
      "  New best validation loss: 15.6857\n",
      "Epoch 15/200, Train Loss: 16.7143, Val Loss: 15.7963\n",
      "Epoch 16/200, Train Loss: 16.7133, Val Loss: 15.7963\n",
      "Epoch 17/200, Train Loss: 16.7131, Val Loss: 15.6889\n",
      "Epoch 18/200, Train Loss: 16.7226, Val Loss: 15.8231\n",
      "Epoch 19/200, Train Loss: 16.7188, Val Loss: 15.6741\n",
      "  New best validation loss: 15.6741\n",
      "Epoch 20/200, Train Loss: 16.6762, Val Loss: 15.7146\n",
      "Epoch 21/200, Train Loss: 16.6895, Val Loss: 15.9078\n",
      "Epoch 22/200, Train Loss: 16.6987, Val Loss: 15.6526\n",
      "  New best validation loss: 15.6526\n",
      "Epoch 23/200, Train Loss: 16.6735, Val Loss: 15.7016\n",
      "Epoch 24/200, Train Loss: 16.6773, Val Loss: 15.6685\n",
      "Epoch 25/200, Train Loss: 16.6460, Val Loss: 15.6501\n",
      "  New best validation loss: 15.6501\n",
      "Epoch 26/200, Train Loss: 16.6596, Val Loss: 15.7125\n",
      "Epoch 27/200, Train Loss: 16.6529, Val Loss: 15.6597\n",
      "Epoch 28/200, Train Loss: 16.6083, Val Loss: 15.5000\n",
      "  New best validation loss: 15.5000\n",
      "Epoch 29/200, Train Loss: 16.6300, Val Loss: 15.6551\n",
      "Epoch 30/200, Train Loss: 16.6277, Val Loss: 15.5392\n",
      "Epoch 31/200, Train Loss: 16.5974, Val Loss: 15.4848\n",
      "  New best validation loss: 15.4848\n",
      "Epoch 32/200, Train Loss: 16.5841, Val Loss: 15.4218\n",
      "  New best validation loss: 15.4218\n",
      "Epoch 33/200, Train Loss: 16.6022, Val Loss: 15.6481\n",
      "Epoch 34/200, Train Loss: 16.5788, Val Loss: 15.4939\n",
      "Epoch 35/200, Train Loss: 16.5339, Val Loss: 15.4106\n",
      "  New best validation loss: 15.4106\n",
      "Epoch 36/200, Train Loss: 16.5260, Val Loss: 15.3778\n",
      "  New best validation loss: 15.3778\n",
      "Epoch 37/200, Train Loss: 16.5109, Val Loss: 15.3940\n",
      "Epoch 38/200, Train Loss: 16.4912, Val Loss: 15.4087\n",
      "Epoch 39/200, Train Loss: 16.4550, Val Loss: 15.5144\n",
      "Epoch 40/200, Train Loss: 16.4675, Val Loss: 15.3234\n",
      "  New best validation loss: 15.3234\n",
      "Epoch 41/200, Train Loss: 16.4818, Val Loss: 15.2976\n",
      "  New best validation loss: 15.2976\n",
      "Epoch 42/200, Train Loss: 16.4285, Val Loss: 15.3691\n",
      "Epoch 43/200, Train Loss: 16.4562, Val Loss: 15.2474\n",
      "  New best validation loss: 15.2474\n",
      "Epoch 44/200, Train Loss: 16.3829, Val Loss: 15.1954\n",
      "  New best validation loss: 15.1954\n",
      "Epoch 45/200, Train Loss: 16.3953, Val Loss: 15.2266\n",
      "Epoch 46/200, Train Loss: 16.3422, Val Loss: 15.1367\n",
      "  New best validation loss: 15.1367\n",
      "Epoch 47/200, Train Loss: 16.3372, Val Loss: 15.1689\n",
      "Epoch 48/200, Train Loss: 16.3213, Val Loss: 15.1083\n",
      "  New best validation loss: 15.1083\n",
      "Epoch 49/200, Train Loss: 16.3003, Val Loss: 15.1314\n",
      "Epoch 50/200, Train Loss: 16.2895, Val Loss: 15.0853\n",
      "  New best validation loss: 15.0853\n",
      "Epoch 51/200, Train Loss: 16.2298, Val Loss: 15.1227\n",
      "Epoch 52/200, Train Loss: 16.2287, Val Loss: 15.0358\n",
      "  New best validation loss: 15.0358\n",
      "Epoch 53/200, Train Loss: 16.2044, Val Loss: 15.0594\n",
      "Epoch 54/200, Train Loss: 16.1971, Val Loss: 15.1427\n",
      "Epoch 55/200, Train Loss: 16.1303, Val Loss: 15.0537\n",
      "Epoch 56/200, Train Loss: 16.1506, Val Loss: 15.0350\n",
      "  New best validation loss: 15.0350\n",
      "Epoch 57/200, Train Loss: 16.1011, Val Loss: 14.9758\n",
      "  New best validation loss: 14.9758\n",
      "Epoch 58/200, Train Loss: 16.0787, Val Loss: 14.9291\n",
      "  New best validation loss: 14.9291\n",
      "Epoch 59/200, Train Loss: 16.0356, Val Loss: 15.1210\n",
      "Epoch 60/200, Train Loss: 16.0503, Val Loss: 14.9388\n",
      "Epoch 61/200, Train Loss: 15.9837, Val Loss: 14.8330\n",
      "  New best validation loss: 14.8330\n",
      "Epoch 62/200, Train Loss: 15.9122, Val Loss: 14.8595\n",
      "Epoch 63/200, Train Loss: 15.8699, Val Loss: 14.7167\n",
      "  New best validation loss: 14.7167\n",
      "Epoch 64/200, Train Loss: 15.8138, Val Loss: 14.7308\n",
      "Epoch 65/200, Train Loss: 15.7705, Val Loss: 14.6788\n",
      "  New best validation loss: 14.6788\n",
      "Epoch 66/200, Train Loss: 15.7172, Val Loss: 14.7147\n",
      "Epoch 67/200, Train Loss: 15.6645, Val Loss: 14.5676\n",
      "  New best validation loss: 14.5676\n",
      "Epoch 68/200, Train Loss: 15.5813, Val Loss: 14.5171\n",
      "  New best validation loss: 14.5171\n",
      "Epoch 69/200, Train Loss: 15.5348, Val Loss: 14.4871\n",
      "  New best validation loss: 14.4871\n",
      "Epoch 70/200, Train Loss: 15.5211, Val Loss: 14.4411\n",
      "  New best validation loss: 14.4411\n",
      "Epoch 71/200, Train Loss: 15.3982, Val Loss: 14.4932\n",
      "Epoch 72/200, Train Loss: 15.4511, Val Loss: 14.3581\n",
      "  New best validation loss: 14.3581\n",
      "Epoch 73/200, Train Loss: 15.2785, Val Loss: 14.1370\n",
      "  New best validation loss: 14.1370\n",
      "Epoch 74/200, Train Loss: 15.2180, Val Loss: 14.2089\n",
      "Epoch 75/200, Train Loss: 15.0869, Val Loss: 14.0853\n",
      "  New best validation loss: 14.0853\n",
      "Epoch 76/200, Train Loss: 15.0050, Val Loss: 13.8525\n",
      "  New best validation loss: 13.8525\n",
      "Epoch 77/200, Train Loss: 14.9299, Val Loss: 13.8331\n",
      "  New best validation loss: 13.8331\n",
      "Epoch 78/200, Train Loss: 14.8428, Val Loss: 13.8057\n",
      "  New best validation loss: 13.8057\n",
      "Epoch 79/200, Train Loss: 14.8056, Val Loss: 13.8410\n",
      "Epoch 80/200, Train Loss: 14.7293, Val Loss: 13.7638\n",
      "  New best validation loss: 13.7638\n",
      "Epoch 81/200, Train Loss: 14.7591, Val Loss: 13.8138\n",
      "Epoch 82/200, Train Loss: 14.6628, Val Loss: 13.6175\n",
      "  New best validation loss: 13.6175\n",
      "Epoch 83/200, Train Loss: 14.6688, Val Loss: 13.6908\n",
      "Epoch 84/200, Train Loss: 14.5866, Val Loss: 13.5964\n",
      "  New best validation loss: 13.5964\n",
      "Epoch 85/200, Train Loss: 14.5234, Val Loss: 13.5694\n",
      "  New best validation loss: 13.5694\n",
      "Epoch 86/200, Train Loss: 14.4941, Val Loss: 13.6001\n",
      "Epoch 87/200, Train Loss: 14.4258, Val Loss: 13.4880\n",
      "  New best validation loss: 13.4880\n",
      "Epoch 88/200, Train Loss: 14.3957, Val Loss: 13.3361\n",
      "  New best validation loss: 13.3361\n",
      "Epoch 89/200, Train Loss: 14.4300, Val Loss: 13.3312\n",
      "  New best validation loss: 13.3312\n",
      "Epoch 90/200, Train Loss: 14.3458, Val Loss: 13.2730\n",
      "  New best validation loss: 13.2730\n",
      "Epoch 91/200, Train Loss: 14.2674, Val Loss: 13.1237\n",
      "  New best validation loss: 13.1237\n",
      "Epoch 92/200, Train Loss: 14.2118, Val Loss: 13.2418\n",
      "Epoch 93/200, Train Loss: 14.1971, Val Loss: 13.0632\n",
      "  New best validation loss: 13.0632\n",
      "Epoch 94/200, Train Loss: 14.1412, Val Loss: 12.9681\n",
      "  New best validation loss: 12.9681\n",
      "Epoch 95/200, Train Loss: 14.1584, Val Loss: 13.0739\n",
      "Epoch 96/200, Train Loss: 14.0649, Val Loss: 13.0670\n",
      "Epoch 97/200, Train Loss: 14.0983, Val Loss: 13.0345\n",
      "Epoch 98/200, Train Loss: 14.0312, Val Loss: 12.9522\n",
      "  New best validation loss: 12.9522\n",
      "Epoch 99/200, Train Loss: 13.9827, Val Loss: 12.9863\n",
      "Epoch 100/200, Train Loss: 13.9759, Val Loss: 12.8683\n",
      "  New best validation loss: 12.8683\n",
      "Epoch 101/200, Train Loss: 14.0116, Val Loss: 12.9181\n",
      "Epoch 102/200, Train Loss: 13.9384, Val Loss: 12.8372\n",
      "  New best validation loss: 12.8372\n",
      "Epoch 103/200, Train Loss: 13.9837, Val Loss: 12.8267\n",
      "  New best validation loss: 12.8267\n",
      "Epoch 104/200, Train Loss: 13.8997, Val Loss: 12.7353\n",
      "  New best validation loss: 12.7353\n",
      "Epoch 105/200, Train Loss: 13.9345, Val Loss: 12.9437\n",
      "Epoch 106/200, Train Loss: 13.8894, Val Loss: 12.7031\n",
      "  New best validation loss: 12.7031\n",
      "Epoch 107/200, Train Loss: 13.9555, Val Loss: 12.7849\n",
      "Epoch 108/200, Train Loss: 13.8874, Val Loss: 12.7613\n",
      "Epoch 109/200, Train Loss: 13.8391, Val Loss: 12.7592\n",
      "Epoch 110/200, Train Loss: 13.8627, Val Loss: 12.8835\n",
      "Epoch 111/200, Train Loss: 13.8647, Val Loss: 12.6696\n",
      "  New best validation loss: 12.6696\n",
      "Epoch 112/200, Train Loss: 13.8550, Val Loss: 12.6655\n",
      "  New best validation loss: 12.6655\n",
      "Epoch 113/200, Train Loss: 13.8256, Val Loss: 12.7995\n",
      "Epoch 114/200, Train Loss: 13.8280, Val Loss: 12.7371\n",
      "Epoch 115/200, Train Loss: 13.8053, Val Loss: 12.7367\n",
      "Epoch 116/200, Train Loss: 13.7622, Val Loss: 12.6135\n",
      "  New best validation loss: 12.6135\n",
      "Epoch 117/200, Train Loss: 13.7825, Val Loss: 12.6882\n",
      "Epoch 118/200, Train Loss: 13.7829, Val Loss: 12.6992\n",
      "Epoch 119/200, Train Loss: 13.7903, Val Loss: 12.7425\n",
      "Epoch 120/200, Train Loss: 13.7295, Val Loss: 12.7262\n",
      "Epoch 121/200, Train Loss: 13.7834, Val Loss: 12.6429\n",
      "Epoch 122/200, Train Loss: 13.7565, Val Loss: 12.8503\n",
      "Epoch 123/200, Train Loss: 13.7949, Val Loss: 12.6294\n",
      "Epoch 124/200, Train Loss: 13.7036, Val Loss: 12.6246\n",
      "Epoch 125/200, Train Loss: 13.7521, Val Loss: 12.6287\n",
      "Epoch 126/200, Train Loss: 13.7018, Val Loss: 12.7774\n",
      "Epoch 127/200, Train Loss: 13.7214, Val Loss: 12.6349\n",
      "Epoch 128/200, Train Loss: 13.7376, Val Loss: 12.6818\n",
      "Epoch 129/200, Train Loss: 13.7643, Val Loss: 12.6343\n",
      "Epoch 130/200, Train Loss: 13.7046, Val Loss: 12.5654\n",
      "  New best validation loss: 12.5654\n",
      "Epoch 131/200, Train Loss: 13.6559, Val Loss: 12.5757\n",
      "Epoch 132/200, Train Loss: 13.6826, Val Loss: 12.5800\n",
      "Epoch 133/200, Train Loss: 13.7213, Val Loss: 12.6296\n",
      "Epoch 134/200, Train Loss: 13.6833, Val Loss: 12.5582\n",
      "  New best validation loss: 12.5582\n",
      "Epoch 135/200, Train Loss: 13.6735, Val Loss: 12.5286\n",
      "  New best validation loss: 12.5286\n",
      "Epoch 136/200, Train Loss: 13.6958, Val Loss: 12.4742\n",
      "  New best validation loss: 12.4742\n",
      "Epoch 137/200, Train Loss: 13.6656, Val Loss: 12.5778\n",
      "Epoch 138/200, Train Loss: 13.6438, Val Loss: 12.4800\n",
      "Epoch 139/200, Train Loss: 13.6634, Val Loss: 12.6049\n",
      "Epoch 140/200, Train Loss: 13.6618, Val Loss: 12.5969\n",
      "Epoch 141/200, Train Loss: 13.6795, Val Loss: 12.6038\n",
      "Epoch 142/200, Train Loss: 13.6808, Val Loss: 12.5335\n",
      "Epoch 143/200, Train Loss: 13.6684, Val Loss: 12.6600\n",
      "Epoch 144/200, Train Loss: 13.6522, Val Loss: 12.5802\n",
      "Epoch 145/200, Train Loss: 13.5749, Val Loss: 12.4739\n",
      "  New best validation loss: 12.4739\n",
      "Epoch 146/200, Train Loss: 13.6252, Val Loss: 12.5550\n",
      "Epoch 147/200, Train Loss: 13.6620, Val Loss: 12.5286\n",
      "Epoch 148/200, Train Loss: 13.6170, Val Loss: 12.5785\n",
      "Epoch 149/200, Train Loss: 13.6326, Val Loss: 12.5675\n",
      "Epoch 150/200, Train Loss: 13.6720, Val Loss: 12.4883\n",
      "Epoch 151/200, Train Loss: 13.6209, Val Loss: 12.5087\n",
      "Epoch 152/200, Train Loss: 13.6158, Val Loss: 12.4880\n",
      "Epoch 153/200, Train Loss: 13.6048, Val Loss: 12.5851\n",
      "Epoch 154/200, Train Loss: 13.6017, Val Loss: 12.5507\n",
      "Epoch 155/200, Train Loss: 13.5471, Val Loss: 12.4937\n",
      "Epoch 156/200, Train Loss: 13.5978, Val Loss: 12.4821\n",
      "Epoch 157/200, Train Loss: 13.6013, Val Loss: 12.5612\n",
      "Epoch 158/200, Train Loss: 13.5886, Val Loss: 12.5762\n",
      "Epoch 159/200, Train Loss: 13.6034, Val Loss: 12.5276\n",
      "Epoch 160/200, Train Loss: 13.6007, Val Loss: 12.5690\n",
      "Epoch 161/200, Train Loss: 13.5816, Val Loss: 12.4691\n",
      "  New best validation loss: 12.4691\n",
      "Epoch 162/200, Train Loss: 13.6053, Val Loss: 12.4411\n",
      "  New best validation loss: 12.4411\n",
      "Epoch 163/200, Train Loss: 13.5629, Val Loss: 12.4228\n",
      "  New best validation loss: 12.4228\n",
      "Epoch 164/200, Train Loss: 13.5359, Val Loss: 12.5090\n",
      "Epoch 165/200, Train Loss: 13.5803, Val Loss: 12.4852\n",
      "Epoch 166/200, Train Loss: 13.6048, Val Loss: 12.4667\n",
      "Epoch 167/200, Train Loss: 13.5530, Val Loss: 12.4156\n",
      "  New best validation loss: 12.4156\n",
      "Epoch 168/200, Train Loss: 13.5601, Val Loss: 12.4916\n",
      "Epoch 169/200, Train Loss: 13.5574, Val Loss: 12.7312\n",
      "Epoch 170/200, Train Loss: 13.5605, Val Loss: 12.4889\n",
      "Epoch 171/200, Train Loss: 13.5035, Val Loss: 12.4940\n",
      "Epoch 172/200, Train Loss: 13.5426, Val Loss: 12.5001\n",
      "Epoch 173/200, Train Loss: 13.5605, Val Loss: 12.4429\n",
      "Epoch 174/200, Train Loss: 13.5842, Val Loss: 12.5347\n",
      "Epoch 175/200, Train Loss: 13.5530, Val Loss: 12.5301\n",
      "Epoch 176/200, Train Loss: 13.5491, Val Loss: 12.4573\n",
      "Epoch 177/200, Train Loss: 13.5663, Val Loss: 12.5028\n",
      "Epoch 178/200, Train Loss: 13.5596, Val Loss: 12.3881\n",
      "  New best validation loss: 12.3881\n",
      "Epoch 179/200, Train Loss: 13.5426, Val Loss: 12.4904\n",
      "Epoch 180/200, Train Loss: 13.5413, Val Loss: 12.4233\n",
      "Epoch 181/200, Train Loss: 13.4921, Val Loss: 12.5983\n",
      "Epoch 182/200, Train Loss: 13.5297, Val Loss: 12.5348\n",
      "Epoch 183/200, Train Loss: 13.5163, Val Loss: 12.4666\n",
      "Epoch 184/200, Train Loss: 13.5553, Val Loss: 12.4279\n",
      "Epoch 185/200, Train Loss: 13.5096, Val Loss: 12.4254\n",
      "Epoch 186/200, Train Loss: 13.5396, Val Loss: 12.4680\n",
      "Epoch 187/200, Train Loss: 13.5195, Val Loss: 12.3805\n",
      "  New best validation loss: 12.3805\n",
      "Epoch 188/200, Train Loss: 13.5436, Val Loss: 12.4633\n",
      "Epoch 189/200, Train Loss: 13.5008, Val Loss: 12.3942\n",
      "Epoch 190/200, Train Loss: 13.5057, Val Loss: 12.5001\n",
      "Epoch 191/200, Train Loss: 13.4827, Val Loss: 12.5428\n",
      "Epoch 192/200, Train Loss: 13.5059, Val Loss: 12.5190\n",
      "Epoch 193/200, Train Loss: 13.5009, Val Loss: 12.5333\n",
      "Epoch 194/200, Train Loss: 13.5263, Val Loss: 12.4445\n",
      "Epoch 195/200, Train Loss: 13.5122, Val Loss: 12.3911\n",
      "Epoch 196/200, Train Loss: 13.5085, Val Loss: 12.3504\n",
      "  New best validation loss: 12.3504\n",
      "Epoch 197/200, Train Loss: 13.4742, Val Loss: 12.4491\n",
      "Epoch 198/200, Train Loss: 13.5255, Val Loss: 12.4415\n",
      "Epoch 199/200, Train Loss: 13.5537, Val Loss: 12.4146\n",
      "Epoch 200/200, Train Loss: 13.4492, Val Loss: 12.4487\n",
      "\n",
      "Loaded best model (Val Loss: 12.3504) for final hidden state extraction.\n",
      "Saved best model for TransformerCausal (samples=1280) to results_data_size_sweep/20250514_045146/samples_1280/TransformerCausal_samples_1280_best.pt\n",
      "\n",
      "--- Performing Decodability Analysis for TransformerCausal (samples=1280, k=15) ---\n",
      "  Analyzing decodability for TransformerCausal...\n",
      "  Hidden states shape: torch.Size([160, 200, 20])\n",
      "  Coefficients shape: torch.Size([160, 15])\n",
      "  Processed hidden states shape for decoder: torch.Size([160, 20])\n",
      "  RidgeCV Decoder for TransformerCausal - Test MSE: 1.0035, Test R2: 0.4939 (best alpha: 0.0695)\n",
      "  Decodability plot saved to results_data_size_sweep/20250514_045146/samples_1280/decodability_TransformerCausal_coeff1.png\n",
      "Decodability (R2 score) for TransformerCausal (samples=1280): 0.4939\n",
      "\n",
      "--- Training HIPPORNN_LegT (samples=1280, k=15) ---\n",
      "Number of parameters: 4029\n",
      "Epoch 1/200, Train Loss: 17.0723, Val Loss: 15.8455\n",
      "  New best validation loss: 15.8455\n",
      "Epoch 2/200, Train Loss: 17.0577, Val Loss: 15.8342\n",
      "  New best validation loss: 15.8342\n",
      "Epoch 3/200, Train Loss: 17.0222, Val Loss: 15.7969\n",
      "  New best validation loss: 15.7969\n",
      "Epoch 4/200, Train Loss: 16.8634, Val Loss: 15.6508\n",
      "  New best validation loss: 15.6508\n",
      "Epoch 5/200, Train Loss: 16.6281, Val Loss: 15.6868\n",
      "Epoch 6/200, Train Loss: 16.5556, Val Loss: 15.6722\n",
      "Epoch 7/200, Train Loss: 16.5247, Val Loss: 15.6276\n",
      "  New best validation loss: 15.6276\n",
      "Epoch 8/200, Train Loss: 16.4934, Val Loss: 15.6527\n",
      "Epoch 9/200, Train Loss: 16.4671, Val Loss: 15.6182\n",
      "  New best validation loss: 15.6182\n",
      "Epoch 10/200, Train Loss: 16.4429, Val Loss: 15.6006\n",
      "  New best validation loss: 15.6006\n",
      "Epoch 11/200, Train Loss: 16.4168, Val Loss: 15.5796\n",
      "  New best validation loss: 15.5796\n",
      "Epoch 12/200, Train Loss: 16.3834, Val Loss: 15.5799\n",
      "Epoch 13/200, Train Loss: 16.3455, Val Loss: 15.5514\n",
      "  New best validation loss: 15.5514\n",
      "Epoch 14/200, Train Loss: 16.2989, Val Loss: 15.5331\n",
      "  New best validation loss: 15.5331\n",
      "Epoch 15/200, Train Loss: 16.2518, Val Loss: 15.5087\n",
      "  New best validation loss: 15.5087\n",
      "Epoch 16/200, Train Loss: 16.1963, Val Loss: 15.4774\n",
      "  New best validation loss: 15.4774\n",
      "Epoch 17/200, Train Loss: 16.1475, Val Loss: 15.4561\n",
      "  New best validation loss: 15.4561\n",
      "Epoch 18/200, Train Loss: 16.1006, Val Loss: 15.4208\n",
      "  New best validation loss: 15.4208\n",
      "Epoch 19/200, Train Loss: 16.0412, Val Loss: 15.4004\n",
      "  New best validation loss: 15.4004\n",
      "Epoch 20/200, Train Loss: 15.9606, Val Loss: 15.3353\n",
      "  New best validation loss: 15.3353\n",
      "Epoch 21/200, Train Loss: 15.8695, Val Loss: 15.2737\n",
      "  New best validation loss: 15.2737\n",
      "Epoch 22/200, Train Loss: 15.7803, Val Loss: 15.2099\n",
      "  New best validation loss: 15.2099\n",
      "Epoch 23/200, Train Loss: 15.7014, Val Loss: 15.1329\n",
      "  New best validation loss: 15.1329\n",
      "Epoch 24/200, Train Loss: 15.6267, Val Loss: 15.1179\n",
      "  New best validation loss: 15.1179\n",
      "Epoch 25/200, Train Loss: 15.5544, Val Loss: 15.0742\n",
      "  New best validation loss: 15.0742\n",
      "Epoch 26/200, Train Loss: 15.4754, Val Loss: 14.9905\n",
      "  New best validation loss: 14.9905\n",
      "Epoch 27/200, Train Loss: 15.4150, Val Loss: 14.9611\n",
      "  New best validation loss: 14.9611\n",
      "Epoch 28/200, Train Loss: 15.3432, Val Loss: 14.9219\n",
      "  New best validation loss: 14.9219\n",
      "Epoch 29/200, Train Loss: 15.2736, Val Loss: 14.8779\n",
      "  New best validation loss: 14.8779\n",
      "Epoch 30/200, Train Loss: 15.2036, Val Loss: 14.8051\n",
      "  New best validation loss: 14.8051\n",
      "Epoch 31/200, Train Loss: 15.1324, Val Loss: 14.7704\n",
      "  New best validation loss: 14.7704\n",
      "Epoch 32/200, Train Loss: 15.0636, Val Loss: 14.7010\n",
      "  New best validation loss: 14.7010\n",
      "Epoch 33/200, Train Loss: 14.9839, Val Loss: 14.6882\n",
      "  New best validation loss: 14.6882\n",
      "Epoch 34/200, Train Loss: 14.9024, Val Loss: 14.6417\n",
      "  New best validation loss: 14.6417\n",
      "Epoch 35/200, Train Loss: 14.8286, Val Loss: 14.5773\n",
      "  New best validation loss: 14.5773\n",
      "Epoch 36/200, Train Loss: 14.7487, Val Loss: 14.5347\n",
      "  New best validation loss: 14.5347\n",
      "Epoch 37/200, Train Loss: 14.6728, Val Loss: 14.5120\n",
      "  New best validation loss: 14.5120\n",
      "Epoch 38/200, Train Loss: 14.6015, Val Loss: 14.3949\n",
      "  New best validation loss: 14.3949\n",
      "Epoch 39/200, Train Loss: 14.5068, Val Loss: 14.4135\n",
      "Epoch 40/200, Train Loss: 14.4474, Val Loss: 14.2999\n",
      "  New best validation loss: 14.2999\n",
      "Epoch 41/200, Train Loss: 14.3699, Val Loss: 14.2558\n",
      "  New best validation loss: 14.2558\n",
      "Epoch 42/200, Train Loss: 14.2887, Val Loss: 14.1891\n",
      "  New best validation loss: 14.1891\n",
      "Epoch 43/200, Train Loss: 14.2281, Val Loss: 14.1509\n",
      "  New best validation loss: 14.1509\n",
      "Epoch 44/200, Train Loss: 14.1533, Val Loss: 14.0342\n",
      "  New best validation loss: 14.0342\n",
      "Epoch 45/200, Train Loss: 14.1031, Val Loss: 13.9503\n",
      "  New best validation loss: 13.9503\n",
      "Epoch 46/200, Train Loss: 14.0312, Val Loss: 13.9163\n",
      "  New best validation loss: 13.9163\n",
      "Epoch 47/200, Train Loss: 13.9752, Val Loss: 13.8721\n",
      "  New best validation loss: 13.8721\n",
      "Epoch 48/200, Train Loss: 13.9135, Val Loss: 13.7712\n",
      "  New best validation loss: 13.7712\n",
      "Epoch 49/200, Train Loss: 13.8539, Val Loss: 13.7587\n",
      "  New best validation loss: 13.7587\n",
      "Epoch 50/200, Train Loss: 13.7878, Val Loss: 13.6698\n",
      "  New best validation loss: 13.6698\n",
      "Epoch 51/200, Train Loss: 13.7553, Val Loss: 13.6452\n",
      "  New best validation loss: 13.6452\n",
      "Epoch 52/200, Train Loss: 13.6985, Val Loss: 13.5937\n",
      "  New best validation loss: 13.5937\n",
      "Epoch 53/200, Train Loss: 13.6717, Val Loss: 13.5171\n",
      "  New best validation loss: 13.5171\n",
      "Epoch 54/200, Train Loss: 13.6331, Val Loss: 13.5404\n",
      "Epoch 55/200, Train Loss: 13.5677, Val Loss: 13.4617\n",
      "  New best validation loss: 13.4617\n",
      "Epoch 56/200, Train Loss: 13.5493, Val Loss: 13.4554\n",
      "  New best validation loss: 13.4554\n",
      "Epoch 57/200, Train Loss: 13.5013, Val Loss: 13.3829\n",
      "  New best validation loss: 13.3829\n",
      "Epoch 58/200, Train Loss: 13.4399, Val Loss: 13.3439\n",
      "  New best validation loss: 13.3439\n",
      "Epoch 59/200, Train Loss: 13.4101, Val Loss: 13.3433\n",
      "  New best validation loss: 13.3433\n",
      "Epoch 60/200, Train Loss: 13.3857, Val Loss: 13.2702\n",
      "  New best validation loss: 13.2702\n",
      "Epoch 61/200, Train Loss: 13.3772, Val Loss: 13.2341\n",
      "  New best validation loss: 13.2341\n",
      "Epoch 62/200, Train Loss: 13.3158, Val Loss: 13.2622\n",
      "Epoch 63/200, Train Loss: 13.2808, Val Loss: 13.2110\n",
      "  New best validation loss: 13.2110\n",
      "Epoch 64/200, Train Loss: 13.2441, Val Loss: 13.1484\n",
      "  New best validation loss: 13.1484\n",
      "Epoch 65/200, Train Loss: 13.2315, Val Loss: 13.1818\n",
      "Epoch 66/200, Train Loss: 13.2001, Val Loss: 13.1540\n",
      "Epoch 67/200, Train Loss: 13.1684, Val Loss: 13.1362\n",
      "  New best validation loss: 13.1362\n",
      "Epoch 68/200, Train Loss: 13.1471, Val Loss: 13.0387\n",
      "  New best validation loss: 13.0387\n",
      "Epoch 69/200, Train Loss: 13.1124, Val Loss: 13.0206\n",
      "  New best validation loss: 13.0206\n",
      "Epoch 70/200, Train Loss: 13.0754, Val Loss: 13.0558\n",
      "Epoch 71/200, Train Loss: 13.0739, Val Loss: 13.0314\n",
      "Epoch 72/200, Train Loss: 13.0364, Val Loss: 13.0142\n",
      "  New best validation loss: 13.0142\n",
      "Epoch 73/200, Train Loss: 13.0223, Val Loss: 13.0514\n",
      "Epoch 74/200, Train Loss: 12.9566, Val Loss: 12.9278\n",
      "  New best validation loss: 12.9278\n",
      "Epoch 75/200, Train Loss: 12.9359, Val Loss: 13.0010\n",
      "Epoch 76/200, Train Loss: 12.9208, Val Loss: 12.9079\n",
      "  New best validation loss: 12.9079\n",
      "Epoch 77/200, Train Loss: 12.8853, Val Loss: 12.9362\n",
      "Epoch 78/200, Train Loss: 12.8621, Val Loss: 12.9291\n",
      "Epoch 79/200, Train Loss: 12.8506, Val Loss: 12.8095\n",
      "  New best validation loss: 12.8095\n",
      "Epoch 80/200, Train Loss: 12.8347, Val Loss: 12.8065\n",
      "  New best validation loss: 12.8065\n",
      "Epoch 81/200, Train Loss: 12.8111, Val Loss: 12.8078\n",
      "Epoch 82/200, Train Loss: 12.7885, Val Loss: 12.6582\n",
      "  New best validation loss: 12.6582\n",
      "Epoch 83/200, Train Loss: 12.7474, Val Loss: 12.6807\n",
      "Epoch 84/200, Train Loss: 12.7515, Val Loss: 12.9256\n",
      "Epoch 85/200, Train Loss: 12.7105, Val Loss: 12.6506\n",
      "  New best validation loss: 12.6506\n",
      "Epoch 86/200, Train Loss: 12.6937, Val Loss: 12.6988\n",
      "Epoch 87/200, Train Loss: 12.6816, Val Loss: 12.7871\n",
      "Epoch 88/200, Train Loss: 12.6560, Val Loss: 12.7804\n",
      "Epoch 89/200, Train Loss: 12.6519, Val Loss: 12.6420\n",
      "  New best validation loss: 12.6420\n",
      "Epoch 90/200, Train Loss: 12.6269, Val Loss: 12.8548\n",
      "Epoch 91/200, Train Loss: 12.5952, Val Loss: 12.4463\n",
      "  New best validation loss: 12.4463\n",
      "Epoch 92/200, Train Loss: 12.5816, Val Loss: 12.6453\n",
      "Epoch 93/200, Train Loss: 12.5467, Val Loss: 12.6277\n",
      "Epoch 94/200, Train Loss: 12.5452, Val Loss: 12.5805\n",
      "Epoch 95/200, Train Loss: 12.5057, Val Loss: 12.6553\n",
      "Epoch 96/200, Train Loss: 12.4834, Val Loss: 12.6121\n",
      "Epoch 97/200, Train Loss: 12.4516, Val Loss: 12.5870\n",
      "Epoch 98/200, Train Loss: 12.4620, Val Loss: 12.6865\n",
      "Epoch 99/200, Train Loss: 12.4541, Val Loss: 12.6230\n",
      "Epoch 100/200, Train Loss: 12.4025, Val Loss: 12.5090\n",
      "Epoch 101/200, Train Loss: 12.3906, Val Loss: 12.4299\n",
      "  New best validation loss: 12.4299\n",
      "Epoch 102/200, Train Loss: 12.3786, Val Loss: 12.5358\n",
      "Epoch 103/200, Train Loss: 12.3633, Val Loss: 12.5124\n",
      "Epoch 104/200, Train Loss: 12.3397, Val Loss: 12.3401\n",
      "  New best validation loss: 12.3401\n",
      "Epoch 105/200, Train Loss: 12.3735, Val Loss: 12.5317\n",
      "Epoch 106/200, Train Loss: 12.3825, Val Loss: 12.3255\n",
      "  New best validation loss: 12.3255\n",
      "Epoch 107/200, Train Loss: 12.2869, Val Loss: 12.3097\n",
      "  New best validation loss: 12.3097\n",
      "Epoch 108/200, Train Loss: 12.2863, Val Loss: 12.3832\n",
      "Epoch 109/200, Train Loss: 12.2580, Val Loss: 12.3165\n",
      "Epoch 110/200, Train Loss: 12.2994, Val Loss: 12.3487\n",
      "Epoch 111/200, Train Loss: 12.2541, Val Loss: 12.5245\n",
      "Epoch 112/200, Train Loss: 12.2727, Val Loss: 12.3661\n",
      "Epoch 113/200, Train Loss: 12.2200, Val Loss: 12.1678\n",
      "  New best validation loss: 12.1678\n",
      "Epoch 114/200, Train Loss: 12.1921, Val Loss: 12.2857\n",
      "Epoch 115/200, Train Loss: 12.1665, Val Loss: 12.2642\n",
      "Epoch 116/200, Train Loss: 12.1547, Val Loss: 12.3040\n",
      "Epoch 117/200, Train Loss: 12.1345, Val Loss: 12.2850\n",
      "Epoch 118/200, Train Loss: 12.1424, Val Loss: 12.1710\n",
      "Epoch 119/200, Train Loss: 12.1174, Val Loss: 12.2344\n",
      "Epoch 120/200, Train Loss: 12.1111, Val Loss: 12.3046\n",
      "Epoch 121/200, Train Loss: 12.0984, Val Loss: 12.2544\n",
      "Epoch 122/200, Train Loss: 12.0874, Val Loss: 12.1980\n",
      "Epoch 123/200, Train Loss: 12.1035, Val Loss: 12.2073\n",
      "Epoch 124/200, Train Loss: 12.1817, Val Loss: 12.2159\n",
      "Epoch 125/200, Train Loss: 12.1236, Val Loss: 12.3199\n",
      "Epoch 126/200, Train Loss: 12.0444, Val Loss: 12.3049\n",
      "Epoch 127/200, Train Loss: 12.0421, Val Loss: 12.1313\n",
      "  New best validation loss: 12.1313\n",
      "Epoch 128/200, Train Loss: 12.0122, Val Loss: 12.0822\n",
      "  New best validation loss: 12.0822\n",
      "Epoch 129/200, Train Loss: 12.0273, Val Loss: 12.1315\n",
      "Epoch 130/200, Train Loss: 12.0821, Val Loss: 12.2341\n",
      "Epoch 131/200, Train Loss: 12.0016, Val Loss: 12.0889\n",
      "Epoch 132/200, Train Loss: 12.0161, Val Loss: 12.1349\n",
      "Epoch 133/200, Train Loss: 11.9824, Val Loss: 12.3543\n",
      "Epoch 134/200, Train Loss: 12.1335, Val Loss: 11.9917\n",
      "  New best validation loss: 11.9917\n",
      "Epoch 135/200, Train Loss: 12.0339, Val Loss: 12.0518\n",
      "Epoch 136/200, Train Loss: 11.9396, Val Loss: 12.0157\n",
      "Epoch 137/200, Train Loss: 11.9136, Val Loss: 12.0366\n",
      "Epoch 138/200, Train Loss: 11.9814, Val Loss: 11.8819\n",
      "  New best validation loss: 11.8819\n",
      "Epoch 139/200, Train Loss: 12.0324, Val Loss: 11.8027\n",
      "  New best validation loss: 11.8027\n",
      "Epoch 140/200, Train Loss: 11.9473, Val Loss: 11.8503\n",
      "Epoch 141/200, Train Loss: 11.8869, Val Loss: 12.0519\n",
      "Epoch 142/200, Train Loss: 11.8759, Val Loss: 12.0408\n",
      "Epoch 143/200, Train Loss: 11.8516, Val Loss: 12.1133\n",
      "Epoch 144/200, Train Loss: 11.8628, Val Loss: 12.0061\n",
      "Epoch 145/200, Train Loss: 11.8754, Val Loss: 11.9029\n",
      "Epoch 146/200, Train Loss: 11.8380, Val Loss: 11.9671\n",
      "Epoch 147/200, Train Loss: 12.4551, Val Loss: 13.0325\n",
      "Epoch 148/200, Train Loss: 13.4512, Val Loss: 12.6411\n",
      "Epoch 149/200, Train Loss: 13.0240, Val Loss: 12.4938\n",
      "Epoch 150/200, Train Loss: 12.7076, Val Loss: 12.1319\n",
      "Epoch 151/200, Train Loss: 12.5338, Val Loss: 12.1128\n",
      "Epoch 152/200, Train Loss: 12.3796, Val Loss: 12.0630\n",
      "Epoch 153/200, Train Loss: 12.2534, Val Loss: 11.9664\n",
      "Epoch 154/200, Train Loss: 12.1744, Val Loss: 11.9242\n",
      "Epoch 155/200, Train Loss: 12.1352, Val Loss: 11.8547\n",
      "Epoch 156/200, Train Loss: 12.1132, Val Loss: 11.9564\n",
      "Epoch 157/200, Train Loss: 12.0536, Val Loss: 11.7503\n",
      "  New best validation loss: 11.7503\n",
      "Epoch 158/200, Train Loss: 11.9878, Val Loss: 11.7418\n",
      "  New best validation loss: 11.7418\n",
      "Epoch 159/200, Train Loss: 11.9731, Val Loss: 11.8278\n",
      "Epoch 160/200, Train Loss: 11.9302, Val Loss: 11.8202\n",
      "Epoch 161/200, Train Loss: 11.9313, Val Loss: 11.7503\n",
      "Epoch 162/200, Train Loss: 11.9728, Val Loss: 11.7251\n",
      "  New best validation loss: 11.7251\n",
      "Epoch 163/200, Train Loss: 11.9124, Val Loss: 11.9765\n",
      "Epoch 164/200, Train Loss: 11.8830, Val Loss: 11.7606\n",
      "Epoch 165/200, Train Loss: 11.8201, Val Loss: 11.6841\n",
      "  New best validation loss: 11.6841\n",
      "Epoch 166/200, Train Loss: 11.8177, Val Loss: 11.6900\n",
      "Epoch 167/200, Train Loss: 11.7804, Val Loss: 11.7253\n",
      "Epoch 168/200, Train Loss: 11.7620, Val Loss: 11.7369\n",
      "Epoch 169/200, Train Loss: 11.8013, Val Loss: 11.7000\n",
      "Epoch 170/200, Train Loss: 11.7716, Val Loss: 11.7402\n",
      "Epoch 171/200, Train Loss: 11.7587, Val Loss: 11.6915\n",
      "Epoch 172/200, Train Loss: 11.7142, Val Loss: 11.6723\n",
      "  New best validation loss: 11.6723\n",
      "Epoch 173/200, Train Loss: 11.8522, Val Loss: 12.3438\n",
      "Epoch 174/200, Train Loss: 12.5245, Val Loss: 12.1286\n",
      "Epoch 175/200, Train Loss: 12.2686, Val Loss: 11.7566\n",
      "Epoch 176/200, Train Loss: 12.0930, Val Loss: 11.7270\n",
      "Epoch 177/200, Train Loss: 12.0007, Val Loss: 11.5793\n",
      "  New best validation loss: 11.5793\n",
      "Epoch 178/200, Train Loss: 11.8546, Val Loss: 11.5723\n",
      "  New best validation loss: 11.5723\n",
      "Epoch 179/200, Train Loss: 11.8217, Val Loss: 11.5448\n",
      "  New best validation loss: 11.5448\n",
      "Epoch 180/200, Train Loss: 11.7824, Val Loss: 11.5806\n",
      "Epoch 181/200, Train Loss: 11.7558, Val Loss: 11.5940\n",
      "Epoch 182/200, Train Loss: 11.7302, Val Loss: 11.5611\n",
      "Epoch 183/200, Train Loss: 11.6978, Val Loss: 11.5632\n",
      "Epoch 184/200, Train Loss: 11.6735, Val Loss: 11.6352\n",
      "Epoch 185/200, Train Loss: 11.6519, Val Loss: 11.5823\n",
      "Epoch 186/200, Train Loss: 11.6462, Val Loss: 11.5464\n",
      "Epoch 187/200, Train Loss: 11.6350, Val Loss: 11.6233\n",
      "Epoch 188/200, Train Loss: 11.6448, Val Loss: 11.5639\n",
      "Epoch 189/200, Train Loss: 11.6109, Val Loss: 11.5819\n",
      "Epoch 190/200, Train Loss: 11.6027, Val Loss: 11.5223\n",
      "  New best validation loss: 11.5223\n",
      "Epoch 191/200, Train Loss: 11.5956, Val Loss: 11.5663\n",
      "Epoch 192/200, Train Loss: 11.5850, Val Loss: 11.5123\n",
      "  New best validation loss: 11.5123\n",
      "Epoch 193/200, Train Loss: 11.5732, Val Loss: 11.5130\n",
      "Epoch 194/200, Train Loss: 11.5653, Val Loss: 11.5010\n",
      "  New best validation loss: 11.5010\n",
      "Epoch 195/200, Train Loss: 11.5521, Val Loss: 11.5137\n",
      "Epoch 196/200, Train Loss: 11.5387, Val Loss: 11.4493\n",
      "  New best validation loss: 11.4493\n",
      "Epoch 197/200, Train Loss: 11.5348, Val Loss: 11.5749\n",
      "Epoch 198/200, Train Loss: 11.5218, Val Loss: 11.4842\n",
      "Epoch 199/200, Train Loss: 11.5349, Val Loss: 11.4150\n",
      "  New best validation loss: 11.4150\n",
      "Epoch 200/200, Train Loss: 11.5121, Val Loss: 11.4947\n",
      "\n",
      "Loaded best model (Val Loss: 11.4150) for final hidden state extraction.\n",
      "Saved best model for HIPPORNN_LegT (samples=1280) to results_data_size_sweep/20250514_045146/samples_1280/HIPPORNN_LegT_samples_1280_best.pt\n",
      "\n",
      "--- Performing Decodability Analysis for HIPPORNN_LegT (samples=1280, k=15) ---\n",
      "  Analyzing decodability for HIPPORNN_LegT...\n",
      "  Hidden states shape: torch.Size([160, 200, 25])\n",
      "  Coefficients shape: torch.Size([160, 15])\n",
      "  Processed hidden states shape for decoder: torch.Size([160, 25])\n",
      "  RidgeCV Decoder for HIPPORNN_LegT - Test MSE: 1.4883, Test R2: 0.2583 (best alpha: 23.3572)\n",
      "  Decodability plot saved to results_data_size_sweep/20250514_045146/samples_1280/decodability_HIPPORNN_LegT_coeff1.png\n",
      "Decodability (R2 score) for HIPPORNN_LegT (samples=1280): 0.2583\n",
      "\n",
      "--- Training NMRNN_Spatial_ModReadout (samples=1280, k=15) ---\n",
      "Number of parameters: 66832\n",
      "Epoch 1/200, Train Loss: 16.8416, Val Loss: 15.7015\n",
      "  New best validation loss: 15.7015\n",
      "Epoch 2/200, Train Loss: 16.6632, Val Loss: 15.7325\n",
      "Epoch 3/200, Train Loss: 16.6061, Val Loss: 15.7810\n",
      "Epoch 4/200, Train Loss: 16.5456, Val Loss: 15.7673\n",
      "Epoch 5/200, Train Loss: 16.5091, Val Loss: 15.7391\n",
      "Epoch 6/200, Train Loss: 16.4905, Val Loss: 15.6918\n",
      "  New best validation loss: 15.6918\n",
      "Epoch 7/200, Train Loss: 16.4468, Val Loss: 15.6490\n",
      "  New best validation loss: 15.6490\n",
      "Epoch 8/200, Train Loss: 16.3885, Val Loss: 15.5384\n",
      "  New best validation loss: 15.5384\n",
      "Epoch 9/200, Train Loss: 16.3106, Val Loss: 15.5657\n",
      "Epoch 10/200, Train Loss: 16.2350, Val Loss: 15.4054\n",
      "  New best validation loss: 15.4054\n",
      "Epoch 11/200, Train Loss: 16.1364, Val Loss: 15.2928\n",
      "  New best validation loss: 15.2928\n",
      "Epoch 12/200, Train Loss: 16.0189, Val Loss: 15.3235\n",
      "Epoch 13/200, Train Loss: 15.9156, Val Loss: 15.1550\n",
      "  New best validation loss: 15.1550\n",
      "Epoch 14/200, Train Loss: 15.7945, Val Loss: 14.8574\n",
      "  New best validation loss: 14.8574\n",
      "Epoch 15/200, Train Loss: 15.6356, Val Loss: 14.9093\n",
      "Epoch 16/200, Train Loss: 15.4871, Val Loss: 14.6600\n",
      "  New best validation loss: 14.6600\n",
      "Epoch 17/200, Train Loss: 15.4093, Val Loss: 14.6543\n",
      "  New best validation loss: 14.6543\n",
      "Epoch 18/200, Train Loss: 15.2281, Val Loss: 14.5431\n",
      "  New best validation loss: 14.5431\n",
      "Epoch 19/200, Train Loss: 15.0246, Val Loss: 14.7015\n",
      "Epoch 20/200, Train Loss: 14.9121, Val Loss: 14.4557\n",
      "  New best validation loss: 14.4557\n",
      "Epoch 21/200, Train Loss: 14.7836, Val Loss: 14.2886\n",
      "  New best validation loss: 14.2886\n",
      "Epoch 22/200, Train Loss: 14.6519, Val Loss: 14.0563\n",
      "  New best validation loss: 14.0563\n",
      "Epoch 23/200, Train Loss: 14.4125, Val Loss: 13.9393\n",
      "  New best validation loss: 13.9393\n",
      "Epoch 24/200, Train Loss: 14.3064, Val Loss: 14.0072\n",
      "Epoch 25/200, Train Loss: 14.0680, Val Loss: 13.4786\n",
      "  New best validation loss: 13.4786\n",
      "Epoch 26/200, Train Loss: 13.8947, Val Loss: 13.5378\n",
      "Epoch 27/200, Train Loss: 13.7231, Val Loss: 13.5848\n",
      "Epoch 28/200, Train Loss: 13.5803, Val Loss: 13.5358\n",
      "Epoch 29/200, Train Loss: 13.4209, Val Loss: 13.1469\n",
      "  New best validation loss: 13.1469\n",
      "Epoch 30/200, Train Loss: 13.2552, Val Loss: 13.2747\n",
      "Epoch 31/200, Train Loss: 13.1039, Val Loss: 13.0184\n",
      "  New best validation loss: 13.0184\n",
      "Epoch 32/200, Train Loss: 13.0646, Val Loss: 13.1355\n",
      "Epoch 33/200, Train Loss: 12.9744, Val Loss: 13.0320\n",
      "Epoch 34/200, Train Loss: 12.8363, Val Loss: 12.5284\n",
      "  New best validation loss: 12.5284\n",
      "Epoch 35/200, Train Loss: 12.6971, Val Loss: 13.2652\n",
      "Epoch 36/200, Train Loss: 12.5232, Val Loss: 12.8379\n",
      "Epoch 37/200, Train Loss: 12.4351, Val Loss: 12.5925\n",
      "Epoch 38/200, Train Loss: 12.3682, Val Loss: 12.5928\n",
      "Epoch 39/200, Train Loss: 12.2589, Val Loss: 12.4454\n",
      "  New best validation loss: 12.4454\n",
      "Epoch 40/200, Train Loss: 12.3074, Val Loss: 12.7428\n",
      "Epoch 41/200, Train Loss: 12.0875, Val Loss: 12.5310\n",
      "Epoch 42/200, Train Loss: 12.0176, Val Loss: 12.4542\n",
      "Epoch 43/200, Train Loss: 11.9054, Val Loss: 12.2938\n",
      "  New best validation loss: 12.2938\n",
      "Epoch 44/200, Train Loss: 11.7560, Val Loss: 12.5609\n",
      "Epoch 45/200, Train Loss: 11.6777, Val Loss: 12.2283\n",
      "  New best validation loss: 12.2283\n",
      "Epoch 46/200, Train Loss: 11.7033, Val Loss: 12.2576\n",
      "Epoch 47/200, Train Loss: 11.5867, Val Loss: 12.5517\n",
      "Epoch 48/200, Train Loss: 11.5141, Val Loss: 12.2944\n",
      "Epoch 49/200, Train Loss: 11.4477, Val Loss: 12.1652\n",
      "  New best validation loss: 12.1652\n",
      "Epoch 50/200, Train Loss: 11.3673, Val Loss: 12.2186\n",
      "Epoch 51/200, Train Loss: 11.3584, Val Loss: 12.4338\n",
      "Epoch 52/200, Train Loss: 11.2410, Val Loss: 11.9949\n",
      "  New best validation loss: 11.9949\n",
      "Epoch 53/200, Train Loss: 11.2509, Val Loss: 12.1150\n",
      "Epoch 54/200, Train Loss: 11.1738, Val Loss: 12.0640\n",
      "Epoch 55/200, Train Loss: 10.9839, Val Loss: 12.4083\n",
      "Epoch 56/200, Train Loss: 10.9975, Val Loss: 12.4371\n",
      "Epoch 57/200, Train Loss: 10.7908, Val Loss: 12.1898\n",
      "Epoch 58/200, Train Loss: 10.8731, Val Loss: 12.1671\n",
      "Epoch 59/200, Train Loss: 10.7721, Val Loss: 12.2556\n",
      "Epoch 60/200, Train Loss: 10.7745, Val Loss: 12.5393\n",
      "Epoch 61/200, Train Loss: 10.6574, Val Loss: 12.1691\n",
      "Epoch 62/200, Train Loss: 10.6636, Val Loss: 12.1133\n",
      "Epoch 63/200, Train Loss: 10.6483, Val Loss: 12.2816\n",
      "Epoch 64/200, Train Loss: 10.5051, Val Loss: 12.1305\n",
      "Epoch 65/200, Train Loss: 10.6066, Val Loss: 12.6870\n",
      "Epoch 66/200, Train Loss: 10.4449, Val Loss: 12.2285\n",
      "Epoch 67/200, Train Loss: 10.3403, Val Loss: 12.1248\n",
      "Epoch 68/200, Train Loss: 10.3342, Val Loss: 12.4655\n",
      "Epoch 69/200, Train Loss: 10.3217, Val Loss: 12.4229\n",
      "Epoch 70/200, Train Loss: 10.3670, Val Loss: 12.7449\n",
      "Epoch 71/200, Train Loss: 10.1926, Val Loss: 12.6449\n",
      "Epoch 72/200, Train Loss: 10.1296, Val Loss: 12.6827\n",
      "Epoch 73/200, Train Loss: 10.1445, Val Loss: 12.3128\n",
      "Epoch 74/200, Train Loss: 10.1062, Val Loss: 12.4248\n",
      "Epoch 75/200, Train Loss: 10.0451, Val Loss: 12.3776\n",
      "Epoch 76/200, Train Loss: 10.0447, Val Loss: 12.0690\n",
      "Epoch 77/200, Train Loss: 9.9865, Val Loss: 12.6643\n",
      "Epoch 78/200, Train Loss: 9.9318, Val Loss: 12.3177\n",
      "Epoch 79/200, Train Loss: 9.8028, Val Loss: 12.2770\n",
      "Epoch 80/200, Train Loss: 9.8608, Val Loss: 12.2317\n",
      "Epoch 81/200, Train Loss: 9.7423, Val Loss: 12.6330\n",
      "Epoch 82/200, Train Loss: 9.6648, Val Loss: 12.2841\n",
      "Epoch 83/200, Train Loss: 9.7326, Val Loss: 12.7326\n",
      "Epoch 84/200, Train Loss: 9.6917, Val Loss: 12.4085\n",
      "Epoch 85/200, Train Loss: 9.5431, Val Loss: 12.7401\n",
      "Epoch 86/200, Train Loss: 9.5936, Val Loss: 12.6174\n",
      "Epoch 87/200, Train Loss: 9.4686, Val Loss: 12.3863\n",
      "Epoch 88/200, Train Loss: 9.5602, Val Loss: 12.5194\n",
      "Epoch 89/200, Train Loss: 9.4554, Val Loss: 12.5843\n",
      "Epoch 90/200, Train Loss: 9.4220, Val Loss: 12.6974\n",
      "Epoch 91/200, Train Loss: 9.4564, Val Loss: 12.6275\n",
      "Epoch 92/200, Train Loss: 9.2647, Val Loss: 12.5961\n",
      "Epoch 93/200, Train Loss: 9.3701, Val Loss: 12.6653\n",
      "Epoch 94/200, Train Loss: 9.2439, Val Loss: 12.7725\n",
      "Epoch 95/200, Train Loss: 9.2426, Val Loss: 12.8441\n",
      "Epoch 96/200, Train Loss: 9.3033, Val Loss: 12.7210\n",
      "Epoch 97/200, Train Loss: 9.2540, Val Loss: 12.9139\n",
      "Epoch 98/200, Train Loss: 9.1462, Val Loss: 12.6897\n",
      "Epoch 99/200, Train Loss: 9.1977, Val Loss: 12.7759\n",
      "Epoch 100/200, Train Loss: 9.0717, Val Loss: 12.7458\n",
      "Epoch 101/200, Train Loss: 9.0659, Val Loss: 12.3778\n",
      "Epoch 102/200, Train Loss: 9.1150, Val Loss: 12.5351\n",
      "Epoch 103/200, Train Loss: 9.1409, Val Loss: 12.7267\n",
      "Epoch 104/200, Train Loss: 9.0211, Val Loss: 12.4425\n",
      "Epoch 105/200, Train Loss: 8.9178, Val Loss: 12.4878\n",
      "Epoch 106/200, Train Loss: 8.8849, Val Loss: 12.4928\n",
      "Epoch 107/200, Train Loss: 8.8484, Val Loss: 12.8675\n",
      "Epoch 108/200, Train Loss: 8.8702, Val Loss: 12.9913\n",
      "Epoch 109/200, Train Loss: 8.8603, Val Loss: 12.8450\n",
      "Epoch 110/200, Train Loss: 8.7610, Val Loss: 12.7342\n",
      "Epoch 111/200, Train Loss: 8.6688, Val Loss: 12.4495\n",
      "Epoch 112/200, Train Loss: 8.7872, Val Loss: 12.6991\n",
      "Epoch 113/200, Train Loss: 8.6690, Val Loss: 12.8519\n",
      "Epoch 114/200, Train Loss: 8.7156, Val Loss: 12.8591\n",
      "Epoch 115/200, Train Loss: 8.6442, Val Loss: 12.7705\n",
      "Epoch 116/200, Train Loss: 8.6138, Val Loss: 12.9894\n",
      "Epoch 117/200, Train Loss: 8.7099, Val Loss: 13.3083\n",
      "Epoch 118/200, Train Loss: 8.5478, Val Loss: 12.9657\n",
      "Epoch 119/200, Train Loss: 8.5535, Val Loss: 12.7607\n",
      "Epoch 120/200, Train Loss: 8.4983, Val Loss: 12.9347\n",
      "Epoch 121/200, Train Loss: 8.4476, Val Loss: 13.1397\n",
      "Epoch 122/200, Train Loss: 8.5342, Val Loss: 12.8063\n",
      "Epoch 123/200, Train Loss: 8.5457, Val Loss: 12.9287\n",
      "Epoch 124/200, Train Loss: 8.4388, Val Loss: 13.0853\n",
      "Epoch 125/200, Train Loss: 8.3838, Val Loss: 13.0499\n",
      "Epoch 126/200, Train Loss: 8.3451, Val Loss: 13.3543\n",
      "Epoch 127/200, Train Loss: 8.3751, Val Loss: 13.0297\n",
      "Epoch 128/200, Train Loss: 8.3548, Val Loss: 13.3580\n",
      "Epoch 129/200, Train Loss: 8.2481, Val Loss: 13.1168\n",
      "Epoch 130/200, Train Loss: 8.2664, Val Loss: 12.9816\n",
      "Epoch 131/200, Train Loss: 8.2288, Val Loss: 12.9865\n",
      "Epoch 132/200, Train Loss: 8.2856, Val Loss: 13.3101\n",
      "Epoch 133/200, Train Loss: 8.1840, Val Loss: 13.5646\n",
      "Epoch 134/200, Train Loss: 8.1855, Val Loss: 13.2268\n",
      "Epoch 135/200, Train Loss: 8.1548, Val Loss: 13.1434\n",
      "Epoch 136/200, Train Loss: 8.1278, Val Loss: 13.2138\n",
      "Epoch 137/200, Train Loss: 8.0846, Val Loss: 13.5212\n",
      "Epoch 138/200, Train Loss: 8.0464, Val Loss: 13.3430\n",
      "Epoch 139/200, Train Loss: 8.0346, Val Loss: 13.4466\n",
      "Epoch 140/200, Train Loss: 8.0331, Val Loss: 13.2283\n",
      "Epoch 141/200, Train Loss: 8.0117, Val Loss: 13.1036\n",
      "Epoch 142/200, Train Loss: 7.9127, Val Loss: 13.2055\n",
      "Epoch 143/200, Train Loss: 7.9645, Val Loss: 13.2580\n",
      "Epoch 144/200, Train Loss: 8.0235, Val Loss: 13.5209\n",
      "Epoch 145/200, Train Loss: 7.9134, Val Loss: 13.3826\n",
      "Epoch 146/200, Train Loss: 7.9144, Val Loss: 13.6051\n",
      "Epoch 147/200, Train Loss: 7.9032, Val Loss: 13.4969\n",
      "Epoch 148/200, Train Loss: 7.8756, Val Loss: 13.3421\n",
      "Epoch 149/200, Train Loss: 7.8091, Val Loss: 13.5636\n",
      "Epoch 150/200, Train Loss: 7.7867, Val Loss: 13.6976\n",
      "Epoch 151/200, Train Loss: 7.8222, Val Loss: 13.1333\n",
      "Epoch 152/200, Train Loss: 7.8307, Val Loss: 13.7445\n",
      "Epoch 153/200, Train Loss: 7.8149, Val Loss: 13.7518\n",
      "Epoch 154/200, Train Loss: 7.7714, Val Loss: 13.5522\n",
      "Epoch 155/200, Train Loss: 7.7088, Val Loss: 13.5980\n",
      "Epoch 156/200, Train Loss: 7.7163, Val Loss: 13.6805\n",
      "Epoch 157/200, Train Loss: 7.7678, Val Loss: 13.2540\n",
      "Epoch 158/200, Train Loss: 7.6486, Val Loss: 13.6295\n",
      "Epoch 159/200, Train Loss: 7.6118, Val Loss: 13.9654\n",
      "Epoch 160/200, Train Loss: 7.6990, Val Loss: 13.9376\n",
      "Epoch 161/200, Train Loss: 7.6391, Val Loss: 13.5533\n",
      "Epoch 162/200, Train Loss: 7.6460, Val Loss: 13.9233\n",
      "Epoch 163/200, Train Loss: 7.5631, Val Loss: 13.8137\n",
      "Epoch 164/200, Train Loss: 7.5234, Val Loss: 13.5575\n",
      "Epoch 165/200, Train Loss: 7.6452, Val Loss: 13.3071\n",
      "Epoch 166/200, Train Loss: 7.5426, Val Loss: 13.7251\n",
      "Epoch 167/200, Train Loss: 7.4974, Val Loss: 14.0042\n",
      "Epoch 168/200, Train Loss: 7.5174, Val Loss: 13.8413\n",
      "Epoch 169/200, Train Loss: 7.4908, Val Loss: 13.8287\n",
      "Epoch 170/200, Train Loss: 7.4702, Val Loss: 13.7700\n",
      "Epoch 171/200, Train Loss: 7.5404, Val Loss: 13.6670\n",
      "Epoch 172/200, Train Loss: 7.5258, Val Loss: 14.2981\n",
      "Epoch 173/200, Train Loss: 7.4455, Val Loss: 13.7261\n",
      "Epoch 174/200, Train Loss: 7.3977, Val Loss: 13.7429\n",
      "Epoch 175/200, Train Loss: 7.3987, Val Loss: 13.9314\n",
      "Epoch 176/200, Train Loss: 7.3248, Val Loss: 13.8013\n",
      "Epoch 177/200, Train Loss: 7.4928, Val Loss: 13.5370\n",
      "Epoch 178/200, Train Loss: 7.3339, Val Loss: 13.9054\n",
      "Epoch 179/200, Train Loss: 7.2854, Val Loss: 13.5884\n",
      "Epoch 180/200, Train Loss: 7.2711, Val Loss: 13.6058\n",
      "Epoch 181/200, Train Loss: 7.2553, Val Loss: 13.9774\n",
      "Epoch 182/200, Train Loss: 7.3356, Val Loss: 13.6864\n",
      "Epoch 183/200, Train Loss: 7.2223, Val Loss: 13.8541\n",
      "Epoch 184/200, Train Loss: 7.3017, Val Loss: 13.7869\n",
      "Epoch 185/200, Train Loss: 7.2485, Val Loss: 14.0189\n",
      "Epoch 186/200, Train Loss: 7.2023, Val Loss: 13.8746\n",
      "Epoch 187/200, Train Loss: 7.1885, Val Loss: 14.0155\n",
      "Epoch 188/200, Train Loss: 7.1614, Val Loss: 14.0286\n",
      "Epoch 189/200, Train Loss: 7.1522, Val Loss: 14.0032\n",
      "Epoch 190/200, Train Loss: 7.1205, Val Loss: 14.3071\n",
      "Epoch 191/200, Train Loss: 7.0468, Val Loss: 14.3607\n",
      "Epoch 192/200, Train Loss: 7.1755, Val Loss: 13.7281\n",
      "Epoch 193/200, Train Loss: 7.0912, Val Loss: 13.8589\n",
      "Epoch 194/200, Train Loss: 7.0946, Val Loss: 14.2514\n",
      "Epoch 195/200, Train Loss: 7.1728, Val Loss: 13.9591\n",
      "Epoch 196/200, Train Loss: 7.1078, Val Loss: 14.0313\n",
      "Epoch 197/200, Train Loss: 6.9845, Val Loss: 14.3171\n",
      "Epoch 198/200, Train Loss: 6.9473, Val Loss: 14.1366\n",
      "Epoch 199/200, Train Loss: 6.9740, Val Loss: 14.2132\n",
      "Epoch 200/200, Train Loss: 7.0365, Val Loss: 13.9835\n",
      "\n",
      "Loaded best model (Val Loss: 11.9949) for final hidden state extraction.\n",
      "Saved best model for NMRNN_Spatial_ModReadout (samples=1280) to results_data_size_sweep/20250514_045146/samples_1280/NMRNN_Spatial_ModReadout_samples_1280_best.pt\n",
      "\n",
      "--- Performing Decodability Analysis for NMRNN_Spatial_ModReadout (samples=1280, k=15) ---\n",
      "  Analyzing decodability for NMRNN_Spatial_ModReadout...\n",
      "  Hidden states shape: torch.Size([160, 200, 128])\n",
      "  Coefficients shape: torch.Size([160, 15])\n",
      "  Processed hidden states shape for decoder: torch.Size([160, 128])\n",
      "  RidgeCV Decoder for NMRNN_Spatial_ModReadout - Test MSE: 1.3661, Test R2: 0.3107 (best alpha: 100.0000)\n",
      "  Decodability plot saved to results_data_size_sweep/20250514_045146/samples_1280/decodability_NMRNN_Spatial_ModReadout_coeff1.png\n",
      "Decodability (R2 score) for NMRNN_Spatial_ModReadout (samples=1280): 0.3107\n",
      "\n",
      "--- Training NMRNN_NoSpatial_ModReadout (samples=1280, k=15) ---\n",
      "Number of parameters: 66832\n",
      "Epoch 1/200, Train Loss: 16.9103, Val Loss: 15.7151\n",
      "  New best validation loss: 15.7151\n",
      "Epoch 2/200, Train Loss: 16.6868, Val Loss: 15.8390\n",
      "Epoch 3/200, Train Loss: 16.6097, Val Loss: 15.7694\n",
      "Epoch 4/200, Train Loss: 16.5701, Val Loss: 15.7914\n",
      "Epoch 5/200, Train Loss: 16.5966, Val Loss: 15.7369\n",
      "Epoch 6/200, Train Loss: 16.5220, Val Loss: 15.7414\n",
      "Epoch 7/200, Train Loss: 16.4871, Val Loss: 15.7632\n",
      "Epoch 8/200, Train Loss: 16.4604, Val Loss: 15.6752\n",
      "  New best validation loss: 15.6752\n",
      "Epoch 9/200, Train Loss: 16.4283, Val Loss: 15.5891\n",
      "  New best validation loss: 15.5891\n",
      "Epoch 10/200, Train Loss: 16.3502, Val Loss: 15.5438\n",
      "  New best validation loss: 15.5438\n",
      "Epoch 11/200, Train Loss: 16.2838, Val Loss: 15.4638\n",
      "  New best validation loss: 15.4638\n",
      "Epoch 12/200, Train Loss: 16.1728, Val Loss: 15.2859\n",
      "  New best validation loss: 15.2859\n",
      "Epoch 13/200, Train Loss: 16.0912, Val Loss: 15.1451\n",
      "  New best validation loss: 15.1451\n",
      "Epoch 14/200, Train Loss: 15.9566, Val Loss: 14.9816\n",
      "  New best validation loss: 14.9816\n",
      "Epoch 15/200, Train Loss: 15.7939, Val Loss: 14.8489\n",
      "  New best validation loss: 14.8489\n",
      "Epoch 16/200, Train Loss: 15.7171, Val Loss: 14.7415\n",
      "  New best validation loss: 14.7415\n",
      "Epoch 17/200, Train Loss: 15.5498, Val Loss: 14.8681\n",
      "Epoch 18/200, Train Loss: 15.4722, Val Loss: 14.7111\n",
      "  New best validation loss: 14.7111\n",
      "Epoch 19/200, Train Loss: 15.2697, Val Loss: 14.4949\n",
      "  New best validation loss: 14.4949\n",
      "Epoch 20/200, Train Loss: 15.2231, Val Loss: 14.4104\n",
      "  New best validation loss: 14.4104\n",
      "Epoch 21/200, Train Loss: 15.0930, Val Loss: 14.4740\n",
      "Epoch 22/200, Train Loss: 15.0130, Val Loss: 14.3219\n",
      "  New best validation loss: 14.3219\n",
      "Epoch 23/200, Train Loss: 14.7192, Val Loss: 14.0344\n",
      "  New best validation loss: 14.0344\n",
      "Epoch 24/200, Train Loss: 14.5804, Val Loss: 14.0643\n",
      "Epoch 25/200, Train Loss: 14.4989, Val Loss: 14.0660\n",
      "Epoch 26/200, Train Loss: 14.5053, Val Loss: 13.6968\n",
      "  New best validation loss: 13.6968\n",
      "Epoch 27/200, Train Loss: 14.3081, Val Loss: 13.5801\n",
      "  New best validation loss: 13.5801\n",
      "Epoch 28/200, Train Loss: 14.0452, Val Loss: 13.3630\n",
      "  New best validation loss: 13.3630\n",
      "Epoch 29/200, Train Loss: 13.9847, Val Loss: 13.4981\n",
      "Epoch 30/200, Train Loss: 13.8134, Val Loss: 13.2628\n",
      "  New best validation loss: 13.2628\n",
      "Epoch 31/200, Train Loss: 13.5740, Val Loss: 13.1474\n",
      "  New best validation loss: 13.1474\n",
      "Epoch 32/200, Train Loss: 13.4526, Val Loss: 12.9329\n",
      "  New best validation loss: 12.9329\n",
      "Epoch 33/200, Train Loss: 13.3353, Val Loss: 13.1702\n",
      "Epoch 34/200, Train Loss: 13.1454, Val Loss: 12.6726\n",
      "  New best validation loss: 12.6726\n",
      "Epoch 35/200, Train Loss: 12.9851, Val Loss: 12.5082\n",
      "  New best validation loss: 12.5082\n",
      "Epoch 36/200, Train Loss: 12.8514, Val Loss: 12.7426\n",
      "Epoch 37/200, Train Loss: 12.7400, Val Loss: 12.3540\n",
      "  New best validation loss: 12.3540\n",
      "Epoch 38/200, Train Loss: 12.5703, Val Loss: 12.1990\n",
      "  New best validation loss: 12.1990\n",
      "Epoch 39/200, Train Loss: 12.4621, Val Loss: 12.2119\n",
      "Epoch 40/200, Train Loss: 12.4825, Val Loss: 12.2321\n",
      "Epoch 41/200, Train Loss: 12.1882, Val Loss: 12.0794\n",
      "  New best validation loss: 12.0794\n",
      "Epoch 42/200, Train Loss: 12.1318, Val Loss: 11.9811\n",
      "  New best validation loss: 11.9811\n",
      "Epoch 43/200, Train Loss: 12.0630, Val Loss: 12.0137\n",
      "Epoch 44/200, Train Loss: 11.9301, Val Loss: 12.5636\n",
      "Epoch 45/200, Train Loss: 11.8844, Val Loss: 11.9410\n",
      "  New best validation loss: 11.9410\n",
      "Epoch 46/200, Train Loss: 11.7534, Val Loss: 12.0812\n",
      "Epoch 47/200, Train Loss: 11.5705, Val Loss: 11.5622\n",
      "  New best validation loss: 11.5622\n",
      "Epoch 48/200, Train Loss: 11.5484, Val Loss: 11.9351\n",
      "Epoch 49/200, Train Loss: 11.5163, Val Loss: 11.7353\n",
      "Epoch 50/200, Train Loss: 11.4872, Val Loss: 11.8109\n",
      "Epoch 51/200, Train Loss: 11.3098, Val Loss: 12.1365\n",
      "Epoch 52/200, Train Loss: 11.2837, Val Loss: 11.8892\n",
      "Epoch 53/200, Train Loss: 11.3034, Val Loss: 11.6279\n",
      "Epoch 54/200, Train Loss: 11.0716, Val Loss: 11.8304\n",
      "Epoch 55/200, Train Loss: 11.1177, Val Loss: 11.4208\n",
      "  New best validation loss: 11.4208\n",
      "Epoch 56/200, Train Loss: 11.2883, Val Loss: 11.5611\n",
      "Epoch 57/200, Train Loss: 11.0812, Val Loss: 11.8281\n",
      "Epoch 58/200, Train Loss: 10.9269, Val Loss: 11.7645\n",
      "Epoch 59/200, Train Loss: 10.8582, Val Loss: 11.6758\n",
      "Epoch 60/200, Train Loss: 10.7712, Val Loss: 11.9961\n",
      "Epoch 61/200, Train Loss: 10.7745, Val Loss: 11.8096\n",
      "Epoch 62/200, Train Loss: 10.7067, Val Loss: 11.7163\n",
      "Epoch 63/200, Train Loss: 10.6415, Val Loss: 12.2867\n",
      "Epoch 64/200, Train Loss: 10.6626, Val Loss: 11.8142\n",
      "Epoch 65/200, Train Loss: 10.5229, Val Loss: 11.5023\n",
      "Epoch 66/200, Train Loss: 10.5286, Val Loss: 11.8089\n",
      "Epoch 67/200, Train Loss: 10.4793, Val Loss: 11.6672\n",
      "Epoch 68/200, Train Loss: 10.4109, Val Loss: 11.9522\n",
      "Epoch 69/200, Train Loss: 10.3827, Val Loss: 11.7236\n",
      "Epoch 70/200, Train Loss: 10.3015, Val Loss: 11.7996\n",
      "Epoch 71/200, Train Loss: 10.2721, Val Loss: 11.7888\n",
      "Epoch 72/200, Train Loss: 10.2096, Val Loss: 12.2857\n",
      "Epoch 73/200, Train Loss: 10.2072, Val Loss: 12.1740\n",
      "Epoch 74/200, Train Loss: 10.1434, Val Loss: 11.8381\n",
      "Epoch 75/200, Train Loss: 10.1936, Val Loss: 12.0308\n",
      "Epoch 76/200, Train Loss: 10.0370, Val Loss: 11.7004\n",
      "Epoch 77/200, Train Loss: 9.9613, Val Loss: 12.1218\n",
      "Epoch 78/200, Train Loss: 10.0132, Val Loss: 12.0960\n",
      "Epoch 79/200, Train Loss: 9.8833, Val Loss: 12.1940\n",
      "Epoch 80/200, Train Loss: 9.9174, Val Loss: 11.8044\n",
      "Epoch 81/200, Train Loss: 9.7608, Val Loss: 11.8664\n",
      "Epoch 82/200, Train Loss: 9.8236, Val Loss: 12.1808\n",
      "Epoch 83/200, Train Loss: 9.7355, Val Loss: 12.0332\n",
      "Epoch 84/200, Train Loss: 9.6485, Val Loss: 11.7042\n",
      "Epoch 85/200, Train Loss: 9.7041, Val Loss: 11.8060\n",
      "Epoch 86/200, Train Loss: 9.6063, Val Loss: 11.7771\n",
      "Epoch 87/200, Train Loss: 9.6898, Val Loss: 12.1122\n",
      "Epoch 88/200, Train Loss: 9.6316, Val Loss: 11.9517\n",
      "Epoch 89/200, Train Loss: 9.4734, Val Loss: 11.9165\n",
      "Epoch 90/200, Train Loss: 9.5257, Val Loss: 11.9424\n",
      "Epoch 91/200, Train Loss: 9.4457, Val Loss: 11.9719\n",
      "Epoch 92/200, Train Loss: 9.4579, Val Loss: 12.7756\n",
      "Epoch 93/200, Train Loss: 9.3799, Val Loss: 12.1240\n",
      "Epoch 94/200, Train Loss: 9.3582, Val Loss: 12.2823\n",
      "Epoch 95/200, Train Loss: 9.3305, Val Loss: 12.1302\n",
      "Epoch 96/200, Train Loss: 9.2715, Val Loss: 11.9171\n",
      "Epoch 97/200, Train Loss: 9.4236, Val Loss: 12.4118\n",
      "Epoch 98/200, Train Loss: 9.2887, Val Loss: 12.1954\n",
      "Epoch 99/200, Train Loss: 9.1360, Val Loss: 11.9716\n",
      "Epoch 100/200, Train Loss: 9.1453, Val Loss: 12.1342\n",
      "Epoch 101/200, Train Loss: 9.0644, Val Loss: 12.7511\n",
      "Epoch 102/200, Train Loss: 9.1474, Val Loss: 12.8817\n",
      "Epoch 103/200, Train Loss: 9.1950, Val Loss: 12.0331\n",
      "Epoch 104/200, Train Loss: 9.0347, Val Loss: 12.3292\n",
      "Epoch 105/200, Train Loss: 8.9963, Val Loss: 12.3857\n",
      "Epoch 106/200, Train Loss: 9.0018, Val Loss: 12.5031\n",
      "Epoch 107/200, Train Loss: 9.0059, Val Loss: 12.1343\n",
      "Epoch 108/200, Train Loss: 8.8753, Val Loss: 12.6118\n",
      "Epoch 109/200, Train Loss: 8.8557, Val Loss: 12.6061\n",
      "Epoch 110/200, Train Loss: 8.9390, Val Loss: 12.7340\n",
      "Epoch 111/200, Train Loss: 8.8012, Val Loss: 12.4137\n",
      "Epoch 112/200, Train Loss: 8.7933, Val Loss: 12.5795\n",
      "Epoch 113/200, Train Loss: 8.7873, Val Loss: 12.5540\n",
      "Epoch 114/200, Train Loss: 8.7981, Val Loss: 12.2785\n",
      "Epoch 115/200, Train Loss: 8.6745, Val Loss: 12.3962\n",
      "Epoch 116/200, Train Loss: 8.7051, Val Loss: 12.4842\n",
      "Epoch 117/200, Train Loss: 8.7016, Val Loss: 12.5421\n",
      "Epoch 118/200, Train Loss: 8.6489, Val Loss: 12.5937\n",
      "Epoch 119/200, Train Loss: 8.6306, Val Loss: 12.7677\n",
      "Epoch 120/200, Train Loss: 8.5455, Val Loss: 12.5856\n",
      "Epoch 121/200, Train Loss: 8.5018, Val Loss: 12.7058\n",
      "Epoch 122/200, Train Loss: 8.5300, Val Loss: 12.5593\n",
      "Epoch 123/200, Train Loss: 8.5749, Val Loss: 12.7376\n",
      "Epoch 124/200, Train Loss: 8.4292, Val Loss: 12.8737\n",
      "Epoch 125/200, Train Loss: 8.4322, Val Loss: 12.7268\n",
      "Epoch 126/200, Train Loss: 8.3934, Val Loss: 12.8779\n",
      "Epoch 127/200, Train Loss: 8.3875, Val Loss: 12.7077\n",
      "Epoch 128/200, Train Loss: 8.3378, Val Loss: 12.7656\n",
      "Epoch 129/200, Train Loss: 8.2537, Val Loss: 12.8885\n",
      "Epoch 130/200, Train Loss: 8.3468, Val Loss: 13.0411\n",
      "Epoch 131/200, Train Loss: 8.2886, Val Loss: 12.7640\n",
      "Epoch 132/200, Train Loss: 8.2613, Val Loss: 12.8030\n",
      "Epoch 133/200, Train Loss: 8.2032, Val Loss: 13.3551\n",
      "Epoch 134/200, Train Loss: 8.2760, Val Loss: 13.4846\n",
      "Epoch 135/200, Train Loss: 8.2615, Val Loss: 13.1732\n",
      "Epoch 136/200, Train Loss: 8.1517, Val Loss: 12.7767\n",
      "Epoch 137/200, Train Loss: 8.1946, Val Loss: 12.7153\n",
      "Epoch 138/200, Train Loss: 8.1170, Val Loss: 13.1190\n",
      "Epoch 139/200, Train Loss: 8.0094, Val Loss: 12.8376\n",
      "Epoch 140/200, Train Loss: 8.1051, Val Loss: 12.8479\n",
      "Epoch 141/200, Train Loss: 8.0241, Val Loss: 13.2941\n",
      "Epoch 142/200, Train Loss: 7.9815, Val Loss: 13.2539\n",
      "Epoch 143/200, Train Loss: 7.9057, Val Loss: 13.5688\n",
      "Epoch 144/200, Train Loss: 7.8754, Val Loss: 13.1530\n",
      "Epoch 145/200, Train Loss: 7.8791, Val Loss: 13.3648\n",
      "Epoch 146/200, Train Loss: 7.8802, Val Loss: 13.4827\n",
      "Epoch 147/200, Train Loss: 7.8527, Val Loss: 13.4073\n",
      "Epoch 148/200, Train Loss: 7.8332, Val Loss: 13.4364\n",
      "Epoch 149/200, Train Loss: 7.8335, Val Loss: 13.5490\n",
      "Epoch 150/200, Train Loss: 7.7495, Val Loss: 13.1491\n",
      "Epoch 151/200, Train Loss: 7.8538, Val Loss: 13.1397\n",
      "Epoch 152/200, Train Loss: 7.7520, Val Loss: 13.7195\n",
      "Epoch 153/200, Train Loss: 7.8496, Val Loss: 13.4943\n",
      "Epoch 154/200, Train Loss: 7.8159, Val Loss: 13.4341\n",
      "Epoch 155/200, Train Loss: 7.7526, Val Loss: 13.5061\n",
      "Epoch 156/200, Train Loss: 7.7343, Val Loss: 13.6651\n",
      "Epoch 157/200, Train Loss: 7.6710, Val Loss: 13.3359\n",
      "Epoch 158/200, Train Loss: 7.6818, Val Loss: 13.7092\n",
      "Epoch 159/200, Train Loss: 7.6491, Val Loss: 13.4207\n",
      "Epoch 160/200, Train Loss: 7.6561, Val Loss: 13.4062\n",
      "Epoch 161/200, Train Loss: 7.5193, Val Loss: 13.6469\n",
      "Epoch 162/200, Train Loss: 7.5429, Val Loss: 13.4466\n",
      "Epoch 163/200, Train Loss: 7.5882, Val Loss: 13.6427\n",
      "Epoch 164/200, Train Loss: 7.5665, Val Loss: 13.7905\n",
      "Epoch 165/200, Train Loss: 7.5359, Val Loss: 13.4958\n",
      "Epoch 166/200, Train Loss: 7.4630, Val Loss: 14.0414\n",
      "Epoch 167/200, Train Loss: 7.4691, Val Loss: 13.4841\n",
      "Epoch 168/200, Train Loss: 7.4349, Val Loss: 13.9094\n",
      "Epoch 169/200, Train Loss: 7.3802, Val Loss: 13.9516\n",
      "Epoch 170/200, Train Loss: 7.3932, Val Loss: 13.8327\n",
      "Epoch 171/200, Train Loss: 7.3764, Val Loss: 13.7623\n",
      "Epoch 172/200, Train Loss: 7.4002, Val Loss: 13.6165\n",
      "Epoch 173/200, Train Loss: 7.3211, Val Loss: 13.7264\n",
      "Epoch 174/200, Train Loss: 7.3354, Val Loss: 13.5371\n",
      "Epoch 175/200, Train Loss: 7.2402, Val Loss: 13.6319\n",
      "Epoch 176/200, Train Loss: 7.3057, Val Loss: 14.0936\n",
      "Epoch 177/200, Train Loss: 7.2670, Val Loss: 14.2682\n",
      "Epoch 178/200, Train Loss: 7.2922, Val Loss: 13.9053\n",
      "Epoch 179/200, Train Loss: 7.2580, Val Loss: 13.7600\n",
      "Epoch 180/200, Train Loss: 7.2490, Val Loss: 13.7205\n",
      "Epoch 181/200, Train Loss: 7.1681, Val Loss: 13.8008\n",
      "Epoch 182/200, Train Loss: 7.1914, Val Loss: 14.2419\n",
      "Epoch 183/200, Train Loss: 7.1645, Val Loss: 13.9919\n",
      "Epoch 184/200, Train Loss: 7.1251, Val Loss: 13.6876\n",
      "Epoch 185/200, Train Loss: 7.2107, Val Loss: 13.7864\n",
      "Epoch 186/200, Train Loss: 7.0825, Val Loss: 14.0534\n",
      "Epoch 187/200, Train Loss: 7.0934, Val Loss: 13.9315\n",
      "Epoch 188/200, Train Loss: 7.0587, Val Loss: 13.5494\n",
      "Epoch 189/200, Train Loss: 7.0527, Val Loss: 14.1194\n",
      "Epoch 190/200, Train Loss: 7.0127, Val Loss: 13.9951\n",
      "Epoch 191/200, Train Loss: 7.0419, Val Loss: 14.0637\n",
      "Epoch 192/200, Train Loss: 6.9922, Val Loss: 13.9292\n",
      "Epoch 193/200, Train Loss: 7.0364, Val Loss: 13.8429\n",
      "Epoch 194/200, Train Loss: 6.9337, Val Loss: 14.0276\n",
      "Epoch 195/200, Train Loss: 6.9766, Val Loss: 14.2601\n",
      "Epoch 196/200, Train Loss: 6.9756, Val Loss: 13.8522\n",
      "Epoch 197/200, Train Loss: 6.9248, Val Loss: 14.2212\n",
      "Epoch 198/200, Train Loss: 6.9467, Val Loss: 13.9224\n",
      "Epoch 199/200, Train Loss: 6.9558, Val Loss: 14.0927\n",
      "Epoch 200/200, Train Loss: 6.9426, Val Loss: 14.6425\n",
      "\n",
      "Loaded best model (Val Loss: 11.4208) for final hidden state extraction.\n",
      "Saved best model for NMRNN_NoSpatial_ModReadout (samples=1280) to results_data_size_sweep/20250514_045146/samples_1280/NMRNN_NoSpatial_ModReadout_samples_1280_best.pt\n",
      "\n",
      "--- Performing Decodability Analysis for NMRNN_NoSpatial_ModReadout (samples=1280, k=15) ---\n",
      "  Analyzing decodability for NMRNN_NoSpatial_ModReadout...\n",
      "  Hidden states shape: torch.Size([160, 200, 128])\n",
      "  Coefficients shape: torch.Size([160, 15])\n",
      "  Processed hidden states shape for decoder: torch.Size([160, 128])\n",
      "  RidgeCV Decoder for NMRNN_NoSpatial_ModReadout - Test MSE: 1.2918, Test R2: 0.3493 (best alpha: 100.0000)\n",
      "  Decodability plot saved to results_data_size_sweep/20250514_045146/samples_1280/decodability_NMRNN_NoSpatial_ModReadout_coeff1.png\n",
      "Decodability (R2 score) for NMRNN_NoSpatial_ModReadout (samples=1280): 0.3493\n",
      "\n",
      "--- Training NMRNN_Spatial_FixedReadout (samples=1280, k=15) ---\n",
      "Number of parameters: 66449\n",
      "Epoch 1/200, Train Loss: 16.8806, Val Loss: 15.7427\n",
      "  New best validation loss: 15.7427\n",
      "Epoch 2/200, Train Loss: 16.7204, Val Loss: 15.7805\n",
      "Epoch 3/200, Train Loss: 16.6511, Val Loss: 15.7799\n",
      "Epoch 4/200, Train Loss: 16.6112, Val Loss: 15.7664\n",
      "Epoch 5/200, Train Loss: 16.5400, Val Loss: 15.6488\n",
      "  New best validation loss: 15.6488\n",
      "Epoch 6/200, Train Loss: 16.4984, Val Loss: 15.5632\n",
      "  New best validation loss: 15.5632\n",
      "Epoch 7/200, Train Loss: 16.4293, Val Loss: 15.5936\n",
      "Epoch 8/200, Train Loss: 16.3528, Val Loss: 15.4229\n",
      "  New best validation loss: 15.4229\n",
      "Epoch 9/200, Train Loss: 16.2350, Val Loss: 15.2470\n",
      "  New best validation loss: 15.2470\n",
      "Epoch 10/200, Train Loss: 16.1678, Val Loss: 15.1445\n",
      "  New best validation loss: 15.1445\n",
      "Epoch 11/200, Train Loss: 15.9731, Val Loss: 14.9014\n",
      "  New best validation loss: 14.9014\n",
      "Epoch 12/200, Train Loss: 15.8058, Val Loss: 14.7216\n",
      "  New best validation loss: 14.7216\n",
      "Epoch 13/200, Train Loss: 15.6572, Val Loss: 14.8180\n",
      "Epoch 14/200, Train Loss: 15.5572, Val Loss: 14.7358\n",
      "Epoch 15/200, Train Loss: 15.4554, Val Loss: 14.4563\n",
      "  New best validation loss: 14.4563\n",
      "Epoch 16/200, Train Loss: 15.3412, Val Loss: 14.2979\n",
      "  New best validation loss: 14.2979\n",
      "Epoch 17/200, Train Loss: 15.1170, Val Loss: 14.4326\n",
      "Epoch 18/200, Train Loss: 15.0608, Val Loss: 14.1892\n",
      "  New best validation loss: 14.1892\n",
      "Epoch 19/200, Train Loss: 14.9370, Val Loss: 14.2001\n",
      "Epoch 20/200, Train Loss: 14.8633, Val Loss: 14.3534\n",
      "Epoch 21/200, Train Loss: 14.7430, Val Loss: 13.9108\n",
      "  New best validation loss: 13.9108\n",
      "Epoch 22/200, Train Loss: 14.5536, Val Loss: 14.0208\n",
      "Epoch 23/200, Train Loss: 14.4379, Val Loss: 14.0388\n",
      "Epoch 24/200, Train Loss: 14.3928, Val Loss: 13.7882\n",
      "  New best validation loss: 13.7882\n",
      "Epoch 25/200, Train Loss: 14.2211, Val Loss: 13.9049\n",
      "Epoch 26/200, Train Loss: 14.0809, Val Loss: 13.5433\n",
      "  New best validation loss: 13.5433\n",
      "Epoch 27/200, Train Loss: 13.9174, Val Loss: 13.7170\n",
      "Epoch 28/200, Train Loss: 13.9006, Val Loss: 13.7168\n",
      "Epoch 29/200, Train Loss: 13.7031, Val Loss: 13.4178\n",
      "  New best validation loss: 13.4178\n",
      "Epoch 30/200, Train Loss: 13.5241, Val Loss: 13.9576\n",
      "Epoch 31/200, Train Loss: 13.5126, Val Loss: 13.2888\n",
      "  New best validation loss: 13.2888\n",
      "Epoch 32/200, Train Loss: 13.2779, Val Loss: 13.2199\n",
      "  New best validation loss: 13.2199\n",
      "Epoch 33/200, Train Loss: 13.1686, Val Loss: 13.4971\n",
      "Epoch 34/200, Train Loss: 13.1973, Val Loss: 13.1185\n",
      "  New best validation loss: 13.1185\n",
      "Epoch 35/200, Train Loss: 13.0205, Val Loss: 13.0751\n",
      "  New best validation loss: 13.0751\n",
      "Epoch 36/200, Train Loss: 12.8030, Val Loss: 12.8597\n",
      "  New best validation loss: 12.8597\n",
      "Epoch 37/200, Train Loss: 12.7788, Val Loss: 12.7113\n",
      "  New best validation loss: 12.7113\n",
      "Epoch 38/200, Train Loss: 12.6740, Val Loss: 12.8966\n",
      "Epoch 39/200, Train Loss: 12.5583, Val Loss: 12.7428\n",
      "Epoch 40/200, Train Loss: 12.4014, Val Loss: 12.6587\n",
      "  New best validation loss: 12.6587\n",
      "Epoch 41/200, Train Loss: 12.5459, Val Loss: 12.7064\n",
      "Epoch 42/200, Train Loss: 12.3356, Val Loss: 12.8722\n",
      "Epoch 43/200, Train Loss: 12.1837, Val Loss: 12.8130\n",
      "Epoch 44/200, Train Loss: 12.2047, Val Loss: 12.8397\n",
      "Epoch 45/200, Train Loss: 11.9857, Val Loss: 12.6739\n",
      "Epoch 46/200, Train Loss: 11.9933, Val Loss: 12.9285\n",
      "Epoch 47/200, Train Loss: 12.1502, Val Loss: 12.5048\n",
      "  New best validation loss: 12.5048\n",
      "Epoch 48/200, Train Loss: 11.9354, Val Loss: 12.7343\n",
      "Epoch 49/200, Train Loss: 11.8411, Val Loss: 12.3688\n",
      "  New best validation loss: 12.3688\n",
      "Epoch 50/200, Train Loss: 11.7664, Val Loss: 12.6853\n",
      "Epoch 51/200, Train Loss: 11.7576, Val Loss: 12.8076\n",
      "Epoch 52/200, Train Loss: 11.6458, Val Loss: 12.5885\n",
      "Epoch 53/200, Train Loss: 11.4418, Val Loss: 12.4032\n",
      "Epoch 54/200, Train Loss: 11.3787, Val Loss: 12.4086\n",
      "Epoch 55/200, Train Loss: 11.4336, Val Loss: 12.3855\n",
      "Epoch 56/200, Train Loss: 11.4112, Val Loss: 12.4912\n",
      "Epoch 57/200, Train Loss: 11.3522, Val Loss: 12.1442\n",
      "  New best validation loss: 12.1442\n",
      "Epoch 58/200, Train Loss: 11.3710, Val Loss: 12.4926\n",
      "Epoch 59/200, Train Loss: 11.2500, Val Loss: 12.2608\n",
      "Epoch 60/200, Train Loss: 11.3786, Val Loss: 12.4270\n",
      "Epoch 61/200, Train Loss: 11.2704, Val Loss: 12.3738\n",
      "Epoch 62/200, Train Loss: 11.0286, Val Loss: 12.4814\n",
      "Epoch 63/200, Train Loss: 10.8623, Val Loss: 12.6932\n",
      "Epoch 64/200, Train Loss: 10.9846, Val Loss: 12.4373\n",
      "Epoch 65/200, Train Loss: 10.9008, Val Loss: 12.3684\n",
      "Epoch 66/200, Train Loss: 10.8732, Val Loss: 12.2175\n",
      "Epoch 67/200, Train Loss: 10.8941, Val Loss: 12.4286\n",
      "Epoch 68/200, Train Loss: 10.7935, Val Loss: 12.2367\n",
      "Epoch 69/200, Train Loss: 10.7154, Val Loss: 12.2128\n",
      "Epoch 70/200, Train Loss: 10.7582, Val Loss: 12.1576\n",
      "Epoch 71/200, Train Loss: 10.6119, Val Loss: 13.0007\n",
      "Epoch 72/200, Train Loss: 10.6325, Val Loss: 12.5294\n",
      "Epoch 73/200, Train Loss: 10.5240, Val Loss: 12.5044\n",
      "Epoch 74/200, Train Loss: 10.6555, Val Loss: 12.5375\n",
      "Epoch 75/200, Train Loss: 10.4907, Val Loss: 11.9071\n",
      "  New best validation loss: 11.9071\n",
      "Epoch 76/200, Train Loss: 10.3490, Val Loss: 12.2773\n",
      "Epoch 77/200, Train Loss: 10.3540, Val Loss: 12.6265\n",
      "Epoch 78/200, Train Loss: 10.2933, Val Loss: 12.4927\n",
      "Epoch 79/200, Train Loss: 10.2623, Val Loss: 12.4703\n",
      "Epoch 80/200, Train Loss: 10.2735, Val Loss: 12.4153\n",
      "Epoch 81/200, Train Loss: 10.1546, Val Loss: 12.1059\n",
      "Epoch 82/200, Train Loss: 10.1671, Val Loss: 12.1089\n",
      "Epoch 83/200, Train Loss: 10.1334, Val Loss: 12.4514\n",
      "Epoch 84/200, Train Loss: 10.0308, Val Loss: 12.2612\n",
      "Epoch 85/200, Train Loss: 10.0372, Val Loss: 12.1930\n",
      "Epoch 86/200, Train Loss: 10.1664, Val Loss: 12.5046\n",
      "Epoch 87/200, Train Loss: 10.0276, Val Loss: 12.4529\n",
      "Epoch 88/200, Train Loss: 9.9666, Val Loss: 12.2640\n",
      "Epoch 89/200, Train Loss: 9.8765, Val Loss: 12.4186\n",
      "Epoch 90/200, Train Loss: 9.8584, Val Loss: 12.4236\n",
      "Epoch 91/200, Train Loss: 9.7762, Val Loss: 12.4930\n",
      "Epoch 92/200, Train Loss: 9.8386, Val Loss: 12.7646\n",
      "Epoch 93/200, Train Loss: 9.7903, Val Loss: 12.3067\n",
      "Epoch 94/200, Train Loss: 9.7959, Val Loss: 12.6683\n",
      "Epoch 95/200, Train Loss: 9.7615, Val Loss: 12.5823\n",
      "Epoch 96/200, Train Loss: 9.7484, Val Loss: 12.7874\n",
      "Epoch 97/200, Train Loss: 9.7093, Val Loss: 12.8765\n",
      "Epoch 98/200, Train Loss: 9.6549, Val Loss: 12.5252\n",
      "Epoch 99/200, Train Loss: 9.5659, Val Loss: 12.5222\n",
      "Epoch 100/200, Train Loss: 9.5631, Val Loss: 12.3799\n",
      "Epoch 101/200, Train Loss: 9.5246, Val Loss: 12.5963\n",
      "Epoch 102/200, Train Loss: 9.5231, Val Loss: 12.8767\n",
      "Epoch 103/200, Train Loss: 9.4708, Val Loss: 12.5782\n",
      "Epoch 104/200, Train Loss: 9.5624, Val Loss: 12.6293\n",
      "Epoch 105/200, Train Loss: 9.5013, Val Loss: 13.1561\n",
      "Epoch 106/200, Train Loss: 9.4684, Val Loss: 13.0926\n",
      "Epoch 107/200, Train Loss: 9.4807, Val Loss: 12.5293\n",
      "Epoch 108/200, Train Loss: 9.3440, Val Loss: 12.7497\n",
      "Epoch 109/200, Train Loss: 9.3460, Val Loss: 12.7154\n",
      "Epoch 110/200, Train Loss: 9.3161, Val Loss: 12.9378\n",
      "Epoch 111/200, Train Loss: 9.3147, Val Loss: 12.5578\n",
      "Epoch 112/200, Train Loss: 9.2668, Val Loss: 12.3125\n",
      "Epoch 113/200, Train Loss: 9.1522, Val Loss: 12.9926\n",
      "Epoch 114/200, Train Loss: 9.3228, Val Loss: 12.7373\n",
      "Epoch 115/200, Train Loss: 9.2099, Val Loss: 12.2500\n",
      "Epoch 116/200, Train Loss: 9.2373, Val Loss: 12.9865\n",
      "Epoch 117/200, Train Loss: 9.1327, Val Loss: 12.7884\n",
      "Epoch 118/200, Train Loss: 9.2945, Val Loss: 12.5368\n",
      "Epoch 119/200, Train Loss: 9.1974, Val Loss: 12.5325\n",
      "Epoch 120/200, Train Loss: 9.1311, Val Loss: 12.4347\n",
      "Epoch 121/200, Train Loss: 9.0086, Val Loss: 13.0334\n",
      "Epoch 122/200, Train Loss: 9.0091, Val Loss: 12.6749\n",
      "Epoch 123/200, Train Loss: 9.0861, Val Loss: 12.3859\n",
      "Epoch 124/200, Train Loss: 8.8940, Val Loss: 12.8018\n",
      "Epoch 125/200, Train Loss: 8.8812, Val Loss: 13.1163\n",
      "Epoch 126/200, Train Loss: 8.9578, Val Loss: 12.6099\n",
      "Epoch 127/200, Train Loss: 8.9386, Val Loss: 12.8608\n",
      "Epoch 128/200, Train Loss: 8.8363, Val Loss: 12.6384\n",
      "Epoch 129/200, Train Loss: 8.8057, Val Loss: 12.4418\n",
      "Epoch 130/200, Train Loss: 8.8746, Val Loss: 13.0651\n",
      "Epoch 131/200, Train Loss: 8.7792, Val Loss: 12.6336\n",
      "Epoch 132/200, Train Loss: 8.7599, Val Loss: 12.7974\n",
      "Epoch 133/200, Train Loss: 8.7137, Val Loss: 13.6012\n",
      "Epoch 134/200, Train Loss: 8.7481, Val Loss: 12.7129\n",
      "Epoch 135/200, Train Loss: 8.6254, Val Loss: 12.8657\n",
      "Epoch 136/200, Train Loss: 8.6795, Val Loss: 12.7254\n",
      "Epoch 137/200, Train Loss: 8.6221, Val Loss: 12.8940\n",
      "Epoch 138/200, Train Loss: 8.6204, Val Loss: 12.9656\n",
      "Epoch 139/200, Train Loss: 8.6544, Val Loss: 13.3659\n",
      "Epoch 140/200, Train Loss: 8.5976, Val Loss: 13.2894\n",
      "Epoch 141/200, Train Loss: 8.5804, Val Loss: 13.1585\n",
      "Epoch 142/200, Train Loss: 8.5159, Val Loss: 12.8545\n",
      "Epoch 143/200, Train Loss: 8.5728, Val Loss: 13.1828\n",
      "Epoch 144/200, Train Loss: 8.6169, Val Loss: 12.9057\n",
      "Epoch 145/200, Train Loss: 8.5539, Val Loss: 13.3318\n",
      "Epoch 146/200, Train Loss: 8.5507, Val Loss: 13.2403\n",
      "Epoch 147/200, Train Loss: 8.5683, Val Loss: 13.0928\n",
      "Epoch 148/200, Train Loss: 8.5149, Val Loss: 13.0241\n",
      "Epoch 149/200, Train Loss: 8.4449, Val Loss: 12.8756\n",
      "Epoch 150/200, Train Loss: 8.4856, Val Loss: 12.9832\n",
      "Epoch 151/200, Train Loss: 8.5188, Val Loss: 13.1034\n",
      "Epoch 152/200, Train Loss: 8.4301, Val Loss: 13.1015\n",
      "Epoch 153/200, Train Loss: 8.4042, Val Loss: 13.2262\n",
      "Epoch 154/200, Train Loss: 8.3757, Val Loss: 13.2595\n",
      "Epoch 155/200, Train Loss: 8.3659, Val Loss: 13.2005\n",
      "Epoch 156/200, Train Loss: 8.3754, Val Loss: 13.2124\n",
      "Epoch 157/200, Train Loss: 8.3831, Val Loss: 13.1564\n",
      "Epoch 158/200, Train Loss: 8.2621, Val Loss: 13.3447\n",
      "Epoch 159/200, Train Loss: 8.3143, Val Loss: 13.1389\n",
      "Epoch 160/200, Train Loss: 8.3323, Val Loss: 12.8664\n",
      "Epoch 161/200, Train Loss: 8.2663, Val Loss: 13.2832\n",
      "Epoch 162/200, Train Loss: 8.2552, Val Loss: 13.5089\n",
      "Epoch 163/200, Train Loss: 8.2251, Val Loss: 13.3294\n",
      "Epoch 164/200, Train Loss: 8.2068, Val Loss: 13.3420\n",
      "Epoch 165/200, Train Loss: 8.3381, Val Loss: 13.5662\n",
      "Epoch 166/200, Train Loss: 8.2369, Val Loss: 13.1138\n",
      "Epoch 167/200, Train Loss: 8.2437, Val Loss: 12.7782\n",
      "Epoch 168/200, Train Loss: 8.2736, Val Loss: 12.9719\n",
      "Epoch 169/200, Train Loss: 8.3615, Val Loss: 12.7887\n",
      "Epoch 170/200, Train Loss: 8.2070, Val Loss: 13.0247\n",
      "Epoch 171/200, Train Loss: 8.0130, Val Loss: 13.4078\n",
      "Epoch 172/200, Train Loss: 8.0375, Val Loss: 13.5899\n",
      "Epoch 173/200, Train Loss: 8.1845, Val Loss: 13.1060\n",
      "Epoch 174/200, Train Loss: 8.1335, Val Loss: 12.9948\n",
      "Epoch 175/200, Train Loss: 8.1750, Val Loss: 13.3909\n",
      "Epoch 176/200, Train Loss: 8.0298, Val Loss: 13.1191\n",
      "Epoch 177/200, Train Loss: 7.9932, Val Loss: 13.2001\n",
      "Epoch 178/200, Train Loss: 8.1449, Val Loss: 13.3040\n",
      "Epoch 179/200, Train Loss: 8.0182, Val Loss: 13.4518\n",
      "Epoch 180/200, Train Loss: 8.0006, Val Loss: 13.4097\n",
      "Epoch 181/200, Train Loss: 7.8914, Val Loss: 13.4951\n",
      "Epoch 182/200, Train Loss: 8.0056, Val Loss: 13.1664\n",
      "Epoch 183/200, Train Loss: 7.9880, Val Loss: 13.3581\n",
      "Epoch 184/200, Train Loss: 7.9570, Val Loss: 13.4859\n",
      "Epoch 185/200, Train Loss: 7.9908, Val Loss: 13.0962\n",
      "Epoch 186/200, Train Loss: 8.0091, Val Loss: 13.2491\n",
      "Epoch 187/200, Train Loss: 7.8989, Val Loss: 13.4578\n",
      "Epoch 188/200, Train Loss: 7.8941, Val Loss: 13.5087\n",
      "Epoch 189/200, Train Loss: 7.8312, Val Loss: 13.2646\n",
      "Epoch 190/200, Train Loss: 7.8101, Val Loss: 13.4812\n",
      "Epoch 191/200, Train Loss: 7.8344, Val Loss: 13.5907\n",
      "Epoch 192/200, Train Loss: 7.8634, Val Loss: 13.4975\n",
      "Epoch 193/200, Train Loss: 7.8456, Val Loss: 13.3475\n",
      "Epoch 194/200, Train Loss: 7.7689, Val Loss: 13.3859\n",
      "Epoch 195/200, Train Loss: 7.8007, Val Loss: 13.5943\n",
      "Epoch 196/200, Train Loss: 7.7221, Val Loss: 13.5807\n",
      "Epoch 197/200, Train Loss: 7.9082, Val Loss: 13.5204\n",
      "Epoch 198/200, Train Loss: 7.8319, Val Loss: 13.2970\n",
      "Epoch 199/200, Train Loss: 7.6751, Val Loss: 13.7891\n",
      "Epoch 200/200, Train Loss: 7.7354, Val Loss: 13.6399\n",
      "\n",
      "Loaded best model (Val Loss: 11.9071) for final hidden state extraction.\n",
      "Saved best model for NMRNN_Spatial_FixedReadout (samples=1280) to results_data_size_sweep/20250514_045146/samples_1280/NMRNN_Spatial_FixedReadout_samples_1280_best.pt\n",
      "\n",
      "--- Performing Decodability Analysis for NMRNN_Spatial_FixedReadout (samples=1280, k=15) ---\n",
      "  Analyzing decodability for NMRNN_Spatial_FixedReadout...\n",
      "  Hidden states shape: torch.Size([160, 200, 128])\n",
      "  Coefficients shape: torch.Size([160, 15])\n",
      "  Processed hidden states shape for decoder: torch.Size([160, 128])\n",
      "  RidgeCV Decoder for NMRNN_Spatial_FixedReadout - Test MSE: 1.3723, Test R2: 0.3132 (best alpha: 100.0000)\n",
      "  Decodability plot saved to results_data_size_sweep/20250514_045146/samples_1280/decodability_NMRNN_Spatial_FixedReadout_coeff1.png\n",
      "Decodability (R2 score) for NMRNN_Spatial_FixedReadout (samples=1280): 0.3132\n",
      "Learning curves saved to results_data_size_sweep/20250514_045146/samples_1280/learning_curves_validation.png\n",
      "\n",
      "Validation learning curves for samples=1280 plotted.\n",
      "Learning curves saved to results_data_size_sweep/20250514_045146/samples_1280/learning_curves_training.png\n",
      "\n",
      "Training learning curves for samples=1280 plotted.\n",
      "Decodability summary for samples=1280 saved to results_data_size_sweep/20250514_045146/samples_1280/decodability_summary.txt\n",
      "\n",
      "========================= Running for train_samples: 1600, k: 15 =========================\n",
      "Results for train_samples=1600 will be saved in: results_data_size_sweep/20250514_045146/samples_1600\n",
      "Loading dataset...\n",
      "Dataset loaded.\n",
      "Warning: Modulated readout requested but N_nm is 0. Using fixed readout.\n",
      "\n",
      "--- Training RNN_Vanillia (samples=1600, k=15) ---\n",
      "Number of parameters: 51301\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/conda/lib/python3.10/site-packages/torch/nn/init.py:405: UserWarning: Initializing zero-element tensors is a no-op\n",
      "  warnings.warn(\"Initializing zero-element tensors is a no-op\")\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/200, Train Loss: 16.8191, Val Loss: 15.7798\n",
      "  New best validation loss: 15.7798\n",
      "Epoch 2/200, Train Loss: 16.6352, Val Loss: 15.7262\n",
      "  New best validation loss: 15.7262\n",
      "Epoch 3/200, Train Loss: 16.5989, Val Loss: 15.7797\n",
      "Epoch 4/200, Train Loss: 16.5861, Val Loss: 15.7783\n",
      "Epoch 5/200, Train Loss: 16.5831, Val Loss: 15.7156\n",
      "  New best validation loss: 15.7156\n",
      "Epoch 6/200, Train Loss: 16.5596, Val Loss: 15.6859\n",
      "  New best validation loss: 15.6859\n",
      "Epoch 7/200, Train Loss: 16.5539, Val Loss: 15.7138\n",
      "Epoch 8/200, Train Loss: 16.5378, Val Loss: 15.6911\n",
      "Epoch 9/200, Train Loss: 16.5300, Val Loss: 15.6821\n",
      "  New best validation loss: 15.6821\n",
      "Epoch 10/200, Train Loss: 16.5233, Val Loss: 15.6793\n",
      "  New best validation loss: 15.6793\n",
      "Epoch 11/200, Train Loss: 16.5009, Val Loss: 15.6629\n",
      "  New best validation loss: 15.6629\n",
      "Epoch 12/200, Train Loss: 16.4795, Val Loss: 15.6542\n",
      "  New best validation loss: 15.6542\n",
      "Epoch 13/200, Train Loss: 16.4730, Val Loss: 15.7008\n",
      "Epoch 14/200, Train Loss: 16.4517, Val Loss: 15.6995\n",
      "Epoch 15/200, Train Loss: 16.4415, Val Loss: 15.7100\n",
      "Epoch 16/200, Train Loss: 16.4421, Val Loss: 15.6540\n",
      "  New best validation loss: 15.6540\n",
      "Epoch 17/200, Train Loss: 16.4331, Val Loss: 15.6511\n",
      "  New best validation loss: 15.6511\n",
      "Epoch 18/200, Train Loss: 16.4300, Val Loss: 15.6611\n",
      "Epoch 19/200, Train Loss: 16.4136, Val Loss: 15.6556\n",
      "Epoch 20/200, Train Loss: 16.4135, Val Loss: 15.6742\n",
      "Epoch 21/200, Train Loss: 16.4002, Val Loss: 15.6703\n",
      "Epoch 22/200, Train Loss: 16.3933, Val Loss: 15.6099\n",
      "  New best validation loss: 15.6099\n",
      "Epoch 23/200, Train Loss: 16.4006, Val Loss: 15.6899\n",
      "Epoch 24/200, Train Loss: 16.3867, Val Loss: 15.6633\n",
      "Epoch 25/200, Train Loss: 16.3764, Val Loss: 15.6185\n",
      "Epoch 26/200, Train Loss: 16.3687, Val Loss: 15.6632\n",
      "Epoch 27/200, Train Loss: 16.3757, Val Loss: 15.6082\n",
      "  New best validation loss: 15.6082\n",
      "Epoch 28/200, Train Loss: 16.3600, Val Loss: 15.6132\n",
      "Epoch 29/200, Train Loss: 16.3484, Val Loss: 15.6861\n",
      "Epoch 30/200, Train Loss: 16.3434, Val Loss: 15.6093\n",
      "Epoch 31/200, Train Loss: 16.3421, Val Loss: 15.6469\n",
      "Epoch 32/200, Train Loss: 16.3286, Val Loss: 15.5574\n",
      "  New best validation loss: 15.5574\n",
      "Epoch 33/200, Train Loss: 16.3216, Val Loss: 15.5958\n",
      "Epoch 34/200, Train Loss: 16.3087, Val Loss: 15.5796\n",
      "Epoch 35/200, Train Loss: 16.2952, Val Loss: 15.5981\n",
      "Epoch 36/200, Train Loss: 16.2883, Val Loss: 15.5215\n",
      "  New best validation loss: 15.5215\n",
      "Epoch 37/200, Train Loss: 16.2887, Val Loss: 15.5511\n",
      "Epoch 38/200, Train Loss: 16.2672, Val Loss: 15.5200\n",
      "  New best validation loss: 15.5200\n",
      "Epoch 39/200, Train Loss: 16.2551, Val Loss: 15.4653\n",
      "  New best validation loss: 15.4653\n",
      "Epoch 40/200, Train Loss: 16.2609, Val Loss: 15.4739\n",
      "Epoch 41/200, Train Loss: 16.2253, Val Loss: 15.4192\n",
      "  New best validation loss: 15.4192\n",
      "Epoch 42/200, Train Loss: 16.2175, Val Loss: 15.4360\n",
      "Epoch 43/200, Train Loss: 16.1963, Val Loss: 15.4303\n",
      "Epoch 44/200, Train Loss: 16.1966, Val Loss: 15.3522\n",
      "  New best validation loss: 15.3522\n",
      "Epoch 45/200, Train Loss: 16.1634, Val Loss: 15.3716\n",
      "Epoch 46/200, Train Loss: 16.1530, Val Loss: 15.3570\n",
      "Epoch 47/200, Train Loss: 16.1365, Val Loss: 15.2960\n",
      "  New best validation loss: 15.2960\n",
      "Epoch 48/200, Train Loss: 16.1226, Val Loss: 15.3581\n",
      "Epoch 49/200, Train Loss: 16.1126, Val Loss: 15.2267\n",
      "  New best validation loss: 15.2267\n",
      "Epoch 50/200, Train Loss: 16.1045, Val Loss: 15.2470\n",
      "Epoch 51/200, Train Loss: 16.0566, Val Loss: 15.2228\n",
      "  New best validation loss: 15.2228\n",
      "Epoch 52/200, Train Loss: 16.0482, Val Loss: 15.1661\n",
      "  New best validation loss: 15.1661\n",
      "Epoch 53/200, Train Loss: 16.0058, Val Loss: 15.0754\n",
      "  New best validation loss: 15.0754\n",
      "Epoch 54/200, Train Loss: 15.9801, Val Loss: 15.0165\n",
      "  New best validation loss: 15.0165\n",
      "Epoch 55/200, Train Loss: 15.9418, Val Loss: 14.9756\n",
      "  New best validation loss: 14.9756\n",
      "Epoch 56/200, Train Loss: 15.8910, Val Loss: 14.9965\n",
      "Epoch 57/200, Train Loss: 15.8351, Val Loss: 14.8090\n",
      "  New best validation loss: 14.8090\n",
      "Epoch 58/200, Train Loss: 15.7646, Val Loss: 14.7120\n",
      "  New best validation loss: 14.7120\n",
      "Epoch 59/200, Train Loss: 15.7027, Val Loss: 14.7034\n",
      "  New best validation loss: 14.7034\n",
      "Epoch 60/200, Train Loss: 15.6160, Val Loss: 14.6243\n",
      "  New best validation loss: 14.6243\n",
      "Epoch 61/200, Train Loss: 15.4931, Val Loss: 14.4434\n",
      "  New best validation loss: 14.4434\n",
      "Epoch 62/200, Train Loss: 15.3619, Val Loss: 14.3516\n",
      "  New best validation loss: 14.3516\n",
      "Epoch 63/200, Train Loss: 15.2598, Val Loss: 14.2559\n",
      "  New best validation loss: 14.2559\n",
      "Epoch 64/200, Train Loss: 15.1229, Val Loss: 14.1206\n",
      "  New best validation loss: 14.1206\n",
      "Epoch 65/200, Train Loss: 15.0673, Val Loss: 14.0200\n",
      "  New best validation loss: 14.0200\n",
      "Epoch 66/200, Train Loss: 14.9209, Val Loss: 13.9163\n",
      "  New best validation loss: 13.9163\n",
      "Epoch 67/200, Train Loss: 14.8177, Val Loss: 14.0244\n",
      "Epoch 68/200, Train Loss: 14.7720, Val Loss: 13.7882\n",
      "  New best validation loss: 13.7882\n",
      "Epoch 69/200, Train Loss: 14.6524, Val Loss: 13.6789\n",
      "  New best validation loss: 13.6789\n",
      "Epoch 70/200, Train Loss: 14.6128, Val Loss: 13.6056\n",
      "  New best validation loss: 13.6056\n",
      "Epoch 71/200, Train Loss: 14.5123, Val Loss: 13.6227\n",
      "Epoch 72/200, Train Loss: 14.4341, Val Loss: 13.7061\n",
      "Epoch 73/200, Train Loss: 14.4038, Val Loss: 13.4935\n",
      "  New best validation loss: 13.4935\n",
      "Epoch 74/200, Train Loss: 14.3350, Val Loss: 13.4596\n",
      "  New best validation loss: 13.4596\n",
      "Epoch 75/200, Train Loss: 14.2823, Val Loss: 13.4697\n",
      "Epoch 76/200, Train Loss: 14.2406, Val Loss: 13.4404\n",
      "  New best validation loss: 13.4404\n",
      "Epoch 77/200, Train Loss: 14.1993, Val Loss: 13.3367\n",
      "  New best validation loss: 13.3367\n",
      "Epoch 78/200, Train Loss: 14.1212, Val Loss: 13.5463\n",
      "Epoch 79/200, Train Loss: 14.0650, Val Loss: 13.3902\n",
      "Epoch 80/200, Train Loss: 13.9979, Val Loss: 13.3869\n",
      "Epoch 81/200, Train Loss: 14.0152, Val Loss: 13.2462\n",
      "  New best validation loss: 13.2462\n",
      "Epoch 82/200, Train Loss: 13.9375, Val Loss: 13.4182\n",
      "Epoch 83/200, Train Loss: 13.9429, Val Loss: 13.3974\n",
      "Epoch 84/200, Train Loss: 13.8481, Val Loss: 13.2982\n",
      "Epoch 85/200, Train Loss: 13.8116, Val Loss: 13.2128\n",
      "  New best validation loss: 13.2128\n",
      "Epoch 86/200, Train Loss: 13.7517, Val Loss: 13.2630\n",
      "Epoch 87/200, Train Loss: 13.7440, Val Loss: 13.1130\n",
      "  New best validation loss: 13.1130\n",
      "Epoch 88/200, Train Loss: 13.6621, Val Loss: 13.1061\n",
      "  New best validation loss: 13.1061\n",
      "Epoch 89/200, Train Loss: 13.6645, Val Loss: 13.1734\n",
      "Epoch 90/200, Train Loss: 13.5935, Val Loss: 13.1809\n",
      "Epoch 91/200, Train Loss: 13.5710, Val Loss: 13.0661\n",
      "  New best validation loss: 13.0661\n",
      "Epoch 92/200, Train Loss: 13.5078, Val Loss: 12.9442\n",
      "  New best validation loss: 12.9442\n",
      "Epoch 93/200, Train Loss: 13.4821, Val Loss: 12.9002\n",
      "  New best validation loss: 12.9002\n",
      "Epoch 94/200, Train Loss: 13.4304, Val Loss: 12.8632\n",
      "  New best validation loss: 12.8632\n",
      "Epoch 95/200, Train Loss: 13.3678, Val Loss: 12.8283\n",
      "  New best validation loss: 12.8283\n",
      "Epoch 96/200, Train Loss: 13.3654, Val Loss: 12.8536\n",
      "Epoch 97/200, Train Loss: 13.3112, Val Loss: 12.8045\n",
      "  New best validation loss: 12.8045\n",
      "Epoch 98/200, Train Loss: 13.3243, Val Loss: 12.9265\n",
      "Epoch 99/200, Train Loss: 13.2703, Val Loss: 12.9939\n",
      "Epoch 100/200, Train Loss: 13.2274, Val Loss: 12.8242\n",
      "Epoch 101/200, Train Loss: 13.2175, Val Loss: 12.5632\n",
      "  New best validation loss: 12.5632\n",
      "Epoch 102/200, Train Loss: 13.1571, Val Loss: 12.5929\n",
      "Epoch 103/200, Train Loss: 13.1678, Val Loss: 12.6956\n",
      "Epoch 104/200, Train Loss: 13.1062, Val Loss: 12.5185\n",
      "  New best validation loss: 12.5185\n",
      "Epoch 105/200, Train Loss: 13.0781, Val Loss: 12.4742\n",
      "  New best validation loss: 12.4742\n",
      "Epoch 106/200, Train Loss: 13.0446, Val Loss: 12.6024\n",
      "Epoch 107/200, Train Loss: 13.0114, Val Loss: 12.5305\n",
      "Epoch 108/200, Train Loss: 12.9793, Val Loss: 12.4896\n",
      "Epoch 109/200, Train Loss: 12.9319, Val Loss: 12.4512\n",
      "  New best validation loss: 12.4512\n",
      "Epoch 110/200, Train Loss: 12.9471, Val Loss: 12.3471\n",
      "  New best validation loss: 12.3471\n",
      "Epoch 111/200, Train Loss: 12.9001, Val Loss: 12.3766\n",
      "Epoch 112/200, Train Loss: 12.9059, Val Loss: 12.4193\n",
      "Epoch 113/200, Train Loss: 12.8466, Val Loss: 12.3275\n",
      "  New best validation loss: 12.3275\n",
      "Epoch 114/200, Train Loss: 12.8080, Val Loss: 12.3488\n",
      "Epoch 115/200, Train Loss: 12.8850, Val Loss: 12.4666\n",
      "Epoch 116/200, Train Loss: 12.7633, Val Loss: 12.4549\n",
      "Epoch 117/200, Train Loss: 12.7567, Val Loss: 12.2429\n",
      "  New best validation loss: 12.2429\n",
      "Epoch 118/200, Train Loss: 12.7585, Val Loss: 12.3261\n",
      "Epoch 119/200, Train Loss: 12.6960, Val Loss: 12.2711\n",
      "Epoch 120/200, Train Loss: 12.6623, Val Loss: 12.2668\n",
      "Epoch 121/200, Train Loss: 12.6379, Val Loss: 12.2516\n",
      "Epoch 122/200, Train Loss: 12.6170, Val Loss: 12.1936\n",
      "  New best validation loss: 12.1936\n",
      "Epoch 123/200, Train Loss: 12.6109, Val Loss: 12.2169\n",
      "Epoch 124/200, Train Loss: 12.5973, Val Loss: 12.4515\n",
      "Epoch 125/200, Train Loss: 12.5216, Val Loss: 12.2127\n",
      "Epoch 126/200, Train Loss: 12.5145, Val Loss: 12.0763\n",
      "  New best validation loss: 12.0763\n",
      "Epoch 127/200, Train Loss: 12.4601, Val Loss: 12.1638\n",
      "Epoch 128/200, Train Loss: 12.4299, Val Loss: 12.2049\n",
      "Epoch 129/200, Train Loss: 12.4331, Val Loss: 12.1570\n",
      "Epoch 130/200, Train Loss: 12.4213, Val Loss: 11.8945\n",
      "  New best validation loss: 11.8945\n",
      "Epoch 131/200, Train Loss: 12.3643, Val Loss: 11.9026\n",
      "Epoch 132/200, Train Loss: 12.3923, Val Loss: 11.8187\n",
      "  New best validation loss: 11.8187\n",
      "Epoch 133/200, Train Loss: 12.3497, Val Loss: 11.8727\n",
      "Epoch 134/200, Train Loss: 12.3226, Val Loss: 12.0673\n",
      "Epoch 135/200, Train Loss: 12.3186, Val Loss: 11.8017\n",
      "  New best validation loss: 11.8017\n",
      "Epoch 136/200, Train Loss: 12.2668, Val Loss: 12.0883\n",
      "Epoch 137/200, Train Loss: 12.2734, Val Loss: 11.8096\n",
      "Epoch 138/200, Train Loss: 12.2320, Val Loss: 11.8010\n",
      "  New best validation loss: 11.8010\n",
      "Epoch 139/200, Train Loss: 12.1894, Val Loss: 11.9272\n",
      "Epoch 140/200, Train Loss: 12.1945, Val Loss: 11.8984\n",
      "Epoch 141/200, Train Loss: 12.1892, Val Loss: 11.6404\n",
      "  New best validation loss: 11.6404\n",
      "Epoch 142/200, Train Loss: 12.1496, Val Loss: 11.6265\n",
      "  New best validation loss: 11.6265\n",
      "Epoch 143/200, Train Loss: 12.0977, Val Loss: 11.6544\n",
      "Epoch 144/200, Train Loss: 12.0599, Val Loss: 11.6349\n",
      "Epoch 145/200, Train Loss: 12.0829, Val Loss: 11.6269\n",
      "Epoch 146/200, Train Loss: 12.0635, Val Loss: 11.6178\n",
      "  New best validation loss: 11.6178\n",
      "Epoch 147/200, Train Loss: 12.0102, Val Loss: 11.6203\n",
      "Epoch 148/200, Train Loss: 12.0550, Val Loss: 11.6438\n",
      "Epoch 149/200, Train Loss: 11.9794, Val Loss: 11.6227\n",
      "Epoch 150/200, Train Loss: 11.9918, Val Loss: 11.5282\n",
      "  New best validation loss: 11.5282\n",
      "Epoch 151/200, Train Loss: 11.9173, Val Loss: 11.5637\n",
      "Epoch 152/200, Train Loss: 11.9052, Val Loss: 11.6268\n",
      "Epoch 153/200, Train Loss: 11.8665, Val Loss: 11.5569\n",
      "Epoch 154/200, Train Loss: 11.8530, Val Loss: 11.4471\n",
      "  New best validation loss: 11.4471\n",
      "Epoch 155/200, Train Loss: 11.8352, Val Loss: 11.4953\n",
      "Epoch 156/200, Train Loss: 11.8534, Val Loss: 11.6177\n",
      "Epoch 157/200, Train Loss: 11.7909, Val Loss: 11.4273\n",
      "  New best validation loss: 11.4273\n",
      "Epoch 158/200, Train Loss: 11.8288, Val Loss: 11.4315\n",
      "Epoch 159/200, Train Loss: 11.8128, Val Loss: 11.4578\n",
      "Epoch 160/200, Train Loss: 11.7317, Val Loss: 11.4295\n",
      "Epoch 161/200, Train Loss: 11.7534, Val Loss: 11.4162\n",
      "  New best validation loss: 11.4162\n",
      "Epoch 162/200, Train Loss: 11.7473, Val Loss: 11.4677\n",
      "Epoch 163/200, Train Loss: 11.6910, Val Loss: 11.4019\n",
      "  New best validation loss: 11.4019\n",
      "Epoch 164/200, Train Loss: 11.6882, Val Loss: 11.3115\n",
      "  New best validation loss: 11.3115\n",
      "Epoch 165/200, Train Loss: 11.6781, Val Loss: 11.4115\n",
      "Epoch 166/200, Train Loss: 11.6884, Val Loss: 11.3043\n",
      "  New best validation loss: 11.3043\n",
      "Epoch 167/200, Train Loss: 11.6359, Val Loss: 11.1959\n",
      "  New best validation loss: 11.1959\n",
      "Epoch 168/200, Train Loss: 11.5869, Val Loss: 11.4313\n",
      "Epoch 169/200, Train Loss: 11.6228, Val Loss: 11.3382\n",
      "Epoch 170/200, Train Loss: 11.5532, Val Loss: 11.5526\n",
      "Epoch 171/200, Train Loss: 11.5464, Val Loss: 11.6472\n",
      "Epoch 172/200, Train Loss: 11.5324, Val Loss: 11.5234\n",
      "Epoch 173/200, Train Loss: 11.5177, Val Loss: 11.2444\n",
      "Epoch 174/200, Train Loss: 11.4560, Val Loss: 11.4784\n",
      "Epoch 175/200, Train Loss: 11.4942, Val Loss: 11.1607\n",
      "  New best validation loss: 11.1607\n",
      "Epoch 176/200, Train Loss: 11.4371, Val Loss: 11.0282\n",
      "  New best validation loss: 11.0282\n",
      "Epoch 177/200, Train Loss: 11.4004, Val Loss: 11.1291\n",
      "Epoch 178/200, Train Loss: 11.4348, Val Loss: 11.3877\n",
      "Epoch 179/200, Train Loss: 11.4172, Val Loss: 11.2866\n",
      "Epoch 180/200, Train Loss: 11.3537, Val Loss: 11.2127\n",
      "Epoch 181/200, Train Loss: 11.3310, Val Loss: 11.0501\n",
      "Epoch 182/200, Train Loss: 11.3466, Val Loss: 11.3076\n",
      "Epoch 183/200, Train Loss: 11.3301, Val Loss: 11.2512\n",
      "Epoch 184/200, Train Loss: 11.2714, Val Loss: 11.1826\n",
      "Epoch 185/200, Train Loss: 11.2778, Val Loss: 11.0301\n",
      "Epoch 186/200, Train Loss: 11.2711, Val Loss: 11.4034\n",
      "Epoch 187/200, Train Loss: 11.2663, Val Loss: 11.1442\n",
      "Epoch 188/200, Train Loss: 11.2596, Val Loss: 11.1626\n",
      "Epoch 189/200, Train Loss: 11.1864, Val Loss: 11.1319\n",
      "Epoch 190/200, Train Loss: 11.2012, Val Loss: 10.9753\n",
      "  New best validation loss: 10.9753\n",
      "Epoch 191/200, Train Loss: 11.2112, Val Loss: 11.3311\n",
      "Epoch 192/200, Train Loss: 11.1889, Val Loss: 11.0728\n",
      "Epoch 193/200, Train Loss: 11.1400, Val Loss: 11.1580\n",
      "Epoch 194/200, Train Loss: 11.1469, Val Loss: 10.9107\n",
      "  New best validation loss: 10.9107\n",
      "Epoch 195/200, Train Loss: 11.1030, Val Loss: 10.9157\n",
      "Epoch 196/200, Train Loss: 11.1380, Val Loss: 10.8723\n",
      "  New best validation loss: 10.8723\n",
      "Epoch 197/200, Train Loss: 11.1063, Val Loss: 10.8989\n",
      "Epoch 198/200, Train Loss: 11.0624, Val Loss: 11.0128\n",
      "Epoch 199/200, Train Loss: 11.0293, Val Loss: 11.0142\n",
      "Epoch 200/200, Train Loss: 11.0464, Val Loss: 11.1018\n",
      "\n",
      "Loaded best model (Val Loss: 10.8723) for final hidden state extraction.\n",
      "Saved best model for RNN_Vanillia (samples=1600) to results_data_size_sweep/20250514_045146/samples_1600/RNN_Vanillia_samples_1600_best.pt\n",
      "\n",
      "--- Performing Decodability Analysis for RNN_Vanillia (samples=1600, k=15) ---\n",
      "  Analyzing decodability for RNN_Vanillia...\n",
      "  Hidden states shape: torch.Size([160, 200, 225])\n",
      "  Coefficients shape: torch.Size([160, 15])\n",
      "  Processed hidden states shape for decoder: torch.Size([160, 225])\n",
      "  RidgeCV Decoder for RNN_Vanillia - Test MSE: 1.0369, Test R2: 0.4755 (best alpha: 23.3572)\n",
      "  Decodability plot saved to results_data_size_sweep/20250514_045146/samples_1600/decodability_RNN_Vanillia_coeff1.png\n",
      "Decodability (R2 score) for RNN_Vanillia (samples=1600): 0.4755\n",
      "\n",
      "--- Training ComplexOscillatorNet (samples=1600, k=15) ---\n",
      "Number of parameters: 17152\n",
      "Epoch 1/200, Train Loss: 16.1605, Val Loss: 14.4963\n",
      "  New best validation loss: 14.4963\n",
      "Epoch 2/200, Train Loss: 15.4210, Val Loss: 14.3542\n",
      "  New best validation loss: 14.3542\n",
      "Epoch 3/200, Train Loss: 15.1446, Val Loss: 14.0516\n",
      "  New best validation loss: 14.0516\n",
      "Epoch 4/200, Train Loss: 14.9306, Val Loss: 13.8989\n",
      "  New best validation loss: 13.8989\n",
      "Epoch 5/200, Train Loss: 14.7872, Val Loss: 13.8566\n",
      "  New best validation loss: 13.8566\n",
      "Epoch 6/200, Train Loss: 14.6936, Val Loss: 13.7821\n",
      "  New best validation loss: 13.7821\n",
      "Epoch 7/200, Train Loss: 14.5709, Val Loss: 13.6636\n",
      "  New best validation loss: 13.6636\n",
      "Epoch 8/200, Train Loss: 14.5165, Val Loss: 13.7413\n",
      "Epoch 9/200, Train Loss: 14.4404, Val Loss: 13.6739\n",
      "Epoch 10/200, Train Loss: 14.3868, Val Loss: 13.5680\n",
      "  New best validation loss: 13.5680\n",
      "Epoch 11/200, Train Loss: 14.3192, Val Loss: 13.5822\n",
      "Epoch 12/200, Train Loss: 14.2313, Val Loss: 13.5291\n",
      "  New best validation loss: 13.5291\n",
      "Epoch 13/200, Train Loss: 14.1839, Val Loss: 13.5447\n",
      "Epoch 14/200, Train Loss: 14.1744, Val Loss: 13.6591\n",
      "Epoch 15/200, Train Loss: 14.1040, Val Loss: 13.5323\n",
      "Epoch 16/200, Train Loss: 14.0418, Val Loss: 13.4597\n",
      "  New best validation loss: 13.4597\n",
      "Epoch 17/200, Train Loss: 13.9993, Val Loss: 13.5681\n",
      "Epoch 18/200, Train Loss: 13.9694, Val Loss: 13.5746\n",
      "Epoch 19/200, Train Loss: 13.9235, Val Loss: 13.5809\n",
      "Epoch 20/200, Train Loss: 13.9124, Val Loss: 13.5245\n",
      "Epoch 21/200, Train Loss: 13.8666, Val Loss: 13.5236\n",
      "Epoch 22/200, Train Loss: 13.8394, Val Loss: 13.5814\n",
      "Epoch 23/200, Train Loss: 13.7777, Val Loss: 13.5072\n",
      "Epoch 24/200, Train Loss: 13.7766, Val Loss: 13.5917\n",
      "Epoch 25/200, Train Loss: 13.7312, Val Loss: 13.5355\n",
      "Epoch 26/200, Train Loss: 13.6974, Val Loss: 13.6511\n",
      "Epoch 27/200, Train Loss: 13.6603, Val Loss: 13.5468\n",
      "Epoch 28/200, Train Loss: 13.6452, Val Loss: 13.5082\n",
      "Epoch 29/200, Train Loss: 13.5920, Val Loss: 13.5064\n",
      "Epoch 30/200, Train Loss: 13.5610, Val Loss: 13.5815\n",
      "Epoch 31/200, Train Loss: 13.5569, Val Loss: 13.5599\n",
      "Epoch 32/200, Train Loss: 13.5204, Val Loss: 13.5162\n",
      "Epoch 33/200, Train Loss: 13.4859, Val Loss: 13.5761\n",
      "Epoch 34/200, Train Loss: 13.4634, Val Loss: 13.6993\n",
      "Epoch 35/200, Train Loss: 13.4812, Val Loss: 13.6327\n",
      "Epoch 36/200, Train Loss: 13.4171, Val Loss: 13.5632\n",
      "Epoch 37/200, Train Loss: 13.3857, Val Loss: 13.6093\n",
      "Epoch 38/200, Train Loss: 13.3400, Val Loss: 13.6195\n",
      "Epoch 39/200, Train Loss: 13.3384, Val Loss: 13.6964\n",
      "Epoch 40/200, Train Loss: 13.3091, Val Loss: 13.5909\n",
      "Epoch 41/200, Train Loss: 13.2748, Val Loss: 13.6609\n",
      "Epoch 42/200, Train Loss: 13.2698, Val Loss: 13.7255\n",
      "Epoch 43/200, Train Loss: 13.2395, Val Loss: 13.6259\n",
      "Epoch 44/200, Train Loss: 13.2118, Val Loss: 13.8117\n",
      "Epoch 45/200, Train Loss: 13.1857, Val Loss: 13.8564\n",
      "Epoch 46/200, Train Loss: 13.1755, Val Loss: 13.7628\n",
      "Epoch 47/200, Train Loss: 13.2328, Val Loss: 13.7775\n",
      "Epoch 48/200, Train Loss: 13.1216, Val Loss: 13.7197\n",
      "Epoch 49/200, Train Loss: 13.1202, Val Loss: 13.8154\n",
      "Epoch 50/200, Train Loss: 13.0885, Val Loss: 13.7930\n",
      "Epoch 51/200, Train Loss: 13.0601, Val Loss: 13.8123\n",
      "Epoch 52/200, Train Loss: 13.0620, Val Loss: 13.8807\n",
      "Epoch 53/200, Train Loss: 13.0118, Val Loss: 13.7973\n",
      "Epoch 54/200, Train Loss: 13.0128, Val Loss: 13.9399\n",
      "Epoch 55/200, Train Loss: 13.0284, Val Loss: 13.8827\n",
      "Epoch 56/200, Train Loss: 13.0317, Val Loss: 13.8564\n",
      "Epoch 57/200, Train Loss: 13.0249, Val Loss: 13.8373\n",
      "Epoch 58/200, Train Loss: 12.9781, Val Loss: 13.8282\n",
      "Epoch 59/200, Train Loss: 12.9275, Val Loss: 13.9210\n",
      "Epoch 60/200, Train Loss: 12.8966, Val Loss: 13.9778\n",
      "Epoch 61/200, Train Loss: 12.9574, Val Loss: 13.9073\n",
      "Epoch 62/200, Train Loss: 12.8971, Val Loss: 13.9109\n",
      "Epoch 63/200, Train Loss: 12.8617, Val Loss: 13.8984\n",
      "Epoch 64/200, Train Loss: 12.8268, Val Loss: 13.8608\n",
      "Epoch 65/200, Train Loss: 12.8061, Val Loss: 13.9579\n",
      "Epoch 66/200, Train Loss: 12.7918, Val Loss: 13.9485\n",
      "Epoch 67/200, Train Loss: 12.7983, Val Loss: 13.9981\n",
      "Epoch 68/200, Train Loss: 12.7753, Val Loss: 13.9508\n",
      "Epoch 69/200, Train Loss: 12.7508, Val Loss: 13.9926\n",
      "Epoch 70/200, Train Loss: 12.7328, Val Loss: 14.0568\n",
      "Epoch 71/200, Train Loss: 12.7332, Val Loss: 13.9739\n",
      "Epoch 72/200, Train Loss: 12.7206, Val Loss: 14.0337\n",
      "Epoch 73/200, Train Loss: 12.7130, Val Loss: 13.9675\n",
      "Epoch 74/200, Train Loss: 12.7058, Val Loss: 13.9883\n",
      "Epoch 75/200, Train Loss: 12.6956, Val Loss: 14.0496\n",
      "Epoch 76/200, Train Loss: 12.6737, Val Loss: 14.0018\n",
      "Epoch 77/200, Train Loss: 12.6328, Val Loss: 14.0637\n",
      "Epoch 78/200, Train Loss: 12.6425, Val Loss: 14.0859\n",
      "Epoch 79/200, Train Loss: 12.6169, Val Loss: 14.0680\n",
      "Epoch 80/200, Train Loss: 12.6470, Val Loss: 14.0378\n",
      "Epoch 81/200, Train Loss: 12.6063, Val Loss: 14.1796\n",
      "Epoch 82/200, Train Loss: 12.6076, Val Loss: 14.2422\n",
      "Epoch 83/200, Train Loss: 12.5592, Val Loss: 14.0496\n",
      "Epoch 84/200, Train Loss: 12.5552, Val Loss: 14.1669\n",
      "Epoch 85/200, Train Loss: 12.5536, Val Loss: 14.1612\n",
      "Epoch 86/200, Train Loss: 12.5621, Val Loss: 14.2215\n",
      "Epoch 87/200, Train Loss: 12.5403, Val Loss: 14.2716\n",
      "Epoch 88/200, Train Loss: 12.5319, Val Loss: 14.2240\n",
      "Epoch 89/200, Train Loss: 12.5768, Val Loss: 14.2778\n",
      "Epoch 90/200, Train Loss: 12.5688, Val Loss: 14.2592\n",
      "Epoch 91/200, Train Loss: 12.5106, Val Loss: 14.3346\n",
      "Epoch 92/200, Train Loss: 12.4875, Val Loss: 14.2366\n",
      "Epoch 93/200, Train Loss: 12.4761, Val Loss: 14.3140\n",
      "Epoch 94/200, Train Loss: 12.4622, Val Loss: 14.2299\n",
      "Epoch 95/200, Train Loss: 12.4624, Val Loss: 14.2560\n",
      "Epoch 96/200, Train Loss: 12.4398, Val Loss: 14.3028\n",
      "Epoch 97/200, Train Loss: 12.4061, Val Loss: 14.3803\n",
      "Epoch 98/200, Train Loss: 12.4206, Val Loss: 14.3526\n",
      "Epoch 99/200, Train Loss: 12.4481, Val Loss: 14.2021\n",
      "Epoch 100/200, Train Loss: 12.4749, Val Loss: 15.0408\n",
      "Epoch 101/200, Train Loss: 13.8965, Val Loss: 14.0497\n",
      "Epoch 102/200, Train Loss: 12.9749, Val Loss: 14.1405\n",
      "Epoch 103/200, Train Loss: 12.6145, Val Loss: 14.2758\n",
      "Epoch 104/200, Train Loss: 12.4680, Val Loss: 14.2849\n",
      "Epoch 105/200, Train Loss: 12.4089, Val Loss: 14.4052\n",
      "Epoch 106/200, Train Loss: 12.4775, Val Loss: 14.3547\n",
      "Epoch 107/200, Train Loss: 12.5948, Val Loss: 14.2560\n",
      "Epoch 108/200, Train Loss: 12.4260, Val Loss: 14.3367\n",
      "Epoch 109/200, Train Loss: 12.3780, Val Loss: 14.3327\n",
      "Epoch 110/200, Train Loss: 12.3639, Val Loss: 14.4292\n",
      "Epoch 111/200, Train Loss: 12.3100, Val Loss: 14.4748\n",
      "Epoch 112/200, Train Loss: 12.3226, Val Loss: 14.5151\n",
      "Epoch 113/200, Train Loss: 12.2994, Val Loss: 14.4456\n",
      "Epoch 114/200, Train Loss: 12.2866, Val Loss: 14.4806\n",
      "Epoch 115/200, Train Loss: 12.2774, Val Loss: 14.5289\n",
      "Epoch 116/200, Train Loss: 12.2910, Val Loss: 14.4897\n",
      "Epoch 117/200, Train Loss: 12.2813, Val Loss: 14.5675\n",
      "Epoch 118/200, Train Loss: 12.2357, Val Loss: 14.4371\n",
      "Epoch 119/200, Train Loss: 12.3276, Val Loss: 14.5474\n",
      "Epoch 120/200, Train Loss: 12.3127, Val Loss: 14.4782\n",
      "Epoch 121/200, Train Loss: 12.3638, Val Loss: 14.5285\n",
      "Epoch 122/200, Train Loss: 12.3064, Val Loss: 14.4247\n",
      "Epoch 123/200, Train Loss: 12.3178, Val Loss: 14.5080\n",
      "Epoch 124/200, Train Loss: 12.3088, Val Loss: 14.6233\n",
      "Epoch 125/200, Train Loss: 12.2694, Val Loss: 14.6182\n",
      "Epoch 126/200, Train Loss: 12.2391, Val Loss: 14.5593\n",
      "Epoch 127/200, Train Loss: 12.2858, Val Loss: 14.5541\n",
      "Epoch 128/200, Train Loss: 12.2601, Val Loss: 14.5536\n",
      "Epoch 129/200, Train Loss: 12.2358, Val Loss: 14.5014\n",
      "Epoch 130/200, Train Loss: 12.2226, Val Loss: 14.6332\n",
      "Epoch 131/200, Train Loss: 12.1887, Val Loss: 14.5386\n",
      "Epoch 132/200, Train Loss: 12.1727, Val Loss: 14.5807\n",
      "Epoch 133/200, Train Loss: 12.2156, Val Loss: 14.5574\n",
      "Epoch 134/200, Train Loss: 12.2361, Val Loss: 14.6497\n",
      "Epoch 135/200, Train Loss: 12.1961, Val Loss: 14.7439\n",
      "Epoch 136/200, Train Loss: 12.1758, Val Loss: 14.5633\n",
      "Epoch 137/200, Train Loss: 12.1563, Val Loss: 14.6615\n",
      "Epoch 138/200, Train Loss: 12.1750, Val Loss: 14.6169\n",
      "Epoch 139/200, Train Loss: 12.2006, Val Loss: 14.6663\n",
      "Epoch 140/200, Train Loss: 12.1983, Val Loss: 14.6126\n",
      "Epoch 141/200, Train Loss: 12.1583, Val Loss: 14.6098\n",
      "Epoch 142/200, Train Loss: 12.1573, Val Loss: 14.6532\n",
      "Epoch 143/200, Train Loss: 12.1513, Val Loss: 14.6526\n",
      "Epoch 144/200, Train Loss: 12.1108, Val Loss: 14.6691\n",
      "Epoch 145/200, Train Loss: 12.1171, Val Loss: 14.6852\n",
      "Epoch 146/200, Train Loss: 12.1106, Val Loss: 14.6923\n",
      "Epoch 147/200, Train Loss: 12.2009, Val Loss: 14.7479\n",
      "Epoch 148/200, Train Loss: 12.1787, Val Loss: 14.6224\n",
      "Epoch 149/200, Train Loss: 12.1481, Val Loss: 14.5904\n",
      "Epoch 150/200, Train Loss: 12.1400, Val Loss: 14.6535\n",
      "Epoch 151/200, Train Loss: 12.1136, Val Loss: 14.6364\n",
      "Epoch 152/200, Train Loss: 12.1593, Val Loss: 14.7320\n",
      "Epoch 153/200, Train Loss: 12.2092, Val Loss: 14.5869\n",
      "Epoch 154/200, Train Loss: 12.1580, Val Loss: 14.6008\n",
      "Epoch 155/200, Train Loss: 12.0792, Val Loss: 14.7163\n",
      "Epoch 156/200, Train Loss: 12.0958, Val Loss: 14.6578\n",
      "Epoch 157/200, Train Loss: 12.0852, Val Loss: 14.7671\n",
      "Epoch 158/200, Train Loss: 12.0489, Val Loss: 14.8262\n",
      "Epoch 159/200, Train Loss: 12.0312, Val Loss: 14.6514\n",
      "Epoch 160/200, Train Loss: 12.0382, Val Loss: 14.7453\n",
      "Epoch 161/200, Train Loss: 12.0621, Val Loss: 14.6106\n",
      "Epoch 162/200, Train Loss: 12.0775, Val Loss: 14.8197\n",
      "Epoch 163/200, Train Loss: 12.0697, Val Loss: 14.8265\n",
      "Epoch 164/200, Train Loss: 12.1093, Val Loss: 14.7935\n",
      "Epoch 165/200, Train Loss: 12.0924, Val Loss: 14.7928\n",
      "Epoch 166/200, Train Loss: 12.0635, Val Loss: 14.7520\n",
      "Epoch 167/200, Train Loss: 12.0602, Val Loss: 14.6895\n",
      "Epoch 168/200, Train Loss: 12.1041, Val Loss: 14.7705\n",
      "Epoch 169/200, Train Loss: 12.1043, Val Loss: 14.6378\n",
      "Epoch 170/200, Train Loss: 12.0953, Val Loss: 14.6473\n",
      "Epoch 171/200, Train Loss: 12.0593, Val Loss: 14.6717\n",
      "Epoch 172/200, Train Loss: 12.0060, Val Loss: 14.7743\n",
      "Epoch 173/200, Train Loss: 12.0468, Val Loss: 14.7935\n",
      "Epoch 174/200, Train Loss: 12.0651, Val Loss: 14.7387\n",
      "Epoch 175/200, Train Loss: 12.0126, Val Loss: 14.7412\n",
      "Epoch 176/200, Train Loss: 12.0884, Val Loss: 14.7384\n",
      "Epoch 177/200, Train Loss: 11.9931, Val Loss: 14.5816\n",
      "Epoch 178/200, Train Loss: 11.9590, Val Loss: 14.7151\n",
      "Epoch 179/200, Train Loss: 11.9685, Val Loss: 14.7892\n",
      "Epoch 180/200, Train Loss: 12.0043, Val Loss: 14.7575\n",
      "Epoch 181/200, Train Loss: 12.0129, Val Loss: 14.6566\n",
      "Epoch 182/200, Train Loss: 11.9933, Val Loss: 14.7427\n",
      "Epoch 183/200, Train Loss: 11.9957, Val Loss: 14.6126\n",
      "Epoch 184/200, Train Loss: 12.0061, Val Loss: 14.6806\n",
      "Epoch 185/200, Train Loss: 12.0209, Val Loss: 14.9321\n",
      "Epoch 186/200, Train Loss: 12.0045, Val Loss: 14.7861\n",
      "Epoch 187/200, Train Loss: 11.9975, Val Loss: 14.8389\n",
      "Epoch 188/200, Train Loss: 11.9528, Val Loss: 14.8969\n",
      "Epoch 189/200, Train Loss: 12.0001, Val Loss: 14.8479\n",
      "Epoch 190/200, Train Loss: 12.0165, Val Loss: 14.7895\n",
      "Epoch 191/200, Train Loss: 12.0234, Val Loss: 14.7820\n",
      "Epoch 192/200, Train Loss: 11.9666, Val Loss: 14.7288\n",
      "Epoch 193/200, Train Loss: 11.9649, Val Loss: 14.8242\n",
      "Epoch 194/200, Train Loss: 11.9697, Val Loss: 14.8633\n",
      "Epoch 195/200, Train Loss: 11.9857, Val Loss: 14.7860\n",
      "Epoch 196/200, Train Loss: 11.9472, Val Loss: 14.6828\n",
      "Epoch 197/200, Train Loss: 11.9441, Val Loss: 14.9065\n",
      "Epoch 198/200, Train Loss: 11.9601, Val Loss: 14.8197\n",
      "Epoch 199/200, Train Loss: 11.9369, Val Loss: 14.8555\n",
      "Epoch 200/200, Train Loss: 11.9442, Val Loss: 14.8020\n",
      "\n",
      "Loaded best model (Val Loss: 13.4597) for final hidden state extraction.\n",
      "Saved best model for ComplexOscillatorNet (samples=1600) to results_data_size_sweep/20250514_045146/samples_1600/ComplexOscillatorNet_samples_1600_best.pt\n",
      "\n",
      "--- Performing Decodability Analysis for ComplexOscillatorNet (samples=1600, k=15) ---\n",
      "  Analyzing decodability for ComplexOscillatorNet...\n",
      "  Hidden states shape: torch.Size([160, 200, 128])\n",
      "  Coefficients shape: torch.Size([160, 15])\n",
      "  Processed hidden states shape for decoder: torch.Size([160, 256])\n",
      "  RidgeCV Decoder for ComplexOscillatorNet - Test MSE: 1.2143, Test R2: 0.3890 (best alpha: 100.0000)\n",
      "  Decodability plot saved to results_data_size_sweep/20250514_045146/samples_1600/decodability_ComplexOscillatorNet_coeff1.png\n",
      "Decodability (R2 score) for ComplexOscillatorNet (samples=1600): 0.3890\n",
      "\n",
      "--- Training RNN_GRU (samples=1600, k=15) ---\n",
      "Number of parameters: 12993\n",
      "Epoch 1/200, Train Loss: 16.7686, Val Loss: 15.7522\n",
      "  New best validation loss: 15.7522\n",
      "Epoch 2/200, Train Loss: 16.7066, Val Loss: 15.6989\n",
      "  New best validation loss: 15.6989\n",
      "Epoch 3/200, Train Loss: 16.6659, Val Loss: 15.6879\n",
      "  New best validation loss: 15.6879\n",
      "Epoch 4/200, Train Loss: 16.6547, Val Loss: 15.6871\n",
      "  New best validation loss: 15.6871\n",
      "Epoch 5/200, Train Loss: 16.6421, Val Loss: 15.7219\n",
      "Epoch 6/200, Train Loss: 16.6396, Val Loss: 15.6827\n",
      "  New best validation loss: 15.6827\n",
      "Epoch 7/200, Train Loss: 16.6313, Val Loss: 15.6821\n",
      "  New best validation loss: 15.6821\n",
      "Epoch 8/200, Train Loss: 16.6230, Val Loss: 15.6623\n",
      "  New best validation loss: 15.6623\n",
      "Epoch 9/200, Train Loss: 16.6156, Val Loss: 15.6702\n",
      "Epoch 10/200, Train Loss: 16.6046, Val Loss: 15.6447\n",
      "  New best validation loss: 15.6447\n",
      "Epoch 11/200, Train Loss: 16.5934, Val Loss: 15.6425\n",
      "  New best validation loss: 15.6425\n",
      "Epoch 12/200, Train Loss: 16.5825, Val Loss: 15.6173\n",
      "  New best validation loss: 15.6173\n",
      "Epoch 13/200, Train Loss: 16.5662, Val Loss: 15.6208\n",
      "Epoch 14/200, Train Loss: 16.5432, Val Loss: 15.5807\n",
      "  New best validation loss: 15.5807\n",
      "Epoch 15/200, Train Loss: 16.5252, Val Loss: 15.5511\n",
      "  New best validation loss: 15.5511\n",
      "Epoch 16/200, Train Loss: 16.5161, Val Loss: 15.5482\n",
      "  New best validation loss: 15.5482\n",
      "Epoch 17/200, Train Loss: 16.4918, Val Loss: 15.5187\n",
      "  New best validation loss: 15.5187\n",
      "Epoch 18/200, Train Loss: 16.4763, Val Loss: 15.5530\n",
      "Epoch 19/200, Train Loss: 16.4730, Val Loss: 15.5056\n",
      "  New best validation loss: 15.5056\n",
      "Epoch 20/200, Train Loss: 16.4583, Val Loss: 15.4840\n",
      "  New best validation loss: 15.4840\n",
      "Epoch 21/200, Train Loss: 16.4291, Val Loss: 15.4950\n",
      "Epoch 22/200, Train Loss: 16.4056, Val Loss: 15.5352\n",
      "Epoch 23/200, Train Loss: 16.4014, Val Loss: 15.5135\n",
      "Epoch 24/200, Train Loss: 16.3700, Val Loss: 15.5192\n",
      "Epoch 25/200, Train Loss: 16.3540, Val Loss: 15.5117\n",
      "Epoch 26/200, Train Loss: 16.3668, Val Loss: 15.4108\n",
      "  New best validation loss: 15.4108\n",
      "Epoch 27/200, Train Loss: 16.2739, Val Loss: 15.3942\n",
      "  New best validation loss: 15.3942\n",
      "Epoch 28/200, Train Loss: 16.2449, Val Loss: 15.3653\n",
      "  New best validation loss: 15.3653\n",
      "Epoch 29/200, Train Loss: 16.1974, Val Loss: 15.3743\n",
      "Epoch 30/200, Train Loss: 16.1924, Val Loss: 15.3776\n",
      "Epoch 31/200, Train Loss: 16.1778, Val Loss: 15.3191\n",
      "  New best validation loss: 15.3191\n",
      "Epoch 32/200, Train Loss: 16.1422, Val Loss: 15.3258\n",
      "Epoch 33/200, Train Loss: 16.1631, Val Loss: 15.3370\n",
      "Epoch 34/200, Train Loss: 16.1294, Val Loss: 15.2974\n",
      "  New best validation loss: 15.2974\n",
      "Epoch 35/200, Train Loss: 16.1265, Val Loss: 15.3093\n",
      "Epoch 36/200, Train Loss: 16.1174, Val Loss: 15.3328\n",
      "Epoch 37/200, Train Loss: 16.1138, Val Loss: 15.2716\n",
      "  New best validation loss: 15.2716\n",
      "Epoch 38/200, Train Loss: 16.0913, Val Loss: 15.2780\n",
      "Epoch 39/200, Train Loss: 16.0979, Val Loss: 15.2563\n",
      "  New best validation loss: 15.2563\n",
      "Epoch 40/200, Train Loss: 16.0963, Val Loss: 15.2636\n",
      "Epoch 41/200, Train Loss: 16.0581, Val Loss: 15.2479\n",
      "  New best validation loss: 15.2479\n",
      "Epoch 42/200, Train Loss: 16.0540, Val Loss: 15.2044\n",
      "  New best validation loss: 15.2044\n",
      "Epoch 43/200, Train Loss: 16.0216, Val Loss: 15.2396\n",
      "Epoch 44/200, Train Loss: 16.0250, Val Loss: 15.2007\n",
      "  New best validation loss: 15.2007\n",
      "Epoch 45/200, Train Loss: 16.0051, Val Loss: 15.2281\n",
      "Epoch 46/200, Train Loss: 15.9774, Val Loss: 15.1796\n",
      "  New best validation loss: 15.1796\n",
      "Epoch 47/200, Train Loss: 15.9525, Val Loss: 15.1668\n",
      "  New best validation loss: 15.1668\n",
      "Epoch 48/200, Train Loss: 15.9130, Val Loss: 15.1674\n",
      "Epoch 49/200, Train Loss: 15.8702, Val Loss: 15.0758\n",
      "  New best validation loss: 15.0758\n",
      "Epoch 50/200, Train Loss: 15.8419, Val Loss: 15.0844\n",
      "Epoch 51/200, Train Loss: 15.7570, Val Loss: 15.0606\n",
      "  New best validation loss: 15.0606\n",
      "Epoch 52/200, Train Loss: 15.6671, Val Loss: 14.9658\n",
      "  New best validation loss: 14.9658\n",
      "Epoch 53/200, Train Loss: 15.5581, Val Loss: 14.8384\n",
      "  New best validation loss: 14.8384\n",
      "Epoch 54/200, Train Loss: 15.4642, Val Loss: 14.7571\n",
      "  New best validation loss: 14.7571\n",
      "Epoch 55/200, Train Loss: 15.3761, Val Loss: 14.8568\n",
      "Epoch 56/200, Train Loss: 15.2179, Val Loss: 14.4356\n",
      "  New best validation loss: 14.4356\n",
      "Epoch 57/200, Train Loss: 15.1003, Val Loss: 14.1665\n",
      "  New best validation loss: 14.1665\n",
      "Epoch 58/200, Train Loss: 14.9522, Val Loss: 14.0753\n",
      "  New best validation loss: 14.0753\n",
      "Epoch 59/200, Train Loss: 15.1411, Val Loss: 14.0998\n",
      "Epoch 60/200, Train Loss: 14.7991, Val Loss: 13.8845\n",
      "  New best validation loss: 13.8845\n",
      "Epoch 61/200, Train Loss: 14.7605, Val Loss: 13.8942\n",
      "Epoch 62/200, Train Loss: 14.6899, Val Loss: 14.0755\n",
      "Epoch 63/200, Train Loss: 14.7113, Val Loss: 13.7408\n",
      "  New best validation loss: 13.7408\n",
      "Epoch 64/200, Train Loss: 14.6507, Val Loss: 13.8376\n",
      "Epoch 65/200, Train Loss: 14.7139, Val Loss: 13.8549\n",
      "Epoch 66/200, Train Loss: 14.5560, Val Loss: 13.7767\n",
      "Epoch 67/200, Train Loss: 14.5794, Val Loss: 13.7740\n",
      "Epoch 68/200, Train Loss: 14.4465, Val Loss: 13.6557\n",
      "  New best validation loss: 13.6557\n",
      "Epoch 69/200, Train Loss: 14.5217, Val Loss: 14.0039\n",
      "Epoch 70/200, Train Loss: 14.4348, Val Loss: 13.7758\n",
      "Epoch 71/200, Train Loss: 14.4180, Val Loss: 13.8970\n",
      "Epoch 72/200, Train Loss: 14.3874, Val Loss: 13.6043\n",
      "  New best validation loss: 13.6043\n",
      "Epoch 73/200, Train Loss: 14.2668, Val Loss: 13.7475\n",
      "Epoch 74/200, Train Loss: 14.4004, Val Loss: 13.6982\n",
      "Epoch 75/200, Train Loss: 14.2943, Val Loss: 13.6187\n",
      "Epoch 76/200, Train Loss: 14.2675, Val Loss: 13.8053\n",
      "Epoch 77/200, Train Loss: 14.2909, Val Loss: 13.7877\n",
      "Epoch 78/200, Train Loss: 14.2315, Val Loss: 13.5307\n",
      "  New best validation loss: 13.5307\n",
      "Epoch 79/200, Train Loss: 14.1606, Val Loss: 13.5579\n",
      "Epoch 80/200, Train Loss: 14.2097, Val Loss: 13.5578\n",
      "Epoch 81/200, Train Loss: 14.1282, Val Loss: 13.7009\n",
      "Epoch 82/200, Train Loss: 14.1949, Val Loss: 13.4514\n",
      "  New best validation loss: 13.4514\n",
      "Epoch 83/200, Train Loss: 14.1193, Val Loss: 13.5150\n",
      "Epoch 84/200, Train Loss: 14.1623, Val Loss: 13.5250\n",
      "Epoch 85/200, Train Loss: 14.0674, Val Loss: 13.4041\n",
      "  New best validation loss: 13.4041\n",
      "Epoch 86/200, Train Loss: 14.0621, Val Loss: 13.4187\n",
      "Epoch 87/200, Train Loss: 14.1303, Val Loss: 13.4817\n",
      "Epoch 88/200, Train Loss: 14.0276, Val Loss: 13.5001\n",
      "Epoch 89/200, Train Loss: 14.0610, Val Loss: 13.4820\n",
      "Epoch 90/200, Train Loss: 14.0948, Val Loss: 13.5748\n",
      "Epoch 91/200, Train Loss: 13.9849, Val Loss: 13.4063\n",
      "Epoch 92/200, Train Loss: 14.0270, Val Loss: 13.4085\n",
      "Epoch 93/200, Train Loss: 13.9236, Val Loss: 13.5701\n",
      "Epoch 94/200, Train Loss: 14.0607, Val Loss: 13.3874\n",
      "  New best validation loss: 13.3874\n",
      "Epoch 95/200, Train Loss: 13.9579, Val Loss: 13.5260\n",
      "Epoch 96/200, Train Loss: 13.9046, Val Loss: 13.4408\n",
      "Epoch 97/200, Train Loss: 13.9783, Val Loss: 13.2297\n",
      "  New best validation loss: 13.2297\n",
      "Epoch 98/200, Train Loss: 13.9043, Val Loss: 13.2805\n",
      "Epoch 99/200, Train Loss: 13.8700, Val Loss: 13.6300\n",
      "Epoch 100/200, Train Loss: 13.8812, Val Loss: 13.4484\n",
      "Epoch 101/200, Train Loss: 13.9609, Val Loss: 13.1762\n",
      "  New best validation loss: 13.1762\n",
      "Epoch 102/200, Train Loss: 13.8359, Val Loss: 13.0939\n",
      "  New best validation loss: 13.0939\n",
      "Epoch 103/200, Train Loss: 13.8915, Val Loss: 13.0720\n",
      "  New best validation loss: 13.0720\n",
      "Epoch 104/200, Train Loss: 13.8988, Val Loss: 13.1136\n",
      "Epoch 105/200, Train Loss: 13.7954, Val Loss: 13.2962\n",
      "Epoch 106/200, Train Loss: 13.9023, Val Loss: 13.2762\n",
      "Epoch 107/200, Train Loss: 13.7744, Val Loss: 13.0222\n",
      "  New best validation loss: 13.0222\n",
      "Epoch 108/200, Train Loss: 13.7909, Val Loss: 13.1344\n",
      "Epoch 109/200, Train Loss: 13.9147, Val Loss: 13.2194\n",
      "Epoch 110/200, Train Loss: 13.7910, Val Loss: 13.0583\n",
      "Epoch 111/200, Train Loss: 13.7481, Val Loss: 13.0853\n",
      "Epoch 112/200, Train Loss: 13.7084, Val Loss: 13.0010\n",
      "  New best validation loss: 13.0010\n",
      "Epoch 113/200, Train Loss: 13.7760, Val Loss: 12.9793\n",
      "  New best validation loss: 12.9793\n",
      "Epoch 114/200, Train Loss: 13.6903, Val Loss: 12.9484\n",
      "  New best validation loss: 12.9484\n",
      "Epoch 115/200, Train Loss: 13.7150, Val Loss: 13.0479\n",
      "Epoch 116/200, Train Loss: 13.6425, Val Loss: 13.0182\n",
      "Epoch 117/200, Train Loss: 13.6626, Val Loss: 13.0191\n",
      "Epoch 118/200, Train Loss: 13.6893, Val Loss: 12.9257\n",
      "  New best validation loss: 12.9257\n",
      "Epoch 119/200, Train Loss: 13.6625, Val Loss: 12.9821\n",
      "Epoch 120/200, Train Loss: 13.6680, Val Loss: 12.9419\n",
      "Epoch 121/200, Train Loss: 13.5590, Val Loss: 13.0670\n",
      "Epoch 122/200, Train Loss: 13.6314, Val Loss: 12.8937\n",
      "  New best validation loss: 12.8937\n",
      "Epoch 123/200, Train Loss: 13.5827, Val Loss: 12.9284\n",
      "Epoch 124/200, Train Loss: 13.5344, Val Loss: 12.7876\n",
      "  New best validation loss: 12.7876\n",
      "Epoch 125/200, Train Loss: 13.5474, Val Loss: 12.8809\n",
      "Epoch 126/200, Train Loss: 13.5627, Val Loss: 12.9906\n",
      "Epoch 127/200, Train Loss: 13.5232, Val Loss: 12.8515\n",
      "Epoch 128/200, Train Loss: 13.5186, Val Loss: 12.7887\n",
      "Epoch 129/200, Train Loss: 13.5047, Val Loss: 12.8657\n",
      "Epoch 130/200, Train Loss: 13.5072, Val Loss: 13.0670\n",
      "Epoch 131/200, Train Loss: 13.6051, Val Loss: 12.7563\n",
      "  New best validation loss: 12.7563\n",
      "Epoch 132/200, Train Loss: 13.5652, Val Loss: 12.7743\n",
      "Epoch 133/200, Train Loss: 13.4630, Val Loss: 12.9325\n",
      "Epoch 134/200, Train Loss: 13.4963, Val Loss: 12.7326\n",
      "  New best validation loss: 12.7326\n",
      "Epoch 135/200, Train Loss: 13.4129, Val Loss: 12.8102\n",
      "Epoch 136/200, Train Loss: 13.4287, Val Loss: 12.8641\n",
      "Epoch 137/200, Train Loss: 13.4076, Val Loss: 13.0428\n",
      "Epoch 138/200, Train Loss: 13.4071, Val Loss: 12.9023\n",
      "Epoch 139/200, Train Loss: 13.4410, Val Loss: 12.9183\n",
      "Epoch 140/200, Train Loss: 13.3900, Val Loss: 12.7394\n",
      "Epoch 141/200, Train Loss: 13.3595, Val Loss: 12.7854\n",
      "Epoch 142/200, Train Loss: 13.3187, Val Loss: 12.7939\n",
      "Epoch 143/200, Train Loss: 13.4131, Val Loss: 12.8823\n",
      "Epoch 144/200, Train Loss: 13.3192, Val Loss: 12.7351\n",
      "Epoch 145/200, Train Loss: 13.3325, Val Loss: 12.7026\n",
      "  New best validation loss: 12.7026\n",
      "Epoch 146/200, Train Loss: 13.2883, Val Loss: 13.1519\n",
      "Epoch 147/200, Train Loss: 13.3049, Val Loss: 12.5653\n",
      "  New best validation loss: 12.5653\n",
      "Epoch 148/200, Train Loss: 13.4096, Val Loss: 12.7368\n",
      "Epoch 149/200, Train Loss: 13.3144, Val Loss: 12.5587\n",
      "  New best validation loss: 12.5587\n",
      "Epoch 150/200, Train Loss: 13.2557, Val Loss: 12.6080\n",
      "Epoch 151/200, Train Loss: 13.2848, Val Loss: 12.5866\n",
      "Epoch 152/200, Train Loss: 13.2745, Val Loss: 12.8271\n",
      "Epoch 153/200, Train Loss: 13.2785, Val Loss: 12.6946\n",
      "Epoch 154/200, Train Loss: 13.2717, Val Loss: 12.6105\n",
      "Epoch 155/200, Train Loss: 13.2511, Val Loss: 12.6958\n",
      "Epoch 156/200, Train Loss: 13.1874, Val Loss: 12.5138\n",
      "  New best validation loss: 12.5138\n",
      "Epoch 157/200, Train Loss: 13.2733, Val Loss: 12.6833\n",
      "Epoch 158/200, Train Loss: 13.2200, Val Loss: 12.4532\n",
      "  New best validation loss: 12.4532\n",
      "Epoch 159/200, Train Loss: 13.2261, Val Loss: 12.5669\n",
      "Epoch 160/200, Train Loss: 13.1473, Val Loss: 12.8172\n",
      "Epoch 161/200, Train Loss: 13.3373, Val Loss: 12.5918\n",
      "Epoch 162/200, Train Loss: 13.1685, Val Loss: 13.0009\n",
      "Epoch 163/200, Train Loss: 13.1915, Val Loss: 12.4318\n",
      "  New best validation loss: 12.4318\n",
      "Epoch 164/200, Train Loss: 13.1064, Val Loss: 12.7348\n",
      "Epoch 165/200, Train Loss: 13.1777, Val Loss: 12.4948\n",
      "Epoch 166/200, Train Loss: 13.1415, Val Loss: 12.4555\n",
      "Epoch 167/200, Train Loss: 13.1138, Val Loss: 12.5226\n",
      "Epoch 168/200, Train Loss: 13.0349, Val Loss: 12.3942\n",
      "  New best validation loss: 12.3942\n",
      "Epoch 169/200, Train Loss: 13.1256, Val Loss: 12.5927\n",
      "Epoch 170/200, Train Loss: 13.1045, Val Loss: 12.5506\n",
      "Epoch 171/200, Train Loss: 13.0872, Val Loss: 12.3964\n",
      "Epoch 172/200, Train Loss: 13.1556, Val Loss: 12.6104\n",
      "Epoch 173/200, Train Loss: 13.1709, Val Loss: 12.4674\n",
      "Epoch 174/200, Train Loss: 13.0538, Val Loss: 12.6224\n",
      "Epoch 175/200, Train Loss: 13.0302, Val Loss: 12.3879\n",
      "  New best validation loss: 12.3879\n",
      "Epoch 176/200, Train Loss: 13.0301, Val Loss: 12.3607\n",
      "  New best validation loss: 12.3607\n",
      "Epoch 177/200, Train Loss: 13.0688, Val Loss: 12.3662\n",
      "Epoch 178/200, Train Loss: 13.0885, Val Loss: 12.4417\n",
      "Epoch 179/200, Train Loss: 13.0495, Val Loss: 12.6261\n",
      "Epoch 180/200, Train Loss: 13.0968, Val Loss: 12.4128\n",
      "Epoch 181/200, Train Loss: 13.0099, Val Loss: 12.6626\n",
      "Epoch 182/200, Train Loss: 13.0337, Val Loss: 12.3576\n",
      "  New best validation loss: 12.3576\n",
      "Epoch 183/200, Train Loss: 13.0065, Val Loss: 12.3535\n",
      "  New best validation loss: 12.3535\n",
      "Epoch 184/200, Train Loss: 13.0735, Val Loss: 12.3313\n",
      "  New best validation loss: 12.3313\n",
      "Epoch 185/200, Train Loss: 12.9218, Val Loss: 12.4842\n",
      "Epoch 186/200, Train Loss: 12.9555, Val Loss: 12.5304\n",
      "Epoch 187/200, Train Loss: 12.9936, Val Loss: 12.4889\n",
      "Epoch 188/200, Train Loss: 12.9297, Val Loss: 12.3436\n",
      "Epoch 189/200, Train Loss: 12.9070, Val Loss: 12.6152\n",
      "Epoch 190/200, Train Loss: 13.0783, Val Loss: 12.3445\n",
      "Epoch 191/200, Train Loss: 12.9608, Val Loss: 12.4443\n",
      "Epoch 192/200, Train Loss: 13.0179, Val Loss: 12.2767\n",
      "  New best validation loss: 12.2767\n",
      "Epoch 193/200, Train Loss: 12.9972, Val Loss: 12.4242\n",
      "Epoch 194/200, Train Loss: 12.9638, Val Loss: 12.7628\n",
      "Epoch 195/200, Train Loss: 12.9428, Val Loss: 12.4903\n",
      "Epoch 196/200, Train Loss: 12.9853, Val Loss: 12.3557\n",
      "Epoch 197/200, Train Loss: 12.9146, Val Loss: 12.2848\n",
      "Epoch 198/200, Train Loss: 12.8752, Val Loss: 12.2946\n",
      "Epoch 199/200, Train Loss: 12.8996, Val Loss: 12.2298\n",
      "  New best validation loss: 12.2298\n",
      "Epoch 200/200, Train Loss: 12.9003, Val Loss: 12.3957\n",
      "\n",
      "Loaded best model (Val Loss: 12.2298) for final hidden state extraction.\n",
      "Saved best model for RNN_GRU (samples=1600) to results_data_size_sweep/20250514_045146/samples_1600/RNN_GRU_samples_1600_best.pt\n",
      "\n",
      "--- Performing Decodability Analysis for RNN_GRU (samples=1600, k=15) ---\n",
      "  Analyzing decodability for RNN_GRU...\n",
      "  Hidden states shape: torch.Size([160, 200, 64])\n",
      "  Coefficients shape: torch.Size([160, 15])\n",
      "  Processed hidden states shape for decoder: torch.Size([160, 64])\n",
      "  RidgeCV Decoder for RNN_GRU - Test MSE: 1.4151, Test R2: 0.2843 (best alpha: 2.6367)\n",
      "  Decodability plot saved to results_data_size_sweep/20250514_045146/samples_1600/decodability_RNN_GRU_coeff1.png\n",
      "Decodability (R2 score) for RNN_GRU (samples=1600): 0.2843\n",
      "\n",
      "--- Training Transformer (samples=1600, k=15) ---\n",
      "Number of parameters: 85809\n",
      "Epoch 1/200, Train Loss: 17.1274, Val Loss: 15.9418\n",
      "  New best validation loss: 15.9418\n",
      "Epoch 2/200, Train Loss: 16.8295, Val Loss: 15.8739\n",
      "  New best validation loss: 15.8739\n",
      "Epoch 3/200, Train Loss: 16.8022, Val Loss: 15.9048\n",
      "Epoch 4/200, Train Loss: 16.8146, Val Loss: 15.9733\n",
      "Epoch 5/200, Train Loss: 16.7982, Val Loss: 15.7658\n",
      "  New best validation loss: 15.7658\n",
      "Epoch 6/200, Train Loss: 16.7982, Val Loss: 15.7582\n",
      "  New best validation loss: 15.7582\n",
      "Epoch 7/200, Train Loss: 16.7906, Val Loss: 15.7348\n",
      "  New best validation loss: 15.7348\n",
      "Epoch 8/200, Train Loss: 16.7569, Val Loss: 15.8961\n",
      "Epoch 9/200, Train Loss: 16.7602, Val Loss: 15.7284\n",
      "  New best validation loss: 15.7284\n",
      "Epoch 10/200, Train Loss: 16.7581, Val Loss: 15.7345\n",
      "Epoch 11/200, Train Loss: 16.7534, Val Loss: 15.7668\n",
      "Epoch 12/200, Train Loss: 16.7424, Val Loss: 15.8556\n",
      "Epoch 13/200, Train Loss: 16.7493, Val Loss: 15.6936\n",
      "  New best validation loss: 15.6936\n",
      "Epoch 14/200, Train Loss: 16.7435, Val Loss: 15.6955\n",
      "Epoch 15/200, Train Loss: 16.7439, Val Loss: 15.6542\n",
      "  New best validation loss: 15.6542\n",
      "Epoch 16/200, Train Loss: 16.7158, Val Loss: 15.6947\n",
      "Epoch 17/200, Train Loss: 16.7069, Val Loss: 15.6413\n",
      "  New best validation loss: 15.6413\n",
      "Epoch 18/200, Train Loss: 16.7018, Val Loss: 15.6230\n",
      "  New best validation loss: 15.6230\n",
      "Epoch 19/200, Train Loss: 16.6983, Val Loss: 15.6045\n",
      "  New best validation loss: 15.6045\n",
      "Epoch 20/200, Train Loss: 16.6692, Val Loss: 15.5879\n",
      "  New best validation loss: 15.5879\n",
      "Epoch 21/200, Train Loss: 16.6852, Val Loss: 15.6321\n",
      "Epoch 22/200, Train Loss: 16.6600, Val Loss: 15.5608\n",
      "  New best validation loss: 15.5608\n",
      "Epoch 23/200, Train Loss: 16.6548, Val Loss: 15.5294\n",
      "  New best validation loss: 15.5294\n",
      "Epoch 24/200, Train Loss: 16.6170, Val Loss: 15.4368\n",
      "  New best validation loss: 15.4368\n",
      "Epoch 25/200, Train Loss: 16.5980, Val Loss: 15.4924\n",
      "Epoch 26/200, Train Loss: 16.5393, Val Loss: 15.3097\n",
      "  New best validation loss: 15.3097\n",
      "Epoch 27/200, Train Loss: 16.5105, Val Loss: 15.3232\n",
      "Epoch 28/200, Train Loss: 16.3966, Val Loss: 15.2154\n",
      "  New best validation loss: 15.2154\n",
      "Epoch 29/200, Train Loss: 16.1548, Val Loss: 14.4803\n",
      "  New best validation loss: 14.4803\n",
      "Epoch 30/200, Train Loss: 15.6792, Val Loss: 13.7306\n",
      "  New best validation loss: 13.7306\n",
      "Epoch 31/200, Train Loss: 15.1106, Val Loss: 13.1977\n",
      "  New best validation loss: 13.1977\n",
      "Epoch 32/200, Train Loss: 14.4965, Val Loss: 12.9608\n",
      "  New best validation loss: 12.9608\n",
      "Epoch 33/200, Train Loss: 13.9941, Val Loss: 11.8101\n",
      "  New best validation loss: 11.8101\n",
      "Epoch 34/200, Train Loss: 13.5097, Val Loss: 11.4463\n",
      "  New best validation loss: 11.4463\n",
      "Epoch 35/200, Train Loss: 13.1154, Val Loss: 11.3808\n",
      "  New best validation loss: 11.3808\n",
      "Epoch 36/200, Train Loss: 12.8430, Val Loss: 11.1579\n",
      "  New best validation loss: 11.1579\n",
      "Epoch 37/200, Train Loss: 12.6922, Val Loss: 11.1779\n",
      "Epoch 38/200, Train Loss: 12.5826, Val Loss: 10.8715\n",
      "  New best validation loss: 10.8715\n",
      "Epoch 39/200, Train Loss: 12.4095, Val Loss: 10.7525\n",
      "  New best validation loss: 10.7525\n",
      "Epoch 40/200, Train Loss: 12.3918, Val Loss: 10.9947\n",
      "Epoch 41/200, Train Loss: 12.3395, Val Loss: 10.8648\n",
      "Epoch 42/200, Train Loss: 12.2566, Val Loss: 10.7874\n",
      "Epoch 43/200, Train Loss: 12.1690, Val Loss: 10.7516\n",
      "  New best validation loss: 10.7516\n",
      "Epoch 44/200, Train Loss: 12.1753, Val Loss: 10.6200\n",
      "  New best validation loss: 10.6200\n",
      "Epoch 45/200, Train Loss: 12.1582, Val Loss: 10.5413\n",
      "  New best validation loss: 10.5413\n",
      "Epoch 46/200, Train Loss: 12.0078, Val Loss: 10.6835\n",
      "Epoch 47/200, Train Loss: 11.9888, Val Loss: 10.6607\n",
      "Epoch 48/200, Train Loss: 11.9255, Val Loss: 10.6924\n",
      "Epoch 49/200, Train Loss: 11.9102, Val Loss: 10.6266\n",
      "Epoch 50/200, Train Loss: 11.9155, Val Loss: 10.5319\n",
      "  New best validation loss: 10.5319\n",
      "Epoch 51/200, Train Loss: 11.8039, Val Loss: 10.3833\n",
      "  New best validation loss: 10.3833\n",
      "Epoch 52/200, Train Loss: 11.7613, Val Loss: 10.4230\n",
      "Epoch 53/200, Train Loss: 11.7377, Val Loss: 10.3745\n",
      "  New best validation loss: 10.3745\n",
      "Epoch 54/200, Train Loss: 11.6754, Val Loss: 10.5571\n",
      "Epoch 55/200, Train Loss: 11.6816, Val Loss: 10.2350\n",
      "  New best validation loss: 10.2350\n",
      "Epoch 56/200, Train Loss: 11.6357, Val Loss: 10.4622\n",
      "Epoch 57/200, Train Loss: 11.6171, Val Loss: 10.4500\n",
      "Epoch 58/200, Train Loss: 11.5683, Val Loss: 10.5569\n",
      "Epoch 59/200, Train Loss: 11.5034, Val Loss: 10.1151\n",
      "  New best validation loss: 10.1151\n",
      "Epoch 60/200, Train Loss: 11.4565, Val Loss: 10.4668\n",
      "Epoch 61/200, Train Loss: 11.4794, Val Loss: 10.2185\n",
      "Epoch 62/200, Train Loss: 11.4215, Val Loss: 10.1615\n",
      "Epoch 63/200, Train Loss: 11.4063, Val Loss: 10.2737\n",
      "Epoch 64/200, Train Loss: 11.3928, Val Loss: 10.1700\n",
      "Epoch 65/200, Train Loss: 11.3680, Val Loss: 10.1360\n",
      "Epoch 66/200, Train Loss: 11.4061, Val Loss: 10.0284\n",
      "  New best validation loss: 10.0284\n",
      "Epoch 67/200, Train Loss: 11.3603, Val Loss: 10.1773\n",
      "Epoch 68/200, Train Loss: 11.3957, Val Loss: 10.2775\n",
      "Epoch 69/200, Train Loss: 11.3306, Val Loss: 10.2832\n",
      "Epoch 70/200, Train Loss: 11.3582, Val Loss: 10.0790\n",
      "Epoch 71/200, Train Loss: 11.3110, Val Loss: 10.1016\n",
      "Epoch 72/200, Train Loss: 11.2974, Val Loss: 10.0548\n",
      "Epoch 73/200, Train Loss: 11.2442, Val Loss: 10.1660\n",
      "Epoch 74/200, Train Loss: 11.3030, Val Loss: 10.0341\n",
      "Epoch 75/200, Train Loss: 11.2168, Val Loss: 10.2070\n",
      "Epoch 76/200, Train Loss: 11.1929, Val Loss: 10.1563\n",
      "Epoch 77/200, Train Loss: 11.2221, Val Loss: 10.3999\n",
      "Epoch 78/200, Train Loss: 11.2054, Val Loss: 10.0617\n",
      "Epoch 79/200, Train Loss: 11.2090, Val Loss: 10.2989\n",
      "Epoch 80/200, Train Loss: 11.2366, Val Loss: 10.0131\n",
      "  New best validation loss: 10.0131\n",
      "Epoch 81/200, Train Loss: 11.1720, Val Loss: 10.0521\n",
      "Epoch 82/200, Train Loss: 11.1345, Val Loss: 10.2502\n",
      "Epoch 83/200, Train Loss: 11.1683, Val Loss: 10.1980\n",
      "Epoch 84/200, Train Loss: 11.1643, Val Loss: 10.1004\n",
      "Epoch 85/200, Train Loss: 11.1277, Val Loss: 10.0651\n",
      "Epoch 86/200, Train Loss: 11.1654, Val Loss: 10.0338\n",
      "Epoch 87/200, Train Loss: 11.1149, Val Loss: 9.9737\n",
      "  New best validation loss: 9.9737\n",
      "Epoch 88/200, Train Loss: 11.0890, Val Loss: 9.9638\n",
      "  New best validation loss: 9.9638\n",
      "Epoch 89/200, Train Loss: 11.0892, Val Loss: 10.1002\n",
      "Epoch 90/200, Train Loss: 11.0911, Val Loss: 10.3171\n",
      "Epoch 91/200, Train Loss: 11.2099, Val Loss: 9.9239\n",
      "  New best validation loss: 9.9239\n",
      "Epoch 92/200, Train Loss: 11.0564, Val Loss: 9.9914\n",
      "Epoch 93/200, Train Loss: 11.0858, Val Loss: 10.2677\n",
      "Epoch 94/200, Train Loss: 11.0885, Val Loss: 10.0330\n",
      "Epoch 95/200, Train Loss: 11.1408, Val Loss: 10.0323\n",
      "Epoch 96/200, Train Loss: 11.1647, Val Loss: 9.9808\n",
      "Epoch 97/200, Train Loss: 11.1521, Val Loss: 10.0879\n",
      "Epoch 98/200, Train Loss: 11.1563, Val Loss: 10.0143\n",
      "Epoch 99/200, Train Loss: 11.0780, Val Loss: 9.9562\n",
      "Epoch 100/200, Train Loss: 11.0967, Val Loss: 9.9293\n",
      "Epoch 101/200, Train Loss: 11.0324, Val Loss: 10.0130\n",
      "Epoch 102/200, Train Loss: 11.0588, Val Loss: 9.9326\n",
      "Epoch 103/200, Train Loss: 11.0509, Val Loss: 10.2564\n",
      "Epoch 104/200, Train Loss: 11.0327, Val Loss: 9.9575\n",
      "Epoch 105/200, Train Loss: 11.0403, Val Loss: 9.9140\n",
      "  New best validation loss: 9.9140\n",
      "Epoch 106/200, Train Loss: 10.9519, Val Loss: 9.9691\n",
      "Epoch 107/200, Train Loss: 11.0605, Val Loss: 10.0116\n",
      "Epoch 108/200, Train Loss: 10.9796, Val Loss: 9.9431\n",
      "Epoch 109/200, Train Loss: 11.0031, Val Loss: 9.9573\n",
      "Epoch 110/200, Train Loss: 11.0076, Val Loss: 9.9498\n",
      "Epoch 111/200, Train Loss: 11.0512, Val Loss: 9.8635\n",
      "  New best validation loss: 9.8635\n",
      "Epoch 112/200, Train Loss: 10.9684, Val Loss: 9.8540\n",
      "  New best validation loss: 9.8540\n",
      "Epoch 113/200, Train Loss: 10.9844, Val Loss: 9.8512\n",
      "  New best validation loss: 9.8512\n",
      "Epoch 114/200, Train Loss: 11.0362, Val Loss: 9.9408\n",
      "Epoch 115/200, Train Loss: 11.0066, Val Loss: 9.9598\n",
      "Epoch 116/200, Train Loss: 10.9501, Val Loss: 9.8094\n",
      "  New best validation loss: 9.8094\n",
      "Epoch 117/200, Train Loss: 10.9789, Val Loss: 9.8277\n",
      "Epoch 118/200, Train Loss: 10.9922, Val Loss: 9.9533\n",
      "Epoch 119/200, Train Loss: 10.9722, Val Loss: 9.8376\n",
      "Epoch 120/200, Train Loss: 10.9958, Val Loss: 9.8301\n",
      "Epoch 121/200, Train Loss: 10.9780, Val Loss: 9.8157\n",
      "Epoch 122/200, Train Loss: 10.9045, Val Loss: 9.9032\n",
      "Epoch 123/200, Train Loss: 10.9473, Val Loss: 9.9531\n",
      "Epoch 124/200, Train Loss: 10.9259, Val Loss: 9.8324\n",
      "Epoch 125/200, Train Loss: 10.9426, Val Loss: 9.8415\n",
      "Epoch 126/200, Train Loss: 10.9230, Val Loss: 9.9489\n",
      "Epoch 127/200, Train Loss: 10.9672, Val Loss: 9.9439\n",
      "Epoch 128/200, Train Loss: 10.9435, Val Loss: 9.8027\n",
      "  New best validation loss: 9.8027\n",
      "Epoch 129/200, Train Loss: 10.9378, Val Loss: 9.8913\n",
      "Epoch 130/200, Train Loss: 10.9012, Val Loss: 9.7971\n",
      "  New best validation loss: 9.7971\n",
      "Epoch 131/200, Train Loss: 10.9152, Val Loss: 9.7863\n",
      "  New best validation loss: 9.7863\n",
      "Epoch 132/200, Train Loss: 10.9776, Val Loss: 9.8264\n",
      "Epoch 133/200, Train Loss: 10.9044, Val Loss: 9.9433\n",
      "Epoch 134/200, Train Loss: 10.9627, Val Loss: 9.7366\n",
      "  New best validation loss: 9.7366\n",
      "Epoch 135/200, Train Loss: 10.9127, Val Loss: 9.9263\n",
      "Epoch 136/200, Train Loss: 10.9052, Val Loss: 9.8972\n",
      "Epoch 137/200, Train Loss: 10.8866, Val Loss: 9.7993\n",
      "Epoch 138/200, Train Loss: 10.9360, Val Loss: 10.0110\n",
      "Epoch 139/200, Train Loss: 10.8932, Val Loss: 9.7970\n",
      "Epoch 140/200, Train Loss: 10.8563, Val Loss: 9.8022\n",
      "Epoch 141/200, Train Loss: 10.8654, Val Loss: 9.8030\n",
      "Epoch 142/200, Train Loss: 10.8786, Val Loss: 9.7473\n",
      "Epoch 143/200, Train Loss: 10.9085, Val Loss: 9.8696\n",
      "Epoch 144/200, Train Loss: 10.9162, Val Loss: 9.8483\n",
      "Epoch 145/200, Train Loss: 10.9037, Val Loss: 9.8376\n",
      "Epoch 146/200, Train Loss: 10.8191, Val Loss: 9.7879\n",
      "Epoch 147/200, Train Loss: 10.9185, Val Loss: 9.7991\n",
      "Epoch 148/200, Train Loss: 10.8570, Val Loss: 9.8332\n",
      "Epoch 149/200, Train Loss: 10.9182, Val Loss: 9.8645\n",
      "Epoch 150/200, Train Loss: 10.8747, Val Loss: 9.7929\n",
      "Epoch 151/200, Train Loss: 10.8949, Val Loss: 9.8138\n",
      "Epoch 152/200, Train Loss: 10.8762, Val Loss: 9.8098\n",
      "Epoch 153/200, Train Loss: 10.8921, Val Loss: 9.7651\n",
      "Epoch 154/200, Train Loss: 10.9021, Val Loss: 9.7905\n",
      "Epoch 155/200, Train Loss: 10.8611, Val Loss: 9.7049\n",
      "  New best validation loss: 9.7049\n",
      "Epoch 156/200, Train Loss: 10.8459, Val Loss: 9.7601\n",
      "Epoch 157/200, Train Loss: 10.8152, Val Loss: 9.8228\n",
      "Epoch 158/200, Train Loss: 10.8437, Val Loss: 9.7795\n",
      "Epoch 159/200, Train Loss: 10.8017, Val Loss: 9.7128\n",
      "Epoch 160/200, Train Loss: 10.8374, Val Loss: 9.8614\n",
      "Epoch 161/200, Train Loss: 10.7992, Val Loss: 9.7743\n",
      "Epoch 162/200, Train Loss: 10.7986, Val Loss: 9.7984\n",
      "Epoch 163/200, Train Loss: 10.8403, Val Loss: 9.6747\n",
      "  New best validation loss: 9.6747\n",
      "Epoch 164/200, Train Loss: 10.7744, Val Loss: 9.8398\n",
      "Epoch 165/200, Train Loss: 10.8979, Val Loss: 9.7924\n",
      "Epoch 166/200, Train Loss: 10.8414, Val Loss: 9.6585\n",
      "  New best validation loss: 9.6585\n",
      "Epoch 167/200, Train Loss: 10.8182, Val Loss: 9.6463\n",
      "  New best validation loss: 9.6463\n",
      "Epoch 168/200, Train Loss: 10.8259, Val Loss: 9.6531\n",
      "Epoch 169/200, Train Loss: 10.8313, Val Loss: 9.7084\n",
      "Epoch 170/200, Train Loss: 10.8553, Val Loss: 9.7235\n",
      "Epoch 171/200, Train Loss: 10.7876, Val Loss: 9.8137\n",
      "Epoch 172/200, Train Loss: 10.8165, Val Loss: 9.7939\n",
      "Epoch 173/200, Train Loss: 10.8095, Val Loss: 9.6580\n",
      "Epoch 174/200, Train Loss: 10.8565, Val Loss: 9.7853\n",
      "Epoch 175/200, Train Loss: 10.8014, Val Loss: 9.6700\n",
      "Epoch 176/200, Train Loss: 10.9082, Val Loss: 9.8096\n",
      "Epoch 177/200, Train Loss: 10.8671, Val Loss: 9.6561\n",
      "Epoch 178/200, Train Loss: 10.8510, Val Loss: 9.9439\n",
      "Epoch 179/200, Train Loss: 10.8167, Val Loss: 9.6888\n",
      "Epoch 180/200, Train Loss: 10.7692, Val Loss: 9.7806\n",
      "Epoch 181/200, Train Loss: 10.7801, Val Loss: 9.6755\n",
      "Epoch 182/200, Train Loss: 10.7722, Val Loss: 9.6166\n",
      "  New best validation loss: 9.6166\n",
      "Epoch 183/200, Train Loss: 10.8181, Val Loss: 9.7408\n",
      "Epoch 184/200, Train Loss: 10.7920, Val Loss: 9.7942\n",
      "Epoch 185/200, Train Loss: 10.7936, Val Loss: 9.7316\n",
      "Epoch 186/200, Train Loss: 10.7349, Val Loss: 9.7314\n",
      "Epoch 187/200, Train Loss: 10.7889, Val Loss: 9.7779\n",
      "Epoch 188/200, Train Loss: 10.7975, Val Loss: 9.6199\n",
      "Epoch 189/200, Train Loss: 10.8053, Val Loss: 9.6361\n",
      "Epoch 190/200, Train Loss: 10.7852, Val Loss: 9.6139\n",
      "  New best validation loss: 9.6139\n",
      "Epoch 191/200, Train Loss: 10.7677, Val Loss: 9.6670\n",
      "Epoch 192/200, Train Loss: 10.8059, Val Loss: 9.6171\n",
      "Epoch 193/200, Train Loss: 10.7540, Val Loss: 9.7363\n",
      "Epoch 194/200, Train Loss: 10.8056, Val Loss: 9.6264\n",
      "Epoch 195/200, Train Loss: 10.8155, Val Loss: 9.6370\n",
      "Epoch 196/200, Train Loss: 10.7177, Val Loss: 9.6265\n",
      "Epoch 197/200, Train Loss: 10.7929, Val Loss: 9.6881\n",
      "Epoch 198/200, Train Loss: 10.7921, Val Loss: 9.6287\n",
      "Epoch 199/200, Train Loss: 10.7942, Val Loss: 9.7151\n",
      "Epoch 200/200, Train Loss: 10.7779, Val Loss: 9.5896\n",
      "  New best validation loss: 9.5896\n",
      "\n",
      "Loaded best model (Val Loss: 9.5896) for final hidden state extraction.\n",
      "Saved best model for Transformer (samples=1600) to results_data_size_sweep/20250514_045146/samples_1600/Transformer_samples_1600_best.pt\n",
      "\n",
      "--- Performing Decodability Analysis for Transformer (samples=1600, k=15) ---\n",
      "  Analyzing decodability for Transformer...\n",
      "  Hidden states shape: torch.Size([160, 200, 20])\n",
      "  Coefficients shape: torch.Size([160, 15])\n",
      "  Processed hidden states shape for decoder: torch.Size([160, 20])\n",
      "  RidgeCV Decoder for Transformer - Test MSE: 1.1350, Test R2: 0.4420 (best alpha: 0.0336)\n",
      "  Decodability plot saved to results_data_size_sweep/20250514_045146/samples_1600/decodability_Transformer_coeff1.png\n",
      "Decodability (R2 score) for Transformer (samples=1600): 0.4420\n",
      "\n",
      "--- Training TransformerCausal (samples=1600, k=15) ---\n",
      "Number of parameters: 85809\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/conda/lib/python3.10/site-packages/torch/nn/modules/activation.py:1160: UserWarning: Converting mask without torch.bool dtype to bool; this will negatively affect performance. Prefer to use a boolean mask directly. (Triggered internally at /opt/conda/conda-bld/pytorch_1682343995026/work/aten/src/ATen/native/transformers/attention.cpp:150.)\n",
      "  return torch._native_multi_head_attention(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/200, Train Loss: 17.1214, Val Loss: 15.9138\n",
      "  New best validation loss: 15.9138\n",
      "Epoch 2/200, Train Loss: 16.7728, Val Loss: 15.7512\n",
      "  New best validation loss: 15.7512\n",
      "Epoch 3/200, Train Loss: 16.7394, Val Loss: 15.8627\n",
      "Epoch 4/200, Train Loss: 16.7349, Val Loss: 15.7139\n",
      "  New best validation loss: 15.7139\n",
      "Epoch 5/200, Train Loss: 16.7221, Val Loss: 15.7743\n",
      "Epoch 6/200, Train Loss: 16.7047, Val Loss: 15.7627\n",
      "Epoch 7/200, Train Loss: 16.6891, Val Loss: 15.7676\n",
      "Epoch 8/200, Train Loss: 16.6877, Val Loss: 15.8106\n",
      "Epoch 9/200, Train Loss: 16.6758, Val Loss: 15.6981\n",
      "  New best validation loss: 15.6981\n",
      "Epoch 10/200, Train Loss: 16.6947, Val Loss: 15.7780\n",
      "Epoch 11/200, Train Loss: 16.6432, Val Loss: 15.8397\n",
      "Epoch 12/200, Train Loss: 16.6428, Val Loss: 15.8330\n",
      "Epoch 13/200, Train Loss: 16.6515, Val Loss: 15.7575\n",
      "Epoch 14/200, Train Loss: 16.6359, Val Loss: 15.7917\n",
      "Epoch 15/200, Train Loss: 16.6088, Val Loss: 15.6971\n",
      "  New best validation loss: 15.6971\n",
      "Epoch 16/200, Train Loss: 16.6183, Val Loss: 15.7037\n",
      "Epoch 17/200, Train Loss: 16.6266, Val Loss: 15.6645\n",
      "  New best validation loss: 15.6645\n",
      "Epoch 18/200, Train Loss: 16.5757, Val Loss: 15.5690\n",
      "  New best validation loss: 15.5690\n",
      "Epoch 19/200, Train Loss: 16.6029, Val Loss: 15.7522\n",
      "Epoch 20/200, Train Loss: 16.5810, Val Loss: 15.6549\n",
      "Epoch 21/200, Train Loss: 16.5542, Val Loss: 15.6076\n",
      "Epoch 22/200, Train Loss: 16.5563, Val Loss: 15.5208\n",
      "  New best validation loss: 15.5208\n",
      "Epoch 23/200, Train Loss: 16.5732, Val Loss: 15.6269\n",
      "Epoch 24/200, Train Loss: 16.5426, Val Loss: 15.7126\n",
      "Epoch 25/200, Train Loss: 16.5141, Val Loss: 15.4750\n",
      "  New best validation loss: 15.4750\n",
      "Epoch 26/200, Train Loss: 16.5217, Val Loss: 15.6908\n",
      "Epoch 27/200, Train Loss: 16.4780, Val Loss: 15.5156\n",
      "Epoch 28/200, Train Loss: 16.4712, Val Loss: 15.4555\n",
      "  New best validation loss: 15.4555\n",
      "Epoch 29/200, Train Loss: 16.4446, Val Loss: 15.4125\n",
      "  New best validation loss: 15.4125\n",
      "Epoch 30/200, Train Loss: 16.4026, Val Loss: 15.3403\n",
      "  New best validation loss: 15.3403\n",
      "Epoch 31/200, Train Loss: 16.3867, Val Loss: 15.2914\n",
      "  New best validation loss: 15.2914\n",
      "Epoch 32/200, Train Loss: 16.3796, Val Loss: 15.3133\n",
      "Epoch 33/200, Train Loss: 16.3745, Val Loss: 15.3942\n",
      "Epoch 34/200, Train Loss: 16.3326, Val Loss: 15.2501\n",
      "  New best validation loss: 15.2501\n",
      "Epoch 35/200, Train Loss: 16.3413, Val Loss: 15.2871\n",
      "Epoch 36/200, Train Loss: 16.2922, Val Loss: 15.2533\n",
      "Epoch 37/200, Train Loss: 16.2699, Val Loss: 15.1882\n",
      "  New best validation loss: 15.1882\n",
      "Epoch 38/200, Train Loss: 16.2393, Val Loss: 15.1112\n",
      "  New best validation loss: 15.1112\n",
      "Epoch 39/200, Train Loss: 16.2414, Val Loss: 15.1162\n",
      "Epoch 40/200, Train Loss: 16.1982, Val Loss: 15.2277\n",
      "Epoch 41/200, Train Loss: 16.1753, Val Loss: 15.1844\n",
      "Epoch 42/200, Train Loss: 16.1500, Val Loss: 15.1252\n",
      "Epoch 43/200, Train Loss: 16.1357, Val Loss: 14.9738\n",
      "  New best validation loss: 14.9738\n",
      "Epoch 44/200, Train Loss: 16.1013, Val Loss: 15.1244\n",
      "Epoch 45/200, Train Loss: 16.0645, Val Loss: 14.9528\n",
      "  New best validation loss: 14.9528\n",
      "Epoch 46/200, Train Loss: 16.0332, Val Loss: 14.9180\n",
      "  New best validation loss: 14.9180\n",
      "Epoch 47/200, Train Loss: 16.0036, Val Loss: 14.9270\n",
      "Epoch 48/200, Train Loss: 15.9252, Val Loss: 14.8368\n",
      "  New best validation loss: 14.8368\n",
      "Epoch 49/200, Train Loss: 15.8980, Val Loss: 14.9791\n",
      "Epoch 50/200, Train Loss: 15.8609, Val Loss: 14.8256\n",
      "  New best validation loss: 14.8256\n",
      "Epoch 51/200, Train Loss: 15.7691, Val Loss: 14.7718\n",
      "  New best validation loss: 14.7718\n",
      "Epoch 52/200, Train Loss: 15.7702, Val Loss: 14.7546\n",
      "  New best validation loss: 14.7546\n",
      "Epoch 53/200, Train Loss: 15.7341, Val Loss: 14.7911\n",
      "Epoch 54/200, Train Loss: 15.7001, Val Loss: 14.7931\n",
      "Epoch 55/200, Train Loss: 15.5750, Val Loss: 14.6358\n",
      "  New best validation loss: 14.6358\n",
      "Epoch 56/200, Train Loss: 15.5625, Val Loss: 14.5008\n",
      "  New best validation loss: 14.5008\n",
      "Epoch 57/200, Train Loss: 15.4815, Val Loss: 14.5845\n",
      "Epoch 58/200, Train Loss: 15.4319, Val Loss: 14.3766\n",
      "  New best validation loss: 14.3766\n",
      "Epoch 59/200, Train Loss: 15.3285, Val Loss: 14.3384\n",
      "  New best validation loss: 14.3384\n",
      "Epoch 60/200, Train Loss: 15.2838, Val Loss: 14.4570\n",
      "Epoch 61/200, Train Loss: 15.2171, Val Loss: 14.2235\n",
      "  New best validation loss: 14.2235\n",
      "Epoch 62/200, Train Loss: 15.1293, Val Loss: 14.1092\n",
      "  New best validation loss: 14.1092\n",
      "Epoch 63/200, Train Loss: 15.0079, Val Loss: 13.9774\n",
      "  New best validation loss: 13.9774\n",
      "Epoch 64/200, Train Loss: 14.9492, Val Loss: 13.9533\n",
      "  New best validation loss: 13.9533\n",
      "Epoch 65/200, Train Loss: 14.8795, Val Loss: 13.7934\n",
      "  New best validation loss: 13.7934\n",
      "Epoch 66/200, Train Loss: 14.7337, Val Loss: 13.8115\n",
      "Epoch 67/200, Train Loss: 14.7509, Val Loss: 13.6798\n",
      "  New best validation loss: 13.6798\n",
      "Epoch 68/200, Train Loss: 14.6931, Val Loss: 13.7125\n",
      "Epoch 69/200, Train Loss: 14.5866, Val Loss: 13.6995\n",
      "Epoch 70/200, Train Loss: 14.5716, Val Loss: 13.4627\n",
      "  New best validation loss: 13.4627\n",
      "Epoch 71/200, Train Loss: 14.5028, Val Loss: 13.5147\n",
      "Epoch 72/200, Train Loss: 14.4840, Val Loss: 13.4724\n",
      "Epoch 73/200, Train Loss: 14.4356, Val Loss: 13.4376\n",
      "  New best validation loss: 13.4376\n",
      "Epoch 74/200, Train Loss: 14.4214, Val Loss: 13.3511\n",
      "  New best validation loss: 13.3511\n",
      "Epoch 75/200, Train Loss: 14.3494, Val Loss: 13.2931\n",
      "  New best validation loss: 13.2931\n",
      "Epoch 76/200, Train Loss: 14.3028, Val Loss: 13.1257\n",
      "  New best validation loss: 13.1257\n",
      "Epoch 77/200, Train Loss: 14.2748, Val Loss: 13.2600\n",
      "Epoch 78/200, Train Loss: 14.2054, Val Loss: 12.9811\n",
      "  New best validation loss: 12.9811\n",
      "Epoch 79/200, Train Loss: 14.1804, Val Loss: 12.9972\n",
      "Epoch 80/200, Train Loss: 14.1494, Val Loss: 12.9518\n",
      "  New best validation loss: 12.9518\n",
      "Epoch 81/200, Train Loss: 14.0717, Val Loss: 12.9059\n",
      "  New best validation loss: 12.9059\n",
      "Epoch 82/200, Train Loss: 14.0670, Val Loss: 12.8052\n",
      "  New best validation loss: 12.8052\n",
      "Epoch 83/200, Train Loss: 14.0028, Val Loss: 12.7368\n",
      "  New best validation loss: 12.7368\n",
      "Epoch 84/200, Train Loss: 14.0246, Val Loss: 12.8689\n",
      "Epoch 85/200, Train Loss: 13.9683, Val Loss: 12.7275\n",
      "  New best validation loss: 12.7275\n",
      "Epoch 86/200, Train Loss: 13.9932, Val Loss: 12.7931\n",
      "Epoch 87/200, Train Loss: 14.0135, Val Loss: 12.6464\n",
      "  New best validation loss: 12.6464\n",
      "Epoch 88/200, Train Loss: 13.9344, Val Loss: 12.7601\n",
      "Epoch 89/200, Train Loss: 13.9161, Val Loss: 12.8029\n",
      "Epoch 90/200, Train Loss: 13.9072, Val Loss: 12.6227\n",
      "  New best validation loss: 12.6227\n",
      "Epoch 91/200, Train Loss: 13.8601, Val Loss: 12.7684\n",
      "Epoch 92/200, Train Loss: 13.8821, Val Loss: 12.7410\n",
      "Epoch 93/200, Train Loss: 13.8249, Val Loss: 12.6844\n",
      "Epoch 94/200, Train Loss: 13.8809, Val Loss: 12.7900\n",
      "Epoch 95/200, Train Loss: 13.8639, Val Loss: 12.6107\n",
      "  New best validation loss: 12.6107\n",
      "Epoch 96/200, Train Loss: 13.8310, Val Loss: 12.8128\n",
      "Epoch 97/200, Train Loss: 13.8470, Val Loss: 12.6442\n",
      "Epoch 98/200, Train Loss: 13.7639, Val Loss: 12.5713\n",
      "  New best validation loss: 12.5713\n",
      "Epoch 99/200, Train Loss: 13.7917, Val Loss: 12.5863\n",
      "Epoch 100/200, Train Loss: 13.8083, Val Loss: 12.6893\n",
      "Epoch 101/200, Train Loss: 13.7756, Val Loss: 12.6433\n",
      "Epoch 102/200, Train Loss: 13.7874, Val Loss: 12.5363\n",
      "  New best validation loss: 12.5363\n",
      "Epoch 103/200, Train Loss: 13.7676, Val Loss: 12.6181\n",
      "Epoch 104/200, Train Loss: 13.7834, Val Loss: 12.6739\n",
      "Epoch 105/200, Train Loss: 13.7907, Val Loss: 12.5743\n",
      "Epoch 106/200, Train Loss: 13.7809, Val Loss: 12.5558\n",
      "Epoch 107/200, Train Loss: 13.7539, Val Loss: 12.7700\n",
      "Epoch 108/200, Train Loss: 13.7750, Val Loss: 12.5175\n",
      "  New best validation loss: 12.5175\n",
      "Epoch 109/200, Train Loss: 13.7458, Val Loss: 12.5669\n",
      "Epoch 110/200, Train Loss: 13.7122, Val Loss: 12.6145\n",
      "Epoch 111/200, Train Loss: 13.7095, Val Loss: 12.5811\n",
      "Epoch 112/200, Train Loss: 13.6954, Val Loss: 12.4651\n",
      "  New best validation loss: 12.4651\n",
      "Epoch 113/200, Train Loss: 13.7395, Val Loss: 12.5365\n",
      "Epoch 114/200, Train Loss: 13.7197, Val Loss: 12.6130\n",
      "Epoch 115/200, Train Loss: 13.7411, Val Loss: 12.5325\n",
      "Epoch 116/200, Train Loss: 13.6835, Val Loss: 12.5375\n",
      "Epoch 117/200, Train Loss: 13.7190, Val Loss: 12.5720\n",
      "Epoch 118/200, Train Loss: 13.6970, Val Loss: 12.5663\n",
      "Epoch 119/200, Train Loss: 13.7712, Val Loss: 12.5414\n",
      "Epoch 120/200, Train Loss: 13.7204, Val Loss: 12.5119\n",
      "Epoch 121/200, Train Loss: 13.6857, Val Loss: 12.5423\n",
      "Epoch 122/200, Train Loss: 13.6823, Val Loss: 12.5715\n",
      "Epoch 123/200, Train Loss: 13.6974, Val Loss: 12.5225\n",
      "Epoch 124/200, Train Loss: 13.6729, Val Loss: 12.4498\n",
      "  New best validation loss: 12.4498\n",
      "Epoch 125/200, Train Loss: 13.6648, Val Loss: 12.4729\n",
      "Epoch 126/200, Train Loss: 13.6793, Val Loss: 12.5117\n",
      "Epoch 127/200, Train Loss: 13.6270, Val Loss: 12.5634\n",
      "Epoch 128/200, Train Loss: 13.6693, Val Loss: 12.5498\n",
      "Epoch 129/200, Train Loss: 13.6440, Val Loss: 12.5487\n",
      "Epoch 130/200, Train Loss: 13.6080, Val Loss: 12.4706\n",
      "Epoch 131/200, Train Loss: 13.6338, Val Loss: 12.5057\n",
      "Epoch 132/200, Train Loss: 13.6544, Val Loss: 12.5733\n",
      "Epoch 133/200, Train Loss: 13.6655, Val Loss: 12.5096\n",
      "Epoch 134/200, Train Loss: 13.6185, Val Loss: 12.3722\n",
      "  New best validation loss: 12.3722\n",
      "Epoch 135/200, Train Loss: 13.6021, Val Loss: 12.4218\n",
      "Epoch 136/200, Train Loss: 13.6406, Val Loss: 12.4291\n",
      "Epoch 137/200, Train Loss: 13.6430, Val Loss: 12.4630\n",
      "Epoch 138/200, Train Loss: 13.6120, Val Loss: 12.4356\n",
      "Epoch 139/200, Train Loss: 13.6240, Val Loss: 12.4811\n",
      "Epoch 140/200, Train Loss: 13.6270, Val Loss: 12.3769\n",
      "Epoch 141/200, Train Loss: 13.6291, Val Loss: 12.3765\n",
      "Epoch 142/200, Train Loss: 13.6205, Val Loss: 12.4555\n",
      "Epoch 143/200, Train Loss: 13.6018, Val Loss: 12.3982\n",
      "Epoch 144/200, Train Loss: 13.5820, Val Loss: 12.4184\n",
      "Epoch 145/200, Train Loss: 13.5446, Val Loss: 12.4870\n",
      "Epoch 146/200, Train Loss: 13.6156, Val Loss: 12.3585\n",
      "  New best validation loss: 12.3585\n",
      "Epoch 147/200, Train Loss: 13.5843, Val Loss: 12.4265\n",
      "Epoch 148/200, Train Loss: 13.6272, Val Loss: 12.4478\n",
      "Epoch 149/200, Train Loss: 13.5963, Val Loss: 12.4106\n",
      "Epoch 150/200, Train Loss: 13.5990, Val Loss: 12.4317\n",
      "Epoch 151/200, Train Loss: 13.6219, Val Loss: 12.5116\n",
      "Epoch 152/200, Train Loss: 13.5716, Val Loss: 12.3662\n",
      "Epoch 153/200, Train Loss: 13.5810, Val Loss: 12.6144\n",
      "Epoch 154/200, Train Loss: 13.6185, Val Loss: 12.4848\n",
      "Epoch 155/200, Train Loss: 13.6025, Val Loss: 12.3749\n",
      "Epoch 156/200, Train Loss: 13.5803, Val Loss: 12.4198\n",
      "Epoch 157/200, Train Loss: 13.5953, Val Loss: 12.5330\n",
      "Epoch 158/200, Train Loss: 13.5976, Val Loss: 12.4400\n",
      "Epoch 159/200, Train Loss: 13.6129, Val Loss: 12.3981\n",
      "Epoch 160/200, Train Loss: 13.5772, Val Loss: 12.4154\n",
      "Epoch 161/200, Train Loss: 13.5532, Val Loss: 12.3635\n",
      "Epoch 162/200, Train Loss: 13.6187, Val Loss: 12.4338\n",
      "Epoch 163/200, Train Loss: 13.5370, Val Loss: 12.5224\n",
      "Epoch 164/200, Train Loss: 13.5448, Val Loss: 12.4073\n",
      "Epoch 165/200, Train Loss: 13.5585, Val Loss: 12.5327\n",
      "Epoch 166/200, Train Loss: 13.5897, Val Loss: 12.4043\n",
      "Epoch 167/200, Train Loss: 13.5731, Val Loss: 12.3977\n",
      "Epoch 168/200, Train Loss: 13.5643, Val Loss: 12.4088\n",
      "Epoch 169/200, Train Loss: 13.5983, Val Loss: 12.4427\n",
      "Epoch 170/200, Train Loss: 13.5627, Val Loss: 12.4216\n",
      "Epoch 171/200, Train Loss: 13.5476, Val Loss: 12.3841\n",
      "Epoch 172/200, Train Loss: 13.5518, Val Loss: 12.4070\n",
      "Epoch 173/200, Train Loss: 13.5479, Val Loss: 12.4249\n",
      "Epoch 174/200, Train Loss: 13.5271, Val Loss: 12.3705\n",
      "Epoch 175/200, Train Loss: 13.4984, Val Loss: 12.3864\n",
      "Epoch 176/200, Train Loss: 13.5248, Val Loss: 12.3597\n",
      "Epoch 177/200, Train Loss: 13.5266, Val Loss: 12.3822\n",
      "Epoch 178/200, Train Loss: 13.5379, Val Loss: 12.3536\n",
      "  New best validation loss: 12.3536\n",
      "Epoch 179/200, Train Loss: 13.5302, Val Loss: 12.3318\n",
      "  New best validation loss: 12.3318\n",
      "Epoch 180/200, Train Loss: 13.5159, Val Loss: 12.3279\n",
      "  New best validation loss: 12.3279\n",
      "Epoch 181/200, Train Loss: 13.5352, Val Loss: 12.3567\n",
      "Epoch 182/200, Train Loss: 13.5461, Val Loss: 12.3952\n",
      "Epoch 183/200, Train Loss: 13.5427, Val Loss: 12.3411\n",
      "Epoch 184/200, Train Loss: 13.5322, Val Loss: 12.3648\n",
      "Epoch 185/200, Train Loss: 13.5292, Val Loss: 12.3162\n",
      "  New best validation loss: 12.3162\n",
      "Epoch 186/200, Train Loss: 13.5344, Val Loss: 12.4061\n",
      "Epoch 187/200, Train Loss: 13.5371, Val Loss: 12.3519\n",
      "Epoch 188/200, Train Loss: 13.5033, Val Loss: 12.3058\n",
      "  New best validation loss: 12.3058\n",
      "Epoch 189/200, Train Loss: 13.4905, Val Loss: 12.3553\n",
      "Epoch 190/200, Train Loss: 13.5073, Val Loss: 12.3532\n",
      "Epoch 191/200, Train Loss: 13.5079, Val Loss: 12.3208\n",
      "Epoch 192/200, Train Loss: 13.5298, Val Loss: 12.5578\n",
      "Epoch 193/200, Train Loss: 13.5511, Val Loss: 12.3515\n",
      "Epoch 194/200, Train Loss: 13.5546, Val Loss: 12.3768\n",
      "Epoch 195/200, Train Loss: 13.5024, Val Loss: 12.3645\n",
      "Epoch 196/200, Train Loss: 13.5228, Val Loss: 12.3728\n",
      "Epoch 197/200, Train Loss: 13.5129, Val Loss: 12.3927\n",
      "Epoch 198/200, Train Loss: 13.4668, Val Loss: 12.3921\n",
      "Epoch 199/200, Train Loss: 13.5039, Val Loss: 12.3368\n",
      "Epoch 200/200, Train Loss: 13.4869, Val Loss: 12.3136\n",
      "\n",
      "Loaded best model (Val Loss: 12.3058) for final hidden state extraction.\n",
      "Saved best model for TransformerCausal (samples=1600) to results_data_size_sweep/20250514_045146/samples_1600/TransformerCausal_samples_1600_best.pt\n",
      "\n",
      "--- Performing Decodability Analysis for TransformerCausal (samples=1600, k=15) ---\n",
      "  Analyzing decodability for TransformerCausal...\n",
      "  Hidden states shape: torch.Size([160, 200, 20])\n",
      "  Coefficients shape: torch.Size([160, 15])\n",
      "  Processed hidden states shape for decoder: torch.Size([160, 20])\n",
      "  RidgeCV Decoder for TransformerCausal - Test MSE: 0.9607, Test R2: 0.5163 (best alpha: 0.0336)\n",
      "  Decodability plot saved to results_data_size_sweep/20250514_045146/samples_1600/decodability_TransformerCausal_coeff1.png\n",
      "Decodability (R2 score) for TransformerCausal (samples=1600): 0.5163\n",
      "\n",
      "--- Training HIPPORNN_LegT (samples=1600, k=15) ---\n",
      "Number of parameters: 4029\n",
      "Epoch 1/200, Train Loss: 16.9948, Val Loss: 15.8435\n",
      "  New best validation loss: 15.8435\n",
      "Epoch 2/200, Train Loss: 16.9733, Val Loss: 15.8230\n",
      "  New best validation loss: 15.8230\n",
      "Epoch 3/200, Train Loss: 16.8823, Val Loss: 15.7043\n",
      "  New best validation loss: 15.7043\n",
      "Epoch 4/200, Train Loss: 16.5703, Val Loss: 15.7149\n",
      "Epoch 5/200, Train Loss: 16.4818, Val Loss: 15.6343\n",
      "  New best validation loss: 15.6343\n",
      "Epoch 6/200, Train Loss: 16.4444, Val Loss: 15.6546\n",
      "Epoch 7/200, Train Loss: 16.4156, Val Loss: 15.6487\n",
      "Epoch 8/200, Train Loss: 16.3831, Val Loss: 15.6235\n",
      "  New best validation loss: 15.6235\n",
      "Epoch 9/200, Train Loss: 16.3498, Val Loss: 15.5776\n",
      "  New best validation loss: 15.5776\n",
      "Epoch 10/200, Train Loss: 16.3091, Val Loss: 15.5872\n",
      "Epoch 11/200, Train Loss: 16.2561, Val Loss: 15.5318\n",
      "  New best validation loss: 15.5318\n",
      "Epoch 12/200, Train Loss: 16.1983, Val Loss: 15.4873\n",
      "  New best validation loss: 15.4873\n",
      "Epoch 13/200, Train Loss: 16.1354, Val Loss: 15.4596\n",
      "  New best validation loss: 15.4596\n",
      "Epoch 14/200, Train Loss: 16.0739, Val Loss: 15.4219\n",
      "  New best validation loss: 15.4219\n",
      "Epoch 15/200, Train Loss: 16.0022, Val Loss: 15.3805\n",
      "  New best validation loss: 15.3805\n",
      "Epoch 16/200, Train Loss: 15.8964, Val Loss: 15.2986\n",
      "  New best validation loss: 15.2986\n",
      "Epoch 17/200, Train Loss: 15.7808, Val Loss: 15.2004\n",
      "  New best validation loss: 15.2004\n",
      "Epoch 18/200, Train Loss: 15.6706, Val Loss: 15.1436\n",
      "  New best validation loss: 15.1436\n",
      "Epoch 19/200, Train Loss: 15.5763, Val Loss: 15.1088\n",
      "  New best validation loss: 15.1088\n",
      "Epoch 20/200, Train Loss: 15.4816, Val Loss: 15.0518\n",
      "  New best validation loss: 15.0518\n",
      "Epoch 21/200, Train Loss: 15.3998, Val Loss: 14.9599\n",
      "  New best validation loss: 14.9599\n",
      "Epoch 22/200, Train Loss: 15.3069, Val Loss: 14.9286\n",
      "  New best validation loss: 14.9286\n",
      "Epoch 23/200, Train Loss: 15.2266, Val Loss: 14.8740\n",
      "  New best validation loss: 14.8740\n",
      "Epoch 24/200, Train Loss: 15.1371, Val Loss: 14.8213\n",
      "  New best validation loss: 14.8213\n",
      "Epoch 25/200, Train Loss: 15.0563, Val Loss: 14.7471\n",
      "  New best validation loss: 14.7471\n",
      "Epoch 26/200, Train Loss: 14.9600, Val Loss: 14.6731\n",
      "  New best validation loss: 14.6731\n",
      "Epoch 27/200, Train Loss: 14.8729, Val Loss: 14.6328\n",
      "  New best validation loss: 14.6328\n",
      "Epoch 28/200, Train Loss: 14.7752, Val Loss: 14.5239\n",
      "  New best validation loss: 14.5239\n",
      "Epoch 29/200, Train Loss: 14.6884, Val Loss: 14.4826\n",
      "  New best validation loss: 14.4826\n",
      "Epoch 30/200, Train Loss: 14.5956, Val Loss: 14.3998\n",
      "  New best validation loss: 14.3998\n",
      "Epoch 31/200, Train Loss: 14.5212, Val Loss: 14.3306\n",
      "  New best validation loss: 14.3306\n",
      "Epoch 32/200, Train Loss: 14.4165, Val Loss: 14.3178\n",
      "  New best validation loss: 14.3178\n",
      "Epoch 33/200, Train Loss: 14.3397, Val Loss: 14.2455\n",
      "  New best validation loss: 14.2455\n",
      "Epoch 34/200, Train Loss: 14.2496, Val Loss: 14.1127\n",
      "  New best validation loss: 14.1127\n",
      "Epoch 35/200, Train Loss: 14.1869, Val Loss: 14.0500\n",
      "  New best validation loss: 14.0500\n",
      "Epoch 36/200, Train Loss: 14.0966, Val Loss: 13.9838\n",
      "  New best validation loss: 13.9838\n",
      "Epoch 37/200, Train Loss: 14.0381, Val Loss: 13.9501\n",
      "  New best validation loss: 13.9501\n",
      "Epoch 38/200, Train Loss: 13.9653, Val Loss: 13.8472\n",
      "  New best validation loss: 13.8472\n",
      "Epoch 39/200, Train Loss: 13.8993, Val Loss: 13.8340\n",
      "  New best validation loss: 13.8340\n",
      "Epoch 40/200, Train Loss: 13.8279, Val Loss: 13.7881\n",
      "  New best validation loss: 13.7881\n",
      "Epoch 41/200, Train Loss: 13.7776, Val Loss: 13.7549\n",
      "  New best validation loss: 13.7549\n",
      "Epoch 42/200, Train Loss: 13.7394, Val Loss: 13.7141\n",
      "  New best validation loss: 13.7141\n",
      "Epoch 43/200, Train Loss: 13.6909, Val Loss: 13.6014\n",
      "  New best validation loss: 13.6014\n",
      "Epoch 44/200, Train Loss: 13.6473, Val Loss: 13.5917\n",
      "  New best validation loss: 13.5917\n",
      "Epoch 45/200, Train Loss: 13.6072, Val Loss: 13.6045\n",
      "Epoch 46/200, Train Loss: 13.5693, Val Loss: 13.4699\n",
      "  New best validation loss: 13.4699\n",
      "Epoch 47/200, Train Loss: 13.5190, Val Loss: 13.4494\n",
      "  New best validation loss: 13.4494\n",
      "Epoch 48/200, Train Loss: 13.4763, Val Loss: 13.4966\n",
      "Epoch 49/200, Train Loss: 13.4438, Val Loss: 13.4028\n",
      "  New best validation loss: 13.4028\n",
      "Epoch 50/200, Train Loss: 13.4048, Val Loss: 13.3734\n",
      "  New best validation loss: 13.3734\n",
      "Epoch 51/200, Train Loss: 13.3690, Val Loss: 13.3187\n",
      "  New best validation loss: 13.3187\n",
      "Epoch 52/200, Train Loss: 13.3534, Val Loss: 13.2804\n",
      "  New best validation loss: 13.2804\n",
      "Epoch 53/200, Train Loss: 13.3163, Val Loss: 13.2672\n",
      "  New best validation loss: 13.2672\n",
      "Epoch 54/200, Train Loss: 13.2705, Val Loss: 13.2522\n",
      "  New best validation loss: 13.2522\n",
      "Epoch 55/200, Train Loss: 13.2646, Val Loss: 13.2021\n",
      "  New best validation loss: 13.2021\n",
      "Epoch 56/200, Train Loss: 13.2220, Val Loss: 13.1833\n",
      "  New best validation loss: 13.1833\n",
      "Epoch 57/200, Train Loss: 13.2040, Val Loss: 13.1096\n",
      "  New best validation loss: 13.1096\n",
      "Epoch 58/200, Train Loss: 13.1762, Val Loss: 13.1173\n",
      "Epoch 59/200, Train Loss: 13.1598, Val Loss: 13.0375\n",
      "  New best validation loss: 13.0375\n",
      "Epoch 60/200, Train Loss: 13.1156, Val Loss: 13.0726\n",
      "Epoch 61/200, Train Loss: 13.0969, Val Loss: 13.0685\n",
      "Epoch 62/200, Train Loss: 13.0834, Val Loss: 13.0254\n",
      "  New best validation loss: 13.0254\n",
      "Epoch 63/200, Train Loss: 13.0356, Val Loss: 12.9993\n",
      "  New best validation loss: 12.9993\n",
      "Epoch 64/200, Train Loss: 13.0380, Val Loss: 12.9508\n",
      "  New best validation loss: 12.9508\n",
      "Epoch 65/200, Train Loss: 13.0101, Val Loss: 12.8631\n",
      "  New best validation loss: 12.8631\n",
      "Epoch 66/200, Train Loss: 12.9793, Val Loss: 12.9407\n",
      "Epoch 67/200, Train Loss: 12.9511, Val Loss: 12.8957\n",
      "Epoch 68/200, Train Loss: 12.9325, Val Loss: 12.8225\n",
      "  New best validation loss: 12.8225\n",
      "Epoch 69/200, Train Loss: 12.9055, Val Loss: 12.8625\n",
      "Epoch 70/200, Train Loss: 12.9039, Val Loss: 12.7079\n",
      "  New best validation loss: 12.7079\n",
      "Epoch 71/200, Train Loss: 12.8592, Val Loss: 12.7610\n",
      "Epoch 72/200, Train Loss: 12.8323, Val Loss: 12.7884\n",
      "Epoch 73/200, Train Loss: 12.8162, Val Loss: 12.6614\n",
      "  New best validation loss: 12.6614\n",
      "Epoch 74/200, Train Loss: 12.8078, Val Loss: 12.6026\n",
      "  New best validation loss: 12.6026\n",
      "Epoch 75/200, Train Loss: 12.7770, Val Loss: 12.6182\n",
      "Epoch 76/200, Train Loss: 12.7644, Val Loss: 12.5475\n",
      "  New best validation loss: 12.5475\n",
      "Epoch 77/200, Train Loss: 12.7286, Val Loss: 12.5665\n",
      "Epoch 78/200, Train Loss: 12.7118, Val Loss: 12.4597\n",
      "  New best validation loss: 12.4597\n",
      "Epoch 79/200, Train Loss: 12.6795, Val Loss: 12.5000\n",
      "Epoch 80/200, Train Loss: 12.6731, Val Loss: 12.6011\n",
      "Epoch 81/200, Train Loss: 12.6382, Val Loss: 12.4355\n",
      "  New best validation loss: 12.4355\n",
      "Epoch 82/200, Train Loss: 12.6482, Val Loss: 12.5582\n",
      "Epoch 83/200, Train Loss: 12.5958, Val Loss: 12.3590\n",
      "  New best validation loss: 12.3590\n",
      "Epoch 84/200, Train Loss: 12.5775, Val Loss: 12.4111\n",
      "Epoch 85/200, Train Loss: 12.5762, Val Loss: 12.2899\n",
      "  New best validation loss: 12.2899\n",
      "Epoch 86/200, Train Loss: 12.5355, Val Loss: 12.3983\n",
      "Epoch 87/200, Train Loss: 12.5050, Val Loss: 12.3522\n",
      "Epoch 88/200, Train Loss: 12.4936, Val Loss: 12.3124\n",
      "Epoch 89/200, Train Loss: 12.4974, Val Loss: 12.3161\n",
      "Epoch 90/200, Train Loss: 12.4626, Val Loss: 12.2328\n",
      "  New best validation loss: 12.2328\n",
      "Epoch 91/200, Train Loss: 12.4400, Val Loss: 12.2374\n",
      "Epoch 92/200, Train Loss: 12.4379, Val Loss: 12.1602\n",
      "  New best validation loss: 12.1602\n",
      "Epoch 93/200, Train Loss: 12.3924, Val Loss: 12.1029\n",
      "  New best validation loss: 12.1029\n",
      "Epoch 94/200, Train Loss: 12.3722, Val Loss: 12.2374\n",
      "Epoch 95/200, Train Loss: 12.3603, Val Loss: 12.1096\n",
      "Epoch 96/200, Train Loss: 12.3584, Val Loss: 12.4063\n",
      "Epoch 97/200, Train Loss: 12.3379, Val Loss: 12.1883\n",
      "Epoch 98/200, Train Loss: 12.3238, Val Loss: 12.0647\n",
      "  New best validation loss: 12.0647\n",
      "Epoch 99/200, Train Loss: 12.2949, Val Loss: 12.0161\n",
      "  New best validation loss: 12.0161\n",
      "Epoch 100/200, Train Loss: 12.2906, Val Loss: 12.1030\n",
      "Epoch 101/200, Train Loss: 12.3333, Val Loss: 12.1382\n",
      "Epoch 102/200, Train Loss: 12.2937, Val Loss: 12.0081\n",
      "  New best validation loss: 12.0081\n",
      "Epoch 103/200, Train Loss: 12.3722, Val Loss: 11.7943\n",
      "  New best validation loss: 11.7943\n",
      "Epoch 104/200, Train Loss: 12.2430, Val Loss: 11.8736\n",
      "Epoch 105/200, Train Loss: 12.2268, Val Loss: 11.7610\n",
      "  New best validation loss: 11.7610\n",
      "Epoch 106/200, Train Loss: 12.2154, Val Loss: 12.0249\n",
      "Epoch 107/200, Train Loss: 12.2034, Val Loss: 11.8755\n",
      "Epoch 108/200, Train Loss: 12.1747, Val Loss: 11.7873\n",
      "Epoch 109/200, Train Loss: 12.1435, Val Loss: 11.7555\n",
      "  New best validation loss: 11.7555\n",
      "Epoch 110/200, Train Loss: 12.1425, Val Loss: 11.7981\n",
      "Epoch 111/200, Train Loss: 12.0997, Val Loss: 11.7599\n",
      "Epoch 112/200, Train Loss: 12.0957, Val Loss: 11.7455\n",
      "  New best validation loss: 11.7455\n",
      "Epoch 113/200, Train Loss: 12.1211, Val Loss: 11.9132\n",
      "Epoch 114/200, Train Loss: 12.1081, Val Loss: 11.7814\n",
      "Epoch 115/200, Train Loss: 12.0611, Val Loss: 11.7344\n",
      "  New best validation loss: 11.7344\n",
      "Epoch 116/200, Train Loss: 12.0518, Val Loss: 11.7114\n",
      "  New best validation loss: 11.7114\n",
      "Epoch 117/200, Train Loss: 12.0626, Val Loss: 11.6720\n",
      "  New best validation loss: 11.6720\n",
      "Epoch 118/200, Train Loss: 12.0717, Val Loss: 11.6157\n",
      "  New best validation loss: 11.6157\n",
      "Epoch 119/200, Train Loss: 12.0630, Val Loss: 11.7848\n",
      "Epoch 120/200, Train Loss: 12.0279, Val Loss: 11.7314\n",
      "Epoch 121/200, Train Loss: 12.0221, Val Loss: 11.6382\n",
      "Epoch 122/200, Train Loss: 12.0098, Val Loss: 11.5367\n",
      "  New best validation loss: 11.5367\n",
      "Epoch 123/200, Train Loss: 11.9853, Val Loss: 11.5717\n",
      "Epoch 124/200, Train Loss: 11.9483, Val Loss: 11.5215\n",
      "  New best validation loss: 11.5215\n",
      "Epoch 125/200, Train Loss: 11.9341, Val Loss: 11.5625\n",
      "Epoch 126/200, Train Loss: 11.9796, Val Loss: 11.7930\n",
      "Epoch 127/200, Train Loss: 11.9803, Val Loss: 11.7958\n",
      "Epoch 128/200, Train Loss: 11.9085, Val Loss: 11.6745\n",
      "Epoch 129/200, Train Loss: 11.9024, Val Loss: 11.4864\n",
      "  New best validation loss: 11.4864\n",
      "Epoch 130/200, Train Loss: 11.8827, Val Loss: 11.5401\n",
      "Epoch 131/200, Train Loss: 11.8663, Val Loss: 11.4143\n",
      "  New best validation loss: 11.4143\n",
      "Epoch 132/200, Train Loss: 11.8462, Val Loss: 11.5390\n",
      "Epoch 133/200, Train Loss: 11.9039, Val Loss: 11.3925\n",
      "  New best validation loss: 11.3925\n",
      "Epoch 134/200, Train Loss: 11.8448, Val Loss: 11.3469\n",
      "  New best validation loss: 11.3469\n",
      "Epoch 135/200, Train Loss: 11.8171, Val Loss: 11.4395\n",
      "Epoch 136/200, Train Loss: 11.8094, Val Loss: 11.2811\n",
      "  New best validation loss: 11.2811\n",
      "Epoch 137/200, Train Loss: 11.7748, Val Loss: 11.3103\n",
      "Epoch 138/200, Train Loss: 11.7857, Val Loss: 11.2353\n",
      "  New best validation loss: 11.2353\n",
      "Epoch 139/200, Train Loss: 11.7870, Val Loss: 11.3424\n",
      "Epoch 140/200, Train Loss: 11.7470, Val Loss: 11.4180\n",
      "Epoch 141/200, Train Loss: 11.7477, Val Loss: 11.3211\n",
      "Epoch 142/200, Train Loss: 11.7083, Val Loss: 11.2883\n",
      "Epoch 143/200, Train Loss: 11.7353, Val Loss: 11.2539\n",
      "Epoch 144/200, Train Loss: 11.6954, Val Loss: 11.3057\n",
      "Epoch 145/200, Train Loss: 11.6797, Val Loss: 11.2236\n",
      "  New best validation loss: 11.2236\n",
      "Epoch 146/200, Train Loss: 11.6506, Val Loss: 11.3822\n",
      "Epoch 147/200, Train Loss: 11.6687, Val Loss: 11.1947\n",
      "  New best validation loss: 11.1947\n",
      "Epoch 148/200, Train Loss: 11.6330, Val Loss: 11.1455\n",
      "  New best validation loss: 11.1455\n",
      "Epoch 149/200, Train Loss: 11.6403, Val Loss: 11.2384\n",
      "Epoch 150/200, Train Loss: 11.6090, Val Loss: 11.1103\n",
      "  New best validation loss: 11.1103\n",
      "Epoch 151/200, Train Loss: 11.6034, Val Loss: 11.1011\n",
      "  New best validation loss: 11.1011\n",
      "Epoch 152/200, Train Loss: 11.6069, Val Loss: 11.1690\n",
      "Epoch 153/200, Train Loss: 11.5956, Val Loss: 11.2242\n",
      "Epoch 154/200, Train Loss: 11.5719, Val Loss: 11.0654\n",
      "  New best validation loss: 11.0654\n",
      "Epoch 155/200, Train Loss: 11.5771, Val Loss: 11.0017\n",
      "  New best validation loss: 11.0017\n",
      "Epoch 156/200, Train Loss: 11.5532, Val Loss: 11.1614\n",
      "Epoch 157/200, Train Loss: 11.5420, Val Loss: 11.1183\n",
      "Epoch 158/200, Train Loss: 11.5347, Val Loss: 11.0424\n",
      "Epoch 159/200, Train Loss: 11.5422, Val Loss: 11.1997\n",
      "Epoch 160/200, Train Loss: 11.5430, Val Loss: 11.0823\n",
      "Epoch 161/200, Train Loss: 11.5088, Val Loss: 11.1132\n",
      "Epoch 162/200, Train Loss: 11.5300, Val Loss: 11.0526\n",
      "Epoch 163/200, Train Loss: 11.5317, Val Loss: 11.1591\n",
      "Epoch 164/200, Train Loss: 11.4982, Val Loss: 10.9743\n",
      "  New best validation loss: 10.9743\n",
      "Epoch 165/200, Train Loss: 11.4870, Val Loss: 11.1016\n",
      "Epoch 166/200, Train Loss: 11.4570, Val Loss: 11.0291\n",
      "Epoch 167/200, Train Loss: 11.4572, Val Loss: 11.0277\n",
      "Epoch 168/200, Train Loss: 11.4532, Val Loss: 11.0599\n",
      "Epoch 169/200, Train Loss: 11.4416, Val Loss: 11.0453\n",
      "Epoch 170/200, Train Loss: 11.4197, Val Loss: 11.1181\n",
      "Epoch 171/200, Train Loss: 11.4182, Val Loss: 11.0526\n",
      "Epoch 172/200, Train Loss: 11.4160, Val Loss: 11.0859\n",
      "Epoch 173/200, Train Loss: 11.4301, Val Loss: 11.0736\n",
      "Epoch 174/200, Train Loss: 11.4473, Val Loss: 10.9816\n",
      "Epoch 175/200, Train Loss: 11.4080, Val Loss: 11.1194\n",
      "Epoch 176/200, Train Loss: 11.4051, Val Loss: 11.1397\n",
      "Epoch 177/200, Train Loss: 11.3853, Val Loss: 11.0561\n",
      "Epoch 178/200, Train Loss: 11.3625, Val Loss: 10.9956\n",
      "Epoch 179/200, Train Loss: 11.3459, Val Loss: 11.0302\n",
      "Epoch 180/200, Train Loss: 11.3734, Val Loss: 10.9863\n",
      "Epoch 181/200, Train Loss: 11.3554, Val Loss: 11.0302\n",
      "Epoch 182/200, Train Loss: 11.3620, Val Loss: 11.0233\n",
      "Epoch 183/200, Train Loss: 11.3538, Val Loss: 11.0104\n",
      "Epoch 184/200, Train Loss: 11.3853, Val Loss: 10.9422\n",
      "  New best validation loss: 10.9422\n",
      "Epoch 185/200, Train Loss: 11.3463, Val Loss: 10.9490\n",
      "Epoch 186/200, Train Loss: 11.3445, Val Loss: 11.0186\n",
      "Epoch 187/200, Train Loss: 11.3126, Val Loss: 11.0069\n",
      "Epoch 188/200, Train Loss: 11.3156, Val Loss: 10.8981\n",
      "  New best validation loss: 10.8981\n",
      "Epoch 189/200, Train Loss: 11.4723, Val Loss: 11.0172\n",
      "Epoch 190/200, Train Loss: 11.3208, Val Loss: 10.8778\n",
      "  New best validation loss: 10.8778\n",
      "Epoch 191/200, Train Loss: 11.2893, Val Loss: 10.9521\n",
      "Epoch 192/200, Train Loss: 11.3158, Val Loss: 10.9792\n",
      "Epoch 193/200, Train Loss: 11.2761, Val Loss: 10.9395\n",
      "Epoch 194/200, Train Loss: 11.3395, Val Loss: 10.8488\n",
      "  New best validation loss: 10.8488\n",
      "Epoch 195/200, Train Loss: 11.3059, Val Loss: 10.9548\n",
      "Epoch 196/200, Train Loss: 11.2799, Val Loss: 11.0024\n",
      "Epoch 197/200, Train Loss: 11.2647, Val Loss: 10.9817\n",
      "Epoch 198/200, Train Loss: 11.2155, Val Loss: 10.8619\n",
      "Epoch 199/200, Train Loss: 11.2936, Val Loss: 10.9556\n",
      "Epoch 200/200, Train Loss: 11.2735, Val Loss: 10.8793\n",
      "\n",
      "Loaded best model (Val Loss: 10.8488) for final hidden state extraction.\n",
      "Saved best model for HIPPORNN_LegT (samples=1600) to results_data_size_sweep/20250514_045146/samples_1600/HIPPORNN_LegT_samples_1600_best.pt\n",
      "\n",
      "--- Performing Decodability Analysis for HIPPORNN_LegT (samples=1600, k=15) ---\n",
      "  Analyzing decodability for HIPPORNN_LegT...\n",
      "  Hidden states shape: torch.Size([160, 200, 25])\n",
      "  Coefficients shape: torch.Size([160, 15])\n",
      "  Processed hidden states shape for decoder: torch.Size([160, 25])\n",
      "  RidgeCV Decoder for HIPPORNN_LegT - Test MSE: 1.4755, Test R2: 0.2653 (best alpha: 23.3572)\n",
      "  Decodability plot saved to results_data_size_sweep/20250514_045146/samples_1600/decodability_HIPPORNN_LegT_coeff1.png\n",
      "Decodability (R2 score) for HIPPORNN_LegT (samples=1600): 0.2653\n",
      "\n",
      "--- Training NMRNN_Spatial_ModReadout (samples=1600, k=15) ---\n",
      "Number of parameters: 66832\n",
      "Epoch 1/200, Train Loss: 16.8072, Val Loss: 15.6891\n",
      "  New best validation loss: 15.6891\n",
      "Epoch 2/200, Train Loss: 16.6245, Val Loss: 15.7335\n",
      "Epoch 3/200, Train Loss: 16.5515, Val Loss: 15.7031\n",
      "Epoch 4/200, Train Loss: 16.5211, Val Loss: 15.7506\n",
      "Epoch 5/200, Train Loss: 16.5122, Val Loss: 15.7449\n",
      "Epoch 6/200, Train Loss: 16.4696, Val Loss: 15.7181\n",
      "Epoch 7/200, Train Loss: 16.4428, Val Loss: 15.6318\n",
      "  New best validation loss: 15.6318\n",
      "Epoch 8/200, Train Loss: 16.4045, Val Loss: 15.5477\n",
      "  New best validation loss: 15.5477\n",
      "Epoch 9/200, Train Loss: 16.3427, Val Loss: 15.5593\n",
      "Epoch 10/200, Train Loss: 16.2681, Val Loss: 15.4270\n",
      "  New best validation loss: 15.4270\n",
      "Epoch 11/200, Train Loss: 16.1668, Val Loss: 15.3392\n",
      "  New best validation loss: 15.3392\n",
      "Epoch 12/200, Train Loss: 16.0571, Val Loss: 15.2601\n",
      "  New best validation loss: 15.2601\n",
      "Epoch 13/200, Train Loss: 15.9398, Val Loss: 15.1428\n",
      "  New best validation loss: 15.1428\n",
      "Epoch 14/200, Train Loss: 15.8471, Val Loss: 15.3624\n",
      "Epoch 15/200, Train Loss: 15.8020, Val Loss: 14.9135\n",
      "  New best validation loss: 14.9135\n",
      "Epoch 16/200, Train Loss: 15.6509, Val Loss: 14.9888\n",
      "Epoch 17/200, Train Loss: 15.4865, Val Loss: 14.8026\n",
      "  New best validation loss: 14.8026\n",
      "Epoch 18/200, Train Loss: 15.3873, Val Loss: 14.8968\n",
      "Epoch 19/200, Train Loss: 15.3748, Val Loss: 14.6536\n",
      "  New best validation loss: 14.6536\n",
      "Epoch 20/200, Train Loss: 15.2034, Val Loss: 14.4204\n",
      "  New best validation loss: 14.4204\n",
      "Epoch 21/200, Train Loss: 15.0527, Val Loss: 14.2551\n",
      "  New best validation loss: 14.2551\n",
      "Epoch 22/200, Train Loss: 14.8712, Val Loss: 14.0994\n",
      "  New best validation loss: 14.0994\n",
      "Epoch 23/200, Train Loss: 14.7834, Val Loss: 14.0241\n",
      "  New best validation loss: 14.0241\n",
      "Epoch 24/200, Train Loss: 14.6339, Val Loss: 14.1254\n",
      "Epoch 25/200, Train Loss: 14.4388, Val Loss: 13.6848\n",
      "  New best validation loss: 13.6848\n",
      "Epoch 26/200, Train Loss: 14.2861, Val Loss: 13.5384\n",
      "  New best validation loss: 13.5384\n",
      "Epoch 27/200, Train Loss: 14.1157, Val Loss: 13.5430\n",
      "Epoch 28/200, Train Loss: 13.9965, Val Loss: 13.3112\n",
      "  New best validation loss: 13.3112\n",
      "Epoch 29/200, Train Loss: 13.8661, Val Loss: 13.3672\n",
      "Epoch 30/200, Train Loss: 13.7332, Val Loss: 13.3321\n",
      "Epoch 31/200, Train Loss: 13.5703, Val Loss: 12.9715\n",
      "  New best validation loss: 12.9715\n",
      "Epoch 32/200, Train Loss: 13.4499, Val Loss: 13.2473\n",
      "Epoch 33/200, Train Loss: 13.3686, Val Loss: 12.9430\n",
      "  New best validation loss: 12.9430\n",
      "Epoch 34/200, Train Loss: 13.2172, Val Loss: 13.0164\n",
      "Epoch 35/200, Train Loss: 13.0767, Val Loss: 12.8317\n",
      "  New best validation loss: 12.8317\n",
      "Epoch 36/200, Train Loss: 12.9722, Val Loss: 12.7636\n",
      "  New best validation loss: 12.7636\n",
      "Epoch 37/200, Train Loss: 12.8540, Val Loss: 13.2190\n",
      "Epoch 38/200, Train Loss: 12.9150, Val Loss: 12.6942\n",
      "  New best validation loss: 12.6942\n",
      "Epoch 39/200, Train Loss: 12.8067, Val Loss: 13.1234\n",
      "Epoch 40/200, Train Loss: 12.6707, Val Loss: 12.6531\n",
      "  New best validation loss: 12.6531\n",
      "Epoch 41/200, Train Loss: 12.5983, Val Loss: 12.8689\n",
      "Epoch 42/200, Train Loss: 12.4047, Val Loss: 12.4986\n",
      "  New best validation loss: 12.4986\n",
      "Epoch 43/200, Train Loss: 12.4025, Val Loss: 12.5588\n",
      "Epoch 44/200, Train Loss: 12.1773, Val Loss: 12.6175\n",
      "Epoch 45/200, Train Loss: 12.2155, Val Loss: 12.6414\n",
      "Epoch 46/200, Train Loss: 12.0636, Val Loss: 12.4093\n",
      "  New best validation loss: 12.4093\n",
      "Epoch 47/200, Train Loss: 11.9592, Val Loss: 12.2140\n",
      "  New best validation loss: 12.2140\n",
      "Epoch 48/200, Train Loss: 11.8584, Val Loss: 12.2018\n",
      "  New best validation loss: 12.2018\n",
      "Epoch 49/200, Train Loss: 11.8349, Val Loss: 12.3165\n",
      "Epoch 50/200, Train Loss: 11.7385, Val Loss: 12.7003\n",
      "Epoch 51/200, Train Loss: 12.0893, Val Loss: 12.1158\n",
      "  New best validation loss: 12.1158\n",
      "Epoch 52/200, Train Loss: 11.6671, Val Loss: 12.4005\n",
      "Epoch 53/200, Train Loss: 11.5718, Val Loss: 12.4153\n",
      "Epoch 54/200, Train Loss: 11.5221, Val Loss: 12.0919\n",
      "  New best validation loss: 12.0919\n",
      "Epoch 55/200, Train Loss: 11.4601, Val Loss: 12.3568\n",
      "Epoch 56/200, Train Loss: 11.4281, Val Loss: 12.6542\n",
      "Epoch 57/200, Train Loss: 11.3845, Val Loss: 12.2851\n",
      "Epoch 58/200, Train Loss: 11.2539, Val Loss: 12.1072\n",
      "Epoch 59/200, Train Loss: 11.2723, Val Loss: 12.2288\n",
      "Epoch 60/200, Train Loss: 11.1901, Val Loss: 12.1984\n",
      "Epoch 61/200, Train Loss: 11.1454, Val Loss: 11.9424\n",
      "  New best validation loss: 11.9424\n",
      "Epoch 62/200, Train Loss: 11.0869, Val Loss: 12.2339\n",
      "Epoch 63/200, Train Loss: 11.0687, Val Loss: 12.1830\n",
      "Epoch 64/200, Train Loss: 10.9907, Val Loss: 12.1883\n",
      "Epoch 65/200, Train Loss: 10.9375, Val Loss: 12.1070\n",
      "Epoch 66/200, Train Loss: 10.7785, Val Loss: 12.3188\n",
      "Epoch 67/200, Train Loss: 10.7563, Val Loss: 12.3897\n",
      "Epoch 68/200, Train Loss: 10.6736, Val Loss: 12.4404\n",
      "Epoch 69/200, Train Loss: 10.7193, Val Loss: 12.1766\n",
      "Epoch 70/200, Train Loss: 10.5985, Val Loss: 12.1778\n",
      "Epoch 71/200, Train Loss: 10.5576, Val Loss: 12.2911\n",
      "Epoch 72/200, Train Loss: 10.4651, Val Loss: 12.1795\n",
      "Epoch 73/200, Train Loss: 10.4421, Val Loss: 12.6201\n",
      "Epoch 74/200, Train Loss: 10.4985, Val Loss: 12.6894\n",
      "Epoch 75/200, Train Loss: 10.3487, Val Loss: 12.5910\n",
      "Epoch 76/200, Train Loss: 10.3042, Val Loss: 12.0497\n",
      "Epoch 77/200, Train Loss: 10.3676, Val Loss: 12.2954\n",
      "Epoch 78/200, Train Loss: 10.2265, Val Loss: 12.2536\n",
      "Epoch 79/200, Train Loss: 10.1968, Val Loss: 12.6383\n",
      "Epoch 80/200, Train Loss: 10.1073, Val Loss: 12.5715\n",
      "Epoch 81/200, Train Loss: 10.1573, Val Loss: 12.4782\n",
      "Epoch 82/200, Train Loss: 10.1888, Val Loss: 12.2443\n",
      "Epoch 83/200, Train Loss: 10.0369, Val Loss: 11.9003\n",
      "  New best validation loss: 11.9003\n",
      "Epoch 84/200, Train Loss: 9.9652, Val Loss: 12.4174\n",
      "Epoch 85/200, Train Loss: 9.9757, Val Loss: 12.1872\n",
      "Epoch 86/200, Train Loss: 9.8905, Val Loss: 12.5572\n",
      "Epoch 87/200, Train Loss: 9.9267, Val Loss: 12.1470\n",
      "Epoch 88/200, Train Loss: 9.8104, Val Loss: 12.2595\n",
      "Epoch 89/200, Train Loss: 9.8093, Val Loss: 12.7392\n",
      "Epoch 90/200, Train Loss: 9.8183, Val Loss: 12.4745\n",
      "Epoch 91/200, Train Loss: 9.7718, Val Loss: 12.5510\n",
      "Epoch 92/200, Train Loss: 9.7196, Val Loss: 12.5739\n",
      "Epoch 93/200, Train Loss: 9.6708, Val Loss: 12.3080\n",
      "Epoch 94/200, Train Loss: 9.6007, Val Loss: 12.4400\n",
      "Epoch 95/200, Train Loss: 9.6437, Val Loss: 12.9042\n",
      "Epoch 96/200, Train Loss: 9.6154, Val Loss: 12.2606\n",
      "Epoch 97/200, Train Loss: 9.4814, Val Loss: 12.6972\n",
      "Epoch 98/200, Train Loss: 9.4627, Val Loss: 12.3939\n",
      "Epoch 99/200, Train Loss: 9.4149, Val Loss: 12.2730\n",
      "Epoch 100/200, Train Loss: 9.3804, Val Loss: 12.5250\n",
      "Epoch 101/200, Train Loss: 9.4106, Val Loss: 12.5202\n",
      "Epoch 102/200, Train Loss: 9.3621, Val Loss: 12.4494\n",
      "Epoch 103/200, Train Loss: 9.3034, Val Loss: 12.9395\n",
      "Epoch 104/200, Train Loss: 9.2222, Val Loss: 12.5069\n",
      "Epoch 105/200, Train Loss: 9.1331, Val Loss: 12.1632\n",
      "Epoch 106/200, Train Loss: 9.1277, Val Loss: 12.7505\n",
      "Epoch 107/200, Train Loss: 9.1846, Val Loss: 12.6602\n",
      "Epoch 108/200, Train Loss: 9.1822, Val Loss: 12.7636\n",
      "Epoch 109/200, Train Loss: 9.0408, Val Loss: 12.5667\n",
      "Epoch 110/200, Train Loss: 8.9938, Val Loss: 12.7613\n",
      "Epoch 111/200, Train Loss: 9.0679, Val Loss: 12.8913\n",
      "Epoch 112/200, Train Loss: 8.9969, Val Loss: 12.8164\n",
      "Epoch 113/200, Train Loss: 8.8890, Val Loss: 12.8855\n",
      "Epoch 114/200, Train Loss: 8.8916, Val Loss: 12.6230\n",
      "Epoch 115/200, Train Loss: 8.8665, Val Loss: 12.8654\n",
      "Epoch 116/200, Train Loss: 8.7869, Val Loss: 12.5345\n",
      "Epoch 117/200, Train Loss: 8.7511, Val Loss: 12.6204\n",
      "Epoch 118/200, Train Loss: 8.7421, Val Loss: 12.5764\n",
      "Epoch 119/200, Train Loss: 8.7379, Val Loss: 12.7427\n",
      "Epoch 120/200, Train Loss: 8.7928, Val Loss: 12.7939\n",
      "Epoch 121/200, Train Loss: 8.7142, Val Loss: 12.8273\n",
      "Epoch 122/200, Train Loss: 8.6363, Val Loss: 13.2062\n",
      "Epoch 123/200, Train Loss: 8.5839, Val Loss: 13.0082\n",
      "Epoch 124/200, Train Loss: 8.6027, Val Loss: 12.9772\n",
      "Epoch 125/200, Train Loss: 8.5435, Val Loss: 13.0275\n",
      "Epoch 126/200, Train Loss: 8.5300, Val Loss: 13.2261\n",
      "Epoch 127/200, Train Loss: 8.5096, Val Loss: 12.9780\n",
      "Epoch 128/200, Train Loss: 8.4321, Val Loss: 12.7904\n",
      "Epoch 129/200, Train Loss: 8.4289, Val Loss: 13.3476\n",
      "Epoch 130/200, Train Loss: 8.4170, Val Loss: 13.0063\n",
      "Epoch 131/200, Train Loss: 8.3344, Val Loss: 12.7210\n",
      "Epoch 132/200, Train Loss: 8.3688, Val Loss: 13.1920\n",
      "Epoch 133/200, Train Loss: 8.3455, Val Loss: 13.4548\n",
      "Epoch 134/200, Train Loss: 8.2843, Val Loss: 13.1142\n",
      "Epoch 135/200, Train Loss: 8.2286, Val Loss: 13.2040\n",
      "Epoch 136/200, Train Loss: 8.2158, Val Loss: 13.2290\n",
      "Epoch 137/200, Train Loss: 8.2599, Val Loss: 13.2892\n",
      "Epoch 138/200, Train Loss: 8.1818, Val Loss: 13.2161\n",
      "Epoch 139/200, Train Loss: 8.1582, Val Loss: 13.1678\n",
      "Epoch 140/200, Train Loss: 8.1143, Val Loss: 13.4036\n",
      "Epoch 141/200, Train Loss: 8.0628, Val Loss: 12.9200\n",
      "Epoch 142/200, Train Loss: 8.0959, Val Loss: 13.4468\n",
      "Epoch 143/200, Train Loss: 8.0433, Val Loss: 13.0916\n",
      "Epoch 144/200, Train Loss: 8.0130, Val Loss: 13.5699\n",
      "Epoch 145/200, Train Loss: 7.9874, Val Loss: 13.2655\n",
      "Epoch 146/200, Train Loss: 8.0938, Val Loss: 13.2292\n",
      "Epoch 147/200, Train Loss: 7.9323, Val Loss: 13.3903\n",
      "Epoch 148/200, Train Loss: 7.9832, Val Loss: 13.3659\n",
      "Epoch 149/200, Train Loss: 7.9496, Val Loss: 13.2881\n",
      "Epoch 150/200, Train Loss: 7.8471, Val Loss: 13.5580\n",
      "Epoch 151/200, Train Loss: 7.8959, Val Loss: 13.4289\n",
      "Epoch 152/200, Train Loss: 7.8752, Val Loss: 13.5734\n",
      "Epoch 153/200, Train Loss: 7.8158, Val Loss: 13.8555\n",
      "Epoch 154/200, Train Loss: 7.7838, Val Loss: 13.7449\n",
      "Epoch 155/200, Train Loss: 7.7626, Val Loss: 13.4106\n",
      "Epoch 156/200, Train Loss: 7.7433, Val Loss: 13.5573\n",
      "Epoch 157/200, Train Loss: 7.7178, Val Loss: 13.3532\n",
      "Epoch 158/200, Train Loss: 7.7165, Val Loss: 13.5090\n",
      "Epoch 159/200, Train Loss: 7.6396, Val Loss: 13.7617\n",
      "Epoch 160/200, Train Loss: 7.6390, Val Loss: 13.7001\n",
      "Epoch 161/200, Train Loss: 7.7072, Val Loss: 13.8249\n",
      "Epoch 162/200, Train Loss: 7.6209, Val Loss: 13.4060\n",
      "Epoch 163/200, Train Loss: 7.6165, Val Loss: 13.2504\n",
      "Epoch 164/200, Train Loss: 7.5909, Val Loss: 13.7617\n",
      "Epoch 165/200, Train Loss: 7.6295, Val Loss: 13.3708\n",
      "Epoch 166/200, Train Loss: 7.5483, Val Loss: 13.7447\n",
      "Epoch 167/200, Train Loss: 7.5215, Val Loss: 13.7303\n",
      "Epoch 168/200, Train Loss: 7.4857, Val Loss: 13.2056\n",
      "Epoch 169/200, Train Loss: 7.4837, Val Loss: 13.5201\n",
      "Epoch 170/200, Train Loss: 7.4617, Val Loss: 13.9489\n",
      "Epoch 171/200, Train Loss: 7.4401, Val Loss: 13.5069\n",
      "Epoch 172/200, Train Loss: 7.4123, Val Loss: 13.5540\n",
      "Epoch 173/200, Train Loss: 7.3898, Val Loss: 13.7967\n",
      "Epoch 174/200, Train Loss: 7.3707, Val Loss: 13.6818\n",
      "Epoch 175/200, Train Loss: 7.4111, Val Loss: 13.9394\n",
      "Epoch 176/200, Train Loss: 7.3504, Val Loss: 14.1428\n",
      "Epoch 177/200, Train Loss: 7.3476, Val Loss: 13.6984\n",
      "Epoch 178/200, Train Loss: 7.3200, Val Loss: 13.6374\n",
      "Epoch 179/200, Train Loss: 7.2870, Val Loss: 13.8064\n",
      "Epoch 180/200, Train Loss: 7.2799, Val Loss: 13.7604\n",
      "Epoch 181/200, Train Loss: 7.2495, Val Loss: 14.0244\n",
      "Epoch 182/200, Train Loss: 7.1962, Val Loss: 13.9727\n",
      "Epoch 183/200, Train Loss: 7.2278, Val Loss: 14.0177\n",
      "Epoch 184/200, Train Loss: 7.1786, Val Loss: 14.0666\n",
      "Epoch 185/200, Train Loss: 7.1299, Val Loss: 13.6482\n",
      "Epoch 186/200, Train Loss: 7.1384, Val Loss: 14.1617\n",
      "Epoch 187/200, Train Loss: 7.1490, Val Loss: 13.6547\n",
      "Epoch 188/200, Train Loss: 7.0822, Val Loss: 13.9787\n",
      "Epoch 189/200, Train Loss: 7.0900, Val Loss: 14.4056\n",
      "Epoch 190/200, Train Loss: 7.0749, Val Loss: 14.0758\n",
      "Epoch 191/200, Train Loss: 7.0801, Val Loss: 14.3061\n",
      "Epoch 192/200, Train Loss: 7.0521, Val Loss: 13.8028\n",
      "Epoch 193/200, Train Loss: 7.0002, Val Loss: 14.1452\n",
      "Epoch 194/200, Train Loss: 7.0310, Val Loss: 13.7949\n",
      "Epoch 195/200, Train Loss: 6.9843, Val Loss: 14.3583\n",
      "Epoch 196/200, Train Loss: 6.9888, Val Loss: 13.8916\n",
      "Epoch 197/200, Train Loss: 6.9352, Val Loss: 14.3168\n",
      "Epoch 198/200, Train Loss: 6.9615, Val Loss: 14.2385\n",
      "Epoch 199/200, Train Loss: 6.9649, Val Loss: 14.1072\n",
      "Epoch 200/200, Train Loss: 6.9877, Val Loss: 14.1940\n",
      "\n",
      "Loaded best model (Val Loss: 11.9003) for final hidden state extraction.\n",
      "Saved best model for NMRNN_Spatial_ModReadout (samples=1600) to results_data_size_sweep/20250514_045146/samples_1600/NMRNN_Spatial_ModReadout_samples_1600_best.pt\n",
      "\n",
      "--- Performing Decodability Analysis for NMRNN_Spatial_ModReadout (samples=1600, k=15) ---\n",
      "  Analyzing decodability for NMRNN_Spatial_ModReadout...\n",
      "  Hidden states shape: torch.Size([160, 200, 128])\n",
      "  Coefficients shape: torch.Size([160, 15])\n",
      "  Processed hidden states shape for decoder: torch.Size([160, 128])\n",
      "  RidgeCV Decoder for NMRNN_Spatial_ModReadout - Test MSE: 1.3574, Test R2: 0.3160 (best alpha: 100.0000)\n",
      "  Decodability plot saved to results_data_size_sweep/20250514_045146/samples_1600/decodability_NMRNN_Spatial_ModReadout_coeff1.png\n",
      "Decodability (R2 score) for NMRNN_Spatial_ModReadout (samples=1600): 0.3160\n",
      "\n",
      "--- Training NMRNN_NoSpatial_ModReadout (samples=1600, k=15) ---\n",
      "Number of parameters: 66832\n",
      "Epoch 1/200, Train Loss: 16.7797, Val Loss: 15.7372\n",
      "  New best validation loss: 15.7372\n",
      "Epoch 2/200, Train Loss: 16.6115, Val Loss: 15.7672\n",
      "Epoch 3/200, Train Loss: 16.5561, Val Loss: 15.8172\n",
      "Epoch 4/200, Train Loss: 16.5162, Val Loss: 15.6987\n",
      "  New best validation loss: 15.6987\n",
      "Epoch 5/200, Train Loss: 16.4744, Val Loss: 15.7219\n",
      "Epoch 6/200, Train Loss: 16.4496, Val Loss: 15.6456\n",
      "  New best validation loss: 15.6456\n",
      "Epoch 7/200, Train Loss: 16.4609, Val Loss: 15.7302\n",
      "Epoch 8/200, Train Loss: 16.4101, Val Loss: 15.6528\n",
      "Epoch 9/200, Train Loss: 16.3153, Val Loss: 15.3852\n",
      "  New best validation loss: 15.3852\n",
      "Epoch 10/200, Train Loss: 16.2286, Val Loss: 15.4080\n",
      "Epoch 11/200, Train Loss: 16.1987, Val Loss: 15.3746\n",
      "  New best validation loss: 15.3746\n",
      "Epoch 12/200, Train Loss: 16.0709, Val Loss: 14.9213\n",
      "  New best validation loss: 14.9213\n",
      "Epoch 13/200, Train Loss: 15.8708, Val Loss: 14.9161\n",
      "  New best validation loss: 14.9161\n",
      "Epoch 14/200, Train Loss: 15.6716, Val Loss: 14.9578\n",
      "Epoch 15/200, Train Loss: 15.4802, Val Loss: 14.6385\n",
      "  New best validation loss: 14.6385\n",
      "Epoch 16/200, Train Loss: 15.3159, Val Loss: 14.7557\n",
      "Epoch 17/200, Train Loss: 15.1190, Val Loss: 14.4152\n",
      "  New best validation loss: 14.4152\n",
      "Epoch 18/200, Train Loss: 15.0264, Val Loss: 14.5178\n",
      "Epoch 19/200, Train Loss: 14.9169, Val Loss: 14.1176\n",
      "  New best validation loss: 14.1176\n",
      "Epoch 20/200, Train Loss: 14.6112, Val Loss: 13.8692\n",
      "  New best validation loss: 13.8692\n",
      "Epoch 21/200, Train Loss: 14.3473, Val Loss: 13.6996\n",
      "  New best validation loss: 13.6996\n",
      "Epoch 22/200, Train Loss: 14.1319, Val Loss: 13.8125\n",
      "Epoch 23/200, Train Loss: 13.9816, Val Loss: 13.2198\n",
      "  New best validation loss: 13.2198\n",
      "Epoch 24/200, Train Loss: 13.7793, Val Loss: 13.2974\n",
      "Epoch 25/200, Train Loss: 13.6635, Val Loss: 12.9836\n",
      "  New best validation loss: 12.9836\n",
      "Epoch 26/200, Train Loss: 13.4931, Val Loss: 12.8532\n",
      "  New best validation loss: 12.8532\n",
      "Epoch 27/200, Train Loss: 13.2465, Val Loss: 12.8030\n",
      "  New best validation loss: 12.8030\n",
      "Epoch 28/200, Train Loss: 13.1828, Val Loss: 13.0945\n",
      "Epoch 29/200, Train Loss: 13.0022, Val Loss: 12.7218\n",
      "  New best validation loss: 12.7218\n",
      "Epoch 30/200, Train Loss: 12.8882, Val Loss: 12.4982\n",
      "  New best validation loss: 12.4982\n",
      "Epoch 31/200, Train Loss: 12.9141, Val Loss: 12.4125\n",
      "  New best validation loss: 12.4125\n",
      "Epoch 32/200, Train Loss: 12.6779, Val Loss: 12.4435\n",
      "Epoch 33/200, Train Loss: 12.5665, Val Loss: 12.1215\n",
      "  New best validation loss: 12.1215\n",
      "Epoch 34/200, Train Loss: 12.3302, Val Loss: 12.1087\n",
      "  New best validation loss: 12.1087\n",
      "Epoch 35/200, Train Loss: 12.4681, Val Loss: 12.7145\n",
      "Epoch 36/200, Train Loss: 12.3908, Val Loss: 11.7565\n",
      "  New best validation loss: 11.7565\n",
      "Epoch 37/200, Train Loss: 12.2021, Val Loss: 11.9012\n",
      "Epoch 38/200, Train Loss: 12.1936, Val Loss: 11.8258\n",
      "Epoch 39/200, Train Loss: 12.0130, Val Loss: 11.7085\n",
      "  New best validation loss: 11.7085\n",
      "Epoch 40/200, Train Loss: 11.9347, Val Loss: 12.0541\n",
      "Epoch 41/200, Train Loss: 11.8259, Val Loss: 11.8522\n",
      "Epoch 42/200, Train Loss: 11.8734, Val Loss: 11.4624\n",
      "  New best validation loss: 11.4624\n",
      "Epoch 43/200, Train Loss: 11.7960, Val Loss: 11.6256\n",
      "Epoch 44/200, Train Loss: 11.5970, Val Loss: 11.4249\n",
      "  New best validation loss: 11.4249\n",
      "Epoch 45/200, Train Loss: 11.5245, Val Loss: 12.2042\n",
      "Epoch 46/200, Train Loss: 11.6144, Val Loss: 11.4799\n",
      "Epoch 47/200, Train Loss: 11.5127, Val Loss: 11.5386\n",
      "Epoch 48/200, Train Loss: 11.3450, Val Loss: 11.7279\n",
      "Epoch 49/200, Train Loss: 11.3593, Val Loss: 11.3920\n",
      "  New best validation loss: 11.3920\n",
      "Epoch 50/200, Train Loss: 11.2817, Val Loss: 11.3400\n",
      "  New best validation loss: 11.3400\n",
      "Epoch 51/200, Train Loss: 11.2417, Val Loss: 11.3773\n",
      "Epoch 52/200, Train Loss: 11.2416, Val Loss: 11.6344\n",
      "Epoch 53/200, Train Loss: 11.0747, Val Loss: 11.1975\n",
      "  New best validation loss: 11.1975\n",
      "Epoch 54/200, Train Loss: 11.0493, Val Loss: 11.1443\n",
      "  New best validation loss: 11.1443\n",
      "Epoch 55/200, Train Loss: 11.0492, Val Loss: 11.3933\n",
      "Epoch 56/200, Train Loss: 10.9857, Val Loss: 11.1984\n",
      "Epoch 57/200, Train Loss: 10.8908, Val Loss: 11.7801\n",
      "Epoch 58/200, Train Loss: 10.8956, Val Loss: 11.3258\n",
      "Epoch 59/200, Train Loss: 10.8812, Val Loss: 11.2604\n",
      "Epoch 60/200, Train Loss: 10.8022, Val Loss: 11.0980\n",
      "  New best validation loss: 11.0980\n",
      "Epoch 61/200, Train Loss: 10.7230, Val Loss: 11.3303\n",
      "Epoch 62/200, Train Loss: 10.6498, Val Loss: 11.3485\n",
      "Epoch 63/200, Train Loss: 10.6469, Val Loss: 11.2446\n",
      "Epoch 64/200, Train Loss: 10.6292, Val Loss: 11.2084\n",
      "Epoch 65/200, Train Loss: 10.5646, Val Loss: 11.3332\n",
      "Epoch 66/200, Train Loss: 10.4928, Val Loss: 11.0306\n",
      "  New best validation loss: 11.0306\n",
      "Epoch 67/200, Train Loss: 10.6414, Val Loss: 11.4350\n",
      "Epoch 68/200, Train Loss: 10.5302, Val Loss: 11.2349\n",
      "Epoch 69/200, Train Loss: 10.3858, Val Loss: 11.0900\n",
      "Epoch 70/200, Train Loss: 10.3834, Val Loss: 11.1401\n",
      "Epoch 71/200, Train Loss: 10.3063, Val Loss: 11.0846\n",
      "Epoch 72/200, Train Loss: 10.2965, Val Loss: 11.2521\n",
      "Epoch 73/200, Train Loss: 10.2612, Val Loss: 11.2966\n",
      "Epoch 74/200, Train Loss: 10.2798, Val Loss: 11.3429\n",
      "Epoch 75/200, Train Loss: 10.1942, Val Loss: 11.0281\n",
      "  New best validation loss: 11.0281\n",
      "Epoch 76/200, Train Loss: 10.1168, Val Loss: 11.1608\n",
      "Epoch 77/200, Train Loss: 10.0437, Val Loss: 11.3623\n",
      "Epoch 78/200, Train Loss: 10.0762, Val Loss: 11.3027\n",
      "Epoch 79/200, Train Loss: 10.1854, Val Loss: 11.7192\n",
      "Epoch 80/200, Train Loss: 10.0537, Val Loss: 11.1381\n",
      "Epoch 81/200, Train Loss: 10.0178, Val Loss: 11.1265\n",
      "Epoch 82/200, Train Loss: 9.9527, Val Loss: 11.3673\n",
      "Epoch 83/200, Train Loss: 9.9276, Val Loss: 11.0581\n",
      "Epoch 84/200, Train Loss: 9.8514, Val Loss: 11.2886\n",
      "Epoch 85/200, Train Loss: 9.8385, Val Loss: 11.2967\n",
      "Epoch 86/200, Train Loss: 9.8508, Val Loss: 11.3815\n",
      "Epoch 87/200, Train Loss: 9.7748, Val Loss: 11.3435\n",
      "Epoch 88/200, Train Loss: 9.7321, Val Loss: 11.2068\n",
      "Epoch 89/200, Train Loss: 9.7373, Val Loss: 11.1891\n",
      "Epoch 90/200, Train Loss: 9.6836, Val Loss: 11.0306\n",
      "Epoch 91/200, Train Loss: 9.7403, Val Loss: 11.5786\n",
      "Epoch 92/200, Train Loss: 9.6460, Val Loss: 11.5977\n",
      "Epoch 93/200, Train Loss: 9.6907, Val Loss: 11.4389\n",
      "Epoch 94/200, Train Loss: 9.6259, Val Loss: 11.4258\n",
      "Epoch 95/200, Train Loss: 9.6143, Val Loss: 11.2343\n",
      "Epoch 96/200, Train Loss: 9.6355, Val Loss: 11.7645\n",
      "Epoch 97/200, Train Loss: 9.4985, Val Loss: 11.3838\n",
      "Epoch 98/200, Train Loss: 9.4699, Val Loss: 11.3691\n",
      "Epoch 99/200, Train Loss: 9.4695, Val Loss: 11.4857\n",
      "Epoch 100/200, Train Loss: 9.4133, Val Loss: 11.5269\n",
      "Epoch 101/200, Train Loss: 9.4362, Val Loss: 11.3309\n",
      "Epoch 102/200, Train Loss: 9.3720, Val Loss: 11.5208\n",
      "Epoch 103/200, Train Loss: 9.2818, Val Loss: 11.3651\n",
      "Epoch 104/200, Train Loss: 9.3442, Val Loss: 11.2461\n",
      "Epoch 105/200, Train Loss: 9.2691, Val Loss: 11.4185\n",
      "Epoch 106/200, Train Loss: 9.2727, Val Loss: 11.3244\n",
      "Epoch 107/200, Train Loss: 9.2601, Val Loss: 11.4303\n",
      "Epoch 108/200, Train Loss: 9.2213, Val Loss: 11.2923\n",
      "Epoch 109/200, Train Loss: 9.2277, Val Loss: 11.7210\n",
      "Epoch 110/200, Train Loss: 9.2212, Val Loss: 11.8093\n",
      "Epoch 111/200, Train Loss: 9.0973, Val Loss: 11.8340\n",
      "Epoch 112/200, Train Loss: 9.1168, Val Loss: 11.5097\n",
      "Epoch 113/200, Train Loss: 9.0790, Val Loss: 11.2620\n",
      "Epoch 114/200, Train Loss: 9.0225, Val Loss: 11.7992\n",
      "Epoch 115/200, Train Loss: 9.0443, Val Loss: 11.5680\n",
      "Epoch 116/200, Train Loss: 9.0115, Val Loss: 11.5147\n",
      "Epoch 117/200, Train Loss: 8.9650, Val Loss: 11.8674\n",
      "Epoch 118/200, Train Loss: 9.0405, Val Loss: 11.8327\n",
      "Epoch 119/200, Train Loss: 8.9084, Val Loss: 11.5383\n",
      "Epoch 120/200, Train Loss: 8.9367, Val Loss: 11.7413\n",
      "Epoch 121/200, Train Loss: 8.8607, Val Loss: 11.7654\n",
      "Epoch 122/200, Train Loss: 8.9258, Val Loss: 11.7201\n",
      "Epoch 123/200, Train Loss: 8.9212, Val Loss: 11.9440\n",
      "Epoch 124/200, Train Loss: 8.8204, Val Loss: 11.6796\n",
      "Epoch 125/200, Train Loss: 8.7976, Val Loss: 11.5137\n",
      "Epoch 126/200, Train Loss: 8.7711, Val Loss: 11.7213\n",
      "Epoch 127/200, Train Loss: 8.7296, Val Loss: 11.6578\n",
      "Epoch 128/200, Train Loss: 8.7527, Val Loss: 11.8085\n",
      "Epoch 129/200, Train Loss: 8.6957, Val Loss: 11.9710\n",
      "Epoch 130/200, Train Loss: 8.7008, Val Loss: 11.6309\n",
      "Epoch 131/200, Train Loss: 8.6355, Val Loss: 11.8742\n",
      "Epoch 132/200, Train Loss: 8.6610, Val Loss: 11.8842\n",
      "Epoch 133/200, Train Loss: 8.6627, Val Loss: 11.9794\n",
      "Epoch 134/200, Train Loss: 8.5640, Val Loss: 11.7278\n",
      "Epoch 135/200, Train Loss: 8.5822, Val Loss: 11.8790\n",
      "Epoch 136/200, Train Loss: 8.5530, Val Loss: 12.1438\n",
      "Epoch 137/200, Train Loss: 8.5300, Val Loss: 12.0678\n",
      "Epoch 138/200, Train Loss: 8.5174, Val Loss: 11.8533\n",
      "Epoch 139/200, Train Loss: 8.4620, Val Loss: 11.9793\n",
      "Epoch 140/200, Train Loss: 8.4805, Val Loss: 12.2940\n",
      "Epoch 141/200, Train Loss: 8.4117, Val Loss: 12.2968\n",
      "Epoch 142/200, Train Loss: 8.4263, Val Loss: 12.4145\n",
      "Epoch 143/200, Train Loss: 8.3894, Val Loss: 12.0545\n",
      "Epoch 144/200, Train Loss: 8.3390, Val Loss: 12.3719\n",
      "Epoch 145/200, Train Loss: 8.3209, Val Loss: 12.1369\n",
      "Epoch 146/200, Train Loss: 8.2888, Val Loss: 12.1654\n",
      "Epoch 147/200, Train Loss: 8.3199, Val Loss: 11.8891\n",
      "Epoch 148/200, Train Loss: 8.2360, Val Loss: 12.1753\n",
      "Epoch 149/200, Train Loss: 8.2685, Val Loss: 11.8879\n",
      "Epoch 150/200, Train Loss: 8.2549, Val Loss: 12.0322\n",
      "Epoch 151/200, Train Loss: 8.2055, Val Loss: 12.0447\n",
      "Epoch 152/200, Train Loss: 8.1708, Val Loss: 12.3356\n",
      "Epoch 153/200, Train Loss: 8.1852, Val Loss: 12.4239\n",
      "Epoch 154/200, Train Loss: 8.1593, Val Loss: 12.2794\n",
      "Epoch 155/200, Train Loss: 8.1278, Val Loss: 12.3926\n",
      "Epoch 156/200, Train Loss: 8.0920, Val Loss: 12.2266\n",
      "Epoch 157/200, Train Loss: 8.0374, Val Loss: 11.9680\n",
      "Epoch 158/200, Train Loss: 8.0126, Val Loss: 12.6835\n",
      "Epoch 159/200, Train Loss: 8.0692, Val Loss: 12.5528\n",
      "Epoch 160/200, Train Loss: 8.0128, Val Loss: 12.0531\n",
      "Epoch 161/200, Train Loss: 7.9582, Val Loss: 12.3629\n",
      "Epoch 162/200, Train Loss: 8.0207, Val Loss: 12.3782\n",
      "Epoch 163/200, Train Loss: 8.0258, Val Loss: 12.3400\n",
      "Epoch 164/200, Train Loss: 7.9733, Val Loss: 12.1977\n",
      "Epoch 165/200, Train Loss: 7.9682, Val Loss: 12.3722\n",
      "Epoch 166/200, Train Loss: 7.9307, Val Loss: 12.6995\n",
      "Epoch 167/200, Train Loss: 7.9119, Val Loss: 12.3469\n",
      "Epoch 168/200, Train Loss: 7.8447, Val Loss: 12.2619\n",
      "Epoch 169/200, Train Loss: 7.8359, Val Loss: 12.2435\n",
      "Epoch 170/200, Train Loss: 7.8164, Val Loss: 12.5229\n",
      "Epoch 171/200, Train Loss: 7.7998, Val Loss: 12.3732\n",
      "Epoch 172/200, Train Loss: 7.7998, Val Loss: 12.4028\n",
      "Epoch 173/200, Train Loss: 7.7801, Val Loss: 12.5542\n",
      "Epoch 174/200, Train Loss: 7.7923, Val Loss: 12.5604\n",
      "Epoch 175/200, Train Loss: 7.7663, Val Loss: 12.2795\n",
      "Epoch 176/200, Train Loss: 7.6857, Val Loss: 12.8489\n",
      "Epoch 177/200, Train Loss: 7.7549, Val Loss: 12.6109\n",
      "Epoch 178/200, Train Loss: 7.6794, Val Loss: 12.5145\n",
      "Epoch 179/200, Train Loss: 7.6969, Val Loss: 12.7627\n",
      "Epoch 180/200, Train Loss: 7.6497, Val Loss: 12.4268\n",
      "Epoch 181/200, Train Loss: 7.6657, Val Loss: 12.5434\n",
      "Epoch 182/200, Train Loss: 7.5788, Val Loss: 12.7035\n",
      "Epoch 183/200, Train Loss: 7.5965, Val Loss: 12.6574\n",
      "Epoch 184/200, Train Loss: 7.6089, Val Loss: 12.7318\n",
      "Epoch 185/200, Train Loss: 7.5839, Val Loss: 12.7412\n",
      "Epoch 186/200, Train Loss: 7.5075, Val Loss: 12.5289\n",
      "Epoch 187/200, Train Loss: 7.5518, Val Loss: 12.7178\n",
      "Epoch 188/200, Train Loss: 7.5118, Val Loss: 12.8194\n",
      "Epoch 189/200, Train Loss: 7.4626, Val Loss: 12.5780\n",
      "Epoch 190/200, Train Loss: 7.5037, Val Loss: 12.6882\n",
      "Epoch 191/200, Train Loss: 7.4451, Val Loss: 12.8470\n",
      "Epoch 192/200, Train Loss: 7.3911, Val Loss: 12.4509\n",
      "Epoch 193/200, Train Loss: 7.4483, Val Loss: 12.6690\n",
      "Epoch 194/200, Train Loss: 7.4338, Val Loss: 12.4880\n",
      "Epoch 195/200, Train Loss: 7.3363, Val Loss: 12.9837\n",
      "Epoch 196/200, Train Loss: 7.4304, Val Loss: 12.8906\n",
      "Epoch 197/200, Train Loss: 7.4653, Val Loss: 12.7338\n",
      "Epoch 198/200, Train Loss: 7.3061, Val Loss: 12.9714\n",
      "Epoch 199/200, Train Loss: 7.3125, Val Loss: 12.8702\n",
      "Epoch 200/200, Train Loss: 7.3446, Val Loss: 12.7454\n",
      "\n",
      "Loaded best model (Val Loss: 11.0281) for final hidden state extraction.\n",
      "Saved best model for NMRNN_NoSpatial_ModReadout (samples=1600) to results_data_size_sweep/20250514_045146/samples_1600/NMRNN_NoSpatial_ModReadout_samples_1600_best.pt\n",
      "\n",
      "--- Performing Decodability Analysis for NMRNN_NoSpatial_ModReadout (samples=1600, k=15) ---\n",
      "  Analyzing decodability for NMRNN_NoSpatial_ModReadout...\n",
      "  Hidden states shape: torch.Size([160, 200, 128])\n",
      "  Coefficients shape: torch.Size([160, 15])\n",
      "  Processed hidden states shape for decoder: torch.Size([160, 128])\n",
      "  RidgeCV Decoder for NMRNN_NoSpatial_ModReadout - Test MSE: 1.2623, Test R2: 0.3654 (best alpha: 100.0000)\n",
      "  Decodability plot saved to results_data_size_sweep/20250514_045146/samples_1600/decodability_NMRNN_NoSpatial_ModReadout_coeff1.png\n",
      "Decodability (R2 score) for NMRNN_NoSpatial_ModReadout (samples=1600): 0.3654\n",
      "\n",
      "--- Training NMRNN_Spatial_FixedReadout (samples=1600, k=15) ---\n",
      "Number of parameters: 66449\n",
      "Epoch 1/200, Train Loss: 16.8649, Val Loss: 15.7548\n",
      "  New best validation loss: 15.7548\n",
      "Epoch 2/200, Train Loss: 16.6130, Val Loss: 15.7819\n",
      "Epoch 3/200, Train Loss: 16.5485, Val Loss: 15.7568\n",
      "Epoch 4/200, Train Loss: 16.5110, Val Loss: 15.7019\n",
      "  New best validation loss: 15.7019\n",
      "Epoch 5/200, Train Loss: 16.4540, Val Loss: 15.7500\n",
      "Epoch 6/200, Train Loss: 16.4609, Val Loss: 15.6908\n",
      "  New best validation loss: 15.6908\n",
      "Epoch 7/200, Train Loss: 16.3830, Val Loss: 15.6440\n",
      "  New best validation loss: 15.6440\n",
      "Epoch 8/200, Train Loss: 16.3024, Val Loss: 15.4572\n",
      "  New best validation loss: 15.4572\n",
      "Epoch 9/200, Train Loss: 16.1661, Val Loss: 15.3623\n",
      "  New best validation loss: 15.3623\n",
      "Epoch 10/200, Train Loss: 16.0095, Val Loss: 15.2391\n",
      "  New best validation loss: 15.2391\n",
      "Epoch 11/200, Train Loss: 15.8335, Val Loss: 15.2871\n",
      "Epoch 12/200, Train Loss: 15.6540, Val Loss: 14.8782\n",
      "  New best validation loss: 14.8782\n",
      "Epoch 13/200, Train Loss: 15.4891, Val Loss: 14.6458\n",
      "  New best validation loss: 14.6458\n",
      "Epoch 14/200, Train Loss: 15.1951, Val Loss: 14.2959\n",
      "  New best validation loss: 14.2959\n",
      "Epoch 15/200, Train Loss: 14.8542, Val Loss: 14.2317\n",
      "  New best validation loss: 14.2317\n",
      "Epoch 16/200, Train Loss: 14.5517, Val Loss: 13.8555\n",
      "  New best validation loss: 13.8555\n",
      "Epoch 17/200, Train Loss: 14.1775, Val Loss: 13.3417\n",
      "  New best validation loss: 13.3417\n",
      "Epoch 18/200, Train Loss: 13.9291, Val Loss: 13.2923\n",
      "  New best validation loss: 13.2923\n",
      "Epoch 19/200, Train Loss: 13.6372, Val Loss: 12.9014\n",
      "  New best validation loss: 12.9014\n",
      "Epoch 20/200, Train Loss: 13.3800, Val Loss: 12.6467\n",
      "  New best validation loss: 12.6467\n",
      "Epoch 21/200, Train Loss: 13.2312, Val Loss: 13.3882\n",
      "Epoch 22/200, Train Loss: 13.1609, Val Loss: 12.4837\n",
      "  New best validation loss: 12.4837\n",
      "Epoch 23/200, Train Loss: 12.9243, Val Loss: 12.5126\n",
      "Epoch 24/200, Train Loss: 12.8025, Val Loss: 12.0603\n",
      "  New best validation loss: 12.0603\n",
      "Epoch 25/200, Train Loss: 12.7140, Val Loss: 12.3206\n",
      "Epoch 26/200, Train Loss: 12.5644, Val Loss: 11.9657\n",
      "  New best validation loss: 11.9657\n",
      "Epoch 27/200, Train Loss: 12.4054, Val Loss: 12.3282\n",
      "Epoch 28/200, Train Loss: 12.3721, Val Loss: 11.7529\n",
      "  New best validation loss: 11.7529\n",
      "Epoch 29/200, Train Loss: 12.2470, Val Loss: 11.7229\n",
      "  New best validation loss: 11.7229\n",
      "Epoch 30/200, Train Loss: 12.1592, Val Loss: 11.6798\n",
      "  New best validation loss: 11.6798\n",
      "Epoch 31/200, Train Loss: 12.0323, Val Loss: 11.5904\n",
      "  New best validation loss: 11.5904\n",
      "Epoch 32/200, Train Loss: 11.9109, Val Loss: 12.0882\n",
      "Epoch 33/200, Train Loss: 11.9259, Val Loss: 11.5102\n",
      "  New best validation loss: 11.5102\n",
      "Epoch 34/200, Train Loss: 11.8932, Val Loss: 11.6739\n",
      "Epoch 35/200, Train Loss: 11.7166, Val Loss: 11.4429\n",
      "  New best validation loss: 11.4429\n",
      "Epoch 36/200, Train Loss: 11.7419, Val Loss: 11.4389\n",
      "  New best validation loss: 11.4389\n",
      "Epoch 37/200, Train Loss: 11.5685, Val Loss: 11.4763\n",
      "Epoch 38/200, Train Loss: 11.5901, Val Loss: 11.5885\n",
      "Epoch 39/200, Train Loss: 11.4778, Val Loss: 11.1436\n",
      "  New best validation loss: 11.1436\n",
      "Epoch 40/200, Train Loss: 11.3487, Val Loss: 11.5925\n",
      "Epoch 41/200, Train Loss: 11.2730, Val Loss: 11.3055\n",
      "Epoch 42/200, Train Loss: 11.2309, Val Loss: 11.5332\n",
      "Epoch 43/200, Train Loss: 11.2180, Val Loss: 11.2742\n",
      "Epoch 44/200, Train Loss: 11.1744, Val Loss: 11.2010\n",
      "Epoch 45/200, Train Loss: 11.1720, Val Loss: 11.1647\n",
      "Epoch 46/200, Train Loss: 11.0144, Val Loss: 11.3370\n",
      "Epoch 47/200, Train Loss: 10.9746, Val Loss: 11.4243\n",
      "Epoch 48/200, Train Loss: 10.8879, Val Loss: 11.2991\n",
      "Epoch 49/200, Train Loss: 10.8581, Val Loss: 11.1066\n",
      "  New best validation loss: 11.1066\n",
      "Epoch 50/200, Train Loss: 10.7999, Val Loss: 11.2383\n",
      "Epoch 51/200, Train Loss: 10.9063, Val Loss: 11.2888\n",
      "Epoch 52/200, Train Loss: 10.7516, Val Loss: 10.9169\n",
      "  New best validation loss: 10.9169\n",
      "Epoch 53/200, Train Loss: 10.6948, Val Loss: 11.2139\n",
      "Epoch 54/200, Train Loss: 10.7969, Val Loss: 11.0002\n",
      "Epoch 55/200, Train Loss: 10.5387, Val Loss: 11.2888\n",
      "Epoch 56/200, Train Loss: 10.6228, Val Loss: 11.0802\n",
      "Epoch 57/200, Train Loss: 10.5788, Val Loss: 11.2604\n",
      "Epoch 58/200, Train Loss: 10.4707, Val Loss: 11.2135\n",
      "Epoch 59/200, Train Loss: 10.4599, Val Loss: 11.0217\n",
      "Epoch 60/200, Train Loss: 10.4094, Val Loss: 11.4548\n",
      "Epoch 61/200, Train Loss: 10.3755, Val Loss: 10.8827\n",
      "  New best validation loss: 10.8827\n",
      "Epoch 62/200, Train Loss: 10.2983, Val Loss: 11.0254\n",
      "Epoch 63/200, Train Loss: 10.3061, Val Loss: 11.2517\n",
      "Epoch 64/200, Train Loss: 10.3645, Val Loss: 11.0533\n",
      "Epoch 65/200, Train Loss: 10.3001, Val Loss: 11.1123\n",
      "Epoch 66/200, Train Loss: 10.1940, Val Loss: 11.3842\n",
      "Epoch 67/200, Train Loss: 10.2053, Val Loss: 11.7825\n",
      "Epoch 68/200, Train Loss: 10.1229, Val Loss: 11.4529\n",
      "Epoch 69/200, Train Loss: 10.1750, Val Loss: 11.0556\n",
      "Epoch 70/200, Train Loss: 10.0581, Val Loss: 11.5568\n",
      "Epoch 71/200, Train Loss: 9.9781, Val Loss: 11.2215\n",
      "Epoch 72/200, Train Loss: 9.9910, Val Loss: 11.1435\n",
      "Epoch 73/200, Train Loss: 9.9836, Val Loss: 11.4000\n",
      "Epoch 74/200, Train Loss: 9.9213, Val Loss: 11.4295\n",
      "Epoch 75/200, Train Loss: 9.8869, Val Loss: 10.9705\n",
      "Epoch 76/200, Train Loss: 9.8780, Val Loss: 11.4528\n",
      "Epoch 77/200, Train Loss: 9.8523, Val Loss: 11.5384\n",
      "Epoch 78/200, Train Loss: 9.8086, Val Loss: 11.5047\n",
      "Epoch 79/200, Train Loss: 9.8370, Val Loss: 11.3344\n",
      "Epoch 80/200, Train Loss: 9.8213, Val Loss: 11.1408\n",
      "Epoch 81/200, Train Loss: 9.8230, Val Loss: 11.2649\n",
      "Epoch 82/200, Train Loss: 9.6872, Val Loss: 11.1404\n",
      "Epoch 83/200, Train Loss: 9.6086, Val Loss: 11.3196\n",
      "Epoch 84/200, Train Loss: 9.5950, Val Loss: 11.2275\n",
      "Epoch 85/200, Train Loss: 9.6254, Val Loss: 11.3413\n",
      "Epoch 86/200, Train Loss: 9.5586, Val Loss: 11.1708\n",
      "Epoch 87/200, Train Loss: 9.5318, Val Loss: 11.1853\n",
      "Epoch 88/200, Train Loss: 9.4819, Val Loss: 11.4237\n",
      "Epoch 89/200, Train Loss: 9.4994, Val Loss: 11.2117\n",
      "Epoch 90/200, Train Loss: 9.4382, Val Loss: 11.3654\n",
      "Epoch 91/200, Train Loss: 9.3799, Val Loss: 11.3957\n",
      "Epoch 92/200, Train Loss: 9.3751, Val Loss: 11.2293\n",
      "Epoch 93/200, Train Loss: 9.2762, Val Loss: 11.5562\n",
      "Epoch 94/200, Train Loss: 9.3450, Val Loss: 11.4266\n",
      "Epoch 95/200, Train Loss: 9.3208, Val Loss: 11.2524\n",
      "Epoch 96/200, Train Loss: 9.1896, Val Loss: 11.3317\n",
      "Epoch 97/200, Train Loss: 9.2549, Val Loss: 11.2908\n",
      "Epoch 98/200, Train Loss: 9.2108, Val Loss: 11.6329\n",
      "Epoch 99/200, Train Loss: 9.1597, Val Loss: 11.5679\n",
      "Epoch 100/200, Train Loss: 9.0892, Val Loss: 11.5825\n",
      "Epoch 101/200, Train Loss: 9.1701, Val Loss: 11.4702\n",
      "Epoch 102/200, Train Loss: 9.0474, Val Loss: 11.4892\n",
      "Epoch 103/200, Train Loss: 9.0493, Val Loss: 11.4491\n",
      "Epoch 104/200, Train Loss: 9.0046, Val Loss: 11.6979\n",
      "Epoch 105/200, Train Loss: 8.9481, Val Loss: 11.7029\n",
      "Epoch 106/200, Train Loss: 8.9388, Val Loss: 11.6301\n",
      "Epoch 107/200, Train Loss: 8.9149, Val Loss: 11.2686\n",
      "Epoch 108/200, Train Loss: 8.8842, Val Loss: 11.3794\n",
      "Epoch 109/200, Train Loss: 8.8446, Val Loss: 11.5735\n",
      "Epoch 110/200, Train Loss: 8.8295, Val Loss: 11.6646\n",
      "Epoch 111/200, Train Loss: 8.7721, Val Loss: 11.7215\n",
      "Epoch 112/200, Train Loss: 8.8020, Val Loss: 11.6544\n",
      "Epoch 113/200, Train Loss: 8.7623, Val Loss: 12.0243\n",
      "Epoch 114/200, Train Loss: 8.7118, Val Loss: 11.6451\n",
      "Epoch 115/200, Train Loss: 8.6759, Val Loss: 11.8799\n",
      "Epoch 116/200, Train Loss: 8.7176, Val Loss: 11.5621\n",
      "Epoch 117/200, Train Loss: 8.6696, Val Loss: 12.0650\n",
      "Epoch 118/200, Train Loss: 8.5676, Val Loss: 11.8479\n",
      "Epoch 119/200, Train Loss: 8.6526, Val Loss: 11.6589\n",
      "Epoch 120/200, Train Loss: 8.5989, Val Loss: 11.5479\n",
      "Epoch 121/200, Train Loss: 8.4651, Val Loss: 11.8167\n",
      "Epoch 122/200, Train Loss: 8.5972, Val Loss: 11.9237\n",
      "Epoch 123/200, Train Loss: 8.4681, Val Loss: 11.8959\n",
      "Epoch 124/200, Train Loss: 8.4408, Val Loss: 11.8801\n",
      "Epoch 125/200, Train Loss: 8.5109, Val Loss: 11.7382\n",
      "Epoch 126/200, Train Loss: 8.4411, Val Loss: 11.6522\n",
      "Epoch 127/200, Train Loss: 8.3864, Val Loss: 11.8985\n",
      "Epoch 128/200, Train Loss: 8.3905, Val Loss: 11.9056\n",
      "Epoch 129/200, Train Loss: 8.2718, Val Loss: 12.0998\n",
      "Epoch 130/200, Train Loss: 8.2423, Val Loss: 11.9555\n",
      "Epoch 131/200, Train Loss: 8.2571, Val Loss: 11.7147\n",
      "Epoch 132/200, Train Loss: 8.1853, Val Loss: 11.9761\n",
      "Epoch 133/200, Train Loss: 8.1400, Val Loss: 12.1075\n",
      "Epoch 134/200, Train Loss: 8.1911, Val Loss: 12.1449\n",
      "Epoch 135/200, Train Loss: 8.1343, Val Loss: 12.0602\n",
      "Epoch 136/200, Train Loss: 8.1422, Val Loss: 12.2161\n",
      "Epoch 137/200, Train Loss: 8.0816, Val Loss: 12.3804\n",
      "Epoch 138/200, Train Loss: 8.0345, Val Loss: 12.1557\n",
      "Epoch 139/200, Train Loss: 8.0821, Val Loss: 12.4145\n",
      "Epoch 140/200, Train Loss: 8.0195, Val Loss: 12.2222\n",
      "Epoch 141/200, Train Loss: 7.9592, Val Loss: 12.1341\n",
      "Epoch 142/200, Train Loss: 7.9630, Val Loss: 12.1601\n",
      "Epoch 143/200, Train Loss: 7.9245, Val Loss: 12.0082\n",
      "Epoch 144/200, Train Loss: 7.9020, Val Loss: 12.3771\n",
      "Epoch 145/200, Train Loss: 7.9178, Val Loss: 12.3874\n",
      "Epoch 146/200, Train Loss: 7.8410, Val Loss: 12.5489\n",
      "Epoch 147/200, Train Loss: 7.8824, Val Loss: 12.3323\n",
      "Epoch 148/200, Train Loss: 7.9192, Val Loss: 12.0540\n",
      "Epoch 149/200, Train Loss: 7.8458, Val Loss: 12.6169\n",
      "Epoch 150/200, Train Loss: 7.8528, Val Loss: 12.5279\n",
      "Epoch 151/200, Train Loss: 7.7568, Val Loss: 12.3834\n",
      "Epoch 152/200, Train Loss: 7.7801, Val Loss: 12.4039\n",
      "Epoch 153/200, Train Loss: 7.8492, Val Loss: 12.2917\n",
      "Epoch 154/200, Train Loss: 7.6524, Val Loss: 12.2964\n",
      "Epoch 155/200, Train Loss: 7.6157, Val Loss: 12.6220\n",
      "Epoch 156/200, Train Loss: 7.6511, Val Loss: 12.5534\n",
      "Epoch 157/200, Train Loss: 7.6498, Val Loss: 12.3535\n",
      "Epoch 158/200, Train Loss: 7.6382, Val Loss: 12.1730\n",
      "Epoch 159/200, Train Loss: 7.6533, Val Loss: 12.3159\n",
      "Epoch 160/200, Train Loss: 7.6204, Val Loss: 12.2385\n",
      "Epoch 161/200, Train Loss: 7.5303, Val Loss: 12.4887\n",
      "Epoch 162/200, Train Loss: 7.4826, Val Loss: 12.4102\n",
      "Epoch 163/200, Train Loss: 7.4995, Val Loss: 12.6681\n",
      "Epoch 164/200, Train Loss: 7.4254, Val Loss: 12.4037\n",
      "Epoch 165/200, Train Loss: 7.4380, Val Loss: 12.7925\n",
      "Epoch 166/200, Train Loss: 7.4681, Val Loss: 12.5896\n",
      "Epoch 167/200, Train Loss: 7.4113, Val Loss: 12.4907\n",
      "Epoch 168/200, Train Loss: 7.4123, Val Loss: 12.3782\n",
      "Epoch 169/200, Train Loss: 7.4253, Val Loss: 12.6466\n",
      "Epoch 170/200, Train Loss: 7.3231, Val Loss: 12.6240\n",
      "Epoch 171/200, Train Loss: 7.3850, Val Loss: 12.9571\n",
      "Epoch 172/200, Train Loss: 7.3349, Val Loss: 12.3493\n",
      "Epoch 173/200, Train Loss: 7.2939, Val Loss: 12.2551\n",
      "Epoch 174/200, Train Loss: 7.2480, Val Loss: 12.5959\n",
      "Epoch 175/200, Train Loss: 7.2371, Val Loss: 12.5210\n",
      "Epoch 176/200, Train Loss: 7.2513, Val Loss: 12.5608\n",
      "Epoch 177/200, Train Loss: 7.2127, Val Loss: 12.3182\n",
      "Epoch 178/200, Train Loss: 7.1889, Val Loss: 12.9167\n",
      "Epoch 179/200, Train Loss: 7.2420, Val Loss: 12.6262\n",
      "Epoch 180/200, Train Loss: 7.1697, Val Loss: 12.6631\n",
      "Epoch 181/200, Train Loss: 7.1475, Val Loss: 12.2908\n",
      "Epoch 182/200, Train Loss: 7.1500, Val Loss: 12.5922\n",
      "Epoch 183/200, Train Loss: 7.0889, Val Loss: 12.6948\n",
      "Epoch 184/200, Train Loss: 7.0737, Val Loss: 12.7026\n",
      "Epoch 185/200, Train Loss: 7.0578, Val Loss: 12.7078\n",
      "Epoch 186/200, Train Loss: 7.0246, Val Loss: 12.6478\n",
      "Epoch 187/200, Train Loss: 7.0414, Val Loss: 12.8975\n",
      "Epoch 188/200, Train Loss: 6.9800, Val Loss: 12.8256\n",
      "Epoch 189/200, Train Loss: 6.9837, Val Loss: 12.5929\n",
      "Epoch 190/200, Train Loss: 7.0029, Val Loss: 12.6805\n",
      "Epoch 191/200, Train Loss: 6.9916, Val Loss: 12.7714\n",
      "Epoch 192/200, Train Loss: 6.9754, Val Loss: 12.7644\n",
      "Epoch 193/200, Train Loss: 6.8976, Val Loss: 12.6198\n",
      "Epoch 194/200, Train Loss: 6.8566, Val Loss: 12.7416\n",
      "Epoch 195/200, Train Loss: 6.8961, Val Loss: 12.8665\n",
      "Epoch 196/200, Train Loss: 6.8712, Val Loss: 12.8690\n",
      "Epoch 197/200, Train Loss: 6.8266, Val Loss: 12.5396\n",
      "Epoch 198/200, Train Loss: 6.8656, Val Loss: 13.0978\n",
      "Epoch 199/200, Train Loss: 6.8728, Val Loss: 12.7008\n",
      "Epoch 200/200, Train Loss: 6.8213, Val Loss: 13.3211\n",
      "\n",
      "Loaded best model (Val Loss: 10.8827) for final hidden state extraction.\n",
      "Saved best model for NMRNN_Spatial_FixedReadout (samples=1600) to results_data_size_sweep/20250514_045146/samples_1600/NMRNN_Spatial_FixedReadout_samples_1600_best.pt\n",
      "\n",
      "--- Performing Decodability Analysis for NMRNN_Spatial_FixedReadout (samples=1600, k=15) ---\n",
      "  Analyzing decodability for NMRNN_Spatial_FixedReadout...\n",
      "  Hidden states shape: torch.Size([160, 200, 128])\n",
      "  Coefficients shape: torch.Size([160, 15])\n",
      "  Processed hidden states shape for decoder: torch.Size([160, 128])\n",
      "  RidgeCV Decoder for NMRNN_Spatial_FixedReadout - Test MSE: 1.2691, Test R2: 0.3697 (best alpha: 100.0000)\n",
      "  Decodability plot saved to results_data_size_sweep/20250514_045146/samples_1600/decodability_NMRNN_Spatial_FixedReadout_coeff1.png\n",
      "Decodability (R2 score) for NMRNN_Spatial_FixedReadout (samples=1600): 0.3697\n",
      "Learning curves saved to results_data_size_sweep/20250514_045146/samples_1600/learning_curves_validation.png\n",
      "\n",
      "Validation learning curves for samples=1600 plotted.\n",
      "Learning curves saved to results_data_size_sweep/20250514_045146/samples_1600/learning_curves_training.png\n",
      "\n",
      "Training learning curves for samples=1600 plotted.\n",
      "Decodability summary for samples=1600 saved to results_data_size_sweep/20250514_045146/samples_1600/decodability_summary.txt\n",
      "\n",
      "========================= Running for train_samples: 2400, k: 15 =========================\n",
      "Results for train_samples=2400 will be saved in: results_data_size_sweep/20250514_045146/samples_2400\n",
      "Loading dataset...\n",
      "Dataset loaded.\n",
      "Warning: Modulated readout requested but N_nm is 0. Using fixed readout.\n",
      "\n",
      "--- Training RNN_Vanillia (samples=2400, k=15) ---\n",
      "Number of parameters: 51301\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/conda/lib/python3.10/site-packages/torch/nn/init.py:405: UserWarning: Initializing zero-element tensors is a no-op\n",
      "  warnings.warn(\"Initializing zero-element tensors is a no-op\")\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/200, Train Loss: 16.8417, Val Loss: 15.7420\n",
      "  New best validation loss: 15.7420\n",
      "Epoch 2/200, Train Loss: 16.6887, Val Loss: 15.7292\n",
      "  New best validation loss: 15.7292\n",
      "Epoch 3/200, Train Loss: 16.6515, Val Loss: 15.7005\n",
      "  New best validation loss: 15.7005\n",
      "Epoch 4/200, Train Loss: 16.6408, Val Loss: 15.6664\n",
      "  New best validation loss: 15.6664\n",
      "Epoch 5/200, Train Loss: 16.6252, Val Loss: 15.7207\n",
      "Epoch 6/200, Train Loss: 16.5903, Val Loss: 15.6512\n",
      "  New best validation loss: 15.6512\n",
      "Epoch 7/200, Train Loss: 16.5826, Val Loss: 15.6839\n",
      "Epoch 8/200, Train Loss: 16.5508, Val Loss: 15.6497\n",
      "  New best validation loss: 15.6497\n",
      "Epoch 9/200, Train Loss: 16.5284, Val Loss: 15.6832\n",
      "Epoch 10/200, Train Loss: 16.5084, Val Loss: 15.6766\n",
      "Epoch 11/200, Train Loss: 16.4992, Val Loss: 15.6875\n",
      "Epoch 12/200, Train Loss: 16.4892, Val Loss: 15.6803\n",
      "Epoch 13/200, Train Loss: 16.4803, Val Loss: 15.6789\n",
      "Epoch 14/200, Train Loss: 16.4763, Val Loss: 15.6851\n",
      "Epoch 15/200, Train Loss: 16.4595, Val Loss: 15.7250\n",
      "Epoch 16/200, Train Loss: 16.4584, Val Loss: 15.6301\n",
      "  New best validation loss: 15.6301\n",
      "Epoch 17/200, Train Loss: 16.4406, Val Loss: 15.6490\n",
      "Epoch 18/200, Train Loss: 16.4308, Val Loss: 15.5846\n",
      "  New best validation loss: 15.5846\n",
      "Epoch 19/200, Train Loss: 16.4159, Val Loss: 15.5559\n",
      "  New best validation loss: 15.5559\n",
      "Epoch 20/200, Train Loss: 16.4106, Val Loss: 15.5875\n",
      "Epoch 21/200, Train Loss: 16.3939, Val Loss: 15.5985\n",
      "Epoch 22/200, Train Loss: 16.3840, Val Loss: 15.5475\n",
      "  New best validation loss: 15.5475\n",
      "Epoch 23/200, Train Loss: 16.3650, Val Loss: 15.5217\n",
      "  New best validation loss: 15.5217\n",
      "Epoch 24/200, Train Loss: 16.3513, Val Loss: 15.4603\n",
      "  New best validation loss: 15.4603\n",
      "Epoch 25/200, Train Loss: 16.3471, Val Loss: 15.4613\n",
      "Epoch 26/200, Train Loss: 16.3258, Val Loss: 15.4629\n",
      "Epoch 27/200, Train Loss: 16.3149, Val Loss: 15.4566\n",
      "  New best validation loss: 15.4566\n",
      "Epoch 28/200, Train Loss: 16.2977, Val Loss: 15.4952\n",
      "Epoch 29/200, Train Loss: 16.2824, Val Loss: 15.4232\n",
      "  New best validation loss: 15.4232\n",
      "Epoch 30/200, Train Loss: 16.2578, Val Loss: 15.2749\n",
      "  New best validation loss: 15.2749\n",
      "Epoch 31/200, Train Loss: 16.2192, Val Loss: 15.2444\n",
      "  New best validation loss: 15.2444\n",
      "Epoch 32/200, Train Loss: 16.1614, Val Loss: 15.1499\n",
      "  New best validation loss: 15.1499\n",
      "Epoch 33/200, Train Loss: 16.0996, Val Loss: 15.0990\n",
      "  New best validation loss: 15.0990\n",
      "Epoch 34/200, Train Loss: 16.0095, Val Loss: 14.8744\n",
      "  New best validation loss: 14.8744\n",
      "Epoch 35/200, Train Loss: 15.9033, Val Loss: 14.7625\n",
      "  New best validation loss: 14.7625\n",
      "Epoch 36/200, Train Loss: 15.8023, Val Loss: 14.7171\n",
      "  New best validation loss: 14.7171\n",
      "Epoch 37/200, Train Loss: 15.7031, Val Loss: 14.5133\n",
      "  New best validation loss: 14.5133\n",
      "Epoch 38/200, Train Loss: 15.6398, Val Loss: 14.6152\n",
      "Epoch 39/200, Train Loss: 15.5016, Val Loss: 14.3013\n",
      "  New best validation loss: 14.3013\n",
      "Epoch 40/200, Train Loss: 15.3876, Val Loss: 14.1954\n",
      "  New best validation loss: 14.1954\n",
      "Epoch 41/200, Train Loss: 15.2707, Val Loss: 14.2049\n",
      "Epoch 42/200, Train Loss: 15.1589, Val Loss: 14.1314\n",
      "  New best validation loss: 14.1314\n",
      "Epoch 43/200, Train Loss: 14.9898, Val Loss: 14.0003\n",
      "  New best validation loss: 14.0003\n",
      "Epoch 44/200, Train Loss: 14.8885, Val Loss: 13.7437\n",
      "  New best validation loss: 13.7437\n",
      "Epoch 45/200, Train Loss: 14.7430, Val Loss: 13.9604\n",
      "Epoch 46/200, Train Loss: 14.6541, Val Loss: 13.9434\n",
      "Epoch 47/200, Train Loss: 14.5449, Val Loss: 13.6401\n",
      "  New best validation loss: 13.6401\n",
      "Epoch 48/200, Train Loss: 14.4612, Val Loss: 13.5142\n",
      "  New best validation loss: 13.5142\n",
      "Epoch 49/200, Train Loss: 14.3941, Val Loss: 13.5513\n",
      "Epoch 50/200, Train Loss: 14.3160, Val Loss: 13.4311\n",
      "  New best validation loss: 13.4311\n",
      "Epoch 51/200, Train Loss: 14.2073, Val Loss: 13.4482\n",
      "Epoch 52/200, Train Loss: 14.1690, Val Loss: 13.3174\n",
      "  New best validation loss: 13.3174\n",
      "Epoch 53/200, Train Loss: 14.0954, Val Loss: 13.1982\n",
      "  New best validation loss: 13.1982\n",
      "Epoch 54/200, Train Loss: 14.0209, Val Loss: 13.2063\n",
      "Epoch 55/200, Train Loss: 13.9954, Val Loss: 13.3220\n",
      "Epoch 56/200, Train Loss: 13.9215, Val Loss: 13.0450\n",
      "  New best validation loss: 13.0450\n",
      "Epoch 57/200, Train Loss: 13.8643, Val Loss: 13.0903\n",
      "Epoch 58/200, Train Loss: 13.7676, Val Loss: 12.9412\n",
      "  New best validation loss: 12.9412\n",
      "Epoch 59/200, Train Loss: 13.7346, Val Loss: 12.9135\n",
      "  New best validation loss: 12.9135\n",
      "Epoch 60/200, Train Loss: 13.6879, Val Loss: 12.9111\n",
      "  New best validation loss: 12.9111\n",
      "Epoch 61/200, Train Loss: 13.6091, Val Loss: 12.7899\n",
      "  New best validation loss: 12.7899\n",
      "Epoch 62/200, Train Loss: 13.5675, Val Loss: 12.7824\n",
      "  New best validation loss: 12.7824\n",
      "Epoch 63/200, Train Loss: 13.5022, Val Loss: 12.7802\n",
      "  New best validation loss: 12.7802\n",
      "Epoch 64/200, Train Loss: 13.4773, Val Loss: 12.7815\n",
      "Epoch 65/200, Train Loss: 13.4077, Val Loss: 12.8097\n",
      "Epoch 66/200, Train Loss: 13.3925, Val Loss: 12.8681\n",
      "Epoch 67/200, Train Loss: 13.3384, Val Loss: 12.4865\n",
      "  New best validation loss: 12.4865\n",
      "Epoch 68/200, Train Loss: 13.3000, Val Loss: 12.7273\n",
      "Epoch 69/200, Train Loss: 13.2376, Val Loss: 12.4293\n",
      "  New best validation loss: 12.4293\n",
      "Epoch 70/200, Train Loss: 13.2110, Val Loss: 12.5760\n",
      "Epoch 71/200, Train Loss: 13.1611, Val Loss: 12.4199\n",
      "  New best validation loss: 12.4199\n",
      "Epoch 72/200, Train Loss: 13.1322, Val Loss: 12.4036\n",
      "  New best validation loss: 12.4036\n",
      "Epoch 73/200, Train Loss: 13.0792, Val Loss: 12.4339\n",
      "Epoch 74/200, Train Loss: 13.0468, Val Loss: 12.3075\n",
      "  New best validation loss: 12.3075\n",
      "Epoch 75/200, Train Loss: 12.9969, Val Loss: 12.1649\n",
      "  New best validation loss: 12.1649\n",
      "Epoch 76/200, Train Loss: 12.9538, Val Loss: 12.2955\n",
      "Epoch 77/200, Train Loss: 12.9030, Val Loss: 12.2418\n",
      "Epoch 78/200, Train Loss: 12.9173, Val Loss: 12.4242\n",
      "Epoch 79/200, Train Loss: 12.9081, Val Loss: 11.9721\n",
      "  New best validation loss: 11.9721\n",
      "Epoch 80/200, Train Loss: 12.8295, Val Loss: 12.1098\n",
      "Epoch 81/200, Train Loss: 12.8016, Val Loss: 11.9566\n",
      "  New best validation loss: 11.9566\n",
      "Epoch 82/200, Train Loss: 12.7727, Val Loss: 11.9449\n",
      "  New best validation loss: 11.9449\n",
      "Epoch 83/200, Train Loss: 12.7197, Val Loss: 12.1735\n",
      "Epoch 84/200, Train Loss: 12.7040, Val Loss: 11.8990\n",
      "  New best validation loss: 11.8990\n",
      "Epoch 85/200, Train Loss: 12.6647, Val Loss: 11.8991\n",
      "Epoch 86/200, Train Loss: 12.5895, Val Loss: 11.8983\n",
      "  New best validation loss: 11.8983\n",
      "Epoch 87/200, Train Loss: 12.5756, Val Loss: 11.9152\n",
      "Epoch 88/200, Train Loss: 12.5327, Val Loss: 12.1601\n",
      "Epoch 89/200, Train Loss: 12.5090, Val Loss: 11.7930\n",
      "  New best validation loss: 11.7930\n",
      "Epoch 90/200, Train Loss: 12.4688, Val Loss: 11.7968\n",
      "Epoch 91/200, Train Loss: 12.4334, Val Loss: 11.7083\n",
      "  New best validation loss: 11.7083\n",
      "Epoch 92/200, Train Loss: 12.3993, Val Loss: 11.7604\n",
      "Epoch 93/200, Train Loss: 12.3765, Val Loss: 11.7227\n",
      "Epoch 94/200, Train Loss: 12.3101, Val Loss: 11.9470\n",
      "Epoch 95/200, Train Loss: 12.3166, Val Loss: 11.6820\n",
      "  New best validation loss: 11.6820\n",
      "Epoch 96/200, Train Loss: 12.2518, Val Loss: 11.7519\n",
      "Epoch 97/200, Train Loss: 12.1917, Val Loss: 11.5695\n",
      "  New best validation loss: 11.5695\n",
      "Epoch 98/200, Train Loss: 12.1907, Val Loss: 11.6526\n",
      "Epoch 99/200, Train Loss: 12.2006, Val Loss: 11.3701\n",
      "  New best validation loss: 11.3701\n",
      "Epoch 100/200, Train Loss: 12.1244, Val Loss: 11.3639\n",
      "  New best validation loss: 11.3639\n",
      "Epoch 101/200, Train Loss: 12.1316, Val Loss: 11.4506\n",
      "Epoch 102/200, Train Loss: 12.0400, Val Loss: 11.3043\n",
      "  New best validation loss: 11.3043\n",
      "Epoch 103/200, Train Loss: 12.0258, Val Loss: 11.3911\n",
      "Epoch 104/200, Train Loss: 11.9778, Val Loss: 11.5658\n",
      "Epoch 105/200, Train Loss: 11.9508, Val Loss: 11.2798\n",
      "  New best validation loss: 11.2798\n",
      "Epoch 106/200, Train Loss: 11.9395, Val Loss: 11.2251\n",
      "  New best validation loss: 11.2251\n",
      "Epoch 107/200, Train Loss: 11.9169, Val Loss: 11.5153\n",
      "Epoch 108/200, Train Loss: 11.8745, Val Loss: 11.3225\n",
      "Epoch 109/200, Train Loss: 11.8458, Val Loss: 11.1778\n",
      "  New best validation loss: 11.1778\n",
      "Epoch 110/200, Train Loss: 11.8121, Val Loss: 11.0549\n",
      "  New best validation loss: 11.0549\n",
      "Epoch 111/200, Train Loss: 11.7810, Val Loss: 11.0200\n",
      "  New best validation loss: 11.0200\n",
      "Epoch 112/200, Train Loss: 11.7531, Val Loss: 11.2032\n",
      "Epoch 113/200, Train Loss: 11.7408, Val Loss: 11.0389\n",
      "Epoch 114/200, Train Loss: 11.6993, Val Loss: 10.9784\n",
      "  New best validation loss: 10.9784\n",
      "Epoch 115/200, Train Loss: 11.6843, Val Loss: 10.9967\n",
      "Epoch 116/200, Train Loss: 11.6626, Val Loss: 11.1008\n",
      "Epoch 117/200, Train Loss: 11.6269, Val Loss: 11.0055\n",
      "Epoch 118/200, Train Loss: 11.5920, Val Loss: 11.0514\n",
      "Epoch 119/200, Train Loss: 11.6127, Val Loss: 10.8973\n",
      "  New best validation loss: 10.8973\n",
      "Epoch 120/200, Train Loss: 11.5474, Val Loss: 10.9430\n",
      "Epoch 121/200, Train Loss: 11.5194, Val Loss: 10.8188\n",
      "  New best validation loss: 10.8188\n",
      "Epoch 122/200, Train Loss: 11.5106, Val Loss: 10.9375\n",
      "Epoch 123/200, Train Loss: 11.4824, Val Loss: 10.9391\n",
      "Epoch 124/200, Train Loss: 11.3906, Val Loss: 10.9730\n",
      "Epoch 125/200, Train Loss: 11.4526, Val Loss: 10.7393\n",
      "  New best validation loss: 10.7393\n",
      "Epoch 126/200, Train Loss: 11.3813, Val Loss: 10.6538\n",
      "  New best validation loss: 10.6538\n",
      "Epoch 127/200, Train Loss: 11.3920, Val Loss: 10.8008\n",
      "Epoch 128/200, Train Loss: 11.3597, Val Loss: 10.7817\n",
      "Epoch 129/200, Train Loss: 11.3188, Val Loss: 10.8118\n",
      "Epoch 130/200, Train Loss: 11.3442, Val Loss: 10.6886\n",
      "Epoch 131/200, Train Loss: 11.3042, Val Loss: 10.7479\n",
      "Epoch 132/200, Train Loss: 11.2456, Val Loss: 10.6395\n",
      "  New best validation loss: 10.6395\n",
      "Epoch 133/200, Train Loss: 11.2470, Val Loss: 10.5536\n",
      "  New best validation loss: 10.5536\n",
      "Epoch 134/200, Train Loss: 11.2006, Val Loss: 10.6716\n",
      "Epoch 135/200, Train Loss: 11.1906, Val Loss: 10.5544\n",
      "Epoch 136/200, Train Loss: 11.1923, Val Loss: 10.4298\n",
      "  New best validation loss: 10.4298\n",
      "Epoch 137/200, Train Loss: 11.1671, Val Loss: 10.5507\n",
      "Epoch 138/200, Train Loss: 11.1418, Val Loss: 10.5709\n",
      "Epoch 139/200, Train Loss: 11.1281, Val Loss: 10.6725\n",
      "Epoch 140/200, Train Loss: 11.0967, Val Loss: 10.7428\n",
      "Epoch 141/200, Train Loss: 11.1259, Val Loss: 10.5184\n",
      "Epoch 142/200, Train Loss: 11.0645, Val Loss: 10.4397\n",
      "Epoch 143/200, Train Loss: 11.0562, Val Loss: 10.6111\n",
      "Epoch 144/200, Train Loss: 11.0288, Val Loss: 10.3683\n",
      "  New best validation loss: 10.3683\n",
      "Epoch 145/200, Train Loss: 10.9956, Val Loss: 10.4085\n",
      "Epoch 146/200, Train Loss: 11.0099, Val Loss: 10.6579\n",
      "Epoch 147/200, Train Loss: 10.9918, Val Loss: 10.4234\n",
      "Epoch 148/200, Train Loss: 11.0105, Val Loss: 10.4001\n",
      "Epoch 149/200, Train Loss: 10.9518, Val Loss: 10.5394\n",
      "Epoch 150/200, Train Loss: 10.9222, Val Loss: 10.5222\n",
      "Epoch 151/200, Train Loss: 10.9396, Val Loss: 10.4596\n",
      "Epoch 152/200, Train Loss: 10.8766, Val Loss: 10.6208\n",
      "Epoch 153/200, Train Loss: 10.8903, Val Loss: 10.5031\n",
      "Epoch 154/200, Train Loss: 10.8471, Val Loss: 10.3483\n",
      "  New best validation loss: 10.3483\n",
      "Epoch 155/200, Train Loss: 10.8286, Val Loss: 10.2652\n",
      "  New best validation loss: 10.2652\n",
      "Epoch 156/200, Train Loss: 10.8249, Val Loss: 10.3411\n",
      "Epoch 157/200, Train Loss: 10.7985, Val Loss: 10.3107\n",
      "Epoch 158/200, Train Loss: 10.7997, Val Loss: 10.2954\n",
      "Epoch 159/200, Train Loss: 10.7954, Val Loss: 10.2856\n",
      "Epoch 160/200, Train Loss: 10.7685, Val Loss: 10.1349\n",
      "  New best validation loss: 10.1349\n",
      "Epoch 161/200, Train Loss: 10.7808, Val Loss: 10.3827\n",
      "Epoch 162/200, Train Loss: 10.7548, Val Loss: 10.3710\n",
      "Epoch 163/200, Train Loss: 10.7370, Val Loss: 10.2254\n",
      "Epoch 164/200, Train Loss: 10.7219, Val Loss: 10.4554\n",
      "Epoch 165/200, Train Loss: 10.7202, Val Loss: 10.1838\n",
      "Epoch 166/200, Train Loss: 10.7081, Val Loss: 10.2426\n",
      "Epoch 167/200, Train Loss: 10.6871, Val Loss: 10.1692\n",
      "Epoch 168/200, Train Loss: 10.6648, Val Loss: 10.2457\n",
      "Epoch 169/200, Train Loss: 10.6824, Val Loss: 10.6709\n",
      "Epoch 170/200, Train Loss: 10.6706, Val Loss: 10.1937\n",
      "Epoch 171/200, Train Loss: 10.6841, Val Loss: 10.4009\n",
      "Epoch 172/200, Train Loss: 10.6131, Val Loss: 10.1208\n",
      "  New best validation loss: 10.1208\n",
      "Epoch 173/200, Train Loss: 10.6212, Val Loss: 10.5069\n",
      "Epoch 174/200, Train Loss: 10.6087, Val Loss: 10.3167\n",
      "Epoch 175/200, Train Loss: 10.6100, Val Loss: 10.1548\n",
      "Epoch 176/200, Train Loss: 10.6189, Val Loss: 10.3087\n",
      "Epoch 177/200, Train Loss: 10.5890, Val Loss: 10.1857\n",
      "Epoch 178/200, Train Loss: 10.5824, Val Loss: 10.4160\n",
      "Epoch 179/200, Train Loss: 10.5487, Val Loss: 10.2470\n",
      "Epoch 180/200, Train Loss: 10.5414, Val Loss: 10.2349\n",
      "Epoch 181/200, Train Loss: 10.5399, Val Loss: 10.1924\n",
      "Epoch 182/200, Train Loss: 10.5515, Val Loss: 10.1168\n",
      "  New best validation loss: 10.1168\n",
      "Epoch 183/200, Train Loss: 10.5269, Val Loss: 10.3930\n",
      "Epoch 184/200, Train Loss: 10.5211, Val Loss: 10.1833\n",
      "Epoch 185/200, Train Loss: 10.4721, Val Loss: 10.1096\n",
      "  New best validation loss: 10.1096\n",
      "Epoch 186/200, Train Loss: 10.4681, Val Loss: 10.3588\n",
      "Epoch 187/200, Train Loss: 10.4827, Val Loss: 10.1972\n",
      "Epoch 188/200, Train Loss: 10.4616, Val Loss: 10.2253\n",
      "Epoch 189/200, Train Loss: 10.4191, Val Loss: 10.3792\n",
      "Epoch 190/200, Train Loss: 10.4444, Val Loss: 10.2958\n",
      "Epoch 191/200, Train Loss: 10.4067, Val Loss: 10.1362\n",
      "Epoch 192/200, Train Loss: 10.4678, Val Loss: 10.2027\n",
      "Epoch 193/200, Train Loss: 10.4025, Val Loss: 10.3243\n",
      "Epoch 194/200, Train Loss: 10.4102, Val Loss: 10.2121\n",
      "Epoch 195/200, Train Loss: 10.3788, Val Loss: 10.4502\n",
      "Epoch 196/200, Train Loss: 10.3812, Val Loss: 10.2114\n",
      "Epoch 197/200, Train Loss: 10.3682, Val Loss: 10.0710\n",
      "  New best validation loss: 10.0710\n",
      "Epoch 198/200, Train Loss: 10.3847, Val Loss: 10.2355\n",
      "Epoch 199/200, Train Loss: 10.3840, Val Loss: 10.2628\n",
      "Epoch 200/200, Train Loss: 10.3347, Val Loss: 10.3840\n",
      "\n",
      "Loaded best model (Val Loss: 10.0710) for final hidden state extraction.\n",
      "Saved best model for RNN_Vanillia (samples=2400) to results_data_size_sweep/20250514_045146/samples_2400/RNN_Vanillia_samples_2400_best.pt\n",
      "\n",
      "--- Performing Decodability Analysis for RNN_Vanillia (samples=2400, k=15) ---\n",
      "  Analyzing decodability for RNN_Vanillia...\n",
      "  Hidden states shape: torch.Size([160, 200, 225])\n",
      "  Coefficients shape: torch.Size([160, 15])\n",
      "  Processed hidden states shape for decoder: torch.Size([160, 225])\n",
      "  RidgeCV Decoder for RNN_Vanillia - Test MSE: 0.9716, Test R2: 0.5062 (best alpha: 48.3293)\n",
      "  Decodability plot saved to results_data_size_sweep/20250514_045146/samples_2400/decodability_RNN_Vanillia_coeff1.png\n",
      "Decodability (R2 score) for RNN_Vanillia (samples=2400): 0.5062\n",
      "\n",
      "--- Training ComplexOscillatorNet (samples=2400, k=15) ---\n",
      "Number of parameters: 17152\n",
      "Epoch 1/200, Train Loss: 15.9795, Val Loss: 14.2726\n",
      "  New best validation loss: 14.2726\n",
      "Epoch 2/200, Train Loss: 15.2759, Val Loss: 14.1027\n",
      "  New best validation loss: 14.1027\n",
      "Epoch 3/200, Train Loss: 15.0301, Val Loss: 13.8396\n",
      "  New best validation loss: 13.8396\n",
      "Epoch 4/200, Train Loss: 14.8658, Val Loss: 13.6724\n",
      "  New best validation loss: 13.6724\n",
      "Epoch 5/200, Train Loss: 14.6842, Val Loss: 13.5699\n",
      "  New best validation loss: 13.5699\n",
      "Epoch 6/200, Train Loss: 14.6088, Val Loss: 13.6340\n",
      "Epoch 7/200, Train Loss: 14.5362, Val Loss: 13.4924\n",
      "  New best validation loss: 13.4924\n",
      "Epoch 8/200, Train Loss: 14.4772, Val Loss: 13.4223\n",
      "  New best validation loss: 13.4223\n",
      "Epoch 9/200, Train Loss: 14.3815, Val Loss: 13.4852\n",
      "Epoch 10/200, Train Loss: 14.3748, Val Loss: 13.3377\n",
      "  New best validation loss: 13.3377\n",
      "Epoch 11/200, Train Loss: 14.2969, Val Loss: 13.3231\n",
      "  New best validation loss: 13.3231\n",
      "Epoch 12/200, Train Loss: 14.2629, Val Loss: 13.3331\n",
      "Epoch 13/200, Train Loss: 14.2197, Val Loss: 13.3844\n",
      "Epoch 14/200, Train Loss: 14.1671, Val Loss: 13.2400\n",
      "  New best validation loss: 13.2400\n",
      "Epoch 15/200, Train Loss: 14.1193, Val Loss: 13.4050\n",
      "Epoch 16/200, Train Loss: 14.0840, Val Loss: 13.1461\n",
      "  New best validation loss: 13.1461\n",
      "Epoch 17/200, Train Loss: 14.0547, Val Loss: 13.2861\n",
      "Epoch 18/200, Train Loss: 14.0272, Val Loss: 13.3270\n",
      "Epoch 19/200, Train Loss: 14.0053, Val Loss: 13.2798\n",
      "Epoch 20/200, Train Loss: 13.9312, Val Loss: 13.2586\n",
      "Epoch 21/200, Train Loss: 13.9347, Val Loss: 13.2856\n",
      "Epoch 22/200, Train Loss: 13.9203, Val Loss: 13.2488\n",
      "Epoch 23/200, Train Loss: 13.8856, Val Loss: 13.2992\n",
      "Epoch 24/200, Train Loss: 13.8927, Val Loss: 13.2893\n",
      "Epoch 25/200, Train Loss: 13.8283, Val Loss: 13.2349\n",
      "Epoch 26/200, Train Loss: 13.7833, Val Loss: 13.3233\n",
      "Epoch 27/200, Train Loss: 13.7878, Val Loss: 13.2297\n",
      "Epoch 28/200, Train Loss: 13.7599, Val Loss: 13.4309\n",
      "Epoch 29/200, Train Loss: 13.7296, Val Loss: 13.2998\n",
      "Epoch 30/200, Train Loss: 13.7213, Val Loss: 13.3113\n",
      "Epoch 31/200, Train Loss: 13.6907, Val Loss: 13.2571\n",
      "Epoch 32/200, Train Loss: 13.6628, Val Loss: 13.2407\n",
      "Epoch 33/200, Train Loss: 13.6441, Val Loss: 13.3926\n",
      "Epoch 34/200, Train Loss: 13.6253, Val Loss: 13.3603\n",
      "Epoch 35/200, Train Loss: 13.5911, Val Loss: 13.3655\n",
      "Epoch 36/200, Train Loss: 13.5760, Val Loss: 13.4276\n",
      "Epoch 37/200, Train Loss: 13.5427, Val Loss: 13.2784\n",
      "Epoch 38/200, Train Loss: 13.5362, Val Loss: 13.3623\n",
      "Epoch 39/200, Train Loss: 13.5035, Val Loss: 13.5106\n",
      "Epoch 40/200, Train Loss: 13.4790, Val Loss: 13.3847\n",
      "Epoch 41/200, Train Loss: 13.4762, Val Loss: 13.2678\n",
      "Epoch 42/200, Train Loss: 13.4798, Val Loss: 13.4745\n",
      "Epoch 43/200, Train Loss: 13.4398, Val Loss: 13.3359\n",
      "Epoch 44/200, Train Loss: 13.4399, Val Loss: 13.3163\n",
      "Epoch 45/200, Train Loss: 13.4062, Val Loss: 13.3896\n",
      "Epoch 46/200, Train Loss: 13.4056, Val Loss: 13.3888\n",
      "Epoch 47/200, Train Loss: 13.3812, Val Loss: 13.2614\n",
      "Epoch 48/200, Train Loss: 13.3346, Val Loss: 13.4752\n",
      "Epoch 49/200, Train Loss: 13.3311, Val Loss: 13.5889\n",
      "Epoch 50/200, Train Loss: 13.3150, Val Loss: 13.4178\n",
      "Epoch 51/200, Train Loss: 13.3110, Val Loss: 13.4345\n",
      "Epoch 52/200, Train Loss: 13.2763, Val Loss: 13.5145\n",
      "Epoch 53/200, Train Loss: 13.2629, Val Loss: 13.4883\n",
      "Epoch 54/200, Train Loss: 13.2659, Val Loss: 13.5077\n",
      "Epoch 55/200, Train Loss: 13.2388, Val Loss: 13.5183\n",
      "Epoch 56/200, Train Loss: 13.2244, Val Loss: 13.6118\n",
      "Epoch 57/200, Train Loss: 13.2161, Val Loss: 13.4150\n",
      "Epoch 58/200, Train Loss: 13.2025, Val Loss: 13.5754\n",
      "Epoch 59/200, Train Loss: 13.1704, Val Loss: 13.4869\n",
      "Epoch 60/200, Train Loss: 13.1399, Val Loss: 13.4649\n",
      "Epoch 61/200, Train Loss: 13.1786, Val Loss: 13.5361\n",
      "Epoch 62/200, Train Loss: 13.1217, Val Loss: 13.5040\n",
      "Epoch 63/200, Train Loss: 13.1625, Val Loss: 13.6324\n",
      "Epoch 64/200, Train Loss: 13.1324, Val Loss: 13.6541\n",
      "Epoch 65/200, Train Loss: 13.0997, Val Loss: 13.6698\n",
      "Epoch 66/200, Train Loss: 13.0689, Val Loss: 13.6281\n",
      "Epoch 67/200, Train Loss: 13.0443, Val Loss: 13.6365\n",
      "Epoch 68/200, Train Loss: 13.0546, Val Loss: 13.7089\n",
      "Epoch 69/200, Train Loss: 13.0554, Val Loss: 13.6569\n",
      "Epoch 70/200, Train Loss: 13.0299, Val Loss: 13.6739\n",
      "Epoch 71/200, Train Loss: 13.0054, Val Loss: 13.7194\n",
      "Epoch 72/200, Train Loss: 13.0108, Val Loss: 13.6414\n",
      "Epoch 73/200, Train Loss: 13.0067, Val Loss: 13.7380\n",
      "Epoch 74/200, Train Loss: 12.9955, Val Loss: 13.6809\n",
      "Epoch 75/200, Train Loss: 12.9635, Val Loss: 13.7798\n",
      "Epoch 76/200, Train Loss: 12.9479, Val Loss: 13.6477\n",
      "Epoch 77/200, Train Loss: 12.9459, Val Loss: 13.7260\n",
      "Epoch 78/200, Train Loss: 12.9288, Val Loss: 13.6860\n",
      "Epoch 79/200, Train Loss: 13.0360, Val Loss: 13.6911\n",
      "Epoch 80/200, Train Loss: 12.9642, Val Loss: 13.6997\n",
      "Epoch 81/200, Train Loss: 12.9137, Val Loss: 13.6454\n",
      "Epoch 82/200, Train Loss: 12.9121, Val Loss: 13.6446\n",
      "Epoch 83/200, Train Loss: 12.8892, Val Loss: 13.6949\n",
      "Epoch 84/200, Train Loss: 12.8949, Val Loss: 13.6614\n",
      "Epoch 85/200, Train Loss: 12.8560, Val Loss: 13.7914\n",
      "Epoch 86/200, Train Loss: 12.8588, Val Loss: 13.7216\n",
      "Epoch 87/200, Train Loss: 12.8267, Val Loss: 13.7838\n",
      "Epoch 88/200, Train Loss: 12.8489, Val Loss: 13.8559\n",
      "Epoch 89/200, Train Loss: 12.9179, Val Loss: 13.7641\n",
      "Epoch 90/200, Train Loss: 12.8411, Val Loss: 13.8350\n",
      "Epoch 91/200, Train Loss: 12.8164, Val Loss: 13.8442\n",
      "Epoch 92/200, Train Loss: 12.8511, Val Loss: 13.8715\n",
      "Epoch 93/200, Train Loss: 12.9042, Val Loss: 13.7583\n",
      "Epoch 94/200, Train Loss: 12.8079, Val Loss: 13.7504\n",
      "Epoch 95/200, Train Loss: 12.7916, Val Loss: 13.8478\n",
      "Epoch 96/200, Train Loss: 12.7751, Val Loss: 13.7057\n",
      "Epoch 97/200, Train Loss: 12.7857, Val Loss: 13.8721\n",
      "Epoch 98/200, Train Loss: 12.7832, Val Loss: 13.7941\n",
      "Epoch 99/200, Train Loss: 12.7743, Val Loss: 13.8351\n",
      "Epoch 100/200, Train Loss: 12.7975, Val Loss: 13.7768\n",
      "Epoch 101/200, Train Loss: 12.7876, Val Loss: 13.7658\n",
      "Epoch 102/200, Train Loss: 12.7478, Val Loss: 13.8308\n",
      "Epoch 103/200, Train Loss: 12.7131, Val Loss: 13.8691\n",
      "Epoch 104/200, Train Loss: 12.6895, Val Loss: 13.8104\n",
      "Epoch 105/200, Train Loss: 12.7983, Val Loss: 13.7285\n",
      "Epoch 106/200, Train Loss: 12.7317, Val Loss: 13.8301\n",
      "Epoch 107/200, Train Loss: 12.7154, Val Loss: 13.9218\n",
      "Epoch 108/200, Train Loss: 12.7366, Val Loss: 13.8422\n",
      "Epoch 109/200, Train Loss: 12.7424, Val Loss: 13.7631\n",
      "Epoch 110/200, Train Loss: 12.6723, Val Loss: 13.7160\n",
      "Epoch 111/200, Train Loss: 12.6947, Val Loss: 13.9891\n",
      "Epoch 112/200, Train Loss: 12.6829, Val Loss: 13.8686\n",
      "Epoch 113/200, Train Loss: 12.6550, Val Loss: 13.9356\n",
      "Epoch 114/200, Train Loss: 12.6498, Val Loss: 13.8429\n",
      "Epoch 115/200, Train Loss: 12.6376, Val Loss: 13.9308\n",
      "Epoch 116/200, Train Loss: 12.6505, Val Loss: 13.8649\n",
      "Epoch 117/200, Train Loss: 12.6377, Val Loss: 13.9107\n",
      "Epoch 118/200, Train Loss: 12.6370, Val Loss: 13.9223\n",
      "Epoch 119/200, Train Loss: 12.6555, Val Loss: 13.9562\n",
      "Epoch 120/200, Train Loss: 12.6446, Val Loss: 13.9431\n",
      "Epoch 121/200, Train Loss: 12.6232, Val Loss: 14.0070\n",
      "Epoch 122/200, Train Loss: 12.5970, Val Loss: 14.0378\n",
      "Epoch 123/200, Train Loss: 12.6800, Val Loss: 13.8929\n",
      "Epoch 124/200, Train Loss: 12.6240, Val Loss: 13.9657\n",
      "Epoch 125/200, Train Loss: 12.6238, Val Loss: 13.8992\n",
      "Epoch 126/200, Train Loss: 12.5878, Val Loss: 14.0221\n",
      "Epoch 127/200, Train Loss: 12.5813, Val Loss: 13.9312\n",
      "Epoch 128/200, Train Loss: 12.5665, Val Loss: 13.9062\n",
      "Epoch 129/200, Train Loss: 12.5822, Val Loss: 13.9735\n",
      "Epoch 130/200, Train Loss: 12.5566, Val Loss: 13.9768\n",
      "Epoch 131/200, Train Loss: 12.5609, Val Loss: 13.9492\n",
      "Epoch 132/200, Train Loss: 12.5822, Val Loss: 13.9869\n",
      "Epoch 133/200, Train Loss: 12.5294, Val Loss: 13.9635\n",
      "Epoch 134/200, Train Loss: 12.5514, Val Loss: 13.9790\n",
      "Epoch 135/200, Train Loss: 12.5556, Val Loss: 13.9812\n",
      "Epoch 136/200, Train Loss: 12.5374, Val Loss: 14.0471\n",
      "Epoch 137/200, Train Loss: 12.5251, Val Loss: 14.0442\n",
      "Epoch 138/200, Train Loss: 12.5378, Val Loss: 13.9841\n",
      "Epoch 139/200, Train Loss: 12.5613, Val Loss: 14.1093\n",
      "Epoch 140/200, Train Loss: 12.5834, Val Loss: 14.0012\n",
      "Epoch 141/200, Train Loss: 12.5564, Val Loss: 14.0097\n",
      "Epoch 142/200, Train Loss: 12.5566, Val Loss: 14.1705\n",
      "Epoch 143/200, Train Loss: 12.5884, Val Loss: 14.0443\n",
      "Epoch 144/200, Train Loss: 12.5095, Val Loss: 13.9640\n",
      "Epoch 145/200, Train Loss: 12.4858, Val Loss: 14.0936\n",
      "Epoch 146/200, Train Loss: 12.4663, Val Loss: 14.0326\n",
      "Epoch 147/200, Train Loss: 12.5446, Val Loss: 14.0433\n",
      "Epoch 148/200, Train Loss: 12.6001, Val Loss: 14.0206\n",
      "Epoch 149/200, Train Loss: 12.5330, Val Loss: 14.0487\n",
      "Epoch 150/200, Train Loss: 12.5230, Val Loss: 13.9980\n",
      "Epoch 151/200, Train Loss: 12.5085, Val Loss: 14.1090\n",
      "Epoch 152/200, Train Loss: 12.5246, Val Loss: 14.0961\n",
      "Epoch 153/200, Train Loss: 12.5588, Val Loss: 14.0607\n",
      "Epoch 154/200, Train Loss: 12.5884, Val Loss: 14.0697\n",
      "Epoch 155/200, Train Loss: 12.5495, Val Loss: 14.0240\n",
      "Epoch 156/200, Train Loss: 12.4804, Val Loss: 14.0716\n",
      "Epoch 157/200, Train Loss: 12.4299, Val Loss: 14.0025\n",
      "Epoch 158/200, Train Loss: 12.4261, Val Loss: 14.0518\n",
      "Epoch 159/200, Train Loss: 12.4480, Val Loss: 14.0748\n",
      "Epoch 160/200, Train Loss: 12.4346, Val Loss: 14.1016\n",
      "Epoch 161/200, Train Loss: 12.4201, Val Loss: 14.1076\n",
      "Epoch 162/200, Train Loss: 12.4318, Val Loss: 14.0941\n",
      "Epoch 163/200, Train Loss: 12.4135, Val Loss: 14.1454\n",
      "Epoch 164/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 165/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 166/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 167/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 168/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 169/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 170/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 171/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 172/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 173/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 174/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 175/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 176/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 177/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 178/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 179/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 180/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 181/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 182/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 183/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 184/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 185/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 186/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 187/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 188/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 189/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 190/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 191/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 192/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 193/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 194/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 195/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 196/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 197/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 198/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 199/200, Train Loss: nan, Val Loss: nan\n",
      "Epoch 200/200, Train Loss: nan, Val Loss: nan\n",
      "\n",
      "Loaded best model (Val Loss: 13.1461) for final hidden state extraction.\n",
      "Saved best model for ComplexOscillatorNet (samples=2400) to results_data_size_sweep/20250514_045146/samples_2400/ComplexOscillatorNet_samples_2400_best.pt\n",
      "\n",
      "--- Performing Decodability Analysis for ComplexOscillatorNet (samples=2400, k=15) ---\n",
      "  Analyzing decodability for ComplexOscillatorNet...\n",
      "  Hidden states shape: torch.Size([160, 200, 128])\n",
      "  Coefficients shape: torch.Size([160, 15])\n",
      "  Processed hidden states shape for decoder: torch.Size([160, 256])\n",
      "  Error during RidgeCV for ComplexOscillatorNet: Input X contains NaN.\n",
      "_RidgeGCV does not accept missing values encoded as NaN natively. For supervised learning, you might want to consider sklearn.ensemble.HistGradientBoostingClassifier and Regressor which accept missing values encoded as NaNs natively. Alternatively, it is possible to preprocess the data, for instance by using an imputer transformer in a pipeline or drop samples with missing values. See https://scikit-learn.org/stable/modules/impute.html You can find a list of all estimators that handle NaN values at the following page: https://scikit-learn.org/stable/modules/impute.html#estimators-that-handle-nan-values\n",
      "Decodability (R2 score) for ComplexOscillatorNet (samples=2400): nan\n",
      "\n",
      "--- Training RNN_GRU (samples=2400, k=15) ---\n",
      "Number of parameters: 12993\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/conda/lib/python3.10/site-packages/sklearn/utils/extmath.py:1101: RuntimeWarning: invalid value encountered in divide\n",
      "  updated_mean = (last_sum + new_sum) / updated_sample_count\n",
      "/opt/conda/lib/python3.10/site-packages/sklearn/utils/extmath.py:1106: RuntimeWarning: invalid value encountered in divide\n",
      "  T = new_sum / new_sample_count\n",
      "/opt/conda/lib/python3.10/site-packages/sklearn/utils/extmath.py:1126: RuntimeWarning: invalid value encountered in divide\n",
      "  new_unnormalized_variance -= correction**2 / new_sample_count\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/200, Train Loss: 16.8592, Val Loss: 15.7054\n",
      "  New best validation loss: 15.7054\n",
      "Epoch 2/200, Train Loss: 16.7786, Val Loss: 15.6874\n",
      "  New best validation loss: 15.6874\n",
      "Epoch 3/200, Train Loss: 16.7538, Val Loss: 15.6901\n",
      "Epoch 4/200, Train Loss: 16.7430, Val Loss: 15.6985\n",
      "Epoch 5/200, Train Loss: 16.7307, Val Loss: 15.6805\n",
      "  New best validation loss: 15.6805\n",
      "Epoch 6/200, Train Loss: 16.7234, Val Loss: 15.6778\n",
      "  New best validation loss: 15.6778\n",
      "Epoch 7/200, Train Loss: 16.7055, Val Loss: 15.6562\n",
      "  New best validation loss: 15.6562\n",
      "Epoch 8/200, Train Loss: 16.6895, Val Loss: 15.6325\n",
      "  New best validation loss: 15.6325\n",
      "Epoch 9/200, Train Loss: 16.6734, Val Loss: 15.6310\n",
      "  New best validation loss: 15.6310\n",
      "Epoch 10/200, Train Loss: 16.6218, Val Loss: 15.6233\n",
      "  New best validation loss: 15.6233\n",
      "Epoch 11/200, Train Loss: 16.5650, Val Loss: 15.6627\n",
      "Epoch 12/200, Train Loss: 16.5376, Val Loss: 15.5920\n",
      "  New best validation loss: 15.5920\n",
      "Epoch 13/200, Train Loss: 16.5096, Val Loss: 15.5161\n",
      "  New best validation loss: 15.5161\n",
      "Epoch 14/200, Train Loss: 16.4787, Val Loss: 15.5144\n",
      "  New best validation loss: 15.5144\n",
      "Epoch 15/200, Train Loss: 16.4533, Val Loss: 15.5083\n",
      "  New best validation loss: 15.5083\n",
      "Epoch 16/200, Train Loss: 16.4075, Val Loss: 15.4052\n",
      "  New best validation loss: 15.4052\n",
      "Epoch 17/200, Train Loss: 16.2910, Val Loss: 15.2291\n",
      "  New best validation loss: 15.2291\n",
      "Epoch 18/200, Train Loss: 16.0774, Val Loss: 15.0830\n",
      "  New best validation loss: 15.0830\n",
      "Epoch 19/200, Train Loss: 15.9501, Val Loss: 14.9199\n",
      "  New best validation loss: 14.9199\n",
      "Epoch 20/200, Train Loss: 15.8797, Val Loss: 14.8817\n",
      "  New best validation loss: 14.8817\n",
      "Epoch 21/200, Train Loss: 15.7618, Val Loss: 14.7409\n",
      "  New best validation loss: 14.7409\n",
      "Epoch 22/200, Train Loss: 15.7527, Val Loss: 14.6469\n",
      "  New best validation loss: 14.6469\n",
      "Epoch 23/200, Train Loss: 15.6520, Val Loss: 14.6979\n",
      "Epoch 24/200, Train Loss: 15.6014, Val Loss: 14.7753\n",
      "Epoch 25/200, Train Loss: 15.5469, Val Loss: 14.7933\n",
      "Epoch 26/200, Train Loss: 15.4834, Val Loss: 14.5486\n",
      "  New best validation loss: 14.5486\n",
      "Epoch 27/200, Train Loss: 15.3662, Val Loss: 14.6312\n",
      "Epoch 28/200, Train Loss: 15.2486, Val Loss: 14.6315\n",
      "Epoch 29/200, Train Loss: 15.2021, Val Loss: 14.5410\n",
      "  New best validation loss: 14.5410\n",
      "Epoch 30/200, Train Loss: 15.1388, Val Loss: 14.4456\n",
      "  New best validation loss: 14.4456\n",
      "Epoch 31/200, Train Loss: 15.1375, Val Loss: 14.5331\n",
      "Epoch 32/200, Train Loss: 14.9722, Val Loss: 14.2743\n",
      "  New best validation loss: 14.2743\n",
      "Epoch 33/200, Train Loss: 14.8652, Val Loss: 14.3500\n",
      "Epoch 34/200, Train Loss: 14.8031, Val Loss: 14.5153\n",
      "Epoch 35/200, Train Loss: 14.8220, Val Loss: 14.0540\n",
      "  New best validation loss: 14.0540\n",
      "Epoch 36/200, Train Loss: 14.6285, Val Loss: 13.9164\n",
      "  New best validation loss: 13.9164\n",
      "Epoch 37/200, Train Loss: 14.5826, Val Loss: 13.9742\n",
      "Epoch 38/200, Train Loss: 14.5243, Val Loss: 14.1963\n",
      "Epoch 39/200, Train Loss: 14.4621, Val Loss: 14.0595\n",
      "Epoch 40/200, Train Loss: 14.5239, Val Loss: 13.7346\n",
      "  New best validation loss: 13.7346\n",
      "Epoch 41/200, Train Loss: 14.3361, Val Loss: 13.9562\n",
      "Epoch 42/200, Train Loss: 14.2945, Val Loss: 13.6756\n",
      "  New best validation loss: 13.6756\n",
      "Epoch 43/200, Train Loss: 14.2640, Val Loss: 14.3995\n",
      "Epoch 44/200, Train Loss: 14.3341, Val Loss: 13.4672\n",
      "  New best validation loss: 13.4672\n",
      "Epoch 45/200, Train Loss: 14.1750, Val Loss: 13.6108\n",
      "Epoch 46/200, Train Loss: 14.1569, Val Loss: 13.7208\n",
      "Epoch 47/200, Train Loss: 14.1141, Val Loss: 13.3190\n",
      "  New best validation loss: 13.3190\n",
      "Epoch 48/200, Train Loss: 14.0925, Val Loss: 13.3613\n",
      "Epoch 49/200, Train Loss: 14.0054, Val Loss: 13.3518\n",
      "Epoch 50/200, Train Loss: 13.9988, Val Loss: 13.2797\n",
      "  New best validation loss: 13.2797\n",
      "Epoch 51/200, Train Loss: 14.0309, Val Loss: 13.1950\n",
      "  New best validation loss: 13.1950\n",
      "Epoch 52/200, Train Loss: 13.9676, Val Loss: 13.3179\n",
      "Epoch 53/200, Train Loss: 13.8795, Val Loss: 13.0984\n",
      "  New best validation loss: 13.0984\n",
      "Epoch 54/200, Train Loss: 13.8360, Val Loss: 13.0724\n",
      "  New best validation loss: 13.0724\n",
      "Epoch 55/200, Train Loss: 13.8182, Val Loss: 12.9613\n",
      "  New best validation loss: 12.9613\n",
      "Epoch 56/200, Train Loss: 13.7671, Val Loss: 13.0331\n",
      "Epoch 57/200, Train Loss: 13.7760, Val Loss: 13.1407\n",
      "Epoch 58/200, Train Loss: 13.7573, Val Loss: 13.0842\n",
      "Epoch 59/200, Train Loss: 13.6769, Val Loss: 12.8523\n",
      "  New best validation loss: 12.8523\n",
      "Epoch 60/200, Train Loss: 13.6136, Val Loss: 12.8498\n",
      "  New best validation loss: 12.8498\n",
      "Epoch 61/200, Train Loss: 13.5845, Val Loss: 13.0008\n",
      "Epoch 62/200, Train Loss: 13.6017, Val Loss: 12.8194\n",
      "  New best validation loss: 12.8194\n",
      "Epoch 63/200, Train Loss: 13.5153, Val Loss: 12.6785\n",
      "  New best validation loss: 12.6785\n",
      "Epoch 64/200, Train Loss: 13.5003, Val Loss: 12.7684\n",
      "Epoch 65/200, Train Loss: 13.4484, Val Loss: 12.7995\n",
      "Epoch 66/200, Train Loss: 13.4894, Val Loss: 12.6108\n",
      "  New best validation loss: 12.6108\n",
      "Epoch 67/200, Train Loss: 13.4501, Val Loss: 12.7002\n",
      "Epoch 68/200, Train Loss: 13.3509, Val Loss: 12.5638\n",
      "  New best validation loss: 12.5638\n",
      "Epoch 69/200, Train Loss: 13.4150, Val Loss: 12.6390\n",
      "Epoch 70/200, Train Loss: 13.3359, Val Loss: 12.5780\n",
      "Epoch 71/200, Train Loss: 13.3371, Val Loss: 12.4982\n",
      "  New best validation loss: 12.4982\n",
      "Epoch 72/200, Train Loss: 13.3840, Val Loss: 12.5329\n",
      "Epoch 73/200, Train Loss: 13.3082, Val Loss: 12.4562\n",
      "  New best validation loss: 12.4562\n",
      "Epoch 74/200, Train Loss: 13.3070, Val Loss: 12.5781\n",
      "Epoch 75/200, Train Loss: 13.2652, Val Loss: 12.6535\n",
      "Epoch 76/200, Train Loss: 13.1979, Val Loss: 12.4354\n",
      "  New best validation loss: 12.4354\n",
      "Epoch 77/200, Train Loss: 13.1615, Val Loss: 12.4446\n",
      "Epoch 78/200, Train Loss: 13.1465, Val Loss: 12.4732\n",
      "Epoch 79/200, Train Loss: 13.1443, Val Loss: 12.4335\n",
      "  New best validation loss: 12.4335\n",
      "Epoch 80/200, Train Loss: 13.1208, Val Loss: 12.3943\n",
      "  New best validation loss: 12.3943\n",
      "Epoch 81/200, Train Loss: 13.0365, Val Loss: 12.2879\n",
      "  New best validation loss: 12.2879\n",
      "Epoch 82/200, Train Loss: 13.0742, Val Loss: 12.3788\n",
      "Epoch 83/200, Train Loss: 13.0021, Val Loss: 12.2940\n",
      "Epoch 84/200, Train Loss: 13.0348, Val Loss: 12.4244\n",
      "Epoch 85/200, Train Loss: 12.9835, Val Loss: 12.2568\n",
      "  New best validation loss: 12.2568\n",
      "Epoch 86/200, Train Loss: 12.9608, Val Loss: 12.3928\n",
      "Epoch 87/200, Train Loss: 13.0090, Val Loss: 12.4995\n",
      "Epoch 88/200, Train Loss: 13.0043, Val Loss: 12.2422\n",
      "  New best validation loss: 12.2422\n",
      "Epoch 89/200, Train Loss: 12.8546, Val Loss: 12.2469\n",
      "Epoch 90/200, Train Loss: 12.8486, Val Loss: 12.2668\n",
      "Epoch 91/200, Train Loss: 12.9032, Val Loss: 12.2392\n",
      "  New best validation loss: 12.2392\n",
      "Epoch 92/200, Train Loss: 12.7882, Val Loss: 12.3729\n",
      "Epoch 93/200, Train Loss: 12.7961, Val Loss: 12.4195\n",
      "Epoch 94/200, Train Loss: 12.8367, Val Loss: 12.1179\n",
      "  New best validation loss: 12.1179\n",
      "Epoch 95/200, Train Loss: 12.7464, Val Loss: 12.3848\n",
      "Epoch 96/200, Train Loss: 12.7803, Val Loss: 12.1885\n",
      "Epoch 97/200, Train Loss: 12.6876, Val Loss: 12.2806\n",
      "Epoch 98/200, Train Loss: 12.7674, Val Loss: 11.9613\n",
      "  New best validation loss: 11.9613\n",
      "Epoch 99/200, Train Loss: 12.6296, Val Loss: 12.1006\n",
      "Epoch 100/200, Train Loss: 12.6424, Val Loss: 12.0390\n",
      "Epoch 101/200, Train Loss: 12.5669, Val Loss: 11.9789\n",
      "Epoch 102/200, Train Loss: 12.6519, Val Loss: 12.2505\n",
      "Epoch 103/200, Train Loss: 12.6030, Val Loss: 12.0878\n",
      "Epoch 104/200, Train Loss: 12.5092, Val Loss: 12.0807\n",
      "Epoch 105/200, Train Loss: 12.5073, Val Loss: 11.9563\n",
      "  New best validation loss: 11.9563\n",
      "Epoch 106/200, Train Loss: 12.4413, Val Loss: 11.8498\n",
      "  New best validation loss: 11.8498\n",
      "Epoch 107/200, Train Loss: 12.4008, Val Loss: 11.8042\n",
      "  New best validation loss: 11.8042\n",
      "Epoch 108/200, Train Loss: 12.3852, Val Loss: 11.7555\n",
      "  New best validation loss: 11.7555\n",
      "Epoch 109/200, Train Loss: 12.4849, Val Loss: 11.7602\n",
      "Epoch 110/200, Train Loss: 12.3496, Val Loss: 11.7939\n",
      "Epoch 111/200, Train Loss: 12.2670, Val Loss: 11.8042\n",
      "Epoch 112/200, Train Loss: 12.1858, Val Loss: 11.5198\n",
      "  New best validation loss: 11.5198\n",
      "Epoch 113/200, Train Loss: 12.1303, Val Loss: 11.7741\n",
      "Epoch 114/200, Train Loss: 12.0414, Val Loss: 11.5398\n",
      "Epoch 115/200, Train Loss: 12.0662, Val Loss: 11.5976\n",
      "Epoch 116/200, Train Loss: 12.0035, Val Loss: 11.3763\n",
      "  New best validation loss: 11.3763\n",
      "Epoch 117/200, Train Loss: 11.8664, Val Loss: 11.4007\n",
      "Epoch 118/200, Train Loss: 11.8138, Val Loss: 11.2434\n",
      "  New best validation loss: 11.2434\n",
      "Epoch 119/200, Train Loss: 11.7311, Val Loss: 11.3397\n",
      "Epoch 120/200, Train Loss: 11.7531, Val Loss: 11.2955\n",
      "Epoch 121/200, Train Loss: 11.7566, Val Loss: 11.1048\n",
      "  New best validation loss: 11.1048\n",
      "Epoch 122/200, Train Loss: 11.6241, Val Loss: 11.1609\n",
      "Epoch 123/200, Train Loss: 11.6764, Val Loss: 11.1631\n",
      "Epoch 124/200, Train Loss: 11.7218, Val Loss: 11.0269\n",
      "  New best validation loss: 11.0269\n",
      "Epoch 125/200, Train Loss: 11.5056, Val Loss: 11.1359\n",
      "Epoch 126/200, Train Loss: 11.5335, Val Loss: 10.7782\n",
      "  New best validation loss: 10.7782\n",
      "Epoch 127/200, Train Loss: 11.3945, Val Loss: 10.7890\n",
      "Epoch 128/200, Train Loss: 11.3621, Val Loss: 10.8998\n",
      "Epoch 129/200, Train Loss: 11.4229, Val Loss: 10.8987\n",
      "Epoch 130/200, Train Loss: 11.5204, Val Loss: 10.7508\n",
      "  New best validation loss: 10.7508\n",
      "Epoch 131/200, Train Loss: 11.3317, Val Loss: 10.7884\n",
      "Epoch 132/200, Train Loss: 11.2996, Val Loss: 10.5697\n",
      "  New best validation loss: 10.5697\n",
      "Epoch 133/200, Train Loss: 11.3274, Val Loss: 10.7919\n",
      "Epoch 134/200, Train Loss: 11.2749, Val Loss: 10.7567\n",
      "Epoch 135/200, Train Loss: 11.3639, Val Loss: 10.8189\n",
      "Epoch 136/200, Train Loss: 11.2356, Val Loss: 10.6513\n",
      "Epoch 137/200, Train Loss: 11.2266, Val Loss: 10.7800\n",
      "Epoch 138/200, Train Loss: 11.2131, Val Loss: 10.7159\n",
      "Epoch 139/200, Train Loss: 11.1585, Val Loss: 10.5561\n",
      "  New best validation loss: 10.5561\n",
      "Epoch 140/200, Train Loss: 11.1759, Val Loss: 10.4882\n",
      "  New best validation loss: 10.4882\n",
      "Epoch 141/200, Train Loss: 11.1757, Val Loss: 10.6283\n",
      "Epoch 142/200, Train Loss: 11.1287, Val Loss: 10.5589\n",
      "Epoch 143/200, Train Loss: 11.0675, Val Loss: 10.5853\n",
      "Epoch 144/200, Train Loss: 11.0645, Val Loss: 10.3983\n",
      "  New best validation loss: 10.3983\n",
      "Epoch 145/200, Train Loss: 11.0667, Val Loss: 10.4350\n",
      "Epoch 146/200, Train Loss: 11.0422, Val Loss: 10.6760\n",
      "Epoch 147/200, Train Loss: 11.0172, Val Loss: 10.3319\n",
      "  New best validation loss: 10.3319\n",
      "Epoch 148/200, Train Loss: 10.9762, Val Loss: 10.5390\n",
      "Epoch 149/200, Train Loss: 10.9682, Val Loss: 10.3975\n",
      "Epoch 150/200, Train Loss: 10.9071, Val Loss: 10.3044\n",
      "  New best validation loss: 10.3044\n",
      "Epoch 151/200, Train Loss: 10.9741, Val Loss: 10.3732\n",
      "Epoch 152/200, Train Loss: 10.9813, Val Loss: 10.4043\n",
      "Epoch 153/200, Train Loss: 10.9392, Val Loss: 10.3537\n",
      "Epoch 154/200, Train Loss: 10.8806, Val Loss: 10.2825\n",
      "  New best validation loss: 10.2825\n",
      "Epoch 155/200, Train Loss: 10.9350, Val Loss: 10.3687\n",
      "Epoch 156/200, Train Loss: 10.8759, Val Loss: 10.3164\n",
      "Epoch 157/200, Train Loss: 10.9113, Val Loss: 10.3563\n",
      "Epoch 158/200, Train Loss: 10.9479, Val Loss: 10.3932\n",
      "Epoch 159/200, Train Loss: 10.9120, Val Loss: 10.2887\n",
      "Epoch 160/200, Train Loss: 10.9526, Val Loss: 10.2153\n",
      "  New best validation loss: 10.2153\n",
      "Epoch 161/200, Train Loss: 10.8338, Val Loss: 10.1269\n",
      "  New best validation loss: 10.1269\n",
      "Epoch 162/200, Train Loss: 10.9104, Val Loss: 10.1778\n",
      "Epoch 163/200, Train Loss: 10.7843, Val Loss: 10.1069\n",
      "  New best validation loss: 10.1069\n",
      "Epoch 164/200, Train Loss: 10.7879, Val Loss: 10.0964\n",
      "  New best validation loss: 10.0964\n",
      "Epoch 165/200, Train Loss: 10.8061, Val Loss: 10.2921\n",
      "Epoch 166/200, Train Loss: 10.7613, Val Loss: 10.3402\n",
      "Epoch 167/200, Train Loss: 10.7440, Val Loss: 10.4549\n",
      "Epoch 168/200, Train Loss: 10.7496, Val Loss: 10.0255\n",
      "  New best validation loss: 10.0255\n",
      "Epoch 169/200, Train Loss: 10.7817, Val Loss: 10.4039\n",
      "Epoch 170/200, Train Loss: 10.7471, Val Loss: 10.3606\n",
      "Epoch 171/200, Train Loss: 10.7054, Val Loss: 10.1273\n",
      "Epoch 172/200, Train Loss: 10.7620, Val Loss: 10.2262\n",
      "Epoch 173/200, Train Loss: 10.6573, Val Loss: 10.0203\n",
      "  New best validation loss: 10.0203\n",
      "Epoch 174/200, Train Loss: 10.6987, Val Loss: 10.0368\n",
      "Epoch 175/200, Train Loss: 10.7184, Val Loss: 10.2899\n",
      "Epoch 176/200, Train Loss: 10.7404, Val Loss: 10.0225\n",
      "Epoch 177/200, Train Loss: 10.6272, Val Loss: 10.1226\n",
      "Epoch 178/200, Train Loss: 10.6289, Val Loss: 10.0548\n",
      "Epoch 179/200, Train Loss: 10.7732, Val Loss: 10.0066\n",
      "  New best validation loss: 10.0066\n",
      "Epoch 180/200, Train Loss: 10.6510, Val Loss: 10.2056\n",
      "Epoch 181/200, Train Loss: 10.6862, Val Loss: 9.9906\n",
      "  New best validation loss: 9.9906\n",
      "Epoch 182/200, Train Loss: 10.6375, Val Loss: 9.9653\n",
      "  New best validation loss: 9.9653\n",
      "Epoch 183/200, Train Loss: 10.6315, Val Loss: 10.1346\n",
      "Epoch 184/200, Train Loss: 10.6104, Val Loss: 10.4597\n",
      "Epoch 185/200, Train Loss: 10.7251, Val Loss: 9.9377\n",
      "  New best validation loss: 9.9377\n",
      "Epoch 186/200, Train Loss: 10.5865, Val Loss: 9.9396\n",
      "Epoch 187/200, Train Loss: 10.6068, Val Loss: 9.9751\n",
      "Epoch 188/200, Train Loss: 10.6268, Val Loss: 10.0446\n",
      "Epoch 189/200, Train Loss: 10.5684, Val Loss: 10.0692\n",
      "Epoch 190/200, Train Loss: 10.5955, Val Loss: 9.9383\n",
      "Epoch 191/200, Train Loss: 10.5748, Val Loss: 10.0410\n",
      "Epoch 192/200, Train Loss: 10.5864, Val Loss: 10.2685\n",
      "Epoch 193/200, Train Loss: 10.5824, Val Loss: 9.9544\n",
      "Epoch 194/200, Train Loss: 10.5974, Val Loss: 9.9500\n",
      "Epoch 195/200, Train Loss: 10.5450, Val Loss: 9.8222\n",
      "  New best validation loss: 9.8222\n",
      "Epoch 196/200, Train Loss: 10.5866, Val Loss: 10.0240\n",
      "Epoch 197/200, Train Loss: 10.5268, Val Loss: 9.8574\n",
      "Epoch 198/200, Train Loss: 10.5423, Val Loss: 10.2313\n",
      "Epoch 199/200, Train Loss: 10.5697, Val Loss: 9.9834\n",
      "Epoch 200/200, Train Loss: 10.6257, Val Loss: 10.2306\n",
      "\n",
      "Loaded best model (Val Loss: 9.8222) for final hidden state extraction.\n",
      "Saved best model for RNN_GRU (samples=2400) to results_data_size_sweep/20250514_045146/samples_2400/RNN_GRU_samples_2400_best.pt\n",
      "\n",
      "--- Performing Decodability Analysis for RNN_GRU (samples=2400, k=15) ---\n",
      "  Analyzing decodability for RNN_GRU...\n",
      "  Hidden states shape: torch.Size([160, 200, 64])\n",
      "  Coefficients shape: torch.Size([160, 15])\n",
      "  Processed hidden states shape for decoder: torch.Size([160, 64])\n",
      "  RidgeCV Decoder for RNN_GRU - Test MSE: 0.8442, Test R2: 0.5766 (best alpha: 5.4556)\n",
      "  Decodability plot saved to results_data_size_sweep/20250514_045146/samples_2400/decodability_RNN_GRU_coeff1.png\n",
      "Decodability (R2 score) for RNN_GRU (samples=2400): 0.5766\n",
      "\n",
      "--- Training Transformer (samples=2400, k=15) ---\n",
      "Number of parameters: 85809\n",
      "Epoch 1/200, Train Loss: 17.1811, Val Loss: 15.8062\n",
      "  New best validation loss: 15.8062\n",
      "Epoch 2/200, Train Loss: 16.9231, Val Loss: 15.9255\n",
      "Epoch 3/200, Train Loss: 16.9197, Val Loss: 15.8274\n",
      "Epoch 4/200, Train Loss: 16.8948, Val Loss: 15.7910\n",
      "  New best validation loss: 15.7910\n",
      "Epoch 5/200, Train Loss: 16.8862, Val Loss: 15.7240\n",
      "  New best validation loss: 15.7240\n",
      "Epoch 6/200, Train Loss: 16.8972, Val Loss: 15.7587\n",
      "Epoch 7/200, Train Loss: 16.8850, Val Loss: 15.7521\n",
      "Epoch 8/200, Train Loss: 16.8738, Val Loss: 15.8257\n",
      "Epoch 9/200, Train Loss: 16.8647, Val Loss: 15.7684\n",
      "Epoch 10/200, Train Loss: 16.8418, Val Loss: 15.7083\n",
      "  New best validation loss: 15.7083\n",
      "Epoch 11/200, Train Loss: 16.8452, Val Loss: 15.6354\n",
      "  New best validation loss: 15.6354\n",
      "Epoch 12/200, Train Loss: 16.8154, Val Loss: 15.6088\n",
      "  New best validation loss: 15.6088\n",
      "Epoch 13/200, Train Loss: 16.8257, Val Loss: 15.6644\n",
      "Epoch 14/200, Train Loss: 16.7977, Val Loss: 15.6024\n",
      "  New best validation loss: 15.6024\n",
      "Epoch 15/200, Train Loss: 16.7781, Val Loss: 15.6373\n",
      "Epoch 16/200, Train Loss: 16.7465, Val Loss: 15.5505\n",
      "  New best validation loss: 15.5505\n",
      "Epoch 17/200, Train Loss: 16.7399, Val Loss: 15.5058\n",
      "  New best validation loss: 15.5058\n",
      "Epoch 18/200, Train Loss: 16.7116, Val Loss: 15.5042\n",
      "  New best validation loss: 15.5042\n",
      "Epoch 19/200, Train Loss: 16.6882, Val Loss: 15.5052\n",
      "Epoch 20/200, Train Loss: 16.5804, Val Loss: 15.1344\n",
      "  New best validation loss: 15.1344\n",
      "Epoch 21/200, Train Loss: 16.0736, Val Loss: 14.5261\n",
      "  New best validation loss: 14.5261\n",
      "Epoch 22/200, Train Loss: 15.3601, Val Loss: 12.8843\n",
      "  New best validation loss: 12.8843\n",
      "Epoch 23/200, Train Loss: 14.4584, Val Loss: 11.8866\n",
      "  New best validation loss: 11.8866\n",
      "Epoch 24/200, Train Loss: 13.7688, Val Loss: 11.6340\n",
      "  New best validation loss: 11.6340\n",
      "Epoch 25/200, Train Loss: 13.3428, Val Loss: 11.3613\n",
      "  New best validation loss: 11.3613\n",
      "Epoch 26/200, Train Loss: 13.0023, Val Loss: 11.1443\n",
      "  New best validation loss: 11.1443\n",
      "Epoch 27/200, Train Loss: 12.8488, Val Loss: 10.9183\n",
      "  New best validation loss: 10.9183\n",
      "Epoch 28/200, Train Loss: 12.6529, Val Loss: 10.7604\n",
      "  New best validation loss: 10.7604\n",
      "Epoch 29/200, Train Loss: 12.5122, Val Loss: 10.7431\n",
      "  New best validation loss: 10.7431\n",
      "Epoch 30/200, Train Loss: 12.4271, Val Loss: 10.6195\n",
      "  New best validation loss: 10.6195\n",
      "Epoch 31/200, Train Loss: 12.3908, Val Loss: 10.6516\n",
      "Epoch 32/200, Train Loss: 12.2394, Val Loss: 10.6089\n",
      "  New best validation loss: 10.6089\n",
      "Epoch 33/200, Train Loss: 12.1751, Val Loss: 10.5142\n",
      "  New best validation loss: 10.5142\n",
      "Epoch 34/200, Train Loss: 12.1348, Val Loss: 10.3629\n",
      "  New best validation loss: 10.3629\n",
      "Epoch 35/200, Train Loss: 12.0493, Val Loss: 10.3762\n",
      "Epoch 36/200, Train Loss: 11.9278, Val Loss: 10.3186\n",
      "  New best validation loss: 10.3186\n",
      "Epoch 37/200, Train Loss: 11.8748, Val Loss: 10.5511\n",
      "Epoch 38/200, Train Loss: 11.8623, Val Loss: 10.3683\n",
      "Epoch 39/200, Train Loss: 11.7801, Val Loss: 10.1803\n",
      "  New best validation loss: 10.1803\n",
      "Epoch 40/200, Train Loss: 11.7712, Val Loss: 10.3158\n",
      "Epoch 41/200, Train Loss: 11.7170, Val Loss: 10.2177\n",
      "Epoch 42/200, Train Loss: 11.6429, Val Loss: 10.1239\n",
      "  New best validation loss: 10.1239\n",
      "Epoch 43/200, Train Loss: 11.6531, Val Loss: 10.1302\n",
      "Epoch 44/200, Train Loss: 11.6010, Val Loss: 10.0070\n",
      "  New best validation loss: 10.0070\n",
      "Epoch 45/200, Train Loss: 11.6101, Val Loss: 10.1289\n",
      "Epoch 46/200, Train Loss: 11.5245, Val Loss: 10.1154\n",
      "Epoch 47/200, Train Loss: 11.4878, Val Loss: 10.0744\n",
      "Epoch 48/200, Train Loss: 11.5151, Val Loss: 10.0133\n",
      "Epoch 49/200, Train Loss: 11.4935, Val Loss: 10.0858\n",
      "Epoch 50/200, Train Loss: 11.4772, Val Loss: 10.1665\n",
      "Epoch 51/200, Train Loss: 11.3812, Val Loss: 9.8970\n",
      "  New best validation loss: 9.8970\n",
      "Epoch 52/200, Train Loss: 11.3607, Val Loss: 9.9373\n",
      "Epoch 53/200, Train Loss: 11.3518, Val Loss: 9.9259\n",
      "Epoch 54/200, Train Loss: 11.3960, Val Loss: 9.9747\n",
      "Epoch 55/200, Train Loss: 11.3710, Val Loss: 9.9639\n",
      "Epoch 56/200, Train Loss: 11.3136, Val Loss: 10.2420\n",
      "Epoch 57/200, Train Loss: 11.3892, Val Loss: 9.9703\n",
      "Epoch 58/200, Train Loss: 11.3387, Val Loss: 9.9365\n",
      "Epoch 59/200, Train Loss: 11.2685, Val Loss: 9.8578\n",
      "  New best validation loss: 9.8578\n",
      "Epoch 60/200, Train Loss: 11.2721, Val Loss: 9.8909\n",
      "Epoch 61/200, Train Loss: 11.2903, Val Loss: 10.1193\n",
      "Epoch 62/200, Train Loss: 11.2747, Val Loss: 9.8507\n",
      "  New best validation loss: 9.8507\n",
      "Epoch 63/200, Train Loss: 11.2519, Val Loss: 9.9564\n",
      "Epoch 64/200, Train Loss: 11.2412, Val Loss: 9.8385\n",
      "  New best validation loss: 9.8385\n",
      "Epoch 65/200, Train Loss: 11.2018, Val Loss: 9.8624\n",
      "Epoch 66/200, Train Loss: 11.1994, Val Loss: 9.7885\n",
      "  New best validation loss: 9.7885\n",
      "Epoch 67/200, Train Loss: 11.1617, Val Loss: 9.7995\n",
      "Epoch 68/200, Train Loss: 11.2214, Val Loss: 10.0217\n",
      "Epoch 69/200, Train Loss: 11.2214, Val Loss: 9.8982\n",
      "Epoch 70/200, Train Loss: 11.1836, Val Loss: 9.8462\n",
      "Epoch 71/200, Train Loss: 11.2135, Val Loss: 9.7504\n",
      "  New best validation loss: 9.7504\n",
      "Epoch 72/200, Train Loss: 11.1358, Val Loss: 9.7514\n",
      "Epoch 73/200, Train Loss: 11.1650, Val Loss: 9.9710\n",
      "Epoch 74/200, Train Loss: 11.1626, Val Loss: 9.7505\n",
      "Epoch 75/200, Train Loss: 11.1575, Val Loss: 9.9003\n",
      "Epoch 76/200, Train Loss: 11.1651, Val Loss: 9.7763\n",
      "Epoch 77/200, Train Loss: 11.1581, Val Loss: 9.8736\n",
      "Epoch 78/200, Train Loss: 11.1162, Val Loss: 9.9463\n",
      "Epoch 79/200, Train Loss: 11.1490, Val Loss: 9.8622\n",
      "Epoch 80/200, Train Loss: 11.1093, Val Loss: 9.7702\n",
      "Epoch 81/200, Train Loss: 11.1603, Val Loss: 9.7771\n",
      "Epoch 82/200, Train Loss: 11.1129, Val Loss: 9.9345\n",
      "Epoch 83/200, Train Loss: 11.1141, Val Loss: 9.8711\n",
      "Epoch 84/200, Train Loss: 11.0979, Val Loss: 9.7897\n",
      "Epoch 85/200, Train Loss: 11.1689, Val Loss: 9.7674\n",
      "Epoch 86/200, Train Loss: 11.1008, Val Loss: 9.7841\n",
      "Epoch 87/200, Train Loss: 11.0786, Val Loss: 10.0116\n",
      "Epoch 88/200, Train Loss: 11.0241, Val Loss: 9.9207\n",
      "Epoch 89/200, Train Loss: 11.0526, Val Loss: 9.8250\n",
      "Epoch 90/200, Train Loss: 11.0535, Val Loss: 9.6517\n",
      "  New best validation loss: 9.6517\n",
      "Epoch 91/200, Train Loss: 11.0560, Val Loss: 9.6812\n",
      "Epoch 92/200, Train Loss: 11.0082, Val Loss: 9.6084\n",
      "  New best validation loss: 9.6084\n",
      "Epoch 93/200, Train Loss: 11.0354, Val Loss: 9.7935\n",
      "Epoch 94/200, Train Loss: 11.0570, Val Loss: 9.6939\n",
      "Epoch 95/200, Train Loss: 11.0429, Val Loss: 9.7760\n",
      "Epoch 96/200, Train Loss: 11.0377, Val Loss: 9.6626\n",
      "Epoch 97/200, Train Loss: 11.0588, Val Loss: 9.7468\n",
      "Epoch 98/200, Train Loss: 11.0133, Val Loss: 9.6037\n",
      "  New best validation loss: 9.6037\n",
      "Epoch 99/200, Train Loss: 10.9742, Val Loss: 9.6377\n",
      "Epoch 100/200, Train Loss: 10.9737, Val Loss: 9.6972\n",
      "Epoch 101/200, Train Loss: 11.0720, Val Loss: 9.8876\n",
      "Epoch 102/200, Train Loss: 11.0014, Val Loss: 9.6586\n",
      "Epoch 103/200, Train Loss: 10.9714, Val Loss: 9.6753\n",
      "Epoch 104/200, Train Loss: 11.0333, Val Loss: 9.7814\n",
      "Epoch 105/200, Train Loss: 11.0217, Val Loss: 9.6740\n",
      "Epoch 106/200, Train Loss: 10.9492, Val Loss: 9.6527\n",
      "Epoch 107/200, Train Loss: 11.0166, Val Loss: 9.5275\n",
      "  New best validation loss: 9.5275\n",
      "Epoch 108/200, Train Loss: 11.0128, Val Loss: 9.6544\n",
      "Epoch 109/200, Train Loss: 10.9754, Val Loss: 9.5896\n",
      "Epoch 110/200, Train Loss: 10.9862, Val Loss: 9.6206\n",
      "Epoch 111/200, Train Loss: 10.9529, Val Loss: 9.7804\n",
      "Epoch 112/200, Train Loss: 10.9307, Val Loss: 9.6564\n",
      "Epoch 113/200, Train Loss: 10.9647, Val Loss: 9.6391\n",
      "Epoch 114/200, Train Loss: 10.9860, Val Loss: 9.8113\n",
      "Epoch 115/200, Train Loss: 10.9481, Val Loss: 9.6348\n",
      "Epoch 116/200, Train Loss: 10.9917, Val Loss: 9.5285\n",
      "Epoch 117/200, Train Loss: 10.9816, Val Loss: 9.6850\n",
      "Epoch 118/200, Train Loss: 10.9059, Val Loss: 9.5842\n",
      "Epoch 119/200, Train Loss: 10.9155, Val Loss: 9.6590\n",
      "Epoch 120/200, Train Loss: 11.0063, Val Loss: 9.5672\n",
      "Epoch 121/200, Train Loss: 10.9118, Val Loss: 9.4304\n",
      "  New best validation loss: 9.4304\n",
      "Epoch 122/200, Train Loss: 10.9167, Val Loss: 9.4859\n",
      "Epoch 123/200, Train Loss: 10.9444, Val Loss: 9.5289\n",
      "Epoch 124/200, Train Loss: 10.9441, Val Loss: 9.5993\n",
      "Epoch 125/200, Train Loss: 10.9444, Val Loss: 9.6382\n",
      "Epoch 126/200, Train Loss: 10.9063, Val Loss: 9.5905\n",
      "Epoch 127/200, Train Loss: 10.9200, Val Loss: 9.6520\n",
      "Epoch 128/200, Train Loss: 10.9392, Val Loss: 9.5491\n",
      "Epoch 129/200, Train Loss: 10.8758, Val Loss: 9.5165\n",
      "Epoch 130/200, Train Loss: 10.9282, Val Loss: 9.5201\n",
      "Epoch 131/200, Train Loss: 10.9243, Val Loss: 9.4905\n",
      "Epoch 132/200, Train Loss: 10.8228, Val Loss: 9.5477\n",
      "Epoch 133/200, Train Loss: 10.8717, Val Loss: 9.5942\n",
      "Epoch 134/200, Train Loss: 10.9704, Val Loss: 9.5266\n",
      "Epoch 135/200, Train Loss: 10.8746, Val Loss: 9.6833\n",
      "Epoch 136/200, Train Loss: 10.9166, Val Loss: 9.4683\n",
      "Epoch 137/200, Train Loss: 10.8759, Val Loss: 9.3981\n",
      "  New best validation loss: 9.3981\n",
      "Epoch 138/200, Train Loss: 10.8700, Val Loss: 9.3987\n",
      "Epoch 139/200, Train Loss: 10.8823, Val Loss: 9.3954\n",
      "  New best validation loss: 9.3954\n",
      "Epoch 140/200, Train Loss: 10.8596, Val Loss: 9.5109\n",
      "Epoch 141/200, Train Loss: 10.8901, Val Loss: 9.4350\n",
      "Epoch 142/200, Train Loss: 10.8680, Val Loss: 9.3448\n",
      "  New best validation loss: 9.3448\n",
      "Epoch 143/200, Train Loss: 10.9014, Val Loss: 9.5417\n",
      "Epoch 144/200, Train Loss: 10.8538, Val Loss: 9.5255\n",
      "Epoch 145/200, Train Loss: 10.8378, Val Loss: 9.2914\n",
      "  New best validation loss: 9.2914\n",
      "Epoch 146/200, Train Loss: 10.8273, Val Loss: 9.4507\n",
      "Epoch 147/200, Train Loss: 10.8905, Val Loss: 9.4417\n",
      "Epoch 148/200, Train Loss: 10.8560, Val Loss: 9.4476\n",
      "Epoch 149/200, Train Loss: 10.8295, Val Loss: 9.5243\n",
      "Epoch 150/200, Train Loss: 10.8209, Val Loss: 9.3355\n",
      "Epoch 151/200, Train Loss: 10.8807, Val Loss: 9.6559\n",
      "Epoch 152/200, Train Loss: 10.8284, Val Loss: 9.4614\n",
      "Epoch 153/200, Train Loss: 10.8252, Val Loss: 9.4891\n",
      "Epoch 154/200, Train Loss: 10.8694, Val Loss: 9.5274\n",
      "Epoch 155/200, Train Loss: 10.8461, Val Loss: 9.3635\n",
      "Epoch 156/200, Train Loss: 10.8064, Val Loss: 9.4983\n",
      "Epoch 157/200, Train Loss: 10.8329, Val Loss: 9.4741\n",
      "Epoch 158/200, Train Loss: 10.8291, Val Loss: 9.4507\n",
      "Epoch 159/200, Train Loss: 10.7843, Val Loss: 9.5170\n",
      "Epoch 160/200, Train Loss: 10.8981, Val Loss: 9.5042\n",
      "Epoch 161/200, Train Loss: 10.7836, Val Loss: 9.3797\n",
      "Epoch 162/200, Train Loss: 10.8432, Val Loss: 9.4028\n",
      "Epoch 163/200, Train Loss: 10.8129, Val Loss: 9.4010\n",
      "Epoch 164/200, Train Loss: 10.8258, Val Loss: 9.4152\n",
      "Epoch 165/200, Train Loss: 10.8329, Val Loss: 9.6026\n",
      "Epoch 166/200, Train Loss: 10.8282, Val Loss: 9.4234\n",
      "Epoch 167/200, Train Loss: 10.8389, Val Loss: 9.3943\n",
      "Epoch 168/200, Train Loss: 10.8436, Val Loss: 9.5181\n",
      "Epoch 169/200, Train Loss: 10.8107, Val Loss: 9.4205\n",
      "Epoch 170/200, Train Loss: 10.7893, Val Loss: 9.4753\n",
      "Epoch 171/200, Train Loss: 10.7985, Val Loss: 9.2884\n",
      "  New best validation loss: 9.2884\n",
      "Epoch 172/200, Train Loss: 10.8118, Val Loss: 9.3988\n",
      "Epoch 173/200, Train Loss: 10.8312, Val Loss: 9.2752\n",
      "  New best validation loss: 9.2752\n",
      "Epoch 174/200, Train Loss: 10.7612, Val Loss: 9.2091\n",
      "  New best validation loss: 9.2091\n",
      "Epoch 175/200, Train Loss: 10.7918, Val Loss: 9.3966\n",
      "Epoch 176/200, Train Loss: 10.7670, Val Loss: 9.2605\n",
      "Epoch 177/200, Train Loss: 10.7661, Val Loss: 9.3505\n",
      "Epoch 178/200, Train Loss: 10.7883, Val Loss: 9.3881\n",
      "Epoch 179/200, Train Loss: 10.7864, Val Loss: 9.3197\n",
      "Epoch 180/200, Train Loss: 10.8014, Val Loss: 9.4519\n",
      "Epoch 181/200, Train Loss: 10.7767, Val Loss: 9.3589\n",
      "Epoch 182/200, Train Loss: 10.7861, Val Loss: 9.3933\n",
      "Epoch 183/200, Train Loss: 10.7856, Val Loss: 9.4166\n",
      "Epoch 184/200, Train Loss: 10.7172, Val Loss: 9.3583\n",
      "Epoch 185/200, Train Loss: 10.7843, Val Loss: 9.3485\n",
      "Epoch 186/200, Train Loss: 10.7229, Val Loss: 9.3666\n",
      "Epoch 187/200, Train Loss: 10.8089, Val Loss: 9.3562\n",
      "Epoch 188/200, Train Loss: 10.8042, Val Loss: 9.4098\n",
      "Epoch 189/200, Train Loss: 10.7735, Val Loss: 9.3499\n",
      "Epoch 190/200, Train Loss: 10.7898, Val Loss: 9.3613\n",
      "Epoch 191/200, Train Loss: 10.7731, Val Loss: 9.3516\n",
      "Epoch 192/200, Train Loss: 10.8437, Val Loss: 9.3905\n",
      "Epoch 193/200, Train Loss: 10.7839, Val Loss: 9.3094\n",
      "Epoch 194/200, Train Loss: 10.7896, Val Loss: 9.4777\n",
      "Epoch 195/200, Train Loss: 10.7528, Val Loss: 9.4260\n",
      "Epoch 196/200, Train Loss: 10.7930, Val Loss: 9.3470\n",
      "Epoch 197/200, Train Loss: 10.7723, Val Loss: 9.2982\n",
      "Epoch 198/200, Train Loss: 10.7831, Val Loss: 9.2853\n",
      "Epoch 199/200, Train Loss: 10.7770, Val Loss: 9.2953\n",
      "Epoch 200/200, Train Loss: 10.7918, Val Loss: 9.3741\n",
      "\n",
      "Loaded best model (Val Loss: 9.2091) for final hidden state extraction.\n",
      "Saved best model for Transformer (samples=2400) to results_data_size_sweep/20250514_045146/samples_2400/Transformer_samples_2400_best.pt\n",
      "\n",
      "--- Performing Decodability Analysis for Transformer (samples=2400, k=15) ---\n",
      "  Analyzing decodability for Transformer...\n",
      "  Hidden states shape: torch.Size([160, 200, 20])\n",
      "  Coefficients shape: torch.Size([160, 15])\n",
      "  Processed hidden states shape for decoder: torch.Size([160, 20])\n",
      "  RidgeCV Decoder for Transformer - Test MSE: 1.2504, Test R2: 0.3777 (best alpha: 0.0695)\n",
      "  Decodability plot saved to results_data_size_sweep/20250514_045146/samples_2400/decodability_Transformer_coeff1.png\n",
      "Decodability (R2 score) for Transformer (samples=2400): 0.3777\n",
      "\n",
      "--- Training TransformerCausal (samples=2400, k=15) ---\n",
      "Number of parameters: 85809\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/conda/lib/python3.10/site-packages/torch/nn/modules/activation.py:1160: UserWarning: Converting mask without torch.bool dtype to bool; this will negatively affect performance. Prefer to use a boolean mask directly. (Triggered internally at /opt/conda/conda-bld/pytorch_1682343995026/work/aten/src/ATen/native/transformers/attention.cpp:150.)\n",
      "  return torch._native_multi_head_attention(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/200, Train Loss: 17.1714, Val Loss: 15.7779\n",
      "  New best validation loss: 15.7779\n",
      "Epoch 2/200, Train Loss: 16.8840, Val Loss: 15.7913\n",
      "Epoch 3/200, Train Loss: 16.8507, Val Loss: 15.7632\n",
      "  New best validation loss: 15.7632\n",
      "Epoch 4/200, Train Loss: 16.8366, Val Loss: 15.7267\n",
      "  New best validation loss: 15.7267\n",
      "Epoch 5/200, Train Loss: 16.8133, Val Loss: 15.7759\n",
      "Epoch 6/200, Train Loss: 16.7883, Val Loss: 15.9152\n",
      "Epoch 7/200, Train Loss: 16.7993, Val Loss: 15.8033\n",
      "Epoch 8/200, Train Loss: 16.7770, Val Loss: 15.6942\n",
      "  New best validation loss: 15.6942\n",
      "Epoch 9/200, Train Loss: 16.7605, Val Loss: 15.6577\n",
      "  New best validation loss: 15.6577\n",
      "Epoch 10/200, Train Loss: 16.7401, Val Loss: 15.6820\n",
      "Epoch 11/200, Train Loss: 16.7212, Val Loss: 15.6093\n",
      "  New best validation loss: 15.6093\n",
      "Epoch 12/200, Train Loss: 16.6928, Val Loss: 15.5730\n",
      "  New best validation loss: 15.5730\n",
      "Epoch 13/200, Train Loss: 16.6915, Val Loss: 15.5872\n",
      "Epoch 14/200, Train Loss: 16.6596, Val Loss: 15.5920\n",
      "Epoch 15/200, Train Loss: 16.6574, Val Loss: 15.5397\n",
      "  New best validation loss: 15.5397\n",
      "Epoch 16/200, Train Loss: 16.6293, Val Loss: 15.4875\n",
      "  New best validation loss: 15.4875\n",
      "Epoch 17/200, Train Loss: 16.6197, Val Loss: 15.4963\n",
      "Epoch 18/200, Train Loss: 16.5822, Val Loss: 15.4074\n",
      "  New best validation loss: 15.4074\n",
      "Epoch 19/200, Train Loss: 16.5390, Val Loss: 15.4286\n",
      "Epoch 20/200, Train Loss: 16.5489, Val Loss: 15.3659\n",
      "  New best validation loss: 15.3659\n",
      "Epoch 21/200, Train Loss: 16.4733, Val Loss: 15.2778\n",
      "  New best validation loss: 15.2778\n",
      "Epoch 22/200, Train Loss: 16.4535, Val Loss: 15.1989\n",
      "  New best validation loss: 15.1989\n",
      "Epoch 23/200, Train Loss: 16.4182, Val Loss: 15.2118\n",
      "Epoch 24/200, Train Loss: 16.4034, Val Loss: 15.2441\n",
      "Epoch 25/200, Train Loss: 16.3742, Val Loss: 15.1536\n",
      "  New best validation loss: 15.1536\n",
      "Epoch 26/200, Train Loss: 16.3091, Val Loss: 15.1694\n",
      "Epoch 27/200, Train Loss: 16.2897, Val Loss: 15.0518\n",
      "  New best validation loss: 15.0518\n",
      "Epoch 28/200, Train Loss: 16.2523, Val Loss: 15.0774\n",
      "Epoch 29/200, Train Loss: 16.2113, Val Loss: 15.0389\n",
      "  New best validation loss: 15.0389\n",
      "Epoch 30/200, Train Loss: 16.1431, Val Loss: 14.9671\n",
      "  New best validation loss: 14.9671\n",
      "Epoch 31/200, Train Loss: 16.0823, Val Loss: 14.8373\n",
      "  New best validation loss: 14.8373\n",
      "Epoch 32/200, Train Loss: 16.0051, Val Loss: 14.8222\n",
      "  New best validation loss: 14.8222\n",
      "Epoch 33/200, Train Loss: 15.9638, Val Loss: 14.7249\n",
      "  New best validation loss: 14.7249\n",
      "Epoch 34/200, Train Loss: 15.8500, Val Loss: 14.6820\n",
      "  New best validation loss: 14.6820\n",
      "Epoch 35/200, Train Loss: 15.7753, Val Loss: 14.5184\n",
      "  New best validation loss: 14.5184\n",
      "Epoch 36/200, Train Loss: 15.6288, Val Loss: 14.4441\n",
      "  New best validation loss: 14.4441\n",
      "Epoch 37/200, Train Loss: 15.5036, Val Loss: 14.3523\n",
      "  New best validation loss: 14.3523\n",
      "Epoch 38/200, Train Loss: 15.3540, Val Loss: 14.0737\n",
      "  New best validation loss: 14.0737\n",
      "Epoch 39/200, Train Loss: 15.1680, Val Loss: 13.9245\n",
      "  New best validation loss: 13.9245\n",
      "Epoch 40/200, Train Loss: 15.0381, Val Loss: 13.7872\n",
      "  New best validation loss: 13.7872\n",
      "Epoch 41/200, Train Loss: 14.9606, Val Loss: 13.8889\n",
      "Epoch 42/200, Train Loss: 14.8495, Val Loss: 13.5626\n",
      "  New best validation loss: 13.5626\n",
      "Epoch 43/200, Train Loss: 14.7541, Val Loss: 13.4095\n",
      "  New best validation loss: 13.4095\n",
      "Epoch 44/200, Train Loss: 14.6655, Val Loss: 13.4419\n",
      "Epoch 45/200, Train Loss: 14.6027, Val Loss: 13.1784\n",
      "  New best validation loss: 13.1784\n",
      "Epoch 46/200, Train Loss: 14.4477, Val Loss: 13.1909\n",
      "Epoch 47/200, Train Loss: 14.4212, Val Loss: 13.0667\n",
      "  New best validation loss: 13.0667\n",
      "Epoch 48/200, Train Loss: 14.2967, Val Loss: 13.0694\n",
      "Epoch 49/200, Train Loss: 14.3108, Val Loss: 12.9420\n",
      "  New best validation loss: 12.9420\n",
      "Epoch 50/200, Train Loss: 14.2096, Val Loss: 12.8967\n",
      "  New best validation loss: 12.8967\n",
      "Epoch 51/200, Train Loss: 14.1853, Val Loss: 12.9290\n",
      "Epoch 52/200, Train Loss: 14.1654, Val Loss: 12.8049\n",
      "  New best validation loss: 12.8049\n",
      "Epoch 53/200, Train Loss: 14.0811, Val Loss: 12.8919\n",
      "Epoch 54/200, Train Loss: 14.0618, Val Loss: 12.7128\n",
      "  New best validation loss: 12.7128\n",
      "Epoch 55/200, Train Loss: 14.0906, Val Loss: 12.7766\n",
      "Epoch 56/200, Train Loss: 14.0291, Val Loss: 12.7089\n",
      "  New best validation loss: 12.7089\n",
      "Epoch 57/200, Train Loss: 13.9984, Val Loss: 12.7516\n",
      "Epoch 58/200, Train Loss: 14.0362, Val Loss: 12.7295\n",
      "Epoch 59/200, Train Loss: 14.0050, Val Loss: 12.7729\n",
      "Epoch 60/200, Train Loss: 13.9321, Val Loss: 12.7240\n",
      "Epoch 61/200, Train Loss: 13.9393, Val Loss: 12.6590\n",
      "  New best validation loss: 12.6590\n",
      "Epoch 62/200, Train Loss: 13.9325, Val Loss: 12.6498\n",
      "  New best validation loss: 12.6498\n",
      "Epoch 63/200, Train Loss: 13.9088, Val Loss: 12.5643\n",
      "  New best validation loss: 12.5643\n",
      "Epoch 64/200, Train Loss: 13.8907, Val Loss: 12.6424\n",
      "Epoch 65/200, Train Loss: 13.8908, Val Loss: 12.5836\n",
      "Epoch 66/200, Train Loss: 13.8904, Val Loss: 12.6079\n",
      "Epoch 67/200, Train Loss: 13.8629, Val Loss: 12.5436\n",
      "  New best validation loss: 12.5436\n",
      "Epoch 68/200, Train Loss: 13.8731, Val Loss: 12.6287\n",
      "Epoch 69/200, Train Loss: 13.8547, Val Loss: 12.6376\n",
      "Epoch 70/200, Train Loss: 13.8273, Val Loss: 12.5623\n",
      "Epoch 71/200, Train Loss: 13.8701, Val Loss: 12.4481\n",
      "  New best validation loss: 12.4481\n",
      "Epoch 72/200, Train Loss: 13.7816, Val Loss: 12.4599\n",
      "Epoch 73/200, Train Loss: 13.8132, Val Loss: 12.4973\n",
      "Epoch 74/200, Train Loss: 13.8578, Val Loss: 12.5905\n",
      "Epoch 75/200, Train Loss: 13.7948, Val Loss: 12.5564\n",
      "Epoch 76/200, Train Loss: 13.8066, Val Loss: 12.4654\n",
      "Epoch 77/200, Train Loss: 13.7873, Val Loss: 12.4721\n",
      "Epoch 78/200, Train Loss: 13.7880, Val Loss: 12.5745\n",
      "Epoch 79/200, Train Loss: 13.7645, Val Loss: 12.5338\n",
      "Epoch 80/200, Train Loss: 13.7637, Val Loss: 12.6528\n",
      "Epoch 81/200, Train Loss: 13.7926, Val Loss: 12.5885\n",
      "Epoch 82/200, Train Loss: 13.7897, Val Loss: 12.4261\n",
      "  New best validation loss: 12.4261\n",
      "Epoch 83/200, Train Loss: 13.7674, Val Loss: 12.5319\n",
      "Epoch 84/200, Train Loss: 13.7378, Val Loss: 12.5652\n",
      "Epoch 85/200, Train Loss: 13.7944, Val Loss: 12.4687\n",
      "Epoch 86/200, Train Loss: 13.7416, Val Loss: 12.4342\n",
      "Epoch 87/200, Train Loss: 13.7421, Val Loss: 12.4779\n",
      "Epoch 88/200, Train Loss: 13.8052, Val Loss: 12.5102\n",
      "Epoch 89/200, Train Loss: 13.7268, Val Loss: 12.5125\n",
      "Epoch 90/200, Train Loss: 13.7081, Val Loss: 12.4794\n",
      "Epoch 91/200, Train Loss: 13.7247, Val Loss: 12.4841\n",
      "Epoch 92/200, Train Loss: 13.6796, Val Loss: 12.4729\n",
      "Epoch 93/200, Train Loss: 13.7401, Val Loss: 12.4763\n",
      "Epoch 94/200, Train Loss: 13.6913, Val Loss: 12.4432\n",
      "Epoch 95/200, Train Loss: 13.6802, Val Loss: 12.4109\n",
      "  New best validation loss: 12.4109\n",
      "Epoch 96/200, Train Loss: 13.6630, Val Loss: 12.4852\n",
      "Epoch 97/200, Train Loss: 13.6877, Val Loss: 12.4194\n",
      "Epoch 98/200, Train Loss: 13.7036, Val Loss: 12.4784\n",
      "Epoch 99/200, Train Loss: 13.6957, Val Loss: 12.3988\n",
      "  New best validation loss: 12.3988\n",
      "Epoch 100/200, Train Loss: 13.6910, Val Loss: 12.4302\n",
      "Epoch 101/200, Train Loss: 13.6827, Val Loss: 12.4338\n",
      "Epoch 102/200, Train Loss: 13.6664, Val Loss: 12.4816\n",
      "Epoch 103/200, Train Loss: 13.7137, Val Loss: 12.4803\n",
      "Epoch 104/200, Train Loss: 13.6721, Val Loss: 12.4332\n",
      "Epoch 105/200, Train Loss: 13.6819, Val Loss: 12.3418\n",
      "  New best validation loss: 12.3418\n",
      "Epoch 106/200, Train Loss: 13.6424, Val Loss: 12.3817\n",
      "Epoch 107/200, Train Loss: 13.6462, Val Loss: 12.3404\n",
      "  New best validation loss: 12.3404\n",
      "Epoch 108/200, Train Loss: 13.6494, Val Loss: 12.3351\n",
      "  New best validation loss: 12.3351\n",
      "Epoch 109/200, Train Loss: 13.6433, Val Loss: 12.3421\n",
      "Epoch 110/200, Train Loss: 13.6763, Val Loss: 12.4274\n",
      "Epoch 111/200, Train Loss: 13.6487, Val Loss: 12.4005\n",
      "Epoch 112/200, Train Loss: 13.6521, Val Loss: 12.3507\n",
      "Epoch 113/200, Train Loss: 13.6588, Val Loss: 12.4043\n",
      "Epoch 114/200, Train Loss: 13.6581, Val Loss: 12.3848\n",
      "Epoch 115/200, Train Loss: 13.6413, Val Loss: 12.4401\n",
      "Epoch 116/200, Train Loss: 13.6702, Val Loss: 12.3802\n",
      "Epoch 117/200, Train Loss: 13.6513, Val Loss: 12.4898\n",
      "Epoch 118/200, Train Loss: 13.6644, Val Loss: 12.2526\n",
      "  New best validation loss: 12.2526\n",
      "Epoch 119/200, Train Loss: 13.6522, Val Loss: 12.4171\n",
      "Epoch 120/200, Train Loss: 13.6525, Val Loss: 12.4203\n",
      "Epoch 121/200, Train Loss: 13.6460, Val Loss: 12.4706\n",
      "Epoch 122/200, Train Loss: 13.6161, Val Loss: 12.3366\n",
      "Epoch 123/200, Train Loss: 13.6582, Val Loss: 12.5250\n",
      "Epoch 124/200, Train Loss: 13.6412, Val Loss: 12.3649\n",
      "Epoch 125/200, Train Loss: 13.6184, Val Loss: 12.3854\n",
      "Epoch 126/200, Train Loss: 13.6059, Val Loss: 12.2736\n",
      "Epoch 127/200, Train Loss: 13.6454, Val Loss: 12.4789\n",
      "Epoch 128/200, Train Loss: 13.6569, Val Loss: 12.3285\n",
      "Epoch 129/200, Train Loss: 13.6311, Val Loss: 12.4340\n",
      "Epoch 130/200, Train Loss: 13.5984, Val Loss: 12.4448\n",
      "Epoch 131/200, Train Loss: 13.5903, Val Loss: 12.2954\n",
      "Epoch 132/200, Train Loss: 13.5831, Val Loss: 12.2395\n",
      "  New best validation loss: 12.2395\n",
      "Epoch 133/200, Train Loss: 13.5995, Val Loss: 12.2725\n",
      "Epoch 134/200, Train Loss: 13.6100, Val Loss: 12.3013\n",
      "Epoch 135/200, Train Loss: 13.5894, Val Loss: 12.3431\n",
      "Epoch 136/200, Train Loss: 13.6589, Val Loss: 12.2876\n",
      "Epoch 137/200, Train Loss: 13.5661, Val Loss: 12.2843\n",
      "Epoch 138/200, Train Loss: 13.5743, Val Loss: 12.2956\n",
      "Epoch 139/200, Train Loss: 13.5740, Val Loss: 12.3438\n",
      "Epoch 140/200, Train Loss: 13.5882, Val Loss: 12.2896\n",
      "Epoch 141/200, Train Loss: 13.5714, Val Loss: 12.2891\n",
      "Epoch 142/200, Train Loss: 13.5737, Val Loss: 12.2793\n",
      "Epoch 143/200, Train Loss: 13.5658, Val Loss: 12.3067\n",
      "Epoch 144/200, Train Loss: 13.5375, Val Loss: 12.2804\n",
      "Epoch 145/200, Train Loss: 13.5587, Val Loss: 12.3753\n",
      "Epoch 146/200, Train Loss: 13.5585, Val Loss: 12.2195\n",
      "  New best validation loss: 12.2195\n",
      "Epoch 147/200, Train Loss: 13.5583, Val Loss: 12.3412\n",
      "Epoch 148/200, Train Loss: 13.5672, Val Loss: 12.2081\n",
      "  New best validation loss: 12.2081\n",
      "Epoch 149/200, Train Loss: 13.5813, Val Loss: 12.3812\n",
      "Epoch 150/200, Train Loss: 13.5583, Val Loss: 12.2738\n",
      "Epoch 151/200, Train Loss: 13.5149, Val Loss: 12.2690\n",
      "Epoch 152/200, Train Loss: 13.5313, Val Loss: 12.2006\n",
      "  New best validation loss: 12.2006\n",
      "Epoch 153/200, Train Loss: 13.5441, Val Loss: 12.2139\n",
      "Epoch 154/200, Train Loss: 13.5277, Val Loss: 12.3038\n",
      "Epoch 155/200, Train Loss: 13.5258, Val Loss: 12.3448\n",
      "Epoch 156/200, Train Loss: 13.5713, Val Loss: 12.2406\n",
      "Epoch 157/200, Train Loss: 13.5551, Val Loss: 12.2656\n",
      "Epoch 158/200, Train Loss: 13.5395, Val Loss: 12.2001\n",
      "  New best validation loss: 12.2001\n",
      "Epoch 159/200, Train Loss: 13.5324, Val Loss: 12.2664\n",
      "Epoch 160/200, Train Loss: 13.5489, Val Loss: 12.3592\n",
      "Epoch 161/200, Train Loss: 13.5220, Val Loss: 12.2168\n",
      "Epoch 162/200, Train Loss: 13.5240, Val Loss: 12.1638\n",
      "  New best validation loss: 12.1638\n",
      "Epoch 163/200, Train Loss: 13.5333, Val Loss: 12.2260\n",
      "Epoch 164/200, Train Loss: 13.5431, Val Loss: 12.1950\n",
      "Epoch 165/200, Train Loss: 13.5172, Val Loss: 12.1702\n",
      "Epoch 166/200, Train Loss: 13.5335, Val Loss: 12.2436\n",
      "Epoch 167/200, Train Loss: 13.5345, Val Loss: 12.2381\n",
      "Epoch 168/200, Train Loss: 13.5128, Val Loss: 12.2618\n",
      "Epoch 169/200, Train Loss: 13.4865, Val Loss: 12.2417\n",
      "Epoch 170/200, Train Loss: 13.4814, Val Loss: 12.2258\n",
      "Epoch 171/200, Train Loss: 13.5050, Val Loss: 12.2883\n",
      "Epoch 172/200, Train Loss: 13.5279, Val Loss: 12.1810\n",
      "Epoch 173/200, Train Loss: 13.5225, Val Loss: 12.2408\n",
      "Epoch 174/200, Train Loss: 13.4942, Val Loss: 12.2638\n",
      "Epoch 175/200, Train Loss: 13.4960, Val Loss: 12.1594\n",
      "  New best validation loss: 12.1594\n",
      "Epoch 176/200, Train Loss: 13.4915, Val Loss: 12.1056\n",
      "  New best validation loss: 12.1056\n",
      "Epoch 177/200, Train Loss: 13.4781, Val Loss: 12.1227\n",
      "Epoch 178/200, Train Loss: 13.4652, Val Loss: 12.1229\n",
      "Epoch 179/200, Train Loss: 13.4783, Val Loss: 12.2625\n",
      "Epoch 180/200, Train Loss: 13.4747, Val Loss: 12.1505\n",
      "Epoch 181/200, Train Loss: 13.4609, Val Loss: 12.1787\n",
      "Epoch 182/200, Train Loss: 13.4979, Val Loss: 12.1149\n",
      "Epoch 183/200, Train Loss: 13.4610, Val Loss: 12.1263\n",
      "Epoch 184/200, Train Loss: 13.4533, Val Loss: 12.1207\n",
      "Epoch 185/200, Train Loss: 13.4598, Val Loss: 12.2716\n",
      "Epoch 186/200, Train Loss: 13.4439, Val Loss: 12.1581\n",
      "Epoch 187/200, Train Loss: 13.4532, Val Loss: 12.1908\n",
      "Epoch 188/200, Train Loss: 13.4513, Val Loss: 12.1323\n",
      "Epoch 189/200, Train Loss: 13.4403, Val Loss: 12.1255\n",
      "Epoch 190/200, Train Loss: 13.5140, Val Loss: 12.1542\n",
      "Epoch 191/200, Train Loss: 13.4622, Val Loss: 12.0974\n",
      "  New best validation loss: 12.0974\n",
      "Epoch 192/200, Train Loss: 13.4600, Val Loss: 12.1088\n",
      "Epoch 193/200, Train Loss: 13.4459, Val Loss: 12.1802\n",
      "Epoch 194/200, Train Loss: 13.4162, Val Loss: 12.1215\n",
      "Epoch 195/200, Train Loss: 13.4238, Val Loss: 12.1210\n",
      "Epoch 196/200, Train Loss: 13.4749, Val Loss: 12.1379\n",
      "Epoch 197/200, Train Loss: 13.4734, Val Loss: 12.1201\n",
      "Epoch 198/200, Train Loss: 13.4006, Val Loss: 12.1668\n",
      "Epoch 199/200, Train Loss: 13.4397, Val Loss: 12.0742\n",
      "  New best validation loss: 12.0742\n",
      "Epoch 200/200, Train Loss: 13.3934, Val Loss: 12.0551\n",
      "  New best validation loss: 12.0551\n",
      "\n",
      "Loaded best model (Val Loss: 12.0551) for final hidden state extraction.\n",
      "Saved best model for TransformerCausal (samples=2400) to results_data_size_sweep/20250514_045146/samples_2400/TransformerCausal_samples_2400_best.pt\n",
      "\n",
      "--- Performing Decodability Analysis for TransformerCausal (samples=2400, k=15) ---\n",
      "  Analyzing decodability for TransformerCausal...\n",
      "  Hidden states shape: torch.Size([160, 200, 20])\n",
      "  Coefficients shape: torch.Size([160, 15])\n",
      "  Processed hidden states shape for decoder: torch.Size([160, 20])\n",
      "  RidgeCV Decoder for TransformerCausal - Test MSE: 1.0031, Test R2: 0.4986 (best alpha: 0.1438)\n",
      "  Decodability plot saved to results_data_size_sweep/20250514_045146/samples_2400/decodability_TransformerCausal_coeff1.png\n",
      "Decodability (R2 score) for TransformerCausal (samples=2400): 0.4986\n",
      "\n",
      "--- Training HIPPORNN_LegT (samples=2400, k=15) ---\n",
      "Number of parameters: 4029\n",
      "Epoch 1/200, Train Loss: 17.0954, Val Loss: 15.8377\n",
      "  New best validation loss: 15.8377\n",
      "Epoch 2/200, Train Loss: 17.0109, Val Loss: 15.6881\n",
      "  New best validation loss: 15.6881\n",
      "Epoch 3/200, Train Loss: 16.6413, Val Loss: 15.6283\n",
      "  New best validation loss: 15.6283\n",
      "Epoch 4/200, Train Loss: 16.5454, Val Loss: 15.6395\n",
      "Epoch 5/200, Train Loss: 16.4935, Val Loss: 15.6190\n",
      "  New best validation loss: 15.6190\n",
      "Epoch 6/200, Train Loss: 16.4358, Val Loss: 15.6028\n",
      "  New best validation loss: 15.6028\n",
      "Epoch 7/200, Train Loss: 16.3535, Val Loss: 15.5203\n",
      "  New best validation loss: 15.5203\n",
      "Epoch 8/200, Train Loss: 16.2601, Val Loss: 15.4855\n",
      "  New best validation loss: 15.4855\n",
      "Epoch 9/200, Train Loss: 16.1578, Val Loss: 15.4144\n",
      "  New best validation loss: 15.4144\n",
      "Epoch 10/200, Train Loss: 16.0582, Val Loss: 15.3115\n",
      "  New best validation loss: 15.3115\n",
      "Epoch 11/200, Train Loss: 15.9206, Val Loss: 15.2015\n",
      "  New best validation loss: 15.2015\n",
      "Epoch 12/200, Train Loss: 15.7739, Val Loss: 15.0708\n",
      "  New best validation loss: 15.0708\n",
      "Epoch 13/200, Train Loss: 15.6275, Val Loss: 14.9774\n",
      "  New best validation loss: 14.9774\n",
      "Epoch 14/200, Train Loss: 15.4884, Val Loss: 14.9058\n",
      "  New best validation loss: 14.9058\n",
      "Epoch 15/200, Train Loss: 15.3618, Val Loss: 14.7971\n",
      "  New best validation loss: 14.7971\n",
      "Epoch 16/200, Train Loss: 15.2234, Val Loss: 14.6740\n",
      "  New best validation loss: 14.6740\n",
      "Epoch 17/200, Train Loss: 15.1090, Val Loss: 14.5726\n",
      "  New best validation loss: 14.5726\n",
      "Epoch 18/200, Train Loss: 14.9931, Val Loss: 14.4746\n",
      "  New best validation loss: 14.4746\n",
      "Epoch 19/200, Train Loss: 14.8733, Val Loss: 14.4132\n",
      "  New best validation loss: 14.4132\n",
      "Epoch 20/200, Train Loss: 14.7525, Val Loss: 14.2440\n",
      "  New best validation loss: 14.2440\n",
      "Epoch 21/200, Train Loss: 14.6407, Val Loss: 14.1357\n",
      "  New best validation loss: 14.1357\n",
      "Epoch 22/200, Train Loss: 14.5174, Val Loss: 14.0769\n",
      "  New best validation loss: 14.0769\n",
      "Epoch 23/200, Train Loss: 14.4018, Val Loss: 13.9571\n",
      "  New best validation loss: 13.9571\n",
      "Epoch 24/200, Train Loss: 14.3043, Val Loss: 13.8274\n",
      "  New best validation loss: 13.8274\n",
      "Epoch 25/200, Train Loss: 14.1979, Val Loss: 13.6695\n",
      "  New best validation loss: 13.6695\n",
      "Epoch 26/200, Train Loss: 14.1173, Val Loss: 13.6354\n",
      "  New best validation loss: 13.6354\n",
      "Epoch 27/200, Train Loss: 14.0205, Val Loss: 13.4506\n",
      "  New best validation loss: 13.4506\n",
      "Epoch 28/200, Train Loss: 13.9213, Val Loss: 13.4183\n",
      "  New best validation loss: 13.4183\n",
      "Epoch 29/200, Train Loss: 13.8792, Val Loss: 13.3404\n",
      "  New best validation loss: 13.3404\n",
      "Epoch 30/200, Train Loss: 13.7815, Val Loss: 13.2270\n",
      "  New best validation loss: 13.2270\n",
      "Epoch 31/200, Train Loss: 13.6824, Val Loss: 13.1146\n",
      "  New best validation loss: 13.1146\n",
      "Epoch 32/200, Train Loss: 13.5991, Val Loss: 12.9003\n",
      "  New best validation loss: 12.9003\n",
      "Epoch 33/200, Train Loss: 13.5078, Val Loss: 12.8108\n",
      "  New best validation loss: 12.8108\n",
      "Epoch 34/200, Train Loss: 13.4175, Val Loss: 12.6935\n",
      "  New best validation loss: 12.6935\n",
      "Epoch 35/200, Train Loss: 13.3331, Val Loss: 12.5039\n",
      "  New best validation loss: 12.5039\n",
      "Epoch 36/200, Train Loss: 13.2208, Val Loss: 12.3761\n",
      "  New best validation loss: 12.3761\n",
      "Epoch 37/200, Train Loss: 13.1619, Val Loss: 12.2967\n",
      "  New best validation loss: 12.2967\n",
      "Epoch 38/200, Train Loss: 13.0593, Val Loss: 12.1578\n",
      "  New best validation loss: 12.1578\n",
      "Epoch 39/200, Train Loss: 12.9972, Val Loss: 12.2563\n",
      "Epoch 40/200, Train Loss: 12.9300, Val Loss: 12.0728\n",
      "  New best validation loss: 12.0728\n",
      "Epoch 41/200, Train Loss: 12.8524, Val Loss: 11.9634\n",
      "  New best validation loss: 11.9634\n",
      "Epoch 42/200, Train Loss: 12.7677, Val Loss: 11.9076\n",
      "  New best validation loss: 11.9076\n",
      "Epoch 43/200, Train Loss: 12.7230, Val Loss: 11.9289\n",
      "Epoch 44/200, Train Loss: 12.6520, Val Loss: 11.6463\n",
      "  New best validation loss: 11.6463\n",
      "Epoch 45/200, Train Loss: 12.5703, Val Loss: 11.6563\n",
      "Epoch 46/200, Train Loss: 12.4747, Val Loss: 11.4453\n",
      "  New best validation loss: 11.4453\n",
      "Epoch 47/200, Train Loss: 12.3543, Val Loss: 11.5915\n",
      "Epoch 48/200, Train Loss: 12.2699, Val Loss: 11.3903\n",
      "  New best validation loss: 11.3903\n",
      "Epoch 49/200, Train Loss: 12.2325, Val Loss: 11.2821\n",
      "  New best validation loss: 11.2821\n",
      "Epoch 50/200, Train Loss: 12.1800, Val Loss: 11.1773\n",
      "  New best validation loss: 11.1773\n",
      "Epoch 51/200, Train Loss: 12.1101, Val Loss: 11.1178\n",
      "  New best validation loss: 11.1178\n",
      "Epoch 52/200, Train Loss: 12.0666, Val Loss: 11.1480\n",
      "Epoch 53/200, Train Loss: 12.0147, Val Loss: 11.1163\n",
      "  New best validation loss: 11.1163\n",
      "Epoch 54/200, Train Loss: 11.9736, Val Loss: 11.0948\n",
      "  New best validation loss: 11.0948\n",
      "Epoch 55/200, Train Loss: 11.9259, Val Loss: 11.0776\n",
      "  New best validation loss: 11.0776\n",
      "Epoch 56/200, Train Loss: 11.8894, Val Loss: 11.0142\n",
      "  New best validation loss: 11.0142\n",
      "Epoch 57/200, Train Loss: 11.8426, Val Loss: 10.9814\n",
      "  New best validation loss: 10.9814\n",
      "Epoch 58/200, Train Loss: 11.8158, Val Loss: 11.0913\n",
      "Epoch 59/200, Train Loss: 11.7932, Val Loss: 11.0065\n",
      "Epoch 60/200, Train Loss: 11.7475, Val Loss: 10.7574\n",
      "  New best validation loss: 10.7574\n",
      "Epoch 61/200, Train Loss: 11.6945, Val Loss: 10.8203\n",
      "Epoch 62/200, Train Loss: 11.6705, Val Loss: 10.8073\n",
      "Epoch 63/200, Train Loss: 11.6623, Val Loss: 10.7673\n",
      "Epoch 64/200, Train Loss: 11.6528, Val Loss: 10.7579\n",
      "Epoch 65/200, Train Loss: 11.6172, Val Loss: 10.7536\n",
      "  New best validation loss: 10.7536\n",
      "Epoch 66/200, Train Loss: 11.5492, Val Loss: 11.0445\n",
      "Epoch 67/200, Train Loss: 11.5877, Val Loss: 10.7251\n",
      "  New best validation loss: 10.7251\n",
      "Epoch 68/200, Train Loss: 11.4975, Val Loss: 10.7236\n",
      "  New best validation loss: 10.7236\n",
      "Epoch 69/200, Train Loss: 11.5091, Val Loss: 10.7317\n",
      "Epoch 70/200, Train Loss: 11.5653, Val Loss: 10.7354\n",
      "Epoch 71/200, Train Loss: 11.4753, Val Loss: 10.8653\n",
      "Epoch 72/200, Train Loss: 11.5258, Val Loss: 10.6706\n",
      "  New best validation loss: 10.6706\n",
      "Epoch 73/200, Train Loss: 11.3833, Val Loss: 10.6799\n",
      "Epoch 74/200, Train Loss: 11.4645, Val Loss: 10.8101\n",
      "Epoch 75/200, Train Loss: 11.3893, Val Loss: 10.5628\n",
      "  New best validation loss: 10.5628\n",
      "Epoch 76/200, Train Loss: 11.4345, Val Loss: 10.6362\n",
      "Epoch 77/200, Train Loss: 11.4190, Val Loss: 10.7536\n",
      "Epoch 78/200, Train Loss: 11.2954, Val Loss: 10.5482\n",
      "  New best validation loss: 10.5482\n",
      "Epoch 79/200, Train Loss: 11.2853, Val Loss: 10.6246\n",
      "Epoch 80/200, Train Loss: 11.2771, Val Loss: 10.4825\n",
      "  New best validation loss: 10.4825\n",
      "Epoch 81/200, Train Loss: 11.2498, Val Loss: 10.5517\n",
      "Epoch 82/200, Train Loss: 11.2935, Val Loss: 10.5178\n",
      "Epoch 83/200, Train Loss: 11.2184, Val Loss: 10.6181\n",
      "Epoch 84/200, Train Loss: 11.2383, Val Loss: 10.7557\n",
      "Epoch 85/200, Train Loss: 11.1932, Val Loss: 10.4822\n",
      "  New best validation loss: 10.4822\n",
      "Epoch 86/200, Train Loss: 11.1911, Val Loss: 10.3741\n",
      "  New best validation loss: 10.3741\n",
      "Epoch 87/200, Train Loss: 11.1487, Val Loss: 10.5105\n",
      "Epoch 88/200, Train Loss: 11.1705, Val Loss: 10.3728\n",
      "  New best validation loss: 10.3728\n",
      "Epoch 89/200, Train Loss: 11.0832, Val Loss: 10.2737\n",
      "  New best validation loss: 10.2737\n",
      "Epoch 90/200, Train Loss: 11.0749, Val Loss: 10.5592\n",
      "Epoch 91/200, Train Loss: 11.0949, Val Loss: 10.2946\n",
      "Epoch 92/200, Train Loss: 11.0767, Val Loss: 10.3069\n",
      "Epoch 93/200, Train Loss: 11.0648, Val Loss: 10.2716\n",
      "  New best validation loss: 10.2716\n",
      "Epoch 94/200, Train Loss: 11.0075, Val Loss: 10.2028\n",
      "  New best validation loss: 10.2028\n",
      "Epoch 95/200, Train Loss: 11.0014, Val Loss: 10.3212\n",
      "Epoch 96/200, Train Loss: 11.0030, Val Loss: 10.3538\n",
      "Epoch 97/200, Train Loss: 10.9974, Val Loss: 10.3870\n",
      "Epoch 98/200, Train Loss: 10.9930, Val Loss: 10.2604\n",
      "Epoch 99/200, Train Loss: 10.9634, Val Loss: 10.2543\n",
      "Epoch 100/200, Train Loss: 10.9417, Val Loss: 10.2978\n",
      "Epoch 101/200, Train Loss: 10.9494, Val Loss: 10.2280\n",
      "Epoch 102/200, Train Loss: 10.8746, Val Loss: 10.2723\n",
      "Epoch 103/200, Train Loss: 10.8904, Val Loss: 10.3290\n",
      "Epoch 104/200, Train Loss: 10.8888, Val Loss: 10.2029\n",
      "Epoch 105/200, Train Loss: 10.9056, Val Loss: 10.2639\n",
      "Epoch 106/200, Train Loss: 10.8592, Val Loss: 10.2401\n",
      "Epoch 107/200, Train Loss: 10.9024, Val Loss: 10.2196\n",
      "Epoch 108/200, Train Loss: 10.8321, Val Loss: 10.2025\n",
      "  New best validation loss: 10.2025\n",
      "Epoch 109/200, Train Loss: 10.8579, Val Loss: 10.3356\n",
      "Epoch 110/200, Train Loss: 10.8456, Val Loss: 10.2149\n",
      "Epoch 111/200, Train Loss: 10.8120, Val Loss: 10.1307\n",
      "  New best validation loss: 10.1307\n",
      "Epoch 112/200, Train Loss: 10.7899, Val Loss: 10.1055\n",
      "  New best validation loss: 10.1055\n",
      "Epoch 113/200, Train Loss: 10.7596, Val Loss: 10.2814\n",
      "Epoch 114/200, Train Loss: 10.7931, Val Loss: 10.0928\n",
      "  New best validation loss: 10.0928\n",
      "Epoch 115/200, Train Loss: 10.8095, Val Loss: 10.1316\n",
      "Epoch 116/200, Train Loss: 10.7530, Val Loss: 10.0152\n",
      "  New best validation loss: 10.0152\n",
      "Epoch 117/200, Train Loss: 10.7711, Val Loss: 10.0046\n",
      "  New best validation loss: 10.0046\n",
      "Epoch 118/200, Train Loss: 10.7568, Val Loss: 10.1047\n",
      "Epoch 119/200, Train Loss: 10.7359, Val Loss: 10.0534\n",
      "Epoch 120/200, Train Loss: 10.7335, Val Loss: 10.1338\n",
      "Epoch 121/200, Train Loss: 10.7066, Val Loss: 10.1027\n",
      "Epoch 122/200, Train Loss: 10.7308, Val Loss: 9.9541\n",
      "  New best validation loss: 9.9541\n",
      "Epoch 123/200, Train Loss: 10.6855, Val Loss: 10.1164\n",
      "Epoch 124/200, Train Loss: 10.6696, Val Loss: 9.9571\n",
      "Epoch 125/200, Train Loss: 10.6904, Val Loss: 10.0678\n",
      "Epoch 126/200, Train Loss: 10.6944, Val Loss: 9.9750\n",
      "Epoch 127/200, Train Loss: 10.6940, Val Loss: 10.2812\n",
      "Epoch 128/200, Train Loss: 10.7186, Val Loss: 10.0827\n",
      "Epoch 129/200, Train Loss: 10.7091, Val Loss: 10.0737\n",
      "Epoch 130/200, Train Loss: 10.7212, Val Loss: 10.3165\n",
      "Epoch 131/200, Train Loss: 10.7066, Val Loss: 9.9954\n",
      "Epoch 132/200, Train Loss: 10.6328, Val Loss: 10.2051\n",
      "Epoch 133/200, Train Loss: 10.7020, Val Loss: 10.0884\n",
      "Epoch 134/200, Train Loss: 10.6579, Val Loss: 9.9409\n",
      "  New best validation loss: 9.9409\n",
      "Epoch 135/200, Train Loss: 10.6572, Val Loss: 9.9546\n",
      "Epoch 136/200, Train Loss: 10.6899, Val Loss: 9.8717\n",
      "  New best validation loss: 9.8717\n",
      "Epoch 137/200, Train Loss: 10.6304, Val Loss: 10.1175\n",
      "Epoch 138/200, Train Loss: 10.6167, Val Loss: 9.9586\n",
      "Epoch 139/200, Train Loss: 10.5900, Val Loss: 9.9934\n",
      "Epoch 140/200, Train Loss: 10.5762, Val Loss: 9.8541\n",
      "  New best validation loss: 9.8541\n",
      "Epoch 141/200, Train Loss: 10.6172, Val Loss: 10.0568\n",
      "Epoch 142/200, Train Loss: 10.5939, Val Loss: 10.0849\n",
      "Epoch 143/200, Train Loss: 10.5680, Val Loss: 9.8060\n",
      "  New best validation loss: 9.8060\n",
      "Epoch 144/200, Train Loss: 10.5762, Val Loss: 9.8858\n",
      "Epoch 145/200, Train Loss: 10.5613, Val Loss: 9.8399\n",
      "Epoch 146/200, Train Loss: 10.5894, Val Loss: 9.8542\n",
      "Epoch 147/200, Train Loss: 10.5744, Val Loss: 9.8731\n",
      "Epoch 148/200, Train Loss: 10.5317, Val Loss: 9.8901\n",
      "Epoch 149/200, Train Loss: 10.5218, Val Loss: 9.9661\n",
      "Epoch 150/200, Train Loss: 10.5254, Val Loss: 9.8970\n",
      "Epoch 151/200, Train Loss: 10.5645, Val Loss: 9.9695\n",
      "Epoch 152/200, Train Loss: 10.5227, Val Loss: 10.1162\n",
      "Epoch 153/200, Train Loss: 10.5545, Val Loss: 9.8704\n",
      "Epoch 154/200, Train Loss: 10.5532, Val Loss: 10.0278\n",
      "Epoch 155/200, Train Loss: 10.5300, Val Loss: 9.9024\n",
      "Epoch 156/200, Train Loss: 10.5220, Val Loss: 9.7774\n",
      "  New best validation loss: 9.7774\n",
      "Epoch 157/200, Train Loss: 10.4875, Val Loss: 9.9286\n",
      "Epoch 158/200, Train Loss: 10.5275, Val Loss: 9.8293\n",
      "Epoch 159/200, Train Loss: 10.4748, Val Loss: 10.0478\n",
      "Epoch 160/200, Train Loss: 10.5515, Val Loss: 9.9453\n",
      "Epoch 161/200, Train Loss: 10.4742, Val Loss: 9.9597\n",
      "Epoch 162/200, Train Loss: 10.4889, Val Loss: 9.7864\n",
      "Epoch 163/200, Train Loss: 10.4405, Val Loss: 9.8467\n",
      "Epoch 164/200, Train Loss: 10.4942, Val Loss: 9.9245\n",
      "Epoch 165/200, Train Loss: 10.4866, Val Loss: 9.7829\n",
      "Epoch 166/200, Train Loss: 10.4369, Val Loss: 9.8306\n",
      "Epoch 167/200, Train Loss: 10.4803, Val Loss: 9.8757\n",
      "Epoch 168/200, Train Loss: 10.4442, Val Loss: 9.7560\n",
      "  New best validation loss: 9.7560\n",
      "Epoch 169/200, Train Loss: 10.4220, Val Loss: 9.7948\n",
      "Epoch 170/200, Train Loss: 10.4436, Val Loss: 9.7823\n",
      "Epoch 171/200, Train Loss: 10.4358, Val Loss: 9.6829\n",
      "  New best validation loss: 9.6829\n",
      "Epoch 172/200, Train Loss: 10.4559, Val Loss: 9.8956\n",
      "Epoch 173/200, Train Loss: 10.4355, Val Loss: 9.7030\n",
      "Epoch 174/200, Train Loss: 10.4436, Val Loss: 9.7721\n",
      "Epoch 175/200, Train Loss: 10.3885, Val Loss: 9.7751\n",
      "Epoch 176/200, Train Loss: 10.3908, Val Loss: 9.6885\n",
      "Epoch 177/200, Train Loss: 10.3619, Val Loss: 9.6372\n",
      "  New best validation loss: 9.6372\n",
      "Epoch 178/200, Train Loss: 10.3888, Val Loss: 9.7613\n",
      "Epoch 179/200, Train Loss: 10.3664, Val Loss: 9.6509\n",
      "Epoch 180/200, Train Loss: 10.3958, Val Loss: 9.7351\n",
      "Epoch 181/200, Train Loss: 10.3958, Val Loss: 9.7699\n",
      "Epoch 182/200, Train Loss: 10.3916, Val Loss: 9.7703\n",
      "Epoch 183/200, Train Loss: 10.3719, Val Loss: 9.8597\n",
      "Epoch 184/200, Train Loss: 10.3959, Val Loss: 9.7970\n",
      "Epoch 185/200, Train Loss: 10.3931, Val Loss: 9.7933\n",
      "Epoch 186/200, Train Loss: 10.4014, Val Loss: 9.7735\n",
      "Epoch 187/200, Train Loss: 10.3454, Val Loss: 9.6839\n",
      "Epoch 188/200, Train Loss: 10.3636, Val Loss: 9.7739\n",
      "Epoch 189/200, Train Loss: 10.3727, Val Loss: 9.6897\n",
      "Epoch 190/200, Train Loss: 10.4140, Val Loss: 9.7745\n",
      "Epoch 191/200, Train Loss: 10.3345, Val Loss: 9.8370\n",
      "Epoch 192/200, Train Loss: 10.3726, Val Loss: 9.8690\n",
      "Epoch 193/200, Train Loss: 10.3666, Val Loss: 9.6565\n",
      "Epoch 194/200, Train Loss: 10.3561, Val Loss: 9.5770\n",
      "  New best validation loss: 9.5770\n",
      "Epoch 195/200, Train Loss: 10.3649, Val Loss: 9.6921\n",
      "Epoch 196/200, Train Loss: 10.3638, Val Loss: 9.7393\n",
      "Epoch 197/200, Train Loss: 10.3320, Val Loss: 9.7047\n",
      "Epoch 198/200, Train Loss: 10.3694, Val Loss: 9.6199\n",
      "Epoch 199/200, Train Loss: 10.3032, Val Loss: 9.6421\n",
      "Epoch 200/200, Train Loss: 10.3447, Val Loss: 9.8024\n",
      "\n",
      "Loaded best model (Val Loss: 9.5770) for final hidden state extraction.\n",
      "Saved best model for HIPPORNN_LegT (samples=2400) to results_data_size_sweep/20250514_045146/samples_2400/HIPPORNN_LegT_samples_2400_best.pt\n",
      "\n",
      "--- Performing Decodability Analysis for HIPPORNN_LegT (samples=2400, k=15) ---\n",
      "  Analyzing decodability for HIPPORNN_LegT...\n",
      "  Hidden states shape: torch.Size([160, 200, 25])\n",
      "  Coefficients shape: torch.Size([160, 15])\n",
      "  Processed hidden states shape for decoder: torch.Size([160, 25])\n",
      "  RidgeCV Decoder for HIPPORNN_LegT - Test MSE: 0.9282, Test R2: 0.5387 (best alpha: 5.4556)\n",
      "  Decodability plot saved to results_data_size_sweep/20250514_045146/samples_2400/decodability_HIPPORNN_LegT_coeff1.png\n",
      "Decodability (R2 score) for HIPPORNN_LegT (samples=2400): 0.5387\n",
      "\n",
      "--- Training NMRNN_Spatial_ModReadout (samples=2400, k=15) ---\n",
      "Number of parameters: 66832\n",
      "Epoch 1/200, Train Loss: 16.8016, Val Loss: 15.8010\n",
      "  New best validation loss: 15.8010\n",
      "Epoch 2/200, Train Loss: 16.6330, Val Loss: 15.7077\n",
      "  New best validation loss: 15.7077\n",
      "Epoch 3/200, Train Loss: 16.5711, Val Loss: 15.7550\n",
      "Epoch 4/200, Train Loss: 16.5501, Val Loss: 15.7366\n",
      "Epoch 5/200, Train Loss: 16.4876, Val Loss: 15.6173\n",
      "  New best validation loss: 15.6173\n",
      "Epoch 6/200, Train Loss: 16.4406, Val Loss: 15.5658\n",
      "  New best validation loss: 15.5658\n",
      "Epoch 7/200, Train Loss: 16.3249, Val Loss: 15.3787\n",
      "  New best validation loss: 15.3787\n",
      "Epoch 8/200, Train Loss: 16.0911, Val Loss: 14.9527\n",
      "  New best validation loss: 14.9527\n",
      "Epoch 9/200, Train Loss: 15.8533, Val Loss: 14.7884\n",
      "  New best validation loss: 14.7884\n",
      "Epoch 10/200, Train Loss: 15.6033, Val Loss: 14.4134\n",
      "  New best validation loss: 14.4134\n",
      "Epoch 11/200, Train Loss: 15.2496, Val Loss: 14.3827\n",
      "  New best validation loss: 14.3827\n",
      "Epoch 12/200, Train Loss: 15.1097, Val Loss: 14.3025\n",
      "  New best validation loss: 14.3025\n",
      "Epoch 13/200, Train Loss: 14.9583, Val Loss: 13.9705\n",
      "  New best validation loss: 13.9705\n",
      "Epoch 14/200, Train Loss: 14.7475, Val Loss: 13.8051\n",
      "  New best validation loss: 13.8051\n",
      "Epoch 15/200, Train Loss: 14.5213, Val Loss: 13.7634\n",
      "  New best validation loss: 13.7634\n",
      "Epoch 16/200, Train Loss: 14.3861, Val Loss: 13.5296\n",
      "  New best validation loss: 13.5296\n",
      "Epoch 17/200, Train Loss: 14.2089, Val Loss: 13.2568\n",
      "  New best validation loss: 13.2568\n",
      "Epoch 18/200, Train Loss: 13.8446, Val Loss: 13.2830\n",
      "Epoch 19/200, Train Loss: 13.6531, Val Loss: 12.7364\n",
      "  New best validation loss: 12.7364\n",
      "Epoch 20/200, Train Loss: 13.3009, Val Loss: 12.6115\n",
      "  New best validation loss: 12.6115\n",
      "Epoch 21/200, Train Loss: 13.1753, Val Loss: 12.6229\n",
      "Epoch 22/200, Train Loss: 13.0763, Val Loss: 12.3801\n",
      "  New best validation loss: 12.3801\n",
      "Epoch 23/200, Train Loss: 12.8164, Val Loss: 12.3584\n",
      "  New best validation loss: 12.3584\n",
      "Epoch 24/200, Train Loss: 12.6854, Val Loss: 12.3635\n",
      "Epoch 25/200, Train Loss: 12.5852, Val Loss: 11.5633\n",
      "  New best validation loss: 11.5633\n",
      "Epoch 26/200, Train Loss: 12.3556, Val Loss: 11.9186\n",
      "Epoch 27/200, Train Loss: 12.2745, Val Loss: 11.6758\n",
      "Epoch 28/200, Train Loss: 12.1496, Val Loss: 11.3993\n",
      "  New best validation loss: 11.3993\n",
      "Epoch 29/200, Train Loss: 12.1676, Val Loss: 11.4195\n",
      "Epoch 30/200, Train Loss: 11.8546, Val Loss: 11.3174\n",
      "  New best validation loss: 11.3174\n",
      "Epoch 31/200, Train Loss: 11.8336, Val Loss: 11.4151\n",
      "Epoch 32/200, Train Loss: 11.7322, Val Loss: 11.3790\n",
      "Epoch 33/200, Train Loss: 11.6296, Val Loss: 10.9852\n",
      "  New best validation loss: 10.9852\n",
      "Epoch 34/200, Train Loss: 11.5493, Val Loss: 11.7882\n",
      "Epoch 35/200, Train Loss: 11.5792, Val Loss: 11.1481\n",
      "Epoch 36/200, Train Loss: 11.4110, Val Loss: 11.0601\n",
      "Epoch 37/200, Train Loss: 11.3065, Val Loss: 11.1480\n",
      "Epoch 38/200, Train Loss: 11.2955, Val Loss: 10.8585\n",
      "  New best validation loss: 10.8585\n",
      "Epoch 39/200, Train Loss: 11.1589, Val Loss: 11.1297\n",
      "Epoch 40/200, Train Loss: 11.2103, Val Loss: 10.9029\n",
      "Epoch 41/200, Train Loss: 11.1396, Val Loss: 10.9057\n",
      "Epoch 42/200, Train Loss: 11.0844, Val Loss: 11.0654\n",
      "Epoch 43/200, Train Loss: 11.0093, Val Loss: 10.9773\n",
      "Epoch 44/200, Train Loss: 10.9227, Val Loss: 11.0205\n",
      "Epoch 45/200, Train Loss: 10.8347, Val Loss: 10.8821\n",
      "Epoch 46/200, Train Loss: 10.9520, Val Loss: 10.6669\n",
      "  New best validation loss: 10.6669\n",
      "Epoch 47/200, Train Loss: 10.8533, Val Loss: 10.8329\n",
      "Epoch 48/200, Train Loss: 10.8674, Val Loss: 11.1202\n",
      "Epoch 49/200, Train Loss: 10.7413, Val Loss: 10.7345\n",
      "Epoch 50/200, Train Loss: 10.7094, Val Loss: 10.8485\n",
      "Epoch 51/200, Train Loss: 10.7237, Val Loss: 10.9622\n",
      "Epoch 52/200, Train Loss: 10.6830, Val Loss: 10.9035\n",
      "Epoch 53/200, Train Loss: 10.6047, Val Loss: 10.9517\n",
      "Epoch 54/200, Train Loss: 10.5072, Val Loss: 11.2312\n",
      "Epoch 55/200, Train Loss: 10.6110, Val Loss: 11.0020\n",
      "Epoch 56/200, Train Loss: 10.5495, Val Loss: 11.0545\n",
      "Epoch 57/200, Train Loss: 10.5033, Val Loss: 11.0674\n",
      "Epoch 58/200, Train Loss: 10.5932, Val Loss: 10.9215\n",
      "Epoch 59/200, Train Loss: 10.3975, Val Loss: 10.8129\n",
      "Epoch 60/200, Train Loss: 10.3179, Val Loss: 10.9787\n",
      "Epoch 61/200, Train Loss: 10.3872, Val Loss: 11.0936\n",
      "Epoch 62/200, Train Loss: 10.3356, Val Loss: 11.1891\n",
      "Epoch 63/200, Train Loss: 10.2577, Val Loss: 11.0169\n",
      "Epoch 64/200, Train Loss: 10.2255, Val Loss: 11.0873\n",
      "Epoch 65/200, Train Loss: 10.2689, Val Loss: 10.7545\n",
      "Epoch 66/200, Train Loss: 10.2166, Val Loss: 11.3631\n",
      "Epoch 67/200, Train Loss: 10.2451, Val Loss: 10.7660\n",
      "Epoch 68/200, Train Loss: 10.1634, Val Loss: 10.9443\n",
      "Epoch 69/200, Train Loss: 10.1212, Val Loss: 11.0493\n",
      "Epoch 70/200, Train Loss: 10.1400, Val Loss: 11.4678\n",
      "Epoch 71/200, Train Loss: 10.0534, Val Loss: 11.0639\n",
      "Epoch 72/200, Train Loss: 9.9894, Val Loss: 11.0148\n",
      "Epoch 73/200, Train Loss: 10.0026, Val Loss: 11.1632\n",
      "Epoch 74/200, Train Loss: 10.0015, Val Loss: 11.1610\n",
      "Epoch 75/200, Train Loss: 9.9202, Val Loss: 10.9612\n",
      "Epoch 76/200, Train Loss: 9.8953, Val Loss: 11.1290\n",
      "Epoch 77/200, Train Loss: 9.8765, Val Loss: 11.2651\n",
      "Epoch 78/200, Train Loss: 9.8739, Val Loss: 11.2610\n",
      "Epoch 79/200, Train Loss: 9.7824, Val Loss: 11.2528\n",
      "Epoch 80/200, Train Loss: 9.8104, Val Loss: 11.2279\n",
      "Epoch 81/200, Train Loss: 9.7487, Val Loss: 11.1457\n",
      "Epoch 82/200, Train Loss: 9.7652, Val Loss: 11.1372\n",
      "Epoch 83/200, Train Loss: 9.6435, Val Loss: 10.9845\n",
      "Epoch 84/200, Train Loss: 9.6701, Val Loss: 10.9367\n",
      "Epoch 85/200, Train Loss: 9.6488, Val Loss: 11.0750\n",
      "Epoch 86/200, Train Loss: 9.6632, Val Loss: 11.1290\n",
      "Epoch 87/200, Train Loss: 9.6690, Val Loss: 11.0149\n",
      "Epoch 88/200, Train Loss: 9.6018, Val Loss: 11.3947\n",
      "Epoch 89/200, Train Loss: 9.5134, Val Loss: 11.1601\n",
      "Epoch 90/200, Train Loss: 9.5172, Val Loss: 11.3049\n",
      "Epoch 91/200, Train Loss: 9.4926, Val Loss: 11.2908\n",
      "Epoch 92/200, Train Loss: 9.4995, Val Loss: 11.1536\n",
      "Epoch 93/200, Train Loss: 9.5283, Val Loss: 11.3893\n",
      "Epoch 94/200, Train Loss: 9.4490, Val Loss: 11.2563\n",
      "Epoch 95/200, Train Loss: 9.4732, Val Loss: 11.0920\n",
      "Epoch 96/200, Train Loss: 9.4596, Val Loss: 11.2616\n",
      "Epoch 97/200, Train Loss: 9.3871, Val Loss: 11.1968\n",
      "Epoch 98/200, Train Loss: 9.4341, Val Loss: 11.4769\n",
      "Epoch 99/200, Train Loss: 9.3796, Val Loss: 11.3594\n",
      "Epoch 100/200, Train Loss: 9.3910, Val Loss: 11.2980\n",
      "Epoch 101/200, Train Loss: 9.3651, Val Loss: 11.9068\n",
      "Epoch 102/200, Train Loss: 9.3456, Val Loss: 11.5454\n",
      "Epoch 103/200, Train Loss: 9.2611, Val Loss: 11.7721\n",
      "Epoch 104/200, Train Loss: 9.2841, Val Loss: 11.4163\n",
      "Epoch 105/200, Train Loss: 9.1969, Val Loss: 11.6413\n",
      "Epoch 106/200, Train Loss: 9.2269, Val Loss: 11.6865\n",
      "Epoch 107/200, Train Loss: 9.1747, Val Loss: 11.4359\n",
      "Epoch 108/200, Train Loss: 9.1900, Val Loss: 11.5508\n",
      "Epoch 109/200, Train Loss: 9.1346, Val Loss: 11.2279\n",
      "Epoch 110/200, Train Loss: 9.0842, Val Loss: 11.3565\n",
      "Epoch 111/200, Train Loss: 9.1661, Val Loss: 11.7357\n",
      "Epoch 112/200, Train Loss: 9.0430, Val Loss: 11.8785\n",
      "Epoch 113/200, Train Loss: 9.1126, Val Loss: 11.5606\n",
      "Epoch 114/200, Train Loss: 9.0133, Val Loss: 11.3590\n",
      "Epoch 115/200, Train Loss: 9.0257, Val Loss: 11.4449\n",
      "Epoch 116/200, Train Loss: 9.0108, Val Loss: 11.5974\n",
      "Epoch 117/200, Train Loss: 8.9483, Val Loss: 11.7283\n",
      "Epoch 118/200, Train Loss: 8.9563, Val Loss: 11.5074\n",
      "Epoch 119/200, Train Loss: 8.9102, Val Loss: 11.8953\n",
      "Epoch 120/200, Train Loss: 8.9185, Val Loss: 11.5169\n",
      "Epoch 121/200, Train Loss: 8.8690, Val Loss: 11.7608\n",
      "Epoch 122/200, Train Loss: 8.8615, Val Loss: 11.8652\n",
      "Epoch 123/200, Train Loss: 8.8051, Val Loss: 11.7770\n",
      "Epoch 124/200, Train Loss: 8.8300, Val Loss: 11.6173\n",
      "Epoch 125/200, Train Loss: 8.8102, Val Loss: 11.7892\n",
      "Epoch 126/200, Train Loss: 8.7640, Val Loss: 11.7287\n",
      "Epoch 127/200, Train Loss: 8.8408, Val Loss: 11.4194\n",
      "Epoch 128/200, Train Loss: 8.7470, Val Loss: 11.6061\n",
      "Epoch 129/200, Train Loss: 8.7167, Val Loss: 11.5884\n",
      "Epoch 130/200, Train Loss: 8.6510, Val Loss: 11.8463\n",
      "Epoch 131/200, Train Loss: 8.6441, Val Loss: 11.7073\n",
      "Epoch 132/200, Train Loss: 8.6805, Val Loss: 11.5022\n",
      "Epoch 133/200, Train Loss: 8.6462, Val Loss: 11.9150\n",
      "Epoch 134/200, Train Loss: 8.6146, Val Loss: 11.9051\n",
      "Epoch 135/200, Train Loss: 8.5701, Val Loss: 11.8893\n",
      "Epoch 136/200, Train Loss: 8.5606, Val Loss: 11.8971\n",
      "Epoch 137/200, Train Loss: 8.5777, Val Loss: 12.0234\n",
      "Epoch 138/200, Train Loss: 8.5704, Val Loss: 11.8488\n",
      "Epoch 139/200, Train Loss: 8.4410, Val Loss: 11.8853\n",
      "Epoch 140/200, Train Loss: 8.5066, Val Loss: 11.8385\n",
      "Epoch 141/200, Train Loss: 8.4532, Val Loss: 11.8234\n",
      "Epoch 142/200, Train Loss: 8.4618, Val Loss: 11.9219\n",
      "Epoch 143/200, Train Loss: 8.4442, Val Loss: 12.0540\n",
      "Epoch 144/200, Train Loss: 8.3836, Val Loss: 12.0254\n",
      "Epoch 145/200, Train Loss: 8.4230, Val Loss: 12.0937\n",
      "Epoch 146/200, Train Loss: 8.3460, Val Loss: 11.9002\n",
      "Epoch 147/200, Train Loss: 8.3859, Val Loss: 11.9420\n",
      "Epoch 148/200, Train Loss: 8.3455, Val Loss: 11.7775\n",
      "Epoch 149/200, Train Loss: 8.3740, Val Loss: 12.0260\n",
      "Epoch 150/200, Train Loss: 8.3268, Val Loss: 11.8773\n",
      "Epoch 151/200, Train Loss: 8.2387, Val Loss: 11.8617\n",
      "Epoch 152/200, Train Loss: 8.2403, Val Loss: 12.2469\n",
      "Epoch 153/200, Train Loss: 8.2120, Val Loss: 11.8915\n",
      "Epoch 154/200, Train Loss: 8.2060, Val Loss: 12.3421\n",
      "Epoch 155/200, Train Loss: 8.2050, Val Loss: 12.1538\n",
      "Epoch 156/200, Train Loss: 8.1835, Val Loss: 11.9291\n",
      "Epoch 157/200, Train Loss: 8.1621, Val Loss: 12.0043\n",
      "Epoch 158/200, Train Loss: 8.1181, Val Loss: 12.1167\n",
      "Epoch 159/200, Train Loss: 8.1158, Val Loss: 12.4390\n",
      "Epoch 160/200, Train Loss: 8.1261, Val Loss: 12.3952\n",
      "Epoch 161/200, Train Loss: 8.1756, Val Loss: 12.1871\n",
      "Epoch 162/200, Train Loss: 8.0768, Val Loss: 12.2408\n",
      "Epoch 163/200, Train Loss: 8.0372, Val Loss: 12.1635\n",
      "Epoch 164/200, Train Loss: 8.0213, Val Loss: 12.3302\n",
      "Epoch 165/200, Train Loss: 7.9850, Val Loss: 12.1523\n",
      "Epoch 166/200, Train Loss: 7.9882, Val Loss: 12.0526\n",
      "Epoch 167/200, Train Loss: 8.0029, Val Loss: 12.4794\n",
      "Epoch 168/200, Train Loss: 7.9671, Val Loss: 12.3012\n",
      "Epoch 169/200, Train Loss: 7.9727, Val Loss: 12.2620\n",
      "Epoch 170/200, Train Loss: 7.9339, Val Loss: 12.1343\n",
      "Epoch 171/200, Train Loss: 7.9202, Val Loss: 12.0579\n",
      "Epoch 172/200, Train Loss: 7.9227, Val Loss: 12.2106\n",
      "Epoch 173/200, Train Loss: 7.9083, Val Loss: 12.2178\n",
      "Epoch 174/200, Train Loss: 7.8724, Val Loss: 12.0030\n",
      "Epoch 175/200, Train Loss: 7.8672, Val Loss: 12.3530\n",
      "Epoch 176/200, Train Loss: 7.9322, Val Loss: 12.3378\n",
      "Epoch 177/200, Train Loss: 7.8164, Val Loss: 12.4699\n",
      "Epoch 178/200, Train Loss: 7.7763, Val Loss: 12.4362\n",
      "Epoch 179/200, Train Loss: 7.7406, Val Loss: 12.1535\n",
      "Epoch 180/200, Train Loss: 7.7884, Val Loss: 11.9756\n",
      "Epoch 181/200, Train Loss: 7.8039, Val Loss: 11.9823\n"
     ]
    }
   ],
   "source": [
    "import torch\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import os\n",
    "from datetime import datetime\n",
    "import traceback # For detailed error printing\n",
    "\n",
    "# Project specific imports (ensure these files are in your PYTHONPATH or same directory)\n",
    "# It's assumed these modules exist and are correctly implemented.\n",
    "from dataset import CompositionalDataset, create_dataloaders\n",
    "from model import NonlinearOscillatorNet, RNNModel, TransformerModel, HippoRNNModel, NMRNN_Spatial_ModulatedReadout, NMRNN_NoSpatial_ModulatedReadout, NMRNN_Spatial_FixedReadout, TransformerModelWithCausal\n",
    "from train import train_model_comparative\n",
    "from ana import plot_learning_curves, perform_decodability_analysis\n",
    "from utils import set_seed, get_device, count_parameters\n",
    "\n",
    "# --- Configuration ---\n",
    "CONFIG = {\n",
    "    \"seed\": 0,\n",
    "    \"fixed_num_task_coefficients\": 15, # Fixed k for this sweep\n",
    "    \"seq_length\": 200,\n",
    "    # \"train_samples\": This will be set by the sweep\n",
    "    \"test_samples\": 32 * 5,     # Reduced for quicker testing\n",
    "    \"batch_size\": 32,\n",
    "    \"epochs\": 200, # Reduced for quick test, increase for real runs (e.g., 50-200)\n",
    "    \"lr\": 1e-3,\n",
    "\n",
    "    # Model-specific hidden sizes / main dimension\n",
    "    \"hidden_size_oscillator\": 128,\n",
    "    \"hidden_size_rnn\": 64,       # For standard GRU/LSTM\n",
    "    \"d_model_transformer\": 20,\n",
    "    \"hidden_size_hippo\": 25,     # N for HIPPO\n",
    "    \"hidden_size_nm_rnn\": 128,   # n_rnn for nmRNN variants\n",
    "\n",
    "    # Transformer specific\n",
    "    \"nhead_transformer\": 1,\n",
    "    \"num_layers_transformer\": 1,\n",
    "\n",
    "    # HIPPORNN specific\n",
    "    \"hippo_method\": 'legt', # 'legs' or 'legt'\n",
    "    \"hippo_theta\": 1.0,      # Required for 'legt'\n",
    "    \"hippo_dt\": 1.0 / 200,  # Discretization step for HIPPO (e.g., 1.0 / seq_length)\n",
    "    \"hippo_inv_eps\": 1e-6, # Epsilon for LegS matrix inversion regularization\n",
    "    \"hippo_clip_val\": 50.0, # Clipping for HIPPO state c_t\n",
    "\n",
    "    # nmRNN specific (shared for variants where applicable)\n",
    "    \"nm_N_NM\": 4,            # Number of neuromodulators\n",
    "    \"nm_activation\": 'tanh',  # 'relu', 'tanh'\n",
    "    \"nm_decay\": 0.05,\n",
    "    \"nm_bias\": True,\n",
    "    \"nm_keepW0_spatial\": False,\n",
    "    \"nm_keepW0_no_spatial\": False,\n",
    "    \"nm_grad_clip\": 1.0,\n",
    "    \"nm_spatial_ell\": 0.1,\n",
    "    \"nm_spatial_scale\": 1.0,\n",
    "\n",
    "    # General task params\n",
    "    \"output_dim\": 1,\n",
    "    \"input_dim\": 1,\n",
    "    \"noise_level_data\": 0.01,\n",
    "    \"run_timestamp\": datetime.now().strftime(\"%Y%m%d_%H%M%S\"), # Timestamp for the entire sweep\n",
    "    \"results_dir\": \"results_data_size_sweep\" # Main directory for data size sweep results\n",
    "}\n",
    "\n",
    "def get_model_definitions(current_config, device):\n",
    "    \"\"\"\n",
    "    Helper function to define or re-initialize models based on the current configuration.\n",
    "    This ensures models are fresh for each part of the sweep.\n",
    "    \"\"\"\n",
    "    # NOTE: hidden sizes are fixed for this sweep, they don't change with dataset size\n",
    "    models = {\n",
    "        \"RNN_Vanillia\": NMRNN_NoSpatial_ModulatedReadout(\n",
    "            input_size=current_config[\"input_dim\"],\n",
    "            hidden_size=225,  # Keep parameter count fixed for comparison\n",
    "            output_size=current_config[\"output_dim\"],\n",
    "            N_nm=0, # Vanilla RNN, so no neuromodulators\n",
    "            activation_fn_name=current_config[\"nm_activation\"],\n",
    "            decay=current_config[\"nm_decay\"],\n",
    "            bias=current_config[\"nm_bias\"],\n",
    "            keepW0=True,\n",
    "            grad_clip=current_config[\"nm_grad_clip\"],\n",
    "            device=device,\n",
    "            seed=current_config[\"seed\"]\n",
    "        ),\n",
    "        \"ComplexOscillatorNet\": NonlinearOscillatorNet(\n",
    "            N_oscillators=current_config[\"hidden_size_oscillator\"], # Keep parameter count fixed\n",
    "            device=device,\n",
    "            outputdim=current_config[\"output_dim\"],\n",
    "            inputdim=current_config[\"input_dim\"],\n",
    "            seq_length=current_config[\"seq_length\"],\n",
    "            seed=current_config[\"seed\"]\n",
    "        ),\n",
    "        \"RNN_GRU\": RNNModel(\n",
    "            hidden_size=current_config[\"hidden_size_rnn\"], # Keep parameter count fixed\n",
    "            device=device,\n",
    "            outputdim=current_config[\"output_dim\"],\n",
    "            inputdim=current_config[\"input_dim\"],\n",
    "            num_layers=1,\n",
    "            seed=current_config[\"seed\"]\n",
    "        ),\n",
    "        \"Transformer\": TransformerModel(\n",
    "            d_model=current_config[\"d_model_transformer\"], # Keep parameter count fixed\n",
    "            device=device,\n",
    "            outputdim=current_config[\"output_dim\"],\n",
    "            inputdim=current_config[\"input_dim\"],\n",
    "            num_heads=current_config[\"nhead_transformer\"],\n",
    "            num_layers=current_config[\"num_layers_transformer\"],\n",
    "            seq_length=current_config[\"seq_length\"],\n",
    "            seed=current_config[\"seed\"]\n",
    "        ),\n",
    "        \"TransformerCausal\": TransformerModelWithCausal(\n",
    "            d_model=current_config[\"d_model_transformer\"], # Keep parameter count fixed\n",
    "            device=device,\n",
    "            outputdim=current_config[\"output_dim\"],\n",
    "            inputdim=current_config[\"input_dim\"],\n",
    "            num_heads=current_config[\"nhead_transformer\"],\n",
    "            num_layers=current_config[\"num_layers_transformer\"],\n",
    "            seq_length=current_config[\"seq_length\"],\n",
    "            seed=current_config[\"seed\"]\n",
    "        ),\n",
    "        \"HIPPORNN_LegT\": HippoRNNModel(\n",
    "            hidden_size=current_config[\"hidden_size_hippo\"], # Keep parameter count fixed\n",
    "            outputdim=current_config[\"output_dim\"],\n",
    "            inputdim=current_config[\"input_dim\"],\n",
    "            method=current_config[\"hippo_method\"],\n",
    "            theta=current_config[\"hippo_theta\"],\n",
    "            dt=current_config[\"hippo_dt\"],\n",
    "            inv_eps=current_config[\"hippo_inv_eps\"],\n",
    "            clip_val=current_config[\"hippo_clip_val\"],\n",
    "            device=device,\n",
    "            seed=current_config[\"seed\"]\n",
    "        ),\n",
    "        \"NMRNN_Spatial_ModReadout\": NMRNN_Spatial_ModulatedReadout(\n",
    "            input_size=current_config[\"input_dim\"],\n",
    "            hidden_size=current_config[\"hidden_size_nm_rnn\"], # Keep parameter count fixed\n",
    "            output_size=current_config[\"output_dim\"],\n",
    "            N_nm=current_config[\"nm_N_NM\"], # Keep fixed\n",
    "            activation_fn_name=current_config[\"nm_activation\"],\n",
    "            decay=current_config[\"nm_decay\"],\n",
    "            bias=current_config[\"nm_bias\"],\n",
    "            keepW0=current_config[\"nm_keepW0_spatial\"],\n",
    "            spatial_ell=current_config[\"nm_spatial_ell\"],\n",
    "            spatial_scale=current_config[\"nm_spatial_scale\"],\n",
    "            grad_clip=current_config[\"nm_grad_clip\"],\n",
    "            device=device,\n",
    "            seed=current_config[\"seed\"]\n",
    "        ),\n",
    "        \"NMRNN_NoSpatial_ModReadout\": NMRNN_NoSpatial_ModulatedReadout(\n",
    "            input_size=current_config[\"input_dim\"],\n",
    "            hidden_size=current_config[\"hidden_size_nm_rnn\"], # Keep parameter count fixed\n",
    "            output_size=current_config[\"output_dim\"],\n",
    "            N_nm=current_config[\"nm_N_NM\"], # Keep fixed\n",
    "            activation_fn_name=current_config[\"nm_activation\"],\n",
    "            decay=current_config[\"nm_decay\"],\n",
    "            bias=current_config[\"nm_bias\"],\n",
    "            keepW0=current_config[\"nm_keepW0_no_spatial\"],\n",
    "            grad_clip=current_config[\"nm_grad_clip\"],\n",
    "            device=device,\n",
    "            seed=current_config[\"seed\"]\n",
    "        ),\n",
    "        \"NMRNN_Spatial_FixedReadout\": NMRNN_Spatial_FixedReadout(\n",
    "            input_size=current_config[\"input_dim\"],\n",
    "            hidden_size=current_config[\"hidden_size_nm_rnn\"], # Keep parameter count fixed\n",
    "            output_size=current_config[\"output_dim\"],\n",
    "            N_nm=current_config[\"nm_N_NM\"], # Keep fixed\n",
    "            activation_fn_name=current_config[\"nm_activation\"],\n",
    "            decay=current_config[\"nm_decay\"],\n",
    "            bias=current_config[\"nm_bias\"],\n",
    "            keepW0=current_config[\"nm_keepW0_spatial\"],\n",
    "            spatial_ell=current_config[\"nm_spatial_ell\"],\n",
    "            spatial_scale=current_config[\"nm_spatial_scale\"],\n",
    "            grad_clip=current_config[\"nm_grad_clip\"],\n",
    "            device=device,\n",
    "            seed=current_config[\"seed\"]\n",
    "        ),\n",
    "    }\n",
    "    return models\n",
    "\n",
    "def plot_sweep_summary_metrics(metrics_data, x_values, save_dir, metric_titles, x_label=\"Number of Training Samples\"):\n",
    "    \"\"\"\n",
    "    Plots the collected metrics against the number of training samples.\n",
    "    metrics_data: Dict like {'metric_name': {'model_name': [values]}}\n",
    "    x_values: List of train_samples used.\n",
    "    save_dir: Directory to save plots.\n",
    "    metric_titles: Dict mapping metric_name to plot title and y-axis label.\n",
    "    x_label: Label for the x-axis.\n",
    "    \"\"\"\n",
    "    for metric_key, model_results in metrics_data.items():\n",
    "        plt.figure(figsize=(12, 7)) # Adjusted figure size\n",
    "        for model_name, y_values in model_results.items():\n",
    "            if len(y_values) == len(x_values):\n",
    "                plt.plot(x_values, y_values, lw=3, label=model_name, marker='o', markersize=5)\n",
    "            else:\n",
    "                print(f\"Warning: Mismatch in data length for {model_name} on metric {metric_key}. \"\n",
    "                      f\"Expected {len(x_values)}, got {len(y_values)}. Skipping plot for this line.\")\n",
    "\n",
    "        title, ylabel = metric_titles.get(metric_key, (metric_key.replace(\"_\", \" \").title(), metric_key.replace(\"_\", \" \").title()))\n",
    "        plt.xlabel(x_label)\n",
    "        plt.ylabel(ylabel)\n",
    "        plt.title(title)\n",
    "        plt.legend(loc='best', fontsize='small') # Improved legend placement\n",
    "        plt.grid(True, linestyle='--', alpha=0.7) # Softer grid\n",
    "        plt.tight_layout()\n",
    "        save_path = os.path.join(save_dir, f\"summary_plot_{metric_key}.png\")\n",
    "        plt.savefig(save_path)\n",
    "        plt.close() # Close plot to free memory\n",
    "        print(f\"Saved sweep summary plot: {save_path}\")\n",
    "\n",
    "\n",
    "def run_experiment():\n",
    "    \"\"\"\n",
    "    Runs the full comparative analysis experiment with a sweep over train dataset size.\n",
    "    \"\"\"\n",
    "    set_seed(CONFIG[\"seed\"])\n",
    "    device = get_device()\n",
    "    print(f\"Using device: {device}\")\n",
    "\n",
    "    # Main results directory for the entire sweep\n",
    "    base_sweep_results_dir = os.path.join(CONFIG[\"results_dir\"], CONFIG[\"run_timestamp\"])\n",
    "    os.makedirs(base_sweep_results_dir, exist_ok=True)\n",
    "    print(f\"All sweep results will be saved in: {base_sweep_results_dir}\")\n",
    "\n",
    "    # Define the sweep range for train dataset size (number of samples)\n",
    "    # Example sweep values - adjust these based on your needs\n",
    "    train_samples_sweep = [32 * 5, 32 * 10, 32 * 20, 32 * 30, 32 * 40, 32 * 50, 32 * 75, 32 * 100]\n",
    "    # Ensure sweep values are unique and sorted for consistent plotting\n",
    "    train_samples_sweep = sorted(list(set(train_samples_sweep)))\n",
    "\n",
    "    print(f\"Sweeping over training dataset sizes (number of samples): {train_samples_sweep}\")\n",
    "    print(f\"Fixed number of task coefficients (k): {CONFIG['fixed_num_task_coefficients']}\")\n",
    "\n",
    "    # Get model names for initializing metrics storage\n",
    "    # Create a temporary config for this, dataset size doesn't affect model names\n",
    "    temp_config_for_names = CONFIG.copy()\n",
    "    model_names = list(get_model_definitions(temp_config_for_names, device).keys())\n",
    "\n",
    "    # Fixed optimal learning rates (assuming these were found previously for k=15)\n",
    "    # You might need to re-tune these slightly depending on the dataset size range\n",
    "    optim_lr = {\n",
    "        \"RNN_Vanillia\": 2.35981e-4,\n",
    "        \"ComplexOscillatorNet\": 1.12797e-3,\n",
    "        \"RNN_GRU\": 3.792749e-4,\n",
    "        \"Transformer\": 8.54203917e-4,\n",
    "        \"TransformerCausal\": 6.2038471e-4,\n",
    "        \"HIPPORNN_LegT\": 3.40583e-4,\n",
    "        \"NMRNN_Spatial_ModReadout\": 1.000134e-3,\n",
    "        \"NMRNN_NoSpatial_ModReadout\": 1.1320104e-3,\n",
    "        \"NMRNN_Spatial_FixedReadout\": 9.8572618e-4,\n",
    "    }\n",
    "\n",
    "    # Initialize structures to store metrics for final plotting across the sweep\n",
    "    overall_metrics = {\n",
    "        \"best_val_loss\": {name: [] for name in model_names},\n",
    "        \"final_train_loss\": {name: [] for name in model_names},\n",
    "        \"final_val_loss\": {name: [] for name in model_names},\n",
    "        \"best_val_varex\": {name: [] for name in model_names},\n",
    "        \"final_train_varex\": {name: [] for name in model_names},\n",
    "        \"final_val_varex\": {name: [] for name in model_names},\n",
    "        \"generalization_gap\": {name: [] for name in model_names},\n",
    "        \"decodability_r2\": {name: [] for name in model_names}, # Using R2 for decodability\n",
    "    }\n",
    "\n",
    "    # --- Sweep over train_samples ---\n",
    "    for num_samples in train_samples_sweep:\n",
    "        current_train_samples = int(num_samples) # Ensure it's an integer\n",
    "        print(f\"\\n{'='*25} Running for train_samples: {current_train_samples}, k: {CONFIG['fixed_num_task_coefficients']} {'='*25}\")\n",
    "\n",
    "        # Update config for the current number of training samples\n",
    "        current_config = CONFIG.copy()\n",
    "        current_config[\"train_samples\"] = current_train_samples\n",
    "        current_config[\"num_task_coefficients\"] = CONFIG[\"fixed_num_task_coefficients\"] # Fix k\n",
    "\n",
    "        # Create a subdirectory for this specific dataset size run's detailed artifacts\n",
    "        sample_run_results_dir = os.path.join(base_sweep_results_dir, f\"samples_{current_train_samples}\")\n",
    "        os.makedirs(sample_run_results_dir, exist_ok=True)\n",
    "        print(f\"Results for train_samples={current_train_samples} will be saved in: {sample_run_results_dir}\")\n",
    "\n",
    "        # --- 1. Dataset (depends on train_samples) ---\n",
    "        print(\"Loading dataset...\")\n",
    "        train_loader, val_loader, test_loader, (input_basis, output_basis) = create_dataloaders(\n",
    "            num_train_samples=current_config[\"train_samples\"], # Key change for sweep\n",
    "            num_val_samples=current_config[\"test_samples\"],\n",
    "            num_test_samples=current_config[\"test_samples\"],\n",
    "            num_basis=current_config[\"num_task_coefficients\"], # Fixed k\n",
    "            seq_length=current_config[\"seq_length\"],\n",
    "            batch_size=current_config[\"batch_size\"],\n",
    "            noise=current_config[\"noise_level_data\"]\n",
    "        )\n",
    "        print(\"Dataset loaded.\")\n",
    "\n",
    "        # --- 2. Models (re-initialize for each run) ---\n",
    "        # Although parameters are fixed, re-initializing ensures a clean state\n",
    "        models_to_test = get_model_definitions(current_config, device)\n",
    "\n",
    "        # Store results for the current num_samples run (for individual reports if needed)\n",
    "        current_run_train_losses_epoch = {}\n",
    "        current_run_val_losses_epoch = {}\n",
    "        current_run_train_varex_epoch = {}\n",
    "        current_run_val_varex_epoch = {}\n",
    "        current_run_decodability_results = {}\n",
    "        current_run_trained_models_paths = {}\n",
    "\n",
    "\n",
    "        # --- 3. Training & Evaluation Loop for current num_samples ---\n",
    "        for model_name, model_instance in models_to_test.items():\n",
    "            print(f\"\\n--- Training {model_name} (samples={current_train_samples}, k={current_config['num_task_coefficients']}) ---\")\n",
    "            model = model_instance # Use the already instantiated model\n",
    "            model.to(device)\n",
    "            print(f\"Number of parameters: {count_parameters(model)}\")\n",
    "\n",
    "            # Calculate total variance for varex\n",
    "            total_train_var = float('nan')\n",
    "            if train_loader:\n",
    "                 for x_batch, y_batch, _ in train_loader:\n",
    "                     x_batch, y_batch = x_batch.to(device), y_batch.to(device)\n",
    "                     if y_batch.numel() > 1: # Ensure there's enough data to calculate variance\n",
    "                         total_train_var = torch.std(y_batch).item()**2\n",
    "                     break # Only need one batch to estimate variance\n",
    "\n",
    "            total_val_var = float('nan')\n",
    "            if val_loader:\n",
    "                 for x_batch, y_batch, _ in val_loader:\n",
    "                     x_batch, y_batch = x_batch.to(device), y_batch.to(device)\n",
    "                     if y_batch.numel() > 1: # Ensure there's enough data to calculate variance\n",
    "                         total_val_var = torch.std(y_batch).item()**2\n",
    "                     break # Only need one batch to estimate variance\n",
    "\n",
    "\n",
    "            try:\n",
    "                train_losses_epoch, val_losses_epoch, best_model_state, hidden_states_test, coeffs_test = train_model_comparative(\n",
    "                    model,\n",
    "                    model_name,\n",
    "                    train_loader,\n",
    "                    val_loader,\n",
    "                    test_loader,\n",
    "                    current_config[\"epochs\"],\n",
    "                    optim_lr[model_name],\n",
    "                    device,\n",
    "                    current_config[\"num_task_coefficients\"],\n",
    "                    sample_run_results_dir, # Save intermediate plots/models for this sample run\n",
    "                    plot_intermediate_results=False # Typically off for sweeps to avoid clutter\n",
    "                )\n",
    "\n",
    "                current_run_train_losses_epoch[model_name] = train_losses_epoch\n",
    "                current_run_val_losses_epoch[model_name] = val_losses_epoch\n",
    "\n",
    "                # Calculate Variance Explained (varex)\n",
    "                current_run_train_varex_epoch[model_name] = 1-np.array(train_losses_epoch)/total_train_var if total_train_var > 0 else [float('nan')] * len(train_losses_epoch)\n",
    "                current_run_val_varex_epoch[model_name] = 1-np.array(val_losses_epoch)/total_val_var if total_val_var > 0 else [float('nan')] * len(val_losses_epoch)\n",
    "\n",
    "\n",
    "                # Calculate metrics for overall_metrics storage\n",
    "                # Ensure lists are not empty and handle potential NaN values from training\n",
    "                best_val_loss = min(val_losses_epoch) if val_losses_epoch and not all(np.isnan(l) for l in val_losses_epoch if l is not None) else float('nan')\n",
    "                final_train_loss = train_losses_epoch[-1] if train_losses_epoch and not np.isnan(train_losses_epoch[-1]) else float('nan')\n",
    "                final_val_loss = val_losses_epoch[-1] if val_losses_epoch and not np.isnan(val_losses_epoch[-1]) else float('nan')\n",
    "\n",
    "                if not (np.isnan(final_val_loss) or np.isnan(final_train_loss)):\n",
    "                    gen_gap = final_val_loss - final_train_loss\n",
    "                else:\n",
    "                    gen_gap = float('nan')\n",
    "\n",
    "                overall_metrics[\"best_val_loss\"][model_name].append(best_val_loss)\n",
    "                overall_metrics[\"final_train_loss\"][model_name].append(final_train_loss)\n",
    "                overall_metrics[\"final_val_loss\"][model_name].append(final_val_loss)\n",
    "\n",
    "                # Calculate and append varex to overall_metrics\n",
    "                best_val_varex = 1-best_val_loss/total_val_var if total_val_var > 0 and not np.isnan(best_val_loss) else float('nan')\n",
    "                final_train_varex = 1-final_train_loss/total_train_var if total_train_var > 0 and not np.isnan(final_train_loss) else float('nan')\n",
    "                final_val_varex = 1-final_val_loss/total_val_var if total_val_var > 0 and not np.isnan(final_val_loss) else float('nan')\n",
    "\n",
    "                overall_metrics[\"best_val_varex\"][model_name].append(best_val_varex)\n",
    "                overall_metrics[\"final_train_varex\"][model_name].append(final_train_varex)\n",
    "                overall_metrics[\"final_val_varex\"][model_name].append(final_val_varex)\n",
    "\n",
    "                overall_metrics[\"generalization_gap\"][model_name].append(gen_gap)\n",
    "\n",
    "                if best_model_state:\n",
    "                    model_path = os.path.join(sample_run_results_dir, f\"{model_name}_samples_{current_train_samples}_best.pt\")\n",
    "                    torch.save(best_model_state, model_path)\n",
    "                    current_run_trained_models_paths[model_name] = model_path\n",
    "                    print(f\"Saved best model for {model_name} (samples={current_train_samples}) to {model_path}\")\n",
    "                else:\n",
    "                    print(f\"No best model state saved for {model_name} (samples={current_train_samples}).\")\n",
    "\n",
    "                # --- 4. Decodability Analysis for current num_samples run ---\n",
    "                decodability_score_r2 = float('nan')\n",
    "                if hidden_states_test is not None and coeffs_test is not None:\n",
    "                    print(f\"\\n--- Performing Decodability Analysis for {model_name} (samples={current_train_samples}, k={current_config['num_task_coefficients']}) ---\")\n",
    "                    decodability_score_r2 = perform_decodability_analysis(\n",
    "                        model_name=model_name,\n",
    "                        hidden_states=hidden_states_test,\n",
    "                        coefficients=coeffs_test,\n",
    "                        decoder_type='ridge',\n",
    "                        decoding_metric='r2', # R-squared\n",
    "                        results_dir=sample_run_results_dir, # Save plots for this specific run\n",
    "                        device=device,\n",
    "                    )\n",
    "                    print(f\"Decodability (R2 score) for {model_name} (samples={current_train_samples}): {decodability_score_r2:.4f}\")\n",
    "                else:\n",
    "                    print(f\"Skipping decodability for {model_name} (samples={current_train_samples}) due to missing data.\")\n",
    "\n",
    "                current_run_decodability_results[model_name] = decodability_score_r2\n",
    "                overall_metrics[\"decodability_r2\"][model_name].append(decodability_score_r2)\n",
    "\n",
    "            except Exception as e:\n",
    "                print(f\"!!!!!! ERROR during training or analysis for {model_name} (samples={current_train_samples}): {e} !!!!!!\")\n",
    "                traceback.print_exc()\n",
    "                # Append NaN to all metrics for this model for this sample size to maintain list lengths\n",
    "                overall_metrics[\"best_val_loss\"][model_name].append(float('nan'))\n",
    "                overall_metrics[\"final_train_loss\"][model_name].append(float('nan'))\n",
    "                overall_metrics[\"final_val_loss\"][model_name].append(float('nan'))\n",
    "                overall_metrics[\"best_val_varex\"][model_name].append(float('nan'))\n",
    "                overall_metrics[\"final_train_varex\"][model_name].append(float('nan'))\n",
    "                overall_metrics[\"final_val_varex\"][model_name].append(float('nan'))\n",
    "                overall_metrics[\"generalization_gap\"][model_name].append(float('nan'))\n",
    "                overall_metrics[\"decodability_r2\"][model_name].append(float('nan'))\n",
    "\n",
    "                # Store NaNs for current run reports as well\n",
    "                # Need to append enough NaNs to match the expected length if an early error occurred\n",
    "                epochs_ran = len(current_run_train_losses_epoch.get(model_name, []))\n",
    "                epochs_total = current_config[\"epochs\"]\n",
    "                nan_count = epochs_total - epochs_ran\n",
    "\n",
    "                if nan_count > 0:\n",
    "                     current_run_train_losses_epoch[model_name].extend([float('nan')] * nan_count)\n",
    "                     current_run_val_losses_epoch[model_name].extend([float('nan')] * nan_count)\n",
    "                     current_run_train_varex_epoch[model_name].extend([float('nan')] * nan_count)\n",
    "                     current_run_val_varex_epoch[model_name].extend([float('nan')] * nan_count)\n",
    "\n",
    "                current_run_decodability_results[model_name] = float('nan')\n",
    "\n",
    "\n",
    "        # --- 5. Plot Learning Curves for the current num_samples run ---\n",
    "        # This plots validation losses per epoch for all models for the current num_samples\n",
    "        # Check if any model actually ran and has losses before plotting\n",
    "        if any(loss_list and not all(np.isnan(l) for l in loss_list) for loss_list in current_run_val_losses_epoch.values()):\n",
    "             plot_learning_curves(\n",
    "                 current_run_val_losses_epoch, # Pass the dict of val losses\n",
    "                 title=f\"Validation Learning Curves (Samples={current_train_samples}, k={current_config['num_task_coefficients']})\",\n",
    "                 save_path=os.path.join(sample_run_results_dir, \"learning_curves_validation.png\")\n",
    "             )\n",
    "             print(f\"\\nValidation learning curves for samples={current_train_samples} plotted.\")\n",
    "\n",
    "        # Plot training losses too\n",
    "        if any(loss_list and not all(np.isnan(l) for l in loss_list) for loss_list in current_run_train_losses_epoch.values()):\n",
    "             plot_learning_curves( # Assuming it can take train_losses too\n",
    "                  current_run_train_losses_epoch,\n",
    "                  title=f\"Training Learning Curves (Samples={current_train_samples}, k={current_config['num_task_coefficients']})\",\n",
    "                  save_path=os.path.join(sample_run_results_dir, \"learning_curves_training.png\")\n",
    "             )\n",
    "             print(f\"\\nTraining learning curves for samples={current_train_samples} plotted.\")\n",
    "\n",
    "\n",
    "        # --- 6. Report Decodability for the current num_samples run ---\n",
    "        if current_run_decodability_results: # Check if the dict is not empty\n",
    "             summary_path = os.path.join(sample_run_results_dir, \"decodability_summary.txt\")\n",
    "             with open(summary_path, \"w\") as f:\n",
    "                 f.write(\"Model,R2_Score\\n\")\n",
    "                 for model_name, score in current_run_decodability_results.items():\n",
    "                     f.write(f\"{model_name},{score:.4f}\\n\")\n",
    "             print(f\"Decodability summary for samples={current_train_samples} saved to {summary_path}\")\n",
    "\n",
    "    # --- 7. After all num_samples sweeps, Plot Aggregate Metrics ---\n",
    "    print(\"\\n\\n--- Generating Sweep Summary Plots ---\")\n",
    "    metric_plot_titles = {\n",
    "        \"best_val_loss\": (f\"Best Validation Loss vs. Training Sample Size (k={CONFIG['fixed_num_task_coefficients']})\", \"Best Validation Loss (MSE)\"),\n",
    "        \"final_train_loss\": (f\"Final Training Loss vs. Training Sample Size (k={CONFIG['fixed_num_task_coefficients']})\", \"Final Training Loss (MSE)\"),\n",
    "        \"final_val_loss\": (f\"Final Validation Loss vs. Training Sample Size (k={CONFIG['fixed_num_task_coefficients']})\", \"Final Validation Loss (MSE)\"),\n",
    "        \"best_val_varex\": (f\"Best Validation Variance Explained vs. Training Sample Size (k={CONFIG['fixed_num_task_coefficients']})\", \"Best Validation Variance Explained\"),\n",
    "        \"final_train_varex\": (f\"Final Training Variance Explained vs. Training Sample Size (k={CONFIG['fixed_num_task_coefficients']})\", \"Final Training Variance Explained\"),\n",
    "        \"final_val_varex\": (f\"Final Validation Variance Explained vs. Training Sample Size (k={CONFIG['fixed_num_task_coefficients']})\", \"Final Validation Variance Explained\"),\n",
    "        \"generalization_gap\": (f\"Generalization Gap vs. Training Sample Size (k={CONFIG['fixed_num_task_coefficients']})\", \"Generalization Gap (Val - Train Loss)\"),\n",
    "        \"decodability_r2\": (f\"Hidden Layer Decodability (R²) vs. Training Sample Size (k={CONFIG['fixed_num_task_coefficients']})\", \"Decodability (R²)\"),\n",
    "    }\n",
    "    plot_sweep_summary_metrics(overall_metrics, train_samples_sweep, base_sweep_results_dir, metric_plot_titles, x_label=\"Number of Training Samples\")\n",
    "\n",
    "    # --- 8. Save Overall Metrics Data ---\n",
    "    overall_metrics_save_path = os.path.join(base_sweep_results_dir, \"overall_metrics_data.npz\")\n",
    "    # Convert lists to numpy arrays for saving, handling potential mixed types if NaNs are strings\n",
    "    save_overall_metrics = {}\n",
    "    # Add the sweep values to the saved data\n",
    "    save_overall_metrics['train_samples_sweep'] = np.array(train_samples_sweep)\n",
    "\n",
    "    for metric, models_data in overall_metrics.items():\n",
    "        save_overall_metrics[metric] = {}\n",
    "        for model, values in models_data.items():\n",
    "            try:\n",
    "                # Attempt to cast to float, handling None or other non-numeric\n",
    "                save_overall_metrics[metric][model] = np.array([v if isinstance(v, (int, float)) else np.nan for v in values], dtype=float)\n",
    "            except ValueError:\n",
    "                 # Fallback if direct conversion fails, though the above should cover most cases\n",
    "                 save_overall_metrics[metric][model] = np.array(values, dtype=object) # Save as object array if mixed types exist\n",
    "                 print(f\"Warning: Could not convert metric '{metric}' for model '{model}' to float array. Saved as object array.\")\n",
    "\n",
    "\n",
    "    np.savez_compressed(overall_metrics_save_path, **save_overall_metrics)\n",
    "    print(f\"Overall metrics data saved to: {overall_metrics_save_path}\")\n",
    "\n",
    "\n",
    "    print(f\"\\nExperiment sweep finished. All results in {base_sweep_results_dir}\")\n",
    "\n",
    "\n",
    "if __name__ == \"__main__\":\n",
    "    run_experiment()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c8ba0922-51e8-43c9-925b-f2c041111d75",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.10.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
