{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "==> Using K = 3 arms\n",
      "==> Using Upsilon_T = 20 change points\n",
      "==> Using the following [0, 1000, 2000, 3000, 4000, 5000, 6000, 7000, 8000, 9000, 10000, 11000, 12000, 13000, 14000, 15000, 16000, 17000, 18000, 19000] change points\n",
      "Using sub folder = '/SP__M20_K3_N50_T_scaling_envId8' and plotting in 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8'...\n",
      "Time horizon: 20000\n",
      "Number of repetitions: 50\n",
      "Number of repetitions: 50\n",
      "[[0.2 0.5 0.8]\n",
      " [0.5 0.8 0.2]\n",
      " [0.8 0.2 0.5]\n",
      " [0.2 0.5 0.8]\n",
      " [0.5 0.8 0.2]\n",
      " [0.2 0.5 0.8]\n",
      " [0.5 0.8 0.2]\n",
      " [0.8 0.2 0.5]\n",
      " [0.2 0.5 0.8]\n",
      " [0.5 0.8 0.2]\n",
      " [0.8 0.2 0.5]\n",
      " [0.2 0.5 0.8]\n",
      " [0.5 0.8 0.2]\n",
      " [0.2 0.5 0.8]\n",
      " [0.5 0.8 0.2]\n",
      " [0.8 0.2 0.5]\n",
      " [0.2 0.5 0.8]\n",
      " [0.5 0.8 0.2]\n",
      " [0.2 0.5 0.8]\n",
      " [0.5 0.8 0.2]]\n",
      " Create environments ...\n",
      "[[0.2, 0.5, 0.8], [0.5, 0.8, 0.2], [0.8, 0.2, 0.5], [0.2, 0.5, 0.8], [0.5, 0.8, 0.2], [0.2, 0.5, 0.8], [0.5, 0.8, 0.2], [0.8, 0.2, 0.5], [0.2, 0.5, 0.8], [0.5, 0.8, 0.2], [0.8, 0.2, 0.5], [0.2, 0.5, 0.8], [0.5, 0.8, 0.2], [0.2, 0.5, 0.8], [0.5, 0.8, 0.2], [0.8, 0.2, 0.5], [0.2, 0.5, 0.8], [0.5, 0.8, 0.2], [0.2, 0.5, 0.8], [0.5, 0.8, 0.2]]\n",
      " Create environments ...\n",
      "[[0.2, 0.5, 0.8], [0.5, 0.8, 0.2], [0.8, 0.2, 0.5], [0.2, 0.5, 0.8], [0.5, 0.8, 0.2], [0.2, 0.5, 0.8], [0.5, 0.8, 0.2], [0.8, 0.2, 0.5], [0.2, 0.5, 0.8], [0.5, 0.8, 0.2], [0.8, 0.2, 0.5], [0.2, 0.5, 0.8], [0.5, 0.8, 0.2], [0.2, 0.5, 0.8], [0.5, 0.8, 0.2], [0.8, 0.2, 0.5], [0.2, 0.5, 0.8], [0.5, 0.8, 0.2], [0.2, 0.5, 0.8], [0.5, 0.8, 0.2]]\n",
      " Create environments ...\n",
      "[[0.2, 0.5, 0.8], [0.5, 0.8, 0.2], [0.8, 0.2, 0.5], [0.2, 0.5, 0.8], [0.5, 0.8, 0.2], [0.2, 0.5, 0.8], [0.5, 0.8, 0.2], [0.8, 0.2, 0.5], [0.2, 0.5, 0.8], [0.5, 0.8, 0.2], [0.8, 0.2, 0.5], [0.2, 0.5, 0.8], [0.5, 0.8, 0.2], [0.2, 0.5, 0.8], [0.5, 0.8, 0.2], [0.8, 0.2, 0.5], [0.2, 0.5, 0.8], [0.5, 0.8, 0.2], [0.2, 0.5, 0.8], [0.5, 0.8, 0.2]]\n",
      " Create environments ...\n",
      "[[0.2, 0.5, 0.8], [0.5, 0.8, 0.2], [0.8, 0.2, 0.5], [0.2, 0.5, 0.8], [0.5, 0.8, 0.2], [0.2, 0.5, 0.8], [0.5, 0.8, 0.2], [0.8, 0.2, 0.5], [0.2, 0.5, 0.8], [0.5, 0.8, 0.2], [0.8, 0.2, 0.5], [0.2, 0.5, 0.8], [0.5, 0.8, 0.2], [0.2, 0.5, 0.8], [0.5, 0.8, 0.2], [0.8, 0.2, 0.5], [0.2, 0.5, 0.8], [0.5, 0.8, 0.2], [0.2, 0.5, 0.8], [0.5, 0.8, 0.2]]\n",
      " Create environments ...\n",
      "[[0.2, 0.5, 0.8], [0.5, 0.8, 0.2], [0.8, 0.2, 0.5], [0.2, 0.5, 0.8], [0.5, 0.8, 0.2], [0.2, 0.5, 0.8], [0.5, 0.8, 0.2], [0.8, 0.2, 0.5], [0.2, 0.5, 0.8], [0.5, 0.8, 0.2], [0.8, 0.2, 0.5], [0.2, 0.5, 0.8], [0.5, 0.8, 0.2], [0.2, 0.5, 0.8], [0.5, 0.8, 0.2], [0.8, 0.2, 0.5], [0.2, 0.5, 0.8], [0.5, 0.8, 0.2], [0.2, 0.5, 0.8], [0.5, 0.8, 0.2]]\n",
      " Create environments ...\n",
      "Regret saving ...\n",
      "Time horizon: 20000\n",
      "Number of repetitions: 50\n",
      "Running ...<bound method DTS.__str__ of <DTS.DTS object at 0x000002B4C1B39480>> for T = 2000\n",
      "Running ... Discounted TS\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 50/50 [00:01<00:00, 45.34it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Saving figure with format png, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_Discounted-TS (0.75)_T=2000.png'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_Discounted-TS (0.75)_T=2000.png' created of size '33944b', at 'Sun Jan 28 11:33:23 2024' ...\n",
      "Saving figure with format pdf, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_Discounted-TS (0.75)_T=2000.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__M20_K3_N50_T_scaling_envId8/arm_Discounted-TS (0.75)_T=2000.pdf' created of size '131457b', at 'Sun Jan 28 11:33:23 2024' ...\n",
      "Saving figure with format eps, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_Discounted-TS (0.75)_T=2000.eps'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_Discounted-TS (0.75)_T=2000.eps' created of size '326666b', at 'Sun Jan 28 11:33:24 2024' ...\n",
      "Running ...<bound method DTS.__str__ of <DTS.DTS object at 0x000002B4C1B39480>> for T = 5000\n",
      "Running ... Discounted TS\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 50/50 [00:02<00:00, 16.79it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Saving figure with format png, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_Discounted-TS (0.75)_T=5000.png'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_Discounted-TS (0.75)_T=5000.png' created of size '30232b', at 'Sun Jan 28 11:33:27 2024' ...\n",
      "Saving figure with format pdf, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_Discounted-TS (0.75)_T=5000.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__M20_K3_N50_T_scaling_envId8/arm_Discounted-TS (0.75)_T=5000.pdf' created of size '289193b', at 'Sun Jan 28 11:33:27 2024' ...\n",
      "Saving figure with format eps, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_Discounted-TS (0.75)_T=5000.eps'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_Discounted-TS (0.75)_T=5000.eps' created of size '763357b', at 'Sun Jan 28 11:33:27 2024' ...\n",
      "Running ...<bound method DTS.__str__ of <DTS.DTS object at 0x000002B4C1B39480>> for T = 10000\n",
      "Running ... Discounted TS\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 50/50 [00:06<00:00,  8.03it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Saving figure with format png, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_Discounted-TS (0.75)_T=10000.png'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_Discounted-TS (0.75)_T=10000.png' created of size '27830b', at 'Sun Jan 28 11:33:33 2024' ...\n",
      "Saving figure with format pdf, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_Discounted-TS (0.75)_T=10000.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__M20_K3_N50_T_scaling_envId8/arm_Discounted-TS (0.75)_T=10000.pdf' created of size '541120b', at 'Sun Jan 28 11:33:34 2024' ...\n",
      "Saving figure with format eps, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_Discounted-TS (0.75)_T=10000.eps'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_Discounted-TS (0.75)_T=10000.eps' created of size '1497294b', at 'Sun Jan 28 11:33:34 2024' ...\n",
      "Running ...<bound method DTS.__str__ of <DTS.DTS object at 0x000002B4C1B39480>> for T = 20000\n",
      "Running ... Discounted TS\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 50/50 [00:10<00:00,  4.63it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Saving figure with format png, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_Discounted-TS (0.75)_T=20000.png'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_Discounted-TS (0.75)_T=20000.png' created of size '26354b', at 'Sun Jan 28 11:33:45 2024' ...\n",
      "Saving figure with format pdf, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_Discounted-TS (0.75)_T=20000.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__M20_K3_N50_T_scaling_envId8/arm_Discounted-TS (0.75)_T=20000.pdf' created of size '1060653b', at 'Sun Jan 28 11:33:45 2024' ...\n",
      "Saving figure with format eps, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_Discounted-TS (0.75)_T=20000.eps'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_Discounted-TS (0.75)_T=20000.eps' created of size '2963799b', at 'Sun Jan 28 11:33:45 2024' ...\n",
      "Running ...<bound method DTS.__str__ of <DTS.DTS object at 0x000002B4C1B39480>> for T = 50000\n",
      "Running ... Discounted TS\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 50/50 [00:23<00:00,  2.10it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Saving figure with format png, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_Discounted-TS (0.75)_T=50000.png'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_Discounted-TS (0.75)_T=50000.png' created of size '24546b', at 'Sun Jan 28 11:34:09 2024' ...\n",
      "Saving figure with format pdf, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_Discounted-TS (0.75)_T=50000.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__M20_K3_N50_T_scaling_envId8/arm_Discounted-TS (0.75)_T=50000.pdf' created of size '2423561b', at 'Sun Jan 28 11:34:10 2024' ...\n",
      "Saving figure with format eps, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_Discounted-TS (0.75)_T=50000.eps'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_Discounted-TS (0.75)_T=50000.eps' created of size '7367375b', at 'Sun Jan 28 11:34:11 2024' ...\n",
      "Running ...<bound method DTS.__str__ of <DTS.DTS object at 0x000002B4C1B39480>> for T = 100000\n",
      "Running ... Discounted TS\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 50/50 [00:44<00:00,  1.13it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Saving figure with format png, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_Discounted-TS (0.75)_T=100000.png'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_Discounted-TS (0.75)_T=100000.png' created of size '24101b', at 'Sun Jan 28 11:34:55 2024' ...\n",
      "Saving figure with format pdf, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_Discounted-TS (0.75)_T=100000.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__M20_K3_N50_T_scaling_envId8/arm_Discounted-TS (0.75)_T=100000.pdf' created of size '4562433b', at 'Sun Jan 28 11:34:57 2024' ...\n",
      "Saving figure with format eps, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_Discounted-TS (0.75)_T=100000.eps'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_Discounted-TS (0.75)_T=100000.eps' created of size '14708278b', at 'Sun Jan 28 11:34:57 2024' ...\n",
      "Regret saving ...\n",
      "FileName saving ...\n",
      "Time horizon: 20000\n",
      "Number of repetitions: 50\n",
      "Running ...<bound method DklUCB.__str__ of <DklUCB.DklUCB object at 0x000002B4C1B396C0>> for T = 2000\n",
      "Running ... Discounted klUCB\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 50/50 [00:13<00:00,  3.62it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Saving figure with format png, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_Discounted-klUCB (0.75)_T=2000.png'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_Discounted-klUCB (0.75)_T=2000.png' created of size '32491b', at 'Sun Jan 28 11:35:11 2024' ...\n",
      "Saving figure with format pdf, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_Discounted-klUCB (0.75)_T=2000.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__M20_K3_N50_T_scaling_envId8/arm_Discounted-klUCB (0.75)_T=2000.pdf' created of size '131265b', at 'Sun Jan 28 11:35:11 2024' ...\n",
      "Saving figure with format eps, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_Discounted-klUCB (0.75)_T=2000.eps'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_Discounted-klUCB (0.75)_T=2000.eps' created of size '326344b', at 'Sun Jan 28 11:35:11 2024' ...\n",
      "Running ...<bound method DklUCB.__str__ of <DklUCB.DklUCB object at 0x000002B4C1B396C0>> for T = 5000\n",
      "Running ... Discounted klUCB\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 50/50 [00:30<00:00,  1.64it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Saving figure with format png, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_Discounted-klUCB (0.75)_T=5000.png'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_Discounted-klUCB (0.75)_T=5000.png' created of size '29753b', at 'Sun Jan 28 11:35:42 2024' ...\n",
      "Saving figure with format pdf, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_Discounted-klUCB (0.75)_T=5000.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__M20_K3_N50_T_scaling_envId8/arm_Discounted-klUCB (0.75)_T=5000.pdf' created of size '289147b', at 'Sun Jan 28 11:35:42 2024' ...\n",
      "Saving figure with format eps, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_Discounted-klUCB (0.75)_T=5000.eps'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_Discounted-klUCB (0.75)_T=5000.eps' created of size '761979b', at 'Sun Jan 28 11:35:42 2024' ...\n",
      "Running ...<bound method DklUCB.__str__ of <DklUCB.DklUCB object at 0x000002B4C1B396C0>> for T = 10000\n",
      "Running ... Discounted klUCB\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 50/50 [00:58<00:00,  1.18s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Saving figure with format png, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_Discounted-klUCB (0.75)_T=10000.png'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_Discounted-klUCB (0.75)_T=10000.png' created of size '27624b', at 'Sun Jan 28 11:36:41 2024' ...\n",
      "Saving figure with format pdf, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_Discounted-klUCB (0.75)_T=10000.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__M20_K3_N50_T_scaling_envId8/arm_Discounted-klUCB (0.75)_T=10000.pdf' created of size '543965b', at 'Sun Jan 28 11:36:42 2024' ...\n",
      "Saving figure with format eps, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_Discounted-klUCB (0.75)_T=10000.eps'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_Discounted-klUCB (0.75)_T=10000.eps' created of size '1497532b', at 'Sun Jan 28 11:36:42 2024' ...\n",
      "Running ...<bound method DklUCB.__str__ of <DklUCB.DklUCB object at 0x000002B4C1B396C0>> for T = 20000\n",
      "Running ... Discounted klUCB\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 50/50 [02:01<00:00,  2.42s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Saving figure with format png, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_Discounted-klUCB (0.75)_T=20000.png'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_Discounted-klUCB (0.75)_T=20000.png' created of size '26244b', at 'Sun Jan 28 11:38:43 2024' ...\n",
      "Saving figure with format pdf, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_Discounted-klUCB (0.75)_T=20000.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__M20_K3_N50_T_scaling_envId8/arm_Discounted-klUCB (0.75)_T=20000.pdf' created of size '1067284b', at 'Sun Jan 28 11:38:43 2024' ...\n",
      "Saving figure with format eps, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_Discounted-klUCB (0.75)_T=20000.eps'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_Discounted-klUCB (0.75)_T=20000.eps' created of size '2964863b', at 'Sun Jan 28 11:38:43 2024' ...\n",
      "Running ...<bound method DklUCB.__str__ of <DklUCB.DklUCB object at 0x000002B4C1B396C0>> for T = 50000\n",
      "Running ... Discounted klUCB\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 50/50 [05:00<00:00,  6.01s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Saving figure with format png, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_Discounted-klUCB (0.75)_T=50000.png'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_Discounted-klUCB (0.75)_T=50000.png' created of size '25140b', at 'Sun Jan 28 11:43:44 2024' ...\n",
      "Saving figure with format pdf, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_Discounted-klUCB (0.75)_T=50000.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__M20_K3_N50_T_scaling_envId8/arm_Discounted-klUCB (0.75)_T=50000.pdf' created of size '2460941b', at 'Sun Jan 28 11:43:45 2024' ...\n",
      "Saving figure with format eps, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_Discounted-klUCB (0.75)_T=50000.eps'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_Discounted-klUCB (0.75)_T=50000.eps' created of size '7368731b', at 'Sun Jan 28 11:43:45 2024' ...\n",
      "Running ...<bound method DklUCB.__str__ of <DklUCB.DklUCB object at 0x000002B4C1B396C0>> for T = 100000\n",
      "Running ... Discounted klUCB\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 50/50 [10:55<00:00, 13.11s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Saving figure with format png, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_Discounted-klUCB (0.75)_T=100000.png'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_Discounted-klUCB (0.75)_T=100000.png' created of size '24362b', at 'Sun Jan 28 11:54:41 2024' ...\n",
      "Saving figure with format pdf, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_Discounted-klUCB (0.75)_T=100000.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__M20_K3_N50_T_scaling_envId8/arm_Discounted-klUCB (0.75)_T=100000.pdf' created of size '4673370b', at 'Sun Jan 28 11:54:43 2024' ...\n",
      "Saving figure with format eps, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_Discounted-klUCB (0.75)_T=100000.eps'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_Discounted-klUCB (0.75)_T=100000.eps' created of size '14710116b', at 'Sun Jan 28 11:54:44 2024' ...\n",
      "Regret saving ...\n",
      "FileName saving ...\n",
      "Time horizon: 20000\n",
      "Number of repetitions: 50\n",
      "Running ...<bound method MUCB.__str__ of <MUCB.MUCB object at 0x000002B4C1B395A0>> for T = 2000\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:235: 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:235: 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:235: 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",
      "c:\\Users\\USER\\Code\\SimulatuionByMe\\sim\\MUCB.py:235: RuntimeWarning: invalid value encountered in double_scalars\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:02<00:00, 16.84it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Average alarm 0.0 times\n",
      "Saving figure with format png, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$, with diminishing)_T=2000.png'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$, with diminishing)_T=2000.png' created of size '32234b', at 'Sun Jan 28 11:54:47 2024' ...\n",
      "Saving figure with format pdf, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$, with diminishing)_T=2000.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__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$, with diminishing)_T=2000.pdf' created of size '124978b', at 'Sun Jan 28 11:54:47 2024' ...\n",
      "Saving figure with format eps, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$, with diminishing)_T=2000.eps'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$, with diminishing)_T=2000.eps' created of size '327477b', at 'Sun Jan 28 11:54:47 2024' ...\n",
      "Running ...<bound method MUCB.__str__ of <MUCB.MUCB object at 0x000002B4C1B395A0>> for T = 5000\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:235: 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:235: 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:235: 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",
      "c:\\Users\\USER\\Code\\SimulatuionByMe\\sim\\MUCB.py:235: RuntimeWarning: invalid value encountered in double_scalars\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:07<00:00,  6.52it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Average alarm 0.36 times\n",
      "Saving figure with format png, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$, with diminishing)_T=5000.png'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$, with diminishing)_T=5000.png' created of size '29166b', at 'Sun Jan 28 11:54:55 2024' ...\n",
      "Saving figure with format pdf, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$, with diminishing)_T=5000.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__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$, with diminishing)_T=5000.pdf' created of size '271288b', at 'Sun Jan 28 11:54:55 2024' ...\n",
      "Saving figure with format eps, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$, with diminishing)_T=5000.eps'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$, with diminishing)_T=5000.eps' created of size '760265b', at 'Sun Jan 28 11:54:55 2024' ...\n",
      "Running ...<bound method MUCB.__str__ of <MUCB.MUCB object at 0x000002B4C1B395A0>> for T = 10000\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:235: 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:235: 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:235: 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",
      "c:\\Users\\USER\\Code\\SimulatuionByMe\\sim\\MUCB.py:235: RuntimeWarning: invalid value encountered in double_scalars\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:14<00:00,  3.39it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Average alarm 1.94 times\n",
      "Saving figure with format png, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$, with diminishing)_T=10000.png'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$, with diminishing)_T=10000.png' created of size '28422b', at 'Sun Jan 28 11:55:10 2024' ...\n",
      "Saving figure with format pdf, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$, with diminishing)_T=10000.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__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$, with diminishing)_T=10000.pdf' created of size '509419b', at 'Sun Jan 28 11:55:11 2024' ...\n",
      "Saving figure with format eps, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$, with diminishing)_T=10000.eps'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$, with diminishing)_T=10000.eps' created of size '1492814b', at 'Sun Jan 28 11:55:11 2024' ...\n",
      "Running ...<bound method MUCB.__str__ of <MUCB.MUCB object at 0x000002B4C1B395A0>> for T = 20000\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:235: 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:235: 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:235: 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",
      "c:\\Users\\USER\\Code\\SimulatuionByMe\\sim\\MUCB.py:235: RuntimeWarning: invalid value encountered in double_scalars\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:27<00:00,  1.80it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Average alarm 5.66 times\n",
      "Saving figure with format png, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$, with diminishing)_T=20000.png'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$, with diminishing)_T=20000.png' created of size '27477b', at 'Sun Jan 28 11:55:39 2024' ...\n",
      "Saving figure with format pdf, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$, with diminishing)_T=20000.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__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$, with diminishing)_T=20000.pdf' created of size '998528b', at 'Sun Jan 28 11:55:39 2024' ...\n",
      "Saving figure with format eps, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$, with diminishing)_T=20000.eps'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$, with diminishing)_T=20000.eps' created of size '2961460b', at 'Sun Jan 28 11:55:39 2024' ...\n",
      "Running ...<bound method MUCB.__str__ of <MUCB.MUCB object at 0x000002B4C1B395A0>> for T = 50000\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:235: 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:235: 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:235: 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",
      "c:\\Users\\USER\\Code\\SimulatuionByMe\\sim\\MUCB.py:235: RuntimeWarning: invalid value encountered in double_scalars\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 [01:10<00:00,  1.41s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Average alarm 11.2 times\n",
      "Saving figure with format png, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$, with diminishing)_T=50000.png'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$, with diminishing)_T=50000.png' created of size '22739b', at 'Sun Jan 28 11:56:50 2024' ...\n",
      "Saving figure with format pdf, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$, with diminishing)_T=50000.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__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$, with diminishing)_T=50000.pdf' created of size '2242422b', at 'Sun Jan 28 11:56:51 2024' ...\n",
      "Saving figure with format eps, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$, with diminishing)_T=50000.eps'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$, with diminishing)_T=50000.eps' created of size '7364993b', at 'Sun Jan 28 11:56:51 2024' ...\n",
      "Running ...<bound method MUCB.__str__ of <MUCB.MUCB object at 0x000002B4C1B395A0>> for T = 100000\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:235: 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:235: 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:235: 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",
      "c:\\Users\\USER\\Code\\SimulatuionByMe\\sim\\MUCB.py:235: RuntimeWarning: invalid value encountered in double_scalars\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 [02:11<00:00,  2.62s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Average alarm 14.24 times\n",
      "Saving figure with format png, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$, with diminishing)_T=100000.png'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$, with diminishing)_T=100000.png' created of size '24070b', at 'Sun Jan 28 11:59:03 2024' ...\n",
      "Saving figure with format pdf, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$, with diminishing)_T=100000.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__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$, with diminishing)_T=100000.pdf' created of size '4043600b', at 'Sun Jan 28 11:59:04 2024' ...\n",
      "Saving figure with format eps, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$, with diminishing)_T=100000.eps'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$, with diminishing)_T=100000.eps' created of size '14700635b', at 'Sun Jan 28 11:59:05 2024' ...\n",
      "Regret saving ...\n",
      "FileName saving ...\n",
      "Time horizon: 20000\n",
      "Number of repetitions: 50\n",
      "Running ...<bound method MUCB.__str__ of <MUCB.MUCB object at 0x000002B4CAC48490>> for T = 2000\n",
      "exploration rate = 0.47752180451395354\n",
      "Running ...M-UCB with gamma = 0.47752180451395354\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 50/50 [00:02<00:00, 23.90it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Average alarm 0.18 times\n",
      "Saving figure with format png, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$)_T=2000.png'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$)_T=2000.png' created of size '32163b', at 'Sun Jan 28 11:59:07 2024' ...\n",
      "Saving figure with format pdf, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$)_T=2000.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__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$)_T=2000.pdf' created of size '129967b', at 'Sun Jan 28 11:59:07 2024' ...\n",
      "Saving figure with format eps, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$)_T=2000.eps'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$)_T=2000.eps' created of size '368253b', at 'Sun Jan 28 11:59:08 2024' ...\n",
      "Running ...<bound method MUCB.__str__ of <MUCB.MUCB object at 0x000002B4CAC48490>> for T = 5000\n",
      "exploration rate = 0.3196972291043431\n",
      "Running ...M-UCB with gamma = 0.3196972291043431\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 50/50 [00:05<00:00,  9.77it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Average alarm 5.22 times\n",
      "Saving figure with format png, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$)_T=5000.png'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$)_T=5000.png' created of size '32266b', at 'Sun Jan 28 11:59:13 2024' ...\n",
      "Saving figure with format pdf, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$)_T=5000.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__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$)_T=5000.pdf' created of size '284819b', at 'Sun Jan 28 11:59:13 2024' ...\n",
      "Saving figure with format eps, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$)_T=5000.eps'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$)_T=5000.eps' created of size '764875b', at 'Sun Jan 28 11:59:13 2024' ...\n",
      "Running ...<bound method MUCB.__str__ of <MUCB.MUCB object at 0x000002B4CAC48490>> for T = 10000\n",
      "exploration rate = 0.23507880004767998\n",
      "Running ...M-UCB with gamma = 0.23507880004767998\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 50/50 [00:11<00:00,  4.23it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Average alarm 8.82 times\n",
      "Saving figure with format png, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$)_T=10000.png'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$)_T=10000.png' created of size '30075b', at 'Sun Jan 28 11:59:25 2024' ...\n",
      "Saving figure with format pdf, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$)_T=10000.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__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$)_T=10000.pdf' created of size '534893b', at 'Sun Jan 28 11:59:25 2024' ...\n",
      "Saving figure with format eps, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$)_T=10000.eps'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$)_T=10000.eps' created of size '1497569b', at 'Sun Jan 28 11:59:26 2024' ...\n",
      "Running ...<bound method MUCB.__str__ of <MUCB.MUCB object at 0x000002B4CAC48490>> for T = 20000\n",
      "exploration rate = 0.1723672319717654\n",
      "Running ...M-UCB with gamma = 0.1723672319717654\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 50/50 [00:25<00:00,  1.94it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Average alarm 12.9 times\n",
      "Saving figure with format png, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$)_T=20000.png'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$)_T=20000.png' created of size '27483b', at 'Sun Jan 28 11:59:52 2024' ...\n",
      "Saving figure with format pdf, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$)_T=20000.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__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$)_T=20000.pdf' created of size '1043609b', at 'Sun Jan 28 11:59:52 2024' ...\n",
      "Saving figure with format eps, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$)_T=20000.eps'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$)_T=20000.eps' created of size '2962686b', at 'Sun Jan 28 11:59:52 2024' ...\n",
      "Running ...<bound method MUCB.__str__ of <MUCB.MUCB object at 0x000002B4CAC48490>> for T = 50000\n",
      "exploration rate = 0.11394618879669623\n",
      "Running ...M-UCB with gamma = 0.11394618879669623\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 50/50 [01:10<00:00,  1.40s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Average alarm 18.48 times\n",
      "Saving figure with format png, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$)_T=50000.png'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$)_T=50000.png' created of size '25694b', at 'Sun Jan 28 12:01:03 2024' ...\n",
      "Saving figure with format pdf, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$)_T=50000.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__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$)_T=50000.pdf' created of size '2358462b', at 'Sun Jan 28 12:01:04 2024' ...\n",
      "Saving figure with format eps, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$)_T=50000.eps'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$)_T=50000.eps' created of size '7345410b', at 'Sun Jan 28 12:01:04 2024' ...\n",
      "Running ...<bound method MUCB.__str__ of <MUCB.MUCB object at 0x000002B4CAC48490>> for T = 100000\n",
      "exploration rate = 0.0831129068134555\n",
      "Running ...M-UCB with gamma = 0.0831129068134555\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 50/50 [02:10<00:00,  2.61s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Average alarm 18.68 times\n",
      "Saving figure with format png, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$)_T=100000.png'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$)_T=100000.png' created of size '23067b', at 'Sun Jan 28 12:03:15 2024' ...\n",
      "Saving figure with format pdf, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$)_T=100000.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__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$)_T=100000.pdf' created of size '4349701b', at 'Sun Jan 28 12:03:16 2024' ...\n",
      "Saving figure with format eps, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$)_T=100000.eps'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_M-UCB($w=200$)_T=100000.eps' created of size '14659942b', at 'Sun Jan 28 12:03:17 2024' ...\n",
      "Regret saving ...\n",
      "FileName saving ...\n",
      "Time horizon: 20000\n",
      "Number of repetitions: 50\n",
      "Running ...<bound method GLRUCB.__str__ of <GLR_UCB.GLRUCB object at 0x000002B4CE55B8E0>> for T = 2000\n",
      "Running ...GLR-UCB with alpha0 = 0.06164779987778186\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/50 [00:00<?, ?it/s]c:\\Users\\USER\\Code\\SimulatuionByMe\\sim\\GLR_UCB.py:456: RuntimeWarning: divide by zero encountered in double_scalars\n",
      "  res = p * np.log(p / q) + (1 - p) * np.log((1 - p) / (1 - q))\n",
      "100%|██████████| 50/50 [00:04<00:00, 10.29it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Average alarm 3.78 times\n",
      "Saving figure with format png, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_GLR-UCB(with unknown change point)_T=2000.png'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_GLR-UCB(with unknown change point)_T=2000.png' created of size '32926b', at 'Sun Jan 28 12:03:22 2024' ...\n",
      "Saving figure with format pdf, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_GLR-UCB(with unknown change point)_T=2000.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__M20_K3_N50_T_scaling_envId8/arm_GLR-UCB(with unknown change point)_T=2000.pdf' created of size '129359b', at 'Sun Jan 28 12:03:22 2024' ...\n",
      "Saving figure with format eps, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_GLR-UCB(with unknown change point)_T=2000.eps'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_GLR-UCB(with unknown change point)_T=2000.eps' created of size '324581b', at 'Sun Jan 28 12:03:22 2024' ...\n",
      "Running ...<bound method GLRUCB.__str__ of <GLR_UCB.GLRUCB object at 0x000002B4CE55B8E0>> for T = 5000\n",
      "Running ...GLR-UCB with alpha0 = 0.0412727348049926\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/50 [00:00<?, ?it/s]c:\\Users\\USER\\Code\\SimulatuionByMe\\sim\\GLR_UCB.py:456: RuntimeWarning: divide by zero encountered in double_scalars\n",
      "  res = p * np.log(p / q) + (1 - p) * np.log((1 - p) / (1 - q))\n",
      "100%|██████████| 50/50 [00:10<00:00,  4.97it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Average alarm 12.56 times\n",
      "Saving figure with format png, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_GLR-UCB(with unknown change point)_T=5000.png'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_GLR-UCB(with unknown change point)_T=5000.png' created of size '30126b', at 'Sun Jan 28 12:03:32 2024' ...\n",
      "Saving figure with format pdf, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_GLR-UCB(with unknown change point)_T=5000.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__M20_K3_N50_T_scaling_envId8/arm_GLR-UCB(with unknown change point)_T=5000.pdf' created of size '285772b', at 'Sun Jan 28 12:03:32 2024' ...\n",
      "Saving figure with format eps, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_GLR-UCB(with unknown change point)_T=5000.eps'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_GLR-UCB(with unknown change point)_T=5000.eps' created of size '760674b', at 'Sun Jan 28 12:03:32 2024' ...\n",
      "Running ...<bound method GLRUCB.__str__ of <GLR_UCB.GLRUCB object at 0x000002B4CE55B8E0>> for T = 10000\n",
      "Running ...GLR-UCB with alpha0 = 0.03034854258770293\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/50 [00:00<?, ?it/s]c:\\Users\\USER\\Code\\SimulatuionByMe\\sim\\GLR_UCB.py:456: RuntimeWarning: divide by zero encountered in double_scalars\n",
      "  res = p * np.log(p / q) + (1 - p) * np.log((1 - p) / (1 - q))\n",
      "100%|██████████| 50/50 [00:24<00:00,  2.01it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Average alarm 19.92 times\n",
      "Saving figure with format png, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_GLR-UCB(with unknown change point)_T=10000.png'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_GLR-UCB(with unknown change point)_T=10000.png' created of size '27466b', at 'Sun Jan 28 12:03:57 2024' ...\n",
      "Saving figure with format pdf, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_GLR-UCB(with unknown change point)_T=10000.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__M20_K3_N50_T_scaling_envId8/arm_GLR-UCB(with unknown change point)_T=10000.pdf' created of size '532520b', at 'Sun Jan 28 12:03:58 2024' ...\n",
      "Saving figure with format eps, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_GLR-UCB(with unknown change point)_T=10000.eps'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_GLR-UCB(with unknown change point)_T=10000.eps' created of size '1494238b', at 'Sun Jan 28 12:03:58 2024' ...\n",
      "Running ...<bound method GLRUCB.__str__ of <GLR_UCB.GLRUCB object at 0x000002B4CE55B8E0>> for T = 20000\n",
      "Running ...GLR-UCB with alpha0 = 0.0222525139619506\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/50 [00:00<?, ?it/s]c:\\Users\\USER\\Code\\SimulatuionByMe\\sim\\GLR_UCB.py:456: RuntimeWarning: divide by zero encountered in double_scalars\n",
      "  res = p * np.log(p / q) + (1 - p) * np.log((1 - p) / (1 - q))\n",
      "100%|██████████| 50/50 [01:19<00:00,  1.59s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Average alarm 23.98 times\n",
      "Saving figure with format png, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_GLR-UCB(with unknown change point)_T=20000.png'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_GLR-UCB(with unknown change point)_T=20000.png' created of size '26214b', at 'Sun Jan 28 12:05:18 2024' ...\n",
      "Saving figure with format pdf, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_GLR-UCB(with unknown change point)_T=20000.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__M20_K3_N50_T_scaling_envId8/arm_GLR-UCB(with unknown change point)_T=20000.pdf' created of size '1025854b', at 'Sun Jan 28 12:05:18 2024' ...\n",
      "Saving figure with format eps, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_GLR-UCB(with unknown change point)_T=20000.eps'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_GLR-UCB(with unknown change point)_T=20000.eps' created of size '2964656b', at 'Sun Jan 28 12:05:18 2024' ...\n",
      "Running ...<bound method GLRUCB.__str__ of <GLR_UCB.GLRUCB object at 0x000002B4CE55B8E0>> for T = 50000\n",
      "Running ...GLR-UCB with alpha0 = 0.014710389719113688\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/50 [00:00<?, ?it/s]c:\\Users\\USER\\Code\\SimulatuionByMe\\sim\\GLR_UCB.py:456: RuntimeWarning: divide by zero encountered in double_scalars\n",
      "  res = p * np.log(p / q) + (1 - p) * np.log((1 - p) / (1 - q))\n",
      "100%|██████████| 50/50 [08:56<00:00, 10.72s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Average alarm 24.2 times\n",
      "Saving figure with format png, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_GLR-UCB(with unknown change point)_T=50000.png'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_GLR-UCB(with unknown change point)_T=50000.png' created of size '24099b', at 'Sun Jan 28 12:14:15 2024' ...\n",
      "Saving figure with format pdf, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_GLR-UCB(with unknown change point)_T=50000.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__M20_K3_N50_T_scaling_envId8/arm_GLR-UCB(with unknown change point)_T=50000.pdf' created of size '2205623b', at 'Sun Jan 28 12:14:15 2024' ...\n",
      "Saving figure with format eps, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_GLR-UCB(with unknown change point)_T=50000.eps'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_GLR-UCB(with unknown change point)_T=50000.eps' created of size '7367827b', at 'Sun Jan 28 12:14:16 2024' ...\n",
      "Running ...<bound method GLRUCB.__str__ of <GLR_UCB.GLRUCB object at 0x000002B4CE55B8E0>> for T = 100000\n",
      "Running ...GLR-UCB with alpha0 = 0.010729830131446736\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/50 [00:00<?, ?it/s]c:\\Users\\USER\\Code\\SimulatuionByMe\\sim\\GLR_UCB.py:456: RuntimeWarning: divide by zero encountered in double_scalars\n",
      "  res = p * np.log(p / q) + (1 - p) * np.log((1 - p) / (1 - q))\n",
      "100%|██████████| 50/50 [38:57<00:00, 46.75s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Average alarm 25.24 times\n",
      "Saving figure with format png, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_GLR-UCB(with unknown change point)_T=100000.png'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_GLR-UCB(with unknown change point)_T=100000.png' created of size '23382b', at 'Sun Jan 28 12:53:13 2024' ...\n",
      "Saving figure with format pdf, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_GLR-UCB(with unknown change point)_T=100000.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__M20_K3_N50_T_scaling_envId8/arm_GLR-UCB(with unknown change point)_T=100000.pdf' created of size '3966426b', at 'Sun Jan 28 12:53:15 2024' ...\n",
      "Saving figure with format eps, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_GLR-UCB(with unknown change point)_T=100000.eps'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_GLR-UCB(with unknown change point)_T=100000.eps' created of size '14707772b', at 'Sun Jan 28 12:53:15 2024' ...\n",
      "Regret saving ...\n",
      "FileName saving ...\n",
      "Time horizon: 20000\n",
      "Number of repetitions: 50\n",
      "Running ...<bound method CusumUCB.__str__ of <CUSUM_UCB.CusumUCB object at 0x000002B4CCEEB010>> for T = 2000\n",
      "exploration rate = 0.47752180451395354\n",
      "Running ...CUSUM-UCB with gamma = 0.47752180451395354\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/50 [00:00<?, ?it/s]c:\\Users\\USER\\Code\\SimulatuionByMe\\sim\\CUSUM_UCB.py:149: 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\\CUSUM_UCB.py:149: RuntimeWarning: divide by zero encountered in double_scalars\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:01<00:00, 34.26it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Average alarm 7.6 times\n",
      "Saving figure with format png, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB_T=2000.png'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB_T=2000.png' created of size '33399b', at 'Sun Jan 28 12:53:17 2024' ...\n",
      "Saving figure with format pdf, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB_T=2000.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__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB_T=2000.pdf' created of size '131222b', at 'Sun Jan 28 12:53:17 2024' ...\n",
      "Saving figure with format eps, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB_T=2000.eps'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB_T=2000.eps' created of size '332428b', at 'Sun Jan 28 12:53:17 2024' ...\n",
      "Running ...<bound method CusumUCB.__str__ of <CUSUM_UCB.CusumUCB object at 0x000002B4CCEEB010>> for T = 5000\n",
      "exploration rate = 0.3196972291043431\n",
      "Running ...CUSUM-UCB with gamma = 0.3196972291043431\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/50 [00:00<?, ?it/s]c:\\Users\\USER\\Code\\SimulatuionByMe\\sim\\CUSUM_UCB.py:149: 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\\CUSUM_UCB.py:149: RuntimeWarning: divide by zero encountered in double_scalars\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:13<00:00,  3.67it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Average alarm 19.04 times\n",
      "Saving figure with format png, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB_T=5000.png'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB_T=5000.png' created of size '28526b', at 'Sun Jan 28 12:53:31 2024' ...\n",
      "Saving figure with format pdf, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB_T=5000.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__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB_T=5000.pdf' created of size '288202b', at 'Sun Jan 28 12:53:31 2024' ...\n",
      "Saving figure with format eps, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB_T=5000.eps'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB_T=5000.eps' created of size '763868b', at 'Sun Jan 28 12:53:31 2024' ...\n",
      "Running ...<bound method CusumUCB.__str__ of <CUSUM_UCB.CusumUCB object at 0x000002B4CCEEB010>> for T = 10000\n",
      "exploration rate = 0.23507880004767998\n",
      "Running ...CUSUM-UCB with gamma = 0.23507880004767998\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/50 [00:00<?, ?it/s]c:\\Users\\USER\\Code\\SimulatuionByMe\\sim\\CUSUM_UCB.py:149: 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\\CUSUM_UCB.py:149: RuntimeWarning: divide by zero encountered in double_scalars\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:57<00:00,  1.15s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Average alarm 24.66 times\n",
      "Saving figure with format png, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB_T=10000.png'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB_T=10000.png' created of size '27776b', at 'Sun Jan 28 12:54:29 2024' ...\n",
      "Saving figure with format pdf, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB_T=10000.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__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB_T=10000.pdf' created of size '540399b', at 'Sun Jan 28 12:54:29 2024' ...\n",
      "Saving figure with format eps, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB_T=10000.eps'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB_T=10000.eps' created of size '1498884b', at 'Sun Jan 28 12:54:29 2024' ...\n",
      "Running ...<bound method CusumUCB.__str__ of <CUSUM_UCB.CusumUCB object at 0x000002B4CCEEB010>> for T = 20000\n",
      "exploration rate = 0.1723672319717654\n",
      "Running ...CUSUM-UCB with gamma = 0.1723672319717654\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/50 [00:00<?, ?it/s]c:\\Users\\USER\\Code\\SimulatuionByMe\\sim\\CUSUM_UCB.py:149: 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\\CUSUM_UCB.py:149: RuntimeWarning: divide by zero encountered in double_scalars\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 [03:27<00:00,  4.15s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Average alarm 37.14 times\n",
      "Saving figure with format png, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB_T=20000.png'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB_T=20000.png' created of size '27179b', at 'Sun Jan 28 12:57:57 2024' ...\n",
      "Saving figure with format pdf, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB_T=20000.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__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB_T=20000.pdf' created of size '1061901b', at 'Sun Jan 28 12:57:57 2024' ...\n",
      "Saving figure with format eps, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB_T=20000.eps'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB_T=20000.eps' created of size '2965147b', at 'Sun Jan 28 12:57:58 2024' ...\n",
      "Running ...<bound method CusumUCB.__str__ of <CUSUM_UCB.CusumUCB object at 0x000002B4CCEEB010>> for T = 50000\n",
      "exploration rate = 0.11394618879669623\n",
      "Running ...CUSUM-UCB with gamma = 0.11394618879669623\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/50 [00:00<?, ?it/s]c:\\Users\\USER\\Code\\SimulatuionByMe\\sim\\CUSUM_UCB.py:149: 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\\CUSUM_UCB.py:149: RuntimeWarning: divide by zero encountered in double_scalars\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 [16:17<00:00, 19.56s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Average alarm 69.5 times\n",
      "Saving figure with format png, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB_T=50000.png'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB_T=50000.png' created of size '25993b', at 'Sun Jan 28 13:14:16 2024' ...\n",
      "Saving figure with format pdf, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB_T=50000.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__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB_T=50000.pdf' created of size '2437948b', at 'Sun Jan 28 13:14:17 2024' ...\n",
      "Saving figure with format eps, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB_T=50000.eps'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB_T=50000.eps' created of size '7369257b', at 'Sun Jan 28 13:14:17 2024' ...\n",
      "Running ...<bound method CusumUCB.__str__ of <CUSUM_UCB.CusumUCB object at 0x000002B4CCEEB010>> for T = 100000\n",
      "exploration rate = 0.0831129068134555\n",
      "Running ...CUSUM-UCB with gamma = 0.0831129068134555\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/50 [00:00<?, ?it/s]c:\\Users\\USER\\Code\\SimulatuionByMe\\sim\\CUSUM_UCB.py:149: 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\\CUSUM_UCB.py:149: RuntimeWarning: divide by zero encountered in double_scalars\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 [43:27<00:00, 52.15s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Average alarm 126.14 times\n",
      "Saving figure with format png, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB_T=100000.png'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB_T=100000.png' created of size '25235b', at 'Sun Jan 28 13:57:45 2024' ...\n",
      "Saving figure with format pdf, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB_T=100000.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__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB_T=100000.pdf' created of size '4625016b', at 'Sun Jan 28 13:57:46 2024' ...\n",
      "Saving figure with format eps, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB_T=100000.eps'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB_T=100000.eps' created of size '14709396b', at 'Sun Jan 28 13:57:47 2024' ...\n",
      "Regret saving ...\n",
      "FileName saving ...\n",
      "Time horizon: 20000\n",
      "Number of repetitions: 50\n",
      "Running ...<bound method CusumUCB.__str__ of <CUSUM_UCB.CusumUCB object at 0x000002B4CF89D450>> for T = 2000\n",
      "Running ...CUSUM-UCB with diminishing\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/50 [00:00<?, ?it/s]c:\\Users\\USER\\Code\\SimulatuionByMe\\sim\\CUSUM_UCB.py:235: 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\\CUSUM_UCB.py:235: 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\\CUSUM_UCB.py:235: 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",
      "c:\\Users\\USER\\Code\\SimulatuionByMe\\sim\\CUSUM_UCB.py:235: RuntimeWarning: invalid value encountered in double_scalars\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:02<00:00, 18.07it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Average alarm 6.9 times\n",
      "Saving figure with format png, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB(with diminishing)_T=2000.png'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB(with diminishing)_T=2000.png' created of size '32981b', at 'Sun Jan 28 13:57:50 2024' ...\n",
      "Saving figure with format pdf, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB(with diminishing)_T=2000.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__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB(with diminishing)_T=2000.pdf' created of size '129987b', at 'Sun Jan 28 13:57:50 2024' ...\n",
      "Saving figure with format eps, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB(with diminishing)_T=2000.eps'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB(with diminishing)_T=2000.eps' created of size '325356b', at 'Sun Jan 28 13:57:50 2024' ...\n",
      "Running ...<bound method CusumUCB.__str__ of <CUSUM_UCB.CusumUCB object at 0x000002B4CF89D450>> for T = 5000\n",
      "Running ...CUSUM-UCB with diminishing\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/50 [00:00<?, ?it/s]c:\\Users\\USER\\Code\\SimulatuionByMe\\sim\\CUSUM_UCB.py:235: 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\\CUSUM_UCB.py:235: 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\\CUSUM_UCB.py:235: 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",
      "c:\\Users\\USER\\Code\\SimulatuionByMe\\sim\\CUSUM_UCB.py:235: RuntimeWarning: invalid value encountered in double_scalars\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:12<00:00,  3.99it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Average alarm 18.74 times\n",
      "Saving figure with format png, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB(with diminishing)_T=5000.png'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB(with diminishing)_T=5000.png' created of size '30208b', at 'Sun Jan 28 13:58:03 2024' ...\n",
      "Saving figure with format pdf, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB(with diminishing)_T=5000.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__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB(with diminishing)_T=5000.pdf' created of size '286488b', at 'Sun Jan 28 13:58:03 2024' ...\n",
      "Saving figure with format eps, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB(with diminishing)_T=5000.eps'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB(with diminishing)_T=5000.eps' created of size '763190b', at 'Sun Jan 28 13:58:03 2024' ...\n",
      "Running ...<bound method CusumUCB.__str__ of <CUSUM_UCB.CusumUCB object at 0x000002B4CF89D450>> for T = 10000\n",
      "Running ...CUSUM-UCB with diminishing\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/50 [00:00<?, ?it/s]c:\\Users\\USER\\Code\\SimulatuionByMe\\sim\\CUSUM_UCB.py:235: 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\\CUSUM_UCB.py:235: 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\\CUSUM_UCB.py:235: 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",
      "c:\\Users\\USER\\Code\\SimulatuionByMe\\sim\\CUSUM_UCB.py:235: RuntimeWarning: invalid value encountered in double_scalars\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 [01:00<00:00,  1.21s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Average alarm 24.82 times\n",
      "Saving figure with format png, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB(with diminishing)_T=10000.png'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB(with diminishing)_T=10000.png' created of size '28510b', at 'Sun Jan 28 13:59:03 2024' ...\n",
      "Saving figure with format pdf, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB(with diminishing)_T=10000.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__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB(with diminishing)_T=10000.pdf' created of size '533068b', at 'Sun Jan 28 13:59:04 2024' ...\n",
      "Saving figure with format eps, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB(with diminishing)_T=10000.eps'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB(with diminishing)_T=10000.eps' created of size '1497312b', at 'Sun Jan 28 13:59:04 2024' ...\n",
      "Running ...<bound method CusumUCB.__str__ of <CUSUM_UCB.CusumUCB object at 0x000002B4CF89D450>> for T = 20000\n",
      "Running ...CUSUM-UCB with diminishing\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/50 [00:00<?, ?it/s]c:\\Users\\USER\\Code\\SimulatuionByMe\\sim\\CUSUM_UCB.py:235: 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\\CUSUM_UCB.py:235: 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\\CUSUM_UCB.py:235: 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",
      "c:\\Users\\USER\\Code\\SimulatuionByMe\\sim\\CUSUM_UCB.py:235: RuntimeWarning: invalid value encountered in double_scalars\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 [03:47<00:00,  4.56s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Average alarm 37.86 times\n",
      "Saving figure with format png, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB(with diminishing)_T=20000.png'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB(with diminishing)_T=20000.png' created of size '28080b', at 'Sun Jan 28 14:02:52 2024' ...\n",
      "Saving figure with format pdf, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB(with diminishing)_T=20000.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__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB(with diminishing)_T=20000.pdf' created of size '1044311b', at 'Sun Jan 28 14:02:52 2024' ...\n",
      "Saving figure with format eps, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB(with diminishing)_T=20000.eps'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB(with diminishing)_T=20000.eps' created of size '2964205b', at 'Sun Jan 28 14:02:53 2024' ...\n",
      "Running ...<bound method CusumUCB.__str__ of <CUSUM_UCB.CusumUCB object at 0x000002B4CF89D450>> for T = 50000\n",
      "Running ...CUSUM-UCB with diminishing\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/50 [00:00<?, ?it/s]c:\\Users\\USER\\Code\\SimulatuionByMe\\sim\\CUSUM_UCB.py:235: 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\\CUSUM_UCB.py:235: 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\\CUSUM_UCB.py:235: 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",
      "c:\\Users\\USER\\Code\\SimulatuionByMe\\sim\\CUSUM_UCB.py:235: RuntimeWarning: invalid value encountered in double_scalars\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 [17:01<00:00, 20.42s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Average alarm 69.52 times\n",
      "Saving figure with format png, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB(with diminishing)_T=50000.png'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB(with diminishing)_T=50000.png' created of size '27005b', at 'Sun Jan 28 14:19:54 2024' ...\n",
      "Saving figure with format pdf, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB(with diminishing)_T=50000.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__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB(with diminishing)_T=50000.pdf' created of size '2395330b', at 'Sun Jan 28 14:19:55 2024' ...\n",
      "Saving figure with format eps, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB(with diminishing)_T=50000.eps'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB(with diminishing)_T=50000.eps' created of size '7367300b', at 'Sun Jan 28 14:19:55 2024' ...\n",
      "Running ...<bound method CusumUCB.__str__ of <CUSUM_UCB.CusumUCB object at 0x000002B4CF89D450>> for T = 100000\n",
      "Running ...CUSUM-UCB with diminishing\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/50 [00:00<?, ?it/s]c:\\Users\\USER\\Code\\SimulatuionByMe\\sim\\CUSUM_UCB.py:235: 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\\CUSUM_UCB.py:235: 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\\CUSUM_UCB.py:235: 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",
      "c:\\Users\\USER\\Code\\SimulatuionByMe\\sim\\CUSUM_UCB.py:235: RuntimeWarning: invalid value encountered in double_scalars\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 [46:00<00:00, 55.22s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Average alarm 125.48 times\n",
      "Saving figure with format png, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB(with diminishing)_T=100000.png'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB(with diminishing)_T=100000.png' created of size '26224b', at 'Sun Jan 28 15:05:57 2024' ...\n",
      "Saving figure with format pdf, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB(with diminishing)_T=100000.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__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB(with diminishing)_T=100000.pdf' created of size '4559801b', at 'Sun Jan 28 15:05:58 2024' ...\n",
      "Saving figure with format eps, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB(with diminishing)_T=100000.eps'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/arm_CUSUM-UCB(with diminishing)_T=100000.eps' created of size '14708571b', at 'Sun Jan 28 15:05:58 2024' ...\n",
      "Regret saving ...\n",
      "FileName saving ...\n",
      "['Regrets_versus_T_Discounted-TS (0.75).csv', 'Regrets_versus_T_Discounted-klUCB (0.75).csv', 'Regrets_versus_T_M-UCB($w=200$, with diminishing).csv', 'Regrets_versus_T_M-UCB($w=200$).csv', 'Regrets_versus_T_GLR-UCB(with unknown change point).csv', 'Regrets_versus_T_CUSUM-UCB.csv', 'Regrets_versus_T_CUSUM-UCB(with diminishing).csv']\n",
      "{'Regrets_versus_T_Discounted-TS (0.75).csv': array([ 308.5       ,  594.1       ,  948.22      , 1485.45999999,\n",
      "       2761.76000001, 4313.50000015]), 'Regrets_versus_T_Discounted-klUCB (0.75).csv': array([ 284.96      ,  617.66      , 1063.74      , 1814.67999999,\n",
      "       3675.28      , 6132.32000015]), 'Regrets_versus_T_M-UCB($w=200$, with diminishing).csv': array([ 194.94      ,  331.16      ,  547.54      ,  927.63999999,\n",
      "       1672.96000001, 2657.12000015]), 'Regrets_versus_T_M-UCB($w=200$).csv': array([ 485.5       ,  830.        , 1273.6       , 1890.61999999,\n",
      "       3976.28000001, 6192.80000015]), 'Regrets_versus_T_GLR-UCB(with unknown change point).csv': array([ 242.34      ,  506.96      ,  822.7       , 1184.83999999,\n",
      "       1744.30000001, 2223.52000015]), 'Regrets_versus_T_CUSUM-UCB.csv': array([ 415.64      ,  723.08      , 1103.54      , 1644.55999999,\n",
      "       3051.98      , 5162.84000015]), 'Regrets_versus_T_CUSUM-UCB(with diminishing).csv': array([ 253.5       ,  528.52      ,  795.12      , 1255.01999999,\n",
      "       2472.02000001, 4409.36000015])}\n",
      "Saving figure with format png, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/main__Regret_versus_T.png'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/main__Regret_versus_T.png' created of size '275735b', at 'Sun Jan 28 15:06:00 2024' ...\n",
      "Saving figure with format pdf, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/main__Regret_versus_T.pdf'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/main__Regret_versus_T.pdf' created of size '37978b', at 'Sun Jan 28 15:06:00 2024' ...\n",
      "Saving figure with format eps, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M20_K3_N50_T_scaling_envId8/main__Regret_versus_T.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__M20_K3_N50_T_scaling_envId8/main__Regret_versus_T.eps' created of size '60736b', at 'Sun Jan 28 15:06:00 2024' ...\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<main.main at 0x2b4e0e09ed0>"
      ]
     },
     "execution_count": 1,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "from main import main\n",
    "\n",
    "main(experiment = \"T\", horizon = 20000, repetitions = 50, envId = 8)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "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)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  5%|▌         | 101/2000 [00:00<?, ?it/s]\n"
     ]
    }
   ],
   "source": [
    "from tqdm import tqdm\n",
    "\n",
    "i = 0\n",
    "pbar = tqdm(total=2000)\n",
    "while i <= 100:\n",
    "    pbar.update(1)\n",
    "    i +=1\n",
    "pbar.close()"
   ]
  }
 ],
 "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
}
