{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 53,
   "metadata": {},
   "outputs": [],
   "source": [
    "from math import sqrt\n",
    "from random import seed\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import torch as th\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "\n",
    "plt.rc('font', family='serif', size=8)\n",
    "plt.rc('text', usetex=True)\n",
    "th.manual_seed(0)\n",
    "seed(0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_embeddings(n, d, norm=True):\n",
    "    emb = th.randn(n, d)\n",
    "    if norm:\n",
    "        emb /= emb.norm(dim=1, keepdim=True)\n",
    "    else:\n",
    "        emb /= sqrt(d)\n",
    "    return emb\n",
    "\n",
    "\n",
    "class AssMem(nn.Module):\n",
    "    def __init__(self, E, U, W, learnable=False):\n",
    "        \"\"\"\n",
    "        E: torch.Tensor\n",
    "            Input embedding matrix of size $n \\times d$,\n",
    "            where $n$ is the number of tokens and $d$ is the embedding dimension.\n",
    "        U: torch.Tensor\n",
    "            Output unembedding matrix of size $d \\times m$,\n",
    "            where $m$ is the number of classes and $d$ is the embedding dimension.\n",
    "        W: torch.Tensor\n",
    "            Weight matrix of size $d \\times d$, at initialization.\n",
    "        \"\"\"\n",
    "        super().__init__()\n",
    "        if learnable:\n",
    "            self.W = nn.Parameter(W)\n",
    "        else:\n",
    "            self.W = W\n",
    "        self.E = E\n",
    "        self.U = U\n",
    "\n",
    "    def forward(self, x):\n",
    "        return self.E[x] @ self.W @ self.U\n",
    "\n",
    "    def score(self, x):\n",
    "        out = self.E[x] @ self.W @ self.U\n",
    "        return F.softmax(out, dim=-1)\n",
    "    \n",
    "    def noise_gradient(self, scores, proba):\n",
    "        return self.E.T @ (scores * proba[:, None]) @ self.U.T\n",
    "\n",
    "    def signal_gradient(self, all_y, proba):\n",
    "        gradient = (self.E.T * proba) @ self.U[:, all_y].T\n",
    "        gradient *= -1\n",
    "        return gradient\n",
    "\n",
    "    def population_gradient(self, all_x, all_y, proba):\n",
    "        scores = self.score(all_x)\n",
    "        grad = self.noise_gradient(scores, proba)\n",
    "        grad += self.signal_gradient(all_y, proba)\n",
    "        return grad\n",
    "\n",
    "    def SGD_update(self, all_x, all_y, proba, lr, verbose=False):\n",
    "        grad = self.population_gradient(all_x, all_y, proba)\n",
    "        self.W -= lr * grad\n",
    "        if verbose:\n",
    "            return grad.std()\n",
    "\n",
    "    def rescaleSGD_update(self, all_x, all_y, proba, lr):\n",
    "        grad = self.population_gradient(all_x, all_y, proba)\n",
    "        grad /= grad.std()\n",
    "        self.W -= lr * grad\n",
    "\n",
    "    def signSGD_update(self, all_x, all_y, proba, lr):\n",
    "        grad = self.population_gradient(all_x, all_y, proba)\n",
    "        self.W -= lr * th.sign(grad)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 55,
   "metadata": {},
   "outputs": [],
   "source": [
    "# number of input tokens\n",
    "n = 10\n",
    "# number of output classes\n",
    "m = 5\n",
    "# memory dimension\n",
    "d = 10\n",
    "\n",
    "# Zipf parameter\n",
    "alpha = 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 56,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Population data\n",
    "all_x = th.arange(n)\n",
    "proba = (all_x + 1.) ** (-alpha)\n",
    "proba /= proba.sum()\n",
    "all_y = all_x % m"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 86,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_350405/3438201007.py:34: RuntimeWarning: More than 20 figures have been opened. Figures created through the pyplot interface (`matplotlib.pyplot.figure`) are retained until explicitly closed and may consume too much memory. (To control this warning, see the rcParam `figure.max_open_warning`).\n",
      "  fig, ax = plt.subplots(1, 3, figsize=(4, 4))\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAUoAAAFICAYAAAA24bcOAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8qNh9FAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAFp0lEQVR4nO3WMetWdRiH8f76QA2GbZoOQhjSUkIUCNJQg0s0NLT1JnoHQbT2CpqaQlobkpaC1qAICoWKoMSM/BM5hD6nVxDXWR7uQ34+8z18OQcufkfLsiyPAfCfTkwPANg6oQQIQgkQhBIgCCVAEEqAIJQAQSgBglAChN3aw/3tZw+5Y7Ounbs8PQE4kBv766vuvCgBglACBKEECEIJEIQSIAglQBBKgCCUAEEoAYJQAgShBAhCCRCEEiAIJUAQSoAglABBKAGCUAIEoQQIQgkQhBIgCCVAEEqAIJQAQSgBglACBKEECEIJEIQSIAglQNitPbx27vIBZ2zX8acXpyeMePL9U9MTRuy+vjk9YcTRhfPTEzbNixIgCCVAEEqAIJQAQSgBglACBKEECEIJEIQSIAglQBBKgCCUAEEoAYJQAgShBAhCCRCEEiAIJUAQSoAglABBKAGCUAIEoQQIQgkQhBIgCCVAEEqAIJQAQSgBglAChN30gK07/fqP0xNGXPvmz+kJIz5/4/npCSOW3x/N/72WFyVAEEqAIJQAQSgBglACBKEECEIJEIQSIAglQBBKgCCUAEEoAYJQAgShBAhCCRCEEiAIJUAQSoAglABBKAGCUAIEoQQIQgkQhBIgCCVAEEqAIJQAQSgBglAChN3qw7NnDrljsx7cuTs9YcRnb1+ZnjDi4se3pieMuPnyP9MTNs2LEiAIJUAQSoAglABBKAGCUAIEoQQIQgkQhBIgCCVAEEqAIJQAQSgBglACBKEECEIJEIQSIAglQBBKgCCUAEEoAYJQAgShBAhCCRCEEiAIJUAQSoAglABBKAGCUAKE3drDB3fuHnLHdu0fTi+Y8e0P0wtG3Lp6cnrCiA9//nJ6wqZ5UQIEoQQIQgkQhBIgCCVAEEqAIJQAQSgBglACBKEECEIJEIQSIAglQBBKgCCUAEEoAYJQAgShBAhCCRCEEiAIJUAQSoAglABBKAGCUAIEoQQIQgkQhBIgCCVAEEqAsFt9uewPOGO7dmfPTE+Y8cTj0wtG/P3co/m/X/3q0vSEEbfeWnfnRQkQhBIgCCVAEEqAIJQAQSgBglACBKEECEIJEIQSIAglQBBKgCCUAEEoAYJQAgShBAhCCRCEEiAIJUAQSoAglABBKAGCUAIEoQQIQgkQhBIgCCVAEEqAIJQAQSgBwtGyLMuaw0vvfnDoLWzIMx/9Oj1hxP72nekJI/b3709PGHFjf33VnRclQBBKgCCUAEEoAYJQAgShBAhCCRCEEiAIJUAQSoAglABBKAGCUAIEoQQIQgkQhBIgCCVAEEqAIJQAQSgBglACBKEECEIJEIQSIAglQBBKgCCUAEEoAYJQAgShBAi7tYcnXzg+5I7NuvDOX9MTRtx76enpCSNOffLL9AQ2yIsSIAglQBBKgCCUAEEoAYJQAgShBAhCCRCEEiAIJUAQSoAglABBKAGCUAIEoQQIQgkQhBIgCCVAEEqAIJQAQSgBglACBKEECEIJEIQSIAglQBBKgCCUAEEoAcJu7eH5N7875I7Nerhb/Yn+V05ePjs9YcTpL56anjDi+Oof0xM2zYsSIAglQBBKgCCUAEEoAYJQAgShBAhCCRCEEiAIJUAQSoAglABBKAGCUAIEoQQIQgkQhBIgCCVAEEqAIJQAQSgBglACBKEECEIJEIQSIAglQBBKgCCUAEEoAYJQAoTd2sMHr714yB2b9cT3v01PGLGcOJqeMOL4lXvTE0b89N6V6Qmb5kUJEIQSIAglQBBKgCCUAEEoAYJQAgShBAhCCRCEEiAIJUAQSoAglABBKAGCUAIEoQQIQgkQhBIgCCVAEEqAIJQAQSgBglACBKEECEIJEIQSIAglQBBKgCCUAEEoAcLRsizL9AiALfOiBAhCCRCEEiAIJUAQSoAglABBKAGCUAIEoQQI/wJGKlWEGVaLjwAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAUoAAAFICAYAAAA24bcOAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8qNh9FAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAE7UlEQVR4nO3WwWnkUBRFwfGgKLT3XlkoWEfQOImOonEU1iTg8dGmeYKuWv/FhQ+H93Ycx/EHgP/6Oz0A4OqEEiAIJUAQSoAglABBKAGCUAIEoQQIQgkQlrMPv7/en7njsvZ1m54APMnn98epdy5KgCCUAEEoAYJQAgShBAhCCRCEEiAIJUAQSoAglABBKAGCUAIEoQQIQgkQhBIgCCVAEEqAIJQAQSgBglACBKEECEIJEIQSIAglQBBKgCCUAEEoAYJQAgShBAhCCRCWsw/3dXvijOu6Pe7TE0a86n/DT1yUAEEoAYJQAgShBAhCCRCEEiAIJUAQSoAglABBKAGCUAIEoQQIQgkQhBIgCCVAEEqAIJQAQSgBglACBKEECEIJEIQSIAglQBBKgCCUAEEoAYJQAgShBAhCCRCEEiAs0wOubl+36Qkjbo/79IQRr/rf/M5FCRCEEiAIJUAQSoAglABBKAGCUAIEoQQIQgkQhBIgCCVAEEqAIJQAQSgBglACBKEECEIJEIQSIAglQBBKgCCUAEEoAYJQAgShBAhCCRCEEiAIJUAQSoAglABhmR7ANe3rNj1hxO1xn54w4lX/+ywXJUAQSoAglABBKAGCUAIEoQQIQgkQhBIgCCVAEEqAIJQAQSgBglACBKEECEIJEIQSIAglQBBKgCCUAEEoAYJQAgShBAhCCRCEEiAIJUAQSoAglABBKAGCUAIEoQQIy/QAuJJ93aYnjLg97tMTLs1FCRCEEiAIJUAQSoAglABBKAGCUAIEoQQIQgkQhBIgCCVAEEqAIJQAQSgBglACBKEECEIJEIQSIAglQBBKgCCUAEEoAYJQAgShBAhCCRCEEiAIJUAQSoAglABBKAHC23Ecx5mH31/vz95ySfu6TU8AnuTz++PUOxclQBBKgCCUAEEoAYJQAgShBAhCCRCEEiAIJUAQSoAglABBKAGCUAIEoQQIQgkQhBIgCCVAEEqAIJQAQSgBglACBKEECEIJEIQSIAglQBBKgCCUAEEoAYJQAgShBAjL2Yf7uj1xxnXdHvfpCSNe9b/hJy5KgCCUAEEoAYJQAgShBAhCCRCEEiAIJUAQSoAglABBKAGCUAIEoQQIQgkQhBIgCCVAEEqAIJQAQSgBglACBKEECEIJEIQSIAglQBBKgCCUAEEoAYJQAgShBAhCCRCW6QFXt6/b9IQRt8d9esKIV/1vfueiBAhCCRCEEiAIJUAQSoAglABBKAGCUAIEoQQIQgkQhBIgCCVAEEqAIJQAQSgBglACBKEECEIJEIQSIAglQBBKgCCUAEEoAYJQAgShBAhCCRCEEiAIJUAQSoCwTA/gmvZ1m54w4va4T08Y8ar/fZaLEiAIJUAQSoAglABBKAGCUAIEoQQIQgkQhBIgCCVAEEqAIJQAQSgBglACBKEECEIJEIQSIAglQBBKgCCUAEEoAYJQAgShBAhCCRCEEiAIJUAQSoAglABBKAGCUAKEZXoAXMm+btMTRtwe9+kJl+aiBAhCCRCEEiAIJUAQSoAglABBKAGCUAIEoQQIQgkQhBIgCCVAEEqAIJQAQSgBglACBKEECEIJEIQSIAglQBBKgCCUAEEoAYJQAgShBAhCCRCEEiAIJUAQSoAglADh7TiOY3oEwJW5KAGCUAIEoQQIQgkQhBIgCCVAEEqAIJQAQSgBwj+sgDP6gj/kHAAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAUoAAAFICAYAAAA24bcOAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8qNh9FAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAE7UlEQVR4nO3WwWnkUBRFwfGgKLT3XlkoWEfQOImOonEU1iTg8dGmeYKuWv/FhQ+H93Ycx/EHgP/6Oz0A4OqEEiAIJUAQSoAglABBKAGCUAIEoQQIQgkQlrMPv7/en7njsvZ1m54APMnn98epdy5KgCCUAEEoAYJQAgShBAhCCRCEEiAIJUAQSoAglABBKAGCUAIEoQQIQgkQhBIgCCVAEEqAIJQAQSgBglACBKEECEIJEIQSIAglQBBKgCCUAEEoAYJQAgShBAhCCRCWsw/3dXvijOu6Pe7TE0a86n/DT1yUAEEoAYJQAgShBAhCCRCEEiAIJUAQSoAglABBKAGCUAIEoQQIQgkQhBIgCCVAEEqAIJQAQSgBglACBKEECEIJEIQSIAglQBBKgCCUAEEoAYJQAgShBAhCCRCEEiAs0wOubl+36Qkjbo/79IQRr/rf/M5FCRCEEiAIJUAQSoAglABBKAGCUAIEoQQIQgkQhBIgCCVAEEqAIJQAQSgBglACBKEECEIJEIQSIAglQBBKgCCUAEEoAYJQAgShBAhCCRCEEiAIJUAQSoAglABhmR7ANe3rNj1hxO1xn54w4lX/+ywXJUAQSoAglABBKAGCUAIEoQQIQgkQhBIgCCVAEEqAIJQAQSgBglACBKEECEIJEIQSIAglQBBKgCCUAEEoAYJQAgShBAhCCRCEEiAIJUAQSoAglABBKAGCUAIEoQQIy/QAuJJ93aYnjLg97tMTLs1FCRCEEiAIJUAQSoAglABBKAGCUAIEoQQIQgkQhBIgCCVAEEqAIJQAQSgBglACBKEECEIJEIQSIAglQBBKgCCUAEEoAYJQAgShBAhCCRCEEiAIJUAQSoAglABBKAHC23Ecx5mH31/vz95ySfu6TU8AnuTz++PUOxclQBBKgCCUAEEoAYJQAgShBAhCCRCEEiAIJUAQSoAglABBKAGCUAIEoQQIQgkQhBIgCCVAEEqAIJQAQSgBglACBKEECEIJEIQSIAglQBBKgCCUAEEoAYJQAgShBAjL2Yf7uj1xxnXdHvfpCSNe9b/hJy5KgCCUAEEoAYJQAgShBAhCCRCEEiAIJUAQSoAglABBKAGCUAIEoQQIQgkQhBIgCCVAEEqAIJQAQSgBglACBKEECEIJEIQSIAglQBBKgCCUAEEoAYJQAgShBAhCCRCW6QFXt6/b9IQRt8d9esKIV/1vfueiBAhCCRCEEiAIJUAQSoAglABBKAGCUAIEoQQIQgkQhBIgCCVAEEqAIJQAQSgBglACBKEECEIJEIQSIAglQBBKgCCUAEEoAYJQAgShBAhCCRCEEiAIJUAQSoCwTA/gmvZ1m54w4va4T08Y8ar/fZaLEiAIJUAQSoAglABBKAGCUAIEoQQIQgkQhBIgCCVAEEqAIJQAQSgBglACBKEECEIJEIQSIAglQBBKgCCUAEEoAYJQAgShBAhCCRCEEiAIJUAQSoAglABBKAGCUAKEZXoAXMm+btMTRtwe9+kJl+aiBAhCCRCEEiAIJUAQSoAglABBKAGCUAIEoQQIQgkQhBIgCCVAEEqAIJQAQSgBglACBKEECEIJEIQSIAglQBBKgCCUAEEoAYJQAgShBAhCCRCEEiAIJUAQSoAglADh7TiOY3oEwJW5KAGCUAIEoQQIQgkQhBIgCCVAEEqAIJQAQSgBwj+sgDP6gj/kHAAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "random_init = False\n",
    "lr = 1.\n",
    "\n",
    "E = get_embeddings(n, d, norm=False)\n",
    "U = get_embeddings(m, d, norm=True).T\n",
    "\n",
    "if random_init:\n",
    "    W = th.randn(d, d)\n",
    "else:\n",
    "    W = th.zeros(d, d)\n",
    "\n",
    "model_SGD = AssMem(E, U, W)\n",
    "model_signSGD = AssMem(E, U, W.clone())\n",
    "model_rescaleSGD = AssMem(E, U, W.clone())\n",
    "# model_adam = AssMem(E, U, W.clone(), learnable=True)\n",
    "# opti = th.optim.Adam(model_adam.parameters(), betas=(0, 0), lr=lr)\n",
    "\n",
    "for i in range(100):\n",
    "    model_SGD.SGD_update(all_x, all_y, proba, lr)\n",
    "    model_signSGD.signSGD_update(all_x, all_y, proba, lr)\n",
    "    model_rescaleSGD.rescaleSGD_update(all_x, all_y, proba, lr)\n",
    "\n",
    "    # out = model_adam(all_x)\n",
    "    # loss = (proba * F.cross_entropy(out, all_y, reduction='none')).sum()\n",
    "    # opti.zero_grad()\n",
    "    # loss.backward()\n",
    "    # opti.step()\n",
    "\n",
    "    if i in [0, 1, 2, 3, 6, 99]:\n",
    "        img1 = model_SGD.score(all_x)\n",
    "        img2 = model_signSGD.score(all_x)\n",
    "        img3 = model_rescaleSGD.score(all_x)\n",
    "\n",
    "        fig, ax = plt.subplots(1, 3, figsize=(4, 4))\n",
    "        ax[0].imshow(img1, aspect='auto')\n",
    "        ax[1].imshow(img2, aspect='auto')\n",
    "        ax[2].imshow(img3, aspect='auto')\n",
    "        fig.savefig(f'comparison_{i}.png')\n",
    "\n",
    "        fig, ax = plt.subplots(1, 1, figsize=(4, 4))\n",
    "        ax.imshow(img1, aspect='auto')\n",
    "        ax.set_axis_off()\n",
    "        fig.savefig(f'sgd_{i}.png')\n",
    "\n",
    "        fig, ax = plt.subplots(1, 1, figsize=(4, 4))\n",
    "        ax.imshow(img2, aspect='auto')\n",
    "        ax.set_axis_off()\n",
    "        fig.savefig(f'sign_sgd_{i}.png')\n",
    "\n",
    "        fig, ax = plt.subplots(1, 1, figsize=(4, 4))\n",
    "        ax.imshow(img3, aspect='auto')\n",
    "        ax.set_axis_off()\n",
    "        fig.savefig(f'rescale_sgd_{i}.png')\n",
    "        # with th.no_grad():\n",
    "        #     img4 = model_adam.score(all_x)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 58,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59,60,61,62,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,81,82,83,84,85,86,87,88,89,90,91,92,93,94,95,96,97,98,99,"
     ]
    }
   ],
   "source": [
    "\n",
    "nb_epochs = 100\n",
    "nb_trials = 100\n",
    "random_init = False\n",
    "lr = 1.\n",
    "\n",
    "errors = th.zeros(4, nb_trials, nb_epochs)\n",
    "var = th.zeros(nb_trials, nb_epochs)\n",
    "\n",
    "for i_t in range(nb_trials):\n",
    "\n",
    "    E = get_embeddings(n, d, norm=False)\n",
    "    U = get_embeddings(m, d, norm=True).T\n",
    "\n",
    "    if random_init:\n",
    "        W = th.randn(d, d)\n",
    "    else:\n",
    "        W = th.zeros(d, d)\n",
    "\n",
    "    model_SGD = AssMem(E, U, W)\n",
    "    model_signSGD = AssMem(E, U, W.clone())\n",
    "    model_rescaleSGD = AssMem(E, U, W.clone())\n",
    "    model_adam = AssMem(E, U, W.clone(), learnable=True)\n",
    "    opti = th.optim.Adam(model_adam.parameters(), betas=(0.9, 0), lr=lr)\n",
    "\n",
    "    for i in range(nb_epochs):\n",
    "        var[i_t, i] = model_SGD.SGD_update(all_x, all_y, proba, lr, verbose=True)\n",
    "        model_signSGD.signSGD_update(all_x, all_y, proba, lr)\n",
    "        model_rescaleSGD.rescaleSGD_update(all_x, all_y, proba, lr)\n",
    "\n",
    "        out = model_adam(all_x)\n",
    "        loss = (proba * F.cross_entropy(out, all_y, reduction='none')).sum()\n",
    "        opti.zero_grad()\n",
    "        loss.backward()\n",
    "        opti.step()\n",
    "\n",
    "        with th.no_grad():\n",
    "            pred1 = model_SGD.score(all_x).argmax(dim=-1)\n",
    "            pred2 = model_signSGD.score(all_x).argmax(dim=-1)\n",
    "            pred3 = model_rescaleSGD.score(all_x).argmax(dim=-1)\n",
    "            pred4 = model_adam.score(all_x).argmax(dim=-1)\n",
    "            errors[0, i_t, i] = proba[pred1 != all_y].mean()\n",
    "            errors[1, i_t, i] = proba[pred2 != all_y].mean()\n",
    "            errors[2, i_t, i] = proba[pred3 != all_y].mean()\n",
    "            errors[3, i_t, i] = proba[pred4 != all_y].mean()\n",
    "\n",
    "    print(i_t, end=',')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 59,
   "metadata": {},
   "outputs": [],
   "source": [
    "errors[th.isnan(errors)] = 0\n",
    "mean_errors = errors.mean(dim=1)\n",
    "std_errors = errors.std(dim=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 81,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 150x100 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 150x150 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(1, 1, figsize=(1.5, 1))\n",
    "a, =  ax.plot(mean_errors[0], label='SGD')\n",
    "ax.fill_between(np.arange(nb_epochs), mean_errors[0] - std_errors[0], mean_errors[0] + std_errors[0], alpha=0.2)\n",
    "b, = ax.plot(mean_errors[1], label='signSGD')\n",
    "ax.fill_between(np.arange(nb_epochs), mean_errors[1] - std_errors[1], mean_errors[1] + std_errors[1], alpha=0.2)\n",
    "c, = ax.plot(mean_errors[2], label='rescaleSGD')\n",
    "ax.fill_between(np.arange(nb_epochs), mean_errors[2] - std_errors[2], mean_errors[2] + std_errors[2], alpha=0.2)\n",
    "ax.set_xlabel('Epoch')\n",
    "ax.set_ylabel('Error')\n",
    "ax.set_yscale('log')\n",
    "fig.savefig('adam_errors.pdf', bbox_inches='tight')\n",
    "\n",
    "fig, ax = plt.subplots(1, 1, figsize=(1.5, 1.5))\n",
    "ax.legend([a, b, c], ['SGD', 'sign SGD', 'norm SGD'], fontsize=8, loc='upper left')\n",
    "ax.set_axis_off()\n",
    "fig.savefig('adam_legend.pdf', bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 79,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 150x100 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(1, 1, figsize=(1.5, 1))\n",
    "ax.plot(var.mean(dim=0))\n",
    "ax.set_xlabel('Epoch')\n",
    "ax.set_yscale('log')\n",
    "ax.set_ylabel('Gradient variance')\n",
    "fig.savefig('adam_variance.pdf', bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([0, 1, 2, 3, 4, 0, 1, 2, 3, 4])"
      ]
     },
     "execution_count": 38,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "dev",
   "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.10.4"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
