{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The history saving thread hit an unexpected error (DatabaseError('database disk image is malformed',)).History will not be written to the database.\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import pickle\n",
    "from itertools import combinations"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "class Environment:\n",
    "    \n",
    "    def __init__(self, N, M, C):\n",
    "        self.N = N\n",
    "        self.M = M\n",
    "        self.C = C\n",
    "#         C = C_u in the paper.  fix C_l = 1\n",
    "        self.occupied = np.zeros(N)\n",
    "        self.release_round = np.zeros(N)\n",
    "        \n",
    "    def generate(self, T, c_bar, r_bar):\n",
    "        self.c = np.zeros([T,self.N])\n",
    "        self.r = np.zeros([T,self.N])\n",
    "        for i in range(self.N):\n",
    "            self.r[:,i] = np.random.binomial(1, r_bar[i], size=T)\n",
    "            p = (c_bar[i] - 1) / (self.C - 1)\n",
    "            self.c[:,i] = np.random.binomial(self.C - 1, p, size=T) + 1\n",
    "        q_star = r_bar/c_bar\n",
    "        q_star.sort()\n",
    "        self.optimal_reward = sum(q_star[-self.M:])\n",
    "    \n",
    "    def simulate(self, T, algo):\n",
    "        algo.initialize(self.N, self.M, self.C, T)\n",
    "        feedback = []\n",
    "        cumulative_rewards = np.zeros(T)\n",
    "        regret = np.zeros(T)\n",
    "        cumulative_reward = 0\n",
    "        for t in range(T + self.C):\n",
    "            feedback.append({})\n",
    "        for t in range(T):\n",
    "            action = algo.chosen_action\n",
    "            for i in range(self.N):\n",
    "                if action[i] == 1:\n",
    "                    self.occupied[i] = 1\n",
    "                    self.release_round[i] = t + self.c[t,i]\n",
    "                    feedback[int(t + self.c[t,i])][i] = (self.c[t,i], self.r[t,i], t)\n",
    "                if t == self.release_round[i]:\n",
    "                    self.occupied[i] = 0\n",
    "            algo.update(t+1, feedback[t+1])\n",
    "            for f in feedback[t].values():\n",
    "                cumulative_reward += f[1]\n",
    "            cumulative_rewards[t] = cumulative_reward\n",
    "            regret[t] = (t+1) * self.optimal_reward - cumulative_reward\n",
    "        return regret\n",
    "\n",
    "    \n",
    "EPS = 0.0000001\n",
    "\n",
    "class Algorithm_UCBBV1:\n",
    "    \n",
    "    def __init__(self):\n",
    "        return\n",
    "    \n",
    "    def initialize(self, N, M, C, T):\n",
    "        self.N = N\n",
    "        self.M = M\n",
    "        self.C = C\n",
    "        self.T = T\n",
    "        def n_choose_m(n, m):\n",
    "            elements = range(n)\n",
    "            return list(combinations(elements, m))\n",
    "        self.A_list = n_choose_m(N,M)\n",
    "        self.n_arms = len(self.A_list)\n",
    "        self.chosen_action = np.zeros(N)\n",
    "        self.occupied = np.zeros(N)\n",
    "        self.Ts = np.zeros(self.n_arms)\n",
    "        self.q = np.zeros(self.n_arms)\n",
    "        self.Rs = np.zeros(self.n_arms)\n",
    "        self.Cs = np.zeros(self.n_arms)\n",
    "        self.ts = 1\n",
    "        self.chosen_set = 0\n",
    "        self.chosen_round = 0\n",
    "        self.rew = 0\n",
    "        \n",
    "    def update(self, t, feedback):\n",
    "        self.chosen_action = np.zeros(self.N)\n",
    "        for i in feedback.keys():\n",
    "            self.occupied[i] = 0\n",
    "            self.rew += feedback[i][1]\n",
    "        if np.all(self.occupied == 0):\n",
    "            self.Ts[self.chosen_set] += 1\n",
    "            self.Cs[self.chosen_set] += t - self.chosen_round\n",
    "            self.q[self.chosen_set] = self.Rs[self.chosen_set] / self.Cs[self.chosen_set]\n",
    "            self.Rs[self.chosen_set] += self.rew\n",
    "            self.rew = 0\n",
    "            self.chosen_round = t\n",
    "            argma = 0\n",
    "            ma = -100000\n",
    "            for i in range(self.n_arms):\n",
    "                UCB = self.q[i] + (2 * np.sqrt(np.log(t+1)/(self.Ts[i]+EPS))) / max(EPS, 1 - np.sqrt(np.log(t+1)/(self.Ts[i]+EPS)))\n",
    "                if UCB > ma:\n",
    "                    ma = UCB\n",
    "                    argma = i\n",
    "            self.chosen_set = argma\n",
    "            for i in self.A_list[argma]:\n",
    "                self.chosen_action[i] = 1\n",
    "                self.occupied[i] = 1\n",
    "                \n",
    "                \n",
    "class Algorithm_CombUCB1:\n",
    "    \n",
    "    def __init__(self):\n",
    "        return\n",
    "    \n",
    "    def initialize(self, N, M, C, T):\n",
    "        self.N = N\n",
    "        self.M = M\n",
    "        self.C = C\n",
    "        self.T = T\n",
    "        self.chosen_action = np.zeros(N)\n",
    "        self.occupied = np.zeros(N)\n",
    "        self.Ts = np.zeros(N)\n",
    "        self.q = np.zeros(N)\n",
    "        self.Rs = np.zeros(N)\n",
    "        self.Cs = np.zeros(N)\n",
    "        self.As = set()\n",
    "        \n",
    "    def update(self, t, feedback):\n",
    "        self.chosen_action = np.zeros(self.N)\n",
    "        for i in feedback.keys():\n",
    "            self.occupied[i] = 0\n",
    "            self.Ts[i] += 1\n",
    "            self.Cs[i] += feedback[i][0]\n",
    "            self.Rs[i] += feedback[i][1]\n",
    "        if np.all(self.occupied == 0):\n",
    "            self.q = np.ones(self.N) * 10000\n",
    "            for i in range(self.N):\n",
    "                if self.Ts[i] > 0:\n",
    "                    d = np.sqrt(2 * np.log(t) / self.Ts[i])\n",
    "                    self.q[i] = self.Rs[i] / max(self.Cs[i], EPS) + (2 * np.sqrt(np.log(t+1)/(self.Ts[i]+EPS))) / max(EPS, 1 - np.sqrt(np.log(t+1)/(self.Ts[i]+EPS)))\n",
    "            tmp = (-self.q).argsort()\n",
    "            self.As = set()\n",
    "            for i in range(self.M):\n",
    "                self.As.add(tmp[i])\n",
    "            self.chosen_action = np.zeros(self.N)\n",
    "            for i in self.As:\n",
    "                self.chosen_action[i] = 1\n",
    "                self.occupied[i] = 1\n",
    "                    \n",
    "                    \n",
    "class Algorithm_Proposed:\n",
    "    \n",
    "    def __init__(self):\n",
    "        return\n",
    "    \n",
    "    def initialize(self, N, M, C, T):\n",
    "        self.N = N\n",
    "        self.M = M\n",
    "        self.C = C\n",
    "        self.T = T\n",
    "        self.chosen_action = np.zeros(N)\n",
    "        self.occupied = np.zeros(N)\n",
    "        self.Ts = np.zeros(N)\n",
    "        self.q = np.zeros(N)\n",
    "        self.Rs = np.zeros(N)\n",
    "        self.Cs = np.zeros(N)\n",
    "        self.Vs = np.zeros(N)\n",
    "        self.ts = 1\n",
    "        self.As = set()\n",
    "        \n",
    "    def update(self, t, feedback):\n",
    "        for i in feedback.keys():\n",
    "            self.occupied[i] = 0\n",
    "            self.Ts[i] += 1\n",
    "            self.Cs[i] += feedback[i][0]\n",
    "            self.Vs[i] += feedback[i][0] * feedback[i][0]\n",
    "            self.Rs[i] += feedback[i][1]\n",
    "        if t == self.ts:\n",
    "            self.q = np.ones(self.N) * 10000\n",
    "            for i in range(self.N):\n",
    "                if self.Ts[i] > 0:\n",
    "                    d = np.sqrt(2 * np.log(t) / max(self.Ts[i],1))\n",
    "                    c_hat = self.Cs[i]/self.Ts[i]\n",
    "                    V = self.Vs[i]/self.Ts[i] - c_hat ** 2\n",
    "                    dd = np.sqrt(2 * V * np.log(t) / max(self.Ts[i],1)) + 3 * (self.C - 1) * np.log(t) / max(self.Ts[i],1)\n",
    "                    self.q[i] = min(1, self.Rs[i]/max(self.Ts[i],1) + d) / max(1, c_hat - dd)\n",
    "            tmp = (-self.q).argsort()\n",
    "            self.As = set()\n",
    "            for i in range(self.M):\n",
    "                self.As.add(tmp[i])\n",
    "            if min(self.Ts) == 0:\n",
    "                self.ts += self.C * self.C + 2 * self.C\n",
    "            else:\n",
    "                minT = self.T\n",
    "                for i in self.As:\n",
    "                    minT = min(minT, self.Ts[i])\n",
    "                self.ts += minT + 2 * self.C\n",
    "        self.chosen_action = np.zeros(self.N)\n",
    "        covered = True\n",
    "        for i in range(self.N):\n",
    "            if (self.occupied[i] == 1) and (not i in self.As):\n",
    "                covered = False\n",
    "        if covered:\n",
    "            for i in self.As:\n",
    "                if self.occupied[i] == 0:\n",
    "                    self.chosen_action[i] = 1\n",
    "                    self.occupied[i] = 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "N = 4\n",
    "M = 2\n",
    "T = 10001\n",
    "C = 6\n",
    "c_bar = np.ones(N) * 2.0\n",
    "c_bar[:M] = np.ones(M) * 1.5\n",
    "r_bar = np.ones(N) * 0.5\n",
    "env = Environment(N,M,C)\n",
    "algo0 = Algorithm_UCBBV1()\n",
    "algo1 = Algorithm_CombUCB1()\n",
    "algo2 = Algorithm_Proposed()\n",
    "\n",
    "TT = 100\n",
    "r0 = np.zeros([TT,T])\n",
    "r1 = np.zeros([TT,T])\n",
    "r2 = np.zeros([TT,T])\n",
    "for s in range(TT):\n",
    "    env.generate(T,c_bar,r_bar)\n",
    "    regret0 = env.simulate(T,algo0)\n",
    "    r0[s] = regret0\n",
    "    regret1 = env.simulate(T,algo1)\n",
    "    r1[s] = regret1\n",
    "    regret2 = env.simulate(T,algo2)\n",
    "    r2[s] = regret2\n",
    "    \n",
    "with open('data/small_Delta.pkl', 'wb') as f:\n",
    "    pickle.dump((T, r0,r1,r2), f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f76b4447a58>"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "r0_mean = np.mean(r0,axis=0)\n",
    "r0_std = np.std(r0,axis=0)\n",
    "r1_mean = np.mean(r1,axis=0)\n",
    "r1_std = np.std(r1,axis=0)\n",
    "r2_mean = np.mean(r2,axis=0)\n",
    "r2_std = np.std(r2,axis=0)\n",
    "num_erb = 10\n",
    "cs = 6\n",
    "fs = 16\n",
    "plt.errorbar(x = range(T), y = r0_mean, yerr = r0_std, errorevery = int(T / num_erb), capsize=cs, label=\"UCB-BV1\")\n",
    "plt.errorbar(x = range(T), y = r1_mean, yerr = r1_std, errorevery = int(T / num_erb), capsize=cs, label=\"CombUCB1\")\n",
    "plt.errorbar(x = range(T), y = r2_mean, yerr = r2_std, errorevery = int(T / num_erb), capsize=cs, label=\"Proposed\")\n",
    "plt.xlabel('round',fontsize = fs)\n",
    "plt.ylabel('regret',fontsize=fs)\n",
    "plt.legend(fontsize = fs)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "N = 4\n",
    "M = 2\n",
    "T = 10001\n",
    "C = 6\n",
    "c_bar = np.ones(N) * 5.0\n",
    "c_bar[:M] = np.ones(M) * 1.5\n",
    "r_bar = np.ones(N) * 0.5\n",
    "env = Environment(N,M,C)\n",
    "algo0 = Algorithm_UCBBV1()\n",
    "algo1 = Algorithm_CombUCB1()\n",
    "algo2 = Algorithm_Proposed()\n",
    "\n",
    "TT = 5\n",
    "r0 = np.zeros([TT,T])\n",
    "r1 = np.zeros([TT,T])\n",
    "r2 = np.zeros([TT,T])\n",
    "for s in range(TT):\n",
    "    env.generate(T,c_bar,r_bar)\n",
    "    regret0 = env.simulate(T,algo0)\n",
    "    r0[s] = regret0\n",
    "    regret1 = env.simulate(T,algo1)\n",
    "    r1[s] = regret1\n",
    "    regret2 = env.simulate(T,algo2)\n",
    "    r2[s] = regret2\n",
    "    \n",
    "with open('data/large_Delta.pkl', 'wb') as f:\n",
    "    pickle.dump((T, r0,r1,r2), f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f76657d97b8>"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "r0_mean = np.mean(r0,axis=0)\n",
    "r0_std = np.std(r0,axis=0)\n",
    "r1_mean = np.mean(r1,axis=0)\n",
    "r1_std = np.std(r1,axis=0)\n",
    "r2_mean = np.mean(r2,axis=0)\n",
    "r2_std = np.std(r2,axis=0)\n",
    "num_erb = 10\n",
    "cs = 6\n",
    "fs = 16\n",
    "plt.errorbar(x = range(T), y = r0_mean, yerr = r0_std, errorevery = int(T / num_erb), capsize=cs, label=\"UCB-BV1\")\n",
    "plt.errorbar(x = range(T), y = r1_mean, yerr = r1_std, errorevery = int(T / num_erb), capsize=cs, label=\"CombUCB1\")\n",
    "plt.errorbar(x = range(T), y = r2_mean, yerr = r2_std, errorevery = int(T / num_erb), capsize=cs, label=\"Proposed\")\n",
    "plt.xlabel('round',fontsize = fs)\n",
    "plt.ylabel('regret',fontsize=fs)\n",
    "plt.legend(fontsize = fs)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "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.6.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
