{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "9923b24c-9cd4-48a6-ad49-f93e96d39c14",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import torch.nn as nn\n",
    "from torch.optim import SGD, Optimizer\n",
    "from torchvision import datasets, transforms\n",
    "import random, numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "# Global plotting style (LaTeX, Times font)\n",
    "plt.rcParams.update({\n",
    "    \"text.usetex\": True,\n",
    "    \"font.family\": \"serif\",\n",
    "    \"font.serif\": [\"Times\"],\n",
    "    \"font.size\": 20,\n",
    "    \"text.latex.preamble\": r\"\\usepackage{times}\"\n",
    "})\n",
    "\n",
    "# Fix random seed\n",
    "def set_seed(seed=2025):\n",
    "    torch.manual_seed(seed)\n",
    "    torch.cuda.manual_seed_all(seed)\n",
    "    np.random.seed(seed)\n",
    "    random.seed(seed)\n",
    "\n",
    "# Simple MLP model for MNIST\n",
    "def get_mlp():\n",
    "    return nn.Sequential(\n",
    "        nn.Flatten(),\n",
    "        nn.Linear(784, 128),\n",
    "        nn.Tanh(),\n",
    "        nn.Linear(128, 10)\n",
    "    )\n",
    "\n",
    "# Load MNIST train set in full-batch\n",
    "def get_mnist_fullbatch(device):\n",
    "    transform = transforms.Compose([\n",
    "        transforms.ToTensor(),\n",
    "        transforms.Normalize((0.1307,), (0.3081,))\n",
    "    ])\n",
    "    dataset = datasets.MNIST(\"../data\", train=True, download=True, transform=transform)\n",
    "    loader = torch.utils.data.DataLoader(dataset, batch_size=len(dataset), shuffle=False)\n",
    "    x_all, y_all = next(iter(loader))\n",
    "    return x_all.to(device), y_all.to(device)\n",
    "\n",
    "# Load MNIST test set in full-batch\n",
    "def get_mnist_test_fullbatch(device):\n",
    "    transform = transforms.Compose([\n",
    "        transforms.ToTensor(),\n",
    "        transforms.Normalize((0.1307,), (0.3081,))\n",
    "    ])\n",
    "    dataset = datasets.MNIST(\"../data\", train=False, download=True, transform=transform)\n",
    "    loader = torch.utils.data.DataLoader(dataset, batch_size=len(dataset), shuffle=False)\n",
    "    x_all, y_all = next(iter(loader))\n",
    "    return x_all.to(device), y_all.to(device)\n",
    "\n",
    "# Evaluate model on test set\n",
    "def evaluate(model, x_test, y_test, loss_fn):\n",
    "    model.eval()\n",
    "    with torch.no_grad():\n",
    "        pred = model(x_test)\n",
    "        loss = loss_fn(pred, y_test)\n",
    "        acc = (pred.argmax(1) == y_test).float().mean().item() * 100\n",
    "    return loss.item(), acc\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "7eecf513-2d1c-4702-9b60-af0644468153",
   "metadata": {},
   "outputs": [],
   "source": [
    "class SAM(Optimizer):\n",
    "    def __init__(self, params, base_optimizer, rho=0.05, adaptive=False, **kwargs):\n",
    "        defaults = dict(rho=rho, adaptive=adaptive, **kwargs)\n",
    "        super().__init__(params, defaults)\n",
    "        self.base_optimizer = base_optimizer(self.param_groups, **kwargs)\n",
    "        self.param_groups = self.base_optimizer.param_groups\n",
    "        self.rho = rho\n",
    "        self.GD = False   # Switching strategy flag\n",
    "\n",
    "    @torch.no_grad()\n",
    "    def first_step(self, zero_grad=False):\n",
    "        # Apply perturbation in gradient direction\n",
    "        rho = 0 if self.GD else self.rho\n",
    "        grad_norm = self._grad_norm()\n",
    "        for group in self.param_groups:\n",
    "            scale = rho / (grad_norm + 1e-12)\n",
    "            for p in group[\"params\"]:\n",
    "                if p.grad is None:\n",
    "                    continue\n",
    "                # Save original weights\n",
    "                self.state[p][\"old_p\"] = p.data.clone()\n",
    "                # Perturb weights\n",
    "                e_w = (torch.pow(p, 2) if group[\"adaptive\"] else 1.0) * p.grad * scale.to(p)\n",
    "                p.add_(e_w)\n",
    "        if zero_grad:\n",
    "            self.zero_grad()\n",
    "\n",
    "    @torch.no_grad()\n",
    "    def second_step(self, zero_grad=False):\n",
    "        # Restore weights and perform optimizer step\n",
    "        for group in self.param_groups:\n",
    "            for p in group[\"params\"]:\n",
    "                if p.grad is None:\n",
    "                    continue\n",
    "                p.data = self.state[p][\"old_p\"]\n",
    "        self.base_optimizer.step()\n",
    "        if zero_grad:\n",
    "            self.zero_grad()\n",
    "\n",
    "    def _grad_norm(self):\n",
    "        # Compute gradient L2 norm\n",
    "        shared_device = self.param_groups[0][\"params\"][0].device\n",
    "        return torch.norm(torch.stack([\n",
    "            ((torch.abs(p) if group[\"adaptive\"] else 1.0) * p.grad).norm(p=2).to(shared_device)\n",
    "            for group in self.param_groups for p in group[\"params\"]\n",
    "            if p.grad is not None\n",
    "        ]), p=2)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "3a95175c-2dbc-4e86-8526-4ae199c15428",
   "metadata": {},
   "outputs": [],
   "source": [
    "def train_mnist_fullbatch(rho=2.0, steps=10000, sw=False):\n",
    "    # Fixed hyperparameters\n",
    "    lr = 0.01\n",
    "    seed = 2025\n",
    "\n",
    "    # Reproducibility + device setup\n",
    "    set_seed(seed)\n",
    "    device = torch.device(\"cuda:1\" if torch.cuda.is_available() else \"cpu\")\n",
    "\n",
    "    # Full-batch datasets\n",
    "    model = get_mlp().to(device)\n",
    "    x_all, y_all = get_mnist_fullbatch(device)\n",
    "    x_test, y_test = get_mnist_test_fullbatch(device)\n",
    "\n",
    "    # SAM optimizer (SGD base) + loss\n",
    "    optimizer = SAM(model.parameters(), base_optimizer=SGD, lr=lr, momentum=0.9, rho=rho)\n",
    "    loss_fn = nn.CrossEntropyLoss()\n",
    "\n",
    "    train_losses, test_accs = [], []\n",
    "\n",
    "    for step in range(steps):\n",
    "        # Switching strategy (disable SAM in first 10% if sw=True)\n",
    "        optimizer.GD = (sw and step < steps/10)\n",
    "\n",
    "        model.train()\n",
    "\n",
    "        # First forward-backward step\n",
    "        pred = model(x_all)\n",
    "        loss1 = loss_fn(pred, y_all)\n",
    "        loss1.backward()\n",
    "        optimizer.first_step(zero_grad=True)\n",
    "\n",
    "        # Second forward-backward step\n",
    "        pred = model(x_all)\n",
    "        loss2 = loss_fn(pred, y_all)\n",
    "        loss2.backward()\n",
    "        optimizer.second_step(zero_grad=True)\n",
    "\n",
    "        # Record metrics every 100 steps\n",
    "        if (step + 1) % 100 == 0:\n",
    "            train_losses.append(loss1.item())\n",
    "            _, test_acc = evaluate(model, x_test, y_test, loss_fn)\n",
    "            test_accs.append(test_acc)\n",
    "            if (step + 1) % 10000 == 0:\n",
    "                print(f\"Step {step+1:6d} | Train Loss: {loss1.item():.4f} | Test Acc: {test_acc:.2f}%\")\n",
    "\n",
    "    return train_losses, test_accs\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "3a0f738e-e828-4c93-ad44-1c613cdb6158",
   "metadata": {},
   "outputs": [],
   "source": [
    "def plot_training_curve(train_losses, test_accs, rho=None):\n",
    "    steps = np.arange(1, len(train_losses) + 1) * 100\n",
    "\n",
    "    fig, ax1 = plt.subplots(figsize=(8, 6))\n",
    "\n",
    "    # Training loss (left y-axis)\n",
    "    color_loss = '#1f77b4'\n",
    "    ax1.set_xlabel(\"Step\")\n",
    "    ax1.set_ylabel(\"Train Loss\", color=color_loss)\n",
    "    ax1.plot(steps, train_losses, color=color_loss, linewidth=2)\n",
    "    ax1.tick_params(axis='y', labelcolor=color_loss)\n",
    "    ax1.set_ylim(0, 2.5)\n",
    "    ax1.set_yticks(np.arange(0, 2.41, 0.5))\n",
    "    ax1.grid(True)\n",
    "\n",
    "    # Test accuracy (right y-axis)\n",
    "    color_acc = '#ff7f0e'\n",
    "    ax2 = ax1.twinx()\n",
    "    ax2.set_ylabel(r\"Test Accuracy (\\%)\", color=color_acc)\n",
    "    ax2.plot(steps, test_accs, color=color_acc, linewidth=2)\n",
    "    ax2.tick_params(axis='y', labelcolor=color_acc)\n",
    "    ax2.set_ylim(0, 100)\n",
    "    ax2.set_yticks(np.arange(0, 91, 20))\n",
    "\n",
    "    # X-axis ticks\n",
    "    max_step = steps[-1]\n",
    "    tick_interval = max_step // 5 if max_step >= 5 else 1\n",
    "    ax1.set_xticks(np.arange(0, max_step + 1, tick_interval))\n",
    "\n",
    "    # Title\n",
    "    if rho is not None:\n",
    "        plt.title(rf\"Training Curve ($\\rho={rho}$)\")\n",
    "    else:\n",
    "        plt.title(\"Training Curve\")\n",
    "\n",
    "    plt.tight_layout()\n",
    "    plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "dcd0db6a-610f-45b1-a7bd-eb1351ebbc7f",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Step  10000 | Train Loss: 2.2979 | Test Acc: 14.02%\n",
      "Step  20000 | Train Loss: 2.2981 | Test Acc: 11.79%\n",
      "Step  30000 | Train Loss: 2.2964 | Test Acc: 12.14%\n",
      "Step  40000 | Train Loss: 2.2875 | Test Acc: 12.42%\n",
      "Step  50000 | Train Loss: 2.1216 | Test Acc: 19.98%\n",
      "Step  60000 | Train Loss: 2.0311 | Test Acc: 20.33%\n",
      "Step  70000 | Train Loss: 2.0181 | Test Acc: 20.42%\n",
      "Step  80000 | Train Loss: 2.0134 | Test Acc: 20.27%\n",
      "Step  90000 | Train Loss: 2.0106 | Test Acc: 20.08%\n",
      "Step 100000 | Train Loss: 2.0095 | Test Acc: 20.16%\n"
     ]
    }
   ],
   "source": [
    "# Run full-batch training on MNIST with SAM (rho = 2.0)\n",
    "rho = 2.0\n",
    "train_losses, test_accs = train_mnist_fullbatch(rho=rho, steps=100000)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "9a8ae88d-1bac-45d2-9a6d-60af54715150",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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OO1iedpEceFy4XOxXt8F0VKuThJlSJsgzlfy+MScYz1JC6RlRW9/KhUHwRIRUcJhwKf4d823gD/8MPg6ao1o6U8eB6Ski4dG52m9VqkGviaJwJ0xVdxMK/Ny8SlB+hQxYDJJO7qBz27HxZQzot98sC4f6iTR/378ZP/LvUPutGujW0YiIiJSNAZ8in9/831gzh1AX5cI6O5uJwNhXZsmXhMRERERAz4pREY2gOxYl4KIiIgo7nFkGRERERFRAmHAJyIiIiJKIAz4REREREQJhAGfiIiIiCiBMOATERERESUQBnwiIiIiogTCgE9ERERElEAY8ImIiIiIEggDPhERERFRAmHAJyIiIiJKIAz4REREREQJhAGfiIiIiCiBMOATERERESUQBnwiIiIiogTCgE9ERERElEAY8ImIiIiIEggDPhERERFRAmHAJyIiIiJKIAz4REREREQJhAGfiIiIiCiBMOATERERESUQBnwiIiIiogTCgE9ERERElEAY8ImIiIiIEggDPhERERFRAmHAJyIiIiJKIAz4REREREQJhAGfiIiIiCiBMOATERERESUQBnwiIiIiogTCgE9ERERElEAY8ImIiIiIEggDPhERERFRAmHAJyIiIiJKIAz4REREREQJhAGfiIiIiCiBMOATERERESUQBnwiIiIiogTCgE9ERERElEA0sS5AuHY0t+GVvS0AAKutH3pdMr67NA9LrpgYl/slIiIiojF2eCvQ+Jx4brMAOgOw+GEgb3ksSzVmFBXwv/dyI3Y0n8P2tUswNycTgAjm3/r1XpQtNWL9yqviar9ERERENMZ+dx9w5E2gtAGYOl+8d3gr8NJtwOJ1QPHjMSzc2FBMF531rzdjR/M5/OT2fHcIB4Cb8rNx18JcVDWYsaO5LW72S0RERERjbNs6Ee5vftIT7gFgzm1A4QPAni0i7Cc4RQT8lvM9eHWf6D5z96LcIcvvGXjviXeOxcV+iYiIiGiMdZwEGp8XzxesGbq8cOC9+g1jVqRYUUTA/2WDCQCwZJb//vBzczKRkapBS0cPdh9vj/l+iYiIiGiM7XlSfDUu87986nwgNROwnAJMu8amTDGiiIC/54QI13NyMgKukzshDQDwyr7TMd8vEREREY0x83via/a8wOsYZoiv8gDcBBX3Ab/TZkdLRw8AwJCWHHC93CwRxA+1dsV0v0RE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",
      "text/plain": [
       "<Figure size 800x600 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Plot training curve for SAM-only training\n",
    "plot_training_curve(train_losses, test_accs, rho=rho)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "7cd5f492-0c15-42af-b0c1-2629b7d270e7",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Step  10000 | Train Loss: 0.0146 | Test Acc: 97.64%\n",
      "Step  20000 | Train Loss: 0.0105 | Test Acc: 97.53%\n",
      "Step  30000 | Train Loss: 0.0035 | Test Acc: 97.51%\n",
      "Step  40000 | Train Loss: 0.0019 | Test Acc: 97.56%\n",
      "Step  50000 | Train Loss: 0.0013 | Test Acc: 97.59%\n",
      "Step  60000 | Train Loss: 0.0010 | Test Acc: 97.54%\n",
      "Step  70000 | Train Loss: 0.0008 | Test Acc: 97.53%\n",
      "Step  80000 | Train Loss: 0.0006 | Test Acc: 97.53%\n",
      "Step  90000 | Train Loss: 0.0005 | Test Acc: 97.53%\n",
      "Step 100000 | Train Loss: 0.0005 | Test Acc: 97.54%\n"
     ]
    }
   ],
   "source": [
    "# Run full-batch training with switching strategy (first 10% GD, then SAM)\n",
    "train_losses, test_accs = train_mnist_fullbatch(rho=rho, steps=100000, sw=True)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "4b0085e3-0421-443b-a105-771f82aaaad9",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 800x600 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Plot training curve for switching strategy\n",
    "plot_training_curve(train_losses, test_accs, rho=rho)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "20b3a6a9-2efa-4e6b-965a-1ef39cf79eb4",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python (sam)",
   "language": "python",
   "name": "sam"
  },
  "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.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
