{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "cellView": "form",
    "executionInfo": {
     "elapsed": 5,
     "status": "ok",
     "timestamp": 1622693515966,
     "user": {
      "displayName": "Branislav Kveton",
      "photoUrl": "https://lh3.googleusercontent.com/a-/AOh14GhjPg1PJKD4ixGqLaZ4X3dpkI6w6dO_eTj8z63Y=s64",
      "userId": "09350298559467540088"
     },
     "user_tz": 0
    },
    "id": "dUrLMhAcZYDY",
    "jupyter": {
     "source_hidden": true
    },
    "outputId": "31bb0c27-489c-4d61-85e8-6002f5252ed5",
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "python 3.9.6\n",
      "matplotlib 3.4.3\n"
     ]
    }
   ],
   "source": [
    "#@title Imports and defaults\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",
    "mpl.style.use(\"classic\")\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\"] = 9\n",
    "mpl.rcParams[\"axes.titlesize\"] = \"medium\"\n",
    "mpl.rcParams[\"legend.fontsize\"] = \"medium\"\n",
    "\n",
    "import platform\n",
    "print(\"python %s\" % platform.python_version())\n",
    "print(\"matplotlib %s\" % mpl.__version__)\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": 2,
   "metadata": {
    "cellView": "form",
    "id": "f7uZWkUjRmUs",
    "jupyter": {
     "source_hidden": true
    },
    "tags": []
   },
   "outputs": [],
   "source": [
    "#@title Bandit simulator and environments\n",
    "class BerBandit(object):\n",
    "  \"\"\"Bernoulli bandit.\"\"\"\n",
    "\n",
    "  def __init__(self, mu):\n",
    "    self.mu = np.copy(mu)\n",
    "    self.K = self.mu.size\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 = (np.random.rand() < self.mu).astype(float)\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 \"Bernoulli bandit with arms (%s)\" % \\\n",
    "      \", \".join(\"%.3f\" % s for s in self.mu)\n",
    "\n",
    "\n",
    "class BetaBandit(object):\n",
    "  \"\"\"Beta bandit.\"\"\"\n",
    "\n",
    "  def __init__(self, mu, a_plus_b=4):\n",
    "    self.mu = np.copy(mu)\n",
    "    self.K = self.mu.size\n",
    "    self.a_plus_b = a_plus_b\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 = \\\n",
    "      np.random.beta(self.a_plus_b * self.mu, self.a_plus_b * (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",
    "    return \"Beta bandit with arms (%s)\" % \\\n",
    "      \", \".join(\"%.3f\" % s for s in self.mu)\n",
    "\n",
    "\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",
    "\n",
    "\n",
    "class LogBandit(object):\n",
    "  \"\"\"Logistic bandit.\"\"\"\n",
    "\n",
    "  def __init__(self, X, theta):\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",
    "\n",
    "    self.mu = 1 / (1 + np.exp(- 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",
    "    self.rt = (np.random.rand(self.K) < self.mu).astype(float)\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 \"Logistic bandit: %d dimensions, %d arms\" % (self.d, self.K)\n",
    "\n",
    "  @staticmethod\n",
    "  def ball_env(d=3, K=10, num_env=100):\n",
    "    \"\"\"Arm features and theta are generated randomly in a ball.\"\"\"\n",
    "\n",
    "    env = []\n",
    "    for env_id in range(num_env):\n",
    "      # standard d-dimensional basis (with a bias term)\n",
    "      basis = np.eye(d)\n",
    "      basis[:, -1] = 1\n",
    "\n",
    "      # arm features in a unit (d - 2)-sphere\n",
    "      X = np.random.randn(K, d - 1)\n",
    "      X /= np.sqrt(np.square(X).sum(axis=1))[:, np.newaxis]\n",
    "      X = np.hstack((X, np.ones((K, 1))))  # bias term\n",
    "      X[: basis.shape[0], :] = basis\n",
    "\n",
    "      # parameter vector in a (d - 2)-sphere with radius 1.5\n",
    "      theta = np.random.randn(d - 1)\n",
    "      theta *= 1.5 / np.sqrt(np.square(theta).sum())\n",
    "      theta = np.append(theta, [0])\n",
    "\n",
    "      # create environment\n",
    "      env.append(LogBandit(X, theta))\n",
    "      print(\"%3d: %.2f %.2f | \" % (env[-1].best_arm,\n",
    "        env[-1].mu.min(), env[-1].mu.max()), end=\"\")\n",
    "      if (env_id + 1) % 10 == 0:\n",
    "        print()\n",
    "\n",
    "    return env\n",
    "\n",
    "\n",
    "class CoBandit(object):\n",
    "  \"\"\"Contextual bandit with linear generalization.\"\"\"\n",
    "\n",
    "  def __init__(self, X, Theta, sigma=0.5):\n",
    "    self.X = np.copy(X)  # [number of contexs] x d feature matrix\n",
    "    self.Theta = np.copy(Theta)  # d x [number of arms] parameter matrix\n",
    "    self.K = self.Theta.shape[1]\n",
    "    self.d = self.X.shape[1]\n",
    "    self.num_contexts = self.X.shape[0]\n",
    "    self.sigma = sigma\n",
    "\n",
    "    self.mu = self.X.dot(self.Theta)\n",
    "    self.best_arm = np.argmax(self.mu, axis=1)\n",
    "\n",
    "    self.randomize()\n",
    "\n",
    "  def randomize(self):\n",
    "    # choose context\n",
    "    self.ct = np.random.randint(self.num_contexts)\n",
    "    self.mut = self.mu[self.ct, :]\n",
    "\n",
    "    # generate stochastic rewards\n",
    "    self.rt = self.mut + 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.ct]] - self.rt[arm]\n",
    "\n",
    "  def pregret(self, arm):\n",
    "    # expected regret of the arm\n",
    "    return self.mut[self.best_arm[self.ct]] - self.mut[arm]\n",
    "\n",
    "  def print(self):\n",
    "    return \"Contextual bandit: %d dimensions, %d arms\" % (self.d, self.K)\n",
    "\n",
    "\n",
    "def evaluate_one(Alg, params, env, n, period_size=1):\n",
    "  \"\"\"One run of a bandit algorithm.\"\"\"\n",
    "  alg = Alg(env, n, params)\n",
    "\n",
    "  regret = np.zeros(n // period_size)\n",
    "  for t in range(n):\n",
    "    # generate state\n",
    "    env.randomize()\n",
    "\n",
    "    # take action\n",
    "    arm = alg.get_arm(t)\n",
    "\n",
    "    # update model and regret\n",
    "    alg.update(t, arm, env.reward(arm))\n",
    "    regret_at_t = env.regret(arm)\n",
    "    regret[t // period_size] += regret_at_t\n",
    "\n",
    "  return regret, alg\n",
    "\n",
    "\n",
    "def evaluate(Alg, params, env, n=1000, period_size=1, printout=True):\n",
    "  \"\"\"Multiple runs of a bandit algorithm.\"\"\"\n",
    "  if printout:\n",
    "    print(\"Evaluating %s\" % Alg.print(), end=\"\")\n",
    "  start = time.time()\n",
    "\n",
    "  num_exps = len(env)\n",
    "  regret = np.zeros((n // period_size, num_exps))\n",
    "  alg = num_exps * [None]\n",
    "\n",
    "  dots = np.linspace(0, num_exps - 1, 100).astype(int)\n",
    "  for ex in range(num_exps):\n",
    "    output = evaluate_one(Alg, params, env[ex], n, period_size)\n",
    "    regret[:, ex] = output[0]\n",
    "    alg[ex] = output[1]\n",
    "\n",
    "    if ex in dots:\n",
    "      if printout:\n",
    "        print(\".\", end=\"\")\n",
    "  if printout:\n",
    "    print(\" %.1f seconds\" % (time.time() - start))\n",
    "\n",
    "  if printout:\n",
    "    total_regret = regret.sum(axis=0)\n",
    "    print(\"Regret: %.2f +/- %.2f (median: %.2f, max: %.2f, min: %.2f)\" %\n",
    "      (total_regret.mean(), total_regret.std() / np.sqrt(num_exps),\n",
    "      np.median(total_regret), total_regret.max(), total_regret.min()))\n",
    "\n",
    "  return regret, alg"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "cellView": "form",
    "id": "Lkl993UjR6E_",
    "jupyter": {
     "source_hidden": true
    },
    "tags": []
   },
   "outputs": [],
   "source": [
    "#@title Classical algorithms for multi-armed, linear, and GLM bandits\n",
    "class UCB1:\n",
    "  def __init__(self, env, n, params):\n",
    "    self.K = env.K\n",
    "    self.crs = 1.0  # confidence region scaling\n",
    "\n",
    "    for attr, val in params.items():\n",
    "      setattr(self, attr, val)\n",
    "\n",
    "    self.pulls = 1e-6 * np.ones(self.K)  # number of pulls\n",
    "    self.reward = 1e-6 * np.random.rand(self.K)  # cumulative reward\n",
    "    self.tiebreak = 1e-6 * np.random.rand(self.K)  # tie breaking\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",
    "    # UCBs\n",
    "    t += 1  # time starts at one\n",
    "    ciw = self.crs * np.sqrt(2 * np.log(t))\n",
    "    self.ucb = self.reward / self.pulls + \\\n",
    "      ciw * np.sqrt(1 / self.pulls) + self.tiebreak\n",
    "\n",
    "    arm = np.argmax(self.ucb)\n",
    "    return arm\n",
    "\n",
    "  @staticmethod\n",
    "  def print():\n",
    "    return \"UCB1\"\n",
    "\n",
    "\n",
    "class UCBV:\n",
    "  def __init__(self, env, n, params):\n",
    "    self.K = env.K\n",
    "    self.n = n\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",
    "    self.reward2 = np.zeros(self.K)  # cumulative squared reward\n",
    "    self.tiebreak = 1e-6 * np.random.rand(self.K)  # tie breaking\n",
    "\n",
    "  def update(self, t, arm, r):\n",
    "    self.pulls[arm] += 1\n",
    "    self.reward[arm] += r\n",
    "    self.reward2[arm] += r * r\n",
    "\n",
    "  def get_arm(self, t):\n",
    "    if t < self.K:\n",
    "      # pull each arm once in the first K rounds\n",
    "      self.ucb = np.zeros(self.K)\n",
    "      self.ucb[t] = 1\n",
    "    else:\n",
    "      # UCBs\n",
    "      t += 1  # time starts at one\n",
    "\n",
    "      # from \\sum_{t = 1}^n \\sum_{s = 1}^t (1 / n^2) <= 1\n",
    "      delta = 1.0 / np.power(self.n, 2)\n",
    "      # # from \\sum_{t = 1}^n \\sum_{s = 1}^t (1 / t^3) <= \\pi^2 / 6\n",
    "      # delta = 1.0 / np.power(t, 3)\n",
    "\n",
    "      muhat = self.reward / self.pulls\n",
    "      varhat = (self.reward2 - self.pulls * np.square(muhat)) / self.pulls\n",
    "      varhat = np.maximum(varhat, 0)\n",
    "      self.ucb = muhat + \\\n",
    "        np.sqrt(2 * varhat * np.log(3 / delta) / self.pulls) + \\\n",
    "        3 * np.log(3 / delta) / self.pulls + \\\n",
    "        self.tiebreak\n",
    "\n",
    "    arm = np.argmax(self.ucb)\n",
    "    return arm\n",
    "\n",
    "  @staticmethod\n",
    "  def print():\n",
    "    return \"UCB-V\"\n",
    "\n",
    "\n",
    "class KLUCB:\n",
    "  def __init__(self, env, n, params):\n",
    "    self.K = env.K\n",
    "\n",
    "    for attr, val in params.items():\n",
    "      setattr(self, attr, val)\n",
    "\n",
    "    self.pulls = 1e-6 * np.ones(self.K)  # number of pulls\n",
    "    self.reward = 1e-6 * np.random.rand(self.K)  # cumulative reward\n",
    "    self.tiebreak = 1e-6 * np.random.rand(self.K)  # tie breaking\n",
    "\n",
    "  def UCB(self, p, N, t):\n",
    "    C = (np.log(t) + 3 * np.log(np.log(t) + 1e-6)) / N\n",
    "\n",
    "    qmin = np.minimum(np.maximum(p, 1e-6), 1 - 1e-6)\n",
    "    qmax = (1 - 1e-6) * np.ones(p.size)\n",
    "    for i in range(16):\n",
    "      q = (qmax + qmin) / 2\n",
    "      ndx = (p * np.log(p / q) + (1 - p) * np.log((1 - p) / (1 - q))) < C\n",
    "      qmin[ndx] = q[ndx]\n",
    "      qmax[~ndx] = q[~ndx]\n",
    "\n",
    "    return q\n",
    "\n",
    "  def update(self, t, arm, r):\n",
    "    if (r > 0) and (r < 1):\n",
    "      r = (np.random.rand() < r).astype(float)\n",
    "    self.pulls[arm] += 1\n",
    "    self.reward[arm] += r\n",
    "\n",
    "  def get_arm(self, t):\n",
    "    # UCBs\n",
    "    t += 1  # time starts at one\n",
    "    self.ucb = \\\n",
    "      self.UCB(self.reward / self.pulls, self.pulls, t) + self.tiebreak\n",
    "\n",
    "    arm = np.argmax(self.ucb)\n",
    "    return arm\n",
    "\n",
    "  @staticmethod\n",
    "  def print():\n",
    "    return \"KL-UCB\"\n",
    "\n",
    "\n",
    "class TS:\n",
    "  def __init__(self, env, n, params):\n",
    "    self.K = env.K\n",
    "    self.crs = 1.0  # confidence region scaling\n",
    "\n",
    "    self.alpha = np.ones(self.K)  # positive observations\n",
    "    self.beta = np.ones(self.K)  # negative observations\n",
    "\n",
    "    for attr, val in params.items():\n",
    "      if isinstance(val, np.ndarray):\n",
    "        setattr(self, attr, np.copy(val))\n",
    "      else:\n",
    "        setattr(self, attr, val)\n",
    "\n",
    "  def update(self, t, arm, r):\n",
    "    if (r > 0) and (r < 1):\n",
    "      r = (np.random.rand() < r).astype(float)\n",
    "    self.alpha[arm] += r\n",
    "    self.beta[arm] += 1 - 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 sampling\n",
    "      crs2 = np.square(self.crs)\n",
    "      self.mu = np.random.beta(self.alpha / crs2, self.beta / crs2)\n",
    "\n",
    "    arm = np.argmax(self.mu)\n",
    "    return arm\n",
    "\n",
    "  @staticmethod\n",
    "  def print():\n",
    "    return \"TS\"\n",
    "\n",
    "\n",
    "class GaussTS:\n",
    "  def __init__(self, env, n, params):\n",
    "    self.K = env.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 EpsilonGreedy:\n",
    "  def __init__(self, env, n, params):\n",
    "    self.env = env\n",
    "    self.K = env.K\n",
    "    self.epsilon = self.K / np.sqrt(n)\n",
    "    self.crs = 1.0  # confidence region scaling\n",
    "\n",
    "    for attr, val in params.items():\n",
    "      setattr(self, attr, val)\n",
    "\n",
    "    self.pulls = 1e-6 * np.ones(self.K)  # number of pulls\n",
    "    self.reward = 1e-6 * np.ones(self.K)  # cumulative reward\n",
    "    # self.tiebreak = 1e-6 * np.random.rand(self.K)  # tie breaking\n",
    "\n",
    "    self.grad = np.zeros(n)\n",
    "    self.metrics = np.zeros((n, 3))\n",
    "\n",
    "    # initialize baseline\n",
    "    self.is_baseline = hasattr(self, \"base_Alg\")\n",
    "    if self.is_baseline:\n",
    "      self.base_alg = self.base_Alg(env, n, self.base_params)\n",
    "\n",
    "  def update(self, t, arm, r):\n",
    "    self.pulls[arm] += 1\n",
    "    self.reward[arm] += r\n",
    "\n",
    "    best_r = self.env.rt[self.env.best_arm]\n",
    "    if self.is_baseline:\n",
    "      # baseline action and update\n",
    "      base_arm = self.base_alg.get_arm(t)\n",
    "      base_r = self.env.reward(base_arm)\n",
    "      self.base_alg.update(t, base_arm, base_r)\n",
    "\n",
    "      self.metrics[t, :] = np.asarray([r, r - best_r, r - base_r])\n",
    "    else:\n",
    "      self.metrics[t, :] = np.asarray([r, r - best_r, 0])\n",
    "\n",
    "  def get_arm(self, t):\n",
    "    # decision statistics\n",
    "    muhat = self.reward / self.pulls\n",
    "    best_arm = np.argmax(muhat)\n",
    "\n",
    "    # probabilities of pulling arms\n",
    "    eps = self.crs * self.epsilon\n",
    "    p = (1 - eps) * (np.arange(self.K) == best_arm) + eps / self.K\n",
    "\n",
    "    # pull the arm\n",
    "    arm = best_arm\n",
    "    if np.random.rand() < eps:\n",
    "      arm = np.random.randint(self.K)\n",
    "\n",
    "    # derivative of the probability of the pulled arm\n",
    "    self.grad[t] = self.epsilon * (1 / self.K - (arm == best_arm)) / p[arm]\n",
    "\n",
    "    return arm\n",
    "\n",
    "  @staticmethod\n",
    "  def print():\n",
    "    return \"e-greedy\"\n",
    "\n",
    "\n",
    "class Exp3:\n",
    "  def __init__(self, env, n, params):\n",
    "    self.env = env\n",
    "    self.K = env.K\n",
    "    self.crs = min(1, np.sqrt(self.K * np.log(self.K) / ((np.e - 1) * n)))\n",
    "\n",
    "    for attr, val in params.items():\n",
    "      setattr(self, attr, val)\n",
    "\n",
    "    self.eta = self.crs / self.K\n",
    "    self.reward = np.zeros(self.K)  # cumulative reward\n",
    "\n",
    "    self.grad = np.zeros(n)\n",
    "    self.metrics = np.zeros((n, 3))\n",
    "\n",
    "    # initialize baseline\n",
    "    self.is_baseline = hasattr(self, \"base_Alg\")\n",
    "    if self.is_baseline:\n",
    "      self.base_alg = self.base_Alg(env, n, self.base_params)\n",
    "\n",
    "  def update(self, t, arm, r):\n",
    "    self.reward[arm] += r / self.phat[arm]\n",
    "\n",
    "    best_r = self.env.rt[self.env.best_arm]\n",
    "    if self.is_baseline:\n",
    "      # baseline action and update\n",
    "      base_arm = self.base_alg.get_arm(t)\n",
    "      base_r = self.env.reward(base_arm)\n",
    "      self.base_alg.update(t, base_arm, base_r)\n",
    "\n",
    "      self.metrics[t, :] = np.asarray([r, r - best_r, r - base_r])\n",
    "    else:\n",
    "      self.metrics[t, :] = np.asarray([r, r - best_r, 0])\n",
    "\n",
    "  def get_arm(self, t):\n",
    "    # probabilities of pulling arms\n",
    "    scaled_reward = self.reward - self.reward.max()\n",
    "    p = np.exp(self.eta * scaled_reward)\n",
    "    p /= p.sum()\n",
    "    self.phat = (1 - self.crs) * p + self.eta\n",
    "\n",
    "    # pull the arm\n",
    "    q = np.cumsum(self.phat)\n",
    "    arm = np.flatnonzero(np.random.rand() * q[-1] < q)[0]\n",
    "\n",
    "    # derivative of the probability of the pulled arm\n",
    "    self.grad[t] = (1 / self.phat[arm]) * \\\n",
    "      ((1 - self.crs) * (p[arm] / self.K) *\n",
    "      (scaled_reward[arm] - p.dot(scaled_reward)) - p[arm] + 1 / self.K)\n",
    "\n",
    "    return arm\n",
    "\n",
    "  @staticmethod\n",
    "  def print():\n",
    "    return \"Exp3\"\n",
    "\n",
    "\n",
    "class FPL:\n",
    "  def __init__(self, env, n, params):\n",
    "    self.K = env.K\n",
    "    self.eta = np.sqrt((np.log(self.K) + 1) / (self.K * n))\n",
    "\n",
    "    for attr, val in params.items():\n",
    "      setattr(self, attr, val)\n",
    "\n",
    "    self.loss = np.zeros(self.K) # cumulative loss\n",
    "\n",
    "  def update(self, t, arm, r):\n",
    "    # estimate the probability of pulling the arm\n",
    "    wait_time = 0\n",
    "    while True:\n",
    "      wait_time += 1\n",
    "      ploss = self.loss + np.random.exponential(1 / self.eta, self.K)\n",
    "      if np.argmin(ploss) == arm:\n",
    "        break;\n",
    "\n",
    "    self.loss[arm] += (1 - r) * wait_time\n",
    "\n",
    "  def get_arm(self, t):\n",
    "    # perturb cumulative loss\n",
    "    ploss = self.loss + np.random.exponential(1 / self.eta, self.K)\n",
    "\n",
    "    arm = np.argmin(ploss)\n",
    "    return arm\n",
    "\n",
    "  @staticmethod\n",
    "  def print():\n",
    "    return \"FPL\"\n",
    "\n",
    "\n",
    "class LinBanditAlg:\n",
    "  def __init__(self, env, n, params):\n",
    "    self.env = env\n",
    "    self.X = np.copy(env.X)\n",
    "    self.K = self.X.shape[0]\n",
    "    self.d = self.X.shape[1]\n",
    "    self.n = n\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, arm, r):\n",
    "    x = self.X[arm, :]\n",
    "    self.Gram += np.outer(x, x) / np.square(self.sigma)\n",
    "    self.B += x * r / np.square(self.sigma)\n",
    "\n",
    "\n",
    "class LinUCB(LinBanditAlg):\n",
    "  def __init__(self, env, n, params):\n",
    "    LinBanditAlg.__init__(self, env, n, params)\n",
    "\n",
    "    self.cew = self.crs * self.confidence_ellipsoid_width(n)\n",
    "\n",
    "  def confidence_ellipsoid_width(self, t):\n",
    "    # Theorem 2 in Abassi-Yadkori (2011)\n",
    "    # Improved Algorithms for Linear Stochastic Bandits\n",
    "    delta = 1 / self.n\n",
    "    L = np.amax(np.linalg.norm(self.X, axis=1))\n",
    "    Lambda = 1 / np.square(self.sigma0)\n",
    "    R = self.sigma\n",
    "    S = np.sqrt(self.d)\n",
    "    width = np.sqrt(Lambda) * S + \\\n",
    "      R * np.sqrt(self.d * np.log((1 + t * np.square(L) / Lambda) / delta))\n",
    "    return width\n",
    "\n",
    "  def get_arm(self, t):\n",
    "    Gram_inv = np.linalg.inv(self.Gram)\n",
    "    theta = Gram_inv.dot(self.B)\n",
    "\n",
    "    # UCBs\n",
    "    Gram_inv /= np.square(self.sigma)\n",
    "    self.mu = self.X.dot(theta) + self.cew * \\\n",
    "      np.sqrt((self.X.dot(Gram_inv) * self.X).sum(axis=1))\n",
    "\n",
    "    arm = np.argmax(self.mu)\n",
    "    return arm\n",
    "\n",
    "  @staticmethod\n",
    "  def print():\n",
    "    return \"LinUCB\"\n",
    "\n",
    "\n",
    "class LinGreedy(LinBanditAlg):\n",
    "  def get_arm(self, t):\n",
    "    self.mu = np.zeros(self.K)\n",
    "    if np.random.rand() < 0.05 * np.sqrt(self.n / (t + 1)) / 2:\n",
    "      self.mu[np.random.randint(self.K)] = np.Inf\n",
    "    else:\n",
    "      theta = np.linalg.solve(self.Gram, self.B)\n",
    "      self.mu = self.X.dot(theta)\n",
    "\n",
    "    arm = np.argmax(self.mu)\n",
    "    return arm\n",
    "\n",
    "  @staticmethod\n",
    "  def print():\n",
    "    return \"Lin e-greedy\"\n",
    "\n",
    "\n",
    "class LinTS(LinBanditAlg):\n",
    "  def update(self, t, arm, r):\n",
    "    x = self.env.X[arm, :]\n",
    "    self.Gram += np.outer(x, x) / np.square(self.sigma)\n",
    "    self.B += x * r / np.square(self.sigma)\n",
    "\n",
    "  def get_arm(self, t):\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)\n",
    "    self.mu = self.env.X.dot(thetatilde)\n",
    "\n",
    "    arm = np.argmax(self.mu)\n",
    "    return arm\n",
    "\n",
    "  @staticmethod\n",
    "  def print():\n",
    "    return \"LinTS\"\n",
    "\n",
    "\n",
    "class CoLinTS(LinBanditAlg):\n",
    "  def update(self, t, arm, r):\n",
    "    x = self.env.X[arm, :]\n",
    "    self.Gram += np.outer(x, x) / np.square(self.sigma)\n",
    "    self.B += x * r / np.square(self.sigma)\n",
    "\n",
    "  def get_arm(self, t):\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)\n",
    "    self.mu = self.env.X.dot(thetatilde)\n",
    "\n",
    "    arm = np.argmax(self.mu)\n",
    "    return arm\n",
    "\n",
    "  @staticmethod\n",
    "  def print():\n",
    "    return \"CoLinTS\"\n",
    "\n",
    "\n",
    "class LogBanditAlg:\n",
    "  def __init__(self, env, n, params):\n",
    "    self.env = env\n",
    "    self.X = np.copy(env.X)\n",
    "    self.K = self.X.shape[0]\n",
    "    self.d = self.X.shape[1]\n",
    "    self.n = n\n",
    "    self.sigma0 = 1.0\n",
    "    self.crs = 1.0 # confidence region scaling\n",
    "    self.crs_is_width = False\n",
    "\n",
    "    self.irls_theta = np.zeros(self.d)\n",
    "    self.irls_error = 1e-3\n",
    "    self.irls_num_iter = 30\n",
    "\n",
    "    for attr, val in params.items():\n",
    "      setattr(self, attr, val)\n",
    "\n",
    "    # sufficient statistics\n",
    "    self.pos = np.zeros(self.K, dtype=int) # number of positive observations\n",
    "    self.neg = np.zeros(self.K, dtype=int) # number of negative observations\n",
    "    self.X2 = np.zeros((self.K, self.d, self.d)) # outer products of arm features\n",
    "    for k in range(self.K):\n",
    "      self.X2[k, :, :] = np.outer(self.X[k, :], self.X[k, :])\n",
    "\n",
    "  def update(self, t, arm, r):\n",
    "    self.pos[arm] += r\n",
    "    self.neg[arm] += 1 - r\n",
    "\n",
    "  def sigmoid(self, x):\n",
    "    y = 1 / (1 + np.exp(- x))\n",
    "    return y\n",
    "\n",
    "  def solve(self):\n",
    "    # iterative reweighted least squares for Bayesian logistic regression\n",
    "    # Sections 4.3.3 and 4.5.1 in Bishop (2006)\n",
    "    # Pattern Recognition and Machine Learning\n",
    "    theta = np.copy(self.irls_theta)\n",
    "\n",
    "    num_iter = 0\n",
    "    while num_iter < self.irls_num_iter:\n",
    "      theta_old = np.copy(theta)\n",
    "\n",
    "      Xtheta = self.X.dot(theta)\n",
    "      R = self.sigmoid(Xtheta) * (1 - self.sigmoid(Xtheta))\n",
    "      pulls = self.pos + self.neg\n",
    "      Gram = np.tensordot(R * pulls, self.X2, axes=([0], [0])) + \\\n",
    "        np.eye(self.d) / np.square(self.sigma0)\n",
    "      Rz = R * pulls * Xtheta - \\\n",
    "        self.pos * (self.sigmoid(Xtheta) - 1) - \\\n",
    "        self.neg * (self.sigmoid(Xtheta) - 0)\n",
    "      theta = np.linalg.solve(Gram, self.X.T.dot(Rz))\n",
    "\n",
    "      if np.linalg.norm(theta - theta_old) < self.irls_error:\n",
    "        break;\n",
    "      num_iter += 1\n",
    "\n",
    "    if num_iter == self.irls_num_iter:\n",
    "      self.irls_theta = np.zeros(self.d)\n",
    "    else:\n",
    "      self.irls_theta = np.copy(theta)\n",
    "\n",
    "    return theta, Gram\n",
    "\n",
    "\n",
    "class LogUCB(LogBanditAlg):\n",
    "  def __init__(self, env, n, params):\n",
    "    LogBanditAlg.__init__(self, env, n, params)\n",
    "\n",
    "    if not self.crs_is_width:\n",
    "      self.cew = self.crs * self.confidence_ellipsoid_width(n)\n",
    "    else:\n",
    "      self.cew = self.crs\n",
    "\n",
    "  def confidence_ellipsoid_width(self, t):\n",
    "    # Section 4.1 in Filippi (2010)\n",
    "    # Parametric Bandits: The Generalized Linear Case\n",
    "    delta = 1 / self.n\n",
    "    c_m = np.amax(np.linalg.norm(self.X, axis=1))\n",
    "    c_mu = 0.25 # minimum derivative of the mean function\n",
    "    k_mu = 0.25\n",
    "    kappa = np.sqrt(3 + 2 * np.log(1 + 2 * np.square(c_m / self.sigma0)))\n",
    "    R_max = 1.0\n",
    "    width = (2 * k_mu * kappa * R_max / c_mu) * \\\n",
    "      np.sqrt(2 * self.d * np.log(t) * np.log(2 * self.d * self.n / delta))\n",
    "    return width\n",
    "\n",
    "  def get_arm(self, t):\n",
    "    pulls = self.pos + self.neg\n",
    "    Gram = np.tensordot(pulls, self.X2, axes=([0], [0])) + \\\n",
    "      np.eye(self.d) / np.square(self.sigma0)\n",
    "    Gram_inv = np.linalg.inv(Gram)\n",
    "    theta, _ = self.solve()\n",
    "\n",
    "    # UCBs\n",
    "    self.mu = self.sigmoid(self.X.dot(theta)) + self.cew * \\\n",
    "      np.sqrt((self.X.dot(Gram_inv) * self.X).sum(axis=1))\n",
    "\n",
    "    arm = np.argmax(self.mu)\n",
    "    return arm\n",
    "\n",
    "  @staticmethod\n",
    "  def print():\n",
    "    return \"GLM-UCB (log)\"\n",
    "\n",
    "\n",
    "class UCBLog(LogBanditAlg):\n",
    "  def __init__(self, env, n, params):\n",
    "    LogBanditAlg.__init__(self, env, n, params)\n",
    "\n",
    "    if not self.crs_is_width:\n",
    "      self.cew = self.crs * self.confidence_ellipsoid_width(n)\n",
    "    else:\n",
    "      self.cew = self.crs\n",
    "\n",
    "  def confidence_ellipsoid_width(self, t):\n",
    "    # Theorem 2 in Li (2017)\n",
    "    # Provably Optimal Algorithms for Generalized Linear Contextual Bandits\n",
    "    delta = 1 / self.n\n",
    "    sigma = 0.5\n",
    "    kappa = 0.25 # minimum derivative of a constrained mean function\n",
    "    width = (sigma / kappa) * \\\n",
    "      np.sqrt((self.d / 2) * np.log(1 + 2 * self.n / self.d) + \\\n",
    "      np.log(1 / delta))\n",
    "    return width\n",
    "\n",
    "  def get_arm(self, t):\n",
    "    pulls = self.pos + self.neg\n",
    "    Gram = np.tensordot(pulls, self.X2, axes=([0], [0])) + \\\n",
    "      np.eye(self.d) / np.square(self.sigma0)\n",
    "    Gram_inv = np.linalg.inv(Gram)\n",
    "    theta, _ = self.solve()\n",
    "\n",
    "    # UCBs\n",
    "    self.mu = self.X.dot(theta) + self.cew * \\\n",
    "      np.sqrt((self.X.dot(Gram_inv) * self.X).sum(axis=1))\n",
    "\n",
    "    arm = np.argmax(self.mu)\n",
    "    return arm\n",
    "\n",
    "  @staticmethod\n",
    "  def print():\n",
    "    return \"UCB-GLM (log)\"\n",
    "\n",
    "\n",
    "class LogGreedy(LogBanditAlg):\n",
    "  def __init__(self, env, n, params):\n",
    "    LogBanditAlg.__init__(self, env, n, params)\n",
    "\n",
    "    self.epsilon = 0.05\n",
    "\n",
    "  def get_arm(self, t):\n",
    "    self.mu = np.zeros(self.K)\n",
    "    if np.random.rand() < self.epsilon * np.sqrt(self.n / (t + 1)) / 2:\n",
    "      self.mu[np.random.randint(self.K)] = np.Inf\n",
    "    else:\n",
    "      theta, _ = self.solve()\n",
    "      self.mu = self.sigmoid(self.X.dot(theta))\n",
    "\n",
    "    arm = np.argmax(self.mu)\n",
    "    return arm\n",
    "\n",
    "  @staticmethod\n",
    "  def print():\n",
    "    return \"Log e-greedy\"\n",
    "\n",
    "\n",
    "class LogTS(LogBanditAlg):\n",
    "  def get_arm(self, t):\n",
    "    thetabar, Gram = self.solve()\n",
    "    Gram_inv = np.linalg.inv(Gram)\n",
    "\n",
    "    # posterior sampling\n",
    "    thetatilde = np.random.multivariate_normal(thetabar,\n",
    "      np.square(self.crs) * Gram_inv)\n",
    "    self.mu = self.X.dot(thetatilde)\n",
    "\n",
    "    arm = np.argmax(self.mu)\n",
    "    return arm\n",
    "\n",
    "  @staticmethod\n",
    "  def print():\n",
    "    return \"GLM-TSL (log)\"\n",
    "\n",
    "\n",
    "class LogFPL(LogBanditAlg):\n",
    "  def __init__(self, env, n, params):\n",
    "    self.a = 1.0\n",
    "\n",
    "    LogBanditAlg.__init__(self, env, n, params)\n",
    "\n",
    "  def solve(self):\n",
    "    # normal noise perturbation\n",
    "    pulls = self.pos + self.neg\n",
    "    z = self.a * np.sqrt(pulls) * \\\n",
    "      np.minimum(np.maximum(np.random.randn(self.K), -6), 6)\n",
    "\n",
    "    # iterative reweighted least squares for Bayesian logistic regression\n",
    "    # Sections 4.3.3 and 4.5.1 in Bishop (2006)\n",
    "    # Pattern Recognition and Machine Learning\n",
    "    theta = np.copy(self.irls_theta)\n",
    "\n",
    "    num_iter = 0\n",
    "    while num_iter < self.irls_num_iter:\n",
    "      theta_old = np.copy(theta)\n",
    "\n",
    "      Xtheta = self.X.dot(theta)\n",
    "      R = self.sigmoid(Xtheta) * (1 - self.sigmoid(Xtheta))\n",
    "      Gram = np.tensordot(R * pulls, self.X2, axes=([0], [0])) + \\\n",
    "        np.eye(self.d) / np.square(self.sigma0)\n",
    "      Rz = R * pulls * Xtheta - \\\n",
    "        (pulls * self.sigmoid(Xtheta) - (self.pos + z))\n",
    "      theta = np.linalg.solve(Gram, self.X.T.dot(Rz))\n",
    "\n",
    "      if np.linalg.norm(theta - theta_old) < self.irls_error:\n",
    "        break;\n",
    "      num_iter += 1\n",
    "\n",
    "    if num_iter == self.irls_num_iter:\n",
    "      self.irls_theta = np.zeros(self.d)\n",
    "    else:\n",
    "      self.irls_theta = np.copy(theta)\n",
    "\n",
    "    return theta, Gram\n",
    "\n",
    "  def get_arm(self, t):\n",
    "    self.mu = np.zeros(self.K)\n",
    "    if t < self.d:\n",
    "      self.mu[t] = np.Inf\n",
    "    else:\n",
    "      # history perturbation\n",
    "      theta, _ = self.solve()\n",
    "      self.mu = self.sigmoid(self.X.dot(theta))\n",
    "\n",
    "    arm = np.argmax(self.mu)\n",
    "    return arm\n",
    "\n",
    "  @staticmethod\n",
    "  def print():\n",
    "    return \"GLM-FPL (log)\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "colab": {
     "height": 1000
    },
    "executionInfo": {
     "elapsed": 335818,
     "status": "ok",
     "timestamp": 1622693856032,
     "user": {
      "displayName": "Branislav Kveton",
      "photoUrl": "https://lh3.googleusercontent.com/a-/AOh14GhjPg1PJKD4ixGqLaZ4X3dpkI6w6dO_eTj8z63Y=s64",
      "userId": "09350298559467540088"
     },
     "user_tz": 0
    },
    "id": "O7WNIAqO-9FA",
    "outputId": "5d3114c6-ae59-4504-8b64-111712ff3f84"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "OracleTS: 34.9 +/- 3.5\n",
      "TS: 181.7 +/- 18.2\n",
      "AdaTS: 60.0 +/- 6.0\n",
      "AdaTSx: 58.0 +/- 5.8\n",
      "AdaTSd: 76.3 +/- 7.6\n",
      "MetaTS: 115.7 +/- 11.6\n"
     ]
    },
    {
     "data": {
      "image/png": "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pklw4YMPwNERPvywoUdUOUroFApFjcjPh08/hb174exZcHCA226D9u0bemRVo4SujklLS2PIkCGAJOVaW1vj7u4OwIQJE1i3bh3W1tZYWVnx8ccf07dv34YcrkJRbYqKxGL76CO491545hlwdQV/f3l/3boGHd5VUUJXx7Rv395cllW+pdLu3buZO3cuBw8exN7entTU1DrpT6dQWJrCQvjqK3j/fRgzBn77Ddq0aehR1QwldPVEcnIybm5u5gL60mJ9haKxotfD4sWwejWMHi3pIR4eFfcpH3Xt2FHKtKAsSNFYUEJXTwwfPpw333yTG2+8kaFDh3LvvfcyaNCghh6WQlEpeXkwciQMGQIHD0qgoTIam6BVRb1kuMyYMQMPDw+6detm3jZ//ny8vb3Nrb43b95sfm/BggUEBAQQFBREVOnXRR0wYAB07Vrzx/X0wSrF2dmZAwcO8Mknn+Du7s69997L559/fv0nVigswOzZcN99MH9+1SLXlKgXi2769Ok8+eSTPPTQQxW2P/vss1e0BD958iRr167lxIkTJCUlMXToUGJiYrC2tr7uceysrz5NVWBtbc3gwYMZPHgwoaGhrFq1iunTpzfsoBQtHk2Th8EgDS9PnoQ//oCS5jvNgnoRuoEDBxIXF1etfSMiIpgyZQr29vb4+fkREBDA3r176d+/v2UHaWH++OMPrKysCAwMBODw4cN07ty5gUelaIkYjSJkJ05IB5GICLC2lgqGjh0lirpwYUOPsm5pUB/dsmXL+OKLL+jduzf/+Mc/aNeuHYmJifTr18+8j4+PD4mJiQ04yrohNzeXp556iszMTGxsbAgICOCTTz5p6GEpWhjbtsFTT0GXLtC2LYwdC6+9Bs7ODT0yy9JgQjd79mxee+01dDodr732Gs899xyfffYZlXWNulqn3cbM/Pnzzc979erFrl27Gm4wihaN0SiCtmsXfP+9CF1LosGErkO5FgYzZ87kzjvvBMSCi4+PN7+XkJCAl5dXpefIzc01N6QcMWIEI5pC+EehqAfKp33s3w8xMeDjA2++2fRELioqyhyULL98Z43Q6olz585pISEh5tdJSUnm50uWLNHuvfdeTdM07fjx41pYWJhWUFCgnT17VvPz89MMBkOl5wwODrbsoBWKZkD79pq2dGlDj6JuqO1nvl4suqlTpxIdHU1qaio+Pj78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\n",
      "text/plain": [
       "<Figure size 320x200 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "OracleTS: 35.8 +/- 3.6\n",
      "TS: 151.2 +/- 15.1\n",
      "AdaTS: 49.7 +/- 5.0\n",
      "AdaTSx: 51.9 +/- 5.2\n",
      "AdaTSd: 60.9 +/- 6.1\n",
      "MetaTS: 130.6 +/- 13.1\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 320x200 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "OracleTS: 58.6 +/- 5.9\n",
      "TS: 121.0 +/- 12.1\n",
      "AdaTS: 55.4 +/- 5.5\n",
      "AdaTSx: 59.3 +/- 5.9\n",
      "AdaTSd: 58.9 +/- 5.9\n",
      "MetaTS: 236.1 +/- 23.6\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 320x200 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "OracleTS: 89.3 +/- 8.9\n",
      "TS: 455.2 +/- 45.5\n",
      "AdaTS: 151.6 +/- 15.2\n",
      "AdaTSx: 148.7 +/- 14.9\n",
      "AdaTSd: 155.0 +/- 15.5\n",
      "MetaTS: 237.0 +/- 23.7\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 320x200 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "OracleTS: 101.7 +/- 10.2\n",
      "TS: 382.5 +/- 38.3\n",
      "AdaTS: 141.1 +/- 14.1\n",
      "AdaTSx: 134.9 +/- 13.5\n",
      "AdaTSd: 144.5 +/- 14.5\n",
      "MetaTS: 295.9 +/- 29.6\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 320x200 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "OracleTS: 173.3 +/- 17.3\n",
      "TS: 350.0 +/- 35.0\n",
      "AdaTS: 191.9 +/- 19.2\n",
      "AdaTSx: 192.7 +/- 19.3\n",
      "AdaTSd: 216.0 +/- 21.6\n",
      "MetaTS: 550.2 +/- 55.0\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 320x200 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "OracleTS: 191.7 +/- 19.2\n",
      "TS: 832.6 +/- 83.3\n",
      "AdaTS: 265.9 +/- 26.6\n",
      "AdaTSx: 297.0 +/- 29.7\n",
      "AdaTSd: 280.0 +/- 28.0\n",
      "MetaTS: 427.1 +/- 42.7\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 320x200 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "OracleTS: 266.6 +/- 26.7\n",
      "TS: 775.1 +/- 77.5\n",
      "AdaTS: 311.7 +/- 31.2\n",
      "AdaTSx: 323.9 +/- 32.4\n",
      "AdaTSd: 333.8 +/- 33.4\n",
      "MetaTS: 562.1 +/- 56.2\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 320x200 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "OracleTS: 459.1 +/- 45.9\n",
      "TS: 748.9 +/- 74.9\n",
      "AdaTS: 501.6 +/- 50.2\n",
      "AdaTSx: 530.0 +/- 53.0\n",
      "AdaTSd: 516.7 +/- 51.7\n",
      "MetaTS: 943.8 +/- 94.4\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 320x200 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Gaussian bandit\n",
    "algs = [\n",
    "  (\"GaussTS\", 1, \"cyan\", \"-\", \"OracleTS\"),\n",
    "  (\"GaussTS\", 1, \"blue\", \"-\", \"TS\"),\n",
    "  (\"GaussTS\", 1, \"red\", \"-\", \"AdaTS\"),\n",
    "  (\"GaussTS\", 3, \"red\", \"--\", \"AdaTSx\"),  # AdaTS with 3x wider meta-prior\n",
    "  (\"GaussTS\", 0.333, \"red\", \":\", \"AdaTSd\"),  # AdaTS with 3x narrower meta-prior\n",
    "  (\"GaussTS\", 1, \"gray\", \"-\", \"MetaTS\")]\n",
    "num_runs = 100\n",
    "num_tasks = 20\n",
    "n = 200\n",
    "\n",
    "step = np.arange(1, n * num_tasks + 1) / n\n",
    "sube = (step.size // 10) * np.arange(1, 11) - 1\n",
    "\n",
    "for K in [2, 4, 8]:\n",
    "  for sigma_q_scale in [0.5, 1, 2]:\n",
    "    # meta-prior parameters\n",
    "    mu_q = np.zeros(K)\n",
    "    sigma_q = sigma_q_scale * np.ones(K)\n",
    "    # prior parameters\n",
    "    sigma_0 = 0.1 * np.ones(K)\n",
    "    # reward noise\n",
    "    sigma = 1.0\n",
    "\n",
    "    plt.figure(figsize=(4, 2.5))\n",
    "\n",
    "    alg_num = 0\n",
    "    for alg in algs:\n",
    "      regret = np.zeros((num_tasks * n, num_runs))\n",
    "\n",
    "      for run in range(num_runs):\n",
    "        # true prior\n",
    "        mu_star = mu_q + sigma_q * np.random.randn(K)\n",
    "\n",
    "        # potential meta-prior misspecification\n",
    "        sigma_q_alg = alg[1] * sigma_q \n",
    "\n",
    "        # incrementally updated statistics\n",
    "        mu_inc = mu_q / np.square(sigma_q_alg)\n",
    "        lambda_inc = 1.0 / np.square(sigma_q_alg)\n",
    "\n",
    "        # initial meta-posterior\n",
    "        mu_hat = mu_inc / lambda_inc\n",
    "        sigma_hat = 1.0 / np.sqrt(lambda_inc)\n",
    "\n",
    "        for task in range(num_tasks):\n",
    "          # sample problem instance from N(\\mu_*, \\sigma_0^2 I_K)\n",
    "          mu = mu_star + sigma_0 * np.random.randn(K)\n",
    "          env = GaussBandit(mu, sigma=sigma)\n",
    "\n",
    "          # task prior\n",
    "          if alg_num == 0:\n",
    "            # OracleTS\n",
    "            mu_task = np.copy(mu_star)\n",
    "            sigma_task = np.copy(sigma_0)\n",
    "          elif alg_num == 1:\n",
    "            # TS\n",
    "            mu_task = np.copy(mu_q)\n",
    "            sigma_task = np.sqrt(np.square(sigma_0) + np.square(sigma_q))\n",
    "          elif alg_num >= 2:\n",
    "            if alg[-1].startswith(\"Meta\"):\n",
    "              # MetaTS\n",
    "              mu_tilde = mu_hat + sigma_hat * np.random.randn(K)\n",
    "              mu_task = np.copy(mu_tilde)\n",
    "              sigma_task = np.copy(sigma_0)\n",
    "            else:\n",
    "              # AdaTS\n",
    "              mu_task = np.copy(mu_hat)\n",
    "              sigma_task = np.sqrt(np.square(sigma_0) + np.square(sigma_hat))\n",
    "\n",
    "          # evaluate on a sampled problem instance\n",
    "          alg_class = globals()[alg[0]]\n",
    "          alg_params = {\n",
    "            \"mu0\": mu_task,\n",
    "            \"sigma0\": sigma_task,\n",
    "            \"sigma\": sigma}\n",
    "          task_regret, logs = evaluate(\n",
    "            alg_class, alg_params, [env], n, printout=False)\n",
    "          regret[task * n : (task + 1) * n, run] += task_regret.flatten()\n",
    "\n",
    "          # meta-posterior update\n",
    "          if alg_num >= 2:\n",
    "            sigma2 = np.square(sigma)\n",
    "            sigma_02 = np.square(sigma_0)\n",
    "\n",
    "            # incremental update\n",
    "            mu_inc += logs[0].reward / (logs[0].pulls * sigma_02 + sigma2)\n",
    "            lambda_inc += logs[0].pulls / (logs[0].pulls * sigma_02 + sigma2)\n",
    "\n",
    "            # updated meta-posterior\n",
    "            mu_hat = mu_inc / lambda_inc\n",
    "            sigma_hat = 1.0 / np.sqrt(lambda_inc)\n",
    "\n",
    "      cum_regret = regret.cumsum(axis=0)\n",
    "      plt.plot(step, cum_regret.mean(axis=1),\n",
    "        alg[2], dashes=linestyle2dashes(alg[3]),\n",
    "        label=alg[4] if alg[1] == 1 else \"\")\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[2])\n",
    "\n",
    "      print(\"%s: %.1f +/- %.1f\" % (alg[4],\n",
    "        cum_regret[-1, :].mean(),\n",
    "        cum_regret[-1, :].mean() / np.sqrt(cum_regret.shape[1])))\n",
    "\n",
    "      alg_num += 1\n",
    "\n",
    "    plt.title(r\"Gaussian (K = %d, $\\sigma_q$ = %.3f)\" % (K, sigma_q_scale))\n",
    "    plt.xlabel(\"Task s\")\n",
    "    plt.ylabel(\"Regret\")\n",
    "    plt.ylim(bottom=0)\n",
    "    plt.legend(loc=\"upper left\", frameon=False)\n",
    "\n",
    "    plt.tight_layout()\n",
    "    plt.show()"
   ]
  }
 ],
 "metadata": {
  "colab": {
   "collapsed_sections": [],
   "last_runtime": {
    "build_target": "//learning/deepmind/public/tools/ml_python:ml_notebook",
    "kind": "private"
   },
   "name": "AdaTS Public.ipynb",
   "provenance": [
    {
     "file_id": "1A_VJGRPLw2g7jJFFcasEDsTwIKw6r2pN",
     "timestamp": 1622693066026
    },
    {
     "file_id": "1KQ5KG6apEvn742lA6eFncrYBGcCYsJUX",
     "timestamp": 1607809593691
    },
    {
     "file_id": "/piper/depot/google3/experimental/users/bkveton/PHE/IJCAI2019/PHE.ipynb",
     "timestamp": 1571109683614
    },
    {
     "file_id": "/piper/depot/google3/experimental/users/bkveton/PHE/ICML2019/Giro.ipynb?workspaceId=bkveton:bandits::citc",
     "timestamp": 1550373354024
    },
    {
     "file_id": "/piper/depot/google3/experimental/users/bkveton/PHE/PHE.ipynb?workspaceId=bkveton:custom_colab::citc",
     "timestamp": 1547612018471
    },
    {
     "file_id": "1LhE7RPIsiVHxKVhhQ_ddNwtL78yqsrZi",
     "timestamp": 1546401322558
    },
    {
     "file_id": "1hGOquMsYlCi0_oDMIM_IlidSI7sPWoYF",
     "timestamp": 1536892738296
    },
    {
     "file_id": "11k4kxddvtZjrTYpnuJP549znnEadfMNL",
     "timestamp": 1535848084981
    }
   ]
  },
  "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.9.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
