{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.optim as optim\n",
    "from torchvision import datasets, transforms\n",
    "from torch.utils.data import DataLoader\n",
    "import torch.nn.functional as F\n",
    "\n",
    "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, ff_hid_dim),\n",
    "            nn.ReLU(),\n",
    "            nn.Linear(ff_hid_dim, 2*emb_size)\n",
    "        )\n",
    "        self.norm = nn.LayerNorm(2*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(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(2*emb_size, num_classes)\n",
    "        self.ReLU = nn.ReLU()\n",
    "\n",
    "    def forward(self, x):\n",
    "        # x: (batch_size, channels, height, width)\n",
    "        x = x.view(x.size(0),-1,x.size(-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.ReLU(x)\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()\n",
    "\n"
   ]
  },
  {
   "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 = 32\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.FashionMNIST(root='./data', train=True, download=True, transform=transform)\n",
    "    test_dataset = datasets.FashionMNIST(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 = 40\n",
    "    learning_rate = 0.002\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": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[360.3671569824219, 382.7075500488281, 403.5500183105469, 373.5849609375, 334.3902893066406, 304.9746398925781, 274.802978515625, 247.66297912597656, 222.62844848632812, 202.10336303710938, 180.27267456054688, 165.07809448242188, 152.16775512695312, 142.34619140625, 131.47607421875, 118.6166763305664, 113.15280151367188, 99.42611694335938, 94.79586029052734, 89.00955963134766, 82.78852081298828, 75.20783996582031, 70.92174530029297, 63.9901123046875, 62.66709899902344]\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": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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WVlZea8vxmazuSYqEclr85WYWHAG188P+vXzfEwiIiLerljF7cqVKwt9LSLulZAA48aZXRGSk6F+ffjmG/jkE7jvPti82dzUQURERExOr7ndt28fycnJdOrUiTJlymAYhmZuRdwgMBBiYs69HzgQvv0Wdu+Gp5+G11+3LDQRERGv43ArsD///JNu3brRuHFjevbsSUpKCgCPPPIII0aMcHmAIpJf5cowf775euZMWLLE2nhERES8icPF7fDhw7Hb7Rw8eJCQ8/4+9O6772bZsmUuDU5ECte9+7nZ3IcegtRUS8MRERHxGg4Xt8uXL2fSpEnUqlUr3/FGjRpx4MABlwUmIkWbOBGuusosbB99FAzD6ohERESs53Bxe/r06XwztrmOHj1KUFCQS4ISkUsLDob/+z9zTe7nn8Pbb1sdkYiIiPUcLm47derEu+++m/feZrORk5PD5MmTtTOZiIddcw1MmGC+jomBvXstDUdERMRyDndLmDx5Ml26dGHjxo1kZmYSFxfHzp07+euvv/jmm2/cEaOIFGH4cPjyS1i50mwPtm4d2O1WRyUiImINh2dumzZtyo8//kjr1q2JjIzk9OnT9O3bly1bttBAG92LeJyfn9k9oUIF+OEHGD/e6ohERESsU+yZ2xtuuIEbb7yRLl260L59e1588UV3xiUiDoiIgDffhHvvNTd96NED2rWzOioRERHPK/bMbZMmTViwYAHdu3enUqVKdOnShZdeeol169blbc0rIta55x4YMMDcqvf+++HUKasjEhER8bxiF7dz5sxh3759HDx4kLfeeosGDRowb948OnXqRMWKFYmMjGTixInujFVELmHGDKhd29yqd/hwq6MRERHxPIfX3NaqVYsHHniAOXPmkJyczIEDBxg+fDg//PADzz33nDtiFJFiqlgR3n0XbDazNdinn1odkYiIiGc53C0BIDk5mVWrVuU9jh8/Trt27ejcubOr4xMRB3XuDE8/DQkJ8Mgj0KYNVK1qdVQiIiKeUezidu7cuaxcuZJVq1Zx4sQJOnToQOfOnRk8eDCtWrUiIMCpOllE3ODFF2H5cti6FR5+GD77zOqIREREPKPYFemgQYOoXbs2Y8aM4eGHH8auRpoiXisoyNy9rGVLWLYM3nzTjzp1rI5KRETE/Yq95vb111+nbdu2xMfHU716dW699VamTJnCxo0bMbSpvYjXadrUXJoA8Mwzfhw6VM7agERERDyg2MXtk08+ycKFC0lJSeGbb76hZ8+e/PDDD/Tq1YtKlSpxyy238Morr7gzVhFx0ODBEBUFf/9tY+rUlmRmWh2RiIiIezncLQHMXcqefPJJPvzwQzZv3sxTTz3FunXreOaZZ1wdn4hcBj8/mDsXKlc2+OWXirz4olP/youIiJQYDt8F9scff+TrlLBnzx4CAwNp06YNXbt2dUeMInIZwsPhjTeyufvuACZP9qNXL+jY0eqoRERE3KPYxe3gwYNZuXIlu3fvJiAggNatW3PnnXfStWtX2rdvT3BwsDvjFJHLcPvtBt26HeA//6nD/ffDjz9ChQpWRyUiIuJ6xS5uN2/eTJ8+fejatSsdOnQgJCTEnXGJiIs98sgO9u+vzS+/2Bg6FObPtzoiERER1yv2Arxvv/2WCRMmEBkZ6bLCduLEibRu3Zry5ctTvXp1+vTpw+7du/ONefDBB7HZbPkebdu2zTcmIyODIUOGULVqVcqWLUvv3r05fPiwS2IU8RVlypxl7txs/PzMXcz+9S+rIxIREXE9S+8uWb16NYMHD+a7774jKSmJs2fPEhUVxenTp/ONu+mmm0hJScl7LFmyJN/5mJgYFi9ezMKFC1m3bh2nTp2iV69eZGdne/LriHi9du0Mnn3WfP3EE6D/BxQREV9j6bZiy5Yty/d+7ty5VK9enU2bNtGpU6e840FBQYSFhRX6GSdOnGDOnDm89957dO/eHYD333+fiIgIVqxYQY8ePdz3BURKoH/+09zYYeNGeOAB6NUL9u+HBg0gOhoCA62OUERExHletWfuiRMnAKhcuXK+46tWraJ69epUrFiRzp07M378eKpXrw7Apk2byMrKIioqKm98eHg4zZo1Y/369YUWtxkZGWRkZOS9T0tLAyArK4usrCyXf68L5V7DE9fyJcqb887Pnd0O8+bBtdcGsHKljZUrz40bMcIgJiaHl1/OsSZQL6PfOecob85R3pyn3DmnpOWtuHHajGJsL/baa6/x2GOPERwczMGDB4mIiMBms112kOczDIPbbruNY8eOsXbt2rzjH374IeXKlaNOnTrs37+f559/nrNnz7Jp0yaCgoJYsGABDz30UL5iFSAqKop69erx1ltvFbhWfHw8Y8eOLXB8wYIFulFOSoV585ry6acNgQv/PTb/OOjTZx8PPrjL43GJiIhcTHp6Ov379+fEiROEhoZedFyxituAgAB+//13qlevjr+/PykpKXkzp64yePBgvvzyS9atW0etWrUuOi4lJYU6deqwcOFC+vbte9HiNjIykgYNGvDmm28W+IzCZm4jIiI4evRokclylaysLJKSkoiMjMRut7v9er5CeXPe+bkzDDuhoQHk5EDB4hbAwN8fTpw4W+qXKOh3zjnKm3OUN+cpd84paXlLS0ujatWqlyxui7UsITw8nE8++YSePXtiGAaHDx/m77//LnRs7dq1HQ52yJAhfP7556xZs6bIwhagZs2a1KlTh7179wIQFhZGZmYmx44do1KlSnnjUlNTad++faGfERQURFBQUIHjdrvdo/9wPX09X6G8Oc9ut/P66/b/FbYXYyM7G2bPthMT46HAvJx+55yjvDlHeXOecueckpK34sZYrG4Jzz33HDExMdSvXx+bzUbr1q2pV69evkfdunWpV6+eQ0EahsFTTz3FokWL+Prrr4v183/++SeHDh2iZs2aALRs2RK73U5SUlLemJSUFHbs2HHR4lakNEtOdu04ERERb1KsmdvHHnuMe++9lwMHDnD11VezYsUKqlSpctkXHzx4MAsWLOCzzz6jfPnyHDlyBIAKFSpQpkwZTp06RXx8PHfccQc1a9bk119/5dlnn6Vq1arcfvvteWMHDRrEiBEjqFKlCpUrV2bkyJE0b948r3uCiJzToIFrx4mIiHiTYndLKF++PM2aNWPu3Ll06NCh0L/Wd9Qbb7wBQJcuXfIdnzt3Lg8++CD+/v5s376dd999l+PHj1OzZk26du3Khx9+SPny5fPGT506lYCAAPr168eZM2fo1q0b8+bNw9/f/7JjFPE10dEwciQU1Qba398cJyIiUtI43Aps4MCBgNmC66effsJms/GPf/yD6667zuGLX+petjJlyvDVV19d8nOCg4OZPn0606dPdzgGkdImMBBiY2Hy5IuP+cc/1O9WRERKJoeL29TUVO655x5WrVpFxYoVMQyDEydO0LVrVxYuXEi1atXcEaeIuFBCgvmcmJh/BtfPD3JyYMcOsxfugw9aEZ2IiIjzHN5+d8iQIaSlpbFz507++usvjh07xo4dO0hLS2Po0KHuiFFE3CAhAdLTYepUeOop8/nMGXjxRfN8dDRs325tjCIiIo5yeOZ22bJl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XeONN97wcMTewdG8AQUederU8WzQXsCRvHXu3LnQvA0cONDzgXsBR3L32muvGVdddZUREhJihIaGGi1atDBmzpxpZGdnWxC5tRz9d/V8pbW4NQzH8jZp0iSjQYMGRnBwsFGpUiXjhhtuML788ksLovYOjv7O/fTTT0b37t2NMmXKGLVq1TJiY2ON9PR0D0dtPUfzdvz4caNMmTLGrFmzPByp69gM4393LomIiIiIlHBacysiIiIiPkPFrYiIiIj4DBW3IiIiIuIzVNyKiIiIiM9QcSsiIiIiPkPFrYiIiIj4DBW3IiIiIuIzVNyKiHiJunXrMm3aNKvDcJtVq1Zhs9k4fvy41aGIiA9TcSsichkefPBBbDYbL7/8cr7jn376KTabzaHP2rBhA4899pgrw8vH14tnERFQcSsictmCg4OZNGkSx44du6zPqVatGiEhIS6KSkSkdFJxKyJymbp3705YWBgTJ04sctwnn3zCVVddRVBQEHXr1mXKlCn5zl84sxofH0/t2rUJCgoiPDycoUOH5p3LzMwkLi6OK664grJly9KmTRtWrVp1Wd/jiy++oGXLlgQHB1O/fn3Gjh3L2bNnAbj33nu555578o3PysqiatWqzJ07FwDDMEhISKB+/fqUKVOGa665ho8//viyYhIRcVSA1QGIiJR0/v7+TJgwgf79+zN06FBq1apVYMymTZvo168f8fHx3H333axfv57o6GiqVKnCgw8+WGD8xx9/zNSpU1m4cCFXXXUVR44c4ccff8w7/9BDD/Hrr7+ycOFCwsPDWbx4MTfddBPbt2+nUaNGDn+Hr776ivvuu4/XXnuNjh07kpycnLdE4oUXXmDAgAH069ePU6dOUa5cubyfOX36NHfccQcAzz33HIsWLeKNN96gUaNGrFmzhvvuu49q1arRuXNnh2MSEXGKISIiThs4cKBx2223GYZhGG3btjUefvhhwzAMY/Hixcb5f8T279/fiIyMzPezTz/9tNG0adO893Xq1DGmTp1qGIZhTJkyxWjcuLGRmZlZ4Jr79u0zbDab8dtvv+U73q1bN2P06NEXjfX8z79Qx44djQkTJuQ79t577xk1a9Y0DMMwMjMzjapVqxrvvvtu3vl7773XuOuuuwzDMIxTp04ZwcHBxvr16/N9xqBBg4x7773XMAzDWLlypQEYx44du2iMIiKXS8sSRERcZNKkScyfP59du3YVOPfTTz/RoUOHfMc6dOjA3r17yc7OLjD+rrvu4syZM9SvX59HH32UxYsX5y0R2Lx5M4Zh0LhxY8qVK5f3WL16NcnJyU7FvmnTJl588cV8n/foo4+SkpJCeno6drudu+66i//7v/8D4PTp03z22WcMGDAAgF27dvH3338TGRmZ7zPeffddp2MSEXGGliWIiLhIp06d6NGjB88++2yBpQaGYRTonmAYxkU/KyIigt27d5OUlMSKFSuIjo5m8uTJrF69mpycHPz9/dm0aRP+/v75fi53yYCjcnJyGDt2LH379i1wLjg4GIABAwbQuXNnUlNTSUpKIjg4mJtvvjnv5wG+/PJLrrjiinw/HxQU5FRMIiLOUHErIuJCL7/8Mtdeey2NGzfOd7xp06asW7cu37H169fTuHHjAgVqrjJlytC7d2969+7N4MGDufLKK9m+fTstWrQgOzub1NRUOnbs6JK4r7vuOnbv3k3Dhg0vOqZ9+/ZERETw4YcfsnTpUu666y4CAwPzvl9QUBAHDx7U+loRsZSKWxERF2revDkDBgxg+vTp+Y6PGDGC1q1b89JLL3H33Xfz7bffMmPGDGbOnFno58ybN4/s7GzatGlDSEgI7733HmXKlKFOnTpUqVKFAQMG8MADDzBlyhRatGjB0aNH+frrr2nevDk9e/a8aHy//fYbW7duzXesdu3a/POf/6RXr15ERERw11134efnx7Zt29i+fTvjxo0DwGaz0b9/f95880327NnDypUr8z6jfPnyjBw5kuHDh5OTk8MNN9xAWloa69evp1y5cgwcONDJjIqIOMjiNb8iIiXa+TeU5fr111+NoKAg48I/Yj/++GOjadOmht1uN2rXrm1Mnjw53/nzb/havHix0aZNGyM0NNQoW7as0bZtW2PFihV5YzMzM41//vOfRt26dQ273W6EhYUZt99+u7Ft27aLxlqnTh0DKPCYO3euYRiGsWzZMqN9+/ZGmTJljNDQUOP66683Zs2ale8zdu7caQBGnTp1jJycnHzncnJyjFdffdVo0qSJYbfbjWrVqhk9evQwVq9ebRiGbigTEc+wGUYRi75EREREREoQdUsQEREREZ+h4lZEREREfIaKWxERERHxGSpuRURERMRnqLgVEREREZ+h4lZEREREfIaKWxERERHxGSpuRURERMRnqLgVEREREZ+h4lZEREREfIaKWxERERHxGSpuRURERMRn/D9ryWg4MKIytwAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 800x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "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(\"\")\n",
    "plt.xlabel('Noise Level')\n",
    "plt.ylabel('Square Sum of Weights')\n",
    "plt.grid(True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "with open(\"file_FashionMNIST.txt\", 'w') as f:\n",
    "    for s in weight_list:\n",
    "        f.write(str(s) + '\\n')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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mjVr6sYbb9QLL7zgyloBVABRUZKvb8ltfH3NdgAAOJvdqyVI5i5ljzzyiN577z1t3bpVo0aN0vr16zVhwgRn1wegggkIkGJiSm4TE8PFZAAA17D7KrA//vij0EoJe/bsUUBAgDp16qSePXu6okYAFUxCgnmfmGhePHau6tXNJcMAAHCFMofbRx99VGvXrtVPP/0kPz8/dezYUbfddpt69uyprl27KigoyJV1AqhgEhLM5b4WLDAvHgsPNzdzOHBAmjZNeuYZqysEAHijMofbrVu36uabb1bPnj3VrVs3BQcHu7IuAF4gIKDwcl/Nmkm33moG3xEjzOcAADhTmcPt119/7co6AFQCt9wiRUZKycnmdrwff2x1RQAAb+PQBWUA4AibTZo7V/Lzkz75xLwBAOBMhFsAbtWypTlqK5lTFv7+29JyAABehnALwO2eeEIKCzMvNGN5bACAM5Up3M6dO1d//294Zf/+/exIBqBcqlc/G2qnTpX27bO2HgCA9yhTuI2JidGJEyckSY0bN9Z///tflxYFwPvdeafUvbuUmSmNH291NQAAb1Gm1RLCwsK0fPly9e/fX4Zh6ODBgwUjuee79NJLnVogAO9ks0nz5klXXy0tX26uoBAZaXVVAICKrkzhdvLkyRo9erRGjRolm82mjh07FmljGIZsNptyz9+OCAAu4IorpEcfNVdQGDNG+v57tuUFAJRPmcLtQw89pKFDh2rfvn264oor9Pnnn6t27dqurg1AJTBlirRsmbR7txlyY2OtrggAUJGVeROH6tWrq02bNnrzzTfVrVs3BQYGurIuAJXERRdJ06dL991nBt1hw8yVFAAAcITdS4GNGDFCgYGB2rJli5YsWaJ33nlHW7dudUVtACqJe+6ROneWTp2S4uKsrgYAUJGVeeQ2X3p6uu68806tW7dOF110kQzD0PHjx9WzZ08tW7ZMdevWdUWdALyYj480f77UsaP0zjvSQw+ZKykAAGAvu0duR48erRMnTmjnzp06cuSIjh49qh07dujEiRMaM2aMXZ/10ksv6YorrlBISIhCQkLUpUsXrVq1quB1wzAUHx+vsLAwValSRT169NDOnTsLfUZWVpZGjx6tOnXqqGrVqho4cKAOHjxo79cCYLH27c1QK0mjRklnzlhbDwCgYrI73K5evVovvfSSLr/88oJjrVq10osvvlgo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aN42b5Y6dLC6IgCoXMo8LeE///mPVq1aVejY4sWL1bhxY1188cV66KGHlJWV5fQCAaAiadVKuvtu8/HkydbWAgCVUZnDbXx8vH744YeC59u3b9fIkSPVu3dvPf744/r44481bdo0lxQJABXJU09Jfn7SmjVSSorV1QBA5VLmcPvdd9+pV69eBc+XLVumTp066bXXXlNMTIzmzp2rf/7zny4pEgAqkiZNpAcfNB9PmiSdt6EjAMCFyhxujx49qnr16hU8T0lJ0Q033FDwvGPHjjpw4IBzqwOACmryZCkoSNqwQVq92upqAKDyKHO4rVevnvbu3StJys7O1tatW9WlS5eC10+ePCl/f3/nVwgAFVBYmDRqlPl40iQpL8/aegCgsihzuL3hhhv0+OOP66uvvtLEiRMVHBys6667ruD1H374QU2bNnVJkQBQEU2YIFWvLm3bZq6eAABwvTKH22effVa+vr6KiIjQa6+9ptdee00BAQEFr7/xxht2Lw02bdo0dezYUdWrV9fFF1+sm2++WT/99FOhNoZhKD4+XmFhYapSpYp69Oihneetjp6VlaXRo0erTp06qlq1qgYOHKiDBw/aVQsAOFudOlJMjPn4iSek3Fxr6wGAyqDM4bZu3br66quvdPToUR09elS33HJLodfff/99PfXUU3adPCUlRY8++qi++eYbJScn68yZM+rTp49Onz5d0CYhIUGJiYmaP3++Nm3apNDQUEVGRurkyZMFbaKjo7VixQotW7ZM69ev16lTpzRgwADl8i8JAIvFxEi1akm7d5s7lwEAXMvu7Xdr1KghX1/fIsdr1apVaCS3LFavXq17771XrVu31pVXXqk333xT+/fv15YtWySZo7azZ8/WpEmTNHjwYLVp00ZvvfWWMjIytHTpUknS8ePHtXDhQs2cOVO9e/dWu3bttGTJEm3fvl2ff/65vV8PAJwqJER6/HHzcXy8lJ1taTkA4PXsDreudPz4cUlmUJakvXv36vDhw4WmOwQGBioiIkIbN26UJG3ZskU5OTmF2oSFhalNmzYFbQDASo8+KtWvL/32m/T661ZXAwDezaHtd13BMAzFxMTo2muvVZs2bSRJhw8flqRCS5DlP9+3b19Bm4CAANWsWbNIm/z3ny8rK6vQbmonTpyQJOXk5CgnJ8c5X6gE+edwx7m8Cf3mOPrOMc7qN39/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Wmn9+vWFjm3cuFEtWrQoElDzValSRQMHDtTAgQP16KOPqmXLltq+fbvatWun3Nxcpaen67rrrnNK3VdffbV++uknNWvW7IJtunbtqvDwcL333ntatWqVbr/9dgUEBBR8v8DAQO3fv5/5tQAsRbgFACdq27athg8frnnz5hU6Pn78eHXs2FHPPPOM7rjjDn399deaP3++FixYUOznLFq0SLm5uerUqZOCg4P19ttvq0qVKmrYsKFq166t4cOH65577tHMmTPVrl07/fnnn/riiy/Utm1b9e/f/4L1HTp0SN99912hY5deeqmefPJJDRgwQOHh4br99tvl4+OjH374Qdu3b9ezzz4rSbLZbBo2bJhefvll7dmzR2vXri34jOrVqys2Nlbjxo1TXl6err32Wp04cUIbN25UtWrVNGLECAd7FADsZPGcXwCo0M69oCzfb7/9ZgQGBhrn/xX7wQcfGK1atTL8/f2NSy+91JgxY0ah18+94GvFihVGp06djJCQEKNq1apG586djc8//7ygbXZ2tvHkk08ajRo1Mvz9/Y3Q0FDjlltuMX744YcL1tqwYUNDUpHbm2++aRiGYaxevdro2rWrUaVKFSMkJMS45pprjFdffbXQZ+zcudOQZDRs2NDIy8sr9FpeXp4xZ84c47LLLjP8/f2NunXrGn379jVSUlIMw+CCMgDuYTOMEiZ9AQAAABUIqyUAAADAaxBuAQAA4DUItwAAAPAahFsAAAB4DcItAAAAvAbhFgAAAF6DcAsAAACvQbgFAACA1yDcAgAAwGsQbgEAAOA1CLcAAADwGoRbAAAAeI3/B7SB3Se8xYPZAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 800x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "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(\"\")\n",
    "plt.xlabel('Noise Level')\n",
    "plt.ylabel('Square Sum of Weights')\n",
    "plt.grid(True)\n",
    "\n",
    "# Save the figure as a vector graphic (SVG format)\n",
    "plt.savefig(\"plot_output.svg\", format=\"svg\")\n"
   ]
  }
 ],
 "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
}
