{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['a', 'b']\n",
      "['a', 'b', 'c']\n",
      "<class 'list'>\n",
      "['a', 'b']\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "\n",
    "foo = ['a','b']\n",
    "print(foo)\n",
    "foo1 = foo.copy()\n",
    "foo.append('c')\n",
    "print(foo)\n",
    "print(type(foo))\n",
    "print(foo1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{1: {2: 0.7071067811865475, 4: 0.5, 8: 0.35355339059327373, 16: 0.25, 32: 0.17677669529663687}, 2: {2: 0.5, 4: 0.35355339059327373, 8: 0.25, 16: 0.17677669529663687, 32: 0.125}, 3: {2: 0.4082482904638631, 4: 0.2886751345948129, 8: 0.20412414523193154, 16: 0.14433756729740646, 32: 0.10206207261596577}, 4: {2: 0.35355339059327373, 4: 0.25, 8: 0.17677669529663687, 16: 0.125, 32: 0.08838834764831843}, 5: {2: 0.31622776601683794, 4: 0.22360679774997896, 8: 0.15811388300841897, 16: 0.11180339887498948, 32: 0.07905694150420949}}\n",
      "32\n"
     ]
    }
   ],
   "source": [
    "m_list = [2**i for i in range(1,int(np.ceil(np.log(100)))+1)]\n",
    "# B = np.zeros((self.horizon - self.tl -1, len(m_list)), dtype=float)\n",
    "B = {}\n",
    "for s in range(1,6):\n",
    "    B[s] = {}\n",
    "    for m in m_list:\n",
    "        B[s][m] = 1/np.sqrt(m*(s))\n",
    "print(B)\n",
    "# a = {\"a\":5}\n",
    "# a.items()\n",
    "m = max([k for k,v in B[2].items() if v>0 ])\n",
    "print(m)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "\n",
    "array = np.array([[1, 1, 0, 0],\n",
    "                  [0, 2, 1, 1],\n",
    "                  [0, 0, 0, 0]])\n",
    "\n",
    "solutions = np.argwhere(array == np.max(array))\n",
    "print(solutions[0][1])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 75,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "4\n",
      "3\n",
      "2\n",
      "1\n",
      "0\n"
     ]
    }
   ],
   "source": [
    "for m in range(4,-1,-1):\n",
    "    print(m)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 166,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\oliver\\AppData\\Local\\Temp\\ipykernel_11476\\3818197269.py:8: RuntimeWarning: divide by zero encountered in double_scalars\n",
      "  return 1/np.sqrt(t)\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "[{'alg.s': 0, 'alg.e': 15, 'order-m': 4},\n",
       " {'alg.s': 0, 'alg.e': 7, 'order-m': 3},\n",
       " {'alg.s': 0, 'alg.e': 1, 'order-m': 1},\n",
       " {'alg.s': 2, 'alg.e': 3, 'order-m': 1},\n",
       " {'alg.s': 4, 'alg.e': 7, 'order-m': 2},\n",
       " {'alg.s': 8, 'alg.e': 15, 'order-m': 3},\n",
       " {'alg.s': 8, 'alg.e': 11, 'order-m': 2},\n",
       " {'alg.s': 8, 'alg.e': 9, 'order-m': 1},\n",
       " {'alg.s': 10, 'alg.e': 11, 'order-m': 1},\n",
       " {'alg.s': 12, 'alg.e': 15, 'order-m': 2},\n",
       " {'alg.s': 12, 'alg.e': 13, 'order-m': 1},\n",
       " {'alg.s': 14, 'alg.e': 15, 'order-m': 1}]"
      ]
     },
     "execution_count": 166,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "def Bernoulli(p):\n",
    "    if np.random.rand()<p:\n",
    "        return 1\n",
    "    else :\n",
    "        return 0\n",
    "\n",
    "def rho(t):\n",
    "    return 1/np.sqrt(t)\n",
    "\n",
    "def schedule(n):\n",
    "    schedule_list = []\n",
    "    for tau in range(2**n):\n",
    "        for m in range(n,-1,-1):\n",
    "            if tau%(2**m) == 0:\n",
    "                if Bernoulli(rho(n)/rho(m))==1:\n",
    "                    algs = tau\n",
    "                    alge = tau+2**m-1\n",
    "                    schedule_list.append({\"alg.s\":algs, \"alg.e\":alge, \"order-m\":m})\n",
    "    return schedule_list\n",
    "\n",
    "schedule_list = schedule(4)\n",
    "\n",
    "schedule_list"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 59,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "11"
      ]
     },
     "execution_count": 59,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(schedule_list)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[{'alg.s': 0, 'alg.e': 15, 'order-m': 4}, {'alg.s': 1, 'alg.e': 1, 'order-m': 0}, {'alg.s': 2, 'alg.e': 3, 'order-m': 1}, {'alg.s': 4, 'alg.e': 7, 'order-m': 2}, {'alg.s': 4, 'alg.e': 4, 'order-m': 0}, {'alg.s': 5, 'alg.e': 5, 'order-m': 0}, {'alg.s': 8, 'alg.e': 8, 'order-m': 0}, {'alg.s': 12, 'alg.e': 15, 'order-m': 2}, {'alg.s': 12, 'alg.e': 13, 'order-m': 1}, {'alg.s': 13, 'alg.e': 13, 'order-m': 0}]\n"
     ]
    }
   ],
   "source": [
    "schedule_list = [{'alg.s': 0, 'alg.e': 15, 'order-m': 4},\n",
    "                {'alg.s': 1, 'alg.e': 1, 'order-m': 0},\n",
    "                {'alg.s': 2, 'alg.e': 3, 'order-m': 1},\n",
    "                {'alg.s': 4, 'alg.e': 7, 'order-m': 2},\n",
    "                {'alg.s': 4, 'alg.e': 4, 'order-m': 0},\n",
    "                {'alg.s': 5, 'alg.e': 5, 'order-m': 0},\n",
    "                {'alg.s': 8, 'alg.e': 8, 'order-m': 0},\n",
    "                {'alg.s': 12, 'alg.e': 15, 'order-m': 2},\n",
    "                {'alg.s': 12, 'alg.e': 13, 'order-m': 1},\n",
    "                {'alg.s': 13, 'alg.e': 13, 'order-m': 0}]\n",
    "# for i in range(len(schedule_list)):\n",
    "#     if i < len(schedule_list)-1:\n",
    "#         if schedule_list[i][\"alg.s\"] == schedule_list[i+1][\"alg.s\"]:\n",
    "#             if schedule_list[i][\"order-m\"] > schedule_list[i+1][\"order-m\"]:\n",
    "#                 schedule_list[i+1], schedule_list[i], = schedule_list[i], schedule_list[i+1]\n",
    "#         # elif (schedule_list[i][\"alg.s\"] <= schedule_list[i+1][\"alg.s\"]) and (schedule_list[i][\"alg.e\"] >= schedule_list[i+1][\"alg.e\"]): \n",
    "#         #     if schedule_list[i][\"order-m\"] > schedule_list[i+1][\"order-m\"]:\n",
    "#         #         schedule_list[i+1], schedule_list[i], = schedule_list[i], schedule_list[i+1]\n",
    "#         elif schedule_list[i][\"alg.e\"] == schedule_list[i+1][\"alg.e\"]:\n",
    "#             if schedule_list[i][\"order-m\"] > schedule_list[i+1][\"order-m\"]:\n",
    "#                 schedule_list[i+1], schedule_list[i], = schedule_list[i], schedule_list[i+1]\n",
    "\n",
    "print(schedule_list)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[2]"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "import numpy as np\n",
    "\n",
    "class instance(object):\n",
    "    def __init__(self, nb_arms , order_m):\n",
    "        self.reward = []\n",
    "        self.Z = np.zeros((nb_arms, order_m), dtype= float )\n",
    "        self.n = np.zeros(nb_arms, dtype = float)\n",
    "\n",
    "alg = {}\n",
    "for i in range(len(schedule_list)):\n",
    "    alg[str(schedule_list[i])] = instance(nb_arms = 3, order_m = schedule_list[i][\"order-m\"])\n",
    "\n",
    "alg[str(schedule_list[4])].reward.append(2)\n",
    "\n",
    "alg[str(schedule_list[4])].reward"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([1, 2, 3, 4, 5])"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "a = np.array([1,2,3,4,5,6])\n",
    "a[0:5]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 167,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{'alg.s': 0, 'alg.e': 1, 'order-m': 1}\n",
      "1\n",
      "{'alg.s': 0, 'alg.e': 1, 'order-m': 1}\n",
      "2\n",
      "{'alg.s': 2, 'alg.e': 3, 'order-m': 1}\n",
      "1\n",
      "{'alg.s': 2, 'alg.e': 3, 'order-m': 1}\n",
      "2\n",
      "{'alg.s': 4, 'alg.e': 7, 'order-m': 2}\n",
      "1\n",
      "{'alg.s': 4, 'alg.e': 7, 'order-m': 2}\n",
      "2\n",
      "{'alg.s': 4, 'alg.e': 7, 'order-m': 2}\n",
      "3\n",
      "{'alg.s': 4, 'alg.e': 7, 'order-m': 2}\n",
      "4\n",
      "{'alg.s': 8, 'alg.e': 9, 'order-m': 1}\n",
      "1\n",
      "{'alg.s': 8, 'alg.e': 9, 'order-m': 1}\n",
      "2\n",
      "{'alg.s': 10, 'alg.e': 11, 'order-m': 1}\n",
      "1\n",
      "{'alg.s': 10, 'alg.e': 11, 'order-m': 1}\n",
      "2\n",
      "{'alg.s': 12, 'alg.e': 13, 'order-m': 1}\n",
      "1\n",
      "{'alg.s': 12, 'alg.e': 13, 'order-m': 1}\n",
      "2\n",
      "{'alg.s': 14, 'alg.e': 15, 'order-m': 1}\n",
      "1\n",
      "{'alg.s': 14, 'alg.e': 15, 'order-m': 1}\n",
      "2\n"
     ]
    }
   ],
   "source": [
    "order = 4\n",
    "i = 0\n",
    "backto=[]\n",
    "alg = {}\n",
    "for i in range(len(schedule_list)):\n",
    "    alg[str(schedule_list[i])] = 0\n",
    "\n",
    "for t in range(16):\n",
    "    for i in range(len(schedule_list)):\n",
    "        if t == schedule_list[i][\"alg.s\"]:\n",
    "            if schedule_list[i][\"alg.e\"]<=active_instance[\"alg.e\"] and schedule_list[i][\"order-m\"]<active_instance[\"order-m\"]:\n",
    "                if active_instance not in backto:     \n",
    "                    backto.append(active_instance)\n",
    "                active_instance = schedule_list[i]\n",
    "            else:\n",
    "                active_instance = schedule_list[i]\n",
    "    if t > active_instance[\"alg.e\"]:\n",
    "        active_instance = backto[len(backto)-1]\n",
    "        backto.pop()\n",
    "\n",
    "    alg[str(active_instance)] = alg[str(active_instance)]+1\n",
    "    print(active_instance)\n",
    "    print(alg[str(active_instance)])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 116,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{'alg.s': 1, 'alg.e': 16, 'order-m': 4}\n",
      "{'alg.s': 2, 'alg.e': 2, 'order-m': 0}\n",
      "{'alg.s': 3, 'alg.e': 4, 'order-m': 1}\n",
      "{'alg.s': 5, 'alg.e': 8, 'order-m': 2}\n",
      "{'alg.s': 5, 'alg.e': 5, 'order-m': 0}\n",
      "{'alg.s': 6, 'alg.e': 6, 'order-m': 0}\n",
      "{'alg.s': 9, 'alg.e': 9, 'order-m': 0}\n",
      "{'alg.s': 13, 'alg.e': 16, 'order-m': 2}\n",
      "{'alg.s': 13, 'alg.e': 14, 'order-m': 1}\n",
      "{'alg.s': 14, 'alg.e': 14, 'order-m': 0}\n",
      "[{'alg.s': 1, 'alg.e': 16, 'order-m': 4}, {'alg.s': 5, 'alg.e': 8, 'order-m': 2}, {'alg.s': 13, 'alg.e': 16, 'order-m': 2}, {'alg.s': 13, 'alg.e': 14, 'order-m': 1}]\n"
     ]
    }
   ],
   "source": [
    "active_instance = schedule_list[0]\n",
    "backto = []\n",
    "print(active_instance)\n",
    "for i in range(len(schedule_list)-1):\n",
    "    # if len(backto)!=0:\n",
    "    #     while active_instance[\"alg.e\"]>backto[len(backto)-1][\"alg.e\"]:\n",
    "    #         backto.pop()\n",
    "    #     if backto[len(backto)-1][\"alg.e\"]>active_instance[\"alg.e\"]:\n",
    "    #         active_instance = backto[len(backto)-1]\n",
    "    #         backto.pop()\n",
    "    #         print(active_instance)\n",
    "    if active_instance[\"order-m\"]>schedule_list[i+1][\"order-m\"]:\n",
    "        if schedule_list[i+1][\"alg.s\"]<=active_instance[\"alg.e\"]:\n",
    "            backto.append(active_instance)\n",
    "            active_instance = schedule_list[i+1]\n",
    "            print(active_instance)\n",
    "            ## check recover instance\n",
    "            for dict in backto:\n",
    "                if dict['order-m']\n",
    "    else:\n",
    "        if schedule_list[i+1][\"alg.s\"]>active_instance[\"alg.e\"]:\n",
    "            active_instance = schedule_list[i+1]\n",
    "            print(active_instance)\n",
    "    \n",
    "print(backto)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "5\n",
      "4\n",
      "3\n",
      "2\n",
      "1\n",
      "0\n"
     ]
    }
   ],
   "source": [
    "for i in range(5,-1,-1):\n",
    "    print(i)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "metadata": {},
   "outputs": [
    {
     "ename": "ValueError",
     "evalue": "list.remove(x): x not in list",
     "output_type": "error",
     "traceback": [
      "\u001b[1;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[1;31mValueError\u001b[0m                                Traceback (most recent call last)",
      "Input \u001b[1;32mIn [42]\u001b[0m, in \u001b[0;36m<cell line: 2>\u001b[1;34m()\u001b[0m\n\u001b[0;32m      1\u001b[0m aList \u001b[38;5;241m=\u001b[39m [\u001b[38;5;241m123\u001b[39m, \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mxyz\u001b[39m\u001b[38;5;124m'\u001b[39m, \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mzara\u001b[39m\u001b[38;5;124m'\u001b[39m, \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mabc\u001b[39m\u001b[38;5;124m'\u001b[39m, \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mxyz\u001b[39m\u001b[38;5;124m'\u001b[39m]\n\u001b[1;32m----> 2\u001b[0m \u001b[43maList\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mremove\u001b[49m\u001b[43m(\u001b[49m\u001b[43m[\u001b[49m\u001b[38;5;241;43m123\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[38;5;124;43mxyz\u001b[39;49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[43m]\u001b[49m\u001b[43m)\u001b[49m\n\u001b[0;32m      3\u001b[0m aList\n",
      "\u001b[1;31mValueError\u001b[0m: list.remove(x): x not in list"
     ]
    }
   ],
   "source": [
    "aList = [123, 'xyz', 'zara', 'abc', 'xyz']\n",
    "aList.remove([123, 'xyz'])\n",
    "aList"
   ]
  }
 ],
 "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
}
