{
  "cells": [
    {
      "cell_type": "code",
      "execution_count": 1,
      "metadata": {
        "id": "lESWm6V2QYJu"
      },
      "outputs": [],
      "source": [
        "import math\n",
        "import torch\n",
        "import torch.nn.functional as torchF\n",
        "import matplotlib.pyplot as plt\n",
        "import tqdm"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 2,
      "metadata": {
        "id": "oq6ZsdH0C3Sh"
      },
      "outputs": [],
      "source": [
        "class BanditInstance:\n",
        "    def __init__(self, T, d, A, eps):\n",
        "        self.T = T      # horizon length \n",
        "        self.d = d      # feature dimension \n",
        "        self.A = A      # number of actions \n",
        "        self.eps = eps  # noise level \n",
        "        self.rewards = torch.zeros(T, A)\n",
        "        self.arms = torch.zeros(T, A, d)\n",
        "\n",
        "    def get_arms(self):\n",
        "        return self.arms[self.t]\n",
        "\n",
        "    def choose(self, a):\n",
        "        max_reward = torch.max(self.rewards[self.t])\n",
        "        obv_reward = self.rewards[self.t, a] + torch.randn(1) * self.eps\n",
        "\n",
        "        self.regret[self.t] = max(0, max_reward - self.rewards[self.t, a]) \n",
        "        self.tot_regret += self.regret[self.t]\n",
        "        self.range.set_description(\"Total Regret %.2f\" % self.tot_regret)\n",
        "\n",
        "        self.t += 1\n",
        "\n",
        "        return obv_reward \n",
        "\n",
        "    def horizon(self):\n",
        "        self.regret = torch.zeros(T)\n",
        "        self.tot_regret = 0\n",
        "        self.t = 0\n",
        "        self.range = tqdm.tqdm(range(T))\n",
        "        return self.range\n"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 3,
      "metadata": {
        "id": "V-a0hadgFCqz"
      },
      "outputs": [],
      "source": [
        "class LifeLongLinBandit(BanditInstance):\n",
        "    def __init__(self, T, d, A, eps, k, M):\n",
        "        super().__init__(T, d, A, eps)\n",
        "        self.k = k     # representation dimension\n",
        "        self.M = M     # number of tasks \n",
        "        \n",
        "        assert(self.k <= self.d)\n",
        "        assert(self.T % self.M == 0)\n",
        "\n",
        "        self.idx = [0] * T \n",
        "        for t in range(T):\n",
        "            self.idx[t] = t // (T // M) # tasks come in sequential\n",
        "\n",
        "        B = torch.nn.init.orthogonal_(torch.empty(k, d)) # representation\n",
        "        W = torchF.normalize(torch.randn(M, k), dim=1) # task identified vector\n",
        "        tasks_theta = W @ B\n",
        "        \n",
        "        self.arms = torchF.normalize(torch.randn(T, A, d), dim=2)\n",
        "        for t in range(T):\n",
        "            self.rewards[t] = torch.inner(tasks_theta[self.idx[t]], self.arms[t])\n",
        "\n",
        "    def get_index(self):\n",
        "        return self.idx\n",
        "\n",
        "M = 30         # number of tasks \n",
        "T = 100 * M    # horizon length\n",
        "d = 40         # feature dimensions\n",
        "A = 20         # number of actions\n",
        "k = 3          # representation dimensions\n",
        "eps = 0.2      # noise level\n",
        "LLLB = LifeLongLinBandit(T, d, A, eps, k, M)\n",
        "\n",
        "PASS = 5"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 4,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "cvl-3QZzg7VA",
        "outputId": "c25262b2-0ae2-4ae0-8fc1-1c7e7ac018ca"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "Total Regret 400.54: 100%|██████████| 3000/3000 [00:26<00:00, 111.94it/s]\n",
            "Total Regret 408.21: 100%|██████████| 3000/3000 [00:19<00:00, 157.13it/s]\n",
            "Total Regret 413.25: 100%|██████████| 3000/3000 [00:19<00:00, 157.58it/s]\n",
            "Total Regret 398.02: 100%|██████████| 3000/3000 [00:18<00:00, 159.78it/s]\n",
            "Total Regret 401.30: 100%|██████████| 3000/3000 [00:19<00:00, 156.61it/s]\n"
          ]
        }
      ],
      "source": [
        "# Linear UCB for individual tasks\n",
        "logUCB = torch.zeros(PASS, T)\n",
        "\n",
        "for N in range(PASS):\n",
        "    chosen = torch.zeros(T, d)\n",
        "    obv_reward = torch.zeros(T)\n",
        "\n",
        "    for t in LLLB.horizon():\n",
        "        bonus = (eps ** 2) * math.sqrt(d)\n",
        "\n",
        "        cur_arms = LLLB.get_arms()\n",
        "        A_hat = torch.eye(d)\n",
        "        b_hat = torch.zeros(d)\n",
        "        for s in range(t):\n",
        "            if LLLB.get_index()[s] == LLLB.get_index()[t]:\n",
        "                A_hat += torch.outer(chosen[s], chosen[s])\n",
        "                b_hat += chosen[s] * obv_reward[s]\n",
        "        invA_hat = torch.inverse(A_hat)\n",
        "        theta_hat = invA_hat @ b_hat \n",
        "\n",
        "        reward_hat = torch.inner(theta_hat, cur_arms) + bonus * torch.diag(cur_arms @ invA_hat @ cur_arms.T)\n",
        "        a = max(range(A), key = lambda a: reward_hat[a])\n",
        "        chosen[t] = cur_arms[a]\n",
        "        obv_reward[t] = LLLB.choose(a)\n",
        "\n",
        "    logUCB[N] = LLLB.regret"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 5,
      "metadata": {
        "id": "m_Eq_QPxg5W2",
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "outputId": "a444d2e5-5054-433b-cebd-3f7a42938c7f"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "Total Regret 264.48: 100%|██████████| 3000/3000 [10:53<00:00,  4.59it/s]\n",
            "Total Regret 270.85: 100%|██████████| 3000/3000 [11:01<00:00,  4.53it/s]\n",
            "Total Regret 268.58: 100%|██████████| 3000/3000 [11:24<00:00,  4.38it/s]\n",
            "Total Regret 241.64: 100%|██████████| 3000/3000 [11:16<00:00,  4.43it/s]\n",
            "Total Regret 273.43: 100%|██████████| 3000/3000 [11:15<00:00,  4.44it/s]\n"
          ]
        }
      ],
      "source": [
        "# FGTS.LP\n",
        "logFGTS = torch.zeros(PASS, T)\n",
        "\n",
        "inv_beta = 0.01\n",
        "lam = math.sqrt((d + M) * k / (d * T))\n",
        "\n",
        "Kt = 100\n",
        "Ki = 10\n",
        "\n",
        "for N in range(PASS):\n",
        "    B = torch.nn.init.orthogonal_(torch.empty(k, d))\n",
        "    W = torch.randn(M, k) / math.sqrt(k)\n",
        "\n",
        "    chosen = torch.zeros(T, d)\n",
        "    obv_arms = torch.zeros(T, A, d)\n",
        "    obv_reward = torch.zeros(T)\n",
        "    opt_arms = torch.zeros(T, d)\n",
        "\n",
        "    for t in LLLB.horizon():\n",
        "        idx = 0\n",
        "\n",
        "        obv_arms[t] = LLLB.get_arms()\n",
        "        for step in range(Kt):\n",
        "            if t == 0: continue\n",
        "            lr = 1 / (d * k * (step + 1))\n",
        "            B.requires_grad = True\n",
        "            W.requires_grad = True \n",
        "            Theta_hat = W[LLLB.get_index()] @ B\n",
        "\n",
        "            if step < Ki or step % Ki == 0:\n",
        "                opt_arms[:t] = obv_arms[torch.arange(t), torch.argmax(torch.sum(Theta_hat[:t].unsqueeze(1).repeat(1, A, 1) * obv_arms[:t], dim=-1), dim=1)]\n",
        "\n",
        "            L = torch.pow(torch.sum(Theta_hat[:t] * chosen[:t], dim=-1) - obv_reward[:t], 2)\n",
        "            F = torch.sum(Theta_hat[:t] * opt_arms[:t], dim=-1)\n",
        "            loss = torch.sum(L) - lam * torch.sum(F)\n",
        "            loss.backward()\n",
        "\n",
        "            with torch.no_grad():\n",
        "                B = B - B.grad * lr - B * lr * inv_beta * (d / k) + torch.randn((k, d)) * math.sqrt(2 * lr * inv_beta)\n",
        "                W = W - W.grad * lr - W * lr * inv_beta * k + torch.randn((M, k)) * math.sqrt(2 * lr * inv_beta)\n",
        "\n",
        "        theta_hat = W[LLLB.get_index()[t]] @ B\n",
        "        a = torch.argmax(torch.inner(theta_hat, obv_arms[t]))\n",
        "        chosen[t] = obv_arms[t, a]\n",
        "        obv_reward[t] = LLLB.choose(a)\n",
        "\n",
        "    logFGTS[N] = LLLB.regret\n",
        "\n",
        "torch.save(logFGTS, \"lifelong-k=%d.pt\" % k)\n"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 6,
      "metadata": {
        "id": "V4qtPrCOSjFT",
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 279
        },
        "outputId": "c75cf691-5843-4a25-de66-452df8f023d9"
      },
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 432x288 with 1 Axes>"
            ],
            "image/png": "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\n"
          },
          "metadata": {
            "needs_background": "light"
          }
        }
      ],
      "source": [
        "logFGTS = torch.load(\"lifelong-k=%d.pt\" % k)\n",
        "\n",
        "def plot(log, label):\n",
        "    mean = torch.mean(log, dim=0)\n",
        "    std = torch.std(log, dim=0)\n",
        "    plt.plot(range(log.shape[1]), mean, label=label)\n",
        "    plt.fill_between(range(log.shape[1]), mean-std, mean+std, alpha=0.2)\n",
        "\n",
        "plot(torch.cumsum(logFGTS, dim=1), \"FGTS.LP\")\n",
        "plot(torch.cumsum(logUCB, dim=1), \"LinUCB\")\n",
        "plt.xlabel(\"Rounds\")\n",
        "plt.ylabel(\"Cumulative Regret\")\n",
        "plt.legend()\n",
        "\n",
        "plt.savefig(\"lifelong-k=%d.pdf\" % k, bbox_inches=\"tight\")\n"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 7,
      "metadata": {
        "id": "_TsFEO1iz5w7",
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 279
        },
        "outputId": "4164424a-160e-4031-afa0-9ccd1d86b208"
      },
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 432x288 with 1 Axes>"
            ],
            "image/png": "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\n"
          },
          "metadata": {
            "needs_background": "light"
          }
        }
      ],
      "source": [
        "plot(torch.sum(logFGTS.view(-1, M, T // M), dim=2), \"FGTS.LP\")\n",
        "plot(torch.sum(logUCB.view(-1, M, T // M), dim=2), \"LinUCB\")\n",
        "plt.xlabel(\"Tasks\")\n",
        "plt.ylabel(\"Regret of Task\")\n",
        "plt.xticks(torch.arange(0, M+1, M/4))\n",
        "plt.legend()\n",
        "\n",
        "plt.savefig(\"lifelong-each-k=%d.pdf\", bbox_inches=\"tight\")"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 8,
      "metadata": {
        "id": "FaRf4SJJTr8b",
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 17
        },
        "outputId": "cca178fc-4ed4-444d-fdfc-4078efd7156d"
      },
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<IPython.core.display.Javascript object>"
            ],
            "application/javascript": [
              "\n",
              "    async function download(id, filename, size) {\n",
              "      if (!google.colab.kernel.accessAllowed) {\n",
              "        return;\n",
              "      }\n",
              "      const div = document.createElement('div');\n",
              "      const label = document.createElement('label');\n",
              "      label.textContent = `Downloading \"${filename}\": `;\n",
              "      div.appendChild(label);\n",
              "      const progress = document.createElement('progress');\n",
              "      progress.max = size;\n",
              "      div.appendChild(progress);\n",
              "      document.body.appendChild(div);\n",
              "\n",
              "      const buffers = [];\n",
              "      let downloaded = 0;\n",
              "\n",
              "      const channel = await google.colab.kernel.comms.open(id);\n",
              "      // Send a message to notify the kernel that we're ready.\n",
              "      channel.send({})\n",
              "\n",
              "      for await (const message of channel.messages) {\n",
              "        // Send a message to notify the kernel that we're ready.\n",
              "        channel.send({})\n",
              "        if (message.buffers) {\n",
              "          for (const buffer of message.buffers) {\n",
              "            buffers.push(buffer);\n",
              "            downloaded += buffer.byteLength;\n",
              "            progress.value = downloaded;\n",
              "          }\n",
              "        }\n",
              "      }\n",
              "      const blob = new Blob(buffers, {type: 'application/binary'});\n",
              "      const a = document.createElement('a');\n",
              "      a.href = window.URL.createObjectURL(blob);\n",
              "      a.download = filename;\n",
              "      div.appendChild(a);\n",
              "      a.click();\n",
              "      div.remove();\n",
              "    }\n",
              "  "
            ]
          },
          "metadata": {}
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<IPython.core.display.Javascript object>"
            ],
            "application/javascript": [
              "download(\"download_67774824-15ca-491f-92cd-0ca95f0b95fa\", \"lifelong-k=3.pt\", 60715)"
            ]
          },
          "metadata": {}
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<IPython.core.display.Javascript object>"
            ],
            "application/javascript": [
              "\n",
              "    async function download(id, filename, size) {\n",
              "      if (!google.colab.kernel.accessAllowed) {\n",
              "        return;\n",
              "      }\n",
              "      const div = document.createElement('div');\n",
              "      const label = document.createElement('label');\n",
              "      label.textContent = `Downloading \"${filename}\": `;\n",
              "      div.appendChild(label);\n",
              "      const progress = document.createElement('progress');\n",
              "      progress.max = size;\n",
              "      div.appendChild(progress);\n",
              "      document.body.appendChild(div);\n",
              "\n",
              "      const buffers = [];\n",
              "      let downloaded = 0;\n",
              "\n",
              "      const channel = await google.colab.kernel.comms.open(id);\n",
              "      // Send a message to notify the kernel that we're ready.\n",
              "      channel.send({})\n",
              "\n",
              "      for await (const message of channel.messages) {\n",
              "        // Send a message to notify the kernel that we're ready.\n",
              "        channel.send({})\n",
              "        if (message.buffers) {\n",
              "          for (const buffer of message.buffers) {\n",
              "            buffers.push(buffer);\n",
              "            downloaded += buffer.byteLength;\n",
              "            progress.value = downloaded;\n",
              "          }\n",
              "        }\n",
              "      }\n",
              "      const blob = new Blob(buffers, {type: 'application/binary'});\n",
              "      const a = document.createElement('a');\n",
              "      a.href = window.URL.createObjectURL(blob);\n",
              "      a.download = filename;\n",
              "      div.appendChild(a);\n",
              "      a.click();\n",
              "      div.remove();\n",
              "    }\n",
              "  "
            ]
          },
          "metadata": {}
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<IPython.core.display.Javascript object>"
            ],
            "application/javascript": [
              "download(\"download_6bd8ccd4-9748-439e-83fb-26515584a908\", \"lifelong-k=3.pdf\", 129658)"
            ]
          },
          "metadata": {}
        }
      ],
      "source": [
        "from google.colab import files\n",
        "files.download(\"lifelong-k=%d.pt\" % k)\n",
        "files.download(\"lifelong-k=%d.pdf\" % k)"
      ]
    }
  ],
  "metadata": {
    "colab": {
      "collapsed_sections": [],
      "provenance": []
    },
    "kernelspec": {
      "display_name": "Python 3",
      "name": "python3"
    },
    "language_info": {
      "name": "python"
    }
  },
  "nbformat": 4,
  "nbformat_minor": 0
}
