{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d05bc409",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import glob\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "\n",
    "MIN_EPOCH = 1   \n",
    "MAX_EPOCH = 15  \n",
    "\n",
    "\n",
    "def load_pt_files(pattern):\n",
    "    files = sorted(glob.glob(pattern))\n",
    "    data = []\n",
    "    for f in files:\n",
    "        arr = torch.load(f)  \n",
    "        data.extend(arr)\n",
    "    return np.array(data)  \n",
    "\n",
    "train_losses = load_pt_files(\"train_losses*.pt\")\n",
    "val_accs = load_pt_files(\"val_accs*.pt\")\n",
    "\n",
    "\n",
    "train_losses = train_losses[(train_losses[:, 0] >= MIN_EPOCH) & (train_losses[:, 0] < MAX_EPOCH)]\n",
    "val_accs = val_accs[(val_accs[:, 0] >= MIN_EPOCH) & (val_accs[:, 0] < MAX_EPOCH)]\n",
    "\n",
    "\n",
    "epochs_losses = {}\n",
    "for epoch, loss in train_losses:\n",
    "    epoch = int(epoch)\n",
    "    if epoch not in epochs_losses:\n",
    "        epochs_losses[epoch] = []\n",
    "    epochs_losses[epoch].append(loss)\n",
    "\n",
    "epochs = sorted(epochs_losses.keys())\n",
    "loss_means = [np.mean(epochs_losses[e]) for e in epochs]\n",
    "loss_mins = [np.min(epochs_losses[e]) for e in epochs]\n",
    "loss_maxs = [np.max(epochs_losses[e]) for e in epochs]\n",
    "\n",
    "\n",
    "epochs_accs = {}\n",
    "for epoch, acc in val_accs:\n",
    "    epoch = int(epoch)\n",
    "    if epoch not in epochs_accs:\n",
    "        epochs_accs[epoch] = []\n",
    "    epochs_accs[epoch].append(acc)\n",
    "\n",
    "acc_means = [np.mean(epochs_accs[e]) for e in epochs]\n",
    "acc_mins = [np.min(epochs_accs[e]) for e in epochs]\n",
    "acc_maxs = [np.max(epochs_accs[e]) for e in epochs]\n",
    "\n",
    "\n",
    "plt.figure(figsize=(12, 5))\n",
    "\n",
    "\n",
    "plt.subplot(1, 2, 1)\n",
    "plt.plot(epochs, loss_means, label=\"Mean Loss\", color=\"blue\")\n",
    "plt.fill_between(epochs, loss_mins, loss_maxs, alpha=0.3, color=\"blue\", label=\"Min/Max Loss Range\")\n",
    "plt.xlabel(\"Epoch\")\n",
    "plt.ylabel(\"Training Loss\")\n",
    "plt.title(f\"Training Loss of Four-Layer Transformer (Epochs {MIN_EPOCH}–{MAX_EPOCH-1})\")\n",
    "plt.legend()\n",
    "\n",
    "\n",
    "plt.subplot(1, 2, 2)\n",
    "plt.plot(epochs, acc_means, label=\"Mean Acc\", color=\"green\")\n",
    "plt.fill_between(epochs, acc_mins, acc_maxs, alpha=0.3, color=\"green\", label=\"Min/Max Acc Range\")\n",
    "plt.xlabel(\"Epoch\")\n",
    "plt.ylabel(\"Validation Accuracy\")\n",
    "plt.title(f\"Validation Accuracy of Four-Layer Transformer (Epochs {MIN_EPOCH}–{MAX_EPOCH-1})\")\n",
    "plt.legend()\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.savefig(\"transformer_loss_acc.svg\", format = 'svg')\n"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "hallucination",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.12.3"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
