{
  "cells": [
    {
      "cell_type": "markdown",
      "source": [
        "**TopoFormer: An Efficient Link-Set Prediction Architecture for Spatial Topology Generation**"
      ],
      "metadata": {
        "id": "CuAJZePlOMWZ"
      },
      "id": "CuAJZePlOMWZ"
    },
    {
      "cell_type": "markdown",
      "source": [
        "Simple notebook to try TopoFormer. The dataset generated in this notebook is different from the one used in the paper. It is less constrained and hence more arbitrary, yet it allows to train a TopoFormer instance directly in this notebook, to tune it, and to compare it with a simple Transformer (with DDEs). This notebook should be run in the same directory as topoformer_synthetic.py\n"
      ],
      "metadata": {
        "id": "fU7-T3qEOKi2"
      },
      "id": "fU7-T3qEOKi2"
    },
    {
      "cell_type": "code",
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "BpYrY81U72zP",
        "outputId": "a3c5e668-a238-4028-dfd8-e17a1ff9b1cc"
      },
      "source": [
        "\n",
        "# === Dataset generation ===\n",
        "import math, torch\n",
        "from pathlib import Path\n",
        "from topoformer_synthetic import TopologyConfig, RadioConfig, sample_positions, build_graph, dde_features\n",
        "\n",
        "OUT = Path(\"./synth_100.pt\")\n",
        "OUT.parent.mkdir(parents=True, exist_ok=True)\n",
        "N_SAMPLES = 100\n",
        "N_NODES   = 16\n",
        "LAYOUT    = \"clusters\"\n",
        "TX_RADIUS = 0.35\n",
        "BEAM_DEG  = 360.0\n",
        "N_BEAMS   = 1\n",
        "MAX_DEG   = 4\n",
        "SYMMETRIC = True\n",
        "R_BINS    = 4\n",
        "A_BINS    = 8\n",
        "SEED      = 123\n",
        "\n",
        "topo = TopologyConfig(n_nodes=N_NODES, layout=LAYOUT)\n",
        "radio = RadioConfig(tx_radius=TX_RADIUS, beam_width_deg=BEAM_DEG,\n",
        "                    n_beams=N_BEAMS, max_degree=MAX_DEG, symmetric=SYMMETRIC)\n",
        "r_edges = torch.linspace(0.0, 1.0, steps=R_BINS+1)\n",
        "a_edges = torch.linspace(-math.pi, math.pi, steps=A_BINS+1)\n",
        "\n",
        "pos_list, A_list, H_list = [], [], []\n",
        "for i in range(N_SAMPLES):\n",
        "    pos = sample_positions(topo, seed=SEED+i)\n",
        "    A   = build_graph(pos, radio, seed=SEED+i)\n",
        "    H   = dde_features(pos, r_edges, a_edges)\n",
        "    pos_list.append(pos)\n",
        "    A_list.append(A.to(torch.uint8))\n",
        "    H_list.append(H)\n",
        "\n",
        "pos = torch.stack(pos_list, dim=0)\n",
        "A   = torch.stack(A_list, dim=0)\n",
        "H   = torch.stack(H_list, dim=0)\n",
        "\n",
        "torch.save({\n",
        "    \"pos\": pos, \"A\": A, \"dde\": H,\n",
        "    \"r_edges\": r_edges, \"a_edges\": a_edges,\n",
        "    \"config\": {\n",
        "        \"nodes\": N_NODES, \"layout\": LAYOUT, \"tx_radius\": TX_RADIUS,\n",
        "        \"beam_deg\": BEAM_DEG, \"n_beams\": N_BEAMS, \"max_deg\": MAX_DEG,\n",
        "        \"symmetric\": SYMMETRIC\n",
        "    }\n",
        "}, str(OUT))\n",
        "print(f\"Saved {OUT} | pos{tuple(pos.shape)} A{tuple(A.shape)} dde{tuple(H.shape)}\")\n"
      ],
      "id": "BpYrY81U72zP",
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Saved synth_100.pt | pos(100, 16, 2) A(100, 16, 16) dde(100, 16, 4, 8)\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 1000
        },
        "id": "HlWc3_zF72zQ",
        "outputId": "93d5e329-6173-4118-c9ea-8f08ff4daa5b"
      },
      "source": [
        "\n",
        "# === Quick viz ===\n",
        "import torch, numpy as np, matplotlib.pyplot as plt\n",
        "from matplotlib.collections import LineCollection\n",
        "blob = torch.load(\"./synth_100.pt\", map_location=\"cpu\")\n",
        "pos, A = blob[\"pos\"], blob[\"A\"].bool()\n",
        "\n",
        "def plot_graph(pos, A, ax=None, title=None):\n",
        "    if ax is None:\n",
        "        fig, ax = plt.subplots(figsize=(3.6,3.6))\n",
        "    N = pos.shape[0]\n",
        "    iu = torch.triu_indices(N, N, 1)\n",
        "    ii, jj = iu[0], iu[1]\n",
        "    mask = (A[ii, jj] | A[jj, ii])\n",
        "    ii, jj = ii[mask], jj[mask]\n",
        "    P = pos.cpu().numpy()\n",
        "    segs = np.stack([P[ii.cpu().numpy()], P[jj.cpu().numpy()]], axis=1)\n",
        "    if len(segs) > 0:\n",
        "        ax.add_collection(LineCollection(segs, linewidths=1.5, alpha=0.6, colors=\"0.3\"))\n",
        "    ax.scatter(P[:,0], P[:,1], s=40, zorder=3)\n",
        "    ax.set_xlim(0,1); ax.set_ylim(0,1); ax.set_xticks([]); ax.set_yticks([])\n",
        "    if title: ax.set_title(title)\n",
        "    return ax\n",
        "\n",
        "k = min(9, pos.shape[0]); cols=3; rows=(k+cols-1)//cols\n",
        "fig, axes = plt.subplots(rows, cols, figsize=(4*cols, 4*rows)); axes = axes.flatten()\n",
        "for i in range(k):\n",
        "    plot_graph(pos[i], A[i], ax=axes[i], title=f\"Sample {i}\")\n",
        "for j in range(i+1, rows*cols):\n",
        "    axes[j].axis('off')\n",
        "plt.tight_layout(); plt.show()\n"
      ],
      "id": "HlWc3_zF72zQ",
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 1200x1200 with 9 Axes>"
            ],
            "image/png": "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6GDe2DTb32WIiIiIiIiIiMgQjZuZUiIiIiIiIiIiMnEolBIRERERERERkVGnUEpEREREREREREadQikRERERERERERl1CqVERERERERERGTUKZQSEREREREREZFRp1BKRERERERERERG3YBDqajnfo+fnCzCWdM8kvWIiIiIiIiIiMgkMOBQKmzxC/zPE4Ws//ER/njPJTrcnpGsS0REREREREREJrCAgR5oWG14zK7f7851AvD2zowRKUpERERERERERCa2Ic2UMk3YnePUUj4RERERERERERmSIQ86txgG2fklw1mLiIiIiIiIiIhMEkMOpQwDqlxtw1mLiIiIiIiIiIhMEkMOpTymSWyofThrERERERERERGRSeIJQinIWpI4nLWIiIiIiIiIiMgkMeDd97ozyQhx4aoohOj5OGuayc4vocrVRmyonawliTiig4e30oeM9vVERERERERERGR4DTiUMt0dWANsmCasTwpgGdUc/OIwf3mygoN3mrAYBobRtTPfOwdvsivTwVtZ6disQ27GekyH28Ob2VfYneMcleuJiIiIiIiIiMjIGHAo1XjhM/7kD37It1bMIilqCqdOneLHR4q51OQCDNymCebXx+/OdQLw9s6MYSv2zewr7M51YsKoXE9EREREREREREbGgNuKag/9I7+7JhlHdDCGYeCYv4RLTWGA0ePxpgm7c5w4a5qHpdCi6mZ25zgxzZ4fH+7riYiIiIiIiIjIyBnyWrd9F0qxGj0HUr6TGwbZ+SVDvUQ3ey+UYBnF64mIiIiIiIiIyMgZcihV5Wqjn4wIMLlRVEZDQ8NQLzOo6xlG13EiIiIiIiIiIjK2DXH3PYgNtfe6lM7LY5rUlRXxs59dJiIigqSkJBwOB0lJSdjt9kFfz9PPBT2mSWzo4M4rIiIiIiIiIiKjb8ih1I7Fibxz8Gafx5gYbJgZTEdtA/X19dTX13P16lUMw2Dq1KkkJSWRnJzMtGnTsFqtfZ5rmtX1VSjVe7uUaULWksShvBwRERERERERERlFQw6lkmOC2ZXp6NoNr8cGJpMtqWF8/9tbaW9vp6SkBKfTSXFxMbW1tVRUVFBRUUFeXh42m42EhAQcDgcOh4OoqCiMr9bqdbg9/Jv/7xT7b9R/dVqTntbxGQbsWu7AER081JckIiIiIiIiIiKjZMihFMBbWelA1653FsPA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J598ot/+7d+W1WrVxo0bx/R8AJhuuFfc7pVXXtHRo0f1ox/9aEzHA8B0x73idhcvXlR4eLgiIiKUkJCg//E//of6+vrG9FxgwpnAJPD++++bVqvVtFqt5tq1a80f/vCH5nvvvWf29vbedqzb7b7tc4888oiZkZFxy+fS09NNSebRo0d9n3vvvfdMSWZoaKhZVVXl+/zf//3fm5LMgwcP+j737W9/25RkPvvss77Peb1e89FHHzWDg4PNhoYG3+clmc8995zv99/97nfNxMREs7Gx8ZY17dixw4yKihryNXzRtWvXTEm+j5SUFPOll14a9XkAMF1xr7j9NaalpZn/7b/9N9M0TfPgwYOmJPOVV14Z8XkAMJ1xr7jVr/3ar5l/9Ed/ZL722mvmv/3bv5mPP/64Kcl8+umnR3we4C9USmFSePjhh3Xs2DE9/vjjOnXqlH70ox/pkUceUXJyst56661bjg0NDfX9uq2tTY2NjdqwYYMqKirU1tZ2y7HZ2dlau3at7/erV6+WJD344INKS0u77fMVFRW3re373/++79eGYej73/++ent79cEHHwz5WkzT1GuvvaatW7f6qp0GPx555BG1tbXp5MmTo/6ZxMTEaP/+/dqzZ4+ef/55xcXFUXILYEbjXnGrP/3TP1VfX5/+4A/+YMTjAGAm4V5xq3/8x3/Uc889pyeeeEK//Mu/rDfffFPf+9739PLLL6uwsHDE5wL+wKBzTBoFBQV6/fXX1dvbq1OnTumNN97Qj3/8Yz311FMqLS1Vdna2JOnIkSN67rnndOzYsdt2Gmpra1NUVJTv9zffICT5HktNTR3y8y0tLbd83mKxKCMj45bPLVy4UJJUWVk55OtoaGhQa2urfvrTn+qnP/3pkMeMZchicHCwHnroIUnSY489ps2bN+u+++7T7Nmz9dhjj436fACYjrhXyHfeP/uzP9Pf/u3fyuFwDHscAMxE3CtG9nu/93v62c9+pg8++EBr1qy54+cD44lQCpNOcHCwCgoKVFBQoIULF+o73/mOXnnlFT333HO6cuWKNm/erKysLL344otKTU1VcHCw9u7dqx//+Me39W5brdYhrzHc580xDBoczeAavvWtb+nb3/72kMfk5eXd8XnXrVunxMRE/fu//zuhFIAZb6bfK3bu3Knk5GRt3LjR98NMfX29pIEfYiorK5WWliaL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ERERERER8TiFUiIiIiIiIiIi4nEKpURERERERERExOMUSomIiIiIiIiIiMcplBIREREREREREY9TKCUiIiIiIiIiIh6nUEpERERERERERDxOoZSIiIiIiIiIiHicQikREREREREREfE4hVIiIiIiIiIiIuJxCqVERERERERERMTjFEqJzAPDMPhv/+2/LfQwRERkEdO1QkREZqNrhSw3CqVk0bhy5QrPPPMMiYmJ+Pn5ERcXx8MPP8yPfvSjhR7aghgaGuJP//RPSUtLw8/PjxUrVvD4449TW1u70EMTEVkwulaMqqysxDCMab++/e1vL/QQRUQWjK4VX3K5XPyv//W/yMnJwWazsWLFCr761a9y+vTphR6aCABeCz0AEYDTp0+ze/duEhIS+Pa3v01MTAw1NTWcPXuWv/7rv+b73//+Qg/Ro4aHh3n88cc5ffo03/72t8nKyqKjo4Nz587R1dVFfHz8Qg9RRMTjdK34UlRUFP/6r/866fEjR47w6quv8sgjjyzAqEREFp6uFRP9p//0n3jllVf4xje+wXe+8x06Ozv5+7//ex544AFOnTrFli1bFnqIsswplJJF4b//9/9OSEgIeXl5hIaGTniuubl5YQa1gP7yL/+SEydOcPLkSV0oRES+oGvFlwIDA/nGN74x6fF/+qd/Ijg4mCeffHIBRiUisvB0rfjSyMgIP/7xj3nmmWcm3Mh49tlnWbVqFa+++qo+a8iCU/meLAplZWWsW7du0oUDIDo6esLff/rTn/Lggw8SHR2Nr68vGRkZ/PjHP560X1JSEk888QSffPIJmzdvxt/fn/Xr1/PJJ58A8Oabb7J+/Xr8/PzYtGkTly5dmrD/t771LWw2G+Xl5Tz66KMEBgYSGxvLyy+/jGmas76muro6fvu3f5sVK1bg6+vLunXr+Md//MdZ93O5XPz1X/81X//619myZQsjIyP09fXNup+IyL1O14qZNTQ0cPz4cZ5++mn8/Pxu6xgiIkudrhVfGh4epr+/nxUrVkz6PlgsFvz9/Wc9hsjdplBKFoXExEQuXLjA1atXZ932xz/+MYmJifzxH/8xf/EXf4Hdbuc73/kOf/d3fzdp29LSUn7913+dJ598kh/84Ad0dHTw5JNP8uqrr/KHf/iHfOMb3+BP/uRPKCsr47nnnsPlck3Y3+l08thjj7FixQp++MMfsmnT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4he/+AUOh2OhhyIiIouUrhUiIjIbXStEpqeeUiIiIiIiIiIi4nEKpURERERERERExOMUSomIiIiIiIiIiMepp5SIiIiIiIiIiHicZkqJiIiIiIiIiIjHKZQSERERERERERGP85rLRi6Xi/r6eoKCgjAM426PSUREFohpmvT09BAbG4vFcmv3LXStEBFZHnStEBGR2cz1WjGnUKq+vh673T5vgxMRkcWtpqaG+Pj4W9pH1woRkeVF1woREZnNbNeKOYVSQUFB7oMFBwfPz8hERGTR6e7uxm63u3/v3wpdK0RElgddK0REZDZzvVbMKZQam1obHBysi4eIyDJwOyUVulaIiCwvulaIiMhsZrtWqNG5iIiIiIiIiIh4nEIpERERERERERHxOIVSIiIiIiIiIiLicQqlRERERERERETE4xRKiYiIiIiIiIiIxymUEhERERERERERj1MoJSIiIiIiIiIiHqdQSkREREREREREPE6hlIiIiIiIiIiIeJxCKRERERERERER8TiFUiIiIiIiIiIi4nEKpURERERERERExOMUSomIiIiIiIiIiMcplBIREREREREREY9TKCUiIiIiIiIiIh6nUEpERERERERERDxOoZSIiIiIiIiIiHicQikREREREREREfE4hVIiIiIiIiIiIuJxCqVERERERERERMTjFEqJiIiIiIiIiIjHKZQSERERERERERGPUyglIiIiIiIiIiIep1BKREREREREREQ8TqGUiIiIiIiIiIh4nEIpERERERERERHxOIVSIiIiIiIiIiLicQqlRERERERERETE4xRKiYiIiIiIiIiIxymUEhERERERERERj1MoJSIiIiIiIiIiHqdQSkREREREREREPE6hlIiIiIiIiIiIeJxCKRERERERERER8TiFUiIiIiIiIiIi4nEKpURERERERERExOMUSomIiIiIiIiIiMcplBIREREREREREY9TKCUiIiIiIiIiIh6nUEpERERERERERDxOoZSIiIiIiIiIiHicQikREREREREREfE4hVIiIiIiIiIiIuJxCqVERERERERERMTjFEqJiIiIiIiIiIjHKZQSERERERERERGPUyglIiIiIiIiIiIep1BKREREREREREQ8TqGUiIiIiIiIiIh4nEIpERERERERERHxOIVSIiIiIiIiIiLicQqlRERERERERETE4xRKiYiIiIiIiIiIxymUEhERERERERERj1MoJSIiIiIiIiIiHqdQSkREREREREREPE6hlIiIiIiIiIiIeJxCKRERERERERER8TiFUiIiIiIiIiIi4nEKpURERERERERExOMUSomIiIiIiIiIiMcplBIREREREREREY9TKCUiIiIiIiIiIh6nUEpERERERERERDxOoZSIiIiIiIiIiHicQikREREREREREfE4hVIiIiIiIiIiIuJxCqVERERERERERMTjFEqJiIiIiIiIiIjHKZQSERERERERERGPUyglIiIiIiIiIiIep1BKREREREREREQ8TqGUiIiIiIiIiIh4nEIpERERERERERHxOIVSIiIiIiIiIiLicQqlRERERERERETE4xRKiYiIiIiIiIiIxymUEhERERERERERj1MoJSIiIiIiIiIiHqdQSkREREREREREPE6hlIiIiIiIiIiIeJxCKRERERERERER8TiFUiIiIiIiIiIi4nEKpURERERERERExOMUSomIiIiIiIiIiMcplBIREREREREREY9TKCUiIiIiIiIiIh6nUEpERERERERERDxOoZSIiIiIiIiIiHicQikREREREREREfE4hVIiIiIiIiIiIuJxCqVERERERERERMTjFEqJiIiIiIiIiIjHKZQSERERERERERGPUyglIiIiIiIiIiIep1BKREREREREREQ8TqGUiIiIiIiIiIh4nEIpERERERERERHxOIVSIiIiIiIiIiLicV4LPQARERERERERkbulpr2Pw5fqaHUMEmnzZd+GOOzhAQs9LEGhlIjcw3Tx8bywh36ffzhZzfPbVt3R91o/OxERERG5U8NOFy8evsrBvBoshoFhgGnCK0eLOZBr5+V9mXhbVUC2kOYcSs3XBw0RkbtNF5+FE5TzGP/zsyr+7tOq2/pe62cnIiIiIvPlxcNXOXi+BhNwmiaYXz538HwNAD/Yn7UwgxPgFnpKjX3QuP+Hx/mjNwoYdrqm3bamvY8fHSvhpbev8qNjJdS0983LYEVE5uLmi8+Iy8RpmpiMXnxePHx1oYd4zzKs3ri+uN7fzvdaPzsRERERmQ/VbX0czKvBNKd+3jThYF6N8ooFNudQai4fNIadLv7ojQLu/+Fx/uqjEl49V81ffVQypyBLRGQ+6OKzeJgm/DyvhqpWB06nk5GREYaHhxkaGmJwcJD+/n76+vro7e3F4XBQWN2sn52IiIiIzIu3L9dhMYwZt7EYBocv1XloRDKV2+opNfbB4Du7UyaU8mlqnIgstNGLDzinCTbgy4vP9/ekem5gy5bJ//cfDrM9pGvio6bJ8PDwhK+LgyvAtMMMbx70sxMRERGRuWh1DI6+rZzhc4FhjG4nC+e2G50bmPzFLz7lucxgAgIC6Brx5ud5NdNuP12QJSIyH4aHhykvLyfvSjGmaQDTBxu6+HhWY5+LpoGmSSHUeIZh0OUbBd4m+tmJiIiIyJ2KtPliTjcF/wsu0yTS5uuhEclU7mj1varmDi5dKgPgTFcIBqGYM3yY0B1uEZlPpmlSX1/PjRs3KCsrY2hoCFdfCCahM+6ni49nDVr8iYyMxBg3A8owDKxWK0FBQV9+1Vqoud47bfke6GcnIiIiInPzSFo4f3F05huepgn7NsR5blAyye2HUoZBelIc2Ul2+vr6OHttAKN7xplxusMtIvOis7OTGzducOPGDXp6etyPBwcH83zGak590D7j/rr4eNbKUH+ys7MnBlBBQQQEBEwIqlLa+jhUeHzGY+lnJyIiIiKz6ezs5POP3yMr0JuCXhtTBVOGAQc221XJtcBuO5QyTfh/fW2z+wd4w1rC6Y9KmOkWt+5wi8jtGhwcpLS0lKKiIhobG92P+/j4kJKSwtq1a1m5ciWGYXC6vWC0v90Uv44M4ECuLj6eY7ArK5UHHlgz65YJEQEcyLVP/7PTGwcRERERmUVzczPvvvsu/f39PB7ji6vexdX+4NFYyjS/6F9qcGCznZf3ZS7waOW2QqmpPhjszYnjlaPFM+6nO9wicitcLhc1NTUUFRVRUVGB0+kERku/7HY7aWlpJCcn4+U18VfZ2MXlYF7NF0H56MXHBB5M8tfFx6NMInsrcLlSsFhmX/B1/M9utDGl+cUMXL1xEBEREZGZVVdXc+TIEYaHh4mMjMRms/HVoUq+HhHAr6610NY7xPqUBP7LgQd1o3ORmHMoZTqHsVi9MKf5YKA73CIyX1pbWykqKqKkpIS+vj734+Hh4aSlpZGamorNZpt2f2+rhR/sz+KFLSv5P350iJ4Rgw1pq4nqr2KljzeG6QJmD0jkTpkkOetpqeznxAkfvvKVr0wo15vK2M/uO7tT+PmZUs5cukawt8n/+bt7SYgI9NC4RURERGSpuXHjBseOHcM0TeLj49myZQtvvfUWAA9uzaah9FUa2ht41J6gXGIRmXMo1XP5CI/ct5UdcT58/+mvTfnBYiyo+nleDcZYy3PDwDTRHW4RmVFfXx/FxcUUFRXR1tbmftzf3581a9awdu3aSc2yZxMT5M06o4beoV5+Z/v9XLzYhMPhoLi4mIyMjLvxMpY90zmM1csb04Sc4H42ma1UVbUC4O3tzc6dO+f0M7SHB/AfH83g7ys/AyA60HpXxy0iIiIiS9elS5c4ffo0AKmpqezZs4cjR45gmiarV68mKCgIi8WC1WrF5XIt8GhlvDmHUh0f/T1bv7YW64APbW1tREZGTtpm7A7346u8+V/vX8D0C2J7TgZ7c+KURIosMzXtfRy+VEerY5BImy/7Nkz+PTAyMkJlZSVFRUVUV1e7l2y1Wq0kJSWxdu1aEhISsFpvL5AYGRnBMAx32VhWVhanT5/m8uXLpKen31LAJXPTc/kIf/wfv8fzW1cRYPbzy186wHRRUVGBaZp4eXmxbdu2OR3Ly8uLgIAA+vr66O7uxs/P7y6PXkRERESWEtM0OXXqFPn5+QBkZ2ezc+dOGhsbqaysxDAMtm7dSm9vr3v155GRkQUetYx3Sz2l7HY7TU1NlJeXTxlKjQm2DrM9pIvVqyN57MHUOx6kiCwdw04XLx6+ysG8GiyGgWGMtnV65WgxB3Lt/MnedbS1NHPjxg1KS0sZHPxyRc4VK1aQlpZGSkrKvAQQ40Mpp9PJunXrOH/+PB0dHVRXV5OYmHjH55CJOj76e37vjR8SHBwABPD1r3+dt99+G9M03cGUt7c3mzZtmtPxgoKC6Ovro6enh+jo6Ls7eBERERFZMpxOJ8eOHaOkpASAHTt2kJOTA8DZs2cBSEtLIywsjNbWViwWC15eXu4+tbI43FIolZSU5A6ltmzZMu12Yz1g/P3972x0IrLkvHj46mhvOcBpmjCux9zBvBpKSkvZbWtwP2az2Vi7di1r164lLCxsXscyFkoZhoHT6cTHx4eMjAwuX77M5cuXFUp5QGhoKPv37+fw4cO4XK4JwVRWVtas+wcFBdHU1ERPT48HRisiIiIiS8HQ0BDvv/8+tbW1GIbBgw8+SFpaGjDa7Ly+vh6r1erOLQYGBjRTapG6pU6/CQkJGIZBW1sb3d3d0243FkoFBqoprchyUt3Wx8G8qRc7gNF86nyHD734kZaWxt69e/nmN7/Jtm3b5j2QAhgeHnbPlBqrHc/KysIwDGpra2lpaZn3c8pkNpuNp59+mjVr1hAWFkZFRQUffvghhYWFs+4bFBQEoFBKRERERIDRvOHw4cPU1tbi7e3NE0884Q6kTNPkzJkzAGRmZroXRxofSmmm1OJyS6GUn58fcXFxAJSVlU273VgoFRCgPlIiy8nbl+uwzNKnyWIY+KzZxZ49e4iPj7+rfZ1unikFoyFHSkoKAJcvX75r55aJAgJGS/nWrVtHaGgolZWVvPfee+7p1tMJDg4GFEqJiIiICHR1dfHmm2/S0tKCn58fe/fuJSEhwf18aWkpra2t+Pj4TGgX0d/f7y7f00ypxeWW10RPTk4GoLy8fNptVL4nsjy1OgaZNWMyTfIKrnP27Fnq6+vv6p2K8T2lxl98xmrNS0pKcDgcd+38MpGfnx/79u0jJyeHkJAQKisreeutt6ioqJh2n7GZUjPNzhURERGRe19zczNvvPEGXV1dBAcHs3//flasWOF+3ul0cu7cOWD0/f74PEIzpRavWw6lVq1aBUBTU5M7fLqZyvdElqdIm++0pXtjTIBBBxcuXOCtt97if//v/82vfvUrCgoK6OjocK/ANx9GRkawWCwTyvcAoqOjiY2NxTRNCgoK5u18MjsfHx+eeuoptmzZQnBwMFVVVbz++uvU1NRMub3K90RERESkpqaGw4cP09/fT2RkJPv37yc0NHTCNkVFRXR1deHn50d2dvaE5/r7+9VTapG65VDKZrMRHR2NaZpTzpYyTVPleyLL1N6cOFyzhEomsM7WR3x8PP7+/gwPD1NZWclnn33Gz372M/7lX/6Fjz/+mJKSEgYGBu5oPDevvjfe2Gypa9euMTQ0dEfnkVszVvu/Y8cOgoKCqKqq4tVXX6W+vn7StmOh1NDQ0ISVGkVERERkeSguLubdd99leHiY+Ph4vv71r0/KGkZGRsjLywNg8+bN+Pj4THh+YGBgwup783kjXO7MLYdS8OVsqalKLgYGBtw/YJXviSwvCREBHMi1M10FnwHkBPURYh2moaGBjRs38uyzz7J9+3bi4+OxWq04HA6uX7/Ohx9+yD/+4z/y2muvcfbsWerq6m55qu1UPaXGJCUlERoaytDQENevX7+9Fyy3zWq18tWvfpXdu3cTGBhIdXU1//qv/0pTU9OE7by9vfHz8wM0W0pERERkubl8+TJHjx7F5XKRkpLCE088MSlwArhy5Qq9vb3YbDbWrVs36fmxUMpqtQKohG8R8bqdnVatWsXZs2epra1lcHAQX19f93Njs6T8/PzcP3ARWT7+y8PJFF6/Tr4jEIthYDEMXKaJacKBXDv/+aEkPv3kOLW1tZw6dYq4uDgefPBBNm7cyPDwaFhVU1NDTU0NbW1ttLS00NLSwoULF/D29iY2Nha73U5CQgKhoaHTNkqvae/jtWvdXB1OwMccJMMxcZquYRjk5OTwySefkJ+fz/r167FYbiunl9tktVp5+OGHsVqtHDlyhKqqKn7605/yu7/7u0RGRrq3CwoKYmBggJ6engmPi4iIiMi9yTRNTp8+7V6YKDs7m507d0753n9wcJCLFy8CkJubi5fXxJjDNM0J5XswGkrdvJ0sjNv6KYSFhREWFkZHRwdVVVWsWbPG/ZxK90SWt6LCazwS1srjq7wZXLGeVscgUUG+7M2Jwx4++nvhqaee4tq1a5w6dYq6ujoOHTrEzp07SU9PJyEhwb2ChsPhoLa21h1S9ff3U1VVRVVVFTBaTmy327Hb7V+WAzpdvHj4KgfzakabrpuRmBjkn3Vy1VnAy/sy8baOhk9r167l3Llz9PT0UFZWRmpq6oJ8z5Yzi8XCnj178PLy4t1336W6upqf/OQn/MEf/AFhYWHA6Ap8LS0tanYuIiIisgw4nU4+/vhjiouLAdi+fTsbNmyY9mb05cuXGRgYICwsjLS0tEnPj4yM4HQ6MQwDb29v92PjJ9fIwrntaHDVqlVcuHCB8vJyhVIiAoz2/bl69SoAD2/f4F6t82aGYZCZmUl8fDzHjh2jsbGR48ePU15e7i7ngtHQKS0tjbS0NEzTpK2tjZqaGqqrq2loaHCX+l2/fh3DMIiMjORIWzjHqwYx4Yum61/Ofjp4frSZ9g/2ZwHg5eVFZmYmeXl5XL58mZSUlGkvdnL3GIbBAw88gJeXF2+++SY1NTX8+Mc/5rvf/S4hISFqdi4iIiKyTAwNDXHkyBFqamowDIMHH3xwyqBpTF9fH/n5+QBs3bp1ysqH/v5+gAmzpFS+t3jcdq3KWF+p6urqCd3rFUqJLF/Xr19ncHCQ0NBQkpKSZt0+NDSUr3/96+zYsQOr1UpVVRUHDx6kpKRk0rZjodOGDRvYu3cvv/u7v8uTTz7Jhg0biIiIwDRNSho6+LhqgOnaFpomHMyroab9y5VDMzMzsVqtNDc309DQcJuvXO6UYRjs2rWLZ599Fl9fX2pra/m7v/s7enp66DX8OdMVwv99sYsfHSuZ8PMTERERkXtDX18fhw8fpqamBi8vLx5//PEZAymAixcvMjw8TFRUlDujuNnY4kn+/v4TZkrJ4nDboVRUVBQ2m43h4eEJS3krlBJZnlwul7vmOycnZ84zjiwWCxs2bODZZ58lKiqKgYEBPvzwQz744IMZV9/z8vIiISGBHTt2cODAAb71rW8xGJOFZdo261+czzA4fKnO/feAgADWrl0L4B6/LJzt27fza7/2a/j4+FBdW8ezf/Ymv/fLBk51h/JZg8lffVTC/T88zh+9UcCw07XQwxURERGRedDV1cWbb75JS0sLfn5+7Nu3j8TExBn36e7udldpbN++fdrPH2OfKcb3vdZMqcXjtkMpwzDcpTnl5eXuxxVKiSxPZWVlOBwO/P393SHPrYiIiGD//v3k5uZiGAalpaX8/Oc/p7Kyck77BwYGYvgFYbHMHEoZBrQ6Bic8lpOTA0BlZSWdnZ23PHaZX1u2bOE3f/M3uR6wnqLhCABMDJymgdM0MRktxXzx8NWFHaiIiIiI3LGWlhbeeOMNurq6CAoK4umnn2bFihWz7peXl4fT6SQ+Pp74+Phptxsr3/Pz83M3N9dMqcXjjpaaGpseV1lZics1esdaoZTI8mOaJpcuXQJg/fr1t72ShdVqZcuWLezfv5+wsDD6+vr41a9+xccff8zQ0NCs+0fafL/oIzU9l2kSaZvY1DAsLIykpCRM03TXpMvCikpKp8rLPpoiTmGqUkwRERERWVpqamp466236O/vJzIy0v05YDbt7e3cuHEDGO0lNVOVxvjyPc2UWnzuKJSKjY3Fz8+PgYEBdy8WhVIiy09dXR0tLS1YrVYyMzPv+HgrVqzgueeeIzs7G8MwuH79OgcPHqS2tnbG/fbmxOGaJZVymbBvQ9ykx8dmS12/ft19N0UWztuX67DOUgJ6cymmiIiIiCwdJSUlvPvuuwwPDxMfH8/Xv/5194JHszl37hymaZKcnExMTMyM246fKTUWSmmm1OJxR6GUxWJxNzMeK+FTKCWy/IzNkkpPT8ff339ejunl5cWuXbvYt28fwcHB9PT08Pbbb3Py5EmGh4en3CchIoADufbpJtcAJjlBvfi7Js+uiY2NJSoqCqfT6a5Nl4XT6hic4ec4aqpSTBERERFZ/C5fvsyHH36Iy+UiJSWFJ554Ah8fnznt29TURHl5OYZhsHXr1lm3Hz9TaqyiQzOlFo87CqXgyxK+8vJyRkZG3D/wuSacIrK0tbW1UV1djWEY7tlG8yk2Npbnn3+ejIwMAPLz83nttddobGyccvuX92VyYLMdA7AaYMEFpgsw2Rbt4sGQFt59910cDseE/caP/8qVK7p7ssButxRTRERERBYv0zQ5ffo0p06dAiA7O5tHHnnEPYNpLs6ePQvA2rVriYiImHX7qRqd673+4nHHoZTdbsfb2xuHw+Fehc9iseDrqw8KIsvB2Ip1q1atIiQk5K6cw8fHh927d/PEE08QEBBAZ2cnb775JmfPnp10l8PbauEH+7P49D/v5t/vSWW9fxdrBkv4g7gG/vm7jxIZHkZvby/vvvvupD5Vq1evxmaz0d/fT3Fx8V15LTI3cy3F/FpmtIdGJCIiIiJ3wul08tFHH7mrLLZv387OnTvnvGo3jPagqq2txWKxkJubO6d9pmp0rplSi8cdh1Jjy7ID7g9xAQEBt/QPS0SWJofD4f7//m7MkrpZYmIiv/Zrv0ZqaiqmaXLhwgVef/11WltbJ21rDw/g3z20hidi+0kZKsV3xIGvr6872Gpra+P999+fcEGyWq1kZWUBo2GbOdtUHblr5lKKmRXYw9mP3p3y5y8iIiIii8fw8DDvvfcexcXFGIbBnj172Lhx4y3lBqZpumdJZWZmEhwcPKf9pmp0rplSi8cdh1IwOkOic8SLf73Yykcd4ZzuDNaKSCLLQEFBAS6Xi9jY2FkbDM4XPz8/HnnkER577DH8/Pxoa2vj9ddf58KFC+5VQMcLCgoCvrwYBQcH8/jjj+Pl5UVtbS0nTpyYED5lZGTg4+NDR0cH1dXVHnlNMrWJpZgGXhYDiwEGsDczkn32QTo7O/nFL35BYWGhQkQRERGRBVbT3sePjpXw0ttX+dGxEmra++jr6+Ott96iuroaLy8vHn/8cdLS0m752OXl5TQ3N+Pt7c2mTZvmvN/48j3NlFp8bm/d9nGGnS7+78u9vNYQh8HohwUcBh/+8DgHcu28vC8Tb+u8ZF8isogMDQ1x7do1wDOzpG62evVqVq5cySeffEJFRQVnz56lsrKSBx98cMIysmN3UIaGhjBNE8MwiI6O5pFHHuH999/n+vXrBAcHs3nzZgB8fX1JT08nPz+fy5cvk5iY6PHXJqPGSjG/szuFw5fqaHUMEhXky96cOOzhAfT3Z3Ps2DGqqqo4fvw49fX1PPDAA3h7ey/00EVERESWlWGnixcPX+VgXg0Ww8AwwDThlaPFbAob5P7AFgL9/XjiiSdYsWLFLR/f5XJx7tw5ALKysua8sJppmlp9b5G747ToxcNXef1SPWBgYuDCYLSlMBw8X8OLh7WKlci9qLCwkKGhIcLCwtyrcHpaQEAAX/3qV9mzZw8+Pj40NjZy6NAhCgoK3LNmBr1tlPqkcGogjr/54m4NQHJyMvfffz8wuqTsjRs33MfNzs7GMAxqa2tpaWnx/AuTCezhAXx/Typ/sjeT7z2Yij189E2Iv78/jz/+ONu2bcMwDG7cuMHrr79Oe3v7Ao9YREREZHl58fBVDp6vwQScpsmIy8RpmpjA+Q4fTjhiePrpp28rkAK4ceMGHR0d+Pn5sWHDhjnvN3ZjGrT63mJ1R6FUdVsfB/Nqpl0hyTThYF6NSvlE7jFOp5P8/HxgdJbUQvaQMwyDtLQ0Dhw4QHx8PE6nk88++4y3Dv+S//fBC/zhsR5KfFMpca3gb46VcP8Pj/NHbxQw7HSRmZnpvqh9/PHH1NbWAqMlfykpKcCXjdxlcTIMg02bNrFv3z4CAgLo6Ojg9ddfp6ioaKGHJiIiIrIszJYLgMHFTj8c5u0thuZ0Ovn8888B2Lhx4y0tqjY2S8rHxwer1aqZUovQHYVSb1+uwzLLh1GLYXD4Ut2dnEZEFomxGvE//LczHK2zMuhlY82aNQs9LGA0SHrqqae47777sFqt/NPVft643ACAaVgwDQtOc/Iszu3bt5OSkoLL5eL999+nra0N+LIksaSkBIfDsRAvSW5BbGwszz//PPHx8YyMjHDs2DE+/vhjveEQERERucvudi5w9epVHA4HgYGBrF+//pb2Hd9PCtBMqUXojkKpVsfgDCsjjTKM0e1EZOkadrr4ozcKuP+Hx/mrj0p493onp7pD+ZuKSP5/bxcy7JzcYHwhGIZBVlYWux7bR0GvjS+63E0yfhbn2OofMTExDA0N8e6779Lb20t0dDSxsbGYpklBQYFnX4jcloCAAJ588km2bNmCYRhcv36dX/ziF3R0dCz00ERERETuWXczFxgaGuLChQsA5ObmukOluRrfTwq+DKV043LxuKNQKtLmO8MUvVEu0yTSdnvT9ERkcbi5Rtz1RQ85WJy9446X9WC9hbs1Y6uAhISE4HA4+NWvfsXw8LB7ttS1a9cYGhq628OWeWCxWMjNzeWpp57C39/fvTpjSUnJQg9NRERE5J40l1zA6XLRWltBVVXVLa2YnJ+fT39/PyEhIbe1Yt/YTCl/f38Ad/meZkotHncUSu3NicM1yz8o04R9G+Lu5DQisoCWYu+40bs1M4dSN9+t8fPz48knn8Tf35+WlhY++OADEhISCA0NZWhoiOvXr9/tYcs8io+P5/nnnyc2Npbh4WE+/PBDTpw4obtiIiIiIvNsTrkAEDtSz7vvvsvPfvYzCgoKZr3p29/f7+7vunXrVnegdCtuLt9TT6nF545CqYSIAA7k2qedqmcYcCDX7l4pSUSWnqXYO26ud2tGHB0TLkghISF87Wtfw2q1UlVVxcmTJ8nOzgZG79K4XIujTFHmJjAwkL1797Jp0yZgtB/BG2+8QVdX1wKPTEREROTeMZdcYH/OSh7YtA4fHx86Ozv57LPP+Od//mdOnjxJd3f3lPtdvHiRoaEhIiMj3YsQ3arpyvc0U2rxuKNQCuDlfZkc2GzHAKyGgZfFwGKMdnI5sNnOy/sy73yUIrJglmLvuLnerQloLeTf/u3fuHLlivvCFBMTw8MPP4xhGFy9epWBgQH8/Pzo6emhrKzMA6OX+WSxWNi2bRtPPvkkfn5+tLa28tprr+lnKSIiIjKPbs4FLJhgugCT5zbF8z+e3cCuXbt44YUXuO+++wgJCWFoaIj8/Hz+7d/+jffee4/a2lp3aZ/D4eDKlSvA6MJEt7va93Tle5optXjcWpewKXhbLfxgfxbf2Z3C4Ut1tDoGiQryZW9OnGZIidwDlmLvuLG7NQfPT112aBjwyOog4r39cDgcfPrpp1y8eJHNmzeTlpbG6tWr2blzJydPnuTcuXPExcVRV1fH5cuXSUlJue2LoiychIQEnn/+eT744AMaGxs5cuQIWVlZ7Nix47amgouIiIjIl27OBQpKKqkpvkaafw/f3ZKFt3V0PoyPjw9ZWVmsX7+e6upqCgoKqK6upqKigoqKCiIiIsjKyqK+vh6n00lsbCx2u/22x6XV9xa/Ow6lxtjDA/j+ntT5OpyILBJ7c+J45WjxjNssxt5xY7M0D+bVYDEMDGM0PDPNL2dxWthFYWEhFy5cwOFw8Mknn7jDqfXr19Pd3U1BQQG1tbUMDg7S3NxMQ0MDsbGxC/zq5HbYbDb27dvHuXPnuHTpEgUFBTQ2NvLoo48SHBy80MMTERERWfLGcoGSBPinmk8YGBigtLSUhISECdsZhkFiYiKJiYm0t7dTUFDAjRs3aGtr48iRI1RWVhIaGspjjz12RzeEtfre4jdvoZSI3JvmMuvowObF1zturrM4169fT3p6OteuXePixYt0d3fz8ccfc/HiRTZt2kRSUhKVlZX09PRgGAYfnblEV2gvrY5BIm2+7NugWaFLidVqZceOHaxcuZJjx47R3NzMa6+9xp49e0hOTl7o4YmIiIjcE6KjowkJCaGzs5OysjIeeOCBaWenh4eH85WvfIXt27dTWFjI22+/zcjICIODg3zwwQekpKSQlZVFTEzMLY9Dq+8tfgqlRGRWL+/LZGh4mDcuN4zWiVssk2YdLVZzmcXp5eVFdnY2GRkZXL16lYsXL9LZ2cmxY8cICQnBarUSYAvi7fpAqppNLEYxFsPANOGVo8UcyB39HoxNS5bFLzk5meeee44PP/yQpqYm3nvvPXJycti2bZvK+URERETuUHBwMGFhYdTW1tLV1UV9ff2sZXi+vr7Ex8cTGRmJr68vdrudrq4uSkpKKCkpITo6muzsbFavXj3n92tafW/xUyglIrPytlr49zuiCG86T4UrkrhVa+/J3nHe3t5s2LCBdevWUVBQwOXLl+nq6mJkZIQPWkOossYABi6TCY3UD56vAeAH+7MWaORyO4KDg/n617/OmTNnyM/P5/Lly+5yPpvNttDDExEREVmyDMMgOjqaoKAgdwnfXHpDnT17FsMw2Lx5Mw8//DAtLS0UFBRQUlJCc3MzR48e5dSpU6xfv56MjAwCAqb/LOJyuRgcHF2MST2lFi/d1heROeno6CDUa4T9aQH8yd5Mvvdg6j0VSI3n4+PD5s2b+c3f/E1yc3MZ9A6ijBimW4bQNEd7V9W093l4pHKnrFYru3bt4rHHHsPHx4fGxkYOHTpEVVXVQg9NREREZElbsWIFwcHB9Pf3U15ejsvlmnH7uro6qqurMQyDLVu2ABAVFcWePXv45je/yZYtWwgICKCvr49z587xL//yLxw7dozW1tYpjzcwMIBpmhiGMWmmlEKpxUOhlIjMSWdnJwBhYWELOxAP8vX1ZcuWLXiv3o5llgaLFsPg8KU6D41M5tvq1at5/vnniYqKYmBggHfffZczZ87M+uZJRERERKYWFRVFYGAgw8PDDAwMUF9fP+22pmly9uxZANatW0dISMiE5wMCAsjNzeWb3/wmDz30ENHR0TidToqKijh06BBvvfUWZWVlE967jZXu+fr6YrGMRh9qdL74qHxPROZkLJQKDQ1d0HEshM4BJxbDmFCydzPDgFbHoAdHJfMtODiYp59+mlOnTrl7izU2NvLwww+rnE9ERETkFq1YsQLDMPDx8cHlclFaWkp8fPyU21ZWVtLY2IjVamXz5s3THtNqtbJ27VrWrFlDU1MT+fn5lJWVUV9fT319PUFBQe7Svpv7SQE09gxzpiuEXpeV4Y+K+frG+Hu2+mOpUCglIrOqae/jcMkgnQPhdN3o5zej+5bVL+9Im++UKw+O5zJNIm2+nhmQ3DVeXl488MADxMbG8sknn1BfX89rr73Gww8/PKc+CCIiIiIyKjAwkICAAHdfqfLycu6//373rKUxLpfLPUsqOzubwMDAWY9tGAYxMTHExMTgcDi4evUq165do6enh9OnT/P5558TFhbG4OAgfn5+DDtdvHj4KgfzaoBQDKDgWAl/+VGJFi1aYPqui8i0hp0u/uiNAu7/4XE+aQ0g3xHE/z5bz/0/PM4fvVHAsHN5lDbtzYmbcZYUjPaV2rchzkMjkrstNTWVZ555hoiICPr7+3nnnXf4/PPPVc4nIiIiMkeGYbhL+JxOJ/39/TQ0NEzarqSkhPb2dnx9fdm4ceMtn8dms7Ft2zZeeOEFdu/eTXh4OCMjIxQXF1NaWkppaSl/+G9nOXi+BhMwMXBh4DTBZHTRohcPX73zFyy3RaGUiEzrxcNX9csbSIgI4ECufbo+5xgGHMi1L6vZY8tBWFgYzzzzDBkZGZimSV5eHu+88w59fWpoLyIiIjIX0dHRGIbhnv1UWlo64Xmn08nnn38OwIYNG/D1vf3KAy8vLzIyMjhw4AB79+4lMjISgLrOAd693j5t5YMWLVpYCqVEZErVbX0czKvRL+8vvLwvkwOb7RiA1TDwshhYDDCAA5tHp/zKvcfLy4vdu3fz0EMP4eXlRW1tLYcOHaKuTk3tRURERGYTHR0NfNlg/OZV+AoLC+nu7iYgIICsrKx5OadhGMTHx5OZmUlqaird4WnMvGSRFi1aSOopJSJTevtyHRbDwDlD2drYL+/v70n14MgWhrfVwg/2Z/Gd3SkcvlRHq2OQqCBf9ubEaYbUMrB27VqioqL44IMPaG9v5+2332bLli1s2rQJY5aVGUVERESWq7FQyul04u3tTV9fH42NjcTGxjI8PMz58+cB2Lx5M97e3vN67oGBgdEwzGrDYoBzhm4cWrRo4SiUEpEptToGR8vV9Mt7Ant4wLII4WSy8PBwnnnmGT799FOKioo4d+4cDQ0N7Nmzh4AABZMiIiIiNwsICMBms+FwOIiIiKCpqYnS0lJiY2MpKCigr6+P4OBgMjIy5u2cnZ2dVFVVkZeXR21tLT0RfrjMlTDDfCktWrRwFEqJyJS04pzIZN7e3uzZs4fY2FhOnDhBdXU1r732Go888gixsbELPTwRERGRRSc6OhqHw4HNZqOpqYmysjJyc3O5ePEiAFu2bMFqtd728Z1OJw0NDVRWVlJVVUVnZycAra2tmKZJTtgIF5pmntmuRYsWjkIpEZnS3pw4XjlaPOM2+uUty1V6ejrR0dEcOXKEzs5ODh8+zLZt29iwYYPK+URERETGiY6Opry8HNM08fHxoa+vj48//pihoSEiIiJYs2bNLR+zt7eXqqoqqqqqqKmpYXh42P2cYRjExcXR39+PxWLh1w7so+90y+gCTlPcdDeM0R6xasmxMBRKiciUxlac0y9vkalFRETw3HPPcfz4cUpKSjhz5gz19fU89NBD+Pn5LfTwRERERBaFsb5SbW1tJCcnc/XqVT7//HOio6PZunXrnG7ouVwumpubqayspLq6mpaWlgnPBwQEkJiYSGJiIna7HR8fH37yk58wNDSEv7+/e1Gin+fVYGBiMYzRFcZNLVq00BRKici0xn45H8yrwWIYGMZoyZ5+eYuM8vb25uGHHyY2NpaTJ09SVVXFoUOHePTRR4mJiVno4YmIiIgsuOjoaDpHvDhTDeEjvlQ2+RLVN0BWVgxJSUnT7jc4OEh1dbU7iBoYGHA/ZxgGUVFRJCUlkZiYSFRU1IRwy+l0MjQ0BIC/v7970aLVQ2V8UtFLeGwiaxJitGjRIqBQSkSmpRXnRGZnGAaZmZmsWLGCDz74gK6uLt5880127NhBdna2yvlERERk2Rp2uvhv797g5w1xGIClpxuXKx7Tz461PZCnXCbe1tH3SqZp0t7e7g6hGhoaMMeVbPj4+JCQkEBiYiIJCQkzLjTT398PjL5P8/HxcT9uHehke0gfz3x1DStWrLg7L1puiUIpEZmVVpwTmV1UVBTPPvssx48fp6ysjFOnTtHQ0MCDDz6Ir68WBBAREZHl58XDVzl4vgYYLZdzmoBhAeBoWR//9c0C/mBziLs/lMPhmLB/eHi4uywvJiZmzg3Rx2ZV+fv7u28QDg4O0tfXB0BYWNi8vD65cwqlRERE5omvry+PPvooV65c4dSpU5SXl9Pa2sqjjz7q7qcgIiIishxUt/VxMK+G6Rb0NoFDF2oJrj9HqNcIAFarlfj4eHcQFRwcfFvnHgulxvf5bG9vB8Bms02YPSULS6GUiIjIPDIMg6ysLGJiYjhy5Ajd3d28+eab7Ny5k8zMTJXziYiIyLLw9uU6LIaBc6pVk75gAGUj4byQE01SUhJxcXF4ed15TDFWvjc+lOro6AAgNDT0jo8v88ey0AMQERG5F0VHR/P888+TnJyM0+nk008/5cMPP3Q33RQRERG5l7U6BpntXpzFMIhPSeeBBx4gMTFxXgIpmFi+N2ZsplR4ePi8nEPmh0IpERGRu8TX15evfvWr7Ny5E8MwKC0t5bXXXqO1tXWhhyYiIiJyV0XafJlhkhQwurJ3pG3+e29OVb7X2dkJqJ/UYqNQSkRE5C4yDIOcnByefvppbDYbXV1d/OIXv+DatWsTVpQRERERuZfszYnDNct7HRO4zz7/odRU5XuaKbU4KZQSERHxgJiYGJ5//nkSExNxOp188sknfPTRRwwPDy/00ERERETmXUJEAAdy7dOW8BlAVqCD/tbaeT/3zeV7w8PD7pX91FNqcVEoJSIi4iF+fn48/vjjbN++HcMwKC4u5vXXX6etrW2hhyYiIiIy717el8mBzXYMwGoYWA0wMAGTr6WF8FBYG2VlZfM+e/zmmVKdnZ2Ypomfnx8BAQHzei65MwqlREREPMgwDDZu3Mi+ffsIDAyko6OD119/nevXry/00ERERETmlbfVwg/2Z/Hpf97Nf3golWc3rGRnSCe/F1vP/3/vOny8rHR3d9PS0jKv5715ptRY6Z76SS0+CqVEREQWQGxsLM899xx2ux2n08nHH3/MsWPHVM4nIiIi9xx7eADf35PK/3huI/vTAgmxDlNaWkpSUhIAZWVl83q+mxudd3R0AAqlFiOFUiIiIgskICCAJ598kq1bt2IYBkVFRfziF79wv3ESERERuddkZGQAcP36dVatWgUwryV8pmlOKt8be2+lJueLj0IpERGRBWQYBps3b+app54iICCA9vZ2Xn/9dW7cuLHQQxMRERGZd6tXr8bHx4eenh68vb2xWq10dXXR2to6L8cfGRnB6XQCX5bvaabU4qVQSkREZBGIj4/n+eefJy4ujuHhYT766COOHz/OyMjIQg9NREREZN54eXmxZs0aAEpKSkhMTATmr4RvbJaU1WrFy8sLp9NJZ2cnoFBqMVIoJSIiskgEBATw1FNPsXnzZgzDoLCwkF/84hfuN1IiIiIi94KxEr7y8nLsdjsApaWl81LCN77JuWEYdHV1YZom3t7e2Gy2Oz6+zC+FUiIiIouIxWJh69atPPHEE/j7+9PW1sbrr79OaWnpQg8NgJr2Pn50rISX3r7Kj46VUNPet9BDEhERkSUmKiqKyMhInE4ng4OD7hK+tra2Oz72dE3OQ0NDMQzjjo8v80uhlIiIyCKUkJDAc889R2xsLENDQ3zwwQd8+umn7h4JnjbsdPFHbxRw/w+P81cflfDquWr+6qMS7v/hcf7ojQKGna4FGZeIiIgsTWOzpUpKSibMlrpTanK+tCiUEhERWaRsNht79+5l48aNAFy5coU33niD7u5uj4/lxcNXOXi+BhNwmiYjLhOnaWICB8/X8OLhqx4fk4iIiCxda9aswWq10tbW5g6M5mMVvvHle6Am54udQikREZFFzGKxsH37dp544gn8/PxoaWnh0KFDlJeXe2wM1W19HMyrYbr3iKYJB/NqVMonIiIic+br68uqVasA6O3txWq10tnZSXt7+x0d9+aZUmPHUyi1OCmUEhERWQISExN57rnniImJYWhoiPfff5+TJ096pJzv8OU6ZmvBYDEMDl+qu+tjERERkXvHWAlfRUUFsbGxwJ2vwjd+ppRpmpoptcgplBIREVkigoKC2LdvH9nZ2QDk5+fz1ltv0dPTc1fO19/fT35+Pp/lXcZ0zdwzyjCg1TF4V8YhIiIi96a4uDiCg4MZGhrC19cXuPO+UuMbnff09OB0OrFYLISEhNzxeGX+KZQSERFZQqxWK7t27eKrX/0qPj4+NDU18dprr1FZWTkvx3e5XFRXV3PkyBF+8pOfcOjQIboaa2bfzzSJtPnOyxhERERkeTAMg/T0dAC6u7uxWCx0dHTcUQnf+PK98SvvWSyKPxYjr4UegIiIiNy6VatWERkZyZEjR2hpaeFXv/oVGzZsYOvWrVit1jkdo6a9j8OX6mh1DGLzNlnr201HbSldXV20trbS1taGr68v2WHDFPfPXL9nmrBvQ9x8vDQRERFZRtLS0vj8889pbm4mKiqKlpYWysrKbnu1vPHle62trYBK9xYzhVIiIiJLVHBwMPv37+fUqVNcuXKFS5cu0djYyCOPPILNZpsQOkXafNm3IQ57eADDTtfoanp5NRgGGJi4TDCBNVaTtN4Kgm2BJCcns3r1anbs2IHXyabR1femaHZuGHBgsx17eIDHvwciIiKytNlsNhISEqiqqsL4oollaWkpubm5t3W88eV7anK++CmUEhERWcKsViv3338/sbGxHD9+nIaGBn528BBXfNJ5t7ADi2FgGKMzmV45WszzuXZ6+/p491obJnwRMn05C6rYGYlv+BZ+Y43B9u3bSUhIwDAMXt4XBYyusjd2TJdpYpqjgdTL+zIX5PWLiIjI0peenk5VVRWdnZ0YhkF7ezsdHR23HCaZpjll+d7tzrqSu0+hlIiIyD0gJSWFyMhIPvjgA14tNinobQcMnOYXU6C+cDCv+os/TVeOZ3ClL5jtDz1AYqTN/ai31cIP9mfxnd0p7tlXUUG+7M2J0wwpERERuSNJSUn4+/vT39+PzWbD4XBQVlbG5s2bb+k4Q0NDmF9M6x4fSmmm1OKlTl8iIiL3iNDQUHJ3f5WC3iBmCp2YogRvPKth8Mv8himfs4cH8P09qfzJ3ky+92CqAikRERG5Y1arlbS0NABGRkaA21uFb2yWlI+PD0NDQwwODmIYBqGhofM2VplfCqVERETuIb+60oTVmLkp+bR51djTBrQ6BudvUCIiIiKzGFuFr7e3l5GREdra2twzneZqfD+psX2DgoLw8lKR2GKlUEpEROQe0uoYZLZMarZUymWaRNp8521MIiIiIrMJCwtj5cqVWK1Wd4hUXl5+S8cY309KTc6XBoVSIiIi95BIm++UK+TdCtOEfRvi5mdAIiIiInM0NltqrDfUrZbwjc2U8vf3V5PzJUKhlIiIyD1kb04crjmlUlNvYxhwINeuXlEiIiLicSkpKfj4+GCxWOjv76e1tZWurq457z9V+Z5mSi1uCqVERETuIQkRATy/OR5jhtApN2KYrEAHMNrU3MtiYDFGi/oObLbz8r5MD45YREREZJS3tzcpKSkTekDdymyp8eV7CqWWBnX7EhERucd8e2MIhdevU9Brw2oYGIaByzQxTfja2lDWOi7jF+LN//X4w3xQ1E6rY5CoIF/25sRphpSIiIgsqIyMDAoLCxkeHsbpdFJWVsamTZvmtO/YTCkvLy96e3sBhVKLnUIpERGRe8yNokIeDW/jW1tjqbOudIdOT2XHcvroO7T1QlZWFmviIlgTF7HQwxURERFxi46OJjw8nJGREbq6urBarXR3dxMcHDzrvmOh1PDwMAABAQH4+mrxlsVMoZSIiMg9xOFwUFlZCcDu3PUT7g6WlJTQ1taGj48POTk5CzNAERERkRkYhkFGRgbt7e24XC4AysrK2LBhw6z7jpXvDQ4OAmpyvhSop5SIiMg95Pr165imSWxs7IRAyuVykZeXB0B2djZ+fn4LNUQRERGRGa1Zswar1epueD7XvlJjM6XG/qvSvcVPM6VERETuES6Xi8LCQmC0H8N4JSUldHR04OvrS3Z29kIMT0RERGRO/P39SU5OZnBwkJaWFvz9/edUwjcWRvX19QEKpZYCzZQSERG5R9TU1OBwOPDz82P16tXux8fPktqwYYN6K4iIiMiil56ejpeXFyMjI7hcLsrKymbc3uVyucv2HI7RVYYVSi1+CqVERETuEdeuXQNg7dq1E5ZSLioqoqurCz8/P7KyshZqeCIiIiJzZrfbCQoKIjAwkO7u7llDqYGBAUzTxDRNd28p9ZRa/FS+JyIicg8Y3+B83bp17sedTifnz58HYOPGjXh7ey/E8GSRqmnv4/ClOlodg0TafNm3IQ57eMBCD0tERATDMEhPT6ejo4Pa2lqampro6ekhKChoyu3HSvfG+Pr64u/v74mhyh1QKCUiInIPmK7B+fXr1+np6SEgIIDMzMwFHKEsJsNOFy8evsrBvBoshoFhgGnCK0eLOZBr5+V9mXhbNaFeREQWVlpaGnl5eZimydDQEGVlZdOuIDwWSpmmiWEYhIWFYRiGB0crt0PvNkRERJa46Rqcj4yMaJaUTOnFw1c5eL4GE3CaJiMuE6dpYgIHz9fw4uGrCz1EERERgoKCsNvtBAcH09nZOWMJ31jJntPpBNRPaqlQKCUiIrLETdfg/Nq1a/T29mKz2SaU9MnyVt3Wx8G8Gkxz6udNEw7m1VDT3ufZgYmIiEwhPT2d4OBgOjo6aGhocDcxv9nYTKmRkRFAodRSoVBKRERkiZuqwfnw8DAXL14EYNOmTRMan8vy9vblOiyzlDNYDDh8qc5DIxIREZlecnIyQUFB+Pj44HA4pp0tNRZKDQ0NAWpyvlToHaqIiMgSNl2D86tXr9LX10dQUBDp6ekLNDpZjFodgxgGMM1MKQDTdHHi3EVi2i8TEhJCaGgoISEh7j/7+vqqT4eIiHiE1Wpl7dq11NXVuUv4srOzJ23X39+PaZoMDg4Cmim1VCiUEhERWcKmanA+NDTkniWVm5uL1WpdyCHKIhNp8522dG+My4Selnou9jQTFBSEzWab8O/I19fXHVKND6tCQkLw8/NTYCUiIvMqPT2d8+fP09TURG1tLQ6HA5vNNmGbgYEBhoaGsFgsWK3WaVfpk8VFoZSIiMgSNb7B+fhZUleuXGFgYICQkBDWrl27UMOTRWpvThyvHC2eeSPDYHOUic0IZmhoiObmZvz8/PDz83OXgjY3N9Pc3DxpVx8fH3dIFRwcPGGWlb+/vwIrERG5ZREREcTHx1NbW0tHRwfl5eVkZWVN2GYslLJarVp5bwlRKCUiIrJEVVdXuxucr1q1CoDBwUEuXboEjM6SsljUPlImSogI4ECufXT1vSlnTJlkBfQQFWBh5cpVjIyM0NnZ6X7W5XIRGBhIREQEwcHBuFwuurq66OrqwuFwMDQ0REtLCy0tLZOOPBZYTTXDSoGViIjMJCMjg8LCQtrb2yktLZ0USvX39zMwMICfn59K95YQhVIiIiJL1NgsqfENzvPz8xkcHCQsLIzU1NSFHJ4sYi/vywRGV9mzGAaGAS7TxDRhX9YKtnsP0tLsTWtrK/Hx8dx///20tLRQUVFBU1MTvb299Pb2AhAcHExycjK5ublERUXR09NDd3c3nZ2d7rCqs7OT3t7eWQOr4ODgKXtYKbASEZGUlBTCw8NpbGykvLyc3t5eAgMD3c+PzZQKDAxUk/MlRKGUiIjIEjRVg/OBgQHy8/MB2LJli2ZJybS8rRZ+sD+L7+xO4fClOlodg0QF+bI3Jw57eAAu1yYKCgo4e/YstbW1NDY2sm3bNp5++mn6+/uprKykoqKCmpoauru7yc/PJz8/Hz8/P5KSkkhKSiIzMxNvb2/3OUdGRuju7p4QVN08w6q1tZXW1tbJ4/X2nlQKOFYeGBgYqMBKRGQZ8PHxIT09nYqKCtrb2ykvL2f9+vXu5wcGBhgYGHCX78nSoFBKRERkCZqqwfnly5cZGhoiIiKC1atXL/AIZSmwhwfw/T2TZ9RZLBZycnJISkri+PHj1NfXc/LkSUpLS3nwwQfJyMggIyOD4eFhqqurqaiooKqqioGBAYqKiigqKsJqtWK320lOTiYpKYmAgADCw8OnvHvtdDqnnF3V3d1NT08Pw8PDtLW10dbWNmlfLy+vaXtYKbASEbm3ZGRkcPLkSVpaWigqKnKHUk6nk6GhIYaGhvDy8lIotYQolBIREVlipmpw3tfXR0FBAQBbt27VB3GZF6Ghoezbt49r165x+vRpGhsbOXToEFu2bCEnJwdvb29Wr17N6tWrcblcNDQ0UFFRQUVFBd3d3VRWVlJZWYlhGKxYsYJVq1aRlJQ06cPC2F3tqT5EjA+sbg6uenp6GBkZmTawslqtE0Kq8bOsFFiJiCw9MTExJCQk0NTUxI0bN+jr6yMgIID+/n6Gh4cxTROr1UpISMhCD1XmSKGUiIjIEjNVg/NLly4xPDxMVFQUSUlJCztAuacYhkFmZiaJiYl88sknVFdXc+bMGUpLS9mzZw8REREA1HUOcLioj1ZHKBGx2/jKjgCGOhooLy+npaWFxsZGGhsbOX36NGFhYSQlJbFq1SpWrFgxYzg0l8Dq5rCqq6uL7u5unE7njIHVzc3WFViJiCxuhmGQk5PDlStX3KvwZWZmMjAwwODgoPuaYbVaF3qoMkcKpURERJaYmxuc9/b2cuXKFUCzpOTuCQoK4oknnqCoqIhTp07R0tLCa6+9Rs7GTRyu8eW187XupummCX9pmhzItfPy/mcY7O9zz6Cqq6ujo6ODjo4OLl26REBAgDugiouLczftn4vxgVViYuKE55xOJz09PZPKAcf+63Q6aW9vp729fcrjTtfDKigoaN7/H6tp73P39oq0+bJvw2hvLxERmWzt2rWEhobS2NhIQUHBlKGULB0KpURERJaQqRqcX7hwAafT6Z7SLnK3GIZBeno6CQkJnDhxgoqKCn7wYTlXem2YGDhNE8wvtz94vgaAH+zPYv369axfv57BwcEJfaj6+vooLCyksLAQb29vEhIS3M3S/fz8bnusY6V7oaGhk55zOp04HI5JDdfHvpxOpzs4m+q4Y6sE3jzLymaz3dICA8NOFy8evjphFUTThFeOFo8Gevsy8bZqwQIRkfECAgJYv349jY2NXL9+nb6+Pvr7+xkcHFQ/qSVIoZSIiMgScnODc4fD4Z45pVlS4imBgYF89atf5bOLhfz56xXA1P/uTBN+nlfD89nh2MP8sVgsWK1WVq5cSVxcHDt37qSxsZHq6moqKyvp6+ujrKyMsrIyDMMgNjaW5ORkkpOTCQ4OnnY8tzrTaHzp3s1BrsvlwuFwTGq6Pr4kcK6B1fjgaqrA6sXDVzl4vgYTZgz0RERkoo0bN/LZZ5/R2dlJaWkphmEolFqiFEqJiIgsEVM1OD9//jxOp5PY2Fji4uIWcniyzBiGQX6nD1bDwGnOsJ1p8l9/8jbZXvV4e3vj5eU14b9jfT9M02RgYICenh4cDgeDg4Ncv34dwzAwDAN/f3/Cw8MJCwvDZrON7mdYebPam7MtFizwxUwjg784Wsx9sQa/keaNj5cVi8Uy6ctqHX3cMIxpnw8ICMBmsxEfH+8OlAYGBujt7aWnp8f9X4fDgcPhYHh4mMHBQVpbW90B8dj4LRaLO7AKDQ2l3xLIz/Pqp/2+mSYczKvhO7tTVMonInITu91OdHQ01dXVfP7552RnZzM4OIivr++Uq7zK4qVQSkREZIm4ucF5d3e3ZknJgmp1DI7+uzNnSKUwcYwYdPd1Y36xnWma7j8bhuEOqcaCquDgYEzTZGhoiP7+fgYGBhgeHnav6Oft7U1QUBAXLGu5PhQGGLhGT+X2Wb2Lrq42Hg2f3OT8ToyN3TRNXC6X+79Op9MdSo0tSz48PMzQ0BAjIyMTXjtAZWAaBGaAMX15nsUwOHypju/vSZ3X1yAistRZLBZyc3Oprq6muLiY2NhYnE4nXl5eU5Zty+KlUEpERGSJuLnBeV5eHqZpEh8fT2xs7AKPTpajSJvvzHkUgGEQafMhMzaTiIgIfHx86Ovro7e3l/7+/gkB1fjAZ/xjIyMjDA4OMjAwQH9/P4Zh0DZocN06GkhNc2IKeoM4kB1OqNcIw8PDjIyMMDIy8c9jYZLT6XT/fexr7O/jHx8Loqb7upnVasVqtbqDq7H/DuKLgclM3z7DGA3+RERkstzcXH71q1/hcDgoKioCwGaz4e3tvcAjk1uhUEpERGQJuLnBeUdHBzdu3ABGZ0mJLIS9OXG8crR4xm1MYEP4aLDT1NRESEgI6enppKWl4evr6w6oZvoaHh7GZrMBo2Wsvb29nO4KxnCZmDPMEDQwee9qM9tDumYco2EY7plat2L8fuO/xoKosa+bSwYtFgvvlA/zZvHgjKGeyzSJtPne0phERJaL4OBgVq1axfnrFRypgUG/dfQRSU17n8qelxCFUiIiIkvAzQ3OP/zwQ0zTJDExkZiYmIUenixTCREBHMi1jzbrniJcMQx4fnMC375vC4WFhZSUlNDV1cXZs2c5d+4cSUlJpKenk5iYOOOqdUNDQ5OCqrLP27hWNTRzPytgxMufiIgvw6LxpYIzfY3fbvx+4/881pPqdiRn9vHGnx+fcRvThH0b1CtORGQqw04Xl70z+MSWBJgYQE2bwf0/PK4VTJcQhVIiIiKL3M0Nztva2igtLQU0S0oW3sv7MoHRptwWw8AwRmf4mCYc2Pzlh4Lo6Gh27txJaWkphYWFNDY2UlFRQUVFBYGBgaSlpZGRkTHlKns+Pj74+PhMWFEpq6OEj6tKYIYCOBNYmxTH888uvp5rcwn0Dmy2626/iMg0Xjx8lWOV/aO/MDEw+fKKoBVMlw6FUiIiIovczQ3OP/roI0zTZNWqVURFRS308GSZ87Za+MH+LL6zO4XDl+podQwSFeTL3py4SYGKt7c36enppKen097eTmFhITdu3KC3t5cLFy5w4cIF4uPjycjIYNWqVe6V+aYy19JBn4Z8Xn+9mh07dhAfHz8fL3neTAz0vuipxej9/rFAT0REJqtu6+NgXs20tyW0gunSoVBKRERkkRvf4Lyjo4OysjIMw2DLli0LPDKRL9nDA25plbjw8HB27drF9u3bKS8vp7CwkNraWveXn58fa9euJSMjY8rlvecy02hPUgDRFgstLS28/fbbJCYmsn37diIiIu7kpc6bmwO9yzfKGexq4cn1MTz/hO7ui4hM5+3LdVgMA+cMjfm0gunSoFBKRERkEbu5wfmZM2cAWL169aL5YC1yJ6xWK6mpqaSmptLd3U1hYSFFRUX09vaSn59Pfn4+MTExZGRkkJKSMmFVpbmUDg4PbuP8+fNcvXqVqqoqqqurWbt2LVu3bnU3T19oY4FefXogb731Ft0N/YyMjNxy43W5t9S097lnH0bafNm3YfLsQ5HlqtUxOFq1N1NfQa1guiToSiciIrKIjW9wPjQ0REVFhWZJyT0rODiYbdu2sWXLFqqrqyksLKSyspLGxkYaGxs5efIkqampZGRkEBUVNafSQe+AAO6//36ysrI4d+4cpaWlFBUVUVJSQnZ2Nhs3bsTXd3GscLdy5UpsNps7jE5JSVnoIckCGHa6ePHw1Qlhq2nCK0eL1bxZ5AuRNt8ZVy8FrWC6VCiUEhERWaRubnD++eefA7BmzZoJDZ9F7jUWi4WkpCSSkpLo7e2lqKiI69ev09XVxbVr17h27RoRERGsW7eONWvWzKl0MDQ0lEcffZTs7GzOnDlDfX09Fy9epLCwkM2bN5OZmTljDytPMAyDtWvXcuHCBYqLixVKLVMvHr46WpYKo6VJ4z54q3mzyKg59RXUCqZLgiJ2ERGRRWp8g/OAgACqq6sxDIPNmzcv9NBEPCYwMJBNmzbxG7/xG+zdu5fU1FSsVittbW18+umn/PSnP+Xo0aPU19djznbbHIiJiWHfvn187WtfIywsjIGBAU6ePMnPfvYzSkpK5nSMu2nNmjUAVFZW0t/fv6BjEc9zN2+e5p/hWPPmmvY+zw5MZJEZ6ys43cKqhgEHcrWC6VKgmVIiIiKL1PgG5xcuXAAgLS2N0NDQBRyVyMIwDIP4+Hji4+MZGBjgxo0bFBYW0t7eTnFxMcXFxYSEhJCRkUFaWhoBAdN/EDEMg+TkZBITEykqKuLcuXN0d3fz4YcfcunSpQVdqS88PJyoqChaWlooLS1l/fr1CzIOWRhq3iwyd3PpKyiLn0IpERGRRWh8g/Pw8HDy8/OxWCyaJSUC+Pn5kZ2dTVZWFk1NTVy/fp2SkhK6uro4c+YMZ8+eJTk5mYyMDOx2OxbL1MUBFouFjIwMUlNTyc/P59KlS4tipb41a9bQ0tJCcXGxQqllRs2bReZuLn0FZfFTKCUiIrIIjTU4X7lyJUVFRQBkZGQQHBy8wCMTWTwMwyAmJoaYmBh27txJaWkphYWFNDU1UV5eTnl5OTabjfT0dNLS0qb9/8fb25vNmzeTkZExaaW+tLQ0tmzZ4tGV+tasWcPp06dpbGykq6uLkJAQj51bFo7L5WKktwOnywVMU5OEmjeL3GwufQVl8VIoJSIissiMb3AeGRnJlStXsFqtbNq0aYFHJrJ4+fj4kJGRQUZGBm1tbRQWFnLjxg0cDgd5eXmcP38eu91ORkYGSUlJUzY1Dxi3Ut/Zs2cpKyvj+vXrFBcXk5OTw4YNGzyyUl9AQAB2u53q6mqKi4vJzc296+eUhVVbW8tnn31GQEs3JjM3ZlbzZhG5lyiUEhERWWTGGpz7+vrS0NAAQGZmpkdnaogsZREREdx3331s376diooKCgsLqa2tpbq6murqavz9/UlLSyM9PX3KlSxDQ0N57LHHaGxsdK/Ud+HCBa5du+axlfrWrFlDdXU1N27cYPPmzRjTdfOVJa2np4dTp05RVlYGQIzNj0dTgviwzDFNs3OTZzbGqjRJRO4ZCqVEREQWmbFZUuHh4TQ0NODl5cXGjRsXeFQiS4+XlxepqamkpqbS2dlJUVER169fp6+vj0uXLnHp0iViY2NJT09n9erVeHt7T9h/bKW+yspKzpw5Q0dHBydPnqSgoIBt27aRkpJy18KiVatW4eXlRVdXF01NTcTExNyV88jCGBkZ4dKlS1y4cAGn04lhGKxbt46tW7fyTW8fXjx8dVLzZpdpkhXoYKdvHaa5QUGliNwTFEqJiIgsIuMbnHd3dwOwfv36GVcSE5HZhYaGsm3bNnJzc6murqawsJCqqirq6+upr6/ns88+Y82aNWRkZBAVFeXeb/xKfdevX+fzzz93r9R3+fJlduzYQVzc/JdSeXt7s2rVKvfKggql7g2maVJeXs6pU6fo6ekBIDY2lvvuu4/IyEj3dlM1b74/MYDTR9+hrraN/Px8cnJyFuhViIjMH4VSIiIii8hYg3NfX196e3vx9vZmw4YNCz0skXuG1WolOTmZ5ORkHA4HRUVFFBYW0tPTw9WrV7l69SpRUVFkZGSwZs0afHx8gNGV+tatW8eaNWu4fPkyly5dorm5mcOHD9+1lfrWrl1LcXExJSUl7Ny5866XDMrd1d7ezmeffUZtbS0ANpuNHTt2TDvjbqrmzZb+XZw4cYIzZ84QFxc3IUAVEVmKFEqJiIgsEuMbnA8MDGAYBllZWfj7+y/wyETuTTabjc2bN7Np0yZqa2spLCykvLyclpYWTpw4walTp0hJSSEjI4OYmBgMw8Db25vc3FzWrVtHXl4e165du2sr9cXHxxMQEEBfXx/V1dUkJyfPy3HFswYHB8nLy6OgoADTNLFareTk5LBp06ZJJaOzWbduHdXV1VRUVPDBBx/w/PPP3/IxREQWE4VSIiIii8RYg/P+/n58fX3x9fXVLCkRDzAMA7vdjt1up7+/nxs3blBYWEhHRwdFRUUUFRURFhbmnj0VEBBAQEAADzzwAFlZWZw7d27SSn0bN250z7K6XRaLhdTUVPLz8ykuLlYotcSYpsn169c5e/Ys/f39ACQnJ7Nr1y6Cg4Nv65iGYfDggw9y6NAhurq6+PTTT9mzZ898DltExKMUSomIiCwShYWFmKbJyMgI/v7+5OTkeGT5eRH50tj/e9nZ2TQ2NlJYWEhpaSkdHR2cOnWKM2fOkJyczLp164iPjycsLMy9Ut+pU6dobGx0r9Q3NqPqTsru1q5dS35+PhUVFQwODup3whLR2NjIZ599RnNzMzDa0+y+++4jISHhjo/t5+fHQw89xNtvv01RURF2u501a9bc8XFFRBaCQikREZFFYKzBeVdXF/7+/vj5+ZGdnb3QwxJZtgzDYOXKlaxcuZJdu3ZRUlJCYWEhLS0tlJWVUVZWRlBQEOnp6aSnpxMTE8PTTz9NZWUlp0+fprOzk88++8y9Ut/q1atva7W0yMhIwsLC6OjooLy8nPT09LvwamW+9PX1cebMGYqKigDw8fFh8+bNZGVlzWtPsLi4ODZv3kxeXh4nTpwgJibmtmdfiYgsJIVSIiIii8D169dxuVz09/cTGhrKhg0b7rj0R0Tmh6+vL5mZmWRmZtLS0kJhYSHFxcX09PTw+eefk5eXR0JCAhkZGSQmJpKYmEhhYSF5eXl0dXXxwQcfEB0dzc6dO4mNjb2lcxuGwdq1azl79izFxcUKpRYpp9NJQUEB58+fZ2hoCIC0tDS2b99+11ZP3bx5MzU1NTQ2NvLBBx/w9NNPqxm+iCw5CqVEREQW2FiD887OTvz9/fH392f9+vULPSwRmUJUVBQPPPAAO3bscPeRqq+vp6qqiqqqKgICAkhLSyM9PZ21a9dOWKnvrbfeIikpie3btxMeHj7nc6ampnL27Fnq6upwOBzz1khd5kd1dTUnT56ko6MDGP03cv/99xMTE3NXz2uxWHj44Yd57bXXaG5uJi8vj23btt3Vc4qIzDeFUiIiIgusurqanp4e2tvbSU5OZuPGjVpNSWSR8/b2Ji0tjbS0NDo6Orh+/TpFRUX09fVx8eJFLl68SFxcHBkZGRw4cIBLly5x7do1KisrqaqqIj09ndzc3DkFTMHBwcTGxlJfX09xcTEbN270wCuU2XR3d3Py5EkqKiqA0X5k27ZtIz09/bZKNW9HcHAwu3fv5siRI1y8eJH4+Hji4+M9cm4RkfmgUEpERGSBja3yFRgYSFBQEJmZmQs9JBG5BWFhYezYsYOtW7dSWVlJYWEhNTU11NXVUVdXh6+vL2vXruWxxx7jxo0blJeXU1hYyI0bN+a8Ut+aNWsUSnlQTXsfhy/V0eoYJNLmy74NcdjDR8vwhoeHuXDhApcvX8bpdGIYBllZWeTm5i5II/rVq1eTkZFBYWEhR48e5fnnn79rJYMiIvNNoZSIiMgCcjgclJeX09LSQlJSEps2bcLLS5dnkaXIarWyevVqVq9eTU9PD0VFRRQWFuJwOCgoKKCgoIDo6GiysrJoaGigpaWFCxcuUFhYyObNm2dcqS8lJYXPPvuMtrY2WltbiYyM9PCrWx6GnS5ePHyVg3k1WAwDwwDThFeOFvN8rp0XMv34/OwZHA4HAPHx8dx33323VI55N+zatYuGhgY6Ojr4+OOPefzxxz02W0tE5E5YFnoAIiIiy9n169dpb2/H19eXiIgIMjIyFnpIIjIPgoKCyM3N5Td/8zd58skn3avvNTc3U1BQQEdHBxEREXh5edHf389nn33Gz3/+c8rKyjBNc9LxfH19SUxMBKC4uNjTL2fZePHwVQ6er8EEnKbJiMvEaZqYwKG8av7LaxdxOBwEBQXx2GOP8dRTTy14IAWj5aSPPPIIVquVqqoqCgoKFnpIIiJzolBKRERkgbhcLq5cuUJrayuhoaFs3rxZKyeJ3GMsFgsJCQk89thjfOtb32LHjh2EhoYyMjJCW1sbw8PDjIyM4HA4aG9v58iRI7zxxhvU19dPOtbatWuB0VDK5XJ5+qXc86rb+jiYV8MUmSAAJgYFvTYS123i13/9191B42IRGRnJzp07AThz5gwtLS0LPCIRkdmpPkBERGSBVFdXU1NTg2maxMfHk5aWttBDEpG7KCAggA0bNpCTk0NDQwOFhYWUlpZiGAb+/v50dHQwPDxMb28vTU1NJCcns23bNvdMnMTERHx9fent7aW+vl4NrefZ25frsBgGzulSKcBiGFQ4IxZtmXVmZiY1NTVUVFTw4Ycf8txzz2nhDBFZ1Bbnb1MREZFloKCgwD1LauvWrZolJbJMGIZBbGwssbGx3HfffRQXF3Pt2jWsVisjIyM0Nze7e06VlJSQlZXFli1bCAwMJCUlhVP5N/i/3r9GSHTnpCbccvtaHYMYBjB9JoXFMGh1DHpsTLfKMAwefPBBDh48SGdnJ5999hkPPvjgQg9LRGRaCqVEREQWgMPh4OLFizidThITE1mzZs1CD0lEFoCvry/r168nMzOTlpYWCgsLKSkpoaenh6amJpqbm6mvr+f8+fNs37mLX1T58G5DHAbDWCuq3U24D+TaeXlfJt5Wdee4XZE232lL98a4TJNIm+dX2LsVfn5+PPzww7z99ttcv34du91OamrqQg9LRGRKCqVEREQ8aGyZ8SulVVR1hbA60MkDDzyAxaIPkiLLmWEYREdHEx0dzc6dOyktLaWwsJDy8nIaGxupqKjgncYgqr3jAQMTGHF9maAcPF8DwA/2Zy3MC7gH7M2J45WjMzeRd5nwxPoVHhrR7YuLi2Pjxo1cuHCBTz75hBUrVhAcHLzQwxIRmUShlIiIAKNhyaGz1YQ99PsLPZR70sRlxsE0XZg+KdwwDIIL+vk/V7k0w0FEgNGV1NLT00lPT6e9vZ1r165x9MwlqttGA6mpmCYczKvhO7tTVMp3mxIiAjiQax9dfW/KGVMmWYEOPj/+PmGPPkpoaKiHR3hrtmzZQl1dHY2NjRw9epR9+/apTFxEFh29+xURWeaGnS7+6I0C7vvhcf7u0yqCNjy+0EO6J01cZhxcWDANC2Bw6HwNLx6+utBDFJFFKDw8nPvuu4+IjY9hscy80pvFMDh8qc5DI7s3vbwvkwOb7RiA1TDwshhYjNEo8In0cJ5Y2fv/tHfvsVHeeb7n30+VyzZ2ufAV8KWMDTY2iQEDNoFAAANpCDTBnWQasjOts6elnaON1KujI+0ffXaV3Y12N1JL0xrtaE6fI51d6UzSEyZJJ0TdzcVcA0m4GHO/2ICN8R3s8rV8r6pn/6h2DQ6+AbbLZX9eEmrJT/mpb1kdP48/z/f3/dHS0sIXX3zB/fv3g13umCwWC2+++Sbh4eE0NTVRWloa7JJERJ6hTikRkTnuf/36Jv9yuQ7wz3Y1tIxs0gW2GR/luDocRGQ8rd0DWAwD3xhDjwyDGT2EOxTYrBY+fnclHxRlcehqPS3ufpJiItiX7x8m73avpKSkhMbGRkpKSmhoaGDjxo0zdjc+h8PB1q1bKSkp4cqVK6SlpWnXRhGZUWbmb08REZkWNa6eQCAlU2ei24wfulrPr7ZrGK2IPGu2DOEOFc74qBF/H9vtdoqLi7l06RJlZWXcunWLpqYmds7g5XzZ2dnU1tZy9+5dTpw4wcafvM3Ruy5a3P3avVFEgk6Pw0VE5rD/dr462CXMCYFtxsegDgcRGcu+/NQxu6TA33VZvDp1miqauywWC+vXr2fv3r1ERkaGxHK+N954g5j5sXxVG8mb/895/v7EfX5/sYa/P3Gfzb85za//cINBry/YZYrIHKRQSkRkDit71BbsEuYEdTiIyMsaGsI9WsBtGHCg0KmOl2mUnp7O/v37SUlJYWBggJKSEs6cOYPH4wl2ac+w2WxcMbK50W0HwGuaeHwmXtPExL97o2YbikgwKJQSEZnTxklKZFKow0FEJsNYQ7gPFDj5qDgv2CXOOXa7nX379rF27VoAbt++zZdffkl7e3twC/uRGlcP39xsZrzdG2tbe6a3MBGZ8zRTSkRkDlubHse12o5glzHrjbfNuGH4/6BUh4OIjGW8IdwSHEPL+VJSUjh+/Dgul4vPP/+coqIisrNnxpxAzTYUkZlKoZSIyBz2b17P5P/9vjrYZcwJHxXn4fV6+fxKvb/LwWLB6/NhAptTw9ThICITNtoQbgmuoeV8x48fp6GhgZKSEurr69m0aVPQd+cLzDYco2lXsw1FJBgUSomIzGHpCVGsS/Jy6YmFcSdxy0uxWS38+00Lmd94iUpPHM6sV4hgALO6lFjDw+PGBm3TLSIS4oaW8126dIkrV65w+/btwO58cXFxQavLP9tw7GXkmm0oIsGgmVIiInNYV1cXKY3fEe1zAyaY5rg3rfLi2traiA3z8LNl8/g/9uXxH/etYVN+LgBnzpxhcHAwyBWKiMjLGlrO99Of/pR58+bhcrmCvjvf2/kpYy7dA802FJHgUCglIjKHHT16lDJfBt0WO2CAYWCoY2rKtLa2AhAfHx/42oYNG7Db7XR0dHDp0qVglSYiIpMsPT2dn//856SkpDA4OEhJSQmnT58Oyu58rkcVrIz+ywOoEWj3RhEJFoVSIiJzVEdHByfOX6XWlq6le9NkKJR6eglHeHg4W7duBeD69es8fvw4GKWJiMgUeHp3PsMwuHPnDl9++SVtbW3TVkNTUxMXLlxgR5yLXdkxABiYWPBh/CWk0u6NIhIsCqVEROaoP//5zzz0JSqPmkYjdUoBLF68mGXLlmGaJqdOncLr9QajPBERmQJDy/n27t07bDnfvXv3pvy9+/v7KSkpwTRNcpdl87tfbubrX65go6OdldFdbJzfzv+U2cL/9bM8bFb9aSgi00+/eURE5qC2tjYuXrxIvyUCi1KpadHX10dPTw/wbCgF8MYbbzBv3jxaW1spKyub7vJERGSKOZ3OYcv5jh8/PqXL+UzT5PTp03R1deFwONiyZQuGYeCMj2LD/A7eTu2jaEE/ER43dXV1U1KDiMh4FEqJiMxB33zzDYODg8RG6jIwXYa6pOx2O+Hh4c8cj4yM5I033gCgrKwMl8s1rfWJiMjUG1rOV1hYOOXL+e7cuUNlZSWGYfCTn/yEiAj/znpWqxUAn89HdnY2AOXl5ZP+/iIiE6G/RkRE5piWlhauXLkCwC82L8erzfamxWhL956WlZVFZmYmPp+PU6dO4fP5pqs8ERGZJhaLhXXr1j2znK+iomLS3sPlcnHu3DnAv6HGwoULA8eGQimPx0NOTg4AVVVVDAwMTNr7i4hMlEIpEZE55uuvv8bj8ZCUlESKI5yV0V2MthuPTJ6hp+BjhVKGYbB582bCw8N58uQJ169fn67yRERkmjmdTvbv309qaiqDg4OcOHGCU6dOMTg4+FLn9Xg8lJSU4PV6SU9PJz8/f9jxpzulkpKSiI2Nxev1UlVV9VLvKyLyIhRKiYjMIY2Njdy4cQOA/Px8rl69yo44F28tcwAmmD5M78vdDMvIRtp5byR2u52NGzcCcPHiRdrb26e6NBERCZLo6GjefvvtwHK+u3fvvvRyvu+++47W1laioqLYvn07xo9mRw6FUqZpYppmoFtqMju1REQmSqGUiMgc8vXXX+P1eomPj6epqQmAgjWr+d0vN7Pbe5GU1mt0XTsa5Cpnp4ks3xuyfPly0tLS8Hq9nD59GtNUJ5uIyGw1tJzv7bffJioqitbW1hdezldZWcnt27cB2LFjB1FRUc+8ZiiUAn+31LJlywCor6/H7Xa/4KcQEXkxCqVEROaIR48ecfv2bXw+H3a7HZ/PR2ZmJhs2bADANtBJStt12k78lyBXOvuMt/PejxmGQVFREWFhYTQ0NAT+wBARkdkrLS2N/fv3k5aW9kLL+To7Ozl9+jQAa9aswel0jvi6p0Mpr9eLw+EgJSUF0zS5d+/ey3+QIKtt7eEfTt7nf/vmFv9w8j61rT3BLklExqBQSkRkjjh06BA+nw+r1UpMTAwJCQns2LEj0Nb/sjMsZHTj7bw3EofDwfr16wE4f/68nl6LiMwBUVFR7N27l3Xr1g1bzjd0HRmN1+vl+PHj9Pf3s2jRItatWzfqay0WS+Da7/F4AALdUhUVFSHbnTvo9fHrP9xg829O8/cn7vP7izX8/Yn7bP7NaX79hxsMerV5iMhMpFBKRGQOqKyspKKigp6eHlJSUpg3bx67d+8eFpAolJo6z7N072krVqxg0aJFDAwMcObMmZD9Q0FERCbOYrFQWFj4zHK+8vLywGt+3A305zMXaGpqIjw8nDfffHNYN9RInh52Dv7dX61WK62trbS0tEzdh5tCHx66xcHLtZiA1zTx+Ey8pokJHLxcy4eHbgW7RBEZQViwCxARkalR29rDoav1tLj7Kb9eitFv4IiIID4+nl27duFwOIa9fuhpqUy+Fw2lLBYLRUVFfP755zx69Ih79+4FBtKKiMjsNrSc7/jx49TV1XHy5Eke1dZxqj2Rz8vqsRgGhgE+08RnmqyMTuA3+9c+c30fidVqxePxBK79ERERZGRkBB5iJSUlTfXHm1Q1rh4OltaOupewacLB0lo+KMrCGf/snC0RCR51SomIzDI/bl//9MIjLnYnciHxLWoWbmLT5i2kpKQM+x6fz6dQagoN7aI03s57I4mPj6egoADw76g0NJtKRERmvx8v5/vHCy18XlY3rBvIZwIY3OyO4b/d7J3QeYc6pbxeb+BrQw897t+/H+igmslM08TtdvPo0SN+d6QUY5zXWwyDQ1frp6U2EZk4dUqJiMwyP25fB8DwP4OoGEzgn8s9fPzq8O8ZGBjQ0rAp9KKdUkNWr17NgwcPcLlcnDt3jp07d05meSIiMoMNLefzRcXzm0/uwijxi8nEu4FGCqXS09OJjIykp6eHuro60tPTJ+sjvLT+/n5cLhetra24XK7Av/7+frq6uihtT8AkOXC/MxLDgBZ3/zRWLSIToVBKRGQWGbd9nZFvWLu7u0PiqWgoet6d90ZitVrZvn07X3zxBQ8ePGDZsmVkZmZOZpkiIjLDXWryYTUMvGM8QxrqBvrV9uwxz/XjmVJDX8vOzubmzZuUl5cHJZTyer20tbUFQqehEOrHm3309vbS3t5OZ2cnVquVeRHzGS2sG+IzTRLtEVNYvYi8CIVSIiKzyDfX/DMmvGN0PY10w9rX14dpmoHdeGTyvMjOeyNJSkoiPz+fq1evcubMGVJSUoiI0M21iMhc0eLu91+nx+xsNrlX20RHxwIcDseo1/WROqXAv4Tv5s2bVFVVMTAw8FLXrbGYpklXV9ewrieXy0V7e/uondvh4eEMDg7S1dWFx+MhLi6OhQsXEhMTw+bUpfyHk53jvCcUr06dio8jIi9BoZSIyCziv2GFUVulGLl9vbPTfyNnsWjU4GR72aV7T1u3bh0PHz6kvb2dH374gaKiopc+p4iIhIZEe8TYeRT+bqC2hkd8+ukNoqKiSE5OJiUlheTkZBISEgLX+aFQ6sfzJBcsWEBsbCzVLW7+z6/LMCJjSLRHULw69YUHhPf19Q0Lnoa6n0bb9Tc8PJyEhAQSEhKYP38+3d3dNDU18fjxY0zTxG63Y7VaWbp0Kbm5uaSmpmKxWLjUecM/vmCEn5FhwIECp4aci8xACqVERGaRid6w/rh9fSiUUqfU5JvMUCosLIyioiK+/vpr7ty5Q3Z2NmlpaS99XhERmfn25afy2+P3xnyNicHmjCi8HV309PRQWVlJZWUl4A97kpOTSU5ODizb//HSfY/P5LR7EScae7E0urBY2jBN+O3xexwodPJRcR4268gPsDwez7Cld0P/Rtugw2KxEBcXFwighv5FRUXR2NhIeXk5ly5dGhZepaSkkJOTQ1ZW1jNdXB8V5wHwWWktBqb/IR0GpukPpIaOi8jMolBKRGQWmcgNq8802ZY1fLvooVAqLEyXhck2tPPeZIRS4L8hz8vL49atW5w+fZoDBw5gs9km5dwiIjJzpSdEcaDQOWo3EJjsfSWBv/3vNuDxeHj8+DGNjY00NjbS1NTEwMAAjx494tGjR1RXV9PT00N4eDjNzc0kJyezaNEi/vc/VXDyYR9g4AN8vn99o4OXawH4v99ZQUdHxzODxzs6OkZdehcTEzMseIqPjyc2NjbQsQXQ3t7O7du3qaiooKurK/B1h8NBbm4uOTk5OByOkU4PgM1q4eN3V1KcG80/fHMeb3g0G9fksS//xbu8RGTq6a8PEZFZZLwbVgOTFdFuLpz4Ewl79rBo0SLAP+gcFEpNhaFOqbi4uEk754YNG6iurqazs5OLFy+yadOmSTu3iIjMXEPdPgdLa7EYBobhf9jkM2FltJtX+xpxuZaRkJBAamoqqan+GUo+nw+Xy0VDQ0MgqOru7qa5uZmysjIAOrw2PmtIYdTd/Uz4rLSG2MZL2I2Rd7GLjIwkPj7+mQBqtNlU/f39PHjwgPLycpqamgJfDw8PJysri5ycHJKTk5+rkzt1fgQb5ncQH2/l/W1jD3wXkeDTXx8iIrPMaDespgnvrk5mLZW0tvRx6NAhduzYQUR8Cn966OFhXAHRYT7C5i8M8ieYPSZj572RhIeHU1RUxB//+Edu3LhBVlZWIGAUEZHZa6gb6IOiLA5drafF3U9STAR78hZy9bsTNDYO8Kc//Yl3330Xu90e+D6LxUJSUhJJSUmsWrUKn89HeXk5OTk5REZG0tjYyPkafxw11hQAA7jZGcmmeE8gfHo6hIqKiho3QPL5fNTV1VFeXk5VVVVg2LphGDidTnJzc8nMzHzpB2WjdW2JyMyiUEpEZJYZ7YZ1qH19cHAlJSUlVD6s5j98dpkb3TEYREJMNmCQ8u/+a7A/wqxQ29rDP50t53JbPHHzrLzt9uCMn7xdjNLT08nNzaW8vJxTp06xf//+YcsgRERk9nLGRw3bRRcgefdu/vCHP9De3s6f//xnfvazn43aoRQWFkZERASpqank5+cDcOcP17hQVo/HN+K3AGC1GKRmLedv31v93JujuFwuKioqqKioGDZnKj4+ntzcXLKzs4cFaS9K8zFFQotCKRGRWWqkG1YAm83GW2+9xS9/d5wb3f7hoSYGGP5AQ7dyL2fQ6+PDQ7c4WFr7l50QY8ANm39zetwhsc9r48aN1NTU0NbWRmlpKevXr5+U84qISOiJjIxk7969fPnll7S0tHDs2DH27NkzYng09BBjqEsJIDk2GtMcu1fKZ0JagmPCgVRPTw/379+noqKC5ubmYbVmZ2eTm5tLUlLSpAZJQ+dSp5RIaFAoJSIyB9W19fFtrQdFUJPvw0O3/DO94C9zvf71Zzw0JPbjd1dOyntFRkayefNmjh49ypUrV8jKyiIxMXFSzi0iIqHH4XCwZ88evv76a2pqavj222/ZunXrM6HPUCj19O57E9rdz4Ti1aljvsbr9VJdXU1FRQXV1dWBcMhisbB48WJyc3NZvHixuntFBFAoJSIyJ31zrR6LYeDVU8RJVePq4WBp7ajPmE3TP+vrg6KsSdsJaOnSpSxZsoSqqipOnTrFe++999xLKkREZPZYuHAhO3fu5MiRI9y5cweHw8HatWuHvWZoXtPTnVLpCVFsSrFwrsHLSA+tDAMOFDhHvH6ZpsmTJ08oLy/nwYMH9PX1BY4lJSUFlufNmzdvkj7l6NQpJRJaFEqJiMxBLe7+vywtC3Yls8tEwj6LYXDoav2ISytf1JYtW6ivr6e5uZlr166xZs2aSTu3iIiEnszMTDZt2sS5c+e4cOECdrudnJycwPGhhxcejyfwtcrKSgotVXREJ3CjOwbrjzZLOVDgDGymMsTtdnPv3j3Ky8tpa2sLfD06Opply5aRk5NDQkLCFH/a4TRTSiS0KJQSEZmDEu0R6AHi5JtI2GcY/tdNpqioKDZu3MipU6e4dOkSmZmZxMXFTep7iIhIaFm5ciVdXV1cu3aNU6dOER0dTVpaGvDsTKmenh6+/fZbrAb8xzczSF22csTNUgAGBwepqqqioqKCurq6QEeS1WplyZIl5ObmkpaWFvSuXXVKiYQGhVIiInPQROZGyPObSNjn85nE2Cb/vXNzc7l//z61tbWcOXOG4uJiPS0WEZnjXn/9dbq6uqisrOTIkSO88847JCQkPLN87+zZs/T29hIfH09hYSFWq3VYR69pmjQ0NFBeXk5lZSUDAwOBYykpKeTk5JCVlTXqbn/TScv3REKLQikRkTkoPSGKA4VO/0Bu3bNNmn35qfzdOGGfD5PBBz/w3XftFBQUEBkZOSnvbRgGW7du5eDBgzQ0NHDr1i1WrFgxKecWEZHQZBgGO3bsoLu7m6amJv70pz/x3nvv0dzj43zHfC7f6edsywVsjY+Is/lf+/QA8o6ODioqKqioqKCzszPwdYfDQU5ODrm5uTgcjmB8tHEplBIJDQqlRETmqKG5EAdLa7E8NTfC69NN3IuKtXlY7ejhauc8RhwSC2xYCA7rINevX+fu3busXbuWlStXBp5avwyHw8H69es5d+4c58+fJyMjg5iYmJc+r4iIhK6wsDD27NnDl19+SWt7B//2Px3nksuGQSyWLi++uhZMUtmeMY//IT6B/v5+KisrKS8vp7GxMXCe8PBwli5dSm5uLsnJyTO2G3em1iUiI1MoJSIyR9msFj5+dyUfFGUF5kbEhMOv398B/4uW9j2vwcFBDh8+TJHDhc2WSqnLNizsM004UOgfEtvUUM8PP/xAS0sL58+f5+bNm7z22mssW7bspWdwrFixgvv379PU1MSZM2f46U9/qht0EZE5LjIykr179/Jv/7GEK53+PwFNDLxPPYc6Vd3HL//xKBvDawLL+gzDIC0tjdzcXDIzM7HZpmD9+STT8j2R0KJQSkRkjnPGRwXmRnR2dvI/dzwOckWhxzRNTp48icvlIiY6iv/vv99B24Bl1CGxTqeTn//851RUVHDx4kXcbjcnT57k2rVrvP7666Snp79wLYZhsG3bNv7lX/6FmpoaKioqyM3NnayPKiIiIarDY+NKZ9Sox03gXIOP3GSDzKQ4cnNzWbZsGXa7ffqKnEQKpURCg0IpERGRl1RWVkZlZSUWi4Vdu3Zht9uxw7AhsT9mGAa5ublkZWVx48YNysrKcLlc/PGPfyQtLY3XX3+dpKSkF6onLi6OwsJCLly4wPfff096ejpRUaP/ISIiIrPfN9fqsRoG3jHCGothYMlcx/t780O2yzZU6xaZq4K7T6eIiEiIe/jwIRcvXgRg8+bNJCcnP9f3h4WFsWbNGn7xi1+watUqLBYLdXV1fPHFF5w4cYKurq4Xqis/P5/ExET6+vo4e/bsC51DRERmjxZ3P+PlNRbDoM+0hXSwo+V7IqFFoZSIiMgLam1t5cSJEwDk5eXx6quvvvC5IiMj2bRpE3/9139NdnY2pmlSUVHB73//e3744Qf6+/uf63xWq5Vt27ZhGAaVlZVUVla+cG0iIhL6Eu0R4+646zNNEu0R01PQFFMoJRIaFEqJiIi8gP7+fg4fPszAwAApKSls2rRpUs7rcDj4yU9+wnvvvUdKSgper5erV6/y6aefcv369cDw2YlISkpizZo1AJw9e/a5gy0REZk99uWn4hsnqDFNKF6dOk0VTY1Q7vISmYsUSomIiDwnn89HSUkJHR0d2O12du7cidVqndT3WLhwIcXFxezZs4e4uDj6+vr47rvv+Od//mfu378/4SfABQUFxMXF0dPTw3fffTepNYqISOhIT4jiQKFz1CV8huHfJXZoU45QpeV7IqFFoZSIiMhzunDhAjU1NVitVnbv3j1lQ8QNwyAjI4MDBw5QVFREVFQUnZ2dlJSU8MUXX1BfXz/uOcLCwigqKsIwDMrLy6mpqZmSWkVEZOb7qDiPAwVODMBqGIRZDCwGGMCBAicfFecFu0QRmWO0+56IiMhzuHfvHlevXgVg+/btL7xD3vOwWCy88sorZGdnc/36da5cuUJzczOHDh0iIyOD9evXk5CQMOr3Jycnk5eXx82bNzlz5gzvv/8+NpttyusWEZGZxWa18PG7K/mgKItDV+tpcfeTFBPBvvzUkO+QGqJOKZHQolBKRERkgp48ecKpU6cAWLNmDdnZ2dP6/jabjYKCAl555RVKS0u5ffs21dXVPHr0iOXLl1NYWIjdbh/xezds2EB1dTVdXV2cP3+ezZs3T2vtIiIyczjjo/jV9um9homIjETL90RERCagp6eHI0eO4PV6Wbx4Ma+99lrQaomKimLLli28//77LFmyBNM0uXPnDp9++ikXLlxgYGDgme+x2Wxs3boVgFu3btHY2DjNVYuIiEw9i8X/J646pURCg0IpERGRcXi9Xo4dO4bb7SY2NpY333wzcNMbTHFxcbz11lu88847LFq0CK/XS1lZGZ9++ik3b958Zqe+9PR0cnNzMU2TU6dO4fF4glS5iIjI1FIoJRIagn9HLSIiMsOdO3eOhoYGwsPD2b17NxEREcEuaZjk5GTeeecddu3axfz58+nt7eXs2bN89tlnVFZWDrsx37RpE1FRUbS3t3P58uUgVi0iIjJ1FEqJhAaFUiIiImO4desWt2/fxjAMduzYQVxcXLBLGpFhGCxdupT333+fzZs3M2/ePDo6Ojh69ChfffVVYLleREREYJ7U0MB0ERGR2WImdDKLyMTpv1gREZFRNDQ0cPbsWQBee+01MjMzg1zR+KxWKytWrOBv/uZvKCgoICwsjKamJr766iuOHDlCW1sbS5cuZenSpYFlfD9e5iciIhLq1CklEhq0+56IiMgI3G43R48exTRNsrKyWLNmTbBLei7h4eG89tprvPrqq5SWlnL37l2qqqp4+PAhr776KgUFBdTX19PS0sKx7y9TORhPi7ufRHsExatnz9bgIiIyNymUEgkNCqVERER+ZHBwkMOHD9Pb20tCQgLbtm3DMIxgl/VC7HY7RUVFrFy5kgsXLlBdXc2tW7eoqKggPiGJQ7f7uHm4GYvRgsUwME347fF7HCh08lFxHjarmqpFRCR0hOr1WmSuUiglIiLyFNM0OX36NM3NzURGRrJ7925sNluwy3ppCQkJ7Nmzh/r6er7//nuam5v5pzv93OyJAQx8Jvieeqp88HItAB+/uzJIFYuIiDy/oVBKnVIioUGPP0VERJ5y7do17t+/j2EY7Nq1C4fDEeySJlVqaip/9Vd/xYr1W7nRbQdGfqJsmnCwtJba1p7pLVBERGSSKJgSmfkUSomIiPxFTU0N58+fB+CNN94gNTU1yBVNne/qBrCMs8TBYhgculo/TRWJiIi8PC3fEwktWr4nIiICtLe3c+zYMUzTZPny5eTl5QW7pEnl8Xioq6vj4cOHVFdXU1ofCaZ/6d5oDANa3P3TV6SIiMhLejqUMk1TIZXIDKdQSkRE5ryBgQEOHz7MwMAAixYtYsuWLbPiJra3t5fq6mqqq6upqanB4/EEjjnCIxkrkAL/jKlEe8QUVykiIjJ5fhxKicjMplBKRETmNNM0OX78OG1tbURHR7Nr1y6sVmuwy3phbW1tVFdX8/DhQ5qamobdkNvtdjIyMsjMzGT3vDi2/d3ZMc9lmlC8evYuYRQRERGR4FIoJSIic9rFixeprq7GarXy1ltvER0dHeySnovP5+Px48eBZXltbW3DjicmJpKZmUlmZiaJiYnDniAfKHRy8HItIz1INgw4UODEGR811R9BRERk0qhTSiS0KJQSEZE5q7KykrKyMgC2bt3KwoULg1zRxAwODg6bD9Xb2xs4ZhgGqampgSAqJiZm1PN8VOyfm3WwtBaLYWAY/iV7pukPpIaOi4iIhAqFUiKhRaGUiIjMSS0tLZw4cQKAVatWkZubG+SKxtbT0xNYlldbW4vX6w0cCw8PZ/HixWRmZpKenk5ExMTmQNmsFj5+dyUfFGVx6Go9Le5+kmIi2Jefqg4pEREREZlyCqVERGTO6e3t5fDhw3g8HtLS0nj99deDXdIzTNOkra0t0A31+PHjYU98Y2JiAt1QycnJLzUHyxkfxa+2Z09G2SIiIkGlTimR0KJQSkRE5hSfz0dJSQldXV04HA527tyJxWIJdlmAv7ampiYePnzIw4cP6ejoGHY8KSkpEEQlJCTMih0CRURERGTuUiglIjIH1Lb2BJZnJdojKF49d5dn/fDDD9TV1WGz2di9ezeRkZFBrWdwcJCamhoePnzIo0eP6OvrCxyzWq2kpaWRkZFBRkYGdrs9iJWKiIjMfOqUEgktCqVERGaxQa+PDw/dGjbI2jTht8fvcaDQP8jaZp0ZXULT4e7du1y/fh2A7du3k5CQEJQ63G431dXVVFdXU1dXN2w+VGRkZGA+lNPpJDw8PCg1ioiIhDqFUiIzn0IpEZFZ7MNDtzh4uRYT8JomPHVvdvByLQAfv7syOMVNs6amJr799lsACgsLWbp06bS9t2matLa2BpblPXnyZNhxh8MxbD7UTFlOKCIiEmq0tF0ktCiUEhGZpWpcPRwsrWW0Z4SmCQdLa/mgKGvWL+Vzu90cOXIEr9dLZmYmhYWFU/6eXq+XxsbGwI55nZ2dw44vXLiQzMxMMjIyiI+P1020iIjIJHj6eurz+YJYiYhMhEIpEZFZ6ptr9VgMw98hNQqLYXDoav2s3nnN4/Fw9OhRenp6iI+PZ8eOHVMWAA0MDPDo0SOqq6t59OgR/f39gWNWqxWn00lGRgaZmZlERc3uIFBERCQYalt7ON8xn26flf6z1fzVuoxZ//BNJJQplBIRmaVa3P0YBozaKgUYhv91s5Vpmnz77bc8fvyYiIgIdu/ePekzmtxud2BZXn19/bCnspGRkYEQyul0YrPZJvW9RURExO/pOZoQiwHc+PYh/3Dm4ZycoykSKhRKiYjMUon2CMab7+kzTRLtEdNTUBDcuHGD8vJyDMNg586dzJ8//6XPaZomLS0tVFdXU1VVRUtLy7DjsbGxgWV5ixYt0nwoERGRafD0HE0w/P/7l/uguTZHUySUKJQSEZml9uWn8tvj98Z8jWlC8erUaapoetXV1fH9998D8Prrr+N0Ol/4XF6vl4aGhkBHlNvtDhwzDIOFCxeyZMkSMjIyiIuLe+naRUREZOI0R1MkdCmUEhGZpdITojhQ6PQ/NRzhLs0w4ECBc1benHV2dnLs2DFM0yQnJ4dVq1Y99zn6+/upqamhqqqKmpoaBgYGAsesVivp6elkZmayePFizYcSEREJIs3RFAldCqVERGaxj4rzAP/TQYthYBj+JXum6Q+kho7PJoODgxw+fJi+vj4WLFjA1q1bJzzYvLOzk4cPH1JdXU19fT3mUze3UVFRZGRkkJGRgdPpJCxMl1AREZGZQHM0RUKX7qhFRGYxm9XCx++u5IOiLA5drafF3U9STAT78lNnZYeUaZqcPHkSl8tFVFQUb7311pjhkWmaNDc3B5bluVyuYcfj4uICy/IWLlw4Zbv2iYiIyIub0BxNn4k9bJwXici0UyglIjIHOOOj5kS7ellZGZWVlVgsFnbt2oXdbn/mNV6vl/r6eqqqqqiurqa7uztwzDAMkpOTA4PKY2Njp7F6EREReRETmaPpM036Ks5xal4zBQUFOByOaapORMaiUEpEREJWbWtPoAPM6unBWneV2DDYsmULycnJgdf19fVRXV1NdXU1NTU1DA4OBo7ZbDbS09MDS/MiIyOD8VFERETkBY03RxNMltBIc3U5lz1uKioqWL58OQUFBSM+wBKR6aNQSkREQs6g1+ff+vmpWVlenw+TVLak2fjbnFw6OjoCy/IaGxuHzYeKjo4mIyODzMxMUlNTNR9KREQkxI01R7N45ULWmJ00NThpbm6mp6cHr9dLeXk5r7zyCmvXriU6OjrIn0BkbtJduIiIhJwPD93yPw0F/047JoB/3tPZOg/v/90hiqIbh31PQkICGRkZLFmyhKSkJM2HEhERmUXGm6M5OJjPuXPnuHv3Lt3d3bS1tRETE8PNmze5c+cOeXl5rFmzRjvqikwzhVIiIhJSalw9HCytHXWDHRO43BrOmkgbry5eGOiI0uwIERGR2W+0OZo2m41t27aRmprKt99+y8DAAF6vl8jISPr6+rh+/Tq3b99mxYoVrF69mnnz5gWhepG5R6GUiIiElG+u1WMxDH+H1CgshsG83DfY95Pl01iZiIiIzHQ5OTksWLCAY8eO4XK56O3txel00t/fT3NzM1evXuXWrVusXLmS/Px8zZoUmWKWYBcgIiLyPFrc/Yy38s5iGLT3eqenIBEREQkpcXFxvPfee+Tl5WEYBnV1dVgsFrZu3UpSUhKDg4OUlZXxySefUFpaSn9/f7BLFpm11CklIiIhJdEeMcrOOv/KZ5ok2iOmpyAREREJOWFhYWzZsoW0tDROnTrF48ePaW9vZ9u2bQBcunQJl8vFpUuXuH79Ovn5+axcuZLw8PAgVy4yu6hTSkREQsq+/FR846RSpgnFq1OnqSIREREJVUuXLmX//v0sWLCA/v5+jhw5QkNDA++99x47d+4kLi6O/v5+Ll68yCeffMKVK1cYHBwMdtkis4ZCKRERCSnpCVEcKHSOuoTPMOBAoRNnvHbPERERkfE5HA7eeecdVq1aBcD169f56quvSEpK4sCBA7z55pvExsbS19fH+fPn+eSTT7h27RoejyfIlYuEPoVSIiIScj4qzuNAgRMDsBoGYRYDiwEGcKDAyUfFecEuUUREREKI1Wpl06ZN7N69m8jISJqbm/n888+pqqpi2bJlvP/++2zfvh2Hw0Fvby/ff/89n3zyCTdu3MDr1RxLkRdlmOZ4kzmgs7OT+fPn09HRoS21RURmsZf5fR+Ma0Vtaw+HrtbT4u4nKSaCffmp6pASEZlioXatEHlebrebY8eO0dTUBEBeXh4bN24kLCwMr9dLRUUFly9fpqurCwC73c7atWtZvnw5Vqs1mKUP8/R9UqI9guLVuk+S6TPR3/cKpUREJEB/aIiIyHh0rZC5wOfzcenSJcrKygBISEgIzJgC8Hq93L17l8uXL9Pd3Q1ATEwMBQUF5OTkBDWcGvT6+PDQLQ6W1mIxDAzDP2/TZ5ocKPR3lNusWjQlU2uiv+/1/0QRERERERGRp1gsFtavX8/evXuZN28eLpeLL774gvLycsC/3G9+yhI6UjdwZ14el3sTqW3r5fTp03z22WeUl5fj8/mCUvuHh25x8HItJuA1TTw+E69pYgIHL9fy4aFbQalLZCRhwS5AREREREREZCZKT09n//79HD9+nPr6ek6ePMmj2jpOtSfyeVn9U51Idk6bdtY4ethqPuHkyZOUlZWxbt06li5disUyPf0gNa4eDpb6A6mRmCYcLK3lg6IsLeWTGUGhlIiIiIiIiMgooqOjefvttykrK6O0tJR/vNDCze4+TAy8psnTCdDVrigSEpez3vqQ9vZ2SkpKiIuL47XXXmPJkiUYo20fPAbTNPF4PAwODuLxeMb89/urrsByvdFYDINDV+v51fbsF/hpiEwuhVIiIiIiIiIiY7BYLBQWFmJGJ/Cbf7qDf8/fZ5kmHK/q5d/sf532+kru3r1LW1sbDx48wG63k5WVRUJCwqih0kjB00R29zNNk4GBAa62xmH6EsEYvTPLMKDF3f+iPwqRSaVQSkRERERERGQCLjZ6sRoG3jE6kQxM/vORMjbM7yAiIgK3243L5aKpqYkHDx4QGRnJggULiImJGfZ97Z4w7nZH0+2zEm2B5dH9xIYND6SsVis2m42wMP+f8t3d3bjdbrq6uhgYGMBqRPhTpzH4TJNEe8SL/QBEJplCKREREREREZEJaHH3+5fgjbU+zjRp6uih3WzH4XCQlZXFqlWraGlpob6+Hp/PR29vL/PmzePVV18laeEi/nNpG0fudWIx/MvrfKbJ951xvJO/iA/35BAVGYFhGDx58oS6ujpqa2t5/PgxpmkSHR1NdHQ0FouFrNhF3Lw+dihlmlC8OnWSfzIiL0ahlIiIiIiIiMgEJNojxsyjADAMFjmiiJ0fC0BnZyednZ1ER0ezevVqOjs7efz4MQAVFRX81+s9XGy2AuAz/Z1MQ7661oTb3cW+lB7q6+sZGBgY9lZxcXGkp6fjdDpJSUnBZrNRFX7Dv/veCHUaBhwocGrIucwYCqVEREREREREJmBffiq/PX5vnFcZ/PufbcQ20MmTJ09obm6mvb2d7u5uuru7AQgPD6elpYUmt4cL4YtHG1GFCRx74Ca9u57YMA+RkZGkpaXhdDpJT0/Hbrc/8z0fFecB/l32hnYH9JkmpukPpIaOi8wEEwqlzL9ErJ2dnVNajIiIBNfQ73lz3EeAz9K1QkRkbtC1QuayWBu8k7+Ir641MdJ/AQb+48tSE4AEMjMzARgcHKSlpYWWlhaam5tpaWnB4/FQbo3F6GXEcz19Tpd9CQe2LiExMTGwg5/P5xv1v6Vfv5nBLwoXcfjWE1zdAyTYw9n96gLSYiPp7XbT+zI/BJEJmOi1wjAncDWpq6vD6XROTmUiIjLj1dbWkpaW9lzfo2uFiMjcomuFzFkWK/Fv/o/YV+0E0+f/Z1jAsOC+fozW478D3/g75gHE7fh3xOTvwrDaRn2N6R2k69pR2k78l8n6BCLTZrxrxYRCKZ/PR0NDAzExMYFUVkREZh/TNOnq6iIlJQWLZfSthEeia4WIyNyga4WIiIxnoteKCYVSIiIiIiIiIiIik+n5Hm2IiIiIiIiIiIhMAoVSIiIiIiIiIiIy7RRKiYiIiIiIiIjItFMoJSIiIiIiIiIi006hlIiIiIiIiIiITDuFUiIiIiIiIiIiMu0USomIiIiIiIiIyLT7/wGDLl3rwBNmmwAAAABJRU5ErkJggg==\n"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "2JJ-npiM72zQ"
      },
      "source": [
        "## Model (CAMTokenFiLM + multichannel + bilinear head)"
      ],
      "id": "2JJ-npiM72zQ"
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "ngB-sqf472zR"
      },
      "source": [
        "\n",
        "import torch, torch.nn as nn, torch.nn.functional as F\n",
        "\n",
        "class TokenFiLMBlock(nn.Module):\n",
        "    \"\"\"\n",
        "    Compact FiLM block with learnable tokens:\n",
        "      - tokens attend to nodes (summary)\n",
        "      - nodes attend to tokens (conditioning)\n",
        "      - FiLM modulation: y = LN(x) * gamma + beta\n",
        "    \"\"\"\n",
        "    def __init__(self, embed_size, num_tokens, num_heads, dropout=0.1):\n",
        "        super().__init__()\n",
        "        self.E = embed_size\n",
        "        self.num_tokens = num_tokens\n",
        "        self.tokens = nn.Parameter(torch.randn(num_tokens, embed_size) * 0.02)\n",
        "        self.to_tokens = nn.MultiheadAttention(embed_size, num_heads, batch_first=True, dropout=dropout)\n",
        "        self.from_tokens = nn.MultiheadAttention(embed_size, num_heads, batch_first=True, dropout=dropout)\n",
        "        self.ln_nodes = nn.LayerNorm(embed_size)\n",
        "        self.ln_tok = nn.LayerNorm(embed_size)\n",
        "        self.gamma_mlp = nn.Sequential(\n",
        "            nn.Linear(embed_size, embed_size), nn.ReLU(), nn.Linear(embed_size, embed_size)\n",
        "        )\n",
        "        self.beta_mlp  = nn.Sequential(\n",
        "            nn.Linear(embed_size, embed_size), nn.ReLU(), nn.Linear(embed_size, embed_size)\n",
        "        )\n",
        "        nn.init.xavier_uniform_(self.gamma_mlp[0].weight); nn.init.zeros_(self.gamma_mlp[0].bias)\n",
        "        nn.init.xavier_uniform_(self.gamma_mlp[2].weight); nn.init.zeros_(self.gamma_mlp[2].bias)\n",
        "        nn.init.xavier_uniform_(self.beta_mlp[0].weight);  nn.init.zeros_(self.beta_mlp[0].bias)\n",
        "        nn.init.xavier_uniform_(self.beta_mlp[2].weight);  nn.init.zeros_(self.beta_mlp[2].bias)\n",
        "\n",
        "    def forward(self, x):  # x: (B,N,E)\n",
        "        B, N, E = x.shape\n",
        "        tok = self.tokens.unsqueeze(0).expand(B, -1, -1)   # (B,T,E)\n",
        "        # tokens <- nodes\n",
        "        tok,_ = self.to_tokens(query=self.ln_tok(tok), key=self.ln_nodes(x), value=self.ln_nodes(x))\n",
        "\n",
        "        # FiLM\n",
        "        t_pool = tok.mean(dim=1)                 # (B,E)\n",
        "        gamma = self.gamma_mlp(t_pool).unsqueeze(1)  # (B,1,E)\n",
        "        beta  = self.beta_mlp(t_pool).unsqueeze(1)   # (B,1,E)\n",
        "        return self.ln_nodes(x) * (1.0 + gamma) + beta\n"
      ],
      "id": "ngB-sqf472zR",
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "CyMJZvB172zR"
      },
      "source": [
        "\n",
        "import math\n",
        "import torch\n",
        "import torch.nn as nn\n",
        "import torch.nn.functional as F\n",
        "\n",
        "class MultiChannelRescal(nn.Module):\n",
        "    def __init__(self, embed_size: int, n_channels: int):\n",
        "        super().__init__()\n",
        "        self.E = embed_size\n",
        "        self.C = n_channels\n",
        "        self.norms = nn.ModuleList([nn.LayerNorm(embed_size) for _ in range(n_channels)])\n",
        "        self.alpha_raw = nn.Parameter(torch.zeros(n_channels))\n",
        "        self.sp = nn.Softplus()\n",
        "        self.proj = nn.Linear(embed_size * n_channels, embed_size)\n",
        "        nn.init.xavier_uniform_(self.proj.weight); nn.init.zeros_(self.proj.bias)\n",
        "    def forward(self, channels):\n",
        "        assert len(channels) == self.C\n",
        "        w = self.sp(self.alpha_raw)\n",
        "        outs = [ self.norms[k](x) * w[k] for k, x in enumerate(channels) ]\n",
        "        return self.proj(torch.cat(outs, dim=-1))\n",
        "\n",
        "class BilinearHead(nn.Module):\n",
        "    def __init__(self, dim: int, channels: int = 8, mode: str = \"hadamard\"):\n",
        "        super().__init__()\n",
        "        self.E = dim\n",
        "        self.C = channels\n",
        "        self.mode = mode\n",
        "        self.ln = nn.LayerNorm(dim)\n",
        "        if mode == \"hadamard\":\n",
        "            self.c = nn.Parameter(torch.randn(channels, dim) * 0.02)\n",
        "            self.w = nn.Parameter(torch.zeros(dim))\n",
        "            nn.init.xavier_uniform_(self.w.unsqueeze(0))\n",
        "        elif mode == \"rescal\":\n",
        "            self.R = nn.Parameter(torch.randn(channels, dim, dim) * (1.0 / math.sqrt(dim)))\n",
        "        else:\n",
        "            raise ValueError(\"mode must be 'hadamard' or 'rescal'\")\n",
        "        init_tau = 1.0 / math.sqrt(dim)\n",
        "        self.log_tau = nn.Parameter(torch.tensor(math.log(init_tau)))\n",
        "        self.alpha = nn.Parameter(torch.tensor(1.0))\n",
        "        self.beta  = nn.Parameter(torch.tensor(0.0))\n",
        "        self.sp = nn.Softplus()\n",
        "    def forward(self, p):\n",
        "        B, M, E = p.shape\n",
        "        tau = torch.exp(self.log_tau).clamp(min=1e-6)\n",
        "        if self.mode == \"hadamard\":\n",
        "            pn = self.ln(p)\n",
        "            pc = pn.unsqueeze(2) * self.c.view(1,1,self.C,E)   # (B,M,C,E)\n",
        "            s_c = torch.einsum(\"e,bmce->bmc\", self.w, pc)      # (B,M,C)\n",
        "            s = s_c.sum(dim=-1)                                # (B,M)\n",
        "        else:\n",
        "            s = torch.einsum(\"bme,cee,bmf->bmc\", p, self.R, p).sum(dim=-1)\n",
        "        s = (self.sp(self.alpha) * (s / tau)) + self.beta\n",
        "        return s\n",
        "\n",
        "class GraphLinkPredictorPairVote(nn.Module):\n",
        "    def __init__(self, input_dim, embed_size, num_tokens, num_heads,\n",
        "                 use_two_layers=False, symmetrize=True,\n",
        "                 n_cam=2, pair_dim=None, bilinear_mode=\"hadamard\", bilinear_channels=8):\n",
        "        super().__init__()\n",
        "        self.E = embed_size\n",
        "        self.sym = symmetrize\n",
        "        self.use_two = use_two_layers\n",
        "        self.embed_linear = nn.Linear(input_dim, embed_size)\n",
        "        self.enc1 = nn.TransformerEncoderLayer(d_model=embed_size, nhead=num_heads,\n",
        "                                               batch_first=True, dropout=0.0)\n",
        "        self.enc2 = nn.TransformerEncoderLayer(d_model=embed_size, nhead=num_heads,\n",
        "                                               batch_first=True, dropout=0.0)\n",
        "        self.ln_in  = nn.LayerNorm(embed_size)\n",
        "        self.ln_mid = nn.LayerNorm(embed_size)\n",
        "        self.ln_out = nn.LayerNorm(embed_size)\n",
        "        self.cam_blocks = nn.ModuleList([\n",
        "            TokenFiLMBlock(embed_size, num_tokens, num_heads, dropout=0.1)\n",
        "            for _ in range(n_cam)\n",
        "        ])\n",
        "        self.mc = MultiChannelRescal(embed_size, n_channels=1 + n_cam)\n",
        "        self.post = nn.Linear(embed_size, embed_size)\n",
        "        import torch.nn.init as I\n",
        "        I.xavier_uniform_(self.embed_linear.weight); I.zeros_(self.embed_linear.bias)\n",
        "        I.xavier_uniform_(self.post.weight);         I.zeros_(self.post.bias)\n",
        "        P = pair_dim or embed_size\n",
        "        self.pair_proj = nn.Linear(2 * embed_size, P)\n",
        "        I.xavier_uniform_(self.pair_proj.weight);    I.zeros_(self.pair_proj.bias)\n",
        "        self.bilinear = BilinearHead(dim=P, channels=bilinear_channels, mode=bilinear_mode)\n",
        "    def _prep_inputs(self, x):\n",
        "        B, N, _ = x.shape\n",
        "        x0 = F.layer_norm(x[:, :, [0]], (N, 1))\n",
        "        x1 = F.layer_norm(x[:, :, [1]], (N, 1))\n",
        "        x2 = F.layer_norm(x[:, :, [2]], (N, 1))\n",
        "        x3 = F.layer_norm(x[:, :, [3,4,5,6]], (N, 4))\n",
        "        return torch.cat([x0, x1, x2, x3], dim=-1)\n",
        "    def forward(self, node_features):\n",
        "        B, N, _ = node_features.shape\n",
        "        x = self._prep_inputs(node_features)\n",
        "        h = self.embed_linear(x)\n",
        "        h = self.ln_in(h)\n",
        "        h = self.enc1(h) + h\n",
        "        if self.use_two:\n",
        "            h = self.ln_mid(h); h = self.enc2(h) + h\n",
        "        chans = [h]; h_cam = h\n",
        "        for cam in self.cam_blocks:\n",
        "            h_cam = cam(h_cam); chans.append(h_cam)\n",
        "        h = self.mc(chans)\n",
        "        h = self.ln_out(self.post(h))                      # (B,N,E)\n",
        "        hi = h.unsqueeze(2).expand(B, N, N, self.E)\n",
        "        hj = h.unsqueeze(1).expand(B, N, N, self.E)\n",
        "        pair = torch.cat([hi, hj], dim=-1).reshape(B, N*N, 2*self.E)\n",
        "        p = self.pair_proj(pair)                           # (B,N*N,P)\n",
        "        s = self.bilinear(p).reshape(B, N, N)              # logits\n",
        "        if self.sym:\n",
        "            s = 0.5 * (s + s.transpose(1, 2))\n",
        "        eye = torch.eye(N, dtype=torch.bool, device=s.device).unsqueeze(0)\n",
        "        s = s.masked_fill(eye, float(\"-inf\"))\n",
        "        return s\n"
      ],
      "id": "CyMJZvB172zR",
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "Icu1oacQ72zR"
      },
      "source": [
        "\n",
        "# === Convert (pos,A,dde) -> (N,7) ===\n",
        "import torch\n",
        "from torch.utils.data import Dataset, DataLoader, random_split\n",
        "\n",
        "def _reduce_to_4_sectors(H_sectors):\n",
        "    A = H_sectors.shape[0]\n",
        "    if A == 4:\n",
        "        return H_sectors\n",
        "    splits = torch.linspace(0, A, steps=5, dtype=torch.int64)\n",
        "    return torch.stack([H_sectors[splits[k]:splits[k+1]].sum() for k in range(4)], dim=0)\n",
        "\n",
        "class TopoDataset7D(Dataset):\n",
        "    def __init__(self, blob):\n",
        "        self.pos = blob[\"pos\"].float()\n",
        "        self.A   = blob[\"A\"].bool()\n",
        "        self.H   = blob[\"dde\"].float()\n",
        "    def __len__(self): return self.pos.shape[0]\n",
        "    def __getitem__(self, i):\n",
        "        pos = self.pos[i]; A = self.A[i]; H = self.H[i]\n",
        "        N = pos.shape[0]\n",
        "        deg = A.sum(dim=-1).float()\n",
        "        sector_counts = H.sum(dim=1)  # (N, A)\n",
        "        sector4 = torch.stack([_reduce_to_4_sectors(sector_counts[n]) for n in range(N)], dim=0)  # (N,4)\n",
        "        x3 = torch.stack([pos[:,0], pos[:,1], deg], dim=-1)\n",
        "        feats = torch.cat([x3, sector4], dim=-1)  # (N,7)\n",
        "        return feats, A\n"
      ],
      "id": "Icu1oacQ72zR",
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 1000
        },
        "id": "BR1QhvMc72zR",
        "outputId": "99ec8b2b-a2fc-4392-b749-bfdea2b30052"
      },
      "source": [
        "\n",
        "# === Train TopoFormer ===\n",
        "import torch, torch.nn.functional as F\n",
        "from torch.utils.data import DataLoader, random_split\n",
        "\n",
        "blob = torch.load(\"./synth_100.pt\", map_location=\"cpu\")\n",
        "ds = TopoDataset7D(blob)\n",
        "N = ds.pos.shape[1]\n",
        "tr, va = random_split(ds, [int(len(ds)*0.9), len(ds) - int(len(ds)*0.9)],\n",
        "                      generator=torch.Generator().manual_seed(0))\n",
        "dl_tr = DataLoader(tr, batch_size=32, shuffle=True)\n",
        "dl_va = DataLoader(va, batch_size=32, shuffle=False)\n",
        "\n",
        "device = torch.device(\"cuda\" if torch.cuda.is_available() else \"cpu\")\n",
        "model = GraphLinkPredictorPairVote(\n",
        "    input_dim=7, embed_size=32, num_tokens=16, num_heads=8,\n",
        "    use_two_layers=False, symmetrize=True,\n",
        "    n_cam=1, pair_dim=64, bilinear_mode=\"hadamard\", bilinear_channels=8\n",
        ").to(device)\n",
        "opt = torch.optim.AdamW(model.parameters(), lr=1e-4)\n",
        "\n",
        "iu = torch.triu_indices(N, N, 1, device=device)\n",
        "for ep in range(1, 1000):\n",
        "    model.train(); total=0.0\n",
        "    for x, A in dl_tr:\n",
        "        x = x.to(device); A = A.to(device)\n",
        "        logits = model(x)\n",
        "        y = A[:, iu[0], iu[1]].float(); p = logits[:, iu[0], iu[1]]\n",
        "        loss = F.binary_cross_entropy_with_logits(p, y)\n",
        "        opt.zero_grad(); loss.backward(); opt.step()\n",
        "        total += float(loss.item()) * x.size(0)\n",
        "    tr_loss = total/len(tr)\n",
        "\n",
        "    model.eval(); total=0.0\n",
        "    with torch.no_grad():\n",
        "        for x, A in dl_va:\n",
        "            x = x.to(device); A = A.to(device)\n",
        "            logits = model(x)\n",
        "            y = A[:, iu[0], iu[1]].float(); p = logits[:, iu[0], iu[1]]\n",
        "            loss = F.binary_cross_entropy_with_logits(p, y)\n",
        "            total += float(loss.item()) * x.size(0)\n",
        "    va_loss = total/len(va)\n",
        "    print(f\"Epoch {ep:03d} | train_bce {tr_loss:.4f} | val_bce {va_loss:.4f}\")\n"
      ],
      "id": "BR1QhvMc72zR",
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Epoch 001 | train_bce 0.5996 | val_bce 0.5430\n",
            "Epoch 002 | train_bce 0.5256 | val_bce 0.5025\n",
            "Epoch 003 | train_bce 0.5028 | val_bce 0.5004\n",
            "Epoch 004 | train_bce 0.5027 | val_bce 0.5015\n",
            "Epoch 005 | train_bce 0.4998 | val_bce 0.4957\n",
            "Epoch 006 | train_bce 0.4919 | val_bce 0.4878\n",
            "Epoch 007 | train_bce 0.4850 | val_bce 0.4820\n",
            "Epoch 008 | train_bce 0.4812 | val_bce 0.4787\n",
            "Epoch 009 | train_bce 0.4788 | val_bce 0.4758\n",
            "Epoch 010 | train_bce 0.4759 | val_bce 0.4724\n",
            "Epoch 011 | train_bce 0.4729 | val_bce 0.4693\n",
            "Epoch 012 | train_bce 0.4708 | val_bce 0.4667\n",
            "Epoch 013 | train_bce 0.4689 | val_bce 0.4645\n",
            "Epoch 014 | train_bce 0.4668 | val_bce 0.4626\n",
            "Epoch 015 | train_bce 0.4645 | val_bce 0.4611\n",
            "Epoch 016 | train_bce 0.4625 | val_bce 0.4596\n",
            "Epoch 017 | train_bce 0.4607 | val_bce 0.4578\n",
            "Epoch 018 | train_bce 0.4587 | val_bce 0.4555\n",
            "Epoch 019 | train_bce 0.4565 | val_bce 0.4531\n",
            "Epoch 020 | train_bce 0.4544 | val_bce 0.4507\n",
            "Epoch 021 | train_bce 0.4524 | val_bce 0.4483\n",
            "Epoch 022 | train_bce 0.4503 | val_bce 0.4459\n",
            "Epoch 023 | train_bce 0.4481 | val_bce 0.4437\n",
            "Epoch 024 | train_bce 0.4459 | val_bce 0.4413\n",
            "Epoch 025 | train_bce 0.4437 | val_bce 0.4388\n",
            "Epoch 026 | train_bce 0.4415 | val_bce 0.4363\n",
            "Epoch 027 | train_bce 0.4392 | val_bce 0.4338\n",
            "Epoch 028 | train_bce 0.4371 | val_bce 0.4312\n",
            "Epoch 029 | train_bce 0.4348 | val_bce 0.4286\n",
            "Epoch 030 | train_bce 0.4325 | val_bce 0.4261\n",
            "Epoch 031 | train_bce 0.4302 | val_bce 0.4235\n",
            "Epoch 032 | train_bce 0.4280 | val_bce 0.4208\n",
            "Epoch 033 | train_bce 0.4256 | val_bce 0.4183\n",
            "Epoch 034 | train_bce 0.4233 | val_bce 0.4157\n",
            "Epoch 035 | train_bce 0.4211 | val_bce 0.4130\n",
            "Epoch 036 | train_bce 0.4188 | val_bce 0.4104\n",
            "Epoch 037 | train_bce 0.4166 | val_bce 0.4078\n",
            "Epoch 038 | train_bce 0.4142 | val_bce 0.4052\n",
            "Epoch 039 | train_bce 0.4121 | val_bce 0.4026\n",
            "Epoch 040 | train_bce 0.4099 | val_bce 0.3999\n",
            "Epoch 041 | train_bce 0.4076 | val_bce 0.3973\n",
            "Epoch 042 | train_bce 0.4054 | val_bce 0.3948\n",
            "Epoch 043 | train_bce 0.4032 | val_bce 0.3922\n",
            "Epoch 044 | train_bce 0.4010 | val_bce 0.3895\n",
            "Epoch 045 | train_bce 0.3989 | val_bce 0.3869\n",
            "Epoch 046 | train_bce 0.3967 | val_bce 0.3843\n",
            "Epoch 047 | train_bce 0.3946 | val_bce 0.3816\n",
            "Epoch 048 | train_bce 0.3925 | val_bce 0.3791\n",
            "Epoch 049 | train_bce 0.3904 | val_bce 0.3767\n",
            "Epoch 050 | train_bce 0.3884 | val_bce 0.3741\n",
            "Epoch 051 | train_bce 0.3863 | val_bce 0.3715\n",
            "Epoch 052 | train_bce 0.3842 | val_bce 0.3690\n",
            "Epoch 053 | train_bce 0.3821 | val_bce 0.3663\n",
            "Epoch 054 | train_bce 0.3801 | val_bce 0.3638\n",
            "Epoch 055 | train_bce 0.3781 | val_bce 0.3613\n",
            "Epoch 056 | train_bce 0.3759 | val_bce 0.3590\n",
            "Epoch 057 | train_bce 0.3738 | val_bce 0.3564\n",
            "Epoch 058 | train_bce 0.3716 | val_bce 0.3538\n",
            "Epoch 059 | train_bce 0.3695 | val_bce 0.3515\n",
            "Epoch 060 | train_bce 0.3672 | val_bce 0.3493\n",
            "Epoch 061 | train_bce 0.3651 | val_bce 0.3468\n",
            "Epoch 062 | train_bce 0.3629 | val_bce 0.3444\n",
            "Epoch 063 | train_bce 0.3606 | val_bce 0.3424\n",
            "Epoch 064 | train_bce 0.3586 | val_bce 0.3401\n",
            "Epoch 065 | train_bce 0.3563 | val_bce 0.3379\n",
            "Epoch 066 | train_bce 0.3543 | val_bce 0.3361\n",
            "Epoch 067 | train_bce 0.3523 | val_bce 0.3344\n",
            "Epoch 068 | train_bce 0.3503 | val_bce 0.3322\n",
            "Epoch 069 | train_bce 0.3484 | val_bce 0.3305\n",
            "Epoch 070 | train_bce 0.3465 | val_bce 0.3291\n",
            "Epoch 071 | train_bce 0.3448 | val_bce 0.3268\n",
            "Epoch 072 | train_bce 0.3430 | val_bce 0.3253\n",
            "Epoch 073 | train_bce 0.3413 | val_bce 0.3241\n",
            "Epoch 074 | train_bce 0.3398 | val_bce 0.3231\n",
            "Epoch 075 | train_bce 0.3381 | val_bce 0.3212\n",
            "Epoch 076 | train_bce 0.3363 | val_bce 0.3200\n",
            "Epoch 077 | train_bce 0.3348 | val_bce 0.3184\n",
            "Epoch 078 | train_bce 0.3332 | val_bce 0.3168\n",
            "Epoch 079 | train_bce 0.3314 | val_bce 0.3160\n",
            "Epoch 080 | train_bce 0.3297 | val_bce 0.3149\n",
            "Epoch 081 | train_bce 0.3282 | val_bce 0.3133\n",
            "Epoch 082 | train_bce 0.3263 | val_bce 0.3117\n",
            "Epoch 083 | train_bce 0.3246 | val_bce 0.3104\n",
            "Epoch 084 | train_bce 0.3228 | val_bce 0.3092\n",
            "Epoch 085 | train_bce 0.3208 | val_bce 0.3080\n",
            "Epoch 086 | train_bce 0.3190 | val_bce 0.3064\n",
            "Epoch 087 | train_bce 0.3169 | val_bce 0.3055\n",
            "Epoch 088 | train_bce 0.3148 | val_bce 0.3031\n",
            "Epoch 089 | train_bce 0.3125 | val_bce 0.3017\n",
            "Epoch 090 | train_bce 0.3102 | val_bce 0.3006\n",
            "Epoch 091 | train_bce 0.3080 | val_bce 0.2990\n",
            "Epoch 092 | train_bce 0.3054 | val_bce 0.2974\n",
            "Epoch 093 | train_bce 0.3028 | val_bce 0.2959\n",
            "Epoch 094 | train_bce 0.3000 | val_bce 0.2939\n",
            "Epoch 095 | train_bce 0.2977 | val_bce 0.2918\n",
            "Epoch 096 | train_bce 0.2950 | val_bce 0.2907\n",
            "Epoch 097 | train_bce 0.2924 | val_bce 0.2891\n",
            "Epoch 098 | train_bce 0.2897 | val_bce 0.2870\n",
            "Epoch 099 | train_bce 0.2867 | val_bce 0.2868\n",
            "Epoch 100 | train_bce 0.2838 | val_bce 0.2837\n",
            "Epoch 101 | train_bce 0.2808 | val_bce 0.2827\n",
            "Epoch 102 | train_bce 0.2779 | val_bce 0.2811\n",
            "Epoch 103 | train_bce 0.2754 | val_bce 0.2792\n",
            "Epoch 104 | train_bce 0.2731 | val_bce 0.2783\n",
            "Epoch 105 | train_bce 0.2708 | val_bce 0.2773\n",
            "Epoch 106 | train_bce 0.2688 | val_bce 0.2746\n",
            "Epoch 107 | train_bce 0.2661 | val_bce 0.2747\n",
            "Epoch 108 | train_bce 0.2632 | val_bce 0.2711\n",
            "Epoch 109 | train_bce 0.2609 | val_bce 0.2706\n",
            "Epoch 110 | train_bce 0.2584 | val_bce 0.2690\n",
            "Epoch 111 | train_bce 0.2562 | val_bce 0.2677\n",
            "Epoch 112 | train_bce 0.2543 | val_bce 0.2659\n",
            "Epoch 113 | train_bce 0.2523 | val_bce 0.2652\n",
            "Epoch 114 | train_bce 0.2499 | val_bce 0.2635\n",
            "Epoch 115 | train_bce 0.2483 | val_bce 0.2621\n",
            "Epoch 116 | train_bce 0.2460 | val_bce 0.2608\n",
            "Epoch 117 | train_bce 0.2440 | val_bce 0.2593\n",
            "Epoch 118 | train_bce 0.2421 | val_bce 0.2585\n",
            "Epoch 119 | train_bce 0.2402 | val_bce 0.2565\n",
            "Epoch 120 | train_bce 0.2378 | val_bce 0.2556\n",
            "Epoch 121 | train_bce 0.2360 | val_bce 0.2550\n",
            "Epoch 122 | train_bce 0.2343 | val_bce 0.2544\n",
            "Epoch 123 | train_bce 0.2326 | val_bce 0.2532\n",
            "Epoch 124 | train_bce 0.2311 | val_bce 0.2524\n",
            "Epoch 125 | train_bce 0.2296 | val_bce 0.2521\n",
            "Epoch 126 | train_bce 0.2281 | val_bce 0.2512\n",
            "Epoch 127 | train_bce 0.2278 | val_bce 0.2516\n",
            "Epoch 128 | train_bce 0.2256 | val_bce 0.2495\n",
            "Epoch 129 | train_bce 0.2252 | val_bce 0.2502\n",
            "Epoch 130 | train_bce 0.2243 | val_bce 0.2472\n",
            "Epoch 131 | train_bce 0.2231 | val_bce 0.2523\n",
            "Epoch 132 | train_bce 0.2211 | val_bce 0.2483\n",
            "Epoch 133 | train_bce 0.2209 | val_bce 0.2473\n",
            "Epoch 134 | train_bce 0.2193 | val_bce 0.2469\n",
            "Epoch 135 | train_bce 0.2178 | val_bce 0.2451\n",
            "Epoch 136 | train_bce 0.2164 | val_bce 0.2485\n",
            "Epoch 137 | train_bce 0.2163 | val_bce 0.2461\n",
            "Epoch 138 | train_bce 0.2165 | val_bce 0.2457\n",
            "Epoch 139 | train_bce 0.2129 | val_bce 0.2437\n",
            "Epoch 140 | train_bce 0.2106 | val_bce 0.2449\n",
            "Epoch 141 | train_bce 0.2116 | val_bce 0.2424\n",
            "Epoch 142 | train_bce 0.2086 | val_bce 0.2448\n",
            "Epoch 143 | train_bce 0.2088 | val_bce 0.2415\n",
            "Epoch 144 | train_bce 0.2082 | val_bce 0.2436\n",
            "Epoch 145 | train_bce 0.2073 | val_bce 0.2406\n",
            "Epoch 146 | train_bce 0.2078 | val_bce 0.2393\n",
            "Epoch 147 | train_bce 0.2063 | val_bce 0.2409\n",
            "Epoch 148 | train_bce 0.2033 | val_bce 0.2383\n",
            "Epoch 149 | train_bce 0.2030 | val_bce 0.2411\n",
            "Epoch 150 | train_bce 0.2038 | val_bce 0.2382\n",
            "Epoch 151 | train_bce 0.2019 | val_bce 0.2421\n",
            "Epoch 152 | train_bce 0.2002 | val_bce 0.2367\n",
            "Epoch 153 | train_bce 0.1988 | val_bce 0.2371\n",
            "Epoch 154 | train_bce 0.1974 | val_bce 0.2363\n",
            "Epoch 155 | train_bce 0.1963 | val_bce 0.2369\n",
            "Epoch 156 | train_bce 0.1958 | val_bce 0.2338\n",
            "Epoch 157 | train_bce 0.1943 | val_bce 0.2351\n",
            "Epoch 158 | train_bce 0.1934 | val_bce 0.2352\n",
            "Epoch 159 | train_bce 0.1927 | val_bce 0.2358\n",
            "Epoch 160 | train_bce 0.1927 | val_bce 0.2329\n",
            "Epoch 161 | train_bce 0.1920 | val_bce 0.2330\n",
            "Epoch 162 | train_bce 0.1908 | val_bce 0.2351\n",
            "Epoch 163 | train_bce 0.1898 | val_bce 0.2319\n",
            "Epoch 164 | train_bce 0.1890 | val_bce 0.2332\n",
            "Epoch 165 | train_bce 0.1884 | val_bce 0.2322\n",
            "Epoch 166 | train_bce 0.1884 | val_bce 0.2316\n",
            "Epoch 167 | train_bce 0.1872 | val_bce 0.2321\n",
            "Epoch 168 | train_bce 0.1875 | val_bce 0.2297\n",
            "Epoch 169 | train_bce 0.1860 | val_bce 0.2350\n",
            "Epoch 170 | train_bce 0.1853 | val_bce 0.2288\n",
            "Epoch 171 | train_bce 0.1848 | val_bce 0.2309\n",
            "Epoch 172 | train_bce 0.1838 | val_bce 0.2323\n",
            "Epoch 173 | train_bce 0.1831 | val_bce 0.2271\n",
            "Epoch 174 | train_bce 0.1832 | val_bce 0.2347\n",
            "Epoch 175 | train_bce 0.1829 | val_bce 0.2296\n",
            "Epoch 176 | train_bce 0.1810 | val_bce 0.2268\n",
            "Epoch 177 | train_bce 0.1805 | val_bce 0.2301\n",
            "Epoch 178 | train_bce 0.1800 | val_bce 0.2289\n",
            "Epoch 179 | train_bce 0.1789 | val_bce 0.2306\n",
            "Epoch 180 | train_bce 0.1781 | val_bce 0.2302\n",
            "Epoch 181 | train_bce 0.1776 | val_bce 0.2249\n",
            "Epoch 182 | train_bce 0.1767 | val_bce 0.2264\n",
            "Epoch 183 | train_bce 0.1758 | val_bce 0.2272\n",
            "Epoch 184 | train_bce 0.1747 | val_bce 0.2257\n",
            "Epoch 185 | train_bce 0.1764 | val_bce 0.2263\n",
            "Epoch 186 | train_bce 0.1738 | val_bce 0.2289\n",
            "Epoch 187 | train_bce 0.1739 | val_bce 0.2257\n",
            "Epoch 188 | train_bce 0.1751 | val_bce 0.2293\n",
            "Epoch 189 | train_bce 0.1742 | val_bce 0.2261\n",
            "Epoch 190 | train_bce 0.1717 | val_bce 0.2250\n",
            "Epoch 191 | train_bce 0.1729 | val_bce 0.2265\n",
            "Epoch 192 | train_bce 0.1714 | val_bce 0.2302\n",
            "Epoch 193 | train_bce 0.1718 | val_bce 0.2246\n",
            "Epoch 194 | train_bce 0.1701 | val_bce 0.2211\n",
            "Epoch 195 | train_bce 0.1704 | val_bce 0.2319\n",
            "Epoch 196 | train_bce 0.1711 | val_bce 0.2242\n",
            "Epoch 197 | train_bce 0.1700 | val_bce 0.2242\n",
            "Epoch 198 | train_bce 0.1680 | val_bce 0.2278\n",
            "Epoch 199 | train_bce 0.1705 | val_bce 0.2256\n",
            "Epoch 200 | train_bce 0.1667 | val_bce 0.2239\n",
            "Epoch 201 | train_bce 0.1661 | val_bce 0.2284\n",
            "Epoch 202 | train_bce 0.1661 | val_bce 0.2212\n",
            "Epoch 203 | train_bce 0.1652 | val_bce 0.2277\n",
            "Epoch 204 | train_bce 0.1648 | val_bce 0.2228\n",
            "Epoch 205 | train_bce 0.1652 | val_bce 0.2225\n",
            "Epoch 206 | train_bce 0.1638 | val_bce 0.2246\n",
            "Epoch 207 | train_bce 0.1634 | val_bce 0.2279\n",
            "Epoch 208 | train_bce 0.1636 | val_bce 0.2202\n",
            "Epoch 209 | train_bce 0.1627 | val_bce 0.2245\n",
            "Epoch 210 | train_bce 0.1613 | val_bce 0.2239\n",
            "Epoch 211 | train_bce 0.1611 | val_bce 0.2214\n",
            "Epoch 212 | train_bce 0.1600 | val_bce 0.2233\n",
            "Epoch 213 | train_bce 0.1598 | val_bce 0.2196\n",
            "Epoch 214 | train_bce 0.1585 | val_bce 0.2275\n",
            "Epoch 215 | train_bce 0.1582 | val_bce 0.2229\n",
            "Epoch 216 | train_bce 0.1578 | val_bce 0.2257\n",
            "Epoch 217 | train_bce 0.1576 | val_bce 0.2228\n",
            "Epoch 218 | train_bce 0.1569 | val_bce 0.2255\n",
            "Epoch 219 | train_bce 0.1564 | val_bce 0.2206\n",
            "Epoch 220 | train_bce 0.1556 | val_bce 0.2207\n",
            "Epoch 221 | train_bce 0.1577 | val_bce 0.2282\n",
            "Epoch 222 | train_bce 0.1560 | val_bce 0.2254\n",
            "Epoch 223 | train_bce 0.1564 | val_bce 0.2224\n",
            "Epoch 224 | train_bce 0.1562 | val_bce 0.2219\n",
            "Epoch 225 | train_bce 0.1548 | val_bce 0.2288\n",
            "Epoch 226 | train_bce 0.1538 | val_bce 0.2223\n",
            "Epoch 227 | train_bce 0.1529 | val_bce 0.2217\n",
            "Epoch 228 | train_bce 0.1532 | val_bce 0.2235\n",
            "Epoch 229 | train_bce 0.1524 | val_bce 0.2294\n",
            "Epoch 230 | train_bce 0.1531 | val_bce 0.2221\n",
            "Epoch 231 | train_bce 0.1529 | val_bce 0.2219\n",
            "Epoch 232 | train_bce 0.1530 | val_bce 0.2288\n",
            "Epoch 233 | train_bce 0.1515 | val_bce 0.2291\n",
            "Epoch 234 | train_bce 0.1527 | val_bce 0.2219\n",
            "Epoch 235 | train_bce 0.1527 | val_bce 0.2212\n",
            "Epoch 236 | train_bce 0.1518 | val_bce 0.2310\n",
            "Epoch 237 | train_bce 0.1512 | val_bce 0.2284\n",
            "Epoch 238 | train_bce 0.1486 | val_bce 0.2186\n",
            "Epoch 239 | train_bce 0.1503 | val_bce 0.2417\n",
            "Epoch 240 | train_bce 0.1552 | val_bce 0.2299\n",
            "Epoch 241 | train_bce 0.1537 | val_bce 0.2207\n",
            "Epoch 242 | train_bce 0.1537 | val_bce 0.2233\n",
            "Epoch 243 | train_bce 0.1534 | val_bce 0.2431\n",
            "Epoch 244 | train_bce 0.1552 | val_bce 0.2206\n",
            "Epoch 245 | train_bce 0.1533 | val_bce 0.2292\n",
            "Epoch 246 | train_bce 0.1519 | val_bce 0.2289\n",
            "Epoch 247 | train_bce 0.1499 | val_bce 0.2186\n",
            "Epoch 248 | train_bce 0.1491 | val_bce 0.2388\n",
            "Epoch 249 | train_bce 0.1502 | val_bce 0.2184\n",
            "Epoch 250 | train_bce 0.1477 | val_bce 0.2308\n",
            "Epoch 251 | train_bce 0.1471 | val_bce 0.2238\n",
            "Epoch 252 | train_bce 0.1457 | val_bce 0.2233\n",
            "Epoch 253 | train_bce 0.1452 | val_bce 0.2276\n",
            "Epoch 254 | train_bce 0.1431 | val_bce 0.2223\n",
            "Epoch 255 | train_bce 0.1433 | val_bce 0.2306\n",
            "Epoch 256 | train_bce 0.1425 | val_bce 0.2199\n",
            "Epoch 257 | train_bce 0.1442 | val_bce 0.2224\n",
            "Epoch 258 | train_bce 0.1422 | val_bce 0.2298\n",
            "Epoch 259 | train_bce 0.1426 | val_bce 0.2223\n",
            "Epoch 260 | train_bce 0.1422 | val_bce 0.2249\n",
            "Epoch 261 | train_bce 0.1405 | val_bce 0.2231\n",
            "Epoch 262 | train_bce 0.1397 | val_bce 0.2213\n",
            "Epoch 263 | train_bce 0.1392 | val_bce 0.2287\n",
            "Epoch 264 | train_bce 0.1395 | val_bce 0.2236\n",
            "Epoch 265 | train_bce 0.1413 | val_bce 0.2238\n",
            "Epoch 266 | train_bce 0.1402 | val_bce 0.2287\n",
            "Epoch 267 | train_bce 0.1399 | val_bce 0.2202\n",
            "Epoch 268 | train_bce 0.1388 | val_bce 0.2267\n",
            "Epoch 269 | train_bce 0.1398 | val_bce 0.2337\n",
            "Epoch 270 | train_bce 0.1419 | val_bce 0.2230\n",
            "Epoch 271 | train_bce 0.1383 | val_bce 0.2256\n",
            "Epoch 272 | train_bce 0.1367 | val_bce 0.2232\n",
            "Epoch 273 | train_bce 0.1361 | val_bce 0.2267\n",
            "Epoch 274 | train_bce 0.1359 | val_bce 0.2238\n",
            "Epoch 275 | train_bce 0.1348 | val_bce 0.2268\n",
            "Epoch 276 | train_bce 0.1350 | val_bce 0.2231\n",
            "Epoch 277 | train_bce 0.1334 | val_bce 0.2267\n",
            "Epoch 278 | train_bce 0.1337 | val_bce 0.2229\n",
            "Epoch 279 | train_bce 0.1335 | val_bce 0.2235\n",
            "Epoch 280 | train_bce 0.1336 | val_bce 0.2278\n",
            "Epoch 281 | train_bce 0.1328 | val_bce 0.2312\n",
            "Epoch 282 | train_bce 0.1329 | val_bce 0.2253\n",
            "Epoch 283 | train_bce 0.1319 | val_bce 0.2279\n",
            "Epoch 284 | train_bce 0.1316 | val_bce 0.2272\n",
            "Epoch 285 | train_bce 0.1311 | val_bce 0.2319\n",
            "Epoch 286 | train_bce 0.1308 | val_bce 0.2243\n",
            "Epoch 287 | train_bce 0.1306 | val_bce 0.2298\n",
            "Epoch 288 | train_bce 0.1298 | val_bce 0.2248\n",
            "Epoch 289 | train_bce 0.1297 | val_bce 0.2303\n",
            "Epoch 290 | train_bce 0.1286 | val_bce 0.2252\n",
            "Epoch 291 | train_bce 0.1292 | val_bce 0.2272\n",
            "Epoch 292 | train_bce 0.1285 | val_bce 0.2282\n",
            "Epoch 293 | train_bce 0.1281 | val_bce 0.2289\n",
            "Epoch 294 | train_bce 0.1276 | val_bce 0.2275\n",
            "Epoch 295 | train_bce 0.1275 | val_bce 0.2274\n",
            "Epoch 296 | train_bce 0.1271 | val_bce 0.2288\n",
            "Epoch 297 | train_bce 0.1275 | val_bce 0.2363\n",
            "Epoch 298 | train_bce 0.1279 | val_bce 0.2286\n",
            "Epoch 299 | train_bce 0.1282 | val_bce 0.2296\n",
            "Epoch 300 | train_bce 0.1273 | val_bce 0.2302\n",
            "Epoch 301 | train_bce 0.1270 | val_bce 0.2422\n",
            "Epoch 302 | train_bce 0.1284 | val_bce 0.2281\n",
            "Epoch 303 | train_bce 0.1295 | val_bce 0.2324\n",
            "Epoch 304 | train_bce 0.1327 | val_bce 0.2268\n",
            "Epoch 305 | train_bce 0.1304 | val_bce 0.2545\n",
            "Epoch 306 | train_bce 0.1335 | val_bce 0.2262\n",
            "Epoch 307 | train_bce 0.1316 | val_bce 0.2333\n",
            "Epoch 308 | train_bce 0.1308 | val_bce 0.2444\n",
            "Epoch 309 | train_bce 0.1296 | val_bce 0.2284\n",
            "Epoch 310 | train_bce 0.1279 | val_bce 0.2334\n",
            "Epoch 311 | train_bce 0.1265 | val_bce 0.2361\n",
            "Epoch 312 | train_bce 0.1259 | val_bce 0.2323\n",
            "Epoch 313 | train_bce 0.1244 | val_bce 0.2288\n",
            "Epoch 314 | train_bce 0.1230 | val_bce 0.2339\n",
            "Epoch 315 | train_bce 0.1220 | val_bce 0.2270\n",
            "Epoch 316 | train_bce 0.1218 | val_bce 0.2317\n",
            "Epoch 317 | train_bce 0.1207 | val_bce 0.2305\n",
            "Epoch 318 | train_bce 0.1200 | val_bce 0.2308\n",
            "Epoch 319 | train_bce 0.1197 | val_bce 0.2342\n",
            "Epoch 320 | train_bce 0.1195 | val_bce 0.2277\n",
            "Epoch 321 | train_bce 0.1189 | val_bce 0.2367\n",
            "Epoch 322 | train_bce 0.1189 | val_bce 0.2296\n",
            "Epoch 323 | train_bce 0.1186 | val_bce 0.2313\n",
            "Epoch 324 | train_bce 0.1185 | val_bce 0.2311\n",
            "Epoch 325 | train_bce 0.1178 | val_bce 0.2336\n",
            "Epoch 326 | train_bce 0.1172 | val_bce 0.2296\n",
            "Epoch 327 | train_bce 0.1168 | val_bce 0.2312\n",
            "Epoch 328 | train_bce 0.1189 | val_bce 0.2332\n",
            "Epoch 329 | train_bce 0.1180 | val_bce 0.2397\n",
            "Epoch 330 | train_bce 0.1189 | val_bce 0.2320\n",
            "Epoch 331 | train_bce 0.1164 | val_bce 0.2297\n",
            "Epoch 332 | train_bce 0.1172 | val_bce 0.2368\n",
            "Epoch 333 | train_bce 0.1155 | val_bce 0.2355\n",
            "Epoch 334 | train_bce 0.1160 | val_bce 0.2329\n",
            "Epoch 335 | train_bce 0.1161 | val_bce 0.2378\n",
            "Epoch 336 | train_bce 0.1152 | val_bce 0.2314\n",
            "Epoch 337 | train_bce 0.1158 | val_bce 0.2301\n",
            "Epoch 338 | train_bce 0.1163 | val_bce 0.2368\n",
            "Epoch 339 | train_bce 0.1165 | val_bce 0.2424\n",
            "Epoch 340 | train_bce 0.1172 | val_bce 0.2336\n",
            "Epoch 341 | train_bce 0.1153 | val_bce 0.2319\n",
            "Epoch 342 | train_bce 0.1141 | val_bce 0.2397\n",
            "Epoch 343 | train_bce 0.1139 | val_bce 0.2337\n",
            "Epoch 344 | train_bce 0.1153 | val_bce 0.2362\n",
            "Epoch 345 | train_bce 0.1138 | val_bce 0.2367\n",
            "Epoch 346 | train_bce 0.1126 | val_bce 0.2323\n",
            "Epoch 347 | train_bce 0.1137 | val_bce 0.2298\n",
            "Epoch 348 | train_bce 0.1133 | val_bce 0.2407\n",
            "Epoch 349 | train_bce 0.1119 | val_bce 0.2359\n",
            "Epoch 350 | train_bce 0.1115 | val_bce 0.2363\n",
            "Epoch 351 | train_bce 0.1107 | val_bce 0.2347\n",
            "Epoch 352 | train_bce 0.1112 | val_bce 0.2403\n",
            "Epoch 353 | train_bce 0.1125 | val_bce 0.2308\n",
            "Epoch 354 | train_bce 0.1105 | val_bce 0.2407\n",
            "Epoch 355 | train_bce 0.1102 | val_bce 0.2410\n",
            "Epoch 356 | train_bce 0.1098 | val_bce 0.2373\n",
            "Epoch 357 | train_bce 0.1087 | val_bce 0.2311\n",
            "Epoch 358 | train_bce 0.1086 | val_bce 0.2412\n",
            "Epoch 359 | train_bce 0.1085 | val_bce 0.2329\n",
            "Epoch 360 | train_bce 0.1093 | val_bce 0.2434\n",
            "Epoch 361 | train_bce 0.1087 | val_bce 0.2335\n",
            "Epoch 362 | train_bce 0.1084 | val_bce 0.2422\n",
            "Epoch 363 | train_bce 0.1097 | val_bce 0.2366\n",
            "Epoch 364 | train_bce 0.1096 | val_bce 0.2422\n",
            "Epoch 365 | train_bce 0.1092 | val_bce 0.2360\n",
            "Epoch 366 | train_bce 0.1085 | val_bce 0.2484\n",
            "Epoch 367 | train_bce 0.1085 | val_bce 0.2360\n",
            "Epoch 368 | train_bce 0.1072 | val_bce 0.2426\n",
            "Epoch 369 | train_bce 0.1097 | val_bce 0.2350\n",
            "Epoch 370 | train_bce 0.1068 | val_bce 0.2485\n",
            "Epoch 371 | train_bce 0.1060 | val_bce 0.2362\n",
            "Epoch 372 | train_bce 0.1039 | val_bce 0.2374\n",
            "Epoch 373 | train_bce 0.1040 | val_bce 0.2398\n",
            "Epoch 374 | train_bce 0.1035 | val_bce 0.2452\n",
            "Epoch 375 | train_bce 0.1039 | val_bce 0.2351\n",
            "Epoch 376 | train_bce 0.1042 | val_bce 0.2419\n",
            "Epoch 377 | train_bce 0.1043 | val_bce 0.2373\n",
            "Epoch 378 | train_bce 0.1025 | val_bce 0.2439\n",
            "Epoch 379 | train_bce 0.1010 | val_bce 0.2392\n",
            "Epoch 380 | train_bce 0.1009 | val_bce 0.2428\n",
            "Epoch 381 | train_bce 0.1008 | val_bce 0.2377\n",
            "Epoch 382 | train_bce 0.1002 | val_bce 0.2450\n",
            "Epoch 383 | train_bce 0.1001 | val_bce 0.2388\n",
            "Epoch 384 | train_bce 0.0994 | val_bce 0.2435\n",
            "Epoch 385 | train_bce 0.0990 | val_bce 0.2384\n",
            "Epoch 386 | train_bce 0.0990 | val_bce 0.2463\n",
            "Epoch 387 | train_bce 0.1001 | val_bce 0.2407\n",
            "Epoch 388 | train_bce 0.1010 | val_bce 0.2500\n",
            "Epoch 389 | train_bce 0.1002 | val_bce 0.2376\n",
            "Epoch 390 | train_bce 0.0992 | val_bce 0.2486\n",
            "Epoch 391 | train_bce 0.1011 | val_bce 0.2412\n",
            "Epoch 392 | train_bce 0.1014 | val_bce 0.2533\n",
            "Epoch 393 | train_bce 0.1021 | val_bce 0.2493\n",
            "Epoch 394 | train_bce 0.0999 | val_bce 0.2437\n",
            "Epoch 395 | train_bce 0.0979 | val_bce 0.2445\n",
            "Epoch 396 | train_bce 0.0974 | val_bce 0.2415\n",
            "Epoch 397 | train_bce 0.0966 | val_bce 0.2453\n",
            "Epoch 398 | train_bce 0.0977 | val_bce 0.2404\n",
            "Epoch 399 | train_bce 0.0961 | val_bce 0.2546\n",
            "Epoch 400 | train_bce 0.0973 | val_bce 0.2433\n",
            "Epoch 401 | train_bce 0.0957 | val_bce 0.2441\n",
            "Epoch 402 | train_bce 0.0964 | val_bce 0.2465\n",
            "Epoch 403 | train_bce 0.0969 | val_bce 0.2554\n",
            "Epoch 404 | train_bce 0.1000 | val_bce 0.2521\n",
            "Epoch 405 | train_bce 0.0978 | val_bce 0.2572\n",
            "Epoch 406 | train_bce 0.1004 | val_bce 0.2464\n",
            "Epoch 407 | train_bce 0.0974 | val_bce 0.2513\n",
            "Epoch 408 | train_bce 0.0999 | val_bce 0.2563\n",
            "Epoch 409 | train_bce 0.0985 | val_bce 0.2565\n",
            "Epoch 410 | train_bce 0.0986 | val_bce 0.2528\n",
            "Epoch 411 | train_bce 0.0963 | val_bce 0.2499\n",
            "Epoch 412 | train_bce 0.0961 | val_bce 0.2586\n",
            "Epoch 413 | train_bce 0.0951 | val_bce 0.2413\n",
            "Epoch 414 | train_bce 0.0940 | val_bce 0.2570\n",
            "Epoch 415 | train_bce 0.0928 | val_bce 0.2424\n",
            "Epoch 416 | train_bce 0.0926 | val_bce 0.2577\n",
            "Epoch 417 | train_bce 0.0939 | val_bce 0.2466\n",
            "Epoch 418 | train_bce 0.0925 | val_bce 0.2513\n",
            "Epoch 419 | train_bce 0.0920 | val_bce 0.2508\n",
            "Epoch 420 | train_bce 0.0919 | val_bce 0.2494\n",
            "Epoch 421 | train_bce 0.0905 | val_bce 0.2467\n",
            "Epoch 422 | train_bce 0.0900 | val_bce 0.2503\n",
            "Epoch 423 | train_bce 0.0921 | val_bce 0.2541\n",
            "Epoch 424 | train_bce 0.0920 | val_bce 0.2513\n",
            "Epoch 425 | train_bce 0.0911 | val_bce 0.2551\n",
            "Epoch 426 | train_bce 0.0903 | val_bce 0.2499\n",
            "Epoch 427 | train_bce 0.0897 | val_bce 0.2546\n",
            "Epoch 428 | train_bce 0.0885 | val_bce 0.2512\n",
            "Epoch 429 | train_bce 0.0879 | val_bce 0.2553\n",
            "Epoch 430 | train_bce 0.0868 | val_bce 0.2490\n",
            "Epoch 431 | train_bce 0.0868 | val_bce 0.2526\n",
            "Epoch 432 | train_bce 0.0866 | val_bce 0.2499\n",
            "Epoch 433 | train_bce 0.0864 | val_bce 0.2521\n",
            "Epoch 434 | train_bce 0.0866 | val_bce 0.2562\n",
            "Epoch 435 | train_bce 0.0874 | val_bce 0.2556\n",
            "Epoch 436 | train_bce 0.0859 | val_bce 0.2536\n",
            "Epoch 437 | train_bce 0.0857 | val_bce 0.2527\n",
            "Epoch 438 | train_bce 0.0849 | val_bce 0.2535\n",
            "Epoch 439 | train_bce 0.0853 | val_bce 0.2536\n",
            "Epoch 440 | train_bce 0.0846 | val_bce 0.2573\n",
            "Epoch 441 | train_bce 0.0848 | val_bce 0.2564\n",
            "Epoch 442 | train_bce 0.0846 | val_bce 0.2563\n",
            "Epoch 443 | train_bce 0.0855 | val_bce 0.2543\n",
            "Epoch 444 | train_bce 0.0842 | val_bce 0.2617\n",
            "Epoch 445 | train_bce 0.0865 | val_bce 0.2637\n",
            "Epoch 446 | train_bce 0.0880 | val_bce 0.2605\n",
            "Epoch 447 | train_bce 0.0886 | val_bce 0.2631\n",
            "Epoch 448 | train_bce 0.0890 | val_bce 0.2631\n",
            "Epoch 449 | train_bce 0.0884 | val_bce 0.2618\n",
            "Epoch 450 | train_bce 0.0874 | val_bce 0.2657\n",
            "Epoch 451 | train_bce 0.0888 | val_bce 0.2649\n",
            "Epoch 452 | train_bce 0.0874 | val_bce 0.2600\n",
            "Epoch 453 | train_bce 0.0888 | val_bce 0.2585\n",
            "Epoch 454 | train_bce 0.0871 | val_bce 0.2815\n",
            "Epoch 455 | train_bce 0.0887 | val_bce 0.2679\n",
            "Epoch 456 | train_bce 0.0876 | val_bce 0.2778\n",
            "Epoch 457 | train_bce 0.0896 | val_bce 0.2594\n",
            "Epoch 458 | train_bce 0.0879 | val_bce 0.2757\n",
            "Epoch 459 | train_bce 0.0946 | val_bce 0.2705\n",
            "Epoch 460 | train_bce 0.0916 | val_bce 0.2775\n",
            "Epoch 461 | train_bce 0.0890 | val_bce 0.2646\n",
            "Epoch 462 | train_bce 0.0908 | val_bce 0.2768\n",
            "Epoch 463 | train_bce 0.0911 | val_bce 0.2764\n",
            "Epoch 464 | train_bce 0.0947 | val_bce 0.2644\n",
            "Epoch 465 | train_bce 0.0913 | val_bce 0.2665\n",
            "Epoch 466 | train_bce 0.0889 | val_bce 0.2884\n",
            "Epoch 467 | train_bce 0.0906 | val_bce 0.2632\n",
            "Epoch 468 | train_bce 0.0880 | val_bce 0.2733\n",
            "Epoch 469 | train_bce 0.0871 | val_bce 0.2592\n",
            "Epoch 470 | train_bce 0.0843 | val_bce 0.2740\n",
            "Epoch 471 | train_bce 0.0840 | val_bce 0.2769\n",
            "Epoch 472 | train_bce 0.0865 | val_bce 0.2688\n",
            "Epoch 473 | train_bce 0.0855 | val_bce 0.2575\n",
            "Epoch 474 | train_bce 0.0820 | val_bce 0.2652\n",
            "Epoch 475 | train_bce 0.0822 | val_bce 0.2594\n",
            "Epoch 476 | train_bce 0.0817 | val_bce 0.2664\n",
            "Epoch 477 | train_bce 0.0788 | val_bce 0.2576\n",
            "Epoch 478 | train_bce 0.0793 | val_bce 0.2599\n",
            "Epoch 479 | train_bce 0.0775 | val_bce 0.2577\n",
            "Epoch 480 | train_bce 0.0774 | val_bce 0.2648\n",
            "Epoch 481 | train_bce 0.0772 | val_bce 0.2619\n",
            "Epoch 482 | train_bce 0.0767 | val_bce 0.2618\n",
            "Epoch 483 | train_bce 0.0770 | val_bce 0.2663\n",
            "Epoch 484 | train_bce 0.0763 | val_bce 0.2624\n",
            "Epoch 485 | train_bce 0.0763 | val_bce 0.2667\n",
            "Epoch 486 | train_bce 0.0765 | val_bce 0.2633\n",
            "Epoch 487 | train_bce 0.0756 | val_bce 0.2702\n",
            "Epoch 488 | train_bce 0.0762 | val_bce 0.2637\n",
            "Epoch 489 | train_bce 0.0752 | val_bce 0.2665\n",
            "Epoch 490 | train_bce 0.0757 | val_bce 0.2656\n",
            "Epoch 491 | train_bce 0.0750 | val_bce 0.2692\n",
            "Epoch 492 | train_bce 0.0743 | val_bce 0.2724\n",
            "Epoch 493 | train_bce 0.0760 | val_bce 0.2726\n",
            "Epoch 494 | train_bce 0.0761 | val_bce 0.2694\n",
            "Epoch 495 | train_bce 0.0766 | val_bce 0.2659\n",
            "Epoch 496 | train_bce 0.0751 | val_bce 0.2744\n",
            "Epoch 497 | train_bce 0.0749 | val_bce 0.2706\n",
            "Epoch 498 | train_bce 0.0741 | val_bce 0.2740\n",
            "Epoch 499 | train_bce 0.0749 | val_bce 0.2723\n",
            "Epoch 500 | train_bce 0.0739 | val_bce 0.2739\n",
            "Epoch 501 | train_bce 0.0761 | val_bce 0.2721\n",
            "Epoch 502 | train_bce 0.0748 | val_bce 0.2693\n",
            "Epoch 503 | train_bce 0.0757 | val_bce 0.2760\n",
            "Epoch 504 | train_bce 0.0748 | val_bce 0.2740\n",
            "Epoch 505 | train_bce 0.0746 | val_bce 0.2757\n",
            "Epoch 506 | train_bce 0.0744 | val_bce 0.2711\n",
            "Epoch 507 | train_bce 0.0725 | val_bce 0.2758\n",
            "Epoch 508 | train_bce 0.0707 | val_bce 0.2738\n",
            "Epoch 509 | train_bce 0.0714 | val_bce 0.2765\n",
            "Epoch 510 | train_bce 0.0718 | val_bce 0.2742\n",
            "Epoch 511 | train_bce 0.0713 | val_bce 0.2797\n",
            "Epoch 512 | train_bce 0.0717 | val_bce 0.2782\n",
            "Epoch 513 | train_bce 0.0711 | val_bce 0.2732\n",
            "Epoch 514 | train_bce 0.0723 | val_bce 0.2772\n",
            "Epoch 515 | train_bce 0.0708 | val_bce 0.2862\n",
            "Epoch 516 | train_bce 0.0726 | val_bce 0.2806\n",
            "Epoch 517 | train_bce 0.0708 | val_bce 0.2809\n",
            "Epoch 518 | train_bce 0.0716 | val_bce 0.2776\n",
            "Epoch 519 | train_bce 0.0711 | val_bce 0.2847\n",
            "Epoch 520 | train_bce 0.0721 | val_bce 0.2827\n",
            "Epoch 521 | train_bce 0.0701 | val_bce 0.2837\n",
            "Epoch 522 | train_bce 0.0697 | val_bce 0.2835\n",
            "Epoch 523 | train_bce 0.0692 | val_bce 0.2882\n",
            "Epoch 524 | train_bce 0.0695 | val_bce 0.2788\n",
            "Epoch 525 | train_bce 0.0712 | val_bce 0.2817\n",
            "Epoch 526 | train_bce 0.0698 | val_bce 0.2813\n",
            "Epoch 527 | train_bce 0.0689 | val_bce 0.2791\n",
            "Epoch 528 | train_bce 0.0680 | val_bce 0.2821\n",
            "Epoch 529 | train_bce 0.0690 | val_bce 0.2878\n",
            "Epoch 530 | train_bce 0.0688 | val_bce 0.2949\n",
            "Epoch 531 | train_bce 0.0714 | val_bce 0.2838\n",
            "Epoch 532 | train_bce 0.0723 | val_bce 0.2843\n",
            "Epoch 533 | train_bce 0.0710 | val_bce 0.3025\n",
            "Epoch 534 | train_bce 0.0709 | val_bce 0.2906\n",
            "Epoch 535 | train_bce 0.0698 | val_bce 0.2898\n",
            "Epoch 536 | train_bce 0.0725 | val_bce 0.2888\n",
            "Epoch 537 | train_bce 0.0718 | val_bce 0.2904\n",
            "Epoch 538 | train_bce 0.0708 | val_bce 0.2908\n",
            "Epoch 539 | train_bce 0.0681 | val_bce 0.2829\n",
            "Epoch 540 | train_bce 0.0723 | val_bce 0.2904\n",
            "Epoch 541 | train_bce 0.0739 | val_bce 0.2960\n",
            "Epoch 542 | train_bce 0.0739 | val_bce 0.2938\n",
            "Epoch 543 | train_bce 0.0721 | val_bce 0.2823\n",
            "Epoch 544 | train_bce 0.0717 | val_bce 0.2953\n",
            "Epoch 545 | train_bce 0.0702 | val_bce 0.2868\n",
            "Epoch 546 | train_bce 0.0692 | val_bce 0.2854\n",
            "Epoch 547 | train_bce 0.0708 | val_bce 0.2939\n",
            "Epoch 548 | train_bce 0.0685 | val_bce 0.2898\n",
            "Epoch 549 | train_bce 0.0664 | val_bce 0.2969\n",
            "Epoch 550 | train_bce 0.0686 | val_bce 0.2861\n",
            "Epoch 551 | train_bce 0.0670 | val_bce 0.2870\n",
            "Epoch 552 | train_bce 0.0656 | val_bce 0.2931\n",
            "Epoch 553 | train_bce 0.0690 | val_bce 0.2930\n",
            "Epoch 554 | train_bce 0.0672 | val_bce 0.3084\n",
            "Epoch 555 | train_bce 0.0691 | val_bce 0.2961\n",
            "Epoch 556 | train_bce 0.0673 | val_bce 0.2967\n",
            "Epoch 557 | train_bce 0.0676 | val_bce 0.2923\n",
            "Epoch 558 | train_bce 0.0665 | val_bce 0.2966\n",
            "Epoch 559 | train_bce 0.0648 | val_bce 0.2928\n",
            "Epoch 560 | train_bce 0.0642 | val_bce 0.2924\n",
            "Epoch 561 | train_bce 0.0649 | val_bce 0.2921\n",
            "Epoch 562 | train_bce 0.0662 | val_bce 0.3019\n",
            "Epoch 563 | train_bce 0.0668 | val_bce 0.2929\n",
            "Epoch 564 | train_bce 0.0677 | val_bce 0.2949\n",
            "Epoch 565 | train_bce 0.0658 | val_bce 0.3059\n",
            "Epoch 566 | train_bce 0.0661 | val_bce 0.2946\n",
            "Epoch 567 | train_bce 0.0651 | val_bce 0.3004\n",
            "Epoch 568 | train_bce 0.0656 | val_bce 0.3088\n",
            "Epoch 569 | train_bce 0.0693 | val_bce 0.2938\n",
            "Epoch 570 | train_bce 0.0646 | val_bce 0.2978\n",
            "Epoch 571 | train_bce 0.0652 | val_bce 0.3025\n",
            "Epoch 572 | train_bce 0.0627 | val_bce 0.2992\n",
            "Epoch 573 | train_bce 0.0625 | val_bce 0.2989\n",
            "Epoch 574 | train_bce 0.0626 | val_bce 0.3028\n",
            "Epoch 575 | train_bce 0.0620 | val_bce 0.3019\n",
            "Epoch 576 | train_bce 0.0630 | val_bce 0.2993\n",
            "Epoch 577 | train_bce 0.0625 | val_bce 0.3006\n",
            "Epoch 578 | train_bce 0.0626 | val_bce 0.3069\n",
            "Epoch 579 | train_bce 0.0629 | val_bce 0.3021\n",
            "Epoch 580 | train_bce 0.0632 | val_bce 0.3031\n",
            "Epoch 581 | train_bce 0.0616 | val_bce 0.3055\n",
            "Epoch 582 | train_bce 0.0610 | val_bce 0.2990\n",
            "Epoch 583 | train_bce 0.0602 | val_bce 0.3019\n",
            "Epoch 584 | train_bce 0.0604 | val_bce 0.3053\n",
            "Epoch 585 | train_bce 0.0601 | val_bce 0.2990\n",
            "Epoch 586 | train_bce 0.0598 | val_bce 0.3049\n",
            "Epoch 587 | train_bce 0.0598 | val_bce 0.3036\n",
            "Epoch 588 | train_bce 0.0596 | val_bce 0.2954\n",
            "Epoch 589 | train_bce 0.0586 | val_bce 0.3091\n",
            "Epoch 590 | train_bce 0.0591 | val_bce 0.3079\n",
            "Epoch 591 | train_bce 0.0590 | val_bce 0.3073\n",
            "Epoch 592 | train_bce 0.0583 | val_bce 0.3086\n",
            "Epoch 593 | train_bce 0.0580 | val_bce 0.3084\n",
            "Epoch 594 | train_bce 0.0574 | val_bce 0.3045\n",
            "Epoch 595 | train_bce 0.0566 | val_bce 0.3082\n",
            "Epoch 596 | train_bce 0.0572 | val_bce 0.3020\n",
            "Epoch 597 | train_bce 0.0576 | val_bce 0.3097\n",
            "Epoch 598 | train_bce 0.0573 | val_bce 0.3078\n",
            "Epoch 599 | train_bce 0.0586 | val_bce 0.3167\n",
            "Epoch 600 | train_bce 0.0579 | val_bce 0.3075\n",
            "Epoch 601 | train_bce 0.0561 | val_bce 0.3075\n",
            "Epoch 602 | train_bce 0.0564 | val_bce 0.3083\n",
            "Epoch 603 | train_bce 0.0558 | val_bce 0.3114\n",
            "Epoch 604 | train_bce 0.0567 | val_bce 0.3051\n",
            "Epoch 605 | train_bce 0.0559 | val_bce 0.3177\n",
            "Epoch 606 | train_bce 0.0573 | val_bce 0.3109\n",
            "Epoch 607 | train_bce 0.0554 | val_bce 0.3112\n",
            "Epoch 608 | train_bce 0.0549 | val_bce 0.3159\n",
            "Epoch 609 | train_bce 0.0546 | val_bce 0.3200\n",
            "Epoch 610 | train_bce 0.0542 | val_bce 0.3148\n",
            "Epoch 611 | train_bce 0.0541 | val_bce 0.3124\n",
            "Epoch 612 | train_bce 0.0537 | val_bce 0.3167\n",
            "Epoch 613 | train_bce 0.0535 | val_bce 0.3208\n",
            "Epoch 614 | train_bce 0.0536 | val_bce 0.3157\n",
            "Epoch 615 | train_bce 0.0535 | val_bce 0.3178\n",
            "Epoch 616 | train_bce 0.0530 | val_bce 0.3146\n",
            "Epoch 617 | train_bce 0.0533 | val_bce 0.3166\n",
            "Epoch 618 | train_bce 0.0526 | val_bce 0.3214\n",
            "Epoch 619 | train_bce 0.0527 | val_bce 0.3204\n",
            "Epoch 620 | train_bce 0.0530 | val_bce 0.3215\n",
            "Epoch 621 | train_bce 0.0526 | val_bce 0.3181\n",
            "Epoch 622 | train_bce 0.0526 | val_bce 0.3224\n",
            "Epoch 623 | train_bce 0.0522 | val_bce 0.3255\n",
            "Epoch 624 | train_bce 0.0521 | val_bce 0.3258\n",
            "Epoch 625 | train_bce 0.0519 | val_bce 0.3233\n",
            "Epoch 626 | train_bce 0.0515 | val_bce 0.3224\n",
            "Epoch 627 | train_bce 0.0511 | val_bce 0.3230\n",
            "Epoch 628 | train_bce 0.0510 | val_bce 0.3224\n",
            "Epoch 629 | train_bce 0.0509 | val_bce 0.3202\n",
            "Epoch 630 | train_bce 0.0531 | val_bce 0.3325\n",
            "Epoch 631 | train_bce 0.0521 | val_bce 0.3326\n",
            "Epoch 632 | train_bce 0.0512 | val_bce 0.3343\n",
            "Epoch 633 | train_bce 0.0522 | val_bce 0.3375\n",
            "Epoch 634 | train_bce 0.0543 | val_bce 0.3317\n",
            "Epoch 635 | train_bce 0.0590 | val_bce 0.3392\n",
            "Epoch 636 | train_bce 0.0603 | val_bce 0.3407\n",
            "Epoch 637 | train_bce 0.0602 | val_bce 0.3450\n",
            "Epoch 638 | train_bce 0.0595 | val_bce 0.3407\n",
            "Epoch 639 | train_bce 0.0591 | val_bce 0.3289\n",
            "Epoch 640 | train_bce 0.0574 | val_bce 0.3310\n",
            "Epoch 641 | train_bce 0.0556 | val_bce 0.3370\n",
            "Epoch 642 | train_bce 0.0577 | val_bce 0.3313\n",
            "Epoch 643 | train_bce 0.0561 | val_bce 0.3316\n",
            "Epoch 644 | train_bce 0.0573 | val_bce 0.3304\n",
            "Epoch 645 | train_bce 0.0543 | val_bce 0.3246\n",
            "Epoch 646 | train_bce 0.0597 | val_bce 0.3383\n",
            "Epoch 647 | train_bce 0.0612 | val_bce 0.3744\n",
            "Epoch 648 | train_bce 0.0733 | val_bce 0.3458\n",
            "Epoch 649 | train_bce 0.0649 | val_bce 0.3507\n",
            "Epoch 650 | train_bce 0.0716 | val_bce 0.3614\n",
            "Epoch 651 | train_bce 0.0670 | val_bce 0.3415\n",
            "Epoch 652 | train_bce 0.0639 | val_bce 0.3357\n",
            "Epoch 653 | train_bce 0.0697 | val_bce 0.3398\n",
            "Epoch 654 | train_bce 0.0667 | val_bce 0.3383\n",
            "Epoch 655 | train_bce 0.0645 | val_bce 0.3254\n",
            "Epoch 656 | train_bce 0.0666 | val_bce 0.3521\n",
            "Epoch 657 | train_bce 0.0665 | val_bce 0.3379\n",
            "Epoch 658 | train_bce 0.0598 | val_bce 0.3231\n",
            "Epoch 659 | train_bce 0.0594 | val_bce 0.3320\n",
            "Epoch 660 | train_bce 0.0581 | val_bce 0.3192\n",
            "Epoch 661 | train_bce 0.0551 | val_bce 0.3332\n",
            "Epoch 662 | train_bce 0.0523 | val_bce 0.3236\n",
            "Epoch 663 | train_bce 0.0513 | val_bce 0.3345\n",
            "Epoch 664 | train_bce 0.0519 | val_bce 0.3340\n",
            "Epoch 665 | train_bce 0.0508 | val_bce 0.3231\n",
            "Epoch 666 | train_bce 0.0501 | val_bce 0.3324\n",
            "Epoch 667 | train_bce 0.0506 | val_bce 0.3480\n",
            "Epoch 668 | train_bce 0.0514 | val_bce 0.3324\n",
            "Epoch 669 | train_bce 0.0511 | val_bce 0.3387\n",
            "Epoch 670 | train_bce 0.0498 | val_bce 0.3342\n",
            "Epoch 671 | train_bce 0.0489 | val_bce 0.3324\n",
            "Epoch 672 | train_bce 0.0475 | val_bce 0.3291\n",
            "Epoch 673 | train_bce 0.0479 | val_bce 0.3295\n",
            "Epoch 674 | train_bce 0.0468 | val_bce 0.3328\n",
            "Epoch 675 | train_bce 0.0467 | val_bce 0.3308\n",
            "Epoch 676 | train_bce 0.0473 | val_bce 0.3412\n",
            "Epoch 677 | train_bce 0.0473 | val_bce 0.3340\n",
            "Epoch 678 | train_bce 0.0472 | val_bce 0.3349\n",
            "Epoch 679 | train_bce 0.0465 | val_bce 0.3395\n",
            "Epoch 680 | train_bce 0.0472 | val_bce 0.3327\n",
            "Epoch 681 | train_bce 0.0469 | val_bce 0.3388\n",
            "Epoch 682 | train_bce 0.0471 | val_bce 0.3399\n",
            "Epoch 683 | train_bce 0.0462 | val_bce 0.3399\n",
            "Epoch 684 | train_bce 0.0468 | val_bce 0.3416\n",
            "Epoch 685 | train_bce 0.0466 | val_bce 0.3428\n",
            "Epoch 686 | train_bce 0.0460 | val_bce 0.3464\n",
            "Epoch 687 | train_bce 0.0464 | val_bce 0.3408\n",
            "Epoch 688 | train_bce 0.0460 | val_bce 0.3391\n",
            "Epoch 689 | train_bce 0.0451 | val_bce 0.3489\n",
            "Epoch 690 | train_bce 0.0452 | val_bce 0.3480\n",
            "Epoch 691 | train_bce 0.0446 | val_bce 0.3490\n",
            "Epoch 692 | train_bce 0.0448 | val_bce 0.3475\n",
            "Epoch 693 | train_bce 0.0437 | val_bce 0.3478\n",
            "Epoch 694 | train_bce 0.0435 | val_bce 0.3499\n",
            "Epoch 695 | train_bce 0.0435 | val_bce 0.3456\n",
            "Epoch 696 | train_bce 0.0435 | val_bce 0.3534\n",
            "Epoch 697 | train_bce 0.0437 | val_bce 0.3506\n",
            "Epoch 698 | train_bce 0.0434 | val_bce 0.3530\n",
            "Epoch 699 | train_bce 0.0435 | val_bce 0.3557\n",
            "Epoch 700 | train_bce 0.0433 | val_bce 0.3548\n",
            "Epoch 701 | train_bce 0.0432 | val_bce 0.3515\n",
            "Epoch 702 | train_bce 0.0429 | val_bce 0.3554\n",
            "Epoch 703 | train_bce 0.0432 | val_bce 0.3608\n",
            "Epoch 704 | train_bce 0.0437 | val_bce 0.3529\n",
            "Epoch 705 | train_bce 0.0440 | val_bce 0.3546\n"
          ]
        },
        {
          "output_type": "error",
          "ename": "KeyboardInterrupt",
          "evalue": "",
          "traceback": [
            "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
            "\u001b[0;31mKeyboardInterrupt\u001b[0m                         Traceback (most recent call last)",
            "\u001b[0;32m/tmp/ipython-input-4160466450.py\u001b[0m in \u001b[0;36m<cell line: 0>\u001b[0;34m()\u001b[0m\n\u001b[1;32m     22\u001b[0m \u001b[0;32mfor\u001b[0m \u001b[0mep\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mrange\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;36m1000\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     23\u001b[0m     \u001b[0mmodel\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mtrain\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m;\u001b[0m \u001b[0mtotal\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;36m0.0\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 24\u001b[0;31m     \u001b[0;32mfor\u001b[0m \u001b[0mx\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mA\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mdl_tr\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     25\u001b[0m         \u001b[0mx\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mx\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mto\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mdevice\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m;\u001b[0m \u001b[0mA\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mA\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mto\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mdevice\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     26\u001b[0m         \u001b[0mlogits\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mmodel\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mx\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m/usr/local/lib/python3.12/dist-packages/torch/utils/data/dataloader.py\u001b[0m in \u001b[0;36m__next__\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m    732\u001b[0m                 \u001b[0;31m# TODO(https://github.com/pytorch/pytorch/issues/76750)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    733\u001b[0m                 \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_reset\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m  \u001b[0;31m# type: ignore[call-arg]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 734\u001b[0;31m             \u001b[0mdata\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_next_data\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    735\u001b[0m             \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_num_yielded\u001b[0m \u001b[0;34m+=\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    736\u001b[0m             if (\n",
            "\u001b[0;32m/usr/local/lib/python3.12/dist-packages/torch/utils/data/dataloader.py\u001b[0m in \u001b[0;36m_next_data\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m    788\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0m_next_data\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    789\u001b[0m         \u001b[0mindex\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_next_index\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m  \u001b[0;31m# may raise StopIteration\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 790\u001b[0;31m         \u001b[0mdata\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_dataset_fetcher\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mfetch\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mindex\u001b[0m\u001b[0;34m)\u001b[0m  \u001b[0;31m# may raise StopIteration\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    791\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_pin_memory\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    792\u001b[0m             \u001b[0mdata\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0m_utils\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mpin_memory\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mpin_memory\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mdata\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_pin_memory_device\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m/usr/local/lib/python3.12/dist-packages/torch/utils/data/_utils/fetch.py\u001b[0m in \u001b[0;36mfetch\u001b[0;34m(self, possibly_batched_index)\u001b[0m\n\u001b[1;32m     48\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mauto_collation\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     49\u001b[0m             \u001b[0;32mif\u001b[0m \u001b[0mhasattr\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdataset\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m\"__getitems__\"\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;32mand\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdataset\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m__getitems__\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 50\u001b[0;31m                 \u001b[0mdata\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdataset\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m__getitems__\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mpossibly_batched_index\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     51\u001b[0m             \u001b[0;32melse\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     52\u001b[0m                 \u001b[0mdata\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;34m[\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdataset\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0midx\u001b[0m\u001b[0;34m]\u001b[0m \u001b[0;32mfor\u001b[0m \u001b[0midx\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mpossibly_batched_index\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m/usr/local/lib/python3.12/dist-packages/torch/utils/data/dataset.py\u001b[0m in \u001b[0;36m__getitems__\u001b[0;34m(self, indices)\u001b[0m\n\u001b[1;32m    414\u001b[0m             \u001b[0;32mreturn\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdataset\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m__getitems__\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mindices\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0midx\u001b[0m\u001b[0;34m]\u001b[0m \u001b[0;32mfor\u001b[0m \u001b[0midx\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mindices\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m  \u001b[0;31m# type: ignore[attr-defined]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    415\u001b[0m         \u001b[0;32melse\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 416\u001b[0;31m             \u001b[0;32mreturn\u001b[0m \u001b[0;34m[\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdataset\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mindices\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0midx\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m]\u001b[0m \u001b[0;32mfor\u001b[0m \u001b[0midx\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mindices\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    417\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    418\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0m__len__\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m/tmp/ipython-input-1351358964.py\u001b[0m in \u001b[0;36m__getitem__\u001b[0;34m(self, i)\u001b[0m\n\u001b[1;32m     21\u001b[0m         \u001b[0mdeg\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mA\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msum\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mdim\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m-\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mfloat\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     22\u001b[0m         \u001b[0msector_counts\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mH\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msum\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mdim\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m)\u001b[0m  \u001b[0;31m# (N, A)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 23\u001b[0;31m         \u001b[0msector4\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mtorch\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mstack\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0m_reduce_to_4_sectors\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0msector_counts\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mn\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;32mfor\u001b[0m \u001b[0mn\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mrange\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mN\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mdim\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;36m0\u001b[0m\u001b[0;34m)\u001b[0m  \u001b[0;31m# (N,4)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     24\u001b[0m         \u001b[0mx3\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mtorch\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mstack\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mpos\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;36m0\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mpos\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mdeg\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mdim\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m-\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     25\u001b[0m         \u001b[0mfeats\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mtorch\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mcat\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mx3\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0msector4\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mdim\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m-\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m)\u001b[0m  \u001b[0;31m# (N,7)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m/tmp/ipython-input-1351358964.py\u001b[0m in \u001b[0;36m_reduce_to_4_sectors\u001b[0;34m(H_sectors)\u001b[0m\n\u001b[1;32m      8\u001b[0m         \u001b[0;32mreturn\u001b[0m \u001b[0mH_sectors\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      9\u001b[0m     \u001b[0msplits\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mtorch\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mlinspace\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;36m0\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mA\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0msteps\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;36m5\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mdtype\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mtorch\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mint64\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 10\u001b[0;31m     \u001b[0;32mreturn\u001b[0m \u001b[0mtorch\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mstack\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mH_sectors\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0msplits\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0msplits\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mk\u001b[0m\u001b[0;34m+\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msum\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;32mfor\u001b[0m \u001b[0mk\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mrange\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;36m4\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mdim\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;36m0\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     11\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     12\u001b[0m \u001b[0;32mclass\u001b[0m \u001b[0mTopoDataset7D\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mDataset\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;31mKeyboardInterrupt\u001b[0m: "
          ]
        }
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "Simple Transformer Baseline"
      ],
      "metadata": {
        "id": "xp9_gkVfCyGh"
      },
      "id": "xp9_gkVfCyGh"
    },
    {
      "cell_type": "code",
      "source": [
        "import math\n",
        "import torch\n",
        "import torch.nn as nn\n",
        "import torch.nn.functional as F\n",
        "\n",
        "class SimpleTransformerBaseline(nn.Module):\n",
        "    \"\"\"\n",
        "    Baseline homogène minimaliste :\n",
        "      - Prétraitement 3+4 (comme ton nb)\n",
        "      - Linear(7->E)\n",
        "      - 1x TransformerEncoderLayer (optionnellement 2 via use_two_layers)\n",
        "      - LayerNorm\n",
        "      - Tête = dot-product / tau (température apprenable), symétrisée\n",
        "    Sort : LOGITS (B,N,N) => utiliser BCEWithLogitsLoss\n",
        "    \"\"\"\n",
        "    def __init__(self, input_dim=7, embed_size=128, num_heads=4,\n",
        "                 use_two_layers=False, symmetrize=True):\n",
        "        super().__init__()\n",
        "        self.sym = symmetrize\n",
        "        self.use_two = use_two_layers\n",
        "        self.E = embed_size\n",
        "\n",
        "        self.embed = nn.Linear(input_dim, embed_size)\n",
        "        self.enc1  = nn.TransformerEncoderLayer(d_model=embed_size, nhead=num_heads,\n",
        "                                                batch_first=True, dropout=0.0)\n",
        "        self.enc2  = nn.TransformerEncoderLayer(d_model=embed_size, nhead=num_heads,\n",
        "                                                batch_first=True, dropout=0.0)\n",
        "        self.ln = nn.LayerNorm(embed_size)\n",
        "\n",
        "        # température apprenable pour stabiliser l’échelle du dot-prod\n",
        "        init_tau = 1.0 / math.sqrt(embed_size)\n",
        "        self.log_tau = nn.Parameter(torch.tensor(math.log(init_tau)))\n",
        "\n",
        "        # init douce\n",
        "        nn.init.xavier_uniform_(self.embed.weight); nn.init.zeros_(self.embed.bias)\n",
        "\n",
        "    @staticmethod\n",
        "    def _prep_inputs(x):\n",
        "        \"\"\" même split 3+4 que ton notebook \"\"\"\n",
        "        B, N, _ = x.shape\n",
        "        x0 = F.layer_norm(x[:, :, [0]], (N, 1))            # x\n",
        "        x1 = F.layer_norm(x[:, :, [1]], (N, 1))            # y\n",
        "        x2 = F.layer_norm(x[:, :, [2]], (N, 1))            # deg\n",
        "        x3 = F.layer_norm(x[:, :, [3,4,5,6]], (N, 4))      # 4 secteurs\n",
        "        return torch.cat([x0, x1, x2, x3], dim=-1)         # (B,N,7)\n",
        "\n",
        "    def forward(self, node_features):  # (B,N,7)\n",
        "        B, N, _ = node_features.size()\n",
        "        x = self._prep_inputs(node_features)\n",
        "        h = self.embed(x)\n",
        "        h = self.enc1(h) + h\n",
        "        if self.use_two:\n",
        "            h = self.enc2(h) + h\n",
        "        h = self.ln(h)                           # (B,N,E)\n",
        "\n",
        "        # dot-product head\n",
        "        h = F.normalize(h, p=2, dim=-1)          # L2-norm -> cosine-like\n",
        "        tau = torch.exp(self.log_tau).clamp(min=1e-6)\n",
        "        logits = (h @ h.transpose(1, 2)) / tau   # (B,N,N)\n",
        "\n",
        "        if self.sym:\n",
        "            logits = 0.5 * (logits + logits.transpose(1,2))\n",
        "\n",
        "        eye = torch.eye(N, dtype=torch.bool, device=logits.device).unsqueeze(0)\n",
        "        logits = logits.masked_fill(eye, float(\"-inf\"))\n",
        "        return logits\n"
      ],
      "metadata": {
        "id": "eM_ExaAr_CFd"
      },
      "id": "eM_ExaAr_CFd",
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "import torch, torch.nn.functional as F\n",
        "from torch.utils.data import DataLoader, random_split\n",
        "\n",
        "# charge le dataset généré (par ex. synth_100.pt de ton snippet 16/4)\n",
        "blob = torch.load(\"./synth_100.pt\", map_location=\"cpu\")\n",
        "ds = TopoDataset7D(blob)         # <- ta classe déjà définie (features 7D)\n",
        "N = ds.pos.shape[1]\n",
        "\n",
        "# split\n",
        "tr, va = random_split(ds, [int(len(ds)*0.9), len(ds) - int(len(ds)*0.9)],\n",
        "                      generator=torch.Generator().manual_seed(0))\n",
        "dl_tr = DataLoader(tr, batch_size=32, shuffle=True)\n",
        "dl_va = DataLoader(va, batch_size=32, shuffle=False)\n",
        "\n",
        "device = torch.device(\"cuda\" if torch.cuda.is_available() else \"cpu\")\n",
        "model = SimpleTransformerBaseline(\n",
        "    input_dim=7, embed_size=32, num_heads=8,\n",
        "    use_two_layers=False, symmetrize=True\n",
        ").to(device)\n",
        "\n",
        "opt = torch.optim.AdamW(model.parameters(), lr=1e-4)\n",
        "iu = torch.triu_indices(N, N, 1, device=device)\n",
        "\n",
        "for ep in range(1, 1000):\n",
        "    # train\n",
        "    model.train(); total=0.0\n",
        "    for x, A in dl_tr:\n",
        "        x = x.to(device); A = A.to(device)\n",
        "        logits = model(x)                              # (B,N,N)\n",
        "        y = A[:, iu[0], iu[1]].float()\n",
        "        p = logits[:, iu[0], iu[1]]\n",
        "        loss = F.binary_cross_entropy_with_logits(p, y)\n",
        "        opt.zero_grad(); loss.backward(); opt.step()\n",
        "        total += float(loss.item()) * x.size(0)\n",
        "    tr_loss = total/len(tr)\n",
        "\n",
        "    # val\n",
        "    model.eval(); total=0.0\n",
        "    with torch.no_grad():\n",
        "        for x, A in dl_va:\n",
        "            x = x.to(device); A = A.to(device)\n",
        "            logits = model(x)\n",
        "            y = A[:, iu[0], iu[1]].float()\n",
        "            p = logits[:, iu[0], iu[1]]\n",
        "            loss = F.binary_cross_entropy_with_logits(p, y)\n",
        "            total += float(loss.item()) * x.size(0)\n",
        "    va_loss = total/len(va)\n",
        "    print(f\"Epoch {ep:03d} | train_bce {tr_loss:.4f} | val_bce {va_loss:.4f}\")\n"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 1000
        },
        "id": "9edSuavbAZv2",
        "outputId": "2deae3ab-ae03-4b68-f6f2-8801c187d7cd"
      },
      "id": "9edSuavbAZv2",
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Epoch 001 | train_bce 0.7354 | val_bce 0.7635\n",
            "Epoch 002 | train_bce 0.7095 | val_bce 0.7405\n",
            "Epoch 003 | train_bce 0.6895 | val_bce 0.7194\n",
            "Epoch 004 | train_bce 0.6749 | val_bce 0.6996\n",
            "Epoch 005 | train_bce 0.6636 | val_bce 0.6817\n",
            "Epoch 006 | train_bce 0.6534 | val_bce 0.6673\n",
            "Epoch 007 | train_bce 0.6450 | val_bce 0.6567\n",
            "Epoch 008 | train_bce 0.6377 | val_bce 0.6481\n",
            "Epoch 009 | train_bce 0.6316 | val_bce 0.6412\n",
            "Epoch 010 | train_bce 0.6255 | val_bce 0.6351\n",
            "Epoch 011 | train_bce 0.6198 | val_bce 0.6297\n",
            "Epoch 012 | train_bce 0.6139 | val_bce 0.6248\n",
            "Epoch 013 | train_bce 0.6083 | val_bce 0.6207\n",
            "Epoch 014 | train_bce 0.6023 | val_bce 0.6157\n",
            "Epoch 015 | train_bce 0.5960 | val_bce 0.6103\n",
            "Epoch 016 | train_bce 0.5896 | val_bce 0.6040\n",
            "Epoch 017 | train_bce 0.5825 | val_bce 0.5967\n",
            "Epoch 018 | train_bce 0.5742 | val_bce 0.5889\n",
            "Epoch 019 | train_bce 0.5656 | val_bce 0.5802\n",
            "Epoch 020 | train_bce 0.5555 | val_bce 0.5704\n",
            "Epoch 021 | train_bce 0.5443 | val_bce 0.5589\n",
            "Epoch 022 | train_bce 0.5313 | val_bce 0.5446\n",
            "Epoch 023 | train_bce 0.5168 | val_bce 0.5287\n",
            "Epoch 024 | train_bce 0.5003 | val_bce 0.5116\n",
            "Epoch 025 | train_bce 0.4813 | val_bce 0.4923\n",
            "Epoch 026 | train_bce 0.4624 | val_bce 0.4721\n",
            "Epoch 027 | train_bce 0.4441 | val_bce 0.4525\n",
            "Epoch 028 | train_bce 0.4296 | val_bce 0.4398\n",
            "Epoch 029 | train_bce 0.4199 | val_bce 0.4333\n",
            "Epoch 030 | train_bce 0.4153 | val_bce 0.4273\n",
            "Epoch 031 | train_bce 0.4108 | val_bce 0.4229\n",
            "Epoch 032 | train_bce 0.4058 | val_bce 0.4180\n",
            "Epoch 033 | train_bce 0.4002 | val_bce 0.4129\n",
            "Epoch 034 | train_bce 0.3955 | val_bce 0.4113\n",
            "Epoch 035 | train_bce 0.3913 | val_bce 0.4093\n",
            "Epoch 036 | train_bce 0.3878 | val_bce 0.4072\n",
            "Epoch 037 | train_bce 0.3845 | val_bce 0.4055\n",
            "Epoch 038 | train_bce 0.3816 | val_bce 0.4031\n",
            "Epoch 039 | train_bce 0.3790 | val_bce 0.4019\n",
            "Epoch 040 | train_bce 0.3766 | val_bce 0.3993\n",
            "Epoch 041 | train_bce 0.3739 | val_bce 0.3984\n",
            "Epoch 042 | train_bce 0.3721 | val_bce 0.3968\n",
            "Epoch 043 | train_bce 0.3701 | val_bce 0.3948\n",
            "Epoch 044 | train_bce 0.3683 | val_bce 0.3944\n",
            "Epoch 045 | train_bce 0.3664 | val_bce 0.3933\n",
            "Epoch 046 | train_bce 0.3648 | val_bce 0.3915\n",
            "Epoch 047 | train_bce 0.3632 | val_bce 0.3907\n",
            "Epoch 048 | train_bce 0.3621 | val_bce 0.3906\n",
            "Epoch 049 | train_bce 0.3604 | val_bce 0.3903\n",
            "Epoch 050 | train_bce 0.3596 | val_bce 0.3888\n",
            "Epoch 051 | train_bce 0.3582 | val_bce 0.3886\n",
            "Epoch 052 | train_bce 0.3571 | val_bce 0.3886\n",
            "Epoch 053 | train_bce 0.3561 | val_bce 0.3872\n",
            "Epoch 054 | train_bce 0.3552 | val_bce 0.3849\n",
            "Epoch 055 | train_bce 0.3544 | val_bce 0.3848\n",
            "Epoch 056 | train_bce 0.3533 | val_bce 0.3859\n",
            "Epoch 057 | train_bce 0.3525 | val_bce 0.3845\n",
            "Epoch 058 | train_bce 0.3519 | val_bce 0.3826\n",
            "Epoch 059 | train_bce 0.3508 | val_bce 0.3826\n",
            "Epoch 060 | train_bce 0.3499 | val_bce 0.3820\n",
            "Epoch 061 | train_bce 0.3495 | val_bce 0.3817\n",
            "Epoch 062 | train_bce 0.3485 | val_bce 0.3807\n",
            "Epoch 063 | train_bce 0.3480 | val_bce 0.3799\n",
            "Epoch 064 | train_bce 0.3474 | val_bce 0.3801\n",
            "Epoch 065 | train_bce 0.3467 | val_bce 0.3805\n",
            "Epoch 066 | train_bce 0.3462 | val_bce 0.3794\n",
            "Epoch 067 | train_bce 0.3456 | val_bce 0.3783\n",
            "Epoch 068 | train_bce 0.3455 | val_bce 0.3776\n",
            "Epoch 069 | train_bce 0.3443 | val_bce 0.3768\n",
            "Epoch 070 | train_bce 0.3443 | val_bce 0.3765\n",
            "Epoch 071 | train_bce 0.3434 | val_bce 0.3774\n",
            "Epoch 072 | train_bce 0.3433 | val_bce 0.3771\n",
            "Epoch 073 | train_bce 0.3426 | val_bce 0.3766\n",
            "Epoch 074 | train_bce 0.3421 | val_bce 0.3755\n",
            "Epoch 075 | train_bce 0.3418 | val_bce 0.3751\n",
            "Epoch 076 | train_bce 0.3411 | val_bce 0.3763\n",
            "Epoch 077 | train_bce 0.3408 | val_bce 0.3753\n",
            "Epoch 078 | train_bce 0.3403 | val_bce 0.3745\n",
            "Epoch 079 | train_bce 0.3399 | val_bce 0.3744\n",
            "Epoch 080 | train_bce 0.3396 | val_bce 0.3747\n",
            "Epoch 081 | train_bce 0.3390 | val_bce 0.3739\n",
            "Epoch 082 | train_bce 0.3385 | val_bce 0.3732\n",
            "Epoch 083 | train_bce 0.3382 | val_bce 0.3728\n",
            "Epoch 084 | train_bce 0.3381 | val_bce 0.3732\n",
            "Epoch 085 | train_bce 0.3375 | val_bce 0.3723\n",
            "Epoch 086 | train_bce 0.3373 | val_bce 0.3722\n",
            "Epoch 087 | train_bce 0.3369 | val_bce 0.3727\n",
            "Epoch 088 | train_bce 0.3365 | val_bce 0.3728\n",
            "Epoch 089 | train_bce 0.3360 | val_bce 0.3717\n",
            "Epoch 090 | train_bce 0.3358 | val_bce 0.3713\n",
            "Epoch 091 | train_bce 0.3352 | val_bce 0.3729\n",
            "Epoch 092 | train_bce 0.3352 | val_bce 0.3725\n",
            "Epoch 093 | train_bce 0.3346 | val_bce 0.3707\n",
            "Epoch 094 | train_bce 0.3345 | val_bce 0.3704\n",
            "Epoch 095 | train_bce 0.3340 | val_bce 0.3710\n",
            "Epoch 096 | train_bce 0.3340 | val_bce 0.3710\n",
            "Epoch 097 | train_bce 0.3333 | val_bce 0.3705\n",
            "Epoch 098 | train_bce 0.3334 | val_bce 0.3707\n",
            "Epoch 099 | train_bce 0.3328 | val_bce 0.3704\n",
            "Epoch 100 | train_bce 0.3325 | val_bce 0.3703\n",
            "Epoch 101 | train_bce 0.3323 | val_bce 0.3693\n",
            "Epoch 102 | train_bce 0.3320 | val_bce 0.3697\n",
            "Epoch 103 | train_bce 0.3316 | val_bce 0.3701\n",
            "Epoch 104 | train_bce 0.3312 | val_bce 0.3692\n",
            "Epoch 105 | train_bce 0.3309 | val_bce 0.3686\n",
            "Epoch 106 | train_bce 0.3308 | val_bce 0.3695\n",
            "Epoch 107 | train_bce 0.3304 | val_bce 0.3689\n",
            "Epoch 108 | train_bce 0.3299 | val_bce 0.3676\n",
            "Epoch 109 | train_bce 0.3296 | val_bce 0.3687\n",
            "Epoch 110 | train_bce 0.3292 | val_bce 0.3682\n",
            "Epoch 111 | train_bce 0.3290 | val_bce 0.3677\n",
            "Epoch 112 | train_bce 0.3283 | val_bce 0.3678\n",
            "Epoch 113 | train_bce 0.3283 | val_bce 0.3677\n",
            "Epoch 114 | train_bce 0.3278 | val_bce 0.3673\n",
            "Epoch 115 | train_bce 0.3276 | val_bce 0.3672\n",
            "Epoch 116 | train_bce 0.3273 | val_bce 0.3665\n",
            "Epoch 117 | train_bce 0.3269 | val_bce 0.3672\n",
            "Epoch 118 | train_bce 0.3266 | val_bce 0.3674\n",
            "Epoch 119 | train_bce 0.3263 | val_bce 0.3662\n",
            "Epoch 120 | train_bce 0.3260 | val_bce 0.3659\n",
            "Epoch 121 | train_bce 0.3257 | val_bce 0.3670\n",
            "Epoch 122 | train_bce 0.3255 | val_bce 0.3664\n",
            "Epoch 123 | train_bce 0.3253 | val_bce 0.3660\n",
            "Epoch 124 | train_bce 0.3248 | val_bce 0.3660\n",
            "Epoch 125 | train_bce 0.3246 | val_bce 0.3654\n",
            "Epoch 126 | train_bce 0.3241 | val_bce 0.3657\n",
            "Epoch 127 | train_bce 0.3239 | val_bce 0.3653\n",
            "Epoch 128 | train_bce 0.3233 | val_bce 0.3651\n",
            "Epoch 129 | train_bce 0.3232 | val_bce 0.3653\n",
            "Epoch 130 | train_bce 0.3229 | val_bce 0.3651\n",
            "Epoch 131 | train_bce 0.3227 | val_bce 0.3643\n",
            "Epoch 132 | train_bce 0.3224 | val_bce 0.3649\n",
            "Epoch 133 | train_bce 0.3219 | val_bce 0.3638\n",
            "Epoch 134 | train_bce 0.3219 | val_bce 0.3639\n",
            "Epoch 135 | train_bce 0.3212 | val_bce 0.3649\n",
            "Epoch 136 | train_bce 0.3212 | val_bce 0.3645\n",
            "Epoch 137 | train_bce 0.3209 | val_bce 0.3643\n",
            "Epoch 138 | train_bce 0.3205 | val_bce 0.3643\n",
            "Epoch 139 | train_bce 0.3204 | val_bce 0.3631\n",
            "Epoch 140 | train_bce 0.3198 | val_bce 0.3632\n",
            "Epoch 141 | train_bce 0.3195 | val_bce 0.3646\n",
            "Epoch 142 | train_bce 0.3192 | val_bce 0.3638\n",
            "Epoch 143 | train_bce 0.3189 | val_bce 0.3625\n",
            "Epoch 144 | train_bce 0.3187 | val_bce 0.3630\n",
            "Epoch 145 | train_bce 0.3183 | val_bce 0.3635\n",
            "Epoch 146 | train_bce 0.3181 | val_bce 0.3642\n",
            "Epoch 147 | train_bce 0.3176 | val_bce 0.3628\n",
            "Epoch 148 | train_bce 0.3173 | val_bce 0.3622\n",
            "Epoch 149 | train_bce 0.3175 | val_bce 0.3625\n",
            "Epoch 150 | train_bce 0.3170 | val_bce 0.3633\n",
            "Epoch 151 | train_bce 0.3166 | val_bce 0.3626\n",
            "Epoch 152 | train_bce 0.3160 | val_bce 0.3628\n",
            "Epoch 153 | train_bce 0.3159 | val_bce 0.3613\n",
            "Epoch 154 | train_bce 0.3154 | val_bce 0.3620\n",
            "Epoch 155 | train_bce 0.3155 | val_bce 0.3620\n",
            "Epoch 156 | train_bce 0.3148 | val_bce 0.3619\n",
            "Epoch 157 | train_bce 0.3145 | val_bce 0.3611\n",
            "Epoch 158 | train_bce 0.3143 | val_bce 0.3611\n",
            "Epoch 159 | train_bce 0.3136 | val_bce 0.3625\n",
            "Epoch 160 | train_bce 0.3141 | val_bce 0.3615\n",
            "Epoch 161 | train_bce 0.3133 | val_bce 0.3619\n",
            "Epoch 162 | train_bce 0.3134 | val_bce 0.3615\n",
            "Epoch 163 | train_bce 0.3124 | val_bce 0.3614\n",
            "Epoch 164 | train_bce 0.3122 | val_bce 0.3614\n",
            "Epoch 165 | train_bce 0.3122 | val_bce 0.3606\n",
            "Epoch 166 | train_bce 0.3115 | val_bce 0.3622\n",
            "Epoch 167 | train_bce 0.3115 | val_bce 0.3602\n",
            "Epoch 168 | train_bce 0.3108 | val_bce 0.3603\n",
            "Epoch 169 | train_bce 0.3104 | val_bce 0.3605\n",
            "Epoch 170 | train_bce 0.3101 | val_bce 0.3599\n",
            "Epoch 171 | train_bce 0.3097 | val_bce 0.3591\n",
            "Epoch 172 | train_bce 0.3092 | val_bce 0.3600\n",
            "Epoch 173 | train_bce 0.3092 | val_bce 0.3599\n",
            "Epoch 174 | train_bce 0.3086 | val_bce 0.3592\n",
            "Epoch 175 | train_bce 0.3083 | val_bce 0.3590\n",
            "Epoch 176 | train_bce 0.3080 | val_bce 0.3590\n",
            "Epoch 177 | train_bce 0.3075 | val_bce 0.3604\n",
            "Epoch 178 | train_bce 0.3074 | val_bce 0.3597\n",
            "Epoch 179 | train_bce 0.3068 | val_bce 0.3596\n",
            "Epoch 180 | train_bce 0.3067 | val_bce 0.3592\n",
            "Epoch 181 | train_bce 0.3065 | val_bce 0.3589\n",
            "Epoch 182 | train_bce 0.3056 | val_bce 0.3593\n",
            "Epoch 183 | train_bce 0.3060 | val_bce 0.3581\n",
            "Epoch 184 | train_bce 0.3053 | val_bce 0.3578\n",
            "Epoch 185 | train_bce 0.3050 | val_bce 0.3588\n",
            "Epoch 186 | train_bce 0.3046 | val_bce 0.3576\n",
            "Epoch 187 | train_bce 0.3042 | val_bce 0.3581\n",
            "Epoch 188 | train_bce 0.3040 | val_bce 0.3586\n",
            "Epoch 189 | train_bce 0.3036 | val_bce 0.3577\n",
            "Epoch 190 | train_bce 0.3031 | val_bce 0.3583\n",
            "Epoch 191 | train_bce 0.3028 | val_bce 0.3570\n",
            "Epoch 192 | train_bce 0.3028 | val_bce 0.3581\n",
            "Epoch 193 | train_bce 0.3020 | val_bce 0.3575\n",
            "Epoch 194 | train_bce 0.3016 | val_bce 0.3571\n",
            "Epoch 195 | train_bce 0.3019 | val_bce 0.3555\n",
            "Epoch 196 | train_bce 0.3010 | val_bce 0.3580\n",
            "Epoch 197 | train_bce 0.3006 | val_bce 0.3577\n",
            "Epoch 198 | train_bce 0.3005 | val_bce 0.3569\n",
            "Epoch 199 | train_bce 0.2996 | val_bce 0.3573\n",
            "Epoch 200 | train_bce 0.2998 | val_bce 0.3555\n",
            "Epoch 201 | train_bce 0.3003 | val_bce 0.3567\n",
            "Epoch 202 | train_bce 0.2989 | val_bce 0.3579\n",
            "Epoch 203 | train_bce 0.2989 | val_bce 0.3557\n",
            "Epoch 204 | train_bce 0.2987 | val_bce 0.3571\n",
            "Epoch 205 | train_bce 0.2982 | val_bce 0.3569\n",
            "Epoch 206 | train_bce 0.2978 | val_bce 0.3569\n",
            "Epoch 207 | train_bce 0.2976 | val_bce 0.3552\n",
            "Epoch 208 | train_bce 0.2966 | val_bce 0.3567\n",
            "Epoch 209 | train_bce 0.2967 | val_bce 0.3551\n",
            "Epoch 210 | train_bce 0.2960 | val_bce 0.3570\n",
            "Epoch 211 | train_bce 0.2962 | val_bce 0.3556\n",
            "Epoch 212 | train_bce 0.2956 | val_bce 0.3552\n",
            "Epoch 213 | train_bce 0.2952 | val_bce 0.3550\n",
            "Epoch 214 | train_bce 0.2947 | val_bce 0.3552\n",
            "Epoch 215 | train_bce 0.2945 | val_bce 0.3561\n",
            "Epoch 216 | train_bce 0.2943 | val_bce 0.3546\n",
            "Epoch 217 | train_bce 0.2939 | val_bce 0.3536\n",
            "Epoch 218 | train_bce 0.2930 | val_bce 0.3543\n",
            "Epoch 219 | train_bce 0.2932 | val_bce 0.3545\n",
            "Epoch 220 | train_bce 0.2930 | val_bce 0.3548\n",
            "Epoch 221 | train_bce 0.2926 | val_bce 0.3534\n",
            "Epoch 222 | train_bce 0.2924 | val_bce 0.3557\n",
            "Epoch 223 | train_bce 0.2921 | val_bce 0.3549\n",
            "Epoch 224 | train_bce 0.2918 | val_bce 0.3532\n",
            "Epoch 225 | train_bce 0.2911 | val_bce 0.3547\n",
            "Epoch 226 | train_bce 0.2914 | val_bce 0.3544\n",
            "Epoch 227 | train_bce 0.2905 | val_bce 0.3535\n",
            "Epoch 228 | train_bce 0.2899 | val_bce 0.3535\n",
            "Epoch 229 | train_bce 0.2900 | val_bce 0.3528\n",
            "Epoch 230 | train_bce 0.2895 | val_bce 0.3541\n",
            "Epoch 231 | train_bce 0.2887 | val_bce 0.3540\n",
            "Epoch 232 | train_bce 0.2885 | val_bce 0.3530\n",
            "Epoch 233 | train_bce 0.2885 | val_bce 0.3526\n",
            "Epoch 234 | train_bce 0.2880 | val_bce 0.3539\n",
            "Epoch 235 | train_bce 0.2875 | val_bce 0.3537\n",
            "Epoch 236 | train_bce 0.2874 | val_bce 0.3533\n",
            "Epoch 237 | train_bce 0.2871 | val_bce 0.3532\n",
            "Epoch 238 | train_bce 0.2861 | val_bce 0.3543\n",
            "Epoch 239 | train_bce 0.2864 | val_bce 0.3532\n",
            "Epoch 240 | train_bce 0.2865 | val_bce 0.3521\n",
            "Epoch 241 | train_bce 0.2855 | val_bce 0.3535\n",
            "Epoch 242 | train_bce 0.2850 | val_bce 0.3540\n",
            "Epoch 243 | train_bce 0.2849 | val_bce 0.3514\n",
            "Epoch 244 | train_bce 0.2850 | val_bce 0.3533\n",
            "Epoch 245 | train_bce 0.2850 | val_bce 0.3529\n",
            "Epoch 246 | train_bce 0.2851 | val_bce 0.3553\n",
            "Epoch 247 | train_bce 0.2853 | val_bce 0.3507\n",
            "Epoch 248 | train_bce 0.2834 | val_bce 0.3528\n",
            "Epoch 249 | train_bce 0.2834 | val_bce 0.3522\n",
            "Epoch 250 | train_bce 0.2830 | val_bce 0.3529\n",
            "Epoch 251 | train_bce 0.2824 | val_bce 0.3513\n",
            "Epoch 252 | train_bce 0.2819 | val_bce 0.3518\n",
            "Epoch 253 | train_bce 0.2812 | val_bce 0.3523\n",
            "Epoch 254 | train_bce 0.2811 | val_bce 0.3511\n",
            "Epoch 255 | train_bce 0.2809 | val_bce 0.3509\n",
            "Epoch 256 | train_bce 0.2801 | val_bce 0.3511\n",
            "Epoch 257 | train_bce 0.2796 | val_bce 0.3530\n",
            "Epoch 258 | train_bce 0.2796 | val_bce 0.3518\n",
            "Epoch 259 | train_bce 0.2795 | val_bce 0.3512\n",
            "Epoch 260 | train_bce 0.2789 | val_bce 0.3515\n",
            "Epoch 261 | train_bce 0.2782 | val_bce 0.3514\n",
            "Epoch 262 | train_bce 0.2786 | val_bce 0.3521\n",
            "Epoch 263 | train_bce 0.2777 | val_bce 0.3520\n",
            "Epoch 264 | train_bce 0.2771 | val_bce 0.3499\n",
            "Epoch 265 | train_bce 0.2768 | val_bce 0.3523\n",
            "Epoch 266 | train_bce 0.2764 | val_bce 0.3511\n",
            "Epoch 267 | train_bce 0.2762 | val_bce 0.3503\n",
            "Epoch 268 | train_bce 0.2756 | val_bce 0.3505\n",
            "Epoch 269 | train_bce 0.2756 | val_bce 0.3490\n",
            "Epoch 270 | train_bce 0.2754 | val_bce 0.3520\n",
            "Epoch 271 | train_bce 0.2756 | val_bce 0.3496\n",
            "Epoch 272 | train_bce 0.2750 | val_bce 0.3498\n",
            "Epoch 273 | train_bce 0.2747 | val_bce 0.3500\n",
            "Epoch 274 | train_bce 0.2736 | val_bce 0.3488\n",
            "Epoch 275 | train_bce 0.2736 | val_bce 0.3532\n",
            "Epoch 276 | train_bce 0.2743 | val_bce 0.3498\n",
            "Epoch 277 | train_bce 0.2743 | val_bce 0.3526\n",
            "Epoch 278 | train_bce 0.2730 | val_bce 0.3496\n",
            "Epoch 279 | train_bce 0.2731 | val_bce 0.3492\n",
            "Epoch 280 | train_bce 0.2728 | val_bce 0.3505\n",
            "Epoch 281 | train_bce 0.2723 | val_bce 0.3499\n",
            "Epoch 282 | train_bce 0.2720 | val_bce 0.3505\n",
            "Epoch 283 | train_bce 0.2712 | val_bce 0.3489\n",
            "Epoch 284 | train_bce 0.2704 | val_bce 0.3513\n",
            "Epoch 285 | train_bce 0.2708 | val_bce 0.3480\n",
            "Epoch 286 | train_bce 0.2707 | val_bce 0.3526\n",
            "Epoch 287 | train_bce 0.2709 | val_bce 0.3483\n",
            "Epoch 288 | train_bce 0.2695 | val_bce 0.3503\n",
            "Epoch 289 | train_bce 0.2690 | val_bce 0.3484\n",
            "Epoch 290 | train_bce 0.2692 | val_bce 0.3491\n",
            "Epoch 291 | train_bce 0.2690 | val_bce 0.3509\n",
            "Epoch 292 | train_bce 0.2687 | val_bce 0.3488\n",
            "Epoch 293 | train_bce 0.2688 | val_bce 0.3512\n",
            "Epoch 294 | train_bce 0.2690 | val_bce 0.3514\n",
            "Epoch 295 | train_bce 0.2694 | val_bce 0.3539\n",
            "Epoch 296 | train_bce 0.2701 | val_bce 0.3519\n",
            "Epoch 297 | train_bce 0.2679 | val_bce 0.3502\n",
            "Epoch 298 | train_bce 0.2679 | val_bce 0.3505\n",
            "Epoch 299 | train_bce 0.2670 | val_bce 0.3515\n",
            "Epoch 300 | train_bce 0.2667 | val_bce 0.3502\n",
            "Epoch 301 | train_bce 0.2672 | val_bce 0.3502\n",
            "Epoch 302 | train_bce 0.2660 | val_bce 0.3511\n",
            "Epoch 303 | train_bce 0.2660 | val_bce 0.3487\n",
            "Epoch 304 | train_bce 0.2663 | val_bce 0.3529\n",
            "Epoch 305 | train_bce 0.2656 | val_bce 0.3495\n",
            "Epoch 306 | train_bce 0.2650 | val_bce 0.3521\n",
            "Epoch 307 | train_bce 0.2651 | val_bce 0.3505\n",
            "Epoch 308 | train_bce 0.2652 | val_bce 0.3490\n",
            "Epoch 309 | train_bce 0.2643 | val_bce 0.3498\n",
            "Epoch 310 | train_bce 0.2644 | val_bce 0.3515\n",
            "Epoch 311 | train_bce 0.2632 | val_bce 0.3482\n",
            "Epoch 312 | train_bce 0.2629 | val_bce 0.3511\n",
            "Epoch 313 | train_bce 0.2627 | val_bce 0.3493\n",
            "Epoch 314 | train_bce 0.2627 | val_bce 0.3474\n",
            "Epoch 315 | train_bce 0.2620 | val_bce 0.3508\n",
            "Epoch 316 | train_bce 0.2620 | val_bce 0.3490\n",
            "Epoch 317 | train_bce 0.2617 | val_bce 0.3504\n",
            "Epoch 318 | train_bce 0.2612 | val_bce 0.3480\n",
            "Epoch 319 | train_bce 0.2607 | val_bce 0.3507\n",
            "Epoch 320 | train_bce 0.2608 | val_bce 0.3482\n",
            "Epoch 321 | train_bce 0.2603 | val_bce 0.3493\n",
            "Epoch 322 | train_bce 0.2602 | val_bce 0.3506\n",
            "Epoch 323 | train_bce 0.2602 | val_bce 0.3504\n",
            "Epoch 324 | train_bce 0.2596 | val_bce 0.3486\n",
            "Epoch 325 | train_bce 0.2589 | val_bce 0.3498\n",
            "Epoch 326 | train_bce 0.2588 | val_bce 0.3488\n",
            "Epoch 327 | train_bce 0.2595 | val_bce 0.3526\n",
            "Epoch 328 | train_bce 0.2591 | val_bce 0.3489\n",
            "Epoch 329 | train_bce 0.2585 | val_bce 0.3486\n",
            "Epoch 330 | train_bce 0.2586 | val_bce 0.3515\n",
            "Epoch 331 | train_bce 0.2586 | val_bce 0.3498\n",
            "Epoch 332 | train_bce 0.2588 | val_bce 0.3524\n",
            "Epoch 333 | train_bce 0.2589 | val_bce 0.3513\n",
            "Epoch 334 | train_bce 0.2581 | val_bce 0.3487\n",
            "Epoch 335 | train_bce 0.2574 | val_bce 0.3532\n",
            "Epoch 336 | train_bce 0.2574 | val_bce 0.3485\n",
            "Epoch 337 | train_bce 0.2574 | val_bce 0.3545\n",
            "Epoch 338 | train_bce 0.2573 | val_bce 0.3478\n",
            "Epoch 339 | train_bce 0.2569 | val_bce 0.3539\n",
            "Epoch 340 | train_bce 0.2568 | val_bce 0.3516\n",
            "Epoch 341 | train_bce 0.2575 | val_bce 0.3506\n",
            "Epoch 342 | train_bce 0.2569 | val_bce 0.3501\n",
            "Epoch 343 | train_bce 0.2562 | val_bce 0.3503\n",
            "Epoch 344 | train_bce 0.2556 | val_bce 0.3498\n",
            "Epoch 345 | train_bce 0.2560 | val_bce 0.3502\n",
            "Epoch 346 | train_bce 0.2546 | val_bce 0.3487\n",
            "Epoch 347 | train_bce 0.2544 | val_bce 0.3500\n",
            "Epoch 348 | train_bce 0.2539 | val_bce 0.3500\n",
            "Epoch 349 | train_bce 0.2529 | val_bce 0.3482\n",
            "Epoch 350 | train_bce 0.2524 | val_bce 0.3505\n",
            "Epoch 351 | train_bce 0.2531 | val_bce 0.3502\n",
            "Epoch 352 | train_bce 0.2523 | val_bce 0.3503\n",
            "Epoch 353 | train_bce 0.2537 | val_bce 0.3508\n",
            "Epoch 354 | train_bce 0.2539 | val_bce 0.3575\n",
            "Epoch 355 | train_bce 0.2545 | val_bce 0.3520\n",
            "Epoch 356 | train_bce 0.2545 | val_bce 0.3509\n",
            "Epoch 357 | train_bce 0.2531 | val_bce 0.3527\n",
            "Epoch 358 | train_bce 0.2528 | val_bce 0.3511\n",
            "Epoch 359 | train_bce 0.2534 | val_bce 0.3534\n",
            "Epoch 360 | train_bce 0.2527 | val_bce 0.3525\n",
            "Epoch 361 | train_bce 0.2517 | val_bce 0.3509\n",
            "Epoch 362 | train_bce 0.2514 | val_bce 0.3506\n",
            "Epoch 363 | train_bce 0.2518 | val_bce 0.3480\n",
            "Epoch 364 | train_bce 0.2503 | val_bce 0.3487\n",
            "Epoch 365 | train_bce 0.2501 | val_bce 0.3533\n",
            "Epoch 366 | train_bce 0.2511 | val_bce 0.3492\n",
            "Epoch 367 | train_bce 0.2503 | val_bce 0.3543\n",
            "Epoch 368 | train_bce 0.2491 | val_bce 0.3489\n",
            "Epoch 369 | train_bce 0.2488 | val_bce 0.3504\n",
            "Epoch 370 | train_bce 0.2496 | val_bce 0.3492\n",
            "Epoch 371 | train_bce 0.2491 | val_bce 0.3514\n",
            "Epoch 372 | train_bce 0.2492 | val_bce 0.3493\n",
            "Epoch 373 | train_bce 0.2487 | val_bce 0.3528\n",
            "Epoch 374 | train_bce 0.2483 | val_bce 0.3514\n",
            "Epoch 375 | train_bce 0.2482 | val_bce 0.3503\n",
            "Epoch 376 | train_bce 0.2476 | val_bce 0.3535\n",
            "Epoch 377 | train_bce 0.2481 | val_bce 0.3505\n",
            "Epoch 378 | train_bce 0.2474 | val_bce 0.3493\n",
            "Epoch 379 | train_bce 0.2470 | val_bce 0.3514\n",
            "Epoch 380 | train_bce 0.2467 | val_bce 0.3497\n",
            "Epoch 381 | train_bce 0.2457 | val_bce 0.3496\n",
            "Epoch 382 | train_bce 0.2455 | val_bce 0.3485\n",
            "Epoch 383 | train_bce 0.2455 | val_bce 0.3498\n",
            "Epoch 384 | train_bce 0.2460 | val_bce 0.3517\n",
            "Epoch 385 | train_bce 0.2464 | val_bce 0.3522\n",
            "Epoch 386 | train_bce 0.2446 | val_bce 0.3491\n",
            "Epoch 387 | train_bce 0.2445 | val_bce 0.3495\n",
            "Epoch 388 | train_bce 0.2442 | val_bce 0.3499\n",
            "Epoch 389 | train_bce 0.2435 | val_bce 0.3487\n",
            "Epoch 390 | train_bce 0.2435 | val_bce 0.3479\n",
            "Epoch 391 | train_bce 0.2431 | val_bce 0.3513\n",
            "Epoch 392 | train_bce 0.2436 | val_bce 0.3508\n",
            "Epoch 393 | train_bce 0.2434 | val_bce 0.3532\n",
            "Epoch 394 | train_bce 0.2439 | val_bce 0.3500\n",
            "Epoch 395 | train_bce 0.2434 | val_bce 0.3497\n",
            "Epoch 396 | train_bce 0.2433 | val_bce 0.3500\n",
            "Epoch 397 | train_bce 0.2436 | val_bce 0.3533\n",
            "Epoch 398 | train_bce 0.2429 | val_bce 0.3505\n",
            "Epoch 399 | train_bce 0.2429 | val_bce 0.3552\n",
            "Epoch 400 | train_bce 0.2422 | val_bce 0.3482\n",
            "Epoch 401 | train_bce 0.2420 | val_bce 0.3485\n",
            "Epoch 402 | train_bce 0.2415 | val_bce 0.3526\n",
            "Epoch 403 | train_bce 0.2419 | val_bce 0.3506\n",
            "Epoch 404 | train_bce 0.2414 | val_bce 0.3516\n",
            "Epoch 405 | train_bce 0.2425 | val_bce 0.3521\n",
            "Epoch 406 | train_bce 0.2431 | val_bce 0.3560\n",
            "Epoch 407 | train_bce 0.2425 | val_bce 0.3530\n",
            "Epoch 408 | train_bce 0.2415 | val_bce 0.3483\n",
            "Epoch 409 | train_bce 0.2402 | val_bce 0.3524\n",
            "Epoch 410 | train_bce 0.2406 | val_bce 0.3500\n",
            "Epoch 411 | train_bce 0.2396 | val_bce 0.3558\n",
            "Epoch 412 | train_bce 0.2404 | val_bce 0.3499\n",
            "Epoch 413 | train_bce 0.2398 | val_bce 0.3526\n",
            "Epoch 414 | train_bce 0.2389 | val_bce 0.3531\n",
            "Epoch 415 | train_bce 0.2390 | val_bce 0.3509\n",
            "Epoch 416 | train_bce 0.2395 | val_bce 0.3546\n",
            "Epoch 417 | train_bce 0.2387 | val_bce 0.3526\n",
            "Epoch 418 | train_bce 0.2393 | val_bce 0.3525\n",
            "Epoch 419 | train_bce 0.2385 | val_bce 0.3513\n",
            "Epoch 420 | train_bce 0.2385 | val_bce 0.3524\n",
            "Epoch 421 | train_bce 0.2378 | val_bce 0.3492\n",
            "Epoch 422 | train_bce 0.2373 | val_bce 0.3514\n",
            "Epoch 423 | train_bce 0.2365 | val_bce 0.3504\n",
            "Epoch 424 | train_bce 0.2366 | val_bce 0.3513\n",
            "Epoch 425 | train_bce 0.2362 | val_bce 0.3509\n",
            "Epoch 426 | train_bce 0.2360 | val_bce 0.3523\n",
            "Epoch 427 | train_bce 0.2367 | val_bce 0.3566\n",
            "Epoch 428 | train_bce 0.2370 | val_bce 0.3512\n",
            "Epoch 429 | train_bce 0.2368 | val_bce 0.3543\n",
            "Epoch 430 | train_bce 0.2374 | val_bce 0.3511\n",
            "Epoch 431 | train_bce 0.2359 | val_bce 0.3548\n",
            "Epoch 432 | train_bce 0.2363 | val_bce 0.3544\n",
            "Epoch 433 | train_bce 0.2364 | val_bce 0.3506\n",
            "Epoch 434 | train_bce 0.2363 | val_bce 0.3511\n",
            "Epoch 435 | train_bce 0.2352 | val_bce 0.3518\n",
            "Epoch 436 | train_bce 0.2353 | val_bce 0.3517\n",
            "Epoch 437 | train_bce 0.2357 | val_bce 0.3578\n",
            "Epoch 438 | train_bce 0.2354 | val_bce 0.3540\n",
            "Epoch 439 | train_bce 0.2349 | val_bce 0.3523\n",
            "Epoch 440 | train_bce 0.2340 | val_bce 0.3486\n",
            "Epoch 441 | train_bce 0.2340 | val_bce 0.3572\n",
            "Epoch 442 | train_bce 0.2335 | val_bce 0.3510\n",
            "Epoch 443 | train_bce 0.2343 | val_bce 0.3605\n",
            "Epoch 444 | train_bce 0.2345 | val_bce 0.3570\n",
            "Epoch 445 | train_bce 0.2350 | val_bce 0.3533\n",
            "Epoch 446 | train_bce 0.2336 | val_bce 0.3493\n",
            "Epoch 447 | train_bce 0.2336 | val_bce 0.3531\n",
            "Epoch 448 | train_bce 0.2330 | val_bce 0.3510\n",
            "Epoch 449 | train_bce 0.2333 | val_bce 0.3538\n",
            "Epoch 450 | train_bce 0.2330 | val_bce 0.3526\n",
            "Epoch 451 | train_bce 0.2319 | val_bce 0.3553\n",
            "Epoch 452 | train_bce 0.2326 | val_bce 0.3540\n",
            "Epoch 453 | train_bce 0.2319 | val_bce 0.3517\n",
            "Epoch 454 | train_bce 0.2323 | val_bce 0.3548\n",
            "Epoch 455 | train_bce 0.2316 | val_bce 0.3510\n",
            "Epoch 456 | train_bce 0.2316 | val_bce 0.3533\n",
            "Epoch 457 | train_bce 0.2309 | val_bce 0.3544\n",
            "Epoch 458 | train_bce 0.2320 | val_bce 0.3571\n",
            "Epoch 459 | train_bce 0.2324 | val_bce 0.3504\n",
            "Epoch 460 | train_bce 0.2309 | val_bce 0.3546\n",
            "Epoch 461 | train_bce 0.2304 | val_bce 0.3643\n",
            "Epoch 462 | train_bce 0.2336 | val_bce 0.3510\n",
            "Epoch 463 | train_bce 0.2308 | val_bce 0.3544\n",
            "Epoch 464 | train_bce 0.2309 | val_bce 0.3573\n",
            "Epoch 465 | train_bce 0.2304 | val_bce 0.3521\n",
            "Epoch 466 | train_bce 0.2297 | val_bce 0.3548\n",
            "Epoch 467 | train_bce 0.2305 | val_bce 0.3559\n",
            "Epoch 468 | train_bce 0.2304 | val_bce 0.3565\n",
            "Epoch 469 | train_bce 0.2302 | val_bce 0.3530\n",
            "Epoch 470 | train_bce 0.2292 | val_bce 0.3574\n",
            "Epoch 471 | train_bce 0.2290 | val_bce 0.3529\n",
            "Epoch 472 | train_bce 0.2283 | val_bce 0.3568\n",
            "Epoch 473 | train_bce 0.2289 | val_bce 0.3514\n",
            "Epoch 474 | train_bce 0.2271 | val_bce 0.3549\n",
            "Epoch 475 | train_bce 0.2273 | val_bce 0.3520\n",
            "Epoch 476 | train_bce 0.2270 | val_bce 0.3516\n",
            "Epoch 477 | train_bce 0.2272 | val_bce 0.3575\n",
            "Epoch 478 | train_bce 0.2271 | val_bce 0.3511\n",
            "Epoch 479 | train_bce 0.2270 | val_bce 0.3516\n",
            "Epoch 480 | train_bce 0.2269 | val_bce 0.3565\n",
            "Epoch 481 | train_bce 0.2268 | val_bce 0.3555\n",
            "Epoch 482 | train_bce 0.2277 | val_bce 0.3541\n",
            "Epoch 483 | train_bce 0.2272 | val_bce 0.3515\n",
            "Epoch 484 | train_bce 0.2267 | val_bce 0.3551\n",
            "Epoch 485 | train_bce 0.2267 | val_bce 0.3557\n",
            "Epoch 486 | train_bce 0.2262 | val_bce 0.3551\n",
            "Epoch 487 | train_bce 0.2268 | val_bce 0.3571\n",
            "Epoch 488 | train_bce 0.2274 | val_bce 0.3572\n",
            "Epoch 489 | train_bce 0.2267 | val_bce 0.3538\n",
            "Epoch 490 | train_bce 0.2259 | val_bce 0.3512\n",
            "Epoch 491 | train_bce 0.2249 | val_bce 0.3568\n",
            "Epoch 492 | train_bce 0.2245 | val_bce 0.3541\n",
            "Epoch 493 | train_bce 0.2236 | val_bce 0.3508\n",
            "Epoch 494 | train_bce 0.2236 | val_bce 0.3521\n",
            "Epoch 495 | train_bce 0.2232 | val_bce 0.3551\n",
            "Epoch 496 | train_bce 0.2236 | val_bce 0.3492\n",
            "Epoch 497 | train_bce 0.2231 | val_bce 0.3533\n",
            "Epoch 498 | train_bce 0.2224 | val_bce 0.3574\n",
            "Epoch 499 | train_bce 0.2224 | val_bce 0.3524\n",
            "Epoch 500 | train_bce 0.2228 | val_bce 0.3566\n",
            "Epoch 501 | train_bce 0.2232 | val_bce 0.3532\n",
            "Epoch 502 | train_bce 0.2235 | val_bce 0.3560\n",
            "Epoch 503 | train_bce 0.2230 | val_bce 0.3522\n",
            "Epoch 504 | train_bce 0.2226 | val_bce 0.3532\n",
            "Epoch 505 | train_bce 0.2223 | val_bce 0.3588\n",
            "Epoch 506 | train_bce 0.2228 | val_bce 0.3545\n",
            "Epoch 507 | train_bce 0.2234 | val_bce 0.3561\n",
            "Epoch 508 | train_bce 0.2234 | val_bce 0.3565\n",
            "Epoch 509 | train_bce 0.2225 | val_bce 0.3574\n",
            "Epoch 510 | train_bce 0.2219 | val_bce 0.3524\n",
            "Epoch 511 | train_bce 0.2208 | val_bce 0.3557\n",
            "Epoch 512 | train_bce 0.2210 | val_bce 0.3539\n",
            "Epoch 513 | train_bce 0.2206 | val_bce 0.3548\n",
            "Epoch 514 | train_bce 0.2204 | val_bce 0.3526\n",
            "Epoch 515 | train_bce 0.2198 | val_bce 0.3578\n",
            "Epoch 516 | train_bce 0.2203 | val_bce 0.3536\n",
            "Epoch 517 | train_bce 0.2201 | val_bce 0.3526\n",
            "Epoch 518 | train_bce 0.2209 | val_bce 0.3565\n",
            "Epoch 519 | train_bce 0.2204 | val_bce 0.3549\n",
            "Epoch 520 | train_bce 0.2193 | val_bce 0.3547\n",
            "Epoch 521 | train_bce 0.2195 | val_bce 0.3556\n",
            "Epoch 522 | train_bce 0.2197 | val_bce 0.3549\n",
            "Epoch 523 | train_bce 0.2197 | val_bce 0.3544\n",
            "Epoch 524 | train_bce 0.2193 | val_bce 0.3595\n",
            "Epoch 525 | train_bce 0.2200 | val_bce 0.3558\n",
            "Epoch 526 | train_bce 0.2218 | val_bce 0.3577\n",
            "Epoch 527 | train_bce 0.2205 | val_bce 0.3574\n",
            "Epoch 528 | train_bce 0.2196 | val_bce 0.3574\n",
            "Epoch 529 | train_bce 0.2215 | val_bce 0.3594\n",
            "Epoch 530 | train_bce 0.2208 | val_bce 0.3551\n",
            "Epoch 531 | train_bce 0.2196 | val_bce 0.3593\n",
            "Epoch 532 | train_bce 0.2204 | val_bce 0.3547\n",
            "Epoch 533 | train_bce 0.2195 | val_bce 0.3512\n",
            "Epoch 534 | train_bce 0.2188 | val_bce 0.3579\n",
            "Epoch 535 | train_bce 0.2182 | val_bce 0.3544\n",
            "Epoch 536 | train_bce 0.2179 | val_bce 0.3539\n",
            "Epoch 537 | train_bce 0.2175 | val_bce 0.3560\n",
            "Epoch 538 | train_bce 0.2168 | val_bce 0.3550\n",
            "Epoch 539 | train_bce 0.2175 | val_bce 0.3598\n",
            "Epoch 540 | train_bce 0.2175 | val_bce 0.3539\n",
            "Epoch 541 | train_bce 0.2191 | val_bce 0.3582\n",
            "Epoch 542 | train_bce 0.2183 | val_bce 0.3561\n",
            "Epoch 543 | train_bce 0.2175 | val_bce 0.3526\n",
            "Epoch 544 | train_bce 0.2167 | val_bce 0.3583\n",
            "Epoch 545 | train_bce 0.2169 | val_bce 0.3527\n",
            "Epoch 546 | train_bce 0.2159 | val_bce 0.3583\n",
            "Epoch 547 | train_bce 0.2154 | val_bce 0.3530\n",
            "Epoch 548 | train_bce 0.2148 | val_bce 0.3562\n",
            "Epoch 549 | train_bce 0.2154 | val_bce 0.3570\n",
            "Epoch 550 | train_bce 0.2157 | val_bce 0.3572\n",
            "Epoch 551 | train_bce 0.2150 | val_bce 0.3523\n",
            "Epoch 552 | train_bce 0.2147 | val_bce 0.3538\n",
            "Epoch 553 | train_bce 0.2144 | val_bce 0.3611\n",
            "Epoch 554 | train_bce 0.2155 | val_bce 0.3495\n",
            "Epoch 555 | train_bce 0.2154 | val_bce 0.3576\n",
            "Epoch 556 | train_bce 0.2146 | val_bce 0.3585\n",
            "Epoch 557 | train_bce 0.2142 | val_bce 0.3559\n",
            "Epoch 558 | train_bce 0.2143 | val_bce 0.3550\n",
            "Epoch 559 | train_bce 0.2137 | val_bce 0.3538\n",
            "Epoch 560 | train_bce 0.2134 | val_bce 0.3563\n",
            "Epoch 561 | train_bce 0.2133 | val_bce 0.3545\n",
            "Epoch 562 | train_bce 0.2135 | val_bce 0.3568\n",
            "Epoch 563 | train_bce 0.2133 | val_bce 0.3578\n",
            "Epoch 564 | train_bce 0.2145 | val_bce 0.3553\n",
            "Epoch 565 | train_bce 0.2130 | val_bce 0.3583\n",
            "Epoch 566 | train_bce 0.2141 | val_bce 0.3544\n",
            "Epoch 567 | train_bce 0.2124 | val_bce 0.3532\n",
            "Epoch 568 | train_bce 0.2129 | val_bce 0.3569\n",
            "Epoch 569 | train_bce 0.2123 | val_bce 0.3564\n",
            "Epoch 570 | train_bce 0.2121 | val_bce 0.3539\n",
            "Epoch 571 | train_bce 0.2126 | val_bce 0.3597\n",
            "Epoch 572 | train_bce 0.2129 | val_bce 0.3548\n",
            "Epoch 573 | train_bce 0.2132 | val_bce 0.3616\n",
            "Epoch 574 | train_bce 0.2122 | val_bce 0.3558\n",
            "Epoch 575 | train_bce 0.2124 | val_bce 0.3533\n",
            "Epoch 576 | train_bce 0.2130 | val_bce 0.3602\n",
            "Epoch 577 | train_bce 0.2124 | val_bce 0.3554\n",
            "Epoch 578 | train_bce 0.2117 | val_bce 0.3592\n",
            "Epoch 579 | train_bce 0.2119 | val_bce 0.3578\n",
            "Epoch 580 | train_bce 0.2109 | val_bce 0.3508\n",
            "Epoch 581 | train_bce 0.2116 | val_bce 0.3578\n",
            "Epoch 582 | train_bce 0.2109 | val_bce 0.3593\n",
            "Epoch 583 | train_bce 0.2106 | val_bce 0.3553\n",
            "Epoch 584 | train_bce 0.2107 | val_bce 0.3594\n",
            "Epoch 585 | train_bce 0.2104 | val_bce 0.3515\n",
            "Epoch 586 | train_bce 0.2102 | val_bce 0.3584\n",
            "Epoch 587 | train_bce 0.2103 | val_bce 0.3587\n",
            "Epoch 588 | train_bce 0.2098 | val_bce 0.3543\n",
            "Epoch 589 | train_bce 0.2110 | val_bce 0.3568\n",
            "Epoch 590 | train_bce 0.2101 | val_bce 0.3603\n",
            "Epoch 591 | train_bce 0.2106 | val_bce 0.3566\n",
            "Epoch 592 | train_bce 0.2089 | val_bce 0.3554\n",
            "Epoch 593 | train_bce 0.2091 | val_bce 0.3524\n",
            "Epoch 594 | train_bce 0.2090 | val_bce 0.3603\n",
            "Epoch 595 | train_bce 0.2088 | val_bce 0.3575\n",
            "Epoch 596 | train_bce 0.2089 | val_bce 0.3524\n",
            "Epoch 597 | train_bce 0.2082 | val_bce 0.3578\n",
            "Epoch 598 | train_bce 0.2086 | val_bce 0.3573\n",
            "Epoch 599 | train_bce 0.2078 | val_bce 0.3559\n",
            "Epoch 600 | train_bce 0.2080 | val_bce 0.3560\n",
            "Epoch 601 | train_bce 0.2073 | val_bce 0.3575\n",
            "Epoch 602 | train_bce 0.2085 | val_bce 0.3573\n",
            "Epoch 603 | train_bce 0.2078 | val_bce 0.3561\n",
            "Epoch 604 | train_bce 0.2082 | val_bce 0.3557\n",
            "Epoch 605 | train_bce 0.2078 | val_bce 0.3591\n",
            "Epoch 606 | train_bce 0.2080 | val_bce 0.3554\n",
            "Epoch 607 | train_bce 0.2073 | val_bce 0.3566\n",
            "Epoch 608 | train_bce 0.2068 | val_bce 0.3582\n",
            "Epoch 609 | train_bce 0.2063 | val_bce 0.3561\n",
            "Epoch 610 | train_bce 0.2068 | val_bce 0.3556\n",
            "Epoch 611 | train_bce 0.2064 | val_bce 0.3600\n",
            "Epoch 612 | train_bce 0.2075 | val_bce 0.3537\n",
            "Epoch 613 | train_bce 0.2059 | val_bce 0.3550\n",
            "Epoch 614 | train_bce 0.2054 | val_bce 0.3562\n",
            "Epoch 615 | train_bce 0.2052 | val_bce 0.3553\n",
            "Epoch 616 | train_bce 0.2056 | val_bce 0.3564\n",
            "Epoch 617 | train_bce 0.2051 | val_bce 0.3560\n",
            "Epoch 618 | train_bce 0.2063 | val_bce 0.3564\n",
            "Epoch 619 | train_bce 0.2055 | val_bce 0.3628\n",
            "Epoch 620 | train_bce 0.2070 | val_bce 0.3551\n",
            "Epoch 621 | train_bce 0.2068 | val_bce 0.3597\n",
            "Epoch 622 | train_bce 0.2059 | val_bce 0.3573\n",
            "Epoch 623 | train_bce 0.2063 | val_bce 0.3572\n",
            "Epoch 624 | train_bce 0.2050 | val_bce 0.3578\n",
            "Epoch 625 | train_bce 0.2056 | val_bce 0.3584\n",
            "Epoch 626 | train_bce 0.2057 | val_bce 0.3561\n",
            "Epoch 627 | train_bce 0.2050 | val_bce 0.3575\n",
            "Epoch 628 | train_bce 0.2042 | val_bce 0.3556\n",
            "Epoch 629 | train_bce 0.2039 | val_bce 0.3561\n",
            "Epoch 630 | train_bce 0.2031 | val_bce 0.3558\n",
            "Epoch 631 | train_bce 0.2038 | val_bce 0.3556\n",
            "Epoch 632 | train_bce 0.2031 | val_bce 0.3586\n",
            "Epoch 633 | train_bce 0.2031 | val_bce 0.3537\n",
            "Epoch 634 | train_bce 0.2025 | val_bce 0.3570\n",
            "Epoch 635 | train_bce 0.2029 | val_bce 0.3583\n",
            "Epoch 636 | train_bce 0.2027 | val_bce 0.3566\n",
            "Epoch 637 | train_bce 0.2021 | val_bce 0.3559\n",
            "Epoch 638 | train_bce 0.2018 | val_bce 0.3570\n",
            "Epoch 639 | train_bce 0.2016 | val_bce 0.3556\n",
            "Epoch 640 | train_bce 0.2019 | val_bce 0.3577\n",
            "Epoch 641 | train_bce 0.2016 | val_bce 0.3543\n",
            "Epoch 642 | train_bce 0.2019 | val_bce 0.3587\n",
            "Epoch 643 | train_bce 0.2022 | val_bce 0.3571\n",
            "Epoch 644 | train_bce 0.2015 | val_bce 0.3559\n",
            "Epoch 645 | train_bce 0.2014 | val_bce 0.3571\n",
            "Epoch 646 | train_bce 0.2013 | val_bce 0.3565\n",
            "Epoch 647 | train_bce 0.2020 | val_bce 0.3606\n",
            "Epoch 648 | train_bce 0.2015 | val_bce 0.3537\n",
            "Epoch 649 | train_bce 0.2011 | val_bce 0.3601\n",
            "Epoch 650 | train_bce 0.2013 | val_bce 0.3549\n",
            "Epoch 651 | train_bce 0.2009 | val_bce 0.3627\n",
            "Epoch 652 | train_bce 0.2020 | val_bce 0.3568\n",
            "Epoch 653 | train_bce 0.2011 | val_bce 0.3550\n",
            "Epoch 654 | train_bce 0.2004 | val_bce 0.3557\n",
            "Epoch 655 | train_bce 0.2007 | val_bce 0.3576\n",
            "Epoch 656 | train_bce 0.1999 | val_bce 0.3599\n",
            "Epoch 657 | train_bce 0.2002 | val_bce 0.3548\n",
            "Epoch 658 | train_bce 0.2002 | val_bce 0.3600\n",
            "Epoch 659 | train_bce 0.2010 | val_bce 0.3592\n",
            "Epoch 660 | train_bce 0.2003 | val_bce 0.3564\n",
            "Epoch 661 | train_bce 0.2000 | val_bce 0.3574\n",
            "Epoch 662 | train_bce 0.1993 | val_bce 0.3580\n",
            "Epoch 663 | train_bce 0.1992 | val_bce 0.3556\n",
            "Epoch 664 | train_bce 0.1988 | val_bce 0.3575\n",
            "Epoch 665 | train_bce 0.1988 | val_bce 0.3625\n",
            "Epoch 666 | train_bce 0.1992 | val_bce 0.3568\n",
            "Epoch 667 | train_bce 0.1992 | val_bce 0.3548\n",
            "Epoch 668 | train_bce 0.1984 | val_bce 0.3574\n",
            "Epoch 669 | train_bce 0.1988 | val_bce 0.3591\n",
            "Epoch 670 | train_bce 0.1989 | val_bce 0.3609\n",
            "Epoch 671 | train_bce 0.1991 | val_bce 0.3554\n",
            "Epoch 672 | train_bce 0.1987 | val_bce 0.3563\n",
            "Epoch 673 | train_bce 0.1984 | val_bce 0.3590\n",
            "Epoch 674 | train_bce 0.1989 | val_bce 0.3632\n",
            "Epoch 675 | train_bce 0.2005 | val_bce 0.3591\n",
            "Epoch 676 | train_bce 0.1992 | val_bce 0.3574\n",
            "Epoch 677 | train_bce 0.1996 | val_bce 0.3579\n",
            "Epoch 678 | train_bce 0.1995 | val_bce 0.3599\n",
            "Epoch 679 | train_bce 0.1995 | val_bce 0.3603\n",
            "Epoch 680 | train_bce 0.2018 | val_bce 0.3592\n",
            "Epoch 681 | train_bce 0.2014 | val_bce 0.3617\n",
            "Epoch 682 | train_bce 0.1992 | val_bce 0.3572\n",
            "Epoch 683 | train_bce 0.2001 | val_bce 0.3569\n",
            "Epoch 684 | train_bce 0.1980 | val_bce 0.3589\n",
            "Epoch 685 | train_bce 0.1982 | val_bce 0.3545\n",
            "Epoch 686 | train_bce 0.1977 | val_bce 0.3585\n",
            "Epoch 687 | train_bce 0.1977 | val_bce 0.3569\n",
            "Epoch 688 | train_bce 0.1961 | val_bce 0.3557\n",
            "Epoch 689 | train_bce 0.1957 | val_bce 0.3579\n",
            "Epoch 690 | train_bce 0.1960 | val_bce 0.3569\n",
            "Epoch 691 | train_bce 0.1955 | val_bce 0.3550\n",
            "Epoch 692 | train_bce 0.1968 | val_bce 0.3560\n",
            "Epoch 693 | train_bce 0.1955 | val_bce 0.3601\n",
            "Epoch 694 | train_bce 0.1957 | val_bce 0.3584\n",
            "Epoch 695 | train_bce 0.1959 | val_bce 0.3549\n",
            "Epoch 696 | train_bce 0.1961 | val_bce 0.3620\n",
            "Epoch 697 | train_bce 0.1972 | val_bce 0.3572\n",
            "Epoch 698 | train_bce 0.1955 | val_bce 0.3602\n",
            "Epoch 699 | train_bce 0.1950 | val_bce 0.3591\n",
            "Epoch 700 | train_bce 0.1947 | val_bce 0.3523\n",
            "Epoch 701 | train_bce 0.1948 | val_bce 0.3589\n",
            "Epoch 702 | train_bce 0.1946 | val_bce 0.3586\n",
            "Epoch 703 | train_bce 0.1943 | val_bce 0.3607\n",
            "Epoch 704 | train_bce 0.1947 | val_bce 0.3600\n",
            "Epoch 705 | train_bce 0.1947 | val_bce 0.3555\n",
            "Epoch 706 | train_bce 0.1952 | val_bce 0.3597\n",
            "Epoch 707 | train_bce 0.1944 | val_bce 0.3647\n",
            "Epoch 708 | train_bce 0.1948 | val_bce 0.3558\n",
            "Epoch 709 | train_bce 0.1940 | val_bce 0.3570\n",
            "Epoch 710 | train_bce 0.1937 | val_bce 0.3565\n",
            "Epoch 711 | train_bce 0.1933 | val_bce 0.3608\n",
            "Epoch 712 | train_bce 0.1933 | val_bce 0.3590\n",
            "Epoch 713 | train_bce 0.1933 | val_bce 0.3572\n",
            "Epoch 714 | train_bce 0.1939 | val_bce 0.3602\n",
            "Epoch 715 | train_bce 0.1937 | val_bce 0.3627\n",
            "Epoch 716 | train_bce 0.1949 | val_bce 0.3619\n",
            "Epoch 717 | train_bce 0.1946 | val_bce 0.3583\n",
            "Epoch 718 | train_bce 0.1929 | val_bce 0.3571\n",
            "Epoch 719 | train_bce 0.1936 | val_bce 0.3576\n",
            "Epoch 720 | train_bce 0.1927 | val_bce 0.3621\n",
            "Epoch 721 | train_bce 0.1934 | val_bce 0.3648\n",
            "Epoch 722 | train_bce 0.1931 | val_bce 0.3567\n",
            "Epoch 723 | train_bce 0.1921 | val_bce 0.3580\n",
            "Epoch 724 | train_bce 0.1926 | val_bce 0.3623\n",
            "Epoch 725 | train_bce 0.1927 | val_bce 0.3574\n",
            "Epoch 726 | train_bce 0.1914 | val_bce 0.3553\n",
            "Epoch 727 | train_bce 0.1916 | val_bce 0.3563\n",
            "Epoch 728 | train_bce 0.1919 | val_bce 0.3581\n",
            "Epoch 729 | train_bce 0.1924 | val_bce 0.3605\n",
            "Epoch 730 | train_bce 0.1924 | val_bce 0.3620\n",
            "Epoch 731 | train_bce 0.1922 | val_bce 0.3595\n",
            "Epoch 732 | train_bce 0.1923 | val_bce 0.3542\n",
            "Epoch 733 | train_bce 0.1911 | val_bce 0.3580\n",
            "Epoch 734 | train_bce 0.1905 | val_bce 0.3614\n",
            "Epoch 735 | train_bce 0.1904 | val_bce 0.3570\n",
            "Epoch 736 | train_bce 0.1911 | val_bce 0.3619\n",
            "Epoch 737 | train_bce 0.1909 | val_bce 0.3558\n",
            "Epoch 738 | train_bce 0.1902 | val_bce 0.3570\n",
            "Epoch 739 | train_bce 0.1903 | val_bce 0.3595\n",
            "Epoch 740 | train_bce 0.1900 | val_bce 0.3550\n",
            "Epoch 741 | train_bce 0.1892 | val_bce 0.3600\n",
            "Epoch 742 | train_bce 0.1892 | val_bce 0.3572\n",
            "Epoch 743 | train_bce 0.1894 | val_bce 0.3558\n",
            "Epoch 744 | train_bce 0.1898 | val_bce 0.3581\n",
            "Epoch 745 | train_bce 0.1897 | val_bce 0.3597\n",
            "Epoch 746 | train_bce 0.1890 | val_bce 0.3572\n",
            "Epoch 747 | train_bce 0.1886 | val_bce 0.3584\n",
            "Epoch 748 | train_bce 0.1886 | val_bce 0.3578\n",
            "Epoch 749 | train_bce 0.1886 | val_bce 0.3563\n",
            "Epoch 750 | train_bce 0.1889 | val_bce 0.3603\n",
            "Epoch 751 | train_bce 0.1884 | val_bce 0.3587\n",
            "Epoch 752 | train_bce 0.1887 | val_bce 0.3564\n",
            "Epoch 753 | train_bce 0.1884 | val_bce 0.3578\n",
            "Epoch 754 | train_bce 0.1878 | val_bce 0.3574\n",
            "Epoch 755 | train_bce 0.1879 | val_bce 0.3562\n",
            "Epoch 756 | train_bce 0.1880 | val_bce 0.3626\n",
            "Epoch 757 | train_bce 0.1886 | val_bce 0.3563\n",
            "Epoch 758 | train_bce 0.1879 | val_bce 0.3586\n",
            "Epoch 759 | train_bce 0.1881 | val_bce 0.3603\n",
            "Epoch 760 | train_bce 0.1875 | val_bce 0.3571\n",
            "Epoch 761 | train_bce 0.1874 | val_bce 0.3567\n",
            "Epoch 762 | train_bce 0.1875 | val_bce 0.3628\n",
            "Epoch 763 | train_bce 0.1870 | val_bce 0.3568\n",
            "Epoch 764 | train_bce 0.1862 | val_bce 0.3592\n",
            "Epoch 765 | train_bce 0.1865 | val_bce 0.3565\n",
            "Epoch 766 | train_bce 0.1859 | val_bce 0.3609\n",
            "Epoch 767 | train_bce 0.1864 | val_bce 0.3587\n",
            "Epoch 768 | train_bce 0.1860 | val_bce 0.3589\n",
            "Epoch 769 | train_bce 0.1876 | val_bce 0.3601\n",
            "Epoch 770 | train_bce 0.1869 | val_bce 0.3587\n",
            "Epoch 771 | train_bce 0.1858 | val_bce 0.3556\n",
            "Epoch 772 | train_bce 0.1872 | val_bce 0.3598\n",
            "Epoch 773 | train_bce 0.1870 | val_bce 0.3600\n",
            "Epoch 774 | train_bce 0.1862 | val_bce 0.3568\n",
            "Epoch 775 | train_bce 0.1856 | val_bce 0.3571\n",
            "Epoch 776 | train_bce 0.1860 | val_bce 0.3620\n",
            "Epoch 777 | train_bce 0.1864 | val_bce 0.3603\n",
            "Epoch 778 | train_bce 0.1863 | val_bce 0.3607\n",
            "Epoch 779 | train_bce 0.1859 | val_bce 0.3577\n",
            "Epoch 780 | train_bce 0.1864 | val_bce 0.3597\n",
            "Epoch 781 | train_bce 0.1870 | val_bce 0.3609\n",
            "Epoch 782 | train_bce 0.1867 | val_bce 0.3610\n",
            "Epoch 783 | train_bce 0.1863 | val_bce 0.3649\n",
            "Epoch 784 | train_bce 0.1857 | val_bce 0.3635\n",
            "Epoch 785 | train_bce 0.1855 | val_bce 0.3552\n",
            "Epoch 786 | train_bce 0.1859 | val_bce 0.3595\n",
            "Epoch 787 | train_bce 0.1863 | val_bce 0.3598\n",
            "Epoch 788 | train_bce 0.1861 | val_bce 0.3576\n",
            "Epoch 789 | train_bce 0.1852 | val_bce 0.3635\n",
            "Epoch 790 | train_bce 0.1844 | val_bce 0.3560\n",
            "Epoch 791 | train_bce 0.1840 | val_bce 0.3609\n",
            "Epoch 792 | train_bce 0.1848 | val_bce 0.3571\n",
            "Epoch 793 | train_bce 0.1837 | val_bce 0.3609\n",
            "Epoch 794 | train_bce 0.1837 | val_bce 0.3562\n",
            "Epoch 795 | train_bce 0.1838 | val_bce 0.3650\n",
            "Epoch 796 | train_bce 0.1855 | val_bce 0.3582\n",
            "Epoch 797 | train_bce 0.1848 | val_bce 0.3611\n",
            "Epoch 798 | train_bce 0.1841 | val_bce 0.3595\n",
            "Epoch 799 | train_bce 0.1845 | val_bce 0.3578\n",
            "Epoch 800 | train_bce 0.1838 | val_bce 0.3604\n",
            "Epoch 801 | train_bce 0.1838 | val_bce 0.3622\n",
            "Epoch 802 | train_bce 0.1837 | val_bce 0.3610\n",
            "Epoch 803 | train_bce 0.1833 | val_bce 0.3572\n",
            "Epoch 804 | train_bce 0.1823 | val_bce 0.3595\n",
            "Epoch 805 | train_bce 0.1828 | val_bce 0.3594\n",
            "Epoch 806 | train_bce 0.1824 | val_bce 0.3586\n",
            "Epoch 807 | train_bce 0.1827 | val_bce 0.3618\n",
            "Epoch 808 | train_bce 0.1826 | val_bce 0.3629\n",
            "Epoch 809 | train_bce 0.1837 | val_bce 0.3607\n",
            "Epoch 810 | train_bce 0.1825 | val_bce 0.3613\n",
            "Epoch 811 | train_bce 0.1833 | val_bce 0.3562\n",
            "Epoch 812 | train_bce 0.1821 | val_bce 0.3604\n",
            "Epoch 813 | train_bce 0.1834 | val_bce 0.3595\n",
            "Epoch 814 | train_bce 0.1837 | val_bce 0.3622\n",
            "Epoch 815 | train_bce 0.1833 | val_bce 0.3607\n",
            "Epoch 816 | train_bce 0.1831 | val_bce 0.3653\n",
            "Epoch 817 | train_bce 0.1831 | val_bce 0.3645\n",
            "Epoch 818 | train_bce 0.1824 | val_bce 0.3586\n",
            "Epoch 819 | train_bce 0.1830 | val_bce 0.3559\n",
            "Epoch 820 | train_bce 0.1820 | val_bce 0.3643\n",
            "Epoch 821 | train_bce 0.1816 | val_bce 0.3580\n",
            "Epoch 822 | train_bce 0.1810 | val_bce 0.3561\n",
            "Epoch 823 | train_bce 0.1809 | val_bce 0.3590\n",
            "Epoch 824 | train_bce 0.1811 | val_bce 0.3612\n",
            "Epoch 825 | train_bce 0.1815 | val_bce 0.3577\n",
            "Epoch 826 | train_bce 0.1811 | val_bce 0.3635\n",
            "Epoch 827 | train_bce 0.1800 | val_bce 0.3591\n",
            "Epoch 828 | train_bce 0.1798 | val_bce 0.3595\n",
            "Epoch 829 | train_bce 0.1800 | val_bce 0.3565\n",
            "Epoch 830 | train_bce 0.1792 | val_bce 0.3599\n",
            "Epoch 831 | train_bce 0.1794 | val_bce 0.3565\n",
            "Epoch 832 | train_bce 0.1791 | val_bce 0.3599\n",
            "Epoch 833 | train_bce 0.1791 | val_bce 0.3603\n",
            "Epoch 834 | train_bce 0.1788 | val_bce 0.3576\n",
            "Epoch 835 | train_bce 0.1789 | val_bce 0.3574\n",
            "Epoch 836 | train_bce 0.1784 | val_bce 0.3622\n",
            "Epoch 837 | train_bce 0.1781 | val_bce 0.3558\n",
            "Epoch 838 | train_bce 0.1787 | val_bce 0.3606\n",
            "Epoch 839 | train_bce 0.1787 | val_bce 0.3595\n",
            "Epoch 840 | train_bce 0.1788 | val_bce 0.3624\n",
            "Epoch 841 | train_bce 0.1782 | val_bce 0.3564\n",
            "Epoch 842 | train_bce 0.1787 | val_bce 0.3622\n",
            "Epoch 843 | train_bce 0.1785 | val_bce 0.3582\n",
            "Epoch 844 | train_bce 0.1777 | val_bce 0.3567\n",
            "Epoch 845 | train_bce 0.1776 | val_bce 0.3625\n",
            "Epoch 846 | train_bce 0.1778 | val_bce 0.3673\n",
            "Epoch 847 | train_bce 0.1791 | val_bce 0.3621\n",
            "Epoch 848 | train_bce 0.1793 | val_bce 0.3570\n",
            "Epoch 849 | train_bce 0.1785 | val_bce 0.3635\n",
            "Epoch 850 | train_bce 0.1789 | val_bce 0.3598\n",
            "Epoch 851 | train_bce 0.1784 | val_bce 0.3605\n",
            "Epoch 852 | train_bce 0.1773 | val_bce 0.3627\n",
            "Epoch 853 | train_bce 0.1780 | val_bce 0.3623\n",
            "Epoch 854 | train_bce 0.1775 | val_bce 0.3591\n",
            "Epoch 855 | train_bce 0.1784 | val_bce 0.3619\n",
            "Epoch 856 | train_bce 0.1779 | val_bce 0.3627\n",
            "Epoch 857 | train_bce 0.1776 | val_bce 0.3598\n",
            "Epoch 858 | train_bce 0.1765 | val_bce 0.3574\n",
            "Epoch 859 | train_bce 0.1759 | val_bce 0.3574\n",
            "Epoch 860 | train_bce 0.1761 | val_bce 0.3608\n",
            "Epoch 861 | train_bce 0.1757 | val_bce 0.3572\n",
            "Epoch 862 | train_bce 0.1755 | val_bce 0.3588\n",
            "Epoch 863 | train_bce 0.1757 | val_bce 0.3636\n",
            "Epoch 864 | train_bce 0.1769 | val_bce 0.3608\n",
            "Epoch 865 | train_bce 0.1768 | val_bce 0.3618\n",
            "Epoch 866 | train_bce 0.1765 | val_bce 0.3622\n",
            "Epoch 867 | train_bce 0.1762 | val_bce 0.3589\n",
            "Epoch 868 | train_bce 0.1769 | val_bce 0.3564\n",
            "Epoch 869 | train_bce 0.1773 | val_bce 0.3674\n",
            "Epoch 870 | train_bce 0.1772 | val_bce 0.3645\n",
            "Epoch 871 | train_bce 0.1768 | val_bce 0.3615\n",
            "Epoch 872 | train_bce 0.1759 | val_bce 0.3591\n",
            "Epoch 873 | train_bce 0.1755 | val_bce 0.3598\n",
            "Epoch 874 | train_bce 0.1754 | val_bce 0.3615\n",
            "Epoch 875 | train_bce 0.1749 | val_bce 0.3577\n",
            "Epoch 876 | train_bce 0.1748 | val_bce 0.3601\n",
            "Epoch 877 | train_bce 0.1744 | val_bce 0.3608\n",
            "Epoch 878 | train_bce 0.1751 | val_bce 0.3610\n",
            "Epoch 879 | train_bce 0.1747 | val_bce 0.3590\n",
            "Epoch 880 | train_bce 0.1753 | val_bce 0.3582\n",
            "Epoch 881 | train_bce 0.1745 | val_bce 0.3626\n",
            "Epoch 882 | train_bce 0.1752 | val_bce 0.3587\n",
            "Epoch 883 | train_bce 0.1753 | val_bce 0.3614\n",
            "Epoch 884 | train_bce 0.1751 | val_bce 0.3647\n",
            "Epoch 885 | train_bce 0.1756 | val_bce 0.3660\n",
            "Epoch 886 | train_bce 0.1758 | val_bce 0.3610\n",
            "Epoch 887 | train_bce 0.1762 | val_bce 0.3596\n",
            "Epoch 888 | train_bce 0.1746 | val_bce 0.3627\n",
            "Epoch 889 | train_bce 0.1764 | val_bce 0.3590\n",
            "Epoch 890 | train_bce 0.1752 | val_bce 0.3644\n",
            "Epoch 891 | train_bce 0.1755 | val_bce 0.3678\n",
            "Epoch 892 | train_bce 0.1746 | val_bce 0.3633\n",
            "Epoch 893 | train_bce 0.1737 | val_bce 0.3576\n",
            "Epoch 894 | train_bce 0.1733 | val_bce 0.3598\n",
            "Epoch 895 | train_bce 0.1728 | val_bce 0.3606\n",
            "Epoch 896 | train_bce 0.1733 | val_bce 0.3578\n",
            "Epoch 897 | train_bce 0.1723 | val_bce 0.3629\n",
            "Epoch 898 | train_bce 0.1722 | val_bce 0.3613\n",
            "Epoch 899 | train_bce 0.1719 | val_bce 0.3647\n",
            "Epoch 900 | train_bce 0.1720 | val_bce 0.3593\n",
            "Epoch 901 | train_bce 0.1723 | val_bce 0.3621\n",
            "Epoch 902 | train_bce 0.1722 | val_bce 0.3615\n",
            "Epoch 903 | train_bce 0.1723 | val_bce 0.3606\n",
            "Epoch 904 | train_bce 0.1716 | val_bce 0.3589\n",
            "Epoch 905 | train_bce 0.1720 | val_bce 0.3615\n",
            "Epoch 906 | train_bce 0.1717 | val_bce 0.3639\n",
            "Epoch 907 | train_bce 0.1717 | val_bce 0.3608\n",
            "Epoch 908 | train_bce 0.1714 | val_bce 0.3644\n",
            "Epoch 909 | train_bce 0.1714 | val_bce 0.3596\n",
            "Epoch 910 | train_bce 0.1706 | val_bce 0.3611\n",
            "Epoch 911 | train_bce 0.1712 | val_bce 0.3602\n",
            "Epoch 912 | train_bce 0.1707 | val_bce 0.3640\n",
            "Epoch 913 | train_bce 0.1717 | val_bce 0.3644\n",
            "Epoch 914 | train_bce 0.1719 | val_bce 0.3624\n",
            "Epoch 915 | train_bce 0.1726 | val_bce 0.3585\n",
            "Epoch 916 | train_bce 0.1720 | val_bce 0.3617\n",
            "Epoch 917 | train_bce 0.1723 | val_bce 0.3612\n",
            "Epoch 918 | train_bce 0.1724 | val_bce 0.3626\n",
            "Epoch 919 | train_bce 0.1717 | val_bce 0.3679\n",
            "Epoch 920 | train_bce 0.1728 | val_bce 0.3660\n",
            "Epoch 921 | train_bce 0.1727 | val_bce 0.3673\n",
            "Epoch 922 | train_bce 0.1730 | val_bce 0.3619\n",
            "Epoch 923 | train_bce 0.1727 | val_bce 0.3599\n",
            "Epoch 924 | train_bce 0.1722 | val_bce 0.3622\n",
            "Epoch 925 | train_bce 0.1714 | val_bce 0.3637\n",
            "Epoch 926 | train_bce 0.1718 | val_bce 0.3575\n",
            "Epoch 927 | train_bce 0.1697 | val_bce 0.3651\n",
            "Epoch 928 | train_bce 0.1699 | val_bce 0.3620\n",
            "Epoch 929 | train_bce 0.1703 | val_bce 0.3648\n",
            "Epoch 930 | train_bce 0.1703 | val_bce 0.3637\n",
            "Epoch 931 | train_bce 0.1711 | val_bce 0.3586\n",
            "Epoch 932 | train_bce 0.1698 | val_bce 0.3623\n",
            "Epoch 933 | train_bce 0.1713 | val_bce 0.3676\n",
            "Epoch 934 | train_bce 0.1722 | val_bce 0.3617\n",
            "Epoch 935 | train_bce 0.1713 | val_bce 0.3702\n",
            "Epoch 936 | train_bce 0.1713 | val_bce 0.3644\n",
            "Epoch 937 | train_bce 0.1705 | val_bce 0.3591\n",
            "Epoch 938 | train_bce 0.1699 | val_bce 0.3622\n",
            "Epoch 939 | train_bce 0.1693 | val_bce 0.3672\n",
            "Epoch 940 | train_bce 0.1695 | val_bce 0.3596\n",
            "Epoch 941 | train_bce 0.1698 | val_bce 0.3667\n",
            "Epoch 942 | train_bce 0.1696 | val_bce 0.3638\n",
            "Epoch 943 | train_bce 0.1688 | val_bce 0.3595\n",
            "Epoch 944 | train_bce 0.1680 | val_bce 0.3628\n",
            "Epoch 945 | train_bce 0.1679 | val_bce 0.3596\n",
            "Epoch 946 | train_bce 0.1678 | val_bce 0.3626\n",
            "Epoch 947 | train_bce 0.1686 | val_bce 0.3650\n",
            "Epoch 948 | train_bce 0.1682 | val_bce 0.3641\n",
            "Epoch 949 | train_bce 0.1690 | val_bce 0.3638\n",
            "Epoch 950 | train_bce 0.1684 | val_bce 0.3622\n",
            "Epoch 951 | train_bce 0.1688 | val_bce 0.3598\n",
            "Epoch 952 | train_bce 0.1681 | val_bce 0.3612\n",
            "Epoch 953 | train_bce 0.1676 | val_bce 0.3603\n",
            "Epoch 954 | train_bce 0.1670 | val_bce 0.3619\n",
            "Epoch 955 | train_bce 0.1670 | val_bce 0.3636\n",
            "Epoch 956 | train_bce 0.1678 | val_bce 0.3626\n"
          ]
        },
        {
          "output_type": "error",
          "ename": "KeyboardInterrupt",
          "evalue": "",
          "traceback": [
            "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
            "\u001b[0;31mKeyboardInterrupt\u001b[0m                         Traceback (most recent call last)",
            "\u001b[0;32m/tmp/ipython-input-3953316811.py\u001b[0m in \u001b[0;36m<cell line: 0>\u001b[0;34m()\u001b[0m\n\u001b[1;32m     25\u001b[0m     \u001b[0;31m# train\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     26\u001b[0m     \u001b[0mmodel\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mtrain\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m;\u001b[0m \u001b[0mtotal\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;36m0.0\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 27\u001b[0;31m     \u001b[0;32mfor\u001b[0m \u001b[0mx\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mA\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mdl_tr\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     28\u001b[0m         \u001b[0mx\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mx\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mto\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mdevice\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m;\u001b[0m \u001b[0mA\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mA\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mto\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mdevice\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     29\u001b[0m         \u001b[0mlogits\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mmodel\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mx\u001b[0m\u001b[0;34m)\u001b[0m                              \u001b[0;31m# (B,N,N)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m/usr/local/lib/python3.12/dist-packages/torch/utils/data/dataloader.py\u001b[0m in \u001b[0;36m__next__\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m    732\u001b[0m                 \u001b[0;31m# TODO(https://github.com/pytorch/pytorch/issues/76750)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    733\u001b[0m                 \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_reset\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m  \u001b[0;31m# type: ignore[call-arg]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 734\u001b[0;31m             \u001b[0mdata\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_next_data\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    735\u001b[0m             \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_num_yielded\u001b[0m \u001b[0;34m+=\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    736\u001b[0m             if (\n",
            "\u001b[0;32m/usr/local/lib/python3.12/dist-packages/torch/utils/data/dataloader.py\u001b[0m in \u001b[0;36m_next_data\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m    788\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0m_next_data\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    789\u001b[0m         \u001b[0mindex\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_next_index\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m  \u001b[0;31m# may raise StopIteration\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 790\u001b[0;31m         \u001b[0mdata\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_dataset_fetcher\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mfetch\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mindex\u001b[0m\u001b[0;34m)\u001b[0m  \u001b[0;31m# may raise StopIteration\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    791\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_pin_memory\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    792\u001b[0m             \u001b[0mdata\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0m_utils\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mpin_memory\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mpin_memory\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mdata\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_pin_memory_device\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m/usr/local/lib/python3.12/dist-packages/torch/utils/data/_utils/fetch.py\u001b[0m in \u001b[0;36mfetch\u001b[0;34m(self, possibly_batched_index)\u001b[0m\n\u001b[1;32m     48\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mauto_collation\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     49\u001b[0m             \u001b[0;32mif\u001b[0m \u001b[0mhasattr\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdataset\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m\"__getitems__\"\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;32mand\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdataset\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m__getitems__\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 50\u001b[0;31m                 \u001b[0mdata\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdataset\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m__getitems__\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mpossibly_batched_index\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     51\u001b[0m             \u001b[0;32melse\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     52\u001b[0m                 \u001b[0mdata\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;34m[\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdataset\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0midx\u001b[0m\u001b[0;34m]\u001b[0m \u001b[0;32mfor\u001b[0m \u001b[0midx\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mpossibly_batched_index\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m/usr/local/lib/python3.12/dist-packages/torch/utils/data/dataset.py\u001b[0m in \u001b[0;36m__getitems__\u001b[0;34m(self, indices)\u001b[0m\n\u001b[1;32m    414\u001b[0m             \u001b[0;32mreturn\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdataset\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m__getitems__\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mindices\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0midx\u001b[0m\u001b[0;34m]\u001b[0m \u001b[0;32mfor\u001b[0m \u001b[0midx\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mindices\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m  \u001b[0;31m# type: ignore[attr-defined]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    415\u001b[0m         \u001b[0;32melse\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 416\u001b[0;31m             \u001b[0;32mreturn\u001b[0m \u001b[0;34m[\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdataset\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mindices\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0midx\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m]\u001b[0m \u001b[0;32mfor\u001b[0m \u001b[0midx\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mindices\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    417\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    418\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0m__len__\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m/tmp/ipython-input-1351358964.py\u001b[0m in \u001b[0;36m__getitem__\u001b[0;34m(self, i)\u001b[0m\n\u001b[1;32m     21\u001b[0m         \u001b[0mdeg\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mA\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msum\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mdim\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m-\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mfloat\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     22\u001b[0m         \u001b[0msector_counts\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mH\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msum\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mdim\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m)\u001b[0m  \u001b[0;31m# (N, A)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 23\u001b[0;31m         \u001b[0msector4\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mtorch\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mstack\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0m_reduce_to_4_sectors\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0msector_counts\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mn\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;32mfor\u001b[0m \u001b[0mn\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mrange\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mN\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mdim\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;36m0\u001b[0m\u001b[0;34m)\u001b[0m  \u001b[0;31m# (N,4)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     24\u001b[0m         \u001b[0mx3\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mtorch\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mstack\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mpos\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;36m0\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mpos\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mdeg\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mdim\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m-\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     25\u001b[0m         \u001b[0mfeats\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mtorch\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mcat\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mx3\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0msector4\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mdim\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m-\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m)\u001b[0m  \u001b[0;31m# (N,7)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m/tmp/ipython-input-1351358964.py\u001b[0m in \u001b[0;36m_reduce_to_4_sectors\u001b[0;34m(H_sectors)\u001b[0m\n\u001b[1;32m      8\u001b[0m         \u001b[0;32mreturn\u001b[0m \u001b[0mH_sectors\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      9\u001b[0m     \u001b[0msplits\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mtorch\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mlinspace\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;36m0\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mA\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0msteps\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;36m5\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mdtype\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mtorch\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mint64\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 10\u001b[0;31m     \u001b[0;32mreturn\u001b[0m \u001b[0mtorch\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mstack\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mH_sectors\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0msplits\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0msplits\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mk\u001b[0m\u001b[0;34m+\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msum\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;32mfor\u001b[0m \u001b[0mk\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mrange\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;36m4\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mdim\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;36m0\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     11\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     12\u001b[0m \u001b[0;32mclass\u001b[0m \u001b[0mTopoDataset7D\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mDataset\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;31mKeyboardInterrupt\u001b[0m: "
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "3ipt_Il_72zS"
      },
      "source": [
        "\n",
        "# === Pred viz ===\n",
        "import torch, matplotlib.pyplot as plt, numpy as np\n",
        "from matplotlib.collections import LineCollection\n",
        "\n",
        "blob = torch.load(\"./synth_100.pt\", map_location=\"cpu\")\n",
        "pos = blob[\"pos\"][0]; A = blob[\"A\"][0].bool()\n",
        "\n",
        "model.eval()\n",
        "with torch.no_grad():\n",
        "    H = blob[\"dde\"][0].float()\n",
        "    deg = A.sum(dim=-1).float()\n",
        "    sectors = H.sum(dim=1)\n",
        "    def red4(v):\n",
        "        Ase = v.shape[0]; splits = torch.linspace(0, Ase, steps=5, dtype=torch.int64)\n",
        "        return torch.stack([v[splits[k]:splits[k+1]].sum() for k in range(4)], dim=0)\n",
        "    sector4 = torch.stack([red4(sectors[n]) for n in range(sectors.shape[0])], dim=0)\n",
        "    x3 = torch.stack([pos[:,0], pos[:,1], deg], dim=-1)\n",
        "    x7 = torch.cat([x3, sector4], dim=-1).unsqueeze(0)\n",
        "    logits = model(x7).squeeze(0)\n",
        "    P = torch.sigmoid(logits)\n",
        "\n",
        "def plot_pred(pos, A_true, P, thr=0.5, title=None):\n",
        "    fig, ax = plt.subplots(figsize=(3.6,3.6))\n",
        "    N = pos.shape[0]\n",
        "    iu = torch.triu_indices(N, N, 1)\n",
        "    ii, jj = iu[0], iu[1]\n",
        "    mask_t = (A_true[ii, jj] | A_true[jj, ii])\n",
        "    Ppos = pos.cpu().numpy()\n",
        "    segs_t = np.stack([Ppos[ii[mask_t].cpu().numpy()], Ppos[jj[mask_t].cpu().numpy()]], axis=1)\n",
        "    if len(segs_t) > 0:\n",
        "        ax.add_collection(LineCollection(segs_t, linewidths=1.0, alpha=0.25, colors=\"0.5\"))\n",
        "    mask_p = (P[ii, jj] >= thr)\n",
        "    segs_p = np.stack([Ppos[ii[mask_p].cpu().numpy()], Ppos[jj[mask_p].cpu().numpy()]], axis=1)\n",
        "    if len(segs_p) > 0:\n",
        "        ax.add_collection(LineCollection(segs_p, linewidths=1.8, alpha=0.9))\n",
        "    ax.scatter(Ppos[:,0], Ppos[:,1], s=40, zorder=3)\n",
        "    ax.set_xlim(0,1); ax.set_ylim(0,1); ax.set_xticks([]); ax.set_yticks([])\n",
        "    if title: ax.set_title(title)\n",
        "    plt.show()\n",
        "\n",
        "plot_pred(pos, A, P, thr=0.5, title=\"True (gray) vs Pred (blue) — sample 0\")\n"
      ],
      "id": "3ipt_Il_72zS",
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [],
      "metadata": {
        "id": "8G2cm7Sa8UGm"
      },
      "id": "8G2cm7Sa8UGm",
      "execution_count": null,
      "outputs": []
    }
  ],
  "metadata": {
    "kernelspec": {
      "display_name": "Python 3",
      "language": "python",
      "name": "python3"
    },
    "language_info": {
      "name": "python",
      "pygments_lexer": "ipython3"
    },
    "colab": {
      "provenance": []
    }
  },
  "nbformat": 4,
  "nbformat_minor": 5
}