{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "GiOSzG6ch663",
    "outputId": "c6ab9c0e-181f-4e5d-8aba-73aee33014f7"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "python 3.7.16\n",
      "matplotlib 3.5.3\n"
     ]
    }
   ],
   "source": [
    "\n",
    "import collections\n",
    "import copy\n",
    "import itertools\n",
    "import matplotlib as mpl\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "from scipy.special import loggamma\n",
    "from scipy.stats import beta\n",
    "import time\n",
    "\n",
    "\n",
    "# mpl.style.use(\"classic\")\n",
    "mpl.style.use('seaborn-darkgrid')\n",
    "mpl.rcParams[\"figure.figsize\"] = [5, 3]\n",
    "\n",
    "mpl.rcParams[\"axes.linewidth\"] = 0.75\n",
    "# mpl.rcParams[\"figure.facecolor\"] = \"w\"\n",
    "mpl.rcParams[\"grid.linewidth\"] = 0.75\n",
    "mpl.rcParams[\"lines.linewidth\"] = 0.75\n",
    "mpl.rcParams[\"patch.linewidth\"] = 0.75\n",
    "mpl.rcParams[\"xtick.major.size\"] = 3\n",
    "mpl.rcParams[\"ytick.major.size\"] = 3\n",
    "\n",
    "mpl.rcParams[\"pdf.fonttype\"] = 42\n",
    "mpl.rcParams[\"ps.fonttype\"] = 42\n",
    "mpl.rcParams[\"font.size\"] = 12\n",
    "mpl.rcParams[\"axes.titlesize\"] = \"medium\"\n",
    "mpl.rcParams[\"legend.fontsize\"] = \"medium\"\n",
    "mpl.rcParams['text.usetex'] = True\n",
    "# mpl.rcParams['text.latex.unicode'] = True\n",
    "plt.rc('text', usetex=True) #Use latex\n",
    "\n",
    "\n",
    "import platform\n",
    "print(\"python %s\" % platform.python_version())\n",
    "print(\"matplotlib %s\" % mpl.__version__)\n",
    "\n",
    "import tensorflow.compat.v2 as tf\n",
    "# import tensorflow_probability as tfp\n",
    "tf.enable_v2_behavior()\n",
    "from tensorflow import keras\n",
    "\n",
    "def linestyle2dashes(style):\n",
    "  if style == \"--\":\n",
    "    return (3, 3)\n",
    "  elif style == \":\":\n",
    "    return (0.5, 2.5)\n",
    "  else:\n",
    "    return (None, None)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {
    "cellView": "form",
    "id": "aQKjSr2UzUYq"
   },
   "outputs": [],
   "source": [
    "#@title Bandit simulator and environments\n",
    "class GaussBandit(object):\n",
    "  \"\"\"Gaussian bandit.\"\"\"\n",
    "\n",
    "  def __init__(self, mu, sigma=0.5):\n",
    "    self.mu = np.copy(mu)\n",
    "    self.K = self.mu.size\n",
    "    self.sigma = sigma\n",
    "\n",
    "    self.best_arm = np.argmax(self.mu)\n",
    "\n",
    "    self.randomize()\n",
    "\n",
    "  def randomize(self):\n",
    "    # generate random rewards\n",
    "    self.rt = self.mu + self.sigma * np.random.randn(self.K)\n",
    "\n",
    "  def reward(self, arm):\n",
    "    # instantaneous reward of the arm\n",
    "    return self.rt[arm]\n",
    "\n",
    "  def regret(self, arm):\n",
    "    # instantaneous regret of the arm\n",
    "    return self.rt[self.best_arm] - self.rt[arm]\n",
    "\n",
    "  def pregret(self, arm):\n",
    "    # expected regret of the arm\n",
    "    return self.mu[self.best_arm] - self.mu[arm]\n",
    "\n",
    "  def print(self):\n",
    "    return \"Gaussian bandit with arms (%s)\" % \\\n",
    "      \", \".join(\"%.3f\" % s for s in self.mu)\n",
    "\n",
    "\n",
    "class LinBandit(object):\n",
    "  \"\"\"Linear bandit.\"\"\"\n",
    "\n",
    "  def __init__(self, X, theta, noise=\"normal\", sigma=0.5):\n",
    "    self.X = np.copy(X)\n",
    "    self.K = self.X.shape[0]\n",
    "    self.d = self.X.shape[1]\n",
    "    self.theta = np.copy(theta)\n",
    "    self.noise = noise\n",
    "    if self.noise == \"normal\":\n",
    "      self.sigma = sigma\n",
    "\n",
    "    self.mu = self.X.dot(self.theta)\n",
    "    self.best_arm = np.argmax(self.mu)\n",
    "\n",
    "    self.randomize()\n",
    "\n",
    "  def randomize(self):\n",
    "    # generate random rewards\n",
    "    if self.noise == \"normal\":\n",
    "      self.rt = self.mu + self.sigma * np.random.randn(self.K)\n",
    "    elif self.noise == \"bernoulli\":\n",
    "      self.rt = (np.random.rand(self.K) < self.mu).astype(float)\n",
    "    elif self.noise == \"beta\":\n",
    "      self.rt = np.random.beta(4 * self.mu, 4 * (1 - self.mu))\n",
    "\n",
    "  def reward(self, arm):\n",
    "    # instantaneous reward of the arm\n",
    "    return self.rt[arm]\n",
    "\n",
    "  def regret(self, arm):\n",
    "    # instantaneous regret of the arm\n",
    "    return self.rt[self.best_arm] - self.rt[arm]\n",
    "\n",
    "  def pregret(self, arm):\n",
    "    # expected regret of the arm\n",
    "    return self.mu[self.best_arm] - self.mu[arm]\n",
    "\n",
    "  def print(self):\n",
    "    if self.noise == \"normal\":\n",
    "      return \"Linear bandit: %d dimensions, %d arms\" % \\\n",
    "        (self.d, self.K)\n",
    "    elif self.noise == \"bernoulli\":\n",
    "      return \"Bernoulli linear bandit: %d dimensions, %d arms\" % \\\n",
    "        (self.d, self.K)\n",
    "    elif self.noise == \"beta\":\n",
    "      return \"Beta linear bandit: %d dimensions, %d arms\" % \\\n",
    "        (self.d, self.K)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {
    "cellView": "form",
    "id": "B-9Qk7f1zZDU"
   },
   "outputs": [],
   "source": [
    "#@title Baseline algorithms that handle each task independently\n",
    "\n",
    "class GaussTS(object):\n",
    "  def __init__(self, K, params):\n",
    "    self.K = K\n",
    "    self.sigma = 0.5\n",
    "\n",
    "    self.mu0 = np.zeros(self.K)\n",
    "    self.sigma0 = 0.5 * np.ones(self.K)\n",
    "\n",
    "    for attr, val in params.items():\n",
    "      setattr(self, attr, val)\n",
    "\n",
    "    self.pulls = np.zeros(self.K)  # number of pulls\n",
    "    self.reward = np.zeros(self.K)  # cumulative reward\n",
    "\n",
    "  def update(self, t, arm, r):\n",
    "    self.pulls[arm] += 1\n",
    "    self.reward[arm] += r\n",
    "\n",
    "  def get_arm(self, t):\n",
    "    if t < self.K:\n",
    "      # each arm is initially pulled once\n",
    "      self.mu = np.zeros(self.K)\n",
    "      self.mu[t] = 1\n",
    "    else:\n",
    "      # posterior distribution\n",
    "      sigma2 = np.square(self.sigma)\n",
    "      sigma02 = np.square(self.sigma0)\n",
    "      post_var = 1.0 / (1.0 / sigma02 + self.pulls / sigma2)\n",
    "      post_mean = post_var * (self.mu0 / sigma02 + self.reward / sigma2)\n",
    "\n",
    "      # posterior sampling\n",
    "      self.mu = post_mean + np.sqrt(post_var) * np.random.randn(self.K)\n",
    "\n",
    "    arm = np.argmax(self.mu)\n",
    "    return arm\n",
    "\n",
    "  @staticmethod\n",
    "  def print():\n",
    "    return \"Gaussian TS\"\n",
    "\n",
    "\n",
    "class LinBanditAlg(object):\n",
    "  def __init__(self, K, d, params):\n",
    "    self.K = K\n",
    "    self.d = d\n",
    "    self.theta0 = np.zeros(self.d)\n",
    "    self.sigma0 = 1.0\n",
    "    self.sigma = 0.5\n",
    "    self.crs = 1.0 # confidence region scaling\n",
    "\n",
    "    for attr, val in params.items():\n",
    "      setattr(self, attr, val)\n",
    "\n",
    "    if not hasattr(self, \"Sigma0\"):\n",
    "      self.Sigma0 = np.square(self.sigma0) * np.eye(self.d)\n",
    "\n",
    "    # sufficient statistics\n",
    "    self.Gram = np.linalg.inv(self.Sigma0)\n",
    "    self.B = self.Gram.dot(self.theta0)\n",
    "\n",
    "  def update(self, t, x, arm, r):\n",
    "    x_a = x[arm]\n",
    "    self.Gram += np.outer(x_a, x_a) / np.square(self.sigma)\n",
    "    self.B += x_a * r / np.square(self.sigma)\n",
    "\n",
    "\n",
    "class LinTS(LinBanditAlg):\n",
    "  def get_arm(self, t, x):\n",
    "    Gram_inv = np.linalg.inv(self.Gram)\n",
    "    thetabar = Gram_inv.dot(self.B)\n",
    "\n",
    "    # posterior sampling\n",
    "    thetatilde = np.random.multivariate_normal(thetabar,\n",
    "      np.square(self.crs) * Gram_inv, tol=1e-6)\n",
    "    self.mu = x.dot(thetatilde)\n",
    "\n",
    "    arm = np.argmax(self.mu)\n",
    "    return arm\n",
    "\n",
    "  @staticmethod\n",
    "  def print():\n",
    "    return \"LinTS\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {
    "id": "tF2d1ViMEAzW"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "CPU times: user 31 µs, sys: 0 ns, total: 31 µs\n",
      "Wall time: 33.9 µs\n"
     ]
    }
   ],
   "source": [
    "%%time\n",
    "class IndLinTS(object):\n",
    "  def __init__(self, num_tasks, K, d, params):\n",
    "      self.num_tasks = num_tasks\n",
    "      self.K = K\n",
    "      self.d = d\n",
    "\n",
    "      # set up independent bandit algorithms\n",
    "      self.algs = []\n",
    "      for _ in range(num_tasks):\n",
    "        self.algs.append(LinTS(K, d, copy.deepcopy(params)))\n",
    "\n",
    "  def update(self, t, tasks, xs, arms, rs):\n",
    "    for s, x, arm, r in zip(tasks, xs, arms, rs):\n",
    "      self.algs[s].update(t, x, arm, r)\n",
    "\n",
    "  def get_arm(self, t, tasks, xs):\n",
    "    return [self.algs[s].get_arm(t, x) for s, x in zip(tasks, xs)]\n",
    "\n",
    "\n",
    "class HierLinTS(object):\n",
    "  def __init__(self, num_tasks, K, d, params):\n",
    "      self.num_tasks = num_tasks\n",
    "      self.K = K\n",
    "      self.d = d\n",
    "      self.mu_q = np.zeros(self.d)\n",
    "      self.Sigma_q = np.eye(self.d)\n",
    "      self.sigma0 = 1.0\n",
    "      self.sigma = 0.5\n",
    "      self.crs = 1.0  # confidence region scaling\n",
    "\n",
    "      for attr, val in params.items():\n",
    "        setattr(self, attr, val)\n",
    "\n",
    "      if not hasattr(self, \"Sigma0\"):\n",
    "        self.Sigma0 = np.square(self.sigma0) * np.eye(self.d)\n",
    "\n",
    "      # hyper-posterior\n",
    "      self.mu_tildes = np.tile(self.mu_q, (self.num_tasks, 1))\n",
    "      self.Sigma_tildes = np.tile(self.Sigma_q, (self.num_tasks, 1, 1))\n",
    "  \n",
    "      # sufficient statistics\n",
    "      self.Grams= (np.zeros((self.num_tasks, self.d, self.d)) +\n",
    "                   1e-6 * np.eye(self.d)[np.newaxis, ...])\n",
    "      self.Bs = np.zeros((self.num_tasks, self.d))\n",
    "      self.counts = np.zeros(self.num_tasks)\n",
    "\n",
    "\n",
    "  def update(self, t, tasks, xs, arms, rs):\n",
    "    for s, x, arm, r in zip(tasks, xs, arms, rs):\n",
    "      x_a = x[arm]\n",
    "      self.Grams[s] += np.outer(x[arm], x[arm]) / np.square(self.sigma)\n",
    "      self.Bs[s] += x[arm] * r / np.square(self.sigma)\n",
    "      self.counts[s] += 1\n",
    "\n",
    "    # hyper-posterior update\n",
    "    mu_h = np.linalg.solve(self.Sigma_q, self.mu_q)\n",
    "    Lambda_h = np.linalg.inv(self.Sigma_q)\n",
    "\n",
    "    # compute hyper-posterior parameters\n",
    "    for s in range(self.num_tasks):\n",
    "      if self.counts[s] >= self.d:\n",
    "        Gram = self.Grams[s]\n",
    "        B = self.Bs[s]\n",
    "        M = np.linalg.pinv(np.linalg.inv(self.Sigma0) + Gram)\n",
    "        Lambda_h += Gram - Gram.dot(M).dot(Gram)\n",
    "        mu_h += B - Gram.dot(M).dot(B)\n",
    "\n",
    "    for s in range(self.num_tasks):\n",
    "      mu_h_s = np.copy(mu_h)\n",
    "      Lambda_h_s = np.copy(Lambda_h)\n",
    "      if self.counts[s] >= self.d:\n",
    "        Gram = self.Grams[s]\n",
    "        B = self.Bs[s]\n",
    "        M = np.linalg.pinv(np.linalg.inv(self.Sigma0) + Gram)\n",
    "        # subtract observations from task to keep independence\n",
    "        mu_h_s -= (B - Gram.dot(M).dot(B))\n",
    "        Lambda_h_s -= (Gram - Gram.dot(M).dot(Gram))\n",
    "\n",
    "      self.mu_tildes[s] = np.linalg.solve(Lambda_h_s, mu_h_s)\n",
    "      self.Sigma_tildes[s] = np.linalg.pinv(Lambda_h_s)\n",
    "\n",
    "  def get_arm(self, t, tasks, xs):\n",
    "    arms = []\n",
    "    for s, x in zip(tasks, xs):\n",
    "      Gram = self.Grams[s]\n",
    "      B = self.Bs[s]\n",
    "      Sigma_tilde = self.Sigma_tildes[s]\n",
    "      mu_tilde = self.mu_tildes[s]\n",
    "\n",
    "      thetatilde_s = np.linalg.solve(Sigma_tilde, mu_tilde)\n",
    "      Lambda_hat_s = np.linalg.pinv(self.Sigma0 + Sigma_tilde) + Gram\n",
    "      thetabar_hat_s = np.linalg.solve(Lambda_hat_s, thetatilde_s + B)\n",
    "      Sigma_hat_s = np.linalg.pinv(Lambda_hat_s)\n",
    "\n",
    "      # posterior sampling\n",
    "      thetasample_s = np.random.multivariate_normal(\n",
    "          thetabar_hat_s, np.square(self.crs) * Sigma_hat_s)\n",
    "      mu = x.dot(thetasample_s)\n",
    "\n",
    "      arms.append(np.argmax(mu))\n",
    "    return arms\n",
    "\n",
    "class HierBayesUCB(object):\n",
    "  def __init__(self, num_tasks, K, d, params, delta):\n",
    "      self.num_tasks = num_tasks\n",
    "      self.K = K\n",
    "      self.d = d\n",
    "      self.mu_q = np.zeros(self.d)\n",
    "      self.Sigma_q = np.eye(self.d)\n",
    "      self.sigma0 = 1.0\n",
    "      self.sigma = 0.5\n",
    "      self.delta = delta\n",
    "      self.crs = 1.0  # confidence region scaling\n",
    "\n",
    "      for attr, val in params.items():\n",
    "        setattr(self, attr, val)\n",
    "\n",
    "      if not hasattr(self, \"Sigma0\"):\n",
    "        self.Sigma0 = np.square(self.sigma0) * np.eye(self.d)\n",
    "\n",
    "      # hyper-posterior\n",
    "      self.bar_mu = np.copy(self.mu_q)\n",
    "      self.bar_Sigma = np.copy(self.Sigma_q)\n",
    "  \n",
    "      # sufficient statistics\n",
    "      self.Grams= (np.zeros((self.num_tasks, self.d, self.d)) +\n",
    "                   1e-6 * np.eye(self.d)[np.newaxis, ...])\n",
    "      self.Bs = np.zeros((self.num_tasks, self.d))\n",
    "      self.counts = np.zeros(self.num_tasks)\n",
    "\n",
    "\n",
    "  def update(self, t, tasks, xs, arms, rs):\n",
    "    for s, x, arm, r in zip(tasks, xs, arms, rs):\n",
    "      x_a = x[arm]\n",
    "      self.Grams[s] += np.outer(x[arm], x[arm]) / np.square(self.sigma)\n",
    "      self.Bs[s] += x[arm] * r / np.square(self.sigma)\n",
    "      self.counts[s] += 1\n",
    "\n",
    "    # hyper-posterior update\n",
    "    mu_h = np.linalg.solve(self.Sigma_q, self.mu_q)\n",
    "    Lambda_h = np.linalg.inv(self.Sigma_q)\n",
    "\n",
    "    # compute hyper-posterior parameters\n",
    "    for s in range(self.num_tasks):\n",
    "      if self.counts[s] >= self.d:\n",
    "        Gram = self.Grams[s]\n",
    "        B = self.Bs[s]\n",
    "        M = np.linalg.pinv(np.linalg.inv(self.Sigma0) + Gram)\n",
    "        Lambda_h += Gram - Gram.dot(M).dot(Gram)\n",
    "        mu_h += B - Gram.dot(M).dot(B)\n",
    "\n",
    "    self.bar_Sigma = np.linalg.pinv(Lambda_h)\n",
    "    # print(\"mu_h shape\", mu_h.shape)\n",
    "    self.bar_mu = self.bar_Sigma.dot(mu_h.reshape(-1,1))\n",
    "\n",
    "  def get_arm(self, t, tasks, xs):\n",
    "    arms = []\n",
    "    for s, x in zip(tasks, xs):\n",
    "      Gram = self.Grams[s]\n",
    "      B = self.Bs[s]\n",
    "      M = np.linalg.pinv(np.linalg.inv(self.Sigma0) + Gram)\n",
    "      A = self.bar_mu\n",
    "      # print(\" M shape\", M.shape) #(4,4)\n",
    "      # print(\"self bar_mu shape\", A.shape)# (4,)\n",
    "      # print(\"B shape\", B.shape) #(4,)\n",
    "      hat_mu_s = M.dot(np.linalg.pinv(self.Sigma0).dot(self.bar_mu.reshape(-1,1)) +B.reshape(-1,1))\n",
    "      hat_Sigma_s = M + M.dot(np.linalg.pinv(self.Sigma0)).dot(self.bar_Sigma).dot(np.linalg.pinv(self.Sigma0)).dot(M)\n",
    "      # print(s,x,'yes')\n",
    "      # print(\"x shape\", x.shape) # (20, 4)\n",
    "      # print(\"hat_mu_s shape\", hat_mu_s.shape) # (4,4)\n",
    "      # print(\"hat_Sigma_s shape\", hat_Sigma_s.shape) # (4,4)\n",
    "      diag_x_Sigma_x = np.diagonal(x.dot(hat_Sigma_s).dot(x.T))\n",
    "      UCB_s = x.dot(hat_mu_s) + np.sqrt(2 * np.log(1./self.delta)) * np.sqrt(diag_x_Sigma_x.reshape(-1,1))\n",
    "      # print('yes_second')\n",
    "      arms.append(np.argmax(UCB_s))\n",
    "    return arms"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 509
    },
    "id": "cuyuQsXLZ8mb",
    "outputId": "66d35493-c129-467d-a0c6-59dd771db5ab"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "OracleTS: 51.6 +/- 4.6\n",
      "TS: 378.7 +/- 6.8\n",
      "HierTS: 174.4 +/- 6.8\n",
      "HierBayesUCB: 119.4 +/- 5.2\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x280 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "OracleTS: 32.5 +/- 3.8\n",
      "TS: 354.9 +/- 6.8\n",
      "HierTS: 274.3 +/- 9.1\n",
      "HierBayesUCB: 99.6 +/- 4.1\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x280 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# linear bandit\n",
    "alg_specs = [\n",
    "    (\"OracleTS\", \"cyan\", \"-\"),\n",
    "    (\"TS\", \"blue\", \"-\"),\n",
    "    (\"HierTS\", \"green\", \"-\"),\n",
    "    (\"HierBayesUCB\", \"red\", \"-\")]\n",
    "# alg_specs = [\n",
    "#     (\"OracleTS\", \"cyan\", \"-\"),\n",
    "#     (\"HierBayesUCB\", \"red\", \"-\")]\n",
    "num_runs = 100\n",
    "num_tasks = 10\n",
    "num_tasks_per_round = 5\n",
    "n = 200 * num_tasks // num_tasks_per_round\n",
    "delta = 1./(num_tasks * n)\n",
    "\n",
    "step = np.arange(1, n + 1)\n",
    "sube = (step.size // 10) * np.arange(1, 11) - 1\n",
    "\n",
    "for d in [4]:\n",
    "  K = 5 * d\n",
    "  for sigma_q_scale in [0.5, 1]:\n",
    "    # meta-prior parameters\n",
    "    mu_q = np.zeros(d)\n",
    "    # prior parameters\n",
    "    sigma_0 = 0.1\n",
    "    # reward noise\n",
    "    sigma = 1\n",
    "\n",
    "    Sigma_q = np.square(sigma_q_scale) * np.eye(d)\n",
    "    Sigma_0 = np.square(sigma_0) * np.eye(d)\n",
    "\n",
    "\n",
    "    plt.figure(figsize=(4, 2.8))\n",
    "\n",
    "    for alg_spec in alg_specs:\n",
    "      regret = np.zeros((n, num_runs))\n",
    "\n",
    "      for run in range(num_runs):\n",
    "        # true hyper-prior\n",
    "        mu_star = mu_q + sigma_q_scale * np.random.randn(d)\n",
    "        envs = []\n",
    "        for _ in range(num_tasks):\n",
    "          # sample problem instance from N(\\mu_*, \\sigma_0^2 I_d)\n",
    "          theta = mu_star + sigma_0 * np.random.randn(d)\n",
    "          # sample arms from a unit ball\n",
    "          X = np.random.randn(K, d)\n",
    "          X /= np.linalg.norm(X, axis=-1)[:, np.newaxis]\n",
    "          envs.append(LinBandit(X, theta, sigma=sigma))\n",
    "\n",
    "        # initialize algorithms\n",
    "        if alg_spec[0] == 'OracleTS':\n",
    "          # OracleTS\n",
    "          alg_params = {\n",
    "            \"theta0\": np.copy(mu_star),\n",
    "            \"Sigma0\": np.copy(Sigma_0),\n",
    "            \"sigma\": sigma}\n",
    "          alg = IndLinTS(num_tasks, K, d, alg_params)\n",
    "        elif alg_spec[0] == 'TS':\n",
    "          # TS\n",
    "          alg_params = {\n",
    "            \"theta0\": np.copy(mu_q),\n",
    "            \"Sigma0\": Sigma_q + Sigma_0,\n",
    "            \"sigma\": sigma}\n",
    "          alg = IndLinTS(num_tasks, K, d, alg_params)\n",
    "        \n",
    "        elif alg_spec[0] == 'HierTS':\n",
    "          # HierTS\n",
    "          alg_params = {\n",
    "              \"mu_q\": np.copy(mu_q),\n",
    "              \"Sigma_q\": np.copy(Sigma_q),\n",
    "              \"Sigma0\": np.copy(Sigma_0),\n",
    "              \"sigma\": sigma,\n",
    "          }\n",
    "          alg = HierLinTS(num_tasks, K, d, alg_params)\n",
    "\n",
    "        else:\n",
    "          # HierTS\n",
    "          alg_params = {\n",
    "              \"mu_q\": np.copy(mu_q),\n",
    "              \"Sigma_q\": np.copy(Sigma_q),\n",
    "              \"Sigma0\": np.copy(Sigma_0),\n",
    "              \"sigma\": sigma,\n",
    "          }\n",
    "          alg = HierBayesUCB(num_tasks, K, d, alg_params, delta)\n",
    "\n",
    "        for t in range(n):\n",
    "          tasks = np.random.randint(0, num_tasks, size=num_tasks_per_round)\n",
    "  \n",
    "          for s in tasks:\n",
    "            envs[s].randomize()\n",
    "\n",
    "          Xs = [envs[s].X for s in tasks]\n",
    "          arms = alg.get_arm(t, tasks, Xs)\n",
    "          rs = [envs[s].reward(arm) for s, arm in zip(tasks, arms)]\n",
    "          alg.update(t, tasks, Xs, arms, rs)\n",
    "          regret[t, run] = np.sum(\n",
    "              [envs[s].regret(arm) for s, arm in zip(tasks, arms)])\n",
    "\n",
    "      cum_regret = regret.cumsum(axis=0)\n",
    "      plt.plot(step, cum_regret.mean(axis=1),\n",
    "        dashes=linestyle2dashes(alg_spec[2]), color=alg_spec[1],\n",
    "        label=alg_spec[0])\n",
    "      plt.errorbar(step[sube], cum_regret[sube, :].mean(axis=1),\n",
    "        cum_regret[sube, :].std(axis=1) / np.sqrt(cum_regret.shape[1]),\n",
    "        fmt=\"none\", ecolor=alg_spec[1], capsize=1)\n",
    "\n",
    "      print(\"%s: %.1f +/- %.1f\" % (alg_spec[0],\n",
    "        cum_regret[-1, :].mean(),\n",
    "        cum_regret[-1, :].std() / np.sqrt(cum_regret.shape[1])))\n",
    "\n",
    "    plt.title(r\"Linear Bandit ($d$ = %d, $\\sigma_q$ = %.1f)\" % (d, sigma_q_scale))\n",
    "    plt.xlabel(\"Round $t$\")\n",
    "    plt.xticks(np.arange(n + 1, step=100))\n",
    "    plt.ylabel(\"Regret\")\n",
    "    plt.ylim(bottom=0)\n",
    "    plt.legend(loc=\"upper left\", frameon=False, prop={'size': 10})\n",
    "    # plt.gcf().set_facecolor('white')\n",
    "    plt.tight_layout()\n",
    "    plt.tick_params(axis='both', which='both', length=0)\n",
    "    plt.savefig('regrets_of_different_Bayes_bandit_algorithms_sigma_q_%.1f.pdf'%(sigma_q_scale), transparent = False)\n",
    "    plt.show()"
   ]
  }
 ],
 "metadata": {
  "colab": {
   "collapsed_sections": [],
   "name": "HierTS_Public.ipynb",
   "provenance": []
  },
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.7.16"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 1
}
