{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.optim as optim\n",
    "from torch.utils.data import DataLoader, random_split\n",
    "from torchvision import datasets, transforms\n",
    "from torch.nn import functional as F"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "device = torch.device(\"cuda\" if torch.cuda.is_available() else \"cpu\")\n",
    "\n",
    "# Define a simple Transformer model\n",
    "class TransformerBlock(nn.Module):\n",
    "    def __init__(self, emb_size=28, nhead=1, ff_hid_dim=200, dropout=0.1):\n",
    "        super(TransformerBlock, self).__init__()\n",
    "        self.ffK = nn.Linear(emb_size,2*emb_size,bias=False)\n",
    "        self.ffQ = nn.Linear(emb_size,2*emb_size,bias=False)\n",
    "        self.ffV = nn.Linear(emb_size,2*emb_size,bias=False)\n",
    "        self.attn = nn.MultiheadAttention(2*emb_size, nhead, dropout=dropout)\n",
    "        self.ff = nn.Sequential(\n",
    "            nn.Linear(2*emb_size, ff_hid_dim),\n",
    "            nn.ReLU(),\n",
    "            nn.Linear(ff_hid_dim, emb_size)\n",
    "        )\n",
    "        self.norm = nn.LayerNorm(emb_size)\n",
    "        self.dropout = nn.Dropout(dropout)\n",
    "\n",
    "    def forward(self, x):\n",
    "        # x: (seq_len, batch_size, emb_size)\n",
    "        K = self.ffK(x)\n",
    "        Q = self.ffQ(x)\n",
    "        V = self.ffV(x)\n",
    "        \n",
    "        attn_out, _ = self.attn(K, Q, V)\n",
    "        ff_out = self.ff(attn_out)\n",
    "        return self.norm(x + self.dropout(ff_out))\n",
    "\n",
    "class TransformerModel(nn.Module):\n",
    "    def __init__(self, emb_size=28, num_classes=10, nhead=1):\n",
    "        super(TransformerModel, self).__init__()\n",
    "        self.emb_size = emb_size\n",
    "        self.flatten = nn.Flatten(start_dim=1)\n",
    "        self.encoder = TransformerBlock(emb_size=emb_size, nhead=nhead)\n",
    "        self.fc_out = nn.Linear(emb_size, num_classes)\n",
    "\n",
    "    def forward(self, x):\n",
    "        # x: (batch_size, channels, height, width)\n",
    "        x = x.squeeze(1)  # Remove channel dimension for MNIST (greyscale)\n",
    "        x = torch.transpose(x,dim0=0,dim1=1)  # Change to (seq_len, batch_size) for transformer\n",
    "        x = self.encoder(x)  # Pass through transformer block\n",
    "        x = x.mean(dim=0)  # Global average pooling\n",
    "        x = self.fc_out(x)  # Final output layer\n",
    "        return F.log_softmax(x, dim=1)\n",
    "    \n",
    "# Instantiate the model, loss function, and optimizer\n",
    "\n",
    "model = TransformerModel()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "noise_range = np.arange(0, 0.73, 0.03) \n",
    "\n",
    "weight_sum = []\n",
    "\n",
    "for noise_level in noise_range:\n",
    "    batch_size = 64\n",
    "    # Data transforms with noise addition\n",
    "    transform = transforms.Compose([\n",
    "        transforms.ToTensor(),\n",
    "        transforms.Lambda(lambda x: x + noise_level * torch.randn_like(x))  # Add Gaussian noise\n",
    "    ])\n",
    "\n",
    "    # Load the MNIST dataset\n",
    "    train_dataset = datasets.MNIST(root='./data', train=True, download=True, transform=transform)\n",
    "    test_dataset = datasets.MNIST(root='./data', train=False, download=True, transform=transforms.ToTensor())\n",
    "\n",
    "    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n",
    "    test_loader = DataLoader(test_dataset, batch_size=batch_size, shuffle=False)\n",
    "\n",
    "    # Training setting\n",
    "    epochs = 45\n",
    "    learning_rate = 0.001\n",
    "\n",
    "    model = TransformerModel().to(device)\n",
    "    criterion = nn.CrossEntropyLoss()\n",
    "    optimizer = optim.Adam(model.parameters(), lr=learning_rate)\n",
    "\n",
    "    # Training loop\n",
    "    for epoch in range(epochs):\n",
    "        model.train()\n",
    "        running_loss = 0.0\n",
    "        correct = 0\n",
    "        total = 0\n",
    "\n",
    "        for images, labels in train_loader:\n",
    "            images, labels = images.to(device), labels.to(device)\n",
    "            \n",
    "            optimizer.zero_grad()\n",
    "            \n",
    "            # Forward pass\n",
    "            outputs = model(images)\n",
    "            loss = criterion(outputs, labels)\n",
    "            \n",
    "            # Backward pass and optimization\n",
    "            loss.backward()\n",
    "            optimizer.step()\n",
    "            \n",
    "            # Calculate statistics\n",
    "            running_loss += loss.item()\n",
    "            _, predicted = torch.max(outputs, 1)\n",
    "            total += labels.size(0)\n",
    "            correct += (predicted == labels).sum().item()\n",
    "\n",
    "        print(f\"Epoch {epoch+1}/{epochs}, Loss: {running_loss/len(train_loader):.4f}, Accuracy: {100*correct/total:.2f}%\")\n",
    "    \n",
    "    #calcualte weight sum\n",
    "    weight_sum_item = torch.sum(model.encoder.ffK.weight**2+model.encoder.ffQ.weight**2)\n",
    "    weight_sum.append(weight_sum_item)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[tensor(197.7957, device='cuda:0', grad_fn=<SumBackward0>), tensor(101.7438, device='cuda:0', grad_fn=<SumBackward0>), tensor(84.6582, device='cuda:0', grad_fn=<SumBackward0>), tensor(77.7693, device='cuda:0', grad_fn=<SumBackward0>), tensor(83.2693, device='cuda:0', grad_fn=<SumBackward0>), tensor(86.3369, device='cuda:0', grad_fn=<SumBackward0>), tensor(85.4592, device='cuda:0', grad_fn=<SumBackward0>), tensor(83.6380, device='cuda:0', grad_fn=<SumBackward0>), tensor(67.4926, device='cuda:0', grad_fn=<SumBackward0>), tensor(86.7082, device='cuda:0', grad_fn=<SumBackward0>), tensor(85.1852, device='cuda:0', grad_fn=<SumBackward0>), tensor(81.6134, device='cuda:0', grad_fn=<SumBackward0>), tensor(77.2633, device='cuda:0', grad_fn=<SumBackward0>), tensor(70.1979, device='cuda:0', grad_fn=<SumBackward0>), tensor(64.5430, device='cuda:0', grad_fn=<SumBackward0>), tensor(41.4038, device='cuda:0', grad_fn=<SumBackward0>), tensor(56.8462, device='cuda:0', grad_fn=<SumBackward0>), tensor(53.5523, device='cuda:0', grad_fn=<SumBackward0>), tensor(54.3508, device='cuda:0', grad_fn=<SumBackward0>), tensor(49.7667, device='cuda:0', grad_fn=<SumBackward0>), tensor(48.5352, device='cuda:0', grad_fn=<SumBackward0>), tensor(40.0993, device='cuda:0', grad_fn=<SumBackward0>), tensor(42.8744, device='cuda:0', grad_fn=<SumBackward0>), tensor(42.5262, device='cuda:0', grad_fn=<SumBackward0>), tensor(50.0930, device='cuda:0', grad_fn=<SumBackward0>)]\n"
     ]
    }
   ],
   "source": [
    "print(weight_sum)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[197.79574584960938, 101.7437744140625, 84.65823364257812, 77.769287109375, 83.26934814453125, 86.33685302734375, 85.45921325683594, 83.63801574707031, 67.49258422851562, 86.7082290649414, 85.1851806640625, 81.61337280273438, 77.2633056640625, 70.19786071777344, 64.54304504394531, 41.40381622314453, 56.846214294433594, 53.55229949951172, 54.35084533691406, 49.766727447509766, 48.53523254394531, 40.09934997558594, 42.87444305419922, 42.52619934082031, 50.09297180175781]\n"
     ]
    }
   ],
   "source": [
    "weight_list = []\n",
    "\n",
    "for _ in weight_sum:\n",
    "    weight_list.append(_.item())\n",
    "\n",
    "print(weight_list)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "with open(\"file.txt\", 'w') as f:\n",
    "    for s in weight_list:\n",
    "        f.write(str(s) + '\\n')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Visualization"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAArcAAAIhCAYAAABUopIpAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8hTgPZAAAACXBIWXMAAA9hAAAPYQGoP6dpAAB0i0lEQVR4nO3deVhUZfsH8O8BhlVQQQVR3Jc0zcp9RVMwzaXMJbXUMrNcwYU0tbBMc0Nyyyx3U/u9pWWLCr4patiba65pmksqRCqCCMLInN8fTzMyss0cZubMDN/Pdc01M2fOnHPPLerNPc95HkmWZRlERERERE7ARe0AiIiIiIgshcUtERERETkNFrdERERE5DRY3BIRERGR02BxS0REREROg8UtERERETkNFrdERERE5DRY3BIRERGR02BxS0REREROg8UtEZEK1q5dC0mSIEkS9u7dm+91WZZRp04dSJKEjh07Grbr3/PRRx8VeszDhw8btkVHR0OSJNy8edPo2Fu2bEH79u1RqVIleHp6omrVqujatSs+//xzAMCwYcMM5yrqNmzYMIvlhIjIEljcEhGpyNfXF6tWrcq3PSEhARcvXoSvr2+B7/voo49w+/ZtReecOnUqBg4ciAYNGuDzzz/Hjh07MGvWLAQGBuLbb78FAMyYMQMHDx403JYtWwYAmD17ttH2GTNmKIqBiMha3NQOgIioNBswYAC++OILLFu2DH5+fobtq1atQuvWrZGenp7vPV26dMHevXvx4YcfYuHChWadLysrC7GxsRgyZAhWrlxp9NqwYcOg0+kAALVr10bt2rUNr92/fx8AULduXbRq1cqscxIR2RI7t0REKho4cCAAYPPmzYZtaWlp+Prrr/Haa68V+J769etj+PDhWLZsGa5cuWLW+e7du4fs7GxUrly5wNddXPjfAhE5Nv4rRkSkIj8/P/Tt2xerV682bNu8eTNcXFwwYMCAQt8XHR0NV1dXs4cFVKhQAXXq1MHy5csRExOD33//HbIsK46fiMjesLglIlLZa6+9hl9//RWnT58GAKxevRr9+vUrdLwtAAQFBSEyMhJffPEFTpw4Ydb5Nm3ahPLly2PixIlo0KABypYti549e2LDhg0sdInI4bG4JSJSWWhoKGrXro3Vq1fj5MmTOHToUKFDEvKKioqCv78/3n77bbPO17x5c1y4cAE7d+7E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P/8cQ4cOxalTp9CoUaN84x8eXWShKB07djSM2y1IUa/peXp6YsmSJViyZInJ53Um7NwSERERPWR2cZuYmIgDBw5gx44d+V6zxgVlVDR2bomIiIgeMvuCsnHjxuGVV15BUlISdDqd0Y2Fre2xc0tERET0kNnF7a1btxAZGYlAfcuQVKX/Y0hPB7Ky1I2FiIiISG1mF7d9+vTBnj17rBELKVC2LKCfspdDE4iIiKi0M3vMbb169TB16lQcOHAAjRs3zndB2bhx4ywWHBVPkkT39upVUdzWqKF2RERERETqUTRbQpkyZZCQkICEhASj1yRJYnGrgqAgUdxy3C0RERGVdooWcSD7whkTiIiIiASzx9yS/eGMCURERESC2Z3b1157rcjXV69erTgYUoadWyIiIiLB7OI2NTXV6LlWq8WpU6dw584dPPPMMxYLjEzHzi0RERGRYHZxu23btnzbdDodRo0ahVq1alkkKDIPO7dEREREgkXG3Lq4uCAyMhKLFi2yxOHITOzcEhEREQkWu6Ds4sWLePDggaUOR2Zg55aIiIhIMHtYwoQJE4yey7KMpKQk/PDDDxg6dKjFAiPT6Tu3GRnAvXuAj4+68RARERGpxezi9tixY0bPXVxcULFiRSxcuLDYmRTIOsqUAby8gKws0b3l0GciIiIqrcwubvfs2WONOKgEJEl0by9dEuNuWdwSERFRaVXiMbcJCQn48ccf800RRrbFcbdEREREZnRu58+fj4yMDMycOROAGGvbrVs3xMXFAQAqVaqE//73v3j88cetEykViTMmEBEREZnRud28eTMaNmxoeP7VV19h37592L9/P27evIlmzZoZCl+yPXZuiYiIiMwobi9duoQnnnjC8PzHH3/Eiy++iLZt28Lf3x/Tp0/HwYMHrRIkFY+dWyIiIiIzilutVgsPDw/D84MHD6JNmzaG58HBwbh586ZloyOTsXNLREREZEZxW6dOHezbtw8AcPXqVZw/fx6hoaGG169du4aAgADLR0gmYeeWiIiIyIwLyt566y2MGTMG+/fvxy+//ILWrVsbjcH96aef8NRTT1klSCoeO7dEREREZhS3I0eOhJubG77//nt06NAB7733ntHrN27c4CIOKsrbuZVlMfctERERUWlj1iIOw4cPx/Dhwwt8bfny5RYJiJTRd26zssQyvL6+6sZDREREpIYS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",
      "text/plain": [
       "<Figure size 800x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "# Plotting the segmented line by splitting the points into segments\n",
    "plt.figure(figsize=(8, 6))\n",
    "\n",
    "x = noise_range\n",
    "y = weight_list\n",
    "\n",
    "# Plot each segment individually\n",
    "for i in range(1, len(x)):\n",
    "    plt.plot(x[i-1:i+1], y[i-1:i+1], marker='o', color='b')  # 'o' marks each point\n",
    "\n",
    "# Customize the plot\n",
    "plt.title(\"MNIST\")\n",
    "plt.xlabel('Noise Level')\n",
    "plt.ylabel('Square Sum of Weights')\n",
    "plt.grid(True)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "aipy12",
   "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.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
