{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "cellView": "form",
    "executionInfo": {
     "elapsed": 5,
     "status": "ok",
     "timestamp": 1622693529382,
     "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": "2bf8e007-2d12-4890-dde6-70963e94d673",
    "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": "EnKtuSXdfl4l",
    "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": "YLSfNducfmNs",
    "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": 3383843,
     "status": "ok",
     "timestamp": 1622696918292,
     "user": {
      "displayName": "Branislav Kveton",
      "photoUrl": "https://lh3.googleusercontent.com/a-/AOh14GhjPg1PJKD4ixGqLaZ4X3dpkI6w6dO_eTj8z63Y=s64",
      "userId": "09350298559467540088"
     },
     "user_tz": 0
    },
    "id": "cuyuQsXLZ8mb",
    "outputId": "9b49eb00-4070-44c1-86f8-63e5d3eb3294",
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "OracleTS: 78.8 +/- 7.9\n",
      "TS: 364.5 +/- 36.5\n",
      "AdaTS: 125.4 +/- 12.5\n",
      "AdaTSx: 119.8 +/- 12.0\n",
      "AdaTSd: 120.1 +/- 12.0\n",
      "MetaTS: 191.9 +/- 19.2\n"
     ]
    },
    {
     "data": {
      "image/png": "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V1HrMWsztra2hIaGkp6ejo2NDT/99BMtW7a843EhISEcPny4SKHLG3S5tabd3LlzcXZ25sSJE4A0za6jw3qlRinpYL9kiTR+7thR0kI8PeGll2TRfb16lT1KTVHcUejatGlDmzZt+O2337h48SJnz55l4MCBpKenk56ejr2u31wgDz74IFu2bOGxxx5j7dq1jB07ln379gGQmprK3/72N06cOIHRaGT27Nk8+OCD/POf/yQ9PZ39+/fzxhtv4O7uzksvvWQWzP/+979FlmSKjo7OtxxMl28qHUrB11/DBx9ImsjMmdCrl64gUi0pbtRixYoVqmvXrsrDw0MppdSZM2fU/fffX6IISFlRVaOutra26tixY2rUqFEqPT1dBQQEqD179qiHH35YKaXUG2+8ob744gullFIJCQmqXbt2KiUlRf33v/9VL774ovk8N27cUAaDQSml1E8//aRGjhyZ7zp9+/ZVhw4dMv9+9OhR1axZM9WzZ0/11ltvqTNnzpT3rdY4tm9X6uWXlXrpJaWcnZXy8lJqwgTZrql8SvqZL3Ye3bJlywgKCjKvamjXrh3Xrl0rNwEuDz777LN8BS+Li42NDZMmTbqrY/z9/YmIiGDt2rW3TUV37tzJ5s2bWbhwIQAZGRlcunTptnPcuHGDCRMmcPbsWSwsLDAYDEVeMzAwkPPnz7Nz50527dpFt27d+O233/D29r6rsddmhgyBPn1k7WlGhjR+1hZc9afYQlevXj3q1q1r/t1oNFa7FQt3K1alZdiwYbzyyivs3buXuLg483alFN9///1tU8s//vgj3++zZs2if//+bNiwgYiIiHxrXgvDzs6OkSNHMnLkSCwtLdm6dasWumJgNMJXX8G6dRARIUGFZs20yNUUip1H17dvX95//33S09P56aefePzxx3nkkUfKc2zVnkmTJvHPf/4TPz+/fNuHDBnCxx9/bF7uZkrRsbe3Jzk52bzfjRs3zEGM4lQoOXDggHnNcFZWFidPntQlnO7AxYvwr3+J7+3QIfHHhYXB6tV6eVZNothCN3/+fJo1a4afnx/Lly/noYce4r333ivPsVV7XF1dmTZt2m3bZ82ahcFgwN/fn44dOzJr1iwA+vfvz8mTJwkMDOTrr7/mtdde44033uDee+8lOzv7jtcLDw+nb9+++Pn50alTJ7p27cqoUaPK/L6qO+np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s88+i7e3N9NNTdcpxf++nIIm5c6WLVtUu3btlIeHh3rvvfcqezgVRnh4uPL391f+/v7Kx8enxt/7E088oZo3b66sra1Vy5Yt1aeffqpiY2PV/fffrzw9PdX999+v4uLiKnuY5UZB9//UU0+pjh07Kj8/P/XII4+oqKioyh5mmbNv3z4FKD8/PxUQEKACAgLUli1bSvy/1ysjNBpNjadaTl01Go3mbtBCp9Foajxa6DQaTY1HC51Go6nxaKHTaDQ1Hi10Go2mxlMlKwxragdxcXEMGDAAgKtXr2JlZUWzZs0AKdxQt27dIo//3//+x+HDh1m6dGm5j1VTvdFCp6k0mjRpQkhICCA11uzs7HjllVcqd1CaGomeumqqFCtXrqRbt24EBAQwatQo0tLSAPj222/p2LEjAQEB9OnT57bjtmzZQq9evYiNjc23/ZdffjEXqOzUqZN5+ZymdqGFTlOlGDlyJIcOHeLYsWN4e3uzatUqAN5991127NjBsWPH2Lx5c75jNmzYwLx589i6dStNmzbN99rChQtZtmwZISEh7Nu3D5sCGp1raj5a6DRVitDQUO677z78/PxYs2YNYWFhANx7771MnDiRlStXkp2dbd5/z549zJ8/ny1btuDg4HDb+e69916mT5/OkiVLSExMxNpae2tqI1roNFWKiRMnsnTpUk6cOMHbb79NRkYGAJ988gnvvfcely9fJjAwkLi4OAA8PDxITk7mzJkzBZ5v5syZfPrpp6Snp9OzZ0/+/PPPCrsXTdVBC52mSpGcnIyLiwsGg4E1a9aYt4eHh9OjRw/effddmjZtaq5H2KZNG9avX8/48ePN1l9ewsPD8fPz4/XXX6dr165a6GopWug0VYp//etf9OjRg0GDBtGhQwfz9ldffRU/Pz86duxInz59CAgIML/Wvn171qxZw+OPP054eHi+8y1atMgcxLCxseHBBx+ssHvRVB10mSaNRlPj0RadRqOp8Wih02g0NR4tdBqNpsajhU6j0dR4tNBpNJoajxY6jUZT49FCp9Foajxa6DQaTY1HC51Go6nx/D9/jcochn8fzgAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 320x200 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "OracleTS: 35.5 +/- 3.6\n",
      "TS: 338.0 +/- 33.8\n",
      "AdaTS: 71.6 +/- 7.2\n",
      "AdaTSx: 68.6 +/- 6.9\n",
      "AdaTSd: 82.2 +/- 8.2\n",
      "MetaTS: 221.8 +/- 22.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: 16.7 +/- 1.7\n",
      "TS: 303.8 +/- 30.4\n",
      "AdaTS: 48.7 +/- 4.9\n",
      "AdaTSx: 53.0 +/- 5.3\n",
      "AdaTSd: 49.6 +/- 5.0\n",
      "MetaTS: 372.1 +/- 37.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: 101.0 +/- 10.1\n",
      "TS: 745.8 +/- 74.6\n",
      "AdaTS: 209.8 +/- 21.0\n",
      "AdaTSx: 215.9 +/- 21.6\n",
      "AdaTSd: 212.5 +/- 21.2\n",
      "MetaTS: 353.1 +/- 35.3\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAToAAADCCAYAAADZ9A6cAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjQuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/MnkTPAAAACXBIWXMAAAxOAAAMTgF/d4wjAABATklEQVR4nO2deVzVVfrH3yyyyI6AIiSioAECFxW3chc1M00ttxo1J23S+WVZTc44TZspplmazlipk5Vpq8u4QFpaphaloqLmgqKyKPtygctyOb8/DlwlUQG5LJfzfr2+L773e7/LOd57Pz7nOc/zHDMhhEChUChMGPOGboBCoVAYGyV0CoXC5FFCp1AoTB4ldAqFwuRRQqdQKEweJXQKhcLkUUKnUChMHiV0CoXC5FFC14Sxt7e/6VifPn3qvR2FhYX0798fvV5/03uvvvoqS5curZPn6PV6wsLCGDlyZJ3c726Jioqic+fO+Pn5ERkZWeU57du3Jzg4GI1GQ/fu3at1fVXHi4uL6devH6WlpcbrkAmjhM7EOHjwoNHuLYSgrKzspuPr1q1j7NixWFhYGO3ZAMuXLycgIMCoz6guer2e2bNns2vXLk6dOsXGjRs5depUlefu3buX2NhYfvvttztef6vjVlZWDB48mM8//7y+umhSKKEzMSqsvISEBAICApgxYwZBQUEMHTqUwsJCAD799FN69OiBRqPhqaeeMlhiDz/8MN26dSMoKIgPPvig0n1mzZpF165duXLlyk3P3LBhA6NHjza8fvPNN+ncuTNDhgzhzJkzddKvxMREduzYwZNPPlmt88+cOcP48eMJDQ3lwQcfZPXq1XXSjgpiYmLw8/OjQ4cOWFlZMXHiRLZu3XrX19/uvg8//DAbNmyo0340F5TQmTDnzp1j9uzZnDx5EmdnZ77++mtOnz7N559/zoEDB4iNjcXCwsLw41m3bh2HDx/mt99+Y8WKFWRkZABSNKZMmcLRo0fx8fGp9Izi4mIuXLhA+/btATh8+DCbNm3i6NGjfPPNN/z6669Vtq1v375oNJqbtj179lR5/rPPPstbb72Fufmdv7KFhYUsXryYTz/9lL/85S/Mnj2bv/zlL3e8riZtSkpK4p577jG89vb2Jikp6abzzMzMGDp0KN26dTP853G762933y5dutzy31NxeywbugEK4+Hr64tGowGgW7du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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: 47.7 +/- 4.8\n",
      "TS: 678.6 +/- 67.9\n",
      "AdaTS: 147.9 +/- 14.8\n",
      "AdaTSx: 138.7 +/- 13.9\n",
      "AdaTSd: 146.2 +/- 14.6\n",
      "MetaTS: 390.9 +/- 39.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: 22.2 +/- 2.2\n",
      "TS: 623.9 +/- 62.4\n",
      "AdaTS: 95.3 +/- 9.5\n",
      "AdaTSx: 98.6 +/- 9.9\n",
      "AdaTSd: 113.3 +/- 11.3\n",
      "MetaTS: 695.6 +/- 69.6\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAToAAADCCAYAAADZ9A6cAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjQuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/MnkTPAAAACXBIWXMAAAxOAAAMTgF/d4wjAABAIElEQVR4nO2deVyUVfv/PzPsm4oLiqIIgsQO4p4LiqiZuVEumWJ+zX7qU5blE09+K3syQbNSk0pNi5IHc/kqPmqQCy5hhgtgiAqCqKzKzsAMs53fH4f7ZpBtWGYGhvN+ve7X3HMv577OzJzPXGe7joAQQsBgMBh6jFDXBjAYDIamYULHYDD0HiZ0DAZD72FCx2Aw9B4mdAwGQ+9hQsdgMPQeJnQMBkPvYULHYDD0HiZ0nRhLS8t6x8aOHat1O8RiMSZOnAiFQlHv3MaNG7Ft27Z2eY5CoYCvry9mzpzZLum1hcePH2PSpElwdXWFu7s7duzY0eB1MTExcHFxgZOTE8LCwtQ619BxqVSKCRMmQC6Xay5TegwTOj3jypUrGkubEAKlUlnv+P79+zFv3jwYGBho7NkAsGPHDri6umr0GepiaGiIL7/8Enfu3MHVq1cRHh6O1NTUOtcoFAqsWbMGv/32G1JTUxEVFcVf09i5xo4bGxsjICAAv/76qy6y2+lhQqdncF5eVlYWXF1d8cYbb8Dd3R1Tp06FWCwGABw4cAAjR46Ej48P3nzzTd4TmzNnDvz8/ODu7o49e/bUSWf16tUYNmwYHj9+XO+ZkZGRmD17Nv/+888/h4uLC6ZMmYJ79+61S76ys7Nx6tQprFixQq3r7927h/nz58Pb2xsvvvgivv/++3axg8PW1hbDhg0DAFhZWcHV1RU5OTl1rklISICTkxMcHR1hbGyMhQsXIjo6uslzTd0zZ84cREZGtms+ugqGujaAoTnS09MRFRWFvXv3Yv78+Th69Cj8/Pzw66+/Ij4+HkZGRli9ejUiIyOxdOlS7N+/Hz179oRYLMaIESMQFBQEgIrGjz/+iG+//bbeM6RSKTIzMzF48GAAwI0bN3Dw4EEkJiZCLpdj2LBh8PPzq3ff+PHjUVFRUe/4tm3bMGXKlHrH33nnHWzdurXBe55FLBZjy5YtOHDgAPbt2wd7e3vMmDGj2ftaahNHVlYWEhMTMWrUqDrHc3JyMHDgQP69nZ0d/vrrrybPNXWPh4cHrl271mw+GPVhQqfHODg4wMfHBwDg5+eHrKwslJaW4saNGxgxYgQAKgo2NjYAgJ07d+LYsWMAaBtUeno6+vXrB3t7e4wePbrBZxQWFqJHjx78+8uXL2Pu3LkwNzcHAMyaNavB+y5fvqx2Pk6ePAkbGxv4+fnhwoULzV4fGRmJJUuWwNjYGH369IFUKlXrOS2xiUMkEiEoKAjbt29Ht27d6pxrKF6GQCBo8lxT9xgYGMDY2BgVFRWwsrJqsa1dGSZ0eoyJiQm/b2BgALFYDEIIgoODERoaWufaCxcu4OzZs/jzzz9hbm4Of39/SCQSAICFhUWjzzAzM+Ov4+AKZlO0xHuKj4/HiRMncPr0aUgkEpSXl+O1117DgQMHGkw7OTkZc+fOBQDcvHkTq1atataeltoEADKZDEFBQVi8eDHmzZtX77ydnV2dqn52djb69+/f5Lmm7gGA6upqmJqaqpUfhgqE0WmxsLBo9NiDBw+Iu7s7f/yLL74gn3zyCbl9+zZxcnIiBQUFhBBCioqKSFZWFjl+/DiZOXMmIYSQO3fuEBMTExIXF1cvnYaws7MjYrGYEELIjRs3iKenJ6mqqiLl5eXEycmJfPHFF+2SX0IIiYuLIy+++CL/fvLkySQ7O7vONV9//TV5+PAhKSoqIh988AF/PDMzk0RFRZFPP/2UFBcXt8kOpVJJlixZQtauXdvoNTKZjDg4OJDMzExSXV1NvLy8SEpKSpPnmrqnsLCQPPfcc22yu6vCOiM6MVVVVbCzs+O3r776qtl73NzcsGnTJkydOhVeXl4IDAxEXl4epk+fDrlcDi8vL3z00UeNVlUbYurUqfjjjz8AAMOGDcOCBQvg4+ODoKAgjB8/vtX5aw6lUon79++jZ8+edY6vXr0af/zxB37//Xd8/vnn/PGdO3filVdegUAggLW1dZueHR8fj19++QXnz5+Hj48PfHx8cPr0aQDAjBkzkJubC0NDQ+zatQvTpk2Dq6sr5s+fD3d3dwBo9FxT98TFxanV1sioj4AQFniT0TYSExPx1Vdf4ZdfftHqc1NSUrB//361BB4A9u7di+eeew5XrlzBBx98oGHr2p958+YhNDQULi4uujal06EVj+7rr7+Gu7s7PDw8sGjRIkgkEhQXFyMwMBDOzs4IDAxESUkJf31oaCicnJzg4uKC2NhYbZjIaAO+vr6YNGlSgwOGNYmHh4faIgcAb7zxBm7fvo1+/fpp0CrNIJVKMWfOHCZyrUTjHl1OTg7GjRuH1NRUmJmZYf78+ZgxYwZSU1PRs2dPhISEICwsDCUlJdiyZQtSU1OxaNEiJCQkIDc3F1OmTEFaWprGB6MyGAz9RSsenVwuh1gshlwuR1VVFfr374/o6GgEBwcDAIKDg3H8+HEAQHR0NBYuXAgTExM4ODjAyckJCQkJ2jCTwWDoKRoXugEDBuD999/HoEGDYGtri+7du2Pq1KkoKCiAra0tADrK/MmTJwAaHkj57IhzBoPBaAkaF7qSkhJER0fjwYMHyM3NRWVlZaPjn4CmB1kyGAxGa9D4gOGzZ8/CwcEBffr0AUB7jq5cuYK+ffsiLy8Ptra2yMvL40fnNzdgUhUTExN+bqeFhUWD0Tz0FZFI1KXy+yxdOf9dLe8ikQiVlZX8fnV1dcsT0fRAvatXrxI3NzdSWVlJlEolWbp0Kdm5cyd5//33SWhoKCGEkNDQULJ+/XpCCCEpKSnEy8uLSCQSkpmZSRwcHIhcLm8w7Z49e2ra/A7Lu+++q2sTdEpXzn9Xzntry7zGPbpRo0bh5ZdfxrBhw2BoaAhfX1+sXLkSIpEI8+fPx759+zBo0CAcPnwYAODu7o758+fDzc0NhoaGCA8PZz2uDAajTXTqAcODBg3Co0ePdG2GToiNjcW0adN0bYbO6Mr578p5b22Z79RC5+bmVi/YIYPB0F9aW+bZXFcGg6H3MKFjMBh6DxM6BoOh9zChYzAYeg8TOg2RnZ2N2bNnw9nZGUOGDMHatWvVDundFM0tH/j555/z8dEMDAz4/Z07d+LevXvw9/eHj48PXF1dsXLlyjbbw2B0BpjQaQBCCObNm4c5c+YgPT0daWlpEIlE2LBhQ53rNLFG54YNG5CUlISkpCSYmZnx+2+//TbefvttvPvuu0hKSsKdO3fw1ltvtfvzGYyOCFszQgOcP38epqameP311wHQ9Rq+/vprODg4wMHBAXFxcZBIJKisrMSJEycwe/ZslJSUQCaTYdOmTfzSgT///DO2bdsGgUAALy+veoEtMzIysGbNGjx9+hTm5uZ8YMnGyMvLg52dHf/e09NTA7lndCXu37+PjIwMAEB+fj4f62/IkCFwcnJq92dwU8FaTPtNzmiYu3fvEm9vb36zsrIiX3/9NSkqKiJTpkwhTk5OZMqUKXVi+G/evJkMGTKEDB06lMTExDSatqurq6bNbxU7duwg77zzTr3jPj4+ZMeOHWTAgAGkqKiIEELXDigrKyOEEPL06VMyZMgQolQqSUpKChk6dCh5+vQpIYTw13/yySf8GgyTJ08maWlphBA61W7SpEl1nvfsmhL79+8n3bp1I9OnTydfffUVKSkpab9MMzoU6enpJCYmhsTExJCffvqJ309PT9fYM3ft2qWxtDlaW+Y17tG5uLggKSkJAF2dfMCAAZg7dy7CwsIQEBDAB94MCwvjA28ePHgQt2/fbvfAm88DKGn2qvpYA4hvwfWEkAYjrnDHAwMD+XUOCCH48MMPcenSJQiFQuTk5KCgoADnz5/Hyy+/jN69ewNAvXURRCIRrly5gldeeYU/1txk59dffx3Tpk1DTEwMoqOjsXv3biQnJ9dZLYyhebThBTk5OfFphYeHd9mZFBxarbqeO3cOQ4YMgb29PaKjo/k1OoODg+Hv748tW7Y0GnhzzJgxbX5+S8SqLbi7u+Po0aN1jpWXl+Px48cwMDCos3xgZGQknj59ihs3bsDIyAiDBw+GRCJpVCw5lEolevTowf+JqEv//v2xfPlyLF++HB4eHkhJSWlwgemOiLarSUyE9AetdkYcPHgQixYtAgC9DrwZEBCAqqoq/PzzzwCoJ/vee+9h2bJl/MLOHGVlZbCxsYGRkRHi4uLw8OFDPo1Dhw6hqKgIAFBcXFznvm7dusHBwYEPhkAIQXJycpN2xcTEQCaTAaCFuKioCAMGDGhzfu/fv4/Y2FjExsYiIiKC379//36b01bFyckJ06ZNw7Rp0yASifj99hIgbT2DoX205tFJpVKcOHGi3sLJz0JaEHhTJBJh3bp1AMD/IDsCAoEAx44dw+rVq/HZZ59BqVRixowZ2Lx5M6Kioupcu3jxYrz00ksYPnw4fHx8+M4Ed3d3bNiwARMnToSBgQF8fX3x008/1bk3MjISq1atwqZNmyCTybBw4UJ4e3vXuUbVQ9m+fTtWrFgBY2NjmJiY4IsvvmiXhWKYh8JoD7iyr1QqUV1dDalUiurqapw7dw4XLlyAUqmESCRqVdpaE7rffvsNw4YNQ9++fQGgXQJvWlpatmgVKG0ycOBA/Pe//613fNmyZVi2bBn/vnfv3vjzzz8bTCM4OJhfV4Nj48aN/L6DgwNiYmIatYH7UXAidP/+/SavZzCUSiUA6phwW3V1NZRKJQghUCqVkMvldTaZTAaZTIaqqiqcPXsWMpmMP65UKvl05HI5CCGQyWQNOjQAdRKEQiFMTEz4P2QzMzO88MILMDY2xpUrV1qVL60JXVRUFF9tBYBZs2YhIiICISEhiIiI4IdUzJo1C6+++irWrVuH3NxcpKenY+TIkdoyU6tooz2I0fFRKpW8OHCCIpVKIZPJoFAo+GNCoRCEEMjlckilUigUinqi09BWUVGBX3/9td5xpVLJCxsH9wxOZIyNjWFsbAwDAwMIBAIIBAIYGhrym5GREYyMjGBmZgYDAwPY2dnxxwwNDWFgYMCnYWhoCIFAACMjo1Yvj7B+/fpW3acVoauqqsKZM2ewe/du/lhISEiXD7zJqnyahxACQggUCgW//6yIGBgY8AWcu5bzUjIyMiCXy6FQKOp4Jo15NVy6z6bFPQugXgvn0ZSUlGD37t28MAiFQggEAhgbG8PIyIi3jcsLJzTcOVXRMTc358+pHs/KykJAQECdY6rPaq81Wa5cudLkOE5dohWhMzc35xvVOXr16oVz5841eP2GDRvqzSJgdGy4Qq1UKlFZWcmLAycE3P6zrzKZrI6ANOSpcMKhVCr5Z5SUlOC7776DUqnkC2pj1SGhUMhvDYmIqggJhUIYGBjAyMgI1dXVSEtL4z0TExMTGBkZwdTUtI5Hw+03JE5cWqrHVAkPD8eqVas09K1QDA0N+WFKXRU2M6ILQQiBSCSCWCyGWCyGRCLh21Ge9Uq4qpTqcalUColEAqlU2qAXYGBggPLychw+fJgXB+5V1ft41hMxNTVF9+7d63kqqtUfru2GE4y9e/fizTffbFeP5Fmys7PxwgsvaCRthnZhQtdJqa6uRkVFBSorK1FVVYXKykr+fXV1NSQSCRQKBd97BQClpaU4evQozMzMYGpqCjMzM74Kw7WrWFhY8ALDiQ7nqXBtMU21sYSHh9fpbNEUnPAxGOrAhK6DoVAo+OXdRCIRKioqUFpaioqKCpSXl0MkEvGNxd26dYO5uTnMzc1hYWEBGxsbWFhYwNTUFKampnWqWwKBAOHh4fV6cRmMrgATunamqKgIAQEBAGhPqoGBAb+m7dy5c3Ho0CEIhUIolUp8+OGHGDhwIEpKSlBWVobw8HAIhUJYWlrC0tISFhYWsLKyQv/+/dGtWzdYWVnB0tKSeTKMLkV7TOpnQtfO9OrVi5+WtXHjRlhaWuLdd99FdHQ0/vd//5cPjcR5Xj169ICDgwMePXqE1atXa6y9idG1UBUHS0tLxMbGAmj/oUvaeI7q6ATV6ZMtgQmdhpBIJCgoKEBGRga+++47ZGdnw8bGBsuWLYOZmVm967keQYb+o21x0CTaek5bYULXAK0dyFtRUYG0tDTcu3cPZWVlqKyshIODA9asWYPKykqMGzcO3t7emDJlChYsWICJEydqJT/6gjYEQp9EiFGLVoSutLQUK1asQEpKCgQCAfbv3w8XFxcsWLAAWVlZGDx4MA4dOgRra2sAQGhoKPbt2wcDAwPs3Lmz3QbSPv88UKJWnCanmg0oKSmGo2NPxDcS+qSyshIJCQlIT0+HUCiEi4sLAgMD0bt3bxQUFMDS0hICgQCWlpa4ceMGLl++jLi4OCxYsABhYWFa6aHUNNqqJmlDIJgIdTxOnQKOHgXKy4GCgtaloRWhW7t2LaZPn44jR45AKpWiqqoKmzdv1no8usbEqinCw6OwZs2aeseLi4tx8+ZNpKWlYeTIkViyZEmDVVJVDAwM4O/vD39/f3h6eiIiIkLjQsc8FEZnoagI+PNPIDkZyMykW34+YGgIDBoEODgANVPlW4zGha68vByXLl3iI29w8950EY+uPcjKysLly5chl8vh4+ODlStXwtCw+Y/x3r17EAqFcHZ2BgAkJSXB3t5e0+YyEWJ0aKqqgJ07gcOHAQMDYOxYYNgwwN8fcHSkwnbmDFDz/9xxPbrMzEz06dMHr7/+OpKTk+Hn54cdO3Y0GY9u9OjR/P0dJR5dbm4u4uLiIBQKMWXKFN52dRGJRHjrrbdQWloKQ0NDODk5Yc+ePRqylsHo+Ny5AyxYACxaBJw9C9S0XNVj2jS6AUBrg+9oXOjkcjlu3ryJb775BqNGjcLatWsRFhbW6PUtiUenDZRKJaKjo1FSUoLJkydj0KBBat+rGlLJz8+vXoiZ+/fv48aNGwA027bFYHREPvgACA8Hxo/X/LM0LnR2dnaws7PDqFGjAAAvv/wywsLC2iUenaYDb1ZVVaGsrAyDBg3CrFmz2l1wWbWS0VUhBLh7Fxg3rvlruYjVAFodeFNAGgv50I6MHz8eP/zwA1xcXLBx40Z+dHOvXr34zoji4mJs3boVt2/fxquvvoqEhATk5uYiICAA6enpDXZGuLm5ITU1VWN2R0dH4/79+3jvvfc09gwGQ1+prgZu3wYSE2nHQkkJ7VxITwfkcipye/e2LM3Wlnmt9Lp+8803WLx4MaRSKRwdHfHjjz9CqVR26Hh0eXl5KC4uZitkMRgtID2dDgU5cQKoqAA8PAAfH8DPD+jZE7CxAZycAGNj7dqlFY9OU2jKoyOE4Oeff0ZAQACio6MbHF7CYDBqIQR45x3g+nVgyRLgpZeAdlh3qR4d2qPrbNy9exdWVlZ1VrVnMBiNExMD5OYCf/wBdMSZjEzonkEul+PChQt49dVXdW0Kg9HhiY2l2x9/AGIxwDVnqw4J6QgwoXuGhIQEuLi4oHv37m1K59ixY5g3bx7u3LnTYBx9f39/bNu2DcOHD2/w/rlz5+LBgwcQiUR4+vQpHBwcAADffvstiouL8dFHH/GLqqxduxZvvvlmm+xlMJqjuhpITQVu3qRV1JwcIDubCpy5OSCRAB10UT4mdKpUVVUhMTERAQEBfHd2a8e3RUVFYdy4cTh48GCd8XTqcuzYMQDAhQsXsG3bNpw8eRIAIJPJYG9vj4SEBNjZ2aG6uhpZWVktTp/BUIe8PDpz4cwZKmQeHoCXFzB/PmBnR9vhuDXZ3dx0a2tTMKFT4eLFixgzZgyee+65Nq1mJBKJEB8fj7i4OMyaNQsbN26EWCzG66+/jtTUVLi6ukIsFvPXr1q1CteuXYNYLMbLL7+MTz/9tNG0KyoqIJfL0atXLwCAiYkJXFxcWm0rg9EQ1dXAZ58B0dHAu+8CISFAQ5UcruoKAP36ATXDWlnVtaNSVlaGhw8ftsug4+PHj2P69OkYOnQoevbsiZs3b+LChQswNzfHrVu3cOvWLQwbNoy//vPPP0fPnj2hUCgQEBCAW7duwcvLq8G0e/bsiVmzZsHe3h4BAQGYOXMmFi1axKIOM9qVhQsBX1/gxo2mh4J0NEFrjK4ldE3EaRKKRFhmZAThzp31T1pbtyj0SVRUFN555x0AwMKFCxEVFYX09HS8/fbbAAAvL686Qnbo0CHs2bMHcrkceXl5SE1NbVToAOCHH37A33//jbNnz2Lbtm04c+YMHzSBwWgreXl08vzHH+vakvajawldI2JVVlaGgwcPYuXKlW3uGy8qKsL58+f52HsKhQICgQC+vr4NTiF78OABtm3bhmvXrsHa2hrLli2DRCJp9jmenp7w9PTEkiVL4ODgwISO0SqKi+kg3ydPgMePaQfDjRvUJ9AntFLfGTx4MDw9PeHj48P3MhYXFyMwMBDOzs4IDAxEiYqnFRoaCicnJ7i4uPAdAZokPj4eY8eObZe5rEeOHMHSpUvx8OFDZGVl4fHjx3BwcMCwYcMQGRkJAEhJScGtW7cA0DBWFhYW6N69OwoKCvDbb781mb5IJOLDWwHaC/fE0A/y84FvvgFeeQXw9ARmzAC++w64fBlQKGiIpM8/p+1z+oTWPLq4uLg6q4WHhYVpPfBmQ1RUVODhw4eYPn16u6QXFRWFkJCQOseCgoKQmJgIsVgMLy8v+Pj4YOTIkQAAb29v+Pr6wt3dHY6Ojni+mb9SQgi2bt2KN998E2ZmZrCwsGDeHKNZrl4FNmyg07Lmzwf+938BFxfA1FTXlmkJogXs7e3J06dP6xwbOnQoyc3NJYQQkpubS4YOHUoIIWTz5s1k8+bN/HVTp04lV65caTBdV1fXNtsWExNDEhMT25wOg9FR+esvQry8CLl1S9eWtJ3WlnmtVF0FAgGmTp0KPz8/PthkU4E3Bw4cyN+rycCblZWVyMjIgKenp0bSZzA6Ap99BuzfT6uqXRWtVF3j4+PRv39/PHnyBIGBgU2OUSNaDLx59epVjBw5UifRURgMTRITAxw/TheUOXuWRgyJjOw8w0HaG60IHRc408bGBnPnzkVCQoLOA2+KxWLcvXuXTZ1idGpKS2mst6Qk4No1OjWLW8y+d2+6oIy1NfD117q0sm10isCblZWVUCqVsLKyQmVlJQIDA/Hxxx/j3LlzOg28efHiRZiYmNRZn4LB6AwolbQquncv7Sl1dqbV0lGjgOHD6QwG1RkLSUk0JhzQ+T26Vpd5dRvztm/frtaxZ8nIyCBeXl7Ey8uLuLm5kU2bNhFCCCksLCSTJ08mTk5OZPLkyaSoqIi/Z9OmTcTR0ZEMHTqUnD59utG0W9swKZFIyK5du4hUKm3V/QyGrpDJCAkIIGT1akLy83VtjfZpbZlX26MbNmwYbt68WeeYr68vEhMTW66u7URr1f3KlStQKpUYp07AegajA3H0KHDhAh0L1xVpbZlvttc1KioKL730Eh48eIBZs2bx26RJk/iJ5Z0JhUKBxMTERsMjtQcCgQBLlizh38vlcvTp0wczZ85s8r6kpCScPn26yWtiY2Ph4+MDHx8fWFpawsXFBT4+Pli6dCmqqqqwePFieHp6wsPDA+PGjWt1mwajYyGV0qlZsbHAhAm6tqbz0WxnxNixY2Fra4vCwsI6i8RYWVk1OR+zo5KamgpHR0eYanCkpIWFBVJSUiAWi2FmZoYzZ85ggBpxpZOSknD9+nXMmDGj0WtUO12ejWkXGhqKvn374u+//wZAF802MjJqhxwxtIVcTheUuXyZzli8c4dGEjE2pp0LVlZM6FpDsx6dvb09/P398eeff2Lw4MGQyWSYOHFivVBDnYVr167xSy9qkhdeeAGnTp0CQL3iRYsW8ecqKyuxfPlyjBgxAr6+voiOjoZUKsXHH3+MX3/9FT4+Pvj111+RkJCAsWPHwtfXF2PHjsW9e/eafGZeXl4dQXVxcWGL+3QCUlPpBPoJE2inwqefUsF77z06o+HOHSA5GTh3jg4Z6dtX1xZ3QtRtzNuzZw8ZPnw4cXR0JIQQkpaWRiZPntyqhsH2oqUNk7m5ueTAgQMasqYWCwsLkpycTIKCgohYLCbe3t4kLi6OvPjii4QQQv71r3+RX375hRBCSElJCXF2diYikYj8+OOPZM2aNXw6ZWVlRCaTEUIIOXPmDJk3b16d50ycOJFcu3aNf5+YmEj69OlDRo8eTTZs2EDS0tI0nVVGG/n2W0JGjiTk558Jyc7WtTUdn9Z2Rqg9ji48PBwJCQm8N+Ts7MzPZugs/Oc//4FQKER4eHiL7jMzM8Py5ctbdI+XlxeysrIQFRVVryr6+++/48SJE9i2bRsAQCKR4NGjR/XSKCsrQ3BwMNLT0yEQCCCTyZp8po+PDzIzM/H777/j7NmzGDFiBP7880+4urq2yHaGdpBKge3b6fAPMzNdW6PfqC10JiYmMFaJwCeXyzU2Y0FTdOvWDa+99hrMtPSrmjVrFt5//31cuHABRUVF/HFCCI4ePVovMvBff/1V5/1HH32ESZMm4dixY8jKyoK/v3+zz7S0tMS8efMwb948CIVCnD59mgldB4IQOkPh+HGgsJCGSdqwgZ7r7GPcOjJqC93EiROxefNmiMVinDlzBt9++y1eeuklTdrWrlRXV0OpVGpN5ABg+fLl6N69Ozw9PeuEVpo2bRq++eYbfPPNNxAIBEhMTISvry+srKxQUVHBX1dWVsa3uakToSQ+Ph5ubm6wtraGVCpFamqqWuLI0AxSKW1bu3yZtrVlZtJZCwMG0Mghnp5AVlbHXVBGn1B7Uv+WLVvQp08feHp6Yvfu3ZgxYwY2bdqkSdvalZycHLV6PtsTOzs7rF27tt7xjz76CDKZDF5eXvDw8MBHH30EAJg0aRJSU1P5zoh//vOf+Ne//oXnn38eCoWi2edlZGRg4sSJ8PT0hK+vL4YPH46goKB2zxejcRQK4MgR4MUXAW9vOvXK1BT48EMgLo52LKxfD5iYAGVlgKMjXWdh3bramQwMDaBOQ55CoSDu7u6tagTkkMvlxMfHh2+QLyoqIlOmTCFOTk5kypQppLi4mL928+bNZMiQIWTo0KEkJiam0TRb0jB54cIFkpSU1PoMMBjNUFpKiL8/IStX6kdIpI6IRsM0CYVCeHt7N9hgri47duyo01bEBd5MT09HQEAAwsLCAKBO4M2YmBisXr1aLW+mObKzs+uEf2Iw2putW4HZs4Hdu7t2SKSOiNpV17y8PLi7uyMgIKDODAl1yM7OxqlTp7BixQr+WHR0NIKDgwEAwcHBOH78OH984cKFMDExgYODA5ycnJCQkNCCLNWHEILi4mJYW1u3KR0GozEUCuDSJUBluCSjA6F2Z8Qnn3zS6oe888472Lp1a52G9qYCb6pGFGmPwJtFRUXo3bt3p+slZnQ8KiqAlBTg1i3g77/p9uQJYGgIuLqywbwdlRb1uraGkydPwsbGBn5+fnV6HhuDtCDwprrx6LKzs7XeEcHQD3JygGPH6Er16el0VXoPD1o1nTWLDg3p16/Ni8cxmqA94tGpLXRWVlb1BKd79+4YPnw4vvzySzg6OjZ4X3x8PE6cOIHTp09DIpGgvLwcr732WrsE3rS0tMRXavTNZ2dnw83NTd2sMhgAgEOHaBjypUuB0FA6JIQFo9Y+qk5MTExMq9JQu41u3bp1+OKLL5CTk4Ps7Gxs27YNb7zxBhYuXNjkrIHQ0FBkZ2cjKysLBw8exOTJk3HgwAHMmjULERERAICIiAjMnj0bAB1ke/DgQVRXV+PBgwdIT0/nV8xqLbm5ucyjY7SItDQqbpcu0eEgbm5M5Dozant0MTExdUbur1y5EqNHj8bHH3+MzZs3t/jBISEhmD9/Pvbt24dBgwbh8OHDAAB3d3fMnz8fbm5uMDQ0RHh4eJvWdJBKpVAqlWxyO0MtTp8GDh+m7XCVlbXrm7JZC50btYVOKBTi0KFDePnllwHQhZo51G3k9/f350fq9+rVC+fOnWvwug0bNmADNy+mjeTl5TVa9WV0XaqraUdCUhJ9vX2bxnsD6CDeYcOA8+fZrAV9QW2hi4yMxNq1a7F69WoIBAKMHj0aBw4cgFgsxq5duzRpY5tgHREMDoUCOHkS+PZbIDubzlzw9QUCA4F//pN2Kpw9WztDYeBAOmMBYB5dZ0fji+NoEnXCKh85cgTjxo1Dv379tGQVoyOSmgosXkwXj3n7bTagt7OisVDqHGlpaQgICICHhwcA4NatW51iruuTJ0/Qp08fXZvB0DErVwLff09XzmIi1/VQW+jeeOMNhIaG8qG5vby8cPDgQY0Z1h6IxWIYGxuzBaq7OCIRIBbT5QAZXRO12+iqqqrqDfMwNNTK+tetJi8vj1VZuxh5ebRz4do1GiKpqAh49AjoRBHFGBpAbaXq3bs3MjIy+B7WI0eO8FO4Oir5+fkd3kZG28jMpGGRrlwB7t6lU7Dc3an3NnMm0KcPXameRfDt2rQolPrKlStx9+5dDBgwAA4ODoiMjNSkbW0mPz+/zrxZhv6QkwO8+y711pYuBTZvZjMXGI2jdhudo6Mjzp49i6dPn+Lu3bu4cOEC/vjjj2bvk0gkGDlyJLy9veHu7s4HByguLkZgYCCcnZ0RGBiIkpIS/p7Q0FA4OTnBxcWFn+PWGgoKCvipZQz9ISMDmDoVWLIE+PNPYPVqNnOB0TTNCl15eTlCQ0Pxj3/8A2fOnIG5uTkiIiLg5OSEQ4cONfsAExMTnD9/HsnJyUhKSkJMTAyuXr2q8Xh0UqkUQqGww7cjMlrON98A//43bXdjk+kZ6tCsCixZsgTW1tYYM2YM9u7di61bt0IqleL48ePw8fFp9gECgQCWlpYAAJlMBplMBoFAgOjoaD6aSXBwMPz9/bFly5ZG49GNGTOmRRkrKChAXxYzR6+IiaGLykRH086G+Hh6nA3mZTRHs0KXmZnJr/y+YsUK9O7dG48ePYKVlZXaD1EoFPDz88P9+/exZs0ajBo1SuPx6PLz81mPayeEEOD+fbplZtJqamYmXUSmupp2NixYQGcvsOlZDHVpVui4cXMAYGBgAAcHhxaJHHdfUlISSktLMXfuXKSkpDR6bUvi0TVFXl4evLy8WnwfQzdcvgz8/DN9HTKEdiw4OgJTptD39vbAxYu107Nsbdn0LIb6NCt0ycnJ6NatGwAqQmKxGN26dQMhBAKBAOXl5Wo/rEePHvD390dMTEy7xKNrKvBmQUEB8+g6Cdu20SrpJ58Au3bRFbIaggla16Q9Am+qtQpYW3jy5AkpKSkhhBBSVVVFxo0bR/773/+S999/n4SGhhJCCAkNDSXr168nhBCSkpJCvLy8iEQiIZmZmcTBwYHI5fIG025sRSC5XE7Cw8PbPzOMdufOHULGjiVEItG1JYzOQGtXAdN4l2ReXh6Cg4OhUCigVCoxf/58zJw5E2PGjNFYPLrCwkI2v7UTQAiNFvLii417cQxGe6CX0UuSkpJQUVGB8ePH68AqxrMQAjx8SGcupKfXxn8rKgJ69KCT7dXowGcwWh29RC8HmeXl5cHJyUnXZnRZCKFhkc6epUNAkpOBQYPo1KwhQ2i4JDc3Oj2LwdAGeil0+fn5zJvTEenpwGuvAb17046DkBDAy4suB8hg6Aq9+/kRQlBZWckPUmZol5Urga+/BsaO1bUlDEYtas917SwwkdMd1dVAQQETOUbHQ+88uqdPn7IeVw2iVNKZCnfv0tfMTODqVTqTAQAsLdlAXkbHQy+Frnfv3ro2Q69ISwOioqigZWbSGQvu7vR1+nQamvzWLRo9JClJ19YyGPXRS6FzdXXVtRl6gVhMOxaKimhIpB07AGdnFjGE0fnQO6Fjg4Xbjz17AFdXoBOsgcRgNInGOyMeP36MSZMmwdXVFe7u7tixYwcAzQXerKioYJ0R7YBSSSfRv/KKri1hMNqOxoXO0NAQX375Je7cuYOrV68iPDwcqampGgm8WVVVBTMzs1ZFO+nKVFbSSL0//gj84x/AmDF0QK9QCDz3nK6tYzDajsarrra2tnzcOSsrK7i6uiInJ0cjgTdZj6t6VFcDly4Bp08DcXH0mLc3rabOmkWj9/bsqVsbGYz2RKttdFlZWUhMTNRY4E3WPtc0Uimwbx8NRT5+PPDCC1TUWhhekMHodGhN6EQiEYKCgrB9+3Y+vl1DNBRjQN2q6NOnT9kc10aQy4HJk+lg3j/+YB4bo2uhFaGTyWQICgrC4sWLMW/ePADQSODNp0+fsuUNGyE5GejfH9i6VdeWMBgtoz0Cb2o8TBMhBMHBwejZsye2b9/OH1+/fj169eqFkJAQhIWFobi4GFu3bsXt27fx6quvIiEhAbm5uXyHRUMx6Z4N2bJr1y6sWbOmy3dGSCR0jYXMTBp6/K+/gNxcwNiYtsEBbNYCo3PSYcM0xcfH45dffoGnpye/atjmzZsREhLSroE3q6urYWJi0uVETi4Hzp+nvabJyXRqlrExMHgwDYkkkdBIIg4OQH6+rq1lMHSD3gTezM7OxvXr1zFnzhzdGqVFIiKAL74ARo+m7W/e3nRRGRYSiaGvdFiPTlt0tTmuERHA4cN0eAjraGYwmkZvhK6wsBADBw7UtRlaY/t24Nw51nvKYKiD3ghdcXEx3waoj1RV0Q6Ghw+BBw+AigomcgyGuuiN0JWUlMDa2lrXZrQZuRy4fp2GPbpzh3YuZGUBpqa0Q8Henm5RUbq2lMHoPOiF0BFCoFAoYNiJW+EJoe1uW7cCvr7AsGF0lfq33qLC1sIVHxkMhgqdVxlUqKyshIWFha7NaDVyORAcTCOGxMcDeuCYMhgdCr1YM6K4uLhTV1sjI6m4/ec/TOQYDE2gFx5dSUkJenaylnmZDMjLA0pLgeho4O23WeReBkNTaEXoli9fjpMnT8LGxgYpKSkAqBe2YMECZGVlYfDgwTh06BDvlYWGhmLfvn0wMDDAzp07Ma2ZuUrFxcUdOmpJRgYNYnnnDnDvHp2aBQAmJoBIRKOHbNxI2+UANj2LwWhvtCJ0y5Ytwz/+8Q8sXbqUP8YF3uTmuoaFhWHLli11Am/m5uZiypQpSEtLa3IaWElJCVxcXLSRFbXJzwe2baNzTfv1ozMXxo8HVqygi8oYGdFzXABltqgMo1Py7I+YG+LV0L+1TEYbpM3M6HuxuHY/J4dGnRAI6Nipqiqgb1967scfgb//pvsFBa2zk2iJBw8eEHd3d/790KFDSW5uLiGEkNzcXDJ06FBCCCGbN28mmzdv5q+bOnUquXLlSoNpurq6EkII2bt3L6mqqtKU6S3mxx8JcXMj5KefCBGJdG0No8sgkxHClYOYGEJef52Qd98lZNIkQhYuJOTtt+nxggJCkpJq7ztzpnb/3DlCqqvpfnY2IfHxteciImr3f/yx9lnp6YScOEFITXkkYWG11+3YUfe62Ni65zgOHqx97sOHhFy9WnvuyBF+lyvzLUVnbXTtGXhTIpHAjPtn0DGlpcCWLXQsXCfuCGY0hFIJKBTUHQeo296vH91PS6ORFIyN6Y8gJ4euCQkAv/1Go5wCwIkTdCzRxYtAeTmQkEDHEQE09HN4ON3/5RdgzhzarpGZSX9Q8+fTc1u2AB98QPe/+w5YvBjo1g3IzgZSUoCZM6k3JRIBQUE0Ln5YGB23ZGRE7VP9cfboUbvft29tY3GPHjSePkdgYO1+UBBtewFqB3hyNnGvAG185nByoltD5xYsqN0fNIhuHKqLBbfSo+twnRGkBYE3RSIR1q5di9TUVDg7OzfblqdJlErg0SPagzp+PBM5raJU1hbI0lIqDgYGtPpTUEALIlC3anXhAuDnR6998oSemzqVVsM4UUhKouk4OVHRcXOjYWI4wYmNpeOCACoy/ftToeNs4hgwoHbfzw+wsQFmz6bVOA8P4Kuv6DnVWGtz5wLm5nTfwYG2d3CoCsmqVbX7gwfTjbMtPp5u/foBBw/SjatSqorb8OG1+5w4A/RHLBQC3CR6iYROxzExoZ9bSgrw2Wc0DphQCJSU0PwBVDB9fennMH06MHEiPX7vHl2YRCaj7yMiqEhLpcDu3cCRI/TPxNER+PRTQCZD7NGjiD1wAJDLIeLEtYXoTOjaI/CmpaUlQkJCcOXKFa2KXGUlcPYs/ZO9exdIT6ff08CBNHrI//t/WjOlY9BcO41SST8gU1N6/MkTWtgB2vXMFZ7KStpz4+VFzx0/TgUGAE6epMJ19Sp9vXSJFiCAekY//ED3z5+nhapXL+ohZWfXCp2qN2BnV+uZ9ehR1+YJE2jbkZtbbSHnUJ1PzYkcQBthOXr0qCskXH4AKnqqn1f//rXeimq7lqUlzWdZGW3LAuqK3YULVNSrq6k4eXjUfrY//ADcvk29TE54APr++nXg229p/sPDa73UWbPoFBylEli9mgqtREK/jy+/pMcJod6jiQk9l5hIf/wAFTqRiKYll1OPtrSUCtqlS/R8dTXNU3U19RoJod+vmRn9bQiF9PMwMaF/GF99BRgbY9rff2OahQUgECCmogKtQWthmrKysjBz5ky+17W9Am8eOXIE+fn5mKz6Q9MApaXAf/9Lax63b9M//7Fj6SpZzs61baodjqZEaPLk2sJeVkYzYWxMf6h5ebWFOiEBGDmS7l+9SgPd9elDP5RTp+iPH6BVqogIKg5RUcDzz9MqSHExvW7JEnrd/v3A8uV0/9w5wNOTCl9VFf1wR4yg5+7do/8cAE3D0pLaRwgVoTt3tPt5NfdnWlFBP7eyMlpoVUXm55+Bx4+pGFhYAIWF9HP+6y9aFZDJaAH//nv6WUgkVNzPn6dxt2xsgEWLqEjIZNRGkYgKhoMDFVCZjFanuXmDRUXUDomkNnaXmRn9ExAI6HcvFFKvVfVVIKADOk1MajcDAxrY0MKiVphMTOg//s2b9L6CAsDWlu5PmQKsWUOvMTWt3UxMWh5HTOU7cYuIQGpRUcvuh5aEbtGiRbhw4QIKCwvRt29ffPrpp5gzZw7mz5+PR48e8YE3ubFwn3/+Ofbv3w9DQ0Ns374dL3DtG8/g5uaGPXv2wMLCAr6+vhqxXamkf4DffkubJV56iZZDnYx5q6ysrRPfv09/sNbW9Id87hzw4ov03A8/0O5dgBYWV1cqTs89R398b71Fz335JfDee3T/99/p+UGDqAdx5kxtOOK4OGDSJLr/6BF9ppUV/XCqqqgAcTTkBbUXTYnQ1KlUOCor6ZfTvTs9V1UFXL5M81RVRfNoZESv/eMPWlArK6mALl1KvZRbt+hWVFQrMuPG0c+7sJD+43HFJiCAfhac9/PoES3ohob0z6C6ml5XXk7vEQrp88TiWi/H1JQKiZ0dzRMnCEIhtVVVcExMagXK0JDabWRUu3XrRr3JxET6p2RsTIVPT8YutTYeXacPvLllyxZ4eXnB3t5eI8/Yvh24do22+Taxpk/L4QpgbCz1Vh49oj/yoiLa6Pvaa1RIdu+ubYf55ptakbp9m1b5bG1pAcrIqG3oLSyk/74ArTIaGNCtLSIkk9HCKZXSAsUJiUJBp3TExVE7HjyoLVQjRlCvUCKh56ZMqd0/coRWb5RKKj6entTujAxapVIoqAjMmUPzKZFQrygtjaatVFIblEoqQOXltSLXo0ftFBOFolawjIyoh9izJ/08ZDK6mZtTsRowgIrf7ds03ZIS+jkaGlKPdvlyKjQWFjQtrkpuaFjXc+H2uSqYaoM+0DavsYvTZYUuJCQEc+bMaXJlsbYwahRd/7RXr0YuqKqir1zDcWIibYQFqAC8+irdv3SJ/vi5KqCqaEVHA//6FxWhnBxaOLgB0OXlbVPYZwuVpyetQjk70/aQqVNpwVcoqPBGRFBREQppG0lZGa0ibd1K7xMIaBoeHlQIxGLg11/pPQAVMXNzKgImJrWej4EBzZOZGU2jpIR6VUIhFazBg6moWFvT55mY0HR696Yeo6kprf5ev07vyc+nIioU0l7GDz+kaXNV8fb6vJgIdSi6rNCtWbMGq1evbvNaEaWl9HedlQU83BML+9TfoJArUS0hcPM2Qu/SDEiWr8bwDdPqdu8nJVGR4NpjYmNrC8SjR7Xd5ApFbfsHhzqFSqmkhTo/nwoNJyIVFdTzuHiRtgtJpbUek0RCqy1FRfQ4IVQAOO9DLqdC0r07rZZZW1MhEotrh0+YmFCR6d6dejDcZm5OBcXaunb4wdGjtOosEFChtrenx+fOBT76iIVeYbQbXVbo3nrrLaxS7WJXk5wc2qmXHXsbJx+4w8wMeMt0L3IDg1FNjFF5/Q76KXORFpcNszeD0bcoFT6vurXsT10upwpaXEy37GzagP7kCfVocnKoF6dQ0PcCARUxM7PaYQKEUME0NqYiM2wYbW+zsqLVrtJSYOhQ2p0/cCD1fLjGYlNT2rh4+jRNKyuL9twJBMC8ecCGDS3+3BgMXdIl14xQKBToodqNrwZPH4jwn5Bb2HdnLJYtA4LHZ+KTQ+505INoEWBhBPweC5TWeFpVSQCSgV4AMA0oG03boc6fpx5VQQEVqh49qAdVXEy73OXy2vFAzs60elhdTYWte3daHbWxoV6agQH1wgYOpN7Uyy8DH3/cPh/S5s10YzC6MJ1e6NSKWlJRARQWori7AybNtMCml81wM5Lr5X6JXiOX0+u40e5z59KG77Q02nOZm0tfra2peInFdLOxoY38L7xAG/J69aLxzrl9Vm1jMHROpxe6RuPQ3bxJBYubKPzoEY5e74XPfGIxx+gesOsi9czy8+lQiqoqKkoDB9JqpOpYHW6M0aBBdDhCc7i6tk8GGQxGu9Dpha6OR3f2LB3vlJUFxMRAbNwdEglQdfcRLK6exZIHdyDo3h3IcQEWLqTjzvr2BXbtqh1ywGAw9I4OK3QxMTFYu3YtFAoFVqxYgZCQkHrXKJVKWNcMvSj76y7KvjwM2+kvQQ4DPBX2RUL3QOT3dIdy4POQjlsCi1WOeH2NOWCq7dwwGAxVCAA5AEXNPgEgeOYcd57blPWTUZsO2euqUCgwdOhQnDlzBnZ2dhgxYgSioqLg5uZW5zpbW1tcHzQcxXeKUU2McWfUMpjOmwGvgD5wdq4/TpPB6EjIAEhrNgAwqDlWXbNJal65ayQ1r5wAqApBQ/vqHuP2ZTX71TX7qoIjBBUaZc17ac1+Yc2mBFAFwBhUsCwAWDWTf8OaPDc0MMxI5XxpzSYAUOHmhiJ96XVNSEiAk5MTHGsmMS9cuBDR0dH1hE4iEsEwORnmB0/Cc44XhjeUmJ4SGxur02gtz6L6r0tQWyhUj7fnfkJsLHynTWvyGhkAMWjB5QonJxSqBV91ewQgpyYPJQB61OSvN4CeUE9EmvM8KkBFQVhjGzeBrhsAG1CxMAateJgCMAEt+KY1xx/FxsJ52jReCLhX1f0zAJJAxYETEgGA0QBeaeQe7tWkZoPKMYJaUTKssccAwAUAl2vycgsANxFzWs3WHsTWbACwVzXCSwvokEKXk5ODgSpRIuzs7PDXX3/Vu04mlcLqaSb6dus42SCoX+i5QiZE7Y/u2cKiuslB/70bO68AsDs2FuXTpvH/xE29ykG/aO5fV4q6hZ8TA8kzr9UqeVKtVjyLCLUFVwzAvOb6HqDiwBUoYRv3bwLIrEm7IjYW3WqE3hXAxAauNwJgBupZcIWTEw2uYD+7JQC4WnP/PQDP1eR5IoDJqC8ODe03V5FQLbhJAHxq9tUVh3Wxsfi8mT+5t9RIpz2YX7NpEtXPJaKyslVpdByFUEHdmHQCAkR0M+TdaBlogZOh7j98Q//6jQlMNYBsAE9rrheh9t/NErX/vrytDdhvoLJx/4DGqBU+7poyUK9BCPov371m3xaAPWoLZENbNoC/a67h3Hzu1Vxl/ySAa888VwBgAoDlKtdznoPqK1cNaY62FtzWsA7AVxpIdwSANRpIVxVNfi6MhumQQqduTDqpAPjfmkmoFhYWsLR8VoZaRyVqvZlnw/yp06DJCac6z1H9fyqreZUBaC4QjUgkwpGYGDWe0nDfy581myaIeeZVE4hEIsSomX99o6vlXSQSobLGkxO1suraITsj5HI5hg4dinPnzmHAgAEYMWIE/vOf/8BdNfopg8FgqEmH9OgMDQ2xa9cuTJs2DQqFAsuXL2cix2AwWk2H9OgYDAajPWEjzRgMht7TaYUuJiYGLi4ucHJyQlhYmK7N0SqDBw+Gp6cnfHx8MFx1BSc9ZPny5bCxsYEHt/gLgOLiYgQGBsLZ2RmBgYEoKSnRoYWapaH8b9y4EQMGDICPjw98fHxwmgvDpUc8fvwYkyZNgqurK9zd3bFjxw4AbfjuW7UarI6Ry+XE0dGRZGRkkOrqauLl5UVu376ta7O0hr29PXn69KmuzdAKFy9eJDdu3Kiz+Pn69etJaGgoIYSQ0NBQ8s9//lNX5mmchvL/ySefkC+++EKHVmme3NxccuPGDUIIIeXl5cTZ2Zncvn271d99p/ToVGdOGBsb8zMnGPrHhAkT6oXiio6ORnDNUoPBwcE4fvy4DizTDg3lvytga2uLYTVrj1hZWcHV1RU5OTmt/u47pdA1NHMiJydHhxZpF4FAgKlTp8LPzw979uzRtTlap6CgALa2tgBogXjy5ImOLdI+u3btgpeXF5YvX67XVXeALpWamJiIUaNGtfq775RCR9ScOaGvxMfH4+bNm/jtt98QHh6OS5cu6dokhhZZtWoVMjIykJSUBFtbW7zHLVmph4hEIgQFBWH79u1tWgCrUwqdujMn9BUurzY2Npg7dy4SEhJ0bJF26du3L/Ly8gAAeXl5sLGx0bFF2qVv374wMDCAUCjEG2+8obffv0wmQ1BQEBYvXox58+YBaP133ymFbsSIEUhPT8eDBw8glUpx8OBBzOIWW9ZzKisrUVFRwe///vvvdXrkugKzZs1CREQEACAiIgKzZ8/WsUXahSvoAHDs2DG9/P4JIfif//kfuLq6Yt26dfzxVn/3Guo00TinTp0izs7OxNHRkWzatEnX5miNjIwM4uXlRby8vIibm5ve533hwoWkX79+xNDQkAwYMID88MMPpLCwkEyePJk4OTmRyZMnk6KiIl2bqTEayv9rr71GPDw8iKenJ3nppZdIbm6urs1sdy5fvkwAEE9PT+Lt7U28vb3JqVOnWv3ds5kRDAZD7+mUVVcGg8FoCUzoGAyG3sOEjsFg6D1M6BgMht7DhI7BYOg9TOgYDIbe0yEjDDO6BkVFRQgICAAA5Ofnw8DAAH369AFAAzcYGxs3ef9PP/2E69evY9euXRq3ldG5YULH0Bm9evVCUlISABpjzdLSEu+//75ujWLoJazqyuhQ7N27FyNGjIC3tzeCgoJQVVUFADh8+DA8PDzg7e2NCRMm1Lvv1KlTGDNmDAoLC+scv3jxIh+g0tfXl58+x+haMKFjdCjmzZuHa9euITk5Ga6urti3bx8A4N///jdiY2ORnJyMEydO1Lnn2LFjCAsLw+nTp9G7d+8657Zt24bw8HAkJSXh8uXLMDMz01peGB0HJnSMDkVKSgrGjx8PT09PREZG4vbt2wCA559/HsuWLcPevXuhUNSumhsXF4ctW7bg1KlTsLa2rpfe888/j3Xr1mHnzp0oLS2FoSFrremKMKFjdCiWLVuGXbt24e+//8Ynn3wCiUQCAPj++++xadMmPH78GD4+Pigqokt8Ozo6oqKiAmlpaQ2mFxISgh9++AFisRijR4/G3bt3tZYXRseBCR2jQ1FRUQFbW1vIZDJERkbyxzMyMjBq1Cj8+9//Ru/evfl4hPb29vi///s/LF26lPf+VMnIyICnpyc++OADDB8+nAldF4UJHaND8dlnn2HUqFEIDAzEc889xx9fv349PD094eHhgQkTJsDb25s/5+LigsjISLzyyivIyMiok9727dv5TgwzMzO88MILWssLo+PAwjQxGAy9h3l0DAZD72FCx2Aw9B4mdAwGQ+9hQsdgMPQeJnQMBkPvYULHYDD0HiZ0DAZD72FCx2Aw9B4mdAwGQ+/5//L+mpyXai+gAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 320x200 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "OracleTS: 116.0 +/- 11.6\n",
      "TS: 1272.2 +/- 127.2\n",
      "AdaTS: 320.2 +/- 32.0\n",
      "AdaTSx: 341.9 +/- 34.2\n",
      "AdaTSd: 316.4 +/- 31.6\n",
      "MetaTS: 556.0 +/- 55.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: 62.4 +/- 6.2\n",
      "TS: 1186.2 +/- 118.6\n",
      "AdaTS: 219.6 +/- 22.0\n",
      "AdaTSx: 230.5 +/- 23.1\n",
      "AdaTSd: 264.8 +/- 26.5\n",
      "MetaTS: 757.9 +/- 75.8\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: 27.5 +/- 2.7\n",
      "TS: 1128.5 +/- 112.9\n",
      "AdaTS: 153.4 +/- 15.3\n",
      "AdaTSx: 175.3 +/- 17.5\n",
      "AdaTSd: 244.1 +/- 24.4\n",
      "MetaTS: 1307.3 +/- 130.7\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 320x200 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# linear bandit\n",
    "algs = [\n",
    "  (\"LinTS\", 1, \"cyan\", \"-\", \"OracleTS\"),\n",
    "  (\"LinTS\", 1, \"blue\", \"-\", \"TS\"),\n",
    "  (\"LinTS\", 1, \"red\", \"-\", \"AdaTS\"),\n",
    "  (\"LinTS\", 3, \"red\", \"--\", \"AdaTSx\"),  # AdaTS with 3x wider meta-prior\n",
    "  (\"LinTS\", 0.333, \"red\", \":\", \"AdaTSd\"),  # AdaTS with 3x narrower meta-prior\n",
    "  (\"LinTS\", 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 d in [2, 4, 8]:\n",
    "  K = 5 * d\n",
    "  for sigma_q_scale in [0.5, 1, 2]:\n",
    "    # meta-prior parameters\n",
    "    mu_q = np.zeros(d)\n",
    "    sigma_q = sigma_q_scale * np.ones(d)\n",
    "    # prior parameters\n",
    "    sigma_0 = 0.1 * np.ones(d)\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(d)\n",
    "\n",
    "        # potential meta-prior misspecification\n",
    "        sigma_q_alg = alg[1] * sigma_q \n",
    "\n",
    "        # incrementally updated statistics\n",
    "        mu_inc = np.diag(1.0 / np.square(sigma_q_alg)).dot(mu_q)\n",
    "        Lambda_inc = np.diag(1.0 / np.square(sigma_q_alg))\n",
    "\n",
    "        # initial meta-posterior\n",
    "        mu_hat = np.linalg.inv(Lambda_inc).dot(mu_inc)\n",
    "        Sigma_hat = np.linalg.inv(Lambda_inc)\n",
    "\n",
    "        for task 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",
    "          env = LinBandit(X, theta, sigma=sigma)\n",
    "\n",
    "          # task prior\n",
    "          Sigma_q = np.diag(np.square(sigma_q))\n",
    "          Sigma_0 = np.diag(np.square(sigma_0))\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 = Sigma_0 + Sigma_q\n",
    "          elif alg_num >= 2:\n",
    "            if alg[-1].startswith(\"Meta\"):\n",
    "              # MetaTS\n",
    "              mu_tilde = np.random.multivariate_normal(mu_hat, Sigma_hat)\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 = Sigma_0 + Sigma_hat\n",
    "\n",
    "          # evaluate on a sampled problem instance\n",
    "          alg_class = globals()[alg[0]]\n",
    "          alg_params = {\n",
    "            \"theta0\": 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",
    "            # subtract priors, which are added in LinTS\n",
    "            M = np.linalg.inv(Sigma_task)\n",
    "            Gt = logs[0].Gram - M\n",
    "            Bt = logs[0].B - M.dot(mu_task)\n",
    "\n",
    "            # incremental update\n",
    "            M = np.linalg.inv(np.eye(d) / np.square(sigma_0) + Gt)\n",
    "            mu_inc += Bt - Gt.dot(M).dot(Bt)\n",
    "            Lambda_inc += Gt - Gt.dot(M).dot(Gt)\n",
    "\n",
    "            # updated meta-posterior\n",
    "            mu_hat = np.linalg.inv(Lambda_inc).dot(mu_inc)\n",
    "            Sigma_hat = np.linalg.inv(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\"Linear (d = %d, $\\sigma_q$ = %.3f)\" % (d, 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": "CoAdaTS Public.ipynb",
   "provenance": [
    {
     "file_id": "1HTVL3YcNGgqZwz5MTMOMFrwsn2T5BwXh",
     "timestamp": 1622693093614
    },
    {
     "file_id": "1A_VJGRPLw2g7jJFFcasEDsTwIKw6r2pN",
     "timestamp": 1611938834609
    },
    {
     "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
}
