{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 49,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Files already downloaded and verified\n",
      "Files already downloaded and verified\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 33%|███▎      | 1/3 [00:18<00:37, 18.51s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Accuracy of the model on the 10000 test images: 9.68%\n",
      "Epoch [2/3], Loss: 2.4419\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 67%|██████▋   | 2/3 [00:42<00:21, 21.68s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Accuracy of the model on the 10000 test images: 10.18%\n",
      "Epoch [3/3], Loss: 2.3210\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 3/3 [01:06<00:00, 22.23s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Accuracy of the model on the 10000 test images: 12.34%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      " 33%|███▎      | 1/3 [00:18<00:37, 18.51s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Accuracy of the model on the 10000 test images: 9.76%\n",
      "Epoch [2/3], Loss: 2.1653\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 67%|██████▋   | 2/3 [00:45<00:23, 23.51s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Accuracy of the model on the 10000 test images: 18.22%\n",
      "Epoch [3/3], Loss: 2.0395\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 3/3 [01:12<00:00, 24.09s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Accuracy of the model on the 10000 test images: 21.01%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      " 33%|███▎      | 1/3 [00:18<00:37, 18.56s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Accuracy of the model on the 10000 test images: 10.71%\n",
      "Epoch [2/3], Loss: 2.4179\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 67%|██████▋   | 2/3 [00:42<00:21, 21.54s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Accuracy of the model on the 10000 test images: 11.11%\n",
      "Epoch [3/3], Loss: 2.1982\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 3/3 [01:06<00:00, 22.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Accuracy of the model on the 10000 test images: 13.19%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      " 33%|███▎      | 1/3 [00:18<00:37, 18.55s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Accuracy of the model on the 10000 test images: 9.67%\n",
      "Epoch [2/3], Loss: 2.1249\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 67%|██████▋   | 2/3 [00:48<00:24, 24.97s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Accuracy of the model on the 10000 test images: 20.92%\n",
      "Epoch [3/3], Loss: 1.9653\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 3/3 [01:17<00:00, 25.81s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Accuracy of the model on the 10000 test images: 23.94%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      " 33%|███▎      | 1/3 [00:18<00:37, 18.55s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Accuracy of the model on the 10000 test images: 9.74%\n",
      "Epoch [2/3], Loss: 2.2725\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 67%|██████▋   | 2/3 [00:44<00:22, 22.74s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Accuracy of the model on the 10000 test images: 15.80%\n",
      "Epoch [3/3], Loss: 2.1199\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 3/3 [01:10<00:00, 23.36s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Accuracy of the model on the 10000 test images: 18.72%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "import torch\n",
    "import tqdm\n",
    "import math\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 pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "\n",
    "\n",
    "from utils import variance_norms, isometry_gap\n",
    "\n",
    "\n",
    "# Define the MLP model with layer normalization\n",
    "class MLP(nn.Module):\n",
    "    def __init__(self, input_size, hidden_size, num_layers, num_classes, normalize='LN'):\n",
    "        super(MLP, self).__init__()\n",
    "        if normalize=='LN':\n",
    "            self.norm = nn.LayerNorm(hidden_size)\n",
    "        elif normalize=='None':\n",
    "            self.norm = nn.Identity()\n",
    "            \n",
    "        self.layers = nn.Sequential()\n",
    "        self.layers.add_module('layer0', nn.Linear(input_size, hidden_size))\n",
    "        self.layers.add_module('norm0', self.norm)\n",
    "\n",
    "        for i in range(1, num_layers - 1):\n",
    "            self.layers.add_module(f'act{i}', nn.ReLU())\n",
    "            self.layers.add_module(f'norm{i}', self.norm)\n",
    "            self.layers.add_module(f'layer{i}', nn.Linear(hidden_size, hidden_size))\n",
    "\n",
    "        self.layers.add_module(f'layer{num_layers-1}', nn.Linear(hidden_size, num_classes))\n",
    "        self.apply(self.init_weights)\n",
    "\n",
    "    def init_weights(self, layer):\n",
    "        if isinstance(layer, nn.Linear):\n",
    "            std = 1 / math.sqrt(layer.weight.size(1))\n",
    "            nn.init.normal_(layer.weight, mean=0, std=std)\n",
    "            \n",
    "    def forward(self, x):\n",
    "        x = x.view(x.size(0), -1)\n",
    "        hidden_layers = []\n",
    "        for i, layer in enumerate(self.layers):\n",
    "            x = layer(x)\n",
    "            hidden_layers.append((layer,x))\n",
    "        output = x\n",
    "        return output, hidden_layers\n",
    "\n",
    "# Hyperparameters\n",
    "input_size = 3 * 32 * 32\n",
    "hidden_size = 1000\n",
    "num_layers = 30\n",
    "num_classes = 10\n",
    "batch_size = 256\n",
    "learning_rate = 0.001\n",
    "num_epochs = 3\n",
    "num_rerun = 5\n",
    "\n",
    "\n",
    "# Data preprocessing\n",
    "transform = transforms.Compose([\n",
    "    transforms.ToTensor(),\n",
    "    transforms.Normalize((0.5, 0.5, 0.5), (0.5, 0.5, 0.5))\n",
    "])\n",
    "\n",
    "train_dataset = datasets.CIFAR10(root='./data', train=True, transform=transform, download=True)\n",
    "test_dataset = datasets.CIFAR10(root='./data', train=False, transform=transform, download=True)\n",
    "\n",
    "train_loader = DataLoader(dataset=train_dataset, batch_size=batch_size, shuffle=True)\n",
    "test_loader = DataLoader(dataset=test_dataset, batch_size=batch_size, shuffle=False)\n",
    "\n",
    "# Create the model, loss function, and optimizer\n",
    "device = torch.device('cuda:1' if torch.cuda.is_available() else 'cpu')\n",
    "\n",
    "\n",
    "df = []\n",
    "for rerun in range(num_rerun):\n",
    "    for normalize in [\"LN\"]:\n",
    "\n",
    "        model = MLP(input_size, hidden_size, num_layers, num_classes,normalize=normalize).to(device)\n",
    "        criterion = nn.CrossEntropyLoss()\n",
    "        optimizer = optim.Adam(model.parameters(), lr=learning_rate)\n",
    "\n",
    "        for epoch in tqdm.trange(num_epochs):\n",
    "            for i, (images, labels) in enumerate(train_loader):\n",
    "                if epoch==0:\n",
    "                    break\n",
    "                images = images.to(device)\n",
    "                labels = labels.to(device)\n",
    "\n",
    "                outputs, hidden = model(images)\n",
    "                loss = criterion(outputs, labels)\n",
    "\n",
    "                optimizer.zero_grad()\n",
    "                loss.backward()\n",
    "                optimizer.step()\n",
    "            if epoch>0:\n",
    "                print(f'Epoch [{epoch+1}/{num_epochs}], Loss: {loss.item():.4f}')\n",
    "\n",
    "            # Test the model\n",
    "            model.eval()\n",
    "            with torch.no_grad():\n",
    "                correct = 0\n",
    "                total = 0\n",
    "                for i, (images, labels) in enumerate(test_loader):\n",
    "                    images = images.to(device)\n",
    "                    labels = labels.to(device)\n",
    "\n",
    "                    outputs, hidden = model(images)\n",
    "                    loss = criterion(outputs, labels)\n",
    "                    _, predicted = torch.max(outputs.data, 1)\n",
    "                    total += labels.size(0)\n",
    "                    correct += (predicted == labels).sum().item()\n",
    "                    for li,(l,h) in enumerate(hidden):\n",
    "                        ig = isometry_gap(h.flatten(1) @ h.flatten(1).t(),epsilon=1e-8).item()\n",
    "                        nb = variance_norms(h.flatten(1)).item()\n",
    "                        df.append({'rerun': rerun,\n",
    "                                   'normalize': normalize,\n",
    "                                   'l': li, 'layer': type(l).__name__, \n",
    "                                   'iso_gap': ig, \n",
    "                                   'norm_bias': nb, \n",
    "                                   'stage': 'test', \n",
    "                                   'loss': loss.item(),\n",
    "                                   'accuracy': (predicted == labels).sum().item() / len(labels),\n",
    "                                   'epoch': epoch, \n",
    "                                   'i': i})\n",
    "\n",
    "            print(f'Accuracy of the model on the 10000 test images: {100 * correct / total:.2f}%')\n",
    "df = pd.DataFrame(df)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 52,
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "<ipython-input-52-1217cf3d7532>:20: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame.\n",
      "Try using .loc[row_indexer,col_indexer] = value instead\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df2.l = df2.l//3\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 640x480 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAiAAAAEUCAYAAAASio06AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAABioklEQVR4nO3dd3xUVfr48c+9d1omvSckIRRJIVRBBOlFRVFBFMFVVxRW/bq6ol/dIrqWtf1WXXV3LYug66oLyopK+YoKtkWQDtISekghBEghder9/THJQEyCJDOpPO/Xi03m3jtzz8m4mSfnPOc5iq7rOkIIIYQQrUht6wYIIYQQ4vwjAYgQQgghWp0EIEIIIYRodRKACCGEEKLVSQAihBBCiFYnAYgQQgghWp0EIEIIIYRodRKACCGEEKLVSQAihBBCiFYnAYgQQgghWp0EIEKIc/b73/+e1NRUlixZ8rPX/u1vfyM1NZXU1FTef//9Bq9ZsmQJqampvPTSS/5uqhCinZMARAjR4l599VXKy8vbuhlCiHZEAhAhRItKTk7m5MmTvPnmm23dFCFEOyIBiBCiRd18883ExMTwz3/+k4KCgrZujhCinZAARAjRogICArjvvvuorq6WXA8hhJcEIEKIFjd16lRSUlJYunQpe/bsaevmCCHaAQlAhBAtTlVVfvvb3+J2u/nzn//c1s0RQrQDEoAIIVrFyJEjGTFiBGvXruXbb79t6+YIIdqYBCBCiFbz0EMPoaoqzz//PC6Xq62bI4RoQxKACCFaTVpaGlOmTGHfvn189NFHbd0cIUQbkgBECNGq5syZQ0BAAH/961+pqqpq6+YIIdqIBCBCiFYVGxvLbbfdxvHjx3nnnXfaujlCiDZiaOsGCCE6nsWLF7Nhw4YGz1111VWMGDHirM+fPXs2H374IdnZ2S3RPCFEByABiBCiybZs2cKWLVsaPJeWlvazAUhgYCD33nsvjz32WEs0TwjRASi6rutt3YiOZsWKFbz//vtkZmbicDjYsWNHWzdJCCGE6FAkB6QZQkJC+MUvfsHDDz/c1k0RQgghOiSZgmmGkSNHArB+/fo2bokQQgjRMXXqAGTevHns3r2b3bt3c+TIEVRVZffu3Y1e/8UXXzB//nz27t2L0Whk0KBBPPDAA6SkpLRiq4UQQojOr1NPwbz44ot8//33xMXFERUVddZrFy9ezL333ktVVRUPPvggd911F1lZWcyYMYOsrKxWarEQQghxfujUIyBffvklXbt2BeCWW26hqKiowetKS0t57rnniIuLY+HChQQFBQFwxRVXMGnSJJ5++mn+9a9/tVq7hRBCiM6uU4+A1AYfP2f16tWUl5czbdo0b/AB0KVLFy6//HLWr1/P0aNHW6qZQgghxHmnUwcg52r79u0ADBw4sN652mNnLrV1uVzYbDYcDgcANpsNm83W5Pu63W4qKytxu93NabYQQgjRYXXqKZhzdezYMQDi4uLqnas9VlBQ4D326aef8oc//MH7uF+/fgBNzhWprq5mz549TW6vEEKI1jFo0KC2bkKnJQEIeDfEMplM9c7VHquurvYemzp1KlOnTvXb/VNSUrBarU1+nsvlYseOHfTt2xdN0/zWnvZM+ix97ozOt/7C+dlnUZcEIEBAQAAAdru93rnaYxaLpcXur2maT/8H9PX5HZH0+fxwvvX5fOsvnJ99Fh5NygFxu93s3bvXO2VxJofDwcaNG/3WsNYUGxsL1J1mqVV7rKHpGSGEEEI0zzkHIHl5eVx99dVcc801jBkzhrvuuovi4mLv+dLSUn75y1+2SCNbWm0Ox9atW+ud27ZtGwB9+/ZtzSYJIYQQndo5ByDPP/88MTExrFq1iiVLllBdXc2NN95YZzSko+5rN2HCBAIDA1m8eDHl5eXe4/n5+axcuZIhQ4YQHx/fhi0UQgghOpdzzgHZuHEjCxYsIDExEYC33nqLP/7xj9x0003861//wmQyoShKizW0OT755BPy8/MBzwiOruu89tpr3vN33303AKGhofz2t7/lscce48Ybb2T69OnY7Xbee+89AObOndv6jRdCCNFsut0GbifuwlzUmERQDSgmc1s3S5zhnAOQqqoqjEaj97Gqqjz11FM89thj3Hzzzbzwwgst0kBffPTRR2zYsKHOsVdeecX7fW0AAjBjxgzCwsJYsGABzz//PEajkcGDBzNnzhzS0tJarc1CCCF8o9ttOHeswfHVQnC7QNUwjrsRQ98REoS0I+ccgHTv3p2dO3fSs2fPOsefeOIJHn/8ce666y6/N85X7777bpOunzhxIhMnTmyh1gghhGgVbufp4APA7cLx1UIMGUMBCUDai3POAbnssstYvnx5g+cef/xxrrzyyg6bAyKEEKLzcBfmng4+vAdd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\n",
      "text/plain": [
       "<Figure size 532.375x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "def plot_line_graph(data, y, y_label, file_name, **kwargs):\n",
    "    plt.figure()\n",
    "    sns.set_style('whitegrid')\n",
    "    sns.set_context('paper', font_scale=1.5)  # Increase the font size\n",
    "    g = sns.FacetGrid(data=data, height=3, aspect=1.5, **kwargs)\n",
    "    g.map(sns.lineplot, \"l\", y, marker=\"o\",)\n",
    "    g.set_ylabels(y_label, fontsize=14)  # Increase the font size for y-label\n",
    "    g.set_xlabels(\"$\\ell$\", fontsize=14)  # Increase the font size for x-label\n",
    "    if 'col' in kwargs:\n",
    "        g.set_titles(\" {col_name}\", fontsize=14)  # Increase the font size for titles\n",
    "    if 'hue' in kwargs:\n",
    "        ncols = len(df[kwargs['hue']].unique())\n",
    "        g.add_legend(alignment='left', fontsize=14)  # Increase the font size for legend\n",
    "        # sns.move_legend(g, \"lower center\", bbox_to_anchor=(.45, -0.05), ncols=ncols, frameon=False)\n",
    "    plt.yscale('log')\n",
    "    plt.savefig(file_name, bbox_inches=\"tight\")\n",
    "    plt.show()\n",
    "\n",
    "df2 = df.loc[(df.layer=='ReLU')&(df.epoch<10)]\n",
    "df2.l = df2.l//3\n",
    "plot_line_graph(data=df2,#.loc[df.norm_layer=='BN'], \n",
    "                y='norm_bias', y_label=\" $Var(a_\\ell)/mean(a_\\ell)^2$\", \n",
    "                hue=\"epoch\",col=\"normalize\", \n",
    "                palette=\"rocket\",\n",
    "                file_name='plots/norm_bias_training.pdf')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 53,
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "<ipython-input-53-35dd3113c015>:2: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame.\n",
      "Try using .loc[row_indexer,col_indexer] = value instead\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df2.l = df2.l//3\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 640x480 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 532.375x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "df2 = df.loc[(df.layer=='ReLU')]\n",
    "df2.l = df2.l//3\n",
    "plot_line_graph(data=df2,#.loc[df.norm_layer=='BN'], \n",
    "                y='iso_gap', y_label=\" $\\mathcal{I}(G^\\ell)$\", \n",
    "                hue=\"epoch\",col=\"normalize\", \n",
    "                palette=\"rocket\",\n",
    "                file_name='plots/iso_gap_training.pdf')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "mTjw9aAQz7Qz",
    "outputId": "e83dbe49-267e-42f0-93ff-082d9096de6b"
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "rScmjMMb0XzW"
   },
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "accelerator": "GPU",
  "colab": {
   "provenance": []
  },
  "gpuClass": "standard",
  "kernelspec": {
   "display_name": "Python 3",
   "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.8.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
