{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "id": "stuffed-sweden"
   },
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import scipy\n",
    "import matplotlib.pylab as plt\n",
    "plt.rcParams['pdf.fonttype'] = 42\n",
    "plt.rcParams['ps.fonttype'] = 42\n",
    "#import torch\n",
    "import math\n",
    "import copy\n",
    "import random\n",
    "import os\n",
    "import cvxpy as cp\n",
    "# import cvxgrp as cpg\n",
    "from random import randrange\n",
    "#from matplotlib.backends.backend_pdf import PdfPages"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {
    "id": "short-picnic"
   },
   "outputs": [],
   "source": [
    "dim = 3\n",
    "H = 5\n",
    "T = 10000\n",
    "repeat = 10\n",
    "ACTION = np.power(2,dim-1)\n",
    "STATE = H+2\n",
    "Inner = 1\n",
    "\n",
    "thetastar = np.append(0.01*np.ones(dim-1), 1)\n",
    "delta = 0.05\n",
    "\n",
    "# dim = 5 0.9\n",
    "# H = 5\n",
    "# T = 100000\n",
    "# ACTION = np.power(2,dim-1)\n",
    "# STATE = H+2\n",
    "\n",
    "# thetastar = np.append(0.1*np.ones(dim-1), 1)\n",
    "# delta = 0.3"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "id": "referenced-produce"
   },
   "outputs": [],
   "source": [
    "def trans_action(a, d):###d is dimension, dimension of a is d-1\n",
    "    tt = np.zeros(d-1)-1\n",
    "    bb = bin(a)\n",
    "    for i in range(len(bb)-2):\n",
    "        tt[i] = 2*np.double(bb[i+2])-1\n",
    "    return(tt)\n",
    "\n",
    "\n",
    "def phi(s,a,sp):\n",
    "    tt = np.zeros(dim)\n",
    "    d = dim\n",
    "    aa = trans_action(a,d)\n",
    "    if s<H:\n",
    "        if sp == s+1:            \n",
    "            for i in range(d-1):\n",
    "                tt[i] = -aa[i]\n",
    "            tt[d-1] = 1-delta\n",
    "    if s<H:\n",
    "        if sp == H+1:            \n",
    "            for i in range(d-1):\n",
    "                tt[i] = aa[i]\n",
    "            tt[d-1] = delta\n",
    "    if s==H:\n",
    "        if sp == H:            \n",
    "            for i in range(d-1):\n",
    "                tt[i] = 0\n",
    "            tt[d-1] = 1\n",
    "    if s==H+1:\n",
    "        if sp == H+1:            \n",
    "            for i in range(d-1):\n",
    "                tt[i] = 0\n",
    "            tt[d-1] = 1\n",
    "    return tt\n",
    "\n",
    "\n",
    "def phiv(s,a,v):\n",
    "    if s==H+1:\n",
    "        return phi(s,a,H+1)*v[H+1]\n",
    "    return (phi(s,a,H+1)*v[H+1] + phi(s,a,s+1)*v[s+1])\n",
    "\n",
    "def proba(s,a,sp):\n",
    "    return np.dot(phi(s,a,sp), thetastar)\n",
    "\n",
    "def reward(s,a):\n",
    "    if s== H+1:\n",
    "        return 1\n",
    "    return 0\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "legitimate-journalist",
    "outputId": "6f0bda28-207d-4813-b945-121236f39232"
   },
   "outputs": [],
   "source": [
    "for jjjj in range(repeat):\n",
    "    ############tabular###################\n",
    "    s_cur = 0\n",
    "    REWARD = 0\n",
    "    TOTALREWARD = []\n",
    "    for t in range(T):\n",
    "        s_cur = 0\n",
    "        for stage in range(H):\n",
    "            a_cur = np.int(np.power(2, dim-1))-1\n",
    "            s_next = s_cur\n",
    "            #a_cur = randrange(ACTION)\n",
    "            if s_cur< H:\n",
    "                s_next = H+1-np.random.binomial(1, proba(s_cur, a_cur , s_cur+1))*(H-s_cur)\n",
    "            #print( proba(s_cur, a_cur , s_cur+1))\n",
    "            REWARD += reward(s_cur, a_cur)\n",
    "            TOTALREWARD.append(REWARD)\n",
    "            s_cur = s_next\n",
    "            #print([t, REWARD, s_cur, a_cur, ])\n",
    "    #     print(REWARD)\n",
    "    path  = \"optimal_lowerbound_0.1_\" + str(jjjj) +\".txt\"\n",
    "    fr = open(path,'w')\n",
    "    for i in TOTALREWARD:\n",
    "        fr.write(str(i))\n",
    "        fr.write(\"\\n\")\n",
    "    fr.close() "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {
    "id": "mental-moisture"
   },
   "outputs": [],
   "source": [
    "for jjjj in range(repeat):\n",
    "    ############Random###################\n",
    "    s_cur = 0\n",
    "    REWARD = 0\n",
    "    TOTALREWARD = []\n",
    "    for t in range(T):\n",
    "        s_cur = 0\n",
    "        for stage in range(H):\n",
    "            #a_cur = randrange(ACTION)\n",
    "            s_next = s_cur\n",
    "            a_cur = randrange(ACTION)\n",
    "            if s_cur< H:\n",
    "                s_next = H+1-np.random.binomial(1, proba(s_cur, a_cur , s_cur+1))*(H-s_cur)\n",
    "            #print( proba(s_cur, a_cur , s_cur+1))\n",
    "            REWARD += reward(s_cur, a_cur)\n",
    "            TOTALREWARD.append(REWARD)\n",
    "            s_cur = s_next\n",
    "            #print([t, REWARD, s_cur, a_cur, ])\n",
    "    #     print(REWARD)\n",
    "    path  = \"random_lowerbound_0.1_\" + str(jjjj) +\".txt\"\n",
    "    fr = open(path,'w')\n",
    "    for i in TOTALREWARD:\n",
    "        fr.write(str(i))\n",
    "        fr.write(\"\\n\")\n",
    "    fr.close() "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "artistic-details",
    "outputId": "68a103a2-ab59-4076-80eb-dca8c3f2dd11"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/shawn/opt/anaconda3/lib/python3.8/site-packages/cvxpy/problems/problem.py:1337: UserWarning: Solution may be inaccurate. Try another solver, adjusting the solver settings, or solve with verbose=True for more information.\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "end\n",
      "1\n",
      "end\n",
      "2\n",
      "end\n",
      "3\n",
      "end\n",
      "4\n",
      "end\n",
      "5\n",
      "end\n",
      "6\n",
      "end\n",
      "7\n"
     ]
    }
   ],
   "source": [
    "for jjjj in range(repeat):\n",
    "    ############General###################\n",
    "    print(jjjj)\n",
    "    s_cur = np.zeros(H+1).astype(int)\n",
    "    a_cur = np.zeros(H).astype(int)\n",
    "    QVALUE = np.zeros((STATE, ACTION, H+1))\n",
    "    VVALUE = np.zeros((STATE, H+1))\n",
    "    LAMBDA = 1\n",
    "    beta= 0.01\n",
    "    SIGMA = np.zeros((dim, dim, H))\n",
    "    for stage in range(H):\n",
    "        SIGMA[:,:,stage] = LAMBDA*np.diag(np.ones(dim))\n",
    "    BB = np.zeros((dim, H))\n",
    "    POLICY = np.ones((STATE, ACTION, H+1))/ACTION\n",
    "    REWARD = 0\n",
    "    TOTALREWARD = []\n",
    "    for t in range(T):\n",
    "#         print(t) \n",
    "        s_cur[0] = 0\n",
    "        for stage in range(H):\n",
    "            #a_cur = randrange(ACTION)\n",
    "            a_cur[stage] = np.random.choice(ACTION, 1, p=POLICY[s_cur[stage],:,stage])\n",
    "            #a_cur[stage] = randrange(ACTION)\n",
    "            s_next = s_cur[stage]\n",
    "            if s_cur[stage]< H:\n",
    "                s_next = H+1-np.random.binomial(1, proba(s_cur[stage], a_cur[stage] , s_cur[stage]+1))*(H-s_cur[stage])\n",
    "            #print( proba(s_cur, a_cur , s_cur+1))\n",
    "            REWARD += reward(s_cur[stage], a_cur[stage])\n",
    "            TOTALREWARD.append(REWARD)\n",
    "            s_cur[stage+1] = s_next\n",
    "            #print([t, stage, REWARD, s_cur[stage], a_cur[stage]])\n",
    "        for stage in range(H):\n",
    "            curstage=H-1-stage\n",
    "            phi_v = phiv(s_cur[curstage], a_cur[curstage], VVALUE[:,curstage+1])\n",
    "            BB [:,curstage] = BB [:,curstage] + phi_v*VVALUE[s_cur[curstage+1], curstage+1]\n",
    "            phi_v.shape = (dim,1)\n",
    "            SIGMA[:,:,curstage]  = SIGMA[:,:,curstage] + np.dot(phi_v, phi_v.T)\n",
    "        for ite in range(Inner):\n",
    "            for stage in range(H):\n",
    "                curstage=H-1-stage\n",
    "                hattheta = np.linalg.lstsq(SIGMA[:,:,curstage], BB[:,curstage], rcond=-1)\n",
    "                hattheta = hattheta[0]\n",
    "                hattheta.shape = (dim)\n",
    "                for stat in range(STATE):\n",
    "                    f = cp.Parameter(dim)\n",
    "                    x = cp.Variable(dim)\n",
    "                    constraints1 = [cp.norm(SIGMA[:,:,curstage]@(x-hattheta), 2)<=beta]    \n",
    "                    prob1 = cp.Problem(cp.Minimize(f.T@x),constraints1)\n",
    "                    for act in range(ACTION):\n",
    "                        if  POLICY[stat,act,curstage] != 0:\n",
    "                            phi_v = phiv(stat, act, VVALUE[:,curstage+1])\n",
    "                            f.value = -phi_v\n",
    "                            try:\n",
    "                                prob1.solve() \n",
    "                            except: \n",
    "                                x.value = hattheta\n",
    "                    mmax = -1000\n",
    "                    argmax = 0\n",
    "                    for act in range(ACTION):   \n",
    "                        POLICY[stat,act,curstage] = 0\n",
    "                        phi_v = phiv(stat, act, VVALUE[:,curstage+1])\n",
    "                        QVALUE[stat,act,curstage] = reward(stat,act)+ phi_v.T@x.value\n",
    "                        QVALUE[stat,act,curstage] = min(QVALUE[stat,act,curstage],stage+1) \n",
    "                        QVALUE[stat,act,curstage] = max(QVALUE[stat,act,curstage],0)\n",
    "                        if QVALUE[stat,act,curstage] > mmax:\n",
    "                            argmax = act\n",
    "                            mmax = QVALUE[stat,act,curstage]\n",
    "#                     print(argmax)\n",
    "                    VVALUE [stat, curstage]= mmax\n",
    "                    POLICY[stat,argmax,curstage] = 1\n",
    "    print('end')\n",
    "    path  = \"OPERA_lowerbound_0.1_\" + str(jjjj) +\".txt\"\n",
    "    fr = open(path,'w')\n",
    "    for i in TOTALREWARD:\n",
    "        fr.write(str(i))\n",
    "        fr.write(\"\\n\")\n",
    "    fr.close() \n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 297
    },
    "id": "quick-limitation",
    "outputId": "2aa70caa-16a9-45ec-b07a-05c1b2c56394",
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAYwAAAEGCAYAAAB2EqL0AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8vihELAAAACXBIWXMAAAsTAAALEwEAmpwYAAAxSUlEQVR4nO3deXhU5fXA8e8hbIoCCohIRBBBBZUgARWLYkGLW0FaKlYRxIr6E7WtVUHrUq21Wm0VRStaRFBWEcGlorK6gBAE2VcNEKAQAdm3JOf3x3uHmYRJMiSZubOcz/PMk3vfu8y5IcyZd7nvFVXFGGOMKU0lvwMwxhiTGCxhGGOMiYglDGOMMRGxhGGMMSYiljCMMcZEpLLfAURL3bp1tXHjxn6HYYwxCWXevHk/qmq9cNuSNmE0btyYrKwsv8MwxpiEIiJri9tmTVLGGGMiYgnDGGNMRCxhGGOMiUjS9mGEc+jQIXJycti/f7/foSSE6tWrk56eTpUqVfwOxRgTB6KWMERkKHANsEVVz/HKxgBnervUBn5S1QwRaQwsA1Z422ar6h3eMW2AYcAxwMfAvVrGCbBycnI4/vjjady4MSJSputKFarK1q1bycnJoUmTJn6HY4yJA9FskhoGdAktUNXrVTVDVTOA8cB7IZvXBLYFkoXnVaAf0Mx7FTrn0di/fz916tSxZBEBEaFOnTpWGzPGHBa1hKGqM4Ft4baJ+8T+DTCqpHOISAOgpqrO8moVw4Fu5YnLkkXk7HdljAnlV6d3B2Czqq4KKWsiIvNFZIaIdPDKGgI5IfvkeGVhiUg/EckSkazc3NyKj9oYY+JZdjaMHBm10/uVMG6gcO1iE9BIVVsDfwRGikhNINxX3GL7L1R1iKpmqmpmvXphb1T0XVpaGhkZGZxzzjlce+21/PTTTxVy3mHDhtG/f/8KOZcxJgF98w00aQI33gj/+19U3iLmCUNEKgPdgTGBMlU9oKpbveV5wBqgOa5GkR5yeDqwMXbRVrxjjjmGBQsWsHjxYk488UQGDx7sd0jGmES2dClcfz1ceKFbHz4cTj45Km/lRw2jM7BcVQ83NYlIPRFJ85ZPx3Vuf6+qm4BdInKh1+9xMzDRh5ij4qKLLmLDhg0AzJkzh/bt29O6dWvat2/PihVuwNiwYcPo3r07Xbp0oVmzZjzwwAOHj3/zzTdp3rw5l156KV999dXh8rVr19KpUyfOO+88OnXqxLp16wDo06cPd955J5dddhmnn346M2bMoG/fvpx99tn06dMndhdujCmfffugcmUQgZYtYexYV/7tt9CrV9TeNprDakcBHYG6IpIDPKaq/wF6cmRn9yXAEyKSB+QDd6hqoMP8ToLDav/rvcrv97+HBQsq5FSHZWTACy9EtGt+fj5Tpkzh1ltvBeCss85i5syZVK5cmc8//5yHHnqI8ePHA7BgwQLmz59PtWrVOPPMM7n77rupXLkyjz32GPPmzaNWrVpcdtlltG7dGoD+/ftz880307t3b4YOHco999zD+++/D8D27duZOnUqkyZN4tprr+Wrr77ijTfeoG3btixYsICMjIyK/Z0YYyrWmjVwxhnB9WrVoH9/eOoptxxFUUsYqnpDMeV9wpSNxw2zDbd/FnBOhQbno3379pGRkUF2djZt2rTh8ssvB2DHjh307t2bVatWISIcOnTo8DGdOnWiVq1aALRo0YK1a9fy448/0rFjRwJ9Nddffz0rV64EYNasWbz3nhux3KtXr0K1kmuvvRYR4dxzz6V+/fqce+65ALRs2ZLs7GxLGMbEs+efhwcfdMuXXAKvvgotWsTs7VPqTu9CIqwJVLRAH8aOHTu45pprGDx4MPfccw+PPPIIl112GRMmTCA7O5uOHTsePqZayLeGtLQ08vLygMiHvYbuFzhXpUqVCp23UqVKh89rjIkzu3e7Fow1a9z65MlwxRUxD8PmkvJJrVq1GDRoEM899xyHDh1ix44dNGzoRgwPGzas1OMvuOACpk+fztatWzl06BDjxo07vK19+/aMHj0agHfeeYef/exnUbkGY0yUbdsGp54Kxx8fTBbz5/uSLMAShq9at25Nq1atGD16NA888AADBw7k4osvJj8/v9RjGzRowOOPP85FF11E586dOf/88w9vGzRoEG+++SbnnXceI0aM4MUXX4zmZRhjomHnTqhTB3K88UFXXBGsafhEyjgtU9zLzMzUog9QWrZsGWeffbZPESUm+50Z44PsbNc3sW8fPPss3H9/zN5aROapama4bVbDMMaYePHtt26obJMmLln06xfTZFEaSxjGGOO3ffvgnnugTZtg2d//Dv/+t38xhZG6o6SMMSYeZGe7GkXAM8/AffdBWppvIRXHEoYxxvjh66/h17+GTZuCZUuWxPS+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jRqqXbqUvl+tWqXvc+ml7mf//qpPPqnasmXJ+z/0kOrIkapDhqguWhT8PY4ZU3i/f/xD9ZRTjjz+t791v6dwPvlEdeVK1REjwr/3rbe6GIs7PtFYwoilPXtU33+/8F/U9u3+xGKiavbs4D/xddepzpgRXF+3rvTjDxxQffbZyD+QX3/d/axcOVh2zz2qmzerzp9/dLF//bVqkyaqNWuqLlgQfp/1610No1WrwnEsX+4qyv/7n+qqVe6DdPDg4HH796t+/71LgqGJMD+/YirY+fnu+1h57d/vXkWTdWk2blQ99dTw/0YZGapLl7raR82awfL09MLLt92m2qmT+7s52vdXdf/m0foOWlLCELc9+WRmZmpWVlbs3lDVNYKGGjECbropdjGYClVQ4CYObtCgcPmOHVC7dunH164NV13l2s8LCtw0YRdd5AbH3XZb6cdXrQoffgidO8fH+AjV+IgjXuze7UbIT5sGW7eW/3xjxrj+kuefh+HD3Rykxx3ntt18s7u3909/cn+TobKz4bTT3PKePbBtG5x6KmUmIvNUNTPsxuIySaK/YlbD+OAD1cceU23ePPgVonNn1R9/jM37J4GZM903sxYt3DfzwDeunTsL77dypfv1tmun+uijqqNHq770kupVV6k+/rjqmjXuG+zTT7tmiVWrVC+8UPWf/1StU8ftW1qzwXffqV5++ZHfHC+7LPw3yl//WvXOO1VPO82tP/GEa8Io7htouNef/6w6bpzqn/7kvjlv3RqVX7OJsr173d9x4N/1iivc31tBgfu7/Pxz1ddec3/v4ZrFKvK1Y0fZrwNrkoqC//3vyH+l666L607t1atVmzZ1H06l5bPQavL27RVX/d20KfjhGsmrWTPVnJyK/w8lolq3bnC9atWjO/6RR0pvSpg82bXp9+lT+NiaNVUHDEieNm9TPocOqS5cqPr886qNGhX+cnLGGS7RBJq7xo4tfOxjjx35t3nllar79pU9npIShjVJlUWHDoXH99WpA2+9BVdfHZ33K0FBAbRr54YDduwIjRvD9dcHt597Lqxb54YHbttW+NgOHYLDG594wlVjAzehl6RdOxgwADIyYN482LIFqlWDv/3NjRwONWOGGybZsiX071/8OT/7DEaOhDffLPm9f/Mbd64ffoA5c1xzzdatbkjo9u1H7t+wIWzYAM2auX+m2bNLv773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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 432x288 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "T1=H*T\n",
    "rewardopt = np.zeros(T1+1)\n",
    "rewardran = np.zeros(T1+1)\n",
    "rewardOPERA = np.zeros(T1+1)\n",
    "rewardOPERAbern = np.zeros(T1+1)\n",
    "rewardliu = np.zeros(T1+1)\n",
    "rewardcur = 0\n",
    "# repeat = 1\n",
    "\n",
    "for jjjj in range(repeat):\n",
    "    line1=0\n",
    "    path  = \"optimal_lowerbound_0.1_\" + str(jjjj) +\".txt\"\n",
    "    fr = open(path,'r')\n",
    "    for line in fr:\n",
    "        rewardopt[line1]=rewardopt[line1]+int(line)\n",
    "        line1+=1\n",
    "    fr.close() \n",
    "# for i in range(T1):\n",
    "#     rewardopt[i] = (rewardopt[i])/repeat\n",
    "# x=list(range(1, T+1))\n",
    "# plt.plot(x, rewardopt[0:T1-1:H],color='orange', label='Optimal')\n",
    "    \n",
    "    \n",
    "for jjjj in range(repeat):\n",
    "    line1=0\n",
    "    path  = \"random_lowerbound_0.1_\" + str(jjjj) +\".txt\"\n",
    "    fr = open(path,'r')\n",
    "    for line in fr:\n",
    "        rewardran[line1]=rewardran[line1]+int(line)\n",
    "        line1+=1\n",
    "    fr.close() \n",
    "for i in range(T1):\n",
    "    rewardran[i] = (rewardopt[i]-rewardran[i])/repeat\n",
    "x=list(range(1, T+1))\n",
    "plt.plot(x, rewardran[0:T1-1:H],color='red', label='Random')\n",
    "\n",
    "\n",
    "\n",
    "for jjjj in range(repeat):\n",
    "    line1=0\n",
    "    path  = \"OPERA_lowerbound_0.1_\" + str(jjjj) +\".txt\"\n",
    "    fr = open(path,'r')\n",
    "    for line in fr:\n",
    "        rewardOPERA[line1]=rewardOPERA[line1]+int(line)\n",
    "        line1+=1\n",
    "    fr.close() \n",
    "for i in range(T1):\n",
    "    rewardOPERA[i] = (rewardopt[i]-rewardOPERA[i])/repeat\n",
    "x=list(range(1, T+1))\n",
    "plt.plot(x, rewardOPERA[0:T1-1:H],color='blue', label='OPERA')\n",
    "\n",
    "plt.legend()\n",
    "plt.xlabel('Number of Episodes')\n",
    "# naming the y axis\n",
    "plt.ylabel('Regret')\n",
    "# giving a title to my graph\n",
    "plt.savefig(os.path.join('0_pdf' + \"test.pdf\"), dpi=100)\n",
    "# function to show the plot\n",
    "plt.show()\n",
    "fig=plt.gcf()\n",
    "fig.savefig('./666.jpg')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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c4mWRIEg4NcInHOulqQJBFrV2ilwzrm2KWkCQZSk+BmBc87FSppAoH6/kHPOxZU0gSDK+yx2zrnaki4QOOdcYxUWFnLSSSdRUFDA4MGDufTSSykrK+O1116ja9euHHDAAey7777ccMMNANXjR40aVf166aWXAHvKeNSoUey3336ccMIJbNq0qda2Ro4cyaRJk3Zr/pImELSzxyWcc22EqnLqqady8skns2zZMpYuXcq2bdu45pprADj88MP58MMPmTNnDv/85z+ZO3du9fh58+ZVvyZMmAA03KT1okWLqKqq4o033mD79u27LY/J0+hcwO8eda79ao1WqF955RUyMzM599xzATuiv/XWW8nPz2f8+Jou3Dt16sTo0aNZsWIFvXv3DrXt2CatAR5++GHOPvtsFi1axIwZM3bbmUHynRF4JHDONcLChQsZPXp0rXFdunQhLy+P5cuXV48rKiri3XffZfjw4QC8+eabtaqGVqxYUWsddZu0Bnjsscc4/fTTmTRpEo888kgCc1Vb8p0RJE3oc67jaY1WqFU1bouh0fFvvvkmBxxwACkpKVx11VUMHz6c1157jcMPP5znnntup+Xqa9J69uzZ5ObmsueeezJgwADOO+88Nm7cSPfu3ROex4QWiyJytIgsEZHlIrJT95Zibg+mzxeRA+OtxznnWsvw4cOp277Zli1bWL16NYMHD66+RjB37lwuuOCCXa6vviatH3nkERYvXsygQYMYPHgwW7Zs4V//+ldC8lRXwgKBiESAO4FjgGHAJBEZVme2Y4CC4HU+8PdEpccvFjvnmuKoo46iuLiYBx54ALAqnSuuuILJkyeTnZ3d5PXGNmldWlrK9OnTmT9/PitXrmTlypU888wzu616KJFnBGOB5ar6qaqWAY8CJ9WZ5yTgATXvAt1EpF9CUrPjK8CboXbONY6I8NRTTzF9+nQKCgoYMmQImZmZ/O53v2twubrXCJ544omd5ok2af3444/Tv3//6r4NAI444gg++eQT1q5d2+J5qiuR1wj6A6tjhguBg0PM0x+olXMROR87YyAvL69JiRkwajDf+8+/6ZJf96TEOecaNnDgQJ599tmdxh955JEceeSRccdv3rw57rq2bdtWazi63rPPPrvW+EgksluCACQ2EMQ7+K5bQRNmHlR1KjAVrD+CpiRm3BUnM+6KpizpnHMdWyKr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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 432x288 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "T1=H*T\n",
    "rewardopt = np.zeros(T1+1)\n",
    "rewardran = np.zeros(T1+1)\n",
    "rewardOPERA = np.zeros(T1+1)\n",
    "rewardOPERAbern = np.zeros(T1+1)\n",
    "rewardliu = np.zeros(T1+1)\n",
    "rewardcur = 0\n",
    "# repeat = 1\n",
    "\n",
    "for jjjj in range(repeat):\n",
    "    line1=0\n",
    "    path  = \"optimal_lowerbound_0.1_\" + str(jjjj) +\".txt\"\n",
    "    fr = open(path,'r')\n",
    "    for line in fr:\n",
    "        rewardopt[line1]=rewardopt[line1]+int(line)\n",
    "        line1+=1\n",
    "    fr.close() \n",
    "for i in range(T1):\n",
    "    rewardopt[i] = rewardopt[i]/(repeat*(i+1))\n",
    "x=list(range(1, T+1))\n",
    "plt.plot(x, H*rewardopt[0:T1-1:H],color='orange', label='Optimal')\n",
    "    \n",
    "    \n",
    "for jjjj in range(repeat):\n",
    "    line1=0\n",
    "    path  = \"random_lowerbound_0.1_\" + str(jjjj) +\".txt\"\n",
    "    fr = open(path,'r')\n",
    "    for line in fr:\n",
    "        rewardran[line1]=rewardran[line1]+int(line)\n",
    "        line1+=1\n",
    "    fr.close() \n",
    "for i in range(T1):\n",
    "    rewardran[i] = rewardran[i]/(repeat* (i+1))\n",
    "x=list(range(1, T+1))\n",
    "plt.plot(x, H*rewardran[0:T1-1:H],color='red', label='Random')\n",
    "\n",
    "\n",
    "\n",
    "for jjjj in range(repeat):\n",
    "    line1=0\n",
    "    path  = \"OPERA_lowerbound_0.1_\" + str(jjjj) +\".txt\"\n",
    "    fr = open(path,'r')\n",
    "    for line in fr:\n",
    "        rewardOPERA[line1]=rewardOPERA[line1]+int(line)\n",
    "        line1+=1\n",
    "    fr.close() \n",
    "for i in range(T1):\n",
    "    rewardOPERA[i] = rewardOPERA[i]/(repeat*(i+1))\n",
    "x=list(range(1, T+1))\n",
    "plt.plot(x, H*rewardOPERA[0:T1-1:H],color='blue', label='OPERA')\n",
    "\n",
    "plt.legend()\n",
    "plt.xlabel('Number of Episodes')\n",
    "# naming the y axis\n",
    "plt.ylabel('Average Accumulative Reward')\n",
    "# giving a title to my graph\n",
    "plt.savefig(os.path.join('0_pdf' + \"test.pdf\"), dpi=100)\n",
    "# function to show the plot\n",
    "plt.show()\n",
    "fig=plt.gcf()\n",
    "fig.savefig('./667.jpg')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "colab": {
   "provenance": []
  },
  "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.8.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
