{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "==> Using K = 3 arms\n",
      "==> Using Upsilon_T = 5 change points\n",
      "==> Using the following [0, 1000, 2000, 3000, 4000] change points\n",
      "C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T5000_N1_M5_envId6 is already a directory here...\n",
      "Using sub folder = '/SP__K3_T5000_N1_M5_envId6' and plotting in 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T5000_N1_M5_envId6'...\n",
      "Delete the existing file...\n",
      "Delete the existing file...\n",
      "Time horizon: 5000\n",
      "Number of repetitions: 1\n",
      " Create environments ...\n",
      "Time horizon: 5000\n",
      "Number of repetitions: 1\n",
      "Running ...M-UCB with diminishing\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "cb64dde329844d83997b6c7d05014214",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/1 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Average alarm 0.0 times\n",
      "Roll data saving ...\n",
      "Saving figure with format png, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T5000_N1_M5_envId6/arm_M-UCB($w=200$, with diminishing).png'...\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "c:\\Users\\USER\\Code\\SimulatuionByMe\\sim\\MUCB.py:241: RuntimeWarning: invalid value encountered in long_scalars\n",
      "  UCB[k] = np.sum(Z[k][0:n[k]])/n[k]+np.sqrt(2*np.log(t-tau)/n[k])\n",
      "c:\\Users\\USER\\Code\\SimulatuionByMe\\sim\\MUCB.py:241: RuntimeWarning: divide by zero encountered in log\n",
      "  UCB[k] = np.sum(Z[k][0:n[k]])/n[k]+np.sqrt(2*np.log(t-tau)/n[k])\n",
      "c:\\Users\\USER\\Code\\SimulatuionByMe\\sim\\MUCB.py:241: RuntimeWarning: invalid value encountered in sqrt\n",
      "  UCB[k] = np.sum(Z[k][0:n[k]])/n[k]+np.sqrt(2*np.log(t-tau)/n[k])\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T5000_N1_M5_envId6/arm_M-UCB($w=200$, with diminishing).png' created of size '22318b', at 'Fri Apr  5 14:58:10 2024' ...\n",
      "Saving figure with format pdf, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T5000_N1_M5_envId6/arm_M-UCB($w=200$, with diminishing).pdf'...\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T5000_N1_M5_envId6/arm_M-UCB($w=200$, with diminishing).pdf' created of size '210722b', at 'Fri Apr  5 14:58:10 2024' ...\n",
      "Saving figure with format eps, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T5000_N1_M5_envId6/arm_M-UCB($w=200$, with diminishing).eps'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T5000_N1_M5_envId6/arm_M-UCB($w=200$, with diminishing).eps' created of size '763896b', at 'Fri Apr  5 14:58:10 2024' ...\n",
      "Regret saving ...\n",
      "FileName saving ...\n",
      "Time horizon: 5000\n",
      "Number of repetitions: 1\n",
      "exploration rate = 0.15984861455217156\n",
      "Running ...M-UCB with gamma = 0.15984861455217156\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "4a6aa16728bf41afaa80a5a7b5ed2fee",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/1 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Average alarm 4.0 times\n",
      "Roll data saving ...\n",
      "Saving figure with format png, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T5000_N1_M5_envId6/arm_M-UCB($w=200$).png'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T5000_N1_M5_envId6/arm_M-UCB($w=200$).png' created of size '23248b', at 'Fri Apr  5 14:58:10 2024' ...\n",
      "Saving figure with format pdf, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T5000_N1_M5_envId6/arm_M-UCB($w=200$).pdf'...\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T5000_N1_M5_envId6/arm_M-UCB($w=200$).pdf' created of size '207286b', at 'Fri Apr  5 14:58:10 2024' ...\n",
      "Saving figure with format eps, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T5000_N1_M5_envId6/arm_M-UCB($w=200$).eps'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T5000_N1_M5_envId6/arm_M-UCB($w=200$).eps' created of size '777129b', at 'Fri Apr  5 14:58:11 2024' ...\n",
      "Regret saving ...\n",
      "FileName saving ...\n",
      "Time horizon: 5000\n",
      "Number of repetitions: 1\n",
      "Running ... ArmSwitch\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "67a288103e1049b3a890fa7e90d825cf",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/1 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "arm 0 from GOOD to BAD\n",
      "arm 1 from GOOD to BAD\n",
      "arm 2 from GOOD to BAD\n",
      "New episode\n",
      "New episode\n",
      "New episode\n",
      "New episode\n",
      "New episode\n",
      "New episode\n",
      "arm 2 from GOOD to BAD\n",
      "arm 1 from GOOD to BAD\n",
      "arm 0 from GOOD to BAD\n",
      "New episode\n",
      "New episode\n",
      "arm 0 from GOOD to BAD\n",
      "arm 1 from GOOD to BAD\n",
      "arm 2 from GOOD to BAD\n",
      "New episode\n",
      "New episode\n",
      "New episode\n",
      "arm 2 from GOOD to BAD\n",
      "arm 0 from GOOD to BAD\n",
      "Roll data saving ...\n",
      "Saving figure with format png, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T5000_N1_M5_envId6/arm_ArmSwitch.png'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T5000_N1_M5_envId6/arm_ArmSwitch.png' created of size '21292b', at 'Fri Apr  5 15:00:35 2024' ...\n",
      "Saving figure with format pdf, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T5000_N1_M5_envId6/arm_ArmSwitch.pdf'...\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T5000_N1_M5_envId6/arm_ArmSwitch.pdf' created of size '221403b', at 'Fri Apr  5 15:00:36 2024' ...\n",
      "Saving figure with format eps, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T5000_N1_M5_envId6/arm_ArmSwitch.eps'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T5000_N1_M5_envId6/arm_ArmSwitch.eps' created of size '793999b', at 'Fri Apr  5 15:00:36 2024' ...\n",
      "Regret saving ...\n",
      "FileName saving ...\n",
      "Time horizon: 5000\n",
      "Number of repetitions: 1\n",
      "Running ... AdSwitch\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "ff249449fdff4f51bdbc91bb27c819ed",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/1 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Roll data saving ...\n",
      "Saving figure with format png, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T5000_N1_M5_envId6/arm_AdSwitch.png'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T5000_N1_M5_envId6/arm_AdSwitch.png' created of size '21596b', at 'Fri Apr  5 15:03:06 2024' ...\n",
      "Saving figure with format pdf, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T5000_N1_M5_envId6/arm_AdSwitch.pdf'...\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T5000_N1_M5_envId6/arm_AdSwitch.pdf' created of size '222509b', at 'Fri Apr  5 15:03:06 2024' ...\n",
      "Saving figure with format eps, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T5000_N1_M5_envId6/arm_AdSwitch.eps'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T5000_N1_M5_envId6/arm_AdSwitch.eps' created of size '801545b', at 'Fri Apr  5 15:03:06 2024' ...\n",
      "Regret saving ...\n",
      "FileName saving ...\n",
      "['Regrets_M-UCB($w=200$, with diminishing).csv', 'Regrets_M-UCB($w=200$).csv', 'Regrets_ArmSwitch.csv', 'Regrets_AdSwitch.csv']\n",
      "['std_Regrets_M-UCB($w=200$, with diminishing).csv', 'std_Regrets_M-UCB($w=200$).csv', 'std_Regrets_ArmSwitch.csv', 'std_Regrets_AdSwitch.csv']\n",
      "{'Regrets_M-UCB($w=200$, with diminishing).csv': array([  0.8,   1.6,   2.4, ..., 130.4, 131.2, 131. ]), 'Regrets_M-UCB($w=200$).csv': array([8.000e-01, 6.000e-01, 4.000e-01, ..., 4.254e+02, 4.252e+02,\n",
      "       4.250e+02]), 'Regrets_ArmSwitch.csv': array([8.0000e-01, 1.6000e+00, 2.4000e+00, ..., 1.4734e+03, 1.4732e+03,\n",
      "       1.4730e+03]), 'Regrets_AdSwitch.csv': array([8.0000e-01, 6.0000e-01, 4.0000e-01, ..., 1.7884e+03, 1.7892e+03,\n",
      "       1.7900e+03])}\n",
      "Saving figure with format png, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T5000_N1_M5_envId6/main__Regret.png'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T5000_N1_M5_envId6/main__Regret.png' created of size '167191b', at 'Fri Apr  5 15:03:06 2024' ...\n",
      "Saving figure with format pdf, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T5000_N1_M5_envId6/main__Regret.pdf'...\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T5000_N1_M5_envId6/main__Regret.pdf' created of size '420156b', at 'Fri Apr  5 15:03:06 2024' ...\n",
      "Saving figure with format eps, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T5000_N1_M5_envId6/main__Regret.eps'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T5000_N1_M5_envId6/main__Regret.eps' created of size '1228894b', at 'Fri Apr  5 15:03:07 2024' ...\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<main.main at 0x1e2df597dc0>"
      ]
     },
     "execution_count": 1,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "from main import main\n",
    "\n",
    "main(experiment = None, horizon = 5000, repetitions = 1, envId = 6)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "==> Using K = 3 arms\n",
      "==> Using Upsilon_T = 5 change points\n",
      "==> Using the following [0, 1000, 2000, 3000, 4000] change points\n",
      "C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T5000_N50_M5_envId6 is already a directory here...\n",
      "Using sub folder = '/SP__K3_T5000_N50_M5_envId6' and plotting in 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T5000_N50_M5_envId6'...\n",
      "Delete the existing file...\n",
      "Delete the existing file...\n",
      "Time horizon: 5000\n",
      "Number of repetitions: 50\n",
      " Create environments ...\n",
      "Time horizon: 5000\n",
      "Number of repetitions: 50\n",
      "Running ...M-UCB with diminishing\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/50 [00:00<?, ?it/s]c:\\Users\\USER\\Code\\SimulatuionByMe\\sim\\MUCB.py:240: RuntimeWarning: invalid value encountered in long_scalars\n",
      "  UCB[k] = np.sum(Z[k][0:n[k]])/n[k]+np.sqrt(2*np.log(t-tau)/n[k])\n",
      "c:\\Users\\USER\\Code\\SimulatuionByMe\\sim\\MUCB.py:240: RuntimeWarning: divide by zero encountered in log\n",
      "  UCB[k] = np.sum(Z[k][0:n[k]])/n[k]+np.sqrt(2*np.log(t-tau)/n[k])\n",
      "c:\\Users\\USER\\Code\\SimulatuionByMe\\sim\\MUCB.py:240: RuntimeWarning: invalid value encountered in sqrt\n",
      "  UCB[k] = np.sum(Z[k][0:n[k]])/n[k]+np.sqrt(2*np.log(t-tau)/n[k])\n",
      "100%|██████████| 50/50 [00:04<00:00, 12.08it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Average alarm 1.56 times\n",
      "Roll data saving ...\n",
      "Saving figure with format png, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T5000_N50_M5_envId6/arm_M-UCB($w=200$, with diminishing).png'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T5000_N50_M5_envId6/arm_M-UCB($w=200$, with diminishing).png' created of size '28891b', at 'Thu Apr  4 02:02:12 2024' ...\n",
      "Saving figure with format pdf, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T5000_N50_M5_envId6/arm_M-UCB($w=200$, with diminishing).pdf'...\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T5000_N50_M5_envId6/arm_M-UCB($w=200$, with diminishing).pdf' created of size '264513b', at 'Thu Apr  4 02:02:12 2024' ...\n",
      "Saving figure with format eps, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T5000_N50_M5_envId6/arm_M-UCB($w=200$, with diminishing).eps'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T5000_N50_M5_envId6/arm_M-UCB($w=200$, with diminishing).eps' created of size '758473b', at 'Thu Apr  4 02:02:13 2024' ...\n",
      "Regret saving ...\n",
      "FileName saving ...\n",
      "Time horizon: 5000\n",
      "Number of repetitions: 50\n",
      "exploration rate = 0.15984861455217156\n",
      "Running ...M-UCB with gamma = 0.15984861455217156\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 50/50 [00:03<00:00, 13.03it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Average alarm 3.22 times\n",
      "Roll data saving ...\n",
      "Saving figure with format png, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T5000_N50_M5_envId6/arm_M-UCB($w=200$).png'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T5000_N50_M5_envId6/arm_M-UCB($w=200$).png' created of size '29891b', at 'Thu Apr  4 02:02:17 2024' ...\n",
      "Saving figure with format pdf, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T5000_N50_M5_envId6/arm_M-UCB($w=200$).pdf'...\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T5000_N50_M5_envId6/arm_M-UCB($w=200$).pdf' created of size '269163b', at 'Thu Apr  4 02:02:17 2024' ...\n",
      "Saving figure with format eps, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T5000_N50_M5_envId6/arm_M-UCB($w=200$).eps'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T5000_N50_M5_envId6/arm_M-UCB($w=200$).eps' created of size '763231b', at 'Thu Apr  4 02:02:17 2024' ...\n",
      "Regret saving ...\n",
      "FileName saving ...\n",
      "Time horizon: 5000\n",
      "Number of repetitions: 50\n",
      "Running ... AdSwitch\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "32b935a9593e45f6a4921d7b28c022b6",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/50 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Roll data saving ...\n",
      "Saving figure with format png, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T5000_N50_M5_envId6/arm_AdSwitch.png'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T5000_N50_M5_envId6/arm_AdSwitch.png' created of size '33439b', at 'Thu Apr  4 10:30:25 2024' ...\n",
      "Saving figure with format pdf, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T5000_N50_M5_envId6/arm_AdSwitch.pdf'...\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T5000_N50_M5_envId6/arm_AdSwitch.pdf' created of size '283425b', at 'Thu Apr  4 10:30:25 2024' ...\n",
      "Saving figure with format eps, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T5000_N50_M5_envId6/arm_AdSwitch.eps'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T5000_N50_M5_envId6/arm_AdSwitch.eps' created of size '750849b', at 'Thu Apr  4 10:30:25 2024' ...\n",
      "Regret saving ...\n",
      "FileName saving ...\n",
      "['Regrets_M-UCB($w=200$, with diminishing).csv', 'Regrets_M-UCB($w=200$).csv', 'Regrets_AdSwitch.csv']\n",
      "['std_Regrets_M-UCB($w=200$, with diminishing).csv', 'std_Regrets_M-UCB($w=200$).csv', 'std_Regrets_AdSwitch.csv']\n",
      "{'Regrets_M-UCB($w=200$, with diminishing).csv': array([  0.68,   1.2 ,   1.44, ..., 225.54, 225.54, 225.66]), 'Regrets_M-UCB($w=200$).csv': array([  0.68,   1.12,   1.14, ..., 405.02, 405.02, 405.2 ]), 'Regrets_AdSwitch.csv': array([6.80000e-01, 1.12000e+00, 1.14000e+00, ..., 1.93552e+03,\n",
      "       1.93578e+03, 1.93618e+03])}\n",
      "Saving figure with format png, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T5000_N50_M5_envId6/main__Regret.png'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T5000_N50_M5_envId6/main__Regret.png' created of size '210574b', at 'Thu Apr  4 10:30:25 2024' ...\n",
      "Saving figure with format pdf, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T5000_N50_M5_envId6/main__Regret.pdf'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T5000_N50_M5_envId6/main__Regret.pdf' created of size '314739b', at 'Thu Apr  4 10:30:25 2024' ...\n",
      "Saving figure with format eps, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T5000_N50_M5_envId6/main__Regret.eps'...\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T5000_N50_M5_envId6/main__Regret.eps' created of size '803653b', at 'Thu Apr  4 10:30:25 2024' ...\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<main.main at 0x1d91e1e46a0>"
      ]
     },
     "execution_count": 1,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# from main import main\n",
    "\n",
    "# main(experiment = \"M\", horizon = 20000, repetitions = 100, envId = 6)\n",
    "# main(experiment = \"T\", horizon = 20000, repetitions = 50, envId = 5)\n",
    "from main import main\n",
    "\n",
    "main(experiment = None, horizon = 5000, repetitions = 50, envId = 6)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['Regrets_Discounted-TS (0.75).csv', 'Regrets_Discounted-klUCB (0.75).csv', 'Regrets_M-UCB($w=200$, with diminishing).csv', 'Regrets_M-UCB($w=200$).csv', 'Regrets_GLR-UCB(with unknown change point).csv', 'Regrets_CUSUM-UCB.csv', 'Regrets_CUSUM-UCB(with diminishing).csv']\n",
      "['std_Regrets_Discounted-TS (0.75).csv', 'std_Regrets_Discounted-klUCB (0.75).csv', 'std_Regrets_M-UCB($w=200$, with diminishing).csv', 'std_Regrets_M-UCB($w=200$).csv', 'std_Regrets_GLR-UCB(with unknown change point).csv', 'std_Regrets_CUSUM-UCB.csv', 'std_Regrets_CUSUM-UCB(with diminishing).csv']\n",
      "{'Regrets_Discounted-TS (0.75).csv': array([2.60000e-01, 5.10000e-01, 7.80000e-01, ..., 3.91520e+03,\n",
      "       3.91542e+03, 3.91555e+03]), 'Regrets_Discounted-klUCB (0.75).csv': array([3.20000e-01, 5.60000e-01, 7.30000e-01, ..., 3.48518e+03,\n",
      "       3.48540e+03, 3.48557e+03]), 'Regrets_M-UCB($w=200$, with diminishing).csv': array([  0.58      ,   1.21      ,   1.49      , ..., 457.87999999,\n",
      "       457.94999999, 457.95999999]), 'Regrets_M-UCB($w=200$).csv': array([5.8000e-01, 8.4000e-01, 7.8000e-01, ..., 8.4304e+02, 8.4311e+02,\n",
      "       8.4314e+02]), 'Regrets_GLR-UCB(with unknown change point).csv': array([  0.58      ,   0.84      ,   0.78      , ..., 506.32999999,\n",
      "       506.38999999, 506.41999999]), 'Regrets_CUSUM-UCB.csv': array([5.8000e-01, 8.4000e-01, 7.8000e-01, ..., 9.2088e+02, 9.2098e+02,\n",
      "       9.2101e+02]), 'Regrets_CUSUM-UCB(with diminishing).csv': array([5.8000e-01, 1.2100e+00, 1.4900e+00, ..., 7.2737e+02, 7.2742e+02,\n",
      "       7.2746e+02])}\n",
      "Saving figure with format png, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T20000_N100_M5_envId6/main__Regret.png'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T20000_N100_M5_envId6/main__Regret.png' created of size '244780b', at 'Sat Jan 27 22:17:05 2024' ...\n",
      "Saving figure with format pdf, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T20000_N100_M5_envId6/main__Regret.pdf'...\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T20000_N100_M5_envId6/main__Regret.pdf' created of size '2525115b', at 'Sat Jan 27 22:17:06 2024' ...\n",
      "Saving figure with format eps, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T20000_N100_M5_envId6/main__Regret.eps'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T20000_N100_M5_envId6/main__Regret.eps' created of size '6951471b', at 'Sat Jan 27 22:17:06 2024' ...\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "from Environment import Environment\n",
    "from MUCB import MUCB\n",
    "from CUSUM_UCB import CusumUCB\n",
    "from GLR_UCB import GLRUCB\n",
    "from klUCB import klUCB\n",
    "from Oracle_klUCB import OracleklUCB\n",
    "from DTS import DTS\n",
    "from DklUCB import DklUCB\n",
    "from AdSwitch import AdSwitch\n",
    "from plot import Plot\n",
    "import os, os.path\n",
    "import matplotlib.pyplot as mpl\n",
    "from generate_instance import Regret_versus_K\n",
    "\n",
    "plot_dir = \"C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T20000_N100_M5_envId6\"\n",
    "mpl.rcParams['figure.dpi'] = 100\n",
    "mpl.rcParams['figure.figsize'] = (20,10)\n",
    "mainfig = plot_dir + \"/main\"\n",
    "if mainfig is not None: mainfig = \"{}__Regret\".format(mainfig)\n",
    "mpl.rcParams['figure.figsize'] = (12,8)\n",
    "mpl.rcParams['figure.dpi'] = 200\n",
    "plotfig = Plot()\n",
    "fig = plotfig.plotMyRegret(savefig = mainfig, path = plot_dir)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "sim",
   "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.10.11"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
