{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "637b83fb",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Generating data:   0%|          | 0/1000 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Generating data: 100%|██████████| 1000/1000 [00:41<00:00, 24.36it/s]\n"
     ]
    }
   ],
   "source": [
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "from torch.utils.data import DataLoader\n",
    "from tqdm import tqdm\n",
    "import matplotlib.pyplot as plt\n",
    "import math\n",
    "\n",
    "# -----------------------\n",
    "# Hyperparameters\n",
    "# -----------------------\n",
    "d         = 5       # sequence length & layer-width\n",
    "N_layers  = 3       # # FFN layers\n",
    "K         = 1000    # # teacher networks\n",
    "L_steps   = 20      # GD steps per teacher\n",
    "lr_gd     = 1e-2    # GD lr for teacher\n",
    "lr_train  = 1e-4    # transformer lr\n",
    "EPOCHS    = 20      # training epochs\n",
    "BATCH     = 64      # batch size\n",
    "SEED      = 0\n",
    "num_heads = 32       # attention heads\n",
    "\n",
    "avg_head  = True    # if True, use averaging heads; no pad divisibility needed\n",
    "\n",
    "torch.manual_seed(SEED)\n",
    "device = torch.device(\"cuda\" if torch.cuda.is_available() else \"cpu\")\n",
    "\n",
    "# -----------------------\n",
    "# Derived dimensions\n",
    "# -----------------------\n",
    "rows_block = 1 + 3*d + d**2     # ALWAYS 41\n",
    "hidden_dim = 2 * rows_block\n",
    "pad_size   = (num_heads - (hidden_dim % num_heads)) % num_heads\n",
    "new_hidden = hidden_dim + pad_size\n",
    "input_dim  = hidden_dim if avg_head else new_hidden\n",
    "\n",
    "# -----------------------\n",
    "# Positional Encoding\n",
    "# -----------------------\n",
    "class PositionalEncoding(nn.Module):\n",
    "    def __init__(self, d_model: int, max_len: int = 5000):\n",
    "        super().__init__()\n",
    "        # create constant 'pe' matrix with values dependent on position and i\n",
    "        pe = torch.zeros(max_len, d_model)\n",
    "        position = torch.arange(0, max_len, dtype=torch.float).unsqueeze(1)\n",
    "        div_term = torch.exp(torch.arange(0, d_model, 2).float() *\n",
    "                             (-math.log(10000.0) / d_model))\n",
    "        pe[:, 0::2] = torch.sin(position * div_term)\n",
    "        pe[:, 1::2] = torch.cos(position * div_term)\n",
    "        self.register_buffer('pe', pe)\n",
    "\n",
    "    def forward(self, x: torch.Tensor) -> torch.Tensor:\n",
    "        # x: (batch, seq_len, d_model)\n",
    "        seq_len = x.size(1)\n",
    "        return x + self.pe[:seq_len, :].unsqueeze(0)\n",
    "\n",
    "# -----------------------\n",
    "# Phase 1: Teacher nets\n",
    "# -----------------------\n",
    "def sample_teacher_weights():\n",
    "    return [torch.randn(d, d, device=device) for _ in range(N_layers)]\n",
    "\n",
    "def ff_forward(x, W_list):\n",
    "    h = x\n",
    "    for Wi in W_list[:-1]:\n",
    "        h = F.relu(h @ Wi.T)\n",
    "    return h @ W_list[-1].T  # shape (1, d)\n",
    "\n",
    "# -----------------------\n",
    "# Phase 2: run_icgd\n",
    "# -----------------------\n",
    "def run_icgd(x, y, W_init):\n",
    "    W = [w.clone().requires_grad_(True) for w in W_init]\n",
    "    traj = []\n",
    "    for _ in range(L_steps):\n",
    "        cache = [{} for _ in range(N_layers)]\n",
    "        h = x.clone()\n",
    "        cache[0]['o_prev'] = h.detach().squeeze(0)\n",
    "        zs = []\n",
    "        for i, Wi in enumerate(W):\n",
    "            z = h @ Wi.T; z.retain_grad(); zs.append(z)\n",
    "            sigma = (z > 0).float()\n",
    "            h = F.relu(z) if i < len(W)-1 else z\n",
    "            cache[i]['o_cur']  = h.detach().squeeze(0)\n",
    "            cache[i]['sigma'] = sigma.detach().squeeze(0)\n",
    "            if i+1 < N_layers:\n",
    "                cache[i+1]['o_prev'] = h.detach().squeeze(0)\n",
    "        loss = F.mse_loss(h, y); loss.backward()\n",
    "        for i, (Wi, z) in enumerate(zip(W, zs)):\n",
    "            delta = z.grad.detach().squeeze(0)\n",
    "            cache[i]['delta']    = delta\n",
    "            cache[i]['Wt_delta'] = (Wi.T @ delta).detach()\n",
    "            cache[i]['W']        = Wi.detach().clone()\n",
    "        traj.append(cache)\n",
    "        with torch.no_grad():\n",
    "            for Wi in W:\n",
    "                Wi -= lr_gd * Wi.grad\n",
    "                Wi.grad.zero_()\n",
    "    return traj\n",
    "\n",
    "# -----------------------\n",
    "# Block builders & concat\n",
    "# -----------------------\n",
    "def build_F_block(c):\n",
    "    return torch.cat([\n",
    "        c['o_cur'].unsqueeze(1).repeat(1, d),\n",
    "        c['o_prev'].unsqueeze(1).repeat(1, d),\n",
    "        c['sigma'].unsqueeze(1).repeat(1, d),\n",
    "        c['W'].flatten().unsqueeze(1).repeat(1, d),\n",
    "        torch.ones(1, d, device=device),\n",
    "    ], dim=0)\n",
    "\n",
    "def build_B_block(c):\n",
    "    W_new = c['W'] - lr_gd * torch.ger(c['delta'], c['o_cur'])\n",
    "    return torch.cat([\n",
    "        c['delta'].unsqueeze(1).repeat(1, d),\n",
    "        c['Wt_delta'].unsqueeze(1).repeat(1, d),\n",
    "        W_new.flatten().unsqueeze(1).repeat(1, d),\n",
    "        torch.zeros(d+1, d, device=device),\n",
    "    ], dim=0)\n",
    "\n",
    "def concat_and_pad(Fb, Bb):\n",
    "    M   = torch.cat([Fb, Bb], dim=0)  # (2*rows_block, d)\n",
    "    tok = M.T.contiguous()            # (d, hidden_dim)\n",
    "    if not avg_head and pad_size:\n",
    "        pad = torch.zeros(d, pad_size, device=tok.device)\n",
    "        tok = torch.cat([tok, pad], dim=1)\n",
    "    return tok                         # (d, input_dim)\n",
    "\n",
    "# -----------------------\n",
    "# Phase 3: Data generation\n",
    "# -----------------------\n",
    "forward_examples  = []\n",
    "backward_examples = []\n",
    "for _ in tqdm(range(K), desc=\"Generating data\"):\n",
    "    W0   = sample_teacher_weights()\n",
    "    x0   = torch.randn(1, d, device=device)\n",
    "    y0   = ff_forward(x0, W0)\n",
    "    traj = run_icgd(x0, y0, W0)\n",
    "    for cache in traj:\n",
    "        for i in range(1, N_layers):\n",
    "            Xin  = concat_and_pad(build_F_block(cache[i-1]), build_B_block(cache[i]))\n",
    "            Yout = build_F_block(cache[i]).T\n",
    "            forward_examples.append((Xin, Yout))\n",
    "        for i in range(N_layers-1):\n",
    "            Xin  = concat_and_pad(build_B_block(cache[i+1]), build_F_block(cache[i]))\n",
    "            Yout = build_B_block(cache[i]).T\n",
    "            backward_examples.append((Xin, Yout))\n",
    "\n",
    "# -----------------------\n",
    "# Collate & DataLoaders\n",
    "# -----------------------\n",
    "def collate_fn(batch):\n",
    "    Xs, Ys = zip(*batch)\n",
    "    Xs_p, Ys_p = [], []\n",
    "    for x,y in zip(Xs, Ys):\n",
    "        if x.size(1)!=input_dim:\n",
    "            x = torch.cat([x, x.new_zeros(d, input_dim-x.size(1))],1)\n",
    "        if y.size(1)!=rows_block:\n",
    "            y = torch.cat([y, y.new_zeros(d, rows_block-y.size(1))],1)\n",
    "        Xs_p.append(x); Ys_p.append(y)\n",
    "    return torch.stack(Xs_p), torch.stack(Ys_p)\n",
    "\n",
    "from sklearn.model_selection import train_test_split\n",
    "\n",
    "# Suppose your data is in a list called `forward_examples`:\n",
    "# forward_examples = [...]\n",
    "\n",
    "# Split 80% train / 20% test\n",
    "train_set, test_set = train_test_split(\n",
    "    forward_examples,\n",
    "    test_size=0.2,     # 20% goes to test\n",
    "    random_state=42     # for reproducibility\n",
    ")\n",
    "split_b = int(0.8*len(backward_examples))\n",
    "fwd_loader = DataLoader(train_set, batch_size=BATCH, shuffle=True, collate_fn=collate_fn)\n",
    "fwd_test   = DataLoader(test_set, batch_size=BATCH, shuffle=False, collate_fn=collate_fn)\n",
    "bwd_loader = DataLoader(backward_examples[:split_b], batch_size=BATCH, shuffle=True, collate_fn=collate_fn)\n",
    "bwd_test   = DataLoader(backward_examples[split_b:], batch_size=BATCH, shuffle=False, collate_fn=collate_fn)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "996056d9",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 01 | Fwd 3.1350e+02/1.4995e+02 | Bwd 1.1649e+01/2.2867e-02\n",
      "Epoch 02 | Fwd 9.2259e+01/5.4332e+01 | Bwd 1.3878e-02/4.6772e-02\n",
      "Epoch 03 | Fwd 3.4780e+01/2.1065e+01 | Bwd 7.7515e-02/1.6233e-01\n",
      "Epoch 04 | Fwd 2.3528e+01/2.1934e+01 | Bwd 1.1376e-01/1.3414e-01\n",
      "Epoch 05 | Fwd 2.0777e+01/2.1964e+01 | Bwd 1.5585e-01/1.6166e-01\n",
      "Epoch 06 | Fwd 1.3838e+01/2.5012e+01 | Bwd 1.2401e-01/1.2730e-01\n",
      "Epoch 07 | Fwd 1.3810e+01/8.7225e+00 | Bwd 1.4533e-01/1.5568e-01\n",
      "Epoch 08 | Fwd 1.1462e+01/1.1134e+01 | Bwd 1.5430e-01/1.1869e-01\n",
      "Epoch 09 | Fwd 1.0080e+01/7.0821e+00 | Bwd 1.1610e-01/9.0995e-02\n",
      "Epoch 10 | Fwd 8.3082e+00/9.3717e+00 | Bwd 1.2831e-01/1.6266e-01\n",
      "Epoch 11 | Fwd 1.1115e+01/1.0170e+01 | Bwd 1.3799e-01/1.1926e-01\n",
      "Epoch 12 | Fwd 9.4293e+00/1.0287e+01 | Bwd 1.3492e-01/1.4535e-01\n",
      "Epoch 13 | Fwd 7.3145e+00/4.5836e+00 | Bwd 1.3591e-01/1.2744e-01\n",
      "Epoch 14 | Fwd 9.7245e+00/9.2797e+00 | Bwd 1.2692e-01/1.6940e-01\n",
      "Epoch 15 | Fwd 7.9916e+00/1.0533e+01 | Bwd 1.1370e-01/1.3325e-01\n",
      "Epoch 16 | Fwd 8.0783e+00/7.6755e+00 | Bwd 1.3864e-01/1.5681e-01\n",
      "Epoch 17 | Fwd 6.4747e+00/5.3187e+00 | Bwd 1.1189e-01/1.1419e-01\n",
      "Epoch 18 | Fwd 8.3272e+00/3.0000e+00 | Bwd 1.2760e-01/1.3875e-01\n",
      "Epoch 19 | Fwd 5.0444e+00/2.0738e+01 | Bwd 1.2880e-01/1.0666e-01\n",
      "Epoch 20 | Fwd 8.8854e+00/5.6307e+00 | Bwd 1.2091e-01/1.3975e-01\n"
     ]
    },
    {
     "data": {
      "image/png": "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KdnZ2ZSVlbFr1y7mz59PUlJStfMEBATw4osvcvjwYYqKivjoo49qpGlvesRUBLcHC1q5JCIiIh2b6XRS+PU35H78CYVff4PZzItAHb/6alRUFOPHj+eHH35o1nyreuaZZwgPD6eoqKjGvpKSEiIiInj22WdbrDy+pF7SbVRydAigVcpERESaU96yZfw8+gJ2X3cd+++4g93XXcfOC8ZQvDKtWfOtuvrqp59+ip+fH5MmTWrWPKu69tprKS4u5r333qux77333qOoqIhrrrmmxcrjSwpu2yhPtwT1uRUREWkWecuWse/WmZRnZVXbXp6dzdF77yW/ymB1X6tcfTU+Pp6BAwdy9913s2fPHg4ePAjApZdeyowZMzzpZ86ciWEYbN682V3G8nJCQ0NZunQpAIWFhVx77bWEhISQkJDAM888U2/+MTExTJ48mVdffbXGvldffZUpU6YQExPD3XffTa9evQgKCqJHjx48+OCDbX4hEAW3bdQpFd0S9uYUUVrevF+PiIiIdASmaeIqKvLq4czP58Ajf4Ha1rKq2Jb96GM48/MbPNeJrodVUFDAW2+9Rc+ePYmKigLc/WXT0tI8adLT04mOjiY9PR2AtWvXUlJSwrBhwwC48847WblyJYsWLWLZsmWkpaWxbt26evOdPn066enpZGRkeLb98ssvrFy5kunTpwMQGhrK/Pnz2bJlCy+88AKvvPIKzz333Aldb3NrE/PcSk0xoXaC/a0UljnZc6SInrGhDR8kIiLSiZnFxWw7c5DPzld+4ADbzz6nwXS9v1uH0cgVTj/++GNCQtxdEAsLC0lISODjjz/2zBebmprKrbfeyqFDh7BarWzevJmHHnqItLQ0brrpJtLS0hg0aBAhISEUFBQwb9483njjDcaMGQPA66+/3uDaAePGjSMxMZH58+d7Vm597bXXSExMZOzYsQA88MADnvQnn3wyt99+O//+97+56667GnW9LUktt22UYRj0iHHf9DvUNUFERKRDGTVqFBs2bGDDhg18/fXXjB07lgkTJrBr1y7AvSprVFQU6enpfPHFFwwYMIApU6Z4Wm7T0tIYOXIkADt27KCsrIwhQ46tahoZGUnv3r3rLYPVauW6665j/vz5uFwuTNPk9ddfZ9q0aZ4Zp959912GDx9OfHw8ISEhPPjgg+zevbs5qsRn1HLbhiVHB7NxX64GlYmIiHjBCAyk93f1fxVfqejbb9nzuxsbTJf08j8IOuusBvNtrODgYHr27Ol5PWjQIMLDw3nllVd45JFHMAyDESNGkJaWhr+/P6mpqaSkpOB0Otm4cSOrV6/2TPN1It0ibrjhBh577DE+++wzAHbv3s31118PwJo1a7jiiiuYM2cO48aNIzw8nIULFzbYn7e1KbhtwzQdmIiIiPcMw/C6e0DwsGH4xcdTfuBA7f1uAb/4eIKHDcNogXnzK5ewrVzICtxdE15++WX8/f15+OGHMQyD8847j6effpri4mJPf9uePXtis9lYs2YN3bp1AyAnJ4ft27d7WnfrcsoppzBy5Ehee+01TNMkNTWVU045BYAvv/yS7t27c//993vSV7Yst2UKbtuwyhkT1HIrIiLiW4bVStx997Lv1plgGNUD3IrXsffe02yBbWlpKVkVszTk5OTw0ksvUVBQwOTJkz1pKvvd+vn5cd5553m23X777Zx55pmEhYUBEBISwvTp07nzzjuJiooiLi6O+++/39N/tyHTp0/nt7/9LQD//Oc/Pdt79uzJ7t27WbhwIWeffTaffPIJixYt8sn1Nyf1uW3DelTMdavpwERERHwvbOxYTnrhefzi4qpt94uLI+KxxwitGJzVHJYsWeJZmfXcc89l7dq1vPPOO6SmpnrSpKSkEB0dzYABAzyB7MiRI3E6nTVaZJ966ilGjBjBlClTuOCCCxg+fDiDBnk3uO7SSy/Fbrdjt9uZOnWqZ/tFF13Ebbfdxi233MLAgQNZvXo1Dz744IlffDNTy20bllzRLeFwYRm5RQ7Cg2ytXCIREZGOJWzsWEJHj6bo23WUHzyIX0wMAWeeQX5h8zUszZ8/n/nz5zeYzjAMsrOzq20bOHBgrX1sQ0JCePPNN3nzzTc92+68806vyhMYGMjRo0dr3ffkk0/y5JNPVttWdUnfe+65h0cffdSrfFqKgts2LMTuR2yonez8UjIOFzIwKKK1iyQiItLhGFYrwecem/LL5XK1YmnkRKlbQhunQWUiIiIi3lNw28YlV/S71aAyERERkYYpuG3jTvG03Cq4FREREWmIgts2rnI6sJ1quRURERFpkILbNu7YXLcFuFxNX4FERESkIzqR1bmk7fHF71PBbRuXFBmEn8WgxOEiK6+ktYsjIiLSJths7ukxi4qKWrkk4kuVv8/K329TaCqwNs5mtdAtMoidhwrJOFRIYkTj168WERHpaKxWKxEREZ55YIOCgjAMwyfndrlclJWVUVJS4vUqX52RL+vJNE2KiorIzs4mIiIC6wmsDKfgth3oERPMzkOF7DxYwLCe0a1dHBERkTYhPj4eoMZCByfKNE2Ki4sJDAz0WcDcETVHPUVERHh+r02l4LYd0KAyERGRmgzDICEhgdjYWBwOh8/O63A4+PzzzxkxYsQJfT3e0fm6nmw22wm12FZScNsO9Ihxz3Wr6cBERERqslqtPgmKqp6vvLycgIAABbf1aKv1pI4k7cCxGRMU3IqIiIjUR8FtO1C5BO/enCJKy52tXBoRERGRtkvBbTsQE2InxO6Hy4TdhzXliYiIiEhdFNy2A4ZhaFCZiIiIiBcU3LYTlV0TNKhMREREpG4KbtuJqsvwioiIiEjtFNy2E5oOTERERKRhCm7biR6aDkxERESkQQpu24nKbgmHC8vILfLdKiwiIiIiHYmC23Yi2O5HXJgdgJ3qdysiIiJSKwW37YhWKhMRERGpn4LbdkSDykRERETqp+C2HdGgMhEREZH6tWpw+9hjj3H22WcTGhpKbGwsF198Mdu2bauWxjRNZs+eTWJiIoGBgaSmprJ58+ZqaUpLS5kxYwbR0dEEBwczZcoU9u7d25KX0iIqF3LYcVB9bkVERERq06rBbXp6OjfffDNr1qxh+fLllJeXM3bsWAoLj7VMPvnkkzz77LO89NJLrF27lvj4eMaMGUN+fr4nzcyZM1m0aBELFy5k1apVFBQUMGnSJJxOZ2tcVrNJjnZ3S/jlcCEul9nKpRERERFpe/xaM/MlS5ZUe/3aa68RGxvLunXrGDFiBKZp8vzzz3P//fczdepUAF5//XXi4uJ4++23ufHGG8nNzWXevHm8+eabXHDBBQAsWLCApKQkVqxYwbhx41r8uppLUpdA/CwGJQ4XmXklnBQR2NpFEhEREWlTWjW4PV5ubi4AkZGRAGRkZJCVlcXYsWM9aex2OyNHjmT16tXceOONrFu3DofDUS1NYmIiKSkprF69utbgtrS0lNLSUs/rvLw8ABwOBw5H255DtltkIDsPFfFTVi6xwS3366usl7ZeP61N9eQd1ZN3VE/eUT15R/XkPdWVd1q6nrzNp80Et6ZpMmvWLIYPH05KSgoAWVlZAMTFxVVLGxcXx65duzxp/P396dKlS400lccf77HHHmPOnDk1ti9btoygoKATvpbmFOS0ABY+Tv+G3G0t3zVh+fLlLZ5ne6R68o7qyTuqJ++onryjevKe6so7LVVPRUVFXqVrM8HtLbfcwg8//MCqVatq7DMMo9pr0zRrbDtefWnuvfdeZs2a5Xmdl5dHUlISY8eOJSwsrAmlbzk/WLax6ctdBMUlM3FinxbL1+FwsHz5csaMGYPNZmuxfNsb1ZN3VE/eUT15R/XkHdWT91RX3mnpeqr8pr0hbSK4nTFjBh9++CGff/45Xbt29WyPj48H3K2zCQkJnu3Z2dme1tz4+HjKysrIycmp1nqbnZ3N0KFDa83Pbrdjt9trbLfZbG3+Ju4Z5w6+dx0pbpWytoc6agtUT95RPXlH9eQd1ZN3VE/eU115p6Xqyds8WnW2BNM0ueWWW3j//ff57LPPSE5OrrY/OTmZ+Pj4as3dZWVlpKenewLXQYMGYbPZqqXJzMxk06ZNdQa37VnlXLdagldERESkplZtub355pt5++23+e9//0toaKinj2x4eDiBgYEYhsHMmTN59NFHOfXUUzn11FN59NFHCQoK4qqrrvKknT59OrfffjtRUVFERkZyxx130L9/f8/sCR1JcsVct3tziiktd2L3s7ZyiURERETajlYNbufOnQtAampqte2vvfYa06ZNA+Cuu+6iuLiYm266iZycHM4991yWLVtGaGioJ/1zzz2Hn58fl112GcXFxYwePZr58+djtXa8wC8mxE6o3Y/80nJ2HS6iV1xowweJiIiIdBKtGtyaZsOj/Q3DYPbs2cyePbvONAEBAbz44ou8+OKLPixd22QYBskxwfywN5edBwsV3IqIiIhU0ap9bqVpkiv63WYcKmwgpYiIiEjnouC2HepRsQzvzoMaVCYiIiJSlYLbdqhyUJlabkVERESqU3DbDh2bDkzBrYiIiEhVCm7boco+t0cKyzhaVNbKpRERERFpOxTctkPBdj/iwwIAtd6KiIiIVKXgtp3yzJhwUMGtiIiISCUFt+2UBpWJiIiI1KTgtp06NqhM04GJiIiIVFJw2071qGi53aluCSIiIiIeCm7bqcqFHH45XIjL1fAyxiIiIiKdgYLbdqprl0BsVoMSh4vMvJLWLo6IiIhIm6Dgtp3ys1roFhkEaBleERERkUoKbtux5IquCZoxQURERMRNwW07pkFlIiIiItUpuG3Hjk0HpuBWREREBBTctmueVco0162IiIgIoOC2XesR4+5zuzenmBKHs5VLIyIiItL6FNy2Y9Eh/oTa/TBN2H2kqLWLIyIiItLqFNy2Y4ZhVBlUpq4JIiIiIk0Kbvfs2cPevXs9r7/55htmzpzJyy+/7LOCiXeSNahMRERExKNJwe1VV13FypUrAcjKymLMmDF888033HfffTz88MM+LaDUr7LfbYamAxMRERFpWnC7adMmzjnnHAD+85//kJKSwurVq3n77beZP3++L8snDVDLrYiIiMgxTQpuHQ4HdrsdgBUrVjBlyhQA+vTpQ2Zmpu9KJw06Nh2YglsRERGRJgW3/fr14+9//ztffPEFy5cvZ/z48QDs37+fqKgonxZQ6lcZ3B4pLONoUVkrl0ZERESkdTUpuH3iiSf4xz/+QWpqKldeeSUDBgwA4MMPP/R0V5CWEWz3Iz4sAFDXBBERERG/phyUmprKoUOHyMvLo0uXLp7tv/vd7wgKCvJZ4cQ7PWKCycorYefBQs7s1qXhA0REREQ6qCa13BYXF1NaWuoJbHft2sXzzz/Ptm3biI2N9WkBpWFahldERETErUnB7UUXXcQbb7wBwNGjRzn33HN55plnuPjii5k7d65PCygN80wHpm4JIiIi0sk1Kbj97rvvOO+88wB49913iYuLY9euXbzxxhv89a9/9WkBpWE9KqcD01y3IiIi0sk1KbgtKioiNDQUgGXLljF16lQsFguDBw9m165dPi2gNKzqdGAul9nKpRERERFpPU0Kbnv27MkHH3zAnj17WLp0KWPHjgUgOzubsLAwnxZQGta1SyA2q0FpuYv9ucWtXRwRERGRVtOk4PZPf/oTd9xxByeffDLnnHMOQ4YMAdytuGeccYZPCygN87Na6BbpnqVC/W5FRESkM2vSVGC/+tWvGD58OJmZmZ45bgFGjx7NJZdc4rPCdUguJ+xaDQUHICQOug8Fi/WET9sjJoQdBwvZebCQ806N8UFBRURERNqfJrXcAsTHx3PGGWewf/9+9u3bB8A555xDnz59vD7H559/zuTJk0lMTMQwDD744INq+6dNm4ZhGNUegwcPrpamtLSUGTNmEB0dTXBwMFOmTGHv3r1NvazmteVDeD4FXp8E7013/3w+xb39BPXQMrwiIiIiTQtuXS4XDz/8MOHh4XTv3p1u3boRERHBn//8Z1wul9fnKSwsZMCAAbz00kt1phk/fjyZmZmex+LFi6vtnzlzJosWLWLhwoWsWrWKgoICJk2ahNPpbMqlNZ8tH8J/roW8/dW352W6t59ggNsjpmLGBAW3IiIi0ok1qVvC/fffz7x583j88ccZNmwYpmny5ZdfMnv2bEpKSvjLX/7i1XkmTJjAhAkT6k1jt9uJj4+vdV9ubi7z5s3jzTff5IILLgBgwYIFJCUlsWLFCsaNG9e4C2suLicsuRuobSYDEzBgyT3Q58Imd1FIjnbPdbvzoBZyEBERkc6rScHt66+/zj//+U+mTJni2TZgwABOOukkbrrpJq+DW2+kpaURGxtLREQEI0eO5C9/+YtnFbR169bhcDg8szUAJCYmkpKSwurVq+sMbktLSyktLfW8zsvLA8DhcOBwOHxW9krGrlX4Hd9iW40Jefso3/k5ZvfhTcojKcIfgH1HiykoKsFuO/F+vFVV1ktz1E9HonryjurJO6on76ievKN68p7qyjstXU/e5tOk4PbIkSO19q3t06cPR44cacopazVhwgR+/etf0717dzIyMnjwwQc5//zzWbduHXa7naysLPz9/T3LAFeKi4sjKyurzvM+9thjzJkzp8b2ZcuWERQU5LPyVzrpyFec5UW6DV8sZd/mvCblYZoQaLVS7DR4879LSfT9ZQCwfPny5jlxB6N68o7qyTuqJ++onryjevKe6so7LVVPRUVFXqVrUnBb2U/2+NXIXnrpJU4//fSmnLJWl19+ued5SkoKZ511Ft27d+eTTz5h6tSpdR5nmiaGYdS5/95772XWrFme13l5eSQlJTF27NhmmafX2BUGuxpelnjgeeMY0MSWW4BX96zhh315JJ02iHH94pp8nto4HA6WL1/OmDFjsNlsPj13R6J68o7qyTuqJ++onryjevKe6so7LV1Pld+0N6RJwe2TTz7JhRdeyIoVKxgyZAiGYbB69Wr27NlTY8CXLyUkJNC9e3d++uknwD1jQ1lZGTk5OdVab7Ozsxk6dGid57Hb7djt9hrbbTZb8/xyeoyAsET34LFa+90aEJaIX48RJzQt2CmxofywL49dOSXNdpM1Wx11MKon76ievKN68o7qyTuqJ++prrzTUvXkbR5Nmi1h5MiRbN++nUsuuYSjR49y5MgRpk6dyubNm3nttdea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1ZP3VFfeacl6qq/FtpIGlImIiIhIh6HgVkREREQ6DAW34hW73c5DDz2E3W5v7aK0aaon76ievKN68o7qyTuqJ++prrzTVutJA8pEREREpMNQy62IiIiIdBgKbkVERESkw1BwKyIiIiIdhoJbEREREekwFNwKjz32GGeffTahoaHExsZy8cUXs23btnqPSUtLwzCMGo8ff/yxhUrd8mbPnl3jeuPj4+s9Jj09nUGDBhEQEECPHj34+9//3kKlbT0nn3xyrffGzTffXGv6znIvff7550yePJnExEQMw+CDDz6ott80TWbPnk1iYiKBgYGkpqayefPmBs/73nvv0bdvX+x2O3379mXRokXNdAUto756cjgc3H333fTv35/g4GASExO59tpr2b9/f73nnD9/fq33WElJSTNfTfNp6H6aNm1ajesdPHhwg+ftaPcTNFxXtd0bhmHw1FNP1XnOjnZPeRMHtKf3KAW3Qnp6OjfffDNr1qxh+fLllJeXM3bsWAoLCxs8dtu2bWRmZnoep556aguUuPX069ev2vVu3LixzrQZGRlMnDiR8847j/Xr13Pffffxxz/+kffee68FS9zy1q5dW62Oli9fDsCvf/3reo/r6PdSYWEhAwYM4KWXXqp1/5NPPsmzzz7LSy+9xNq1a4mPj2fMmDHk5+fXec6vvvqKyy+/nGuuuYbvv/+ea665hssuu4yvv/66uS6j2dVXT0VFRXz33Xc8+OCDfPfdd7z//vts376dKVOmNHjesLCwavdXZmYmAQEBzXEJLaKh+wlg/Pjx1a538eLF9Z6zI95P0HBdHX9fvPrqqxiGwaWXXlrveTvSPeVNHNCu3qNMkeNkZ2ebgJmenl5nmpUrV5qAmZOT03IFa2UPPfSQOWDAAK/T33XXXWafPn2qbbvxxhvNwYMH+7hkbdutt95qnnLKKabL5ap1f2e8lwBz0aJFntcul8uMj483H3/8cc+2kpISMzw83Pz73/9e53kuu+wyc/z48dW2jRs3zrziiit8XubWcHw91eabb74xAXPXrl11pnnttdfM8PBw3xauDamtnq677jrzoosuatR5Ovr9ZJre3VMXXXSRef7559ebpqPfU8fHAe3tPUott1JDbm4uAJGRkQ2mPeOMM0hISGD06NGsXLmyuYvW6n766ScSExNJTk7miiuuYOfOnXWm/eqrrxg7dmy1bePGjePbb7/F4XA0d1HbhLKyMhYsWMANN9yAYRj1pu1s91JVGRkZZGVlVbtf7HY7I0eOZPXq1XUeV9c9Vt8xHU1ubi6GYRAREVFvuoKCArp3707Xrl2ZNGkS69evb5kCtqK0tDRiY2Pp1asXv/3tb8nOzq43ve4nOHDgAJ988gnTp09vMG1HvqeOjwPa23uUglupxjRNZs2axfDhw0lJSakzXUJCAi+//DLvvfce77//Pr1792b06NF8/vnnLVjalnXuuefyxhtvsHTpUl555RWysrIYOnQohw8frjV9VlYWcXFx1bbFxcVRXl7OoUOHWqLIre6DDz7g6NGjTJs2rc40nfFeOl5WVhZArfdL5b66jmvsMR1JSUkJ99xzD1dddRVhYWF1puvTpw/z58/nww8/5F//+hcBAQEMGzaMn376qQVL27ImTJjAW2+9xWeffcYzzzzD2rVrOf/88yktLa3zmM5+PwG8/vrrhIaGMnXq1HrTdeR7qrY4oL29R/k169ml3bnlllv44YcfWLVqVb3pevfuTe/evT2vhwwZwp49e3j66acZMWJEcxezVUyYMMHzvH///gwZMoRTTjmF119/nVmzZtV6zPGtlWbFgoANtWJ2FPPmzWPChAkkJibWmaYz3kt1qe1+aeheacoxHYHD4eCKK67A5XLxt7/9rd60gwcPrjaYatiwYZx55pm8+OKL/PWvf23uoraKyy+/3PM8JSWFs846i+7du/PJJ5/UG7h11vup0quvvspvfvObBvvOduR7qr44oL28R6nlVjxmzJjBhx9+yMqVK+natWujjx88eHCH+NTqreDgYPr371/nNcfHx9f4dJqdnY2fnx9RUVEtUcRWtWvXLlasWMH/+3//r9HHdrZ7qXLWjdrul+NbPY4/rrHHdAQOh4PLLruMjIwMli9fXm+rbW0sFgtnn312p7rHEhIS6N69e73X3Fnvp0pffPEF27Zta9J7Vke5p+qKA9rbe5SCW8E0TW655Rbef/99PvvsM5KTk5t0nvXr15OQkODj0rVdpaWlbN26tc5rHjJkiGemgErLli3jrLPOwmaztUQRW9Vrr71GbGwsF154YaOP7Wz3UnJyMvHx8dXul7KyMtLT0xk6dGidx9V1j9V3THtXGdj+9NNPrFixokkfFE3TZMOGDZ3qHjt8+DB79uyp95o74/1U1bx5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",
      "text/plain": [
       "<Figure size 800x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Test-losses: 5.630697858810425 0.13975106525421144\n"
     ]
    }
   ],
   "source": [
    "# -----------------------\n",
    "# Phase 4: Model definitions\n",
    "# -----------------------\n",
    "# class OneLayerDecoder(nn.Module):\n",
    "#     def __init__(self, d_model, out_dim, heads=num_heads):\n",
    "#         super().__init__()\n",
    "#         self.pos_enc = PositionalEncoding(d_model)\n",
    "#         self.attn    = nn.MultiheadAttention(d_model, heads, batch_first=True)\n",
    "#         self.ffn     = nn.Sequential(\n",
    "#             nn.Linear(d_model, 4*d_model), nn.ReLU(),\n",
    "#             nn.Linear(4*d_model, d_model)\n",
    "#         )\n",
    "#         self.ln1, self.ln2 = nn.LayerNorm(d_model), nn.LayerNorm(d_model)\n",
    "#         self.head   = nn.Linear(d_model, out_dim)\n",
    "#     def forward(self, x):\n",
    "#         # x: (batch, seq_len, d_model)\n",
    "#         x = self.pos_enc(x)\n",
    "#         a,_ = self.attn(x, x, x)\n",
    "#         h   = self.ln1(x + a)\n",
    "#         h   = self.ln2(h + self.ffn(h))\n",
    "#         return self.head(h)\n",
    "\n",
    "num_heads = 32       # attention heads\n",
    "lr_train = 1e-4\n",
    "\n",
    "class AveragingMultiHeadAttention(nn.Module):\n",
    "    def __init__(self, d_model, num_heads, dropout=0.0):\n",
    "        super().__init__()\n",
    "        self.num_heads, self.d_model = num_heads, d_model\n",
    "        self.q_linears = nn.ModuleList([nn.Linear(d_model, d_model) for _ in range(num_heads)])\n",
    "        self.k_linears = nn.ModuleList([nn.Linear(d_model, d_model) for _ in range(num_heads)])\n",
    "        self.v_linears = nn.ModuleList([nn.Linear(d_model, 4*d_model) for _ in range(num_heads)])\n",
    "        self.dropout = nn.Dropout(dropout)\n",
    "    def forward(self, x):\n",
    "        head_outs = []\n",
    "        for i in range(self.num_heads):\n",
    "            Q = self.q_linears[i](x); K = self.k_linears[i](x)\n",
    "            V = self.v_linears[i](x)\n",
    "            scores = torch.bmm(Q, K.transpose(1,2)) / math.sqrt(self.d_model)\n",
    "            attn   = self.dropout(torch.softmax(scores, dim=-1))\n",
    "            head_outs.append(torch.bmm(attn, V))\n",
    "        return sum(head_outs) / self.num_heads\n",
    "\n",
    "class OneLayerDecoderAvgEmbed(nn.Module):\n",
    "    def __init__(self, input_dim, d_model, out_dim, heads=num_heads, dropout=0):\n",
    "        super().__init__()\n",
    "        self.input_proj  = nn.Linear(input_dim, d_model)\n",
    "        self.attn        = AveragingMultiHeadAttention(d_model+d, heads, dropout)\n",
    "        self.ln1         = nn.LayerNorm(4*d_model+4*d)\n",
    "        self.ffn         = nn.Sequential(nn.Linear(4*d_model+4*d, 16*d_model),\n",
    "                                          nn.GELU(), nn.Linear(16*d_model, d_model))\n",
    "        self.ln2         = nn.LayerNorm(d_model)\n",
    "        self.output_proj = nn.Linear(d_model, out_dim)\n",
    "    def forward(self, x):\n",
    "        x_emb = self.input_proj(x)\n",
    "        x_temp = x_emb\n",
    "        pos = torch.eye(d, device=\"cuda\").unsqueeze(0).repeat(x.size(0), 1, 1)\n",
    "        x_temp = torch.cat((x_emb,pos),dim=-1)\n",
    "        a     = self.attn(x_temp)\n",
    "        h     = self.ffn(a)\n",
    "        return self.output_proj(h)\n",
    "\n",
    "# Instantiate models\n",
    "if avg_head:\n",
    "    model_fwd = OneLayerDecoderAvgEmbed(input_dim, 64, rows_block, num_heads).to(device)\n",
    "    model_bwd = OneLayerDecoderAvgEmbed(input_dim, 64, rows_block, num_heads).to(device)\n",
    "else:\n",
    "    model_fwd = OneLayerDecoder(input_dim, rows_block).to(device)\n",
    "    model_bwd = OneLayerDecoder(input_dim, rows_block).to(device)\n",
    "\n",
    "opt_fwd = torch.optim.AdamW(model_fwd.parameters(), lr=lr_train)\n",
    "opt_bwd = torch.optim.AdamW(model_bwd.parameters(), lr=lr_train)\n",
    "\n",
    "# -----------------------\n",
    "# Phase 5: Train / Eval\n",
    "# -----------------------\n",
    "def train_epoch(m, loader, opt):\n",
    "    m.train(); total=0.0\n",
    "    for X, Y in loader:\n",
    "        X, Y = X.to(device), Y.to(device)\n",
    "        loss_sum = F.mse_loss(m(X), Y, reduction='sum')\n",
    "        loss     = loss_sum / X.size(0)\n",
    "        opt.zero_grad(); loss.backward(); opt.step()\n",
    "        total += loss.item() * X.size(0)\n",
    "    return total / len(loader.dataset)\n",
    "\n",
    "def eval_loss(m, loader):\n",
    "    m.eval(); total=0.0\n",
    "    with torch.no_grad():\n",
    "        for X, Y in loader:\n",
    "            total += F.mse_loss(m(X), Y, reduction='sum').item()\n",
    "    return total / len(loader.dataset)\n",
    "\n",
    "# Training loop & plotting (UNCHANGED)\n",
    "train_fwd_losses, val_fwd_losses = [], []\n",
    "train_bwd_losses, val_bwd_losses = [], []\n",
    "for ep in range(1, EPOCHS+1):\n",
    "    lf = train_epoch(model_fwd, fwd_loader, opt_fwd)\n",
    "    vf = eval_loss(model_fwd, fwd_test)\n",
    "    lb = train_epoch(model_bwd, bwd_loader, opt_bwd)\n",
    "    vb = eval_loss(model_bwd, bwd_test)\n",
    "    train_fwd_losses.append(lf); val_fwd_losses.append(vf)\n",
    "    train_bwd_losses.append(lb); val_bwd_losses.append(vb)\n",
    "    print(f\"Epoch {ep:02d} | Fwd {lf:.4e}/{vf:.4e} | Bwd {lb:.4e}/{vb:.4e}\")\n",
    "\n",
    "# Plot losses\n",
    "epochs = list(range(1, EPOCHS+1))\n",
    "plt.figure(figsize=(8,4))\n",
    "plt.plot(epochs, train_fwd_losses,  '-o', label='Fwd Train')\n",
    "plt.plot(epochs, val_fwd_losses,    '-o', label='Fwd Val')\n",
    "plt.plot(epochs, train_bwd_losses,  '-o', label='Bwd Train')\n",
    "plt.plot(epochs, val_bwd_losses,    '-o', label='Bwd Val')\n",
    "plt.xlabel('Epoch'); plt.ylabel('Loss')\n",
    "plt.legend(); plt.grid(True); plt.show()\n",
    "\n",
    "# -----------------------\n",
    "# Phase 6: Final test\n",
    "# -----------------------\n",
    "print(\"Test-losses:\", eval_loss(model_fwd, fwd_test),\n",
    "      eval_loss(model_bwd, bwd_test))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "df8136b8",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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KdnZ2ZSVlbFr1y7mz59PUlJStfMEBATw4osvcvjwYYqKivjoo49qpGlvesRUBLcHC1q5JCIiIh2b6XRS+PU35H78CYVff4PZzItAHb/6alRUFOPHj+eHH35o1nyreuaZZwgPD6eoqKjGvpKSEiIiInj22WdbrDy+pF7SbVRydAigVcpERESaU96yZfw8+gJ2X3cd+++4g93XXcfOC8ZQvDKtWfOtuvrqp59+ip+fH5MmTWrWPKu69tprKS4u5r333qux77333qOoqIhrrrmmxcrjSwpu2yhPtwT1uRUREWkWecuWse/WmZRnZVXbXp6dzdF77yW/ymB1X6tcfTU+Pp6BAwdy9913s2fPHg4ePAjApZdeyowZMzzpZ86ciWEYbN682V3G8nJCQ0NZunQpAIWFhVx77bWEhISQkJDAM888U2/+MTExTJ48mVdffbXGvldffZUpU6YQExPD3XffTa9evQgKCqJHjx48+OCDbX4hEAW3bdQpFd0S9uYUUVrevF+PiIiIdASmaeIqKvLq4czP58Ajf4Ha1rKq2Jb96GM48/MbPNeJrodVUFDAW2+9Rc+ePYmKigLc/WXT0tI8adLT04mOjiY9PR2AtWvXUlJSwrBhwwC48847WblyJYsWLWLZsmWkpaWxbt26evOdPn066enpZGRkeLb98ssvrFy5kunTpwMQGhrK/Pnz2bJlCy+88AKvvPIKzz333Aldb3NrE/PcSk0xoXaC/a0UljnZc6SInrGhDR8kIiLSiZnFxWw7c5DPzld+4ADbzz6nwXS9v1uH0cgVTj/++GNCQtxdEAsLC0lISODjjz/2zBebmprKrbfeyqFDh7BarWzevJmHHnqItLQ0brrpJtLS0hg0aBAhISEUFBQwb9483njjDcaMGQPA66+/3uDaAePGjSMxMZH58+d7Vm597bXXSExMZOzYsQA88MADnvQnn3wyt99+O//+97+56667GnW9LUktt22UYRj0iHHf9DvUNUFERKRDGTVqFBs2bGDDhg18/fXXjB07lgkTJrBr1y7AvSprVFQU6enpfPHFFwwYMIApU6Z4Wm7T0tIYOXIkADt27KCsrIwhQ46tahoZGUnv3r3rLYPVauW6665j/vz5uFwuTNPk9ddfZ9q0aZ4Zp959912GDx9OfHw8ISEhPPjgg+zevbs5qsRn1HLbhiVHB7NxX64G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4XTv3p1u3boRERHBn//8Z1wul9fnKSwsZMCAAbz00kt1phk/fjyZmZmex+LFi6vtnzlzJosWLWLhwoWsWrWKgoICJk2ahNPpbMqlNZ8tH8J/roW8/dW352W6t59ggNsjpmLGBAW3IiIi0ok1qVvC/fffz7x583j88ccZNmwYpmny5ZdfMnv2bEpKSvjLX/7i1XkmTJjAhAkT6k1jt9uJj4+vdV9ubi7z5s3jzTff5IILLgBgwYIFJCUlsWLFCsaNG9e4C2suLicsuRuobSYDEzBgyT3Q58Imd1FIjnbPdbvzoBZyEBERkc6rScHt66+/zj//+U+mTJni2TZgwABOOukkbrrpJq+DW2+kpaURGxtLREQEI0eO5C9/+YtnFbR169bhcDg8szUAJCYmkpKSwurVq+sMbktLSyktLfW8zsvLA8DhcOBwOHxW9krGrlX4Hd9iW40Jefso3/k5ZvfhTcojKcIfgH1HiykoKsFuO/F+vFVV1ktz1E9HonryjurJO6on76ievKN68p7qyjstXU/e5tOk4PbIkSO19q3t06cPR44cacopazVhwgR+/etf0717dzIyMnjwwQc5//zzWbduHXa7naysLPz9/T3LAFeKi4sjKyurzvM+9thjzJkzp8b2ZcuWERQU5LPyVzrpyFec5UW6DV8sZd/mvCblYZoQaLVS7DR4879LSfT9ZQCwfPny5jlxB6N68o7qyTuqJ++onryjevKe6so7LVVPRUVFXqVrUnBb2U/2+NXIXnrpJU4//fSmnLJWl19+ued5SkoKZ511Ft27d+eTTz5h6tSpdR5nmiaGYdS5/95772XWrFme13l5eSQlJTF27NhmmafX2BUGuxpelnjgeeMY0MSWW4BX96zhh315JJ02iHH94pp8nto4HA6WL1/OmDFjsNlsPj13R6J68o7qyTuqJ++onryjevKe6so7LV1Pld+0N6RJwe2TTz7JhRdeyIoVKxgyZAiGYbB69Wr27NlTY8CXLyUkJNC9e3d++uknwD1jQ1lZGTk5OdVab7Ozsxk6dGid57Hb7djt9hrbbTZb8/xyeoyAsET34LFa+90aEJaIX48RJzQt2CmxofywL49dOSXNdpM1Wx11MKon76ievKN68o7qyTuqJ++prrzTUvXkbR5Nmi1h5MiRbN++nUsuuYSjR49y5MgRpk6dyubNm3nttdea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1ZP3VFfeacl6qq/FtpIGlImIiIhIh6HgVkREREQ6DAW34hW73c5DDz2E3W5v7aK0aaon76ievKN68o7qyTuqJ++prrzTVutJA8pEREREpMNQy62IiIiIdBgKbkVERESkw1BwKyIiIiIdhoJbEREREekwFNwKjz32GGeffTahoaHExsZy8cUXs23btnqPSUtLwzCMGo8ff/yxhUrd8mbPnl3jeuPj4+s9Jj09nUGDBhEQEECPHj34+9//3kKlbT0nn3xyrffGzTffXGv6znIvff7550yePJnExEQMw+CDDz6ott80TWbPnk1iYiKBgYGkpqayefPmBs/73nvv0bdvX+x2O3379mXRokXNdAUto756cjgc3H333fTv35/g4GASExO59tpr2b9/f73nnD9/fq33WElJSTNfTfNp6H6aNm1ajesdPHhwg+ftaPcTNFxXtd0bhmHw1FNP1XnOjnZPeRMHtKf3KAW3Qnp6OjfffDNr1qxh+fLllJeXM3bsWAoLCxs8dtu2bWRmZnoep556aguUuPX069ev2vVu3LixzrQZGRlMnDiR8847j/Xr13Pffffxxz/+kffee68FS9zy1q5dW62Oli9fDsCvf/3reo/r6PdSYWEhAwYM4KWXXqp1/5NPPsmzzz7LSy+9xNq1a4mPj2fMmDHk5+fXec6vvvqKyy+/nGuuuYbvv/+ea665hssuu4yvv/66uS6j2dVXT0VFRXz33Xc8+OCDfPfdd7z//vts376dKVOmNHjesLCwavdXZmYmAQEBzXEJLaKh+wlg/Pjx1a538eLF9Z6zI95P0HBdHX9fvPrqqxiGwaWXXlrveTvSPeVNHNCu3qNMkeNkZ2ebgJmenl5nmpUrV5qAmZOT03IFa2UPPfSQOWDAAK/T33XXXWafPn2qbbvxxhvNwYMH+7hkbdutt95qnnLKKabL5ap1f2e8lwBz0aJFntcul8uMj483H3/8cc+2kpISMzw83Pz73/9e53kuu+wyc/z48dW2jRs3zrziiit8XubWcHw91eabb74xAXPXrl11pnnttdfM8PBw3xauDamtnq677jrzoosuatR5Ovr9ZJre3VMXXXSRef7559ebpqPfU8fHAe3tPUott1JDbm4uAJGRkQ2mPeOMM0hISGD06NGsXLmyuYvW6n766ScSExNJTk7miiuuYOfOnXWm/eqrrxg7dmy1bePGjePbb7/F4XA0d1HbhLKyMhYsWMANN9yAYRj1pu1s91JVGRkZZGVlVbtf7HY7I0eOZPXq1XUeV9c9Vt8xHU1ubi6GYRAREVFvuoKCArp3707Xrl2ZNGkS69evb5kCtqK0tDRiY2Pp1asXv/3tb8nOzq43ve4nOHDgAJ988gnTp09vMG1HvqeOjwPa23uUglupxjRNZs2axfDhw0lJSakzXUJCAi+//DLvvfce77//Pr1792b06NF8/vnnLVjalnXuuefyxhtvsHTpUl555RWysrIYOnQohw8frjV9VlYWcXFx1bbFxcVRXl7OoUOHWqLIre6DDz7g6NGjTJs2rc40nfFeOl5WVhZArfdL5b66jmvsMR1JSUkJ99xzD1dddRVhYWF1puvTpw/z58/nww8/5F//+hcBAQEMGzaMn376qQVL27ImTJjAW2+9xWeffcYzzzzD2rVrOf/88yktLa3zmM5+PwG8/vrrhIaGMnXq1HrTdeR7qrY4oL29R/k169ml3bnlllv44YcfWLVqVb3pevfuTe/evT2vhwwZwp49e3j66acZMWJEcxezVUyYMMHzvH///gwZMoRTTjmF119/nVmzZtV6zPGtlWbFgoANtWJ2FPPmzWPChAkkJibWmaYz3kt1qe1+aeheacoxHYHD4eCKK67A5XLxt7/9rd60gwcPrjaYatiwYZx55pm8+OKL/PWvf23uoraKyy+/3PM8JSWFs846i+7du/PJJ5/UG7h11vup0quvvspvfvObBvvOduR7qr44oL28R6nlVjxmzJjBhx9+yMqVK+natWujjx88eHCH+NTqreDgYPr371/nNcfHx9f4dJqdnY2fnx9RUVEtUcRWtWvXLlasWMH/+3//r9HHdrZ7qXLWjdrul+NbPY4/rrHHdAQOh4PLLruMjIwMli9fXm+rbW0sFgtnn312p7rHEhIS6N69e73X3Fnvp0pffPEF27Zta9J7Vke5p+qKA9rbe5SCW8E0TW655Rbef/99PvvsM5KTk5t0nvXr15OQkODj0rVdpaWlbN26tc5rHjJkiGemgErLli3jrLPOwmaztUQRW9Vrr71GbGwsF154YaOP7Wz3UnJyMvHx8dXul7KyMtLT0xk6dGidx9V1j9V3THtXGdj+9NNPrFixokkfFE3TZMOGDZ3qHjt8+DB79uyp95o74/1U1bx5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",
      "text/plain": [
       "<Figure size 800x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Test-losses: 5.630697858810425 0.13975106525421144\n"
     ]
    }
   ],
   "source": [
    "# Plot losses\n",
    "epochs = list(range(1, EPOCHS+1))\n",
    "plt.figure(figsize=(8,4))\n",
    "plt.plot(epochs, train_fwd_losses,  '-o', label='Fwd Train')\n",
    "plt.plot(epochs, val_fwd_losses,    '-o', label='Fwd Val')\n",
    "plt.plot(epochs, train_bwd_losses,  '-o', label='Bwd Train')\n",
    "plt.plot(epochs, val_bwd_losses,    '-o', label='Bwd Val')\n",
    "plt.xlabel('Epoch'); plt.ylabel('Loss')\n",
    "plt.legend(); plt.grid(True)\n",
    "plt.savefig(\"out\",format=\"pdf\")\n",
    "plt.show()\n",
    "\n",
    "# -----------------------\n",
    "# Phase 6: Final test\n",
    "# -----------------------\n",
    "print(\"Test-losses:\", eval_loss(model_fwd, fwd_test),\n",
    "      eval_loss(model_bwd, bwd_test))"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "aipy12dit",
   "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.12.3"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
