{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "2685fd1a",
   "metadata": {},
   "outputs": [],
   "source": [
    "import time\n",
    "import copy\n",
    "import control\n",
    "import itertools\n",
    "import numpy as np\n",
    "import scipy as sp\n",
    "import scipy.special as ssp\n",
    "import seaborn as sns\n",
    "import matplotlib.pyplot as plt\n",
    "sns.set_style('ticks')\n",
    "rgblist = sns.color_palette('tab10' )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "7c72c394",
   "metadata": {},
   "outputs": [],
   "source": [
    "class Cont_gridworld():\n",
    "    def __init__(self):\n",
    "        self.d_A = 1\n",
    "        self.d_S = 2\n",
    "        \n",
    "        self.state_space = ([0 for i in range(self.d_S)], [1 for i in range(self.d_S)])\n",
    "        self.action_space = ([0 for i in range(self.d_A)], [1 for i in range(self.d_A)])\n",
    "        \n",
    "        self.state = None\n",
    "        self.reward = None\n",
    "        \n",
    "        self.scaling_factor = self.state_space[1][0] - self.state_space[0][0]\n",
    "        self.step_size = 0.1\n",
    "        self.reward_center = np.array([0.8, 0.8])\n",
    "        self.reward_radii = 0.08\n",
    "    \n",
    "    def reset(self):\n",
    "        self.state = None\n",
    "        self.reward = None\n",
    "    \n",
    "    def init(self):\n",
    "        self.state = np.zeros((self.d_S))\n",
    "        return self.state\n",
    "    \n",
    "    def step(self, action):\n",
    "        theta = 2*np.pi*action[0] + np.random.normal(0,0.1)\n",
    "        self.state = np.clip(self.state + self.step_size*np.array([np.cos(theta), np.sin(theta)]) \n",
    "                             + np.random.normal(0,0.1,2), 0, 1)\n",
    "        \n",
    "        if np.linalg.norm(self.state - self.reward_center) <= self.reward_radii:\n",
    "            self.reward = 1\n",
    "        else:\n",
    "            self.reward = 0\n",
    "        return self.state, self.reward\n",
    "    \n",
    "    def get_reward(self, sa):\n",
    "        s = sa[0]\n",
    "        a = sa[1]\n",
    "        return (1/2592)*(0.01*((s-6)**4) + s**4) + (1/32)*(0.01*((a-1)**4) + (a+1)**4)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "9d414e6f",
   "metadata": {},
   "outputs": [],
   "source": [
    "class Cell:\n",
    "    def __init__(self, start, end, d_S=2, factor=1, parent=None, part_scheme='adapt'):\n",
    "        self.d = len(start)\n",
    "        self.d_S = d_S\n",
    "        self.start = start\n",
    "        self.end = end\n",
    "        self.center = [0.5*(start[i]+end[i]) for i in range(self.d)]\n",
    "        self.factor = factor\n",
    "        self.diam = (end[0] - start[0])/factor\n",
    "        self.parent = parent\n",
    "        self.children = None\n",
    "        self.part_scheme = part_scheme\n",
    "        \n",
    "        if self.part_scheme == 'adapt':\n",
    "            self.active = True\n",
    "            if parent is not None:\n",
    "                for s_child in parent.s_proj.children:\n",
    "                    if np.equal(self.start[:d_S], s_child.start).all() and np.equal(self.end[:d_S], s_child.end).all():\n",
    "                        self.s_proj = s_child\n",
    "                        break\n",
    "                self.visits = self.parent.visits\n",
    "                self.visit_times = self.parent.visit_times.copy()\n",
    "            else:\n",
    "                self.s_proj = State_cell(self.start, self.end, d_S, part_scheme=part_scheme)\n",
    "                self.visits = 0\n",
    "                self.visit_times = []\n",
    "            self.add_self(self.s_proj)\n",
    "            \n",
    "        else:\n",
    "            self.visits = 0\n",
    "    \n",
    "    def remove_self(self, proj):\n",
    "        for child in proj.children:\n",
    "            child.corresp_cells.remove(self)\n",
    "            if child.children is not None:\n",
    "                self.remove_self(child)\n",
    "    \n",
    "    def add_self(self, proj):\n",
    "        proj.corresp_cells.append(self)\n",
    "        if proj.children is not None:\n",
    "            for child in proj.children:\n",
    "                self.add_self(child)\n",
    "                \n",
    "    def get_children(self):\n",
    "        if self.part_scheme == 'adapt':\n",
    "            self.active = False\n",
    "            if self.s_proj.children is None:\n",
    "                self.s_proj.get_children()\n",
    "            self.remove_self(self.s_proj)\n",
    "        \n",
    "        cells = [[] for i in range(self.d)]\n",
    "        self.children = []\n",
    "        for i in range(self.d):\n",
    "            cells[i].append([self.start[i], self.center[i]])\n",
    "            cells[i].append([self.center[i], self.end[i]])\n",
    "        for j in range(2**self.d):\n",
    "            M = []\n",
    "            m = bin(j)[2:]\n",
    "            l_m = len(m)\n",
    "            if l_m < self.d:\n",
    "                for l in range(self.d-l_m):\n",
    "                    m = '0'+m\n",
    "            for k in range(self.d):\n",
    "                M.append(int(m[k:k+1]))\n",
    "            ch = [cells[i][M[i]] for i in range(self.d)]\n",
    "            start = [ch[i][0] for i in range(self.d)]\n",
    "            end = [ch[i][1] for i in range(self.d)]\n",
    "            self.children.append(Cell(start, end, d_S=self.d_S, factor=self.factor, parent=self, \n",
    "                                      part_scheme=self.part_scheme))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "469e0a20",
   "metadata": {},
   "outputs": [],
   "source": [
    "class State_cell:\n",
    "    def __init__(self, start, end, d_S=2, parent=None, part_scheme='adapt'):\n",
    "        self.d_S = d_S\n",
    "        self.start = start[:d_S]\n",
    "        self.end = end[:d_S]\n",
    "        self.center = [0.5*(self.start[i]+self.end[i]) for i in range(self.d_S)]\n",
    "        self.children = None\n",
    "        self.parent = parent\n",
    "        self.part_scheme = part_scheme\n",
    "        self.corresp_cells = []\n",
    "        if self.part_scheme == 'adapt' and parent is not None:\n",
    "            self.corresp_cells = parent.corresp_cells.copy()\n",
    "        else:\n",
    "            self.visits = 0\n",
    "        \n",
    "    def get_children(self):\n",
    "        cells = [[] for i in range(self.d_S)]\n",
    "        self.children = []\n",
    "        for i in range(self.d_S):\n",
    "            cells[i].append([self.start[i], self.center[i]])\n",
    "            cells[i].append([self.center[i], self.end[i]])\n",
    "        for j in range(2**self.d_S):\n",
    "            M = []\n",
    "            m = bin(j)[2:]\n",
    "            l_m = len(m)\n",
    "            if l_m < self.d_S:\n",
    "                for l in range(self.d_S-l_m):\n",
    "                    m = '0'+m\n",
    "            for k in range(self.d_S):\n",
    "                M.append(int(m[k:k+1]))\n",
    "            ch = [cells[i][M[i]] for i in range(self.d_S)]\n",
    "            child = {}\n",
    "            start = [ch[i][0] for i in range(self.d_S)]\n",
    "            end = [ch[i][1] for i in range(self.d_S)]\n",
    "            self.children.append(State_cell(start, end, self.d_S, parent=self, part_scheme=self.part_scheme))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "cdeae943",
   "metadata": {},
   "outputs": [],
   "source": [
    "def update_partition(point, C, time, partition, s_partition):\n",
    "    update_flag = False\n",
    "    update_s_part = False\n",
    "    cur_cell = find_cell(point,partition)\n",
    "    if cur_cell is None:\n",
    "        print(point)\n",
    "    cur_cell.visits += 1\n",
    "    cur_cell.visit_times.append(time)\n",
    "    if cur_cell.visits > C*(cur_cell.diam**(-(d_S+2))):\n",
    "        update_flag = True\n",
    "        cur_cell.get_children()\n",
    "        partition = partition + cur_cell.children\n",
    "        partition.remove(cur_cell)\n",
    "        if cur_cell.s_proj in s_partition:\n",
    "            s_partition.remove(cur_cell.s_proj)\n",
    "            s_partition = s_partition + cur_cell.s_proj.children\n",
    "            update_s_part = True\n",
    "    \n",
    "    return cur_cell, partition, s_partition, update_flag, update_s_part"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "e29c52f0",
   "metadata": {},
   "outputs": [],
   "source": [
    "def find_cell(point, cells):\n",
    "    d = len(point)\n",
    "    for cell in cells:\n",
    "        skip = False\n",
    "        for i in range(d):\n",
    "            if cell.start[i] > point[i] or cell.end[i] < point[i]:\n",
    "                skip = True\n",
    "                break\n",
    "        if skip == False:\n",
    "            return cell\n",
    "    return None"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "d8ac1752",
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_eps_cover(eps, env):\n",
    "    d_S = env.d_S\n",
    "    d_A = env.d_A\n",
    "    d = d_S + d_A\n",
    "    eps_cover = [Cell(env.state_space[0]+env.action_space[0],\n",
    "                      env.state_space[1]+env.action_space[1],\n",
    "                      d_S=d_S, factor=env.scaling_factor, part_scheme='fxd'),]\n",
    "    eps_state_cover = [State_cell(eps_cover[0].start, eps_cover[0].end, d_S=d_S, part_scheme='fxd'),]\n",
    "    l = np.ceil(np.log2(1/eps)).astype(np.int32)\n",
    "    covers = [eps_cover,]\n",
    "    state_covers = [eps_state_cover,]\n",
    "    for i in range(l):\n",
    "        state_covers.append([])\n",
    "        covers.append([])\n",
    "        for state_cell in state_covers[i]:\n",
    "            state_cell.get_children()\n",
    "            state_covers[i+1] = state_covers[i+1] + state_cell.children\n",
    "        for cell in covers[i]:\n",
    "            cell.get_children()\n",
    "            covers[i+1] = covers[i+1] + cell.children\n",
    "    \n",
    "    eps_cover = covers[-1]\n",
    "    eps_state_cover = state_covers[-1]\n",
    "    \n",
    "    for cell in eps_cover:\n",
    "        for s_cell in eps_state_cover:\n",
    "            if np.equal(cell.start[:d_S], s_cell.start).all() and np.equal(cell.end[:d_S], s_cell.end).all():\n",
    "                s_cell.corresp_cells.append(cell)\n",
    "                continue\n",
    "    return eps_cover, eps_state_cover"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "6c449fda",
   "metadata": {},
   "outputs": [],
   "source": [
    "def value_iteration(p, r, cover, state_cover):\n",
    "    V = {}\n",
    "    for s_cell in state_cover:\n",
    "        V[s_cell] = 0\n",
    "    policy = {}\n",
    "    k = state_cover[-1]\n",
    "    count = 0\n",
    "    while True:\n",
    "        count += 1\n",
    "        V_old = V.copy()\n",
    "        for s_cell in state_cover:\n",
    "            Q = {}\n",
    "            for cell in s_cell.corresp_cells:\n",
    "                Q[cell] = r[cell] + sum(p[cell][s_nxt_cell]*V_old[s_nxt_cell] for s_nxt_cell in state_cover)\n",
    "            V[s_cell] = max(Q.values())\n",
    "            policy[s_cell] = max(Q, key=Q.get)\n",
    "        if np.max(abs(np.array(list(V.values())) - np.array(list(V_old.values())))) - np.min(abs(np.array(list(V.values())) - np.array(list(V_old.values())))) < 1e-6:\n",
    "            break\n",
    "    return policy, V[k]/count"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "5ffcca51",
   "metadata": {},
   "outputs": [],
   "source": [
    "def evi(p, r, active_cover, state_partition, tol=0.1, conf_coef=10):\n",
    "    V = {}\n",
    "    for s_cell in state_partition:\n",
    "        V[s_cell] = 0\n",
    "    policy = {}\n",
    "    k = state_partition[-1]\n",
    "    count = 0\n",
    "    while True:\n",
    "        count += 1\n",
    "        V_old = V.copy()\n",
    "        for s_cell in state_partition:\n",
    "            Q = {}\n",
    "            for cell in s_cell.corresp_cells:\n",
    "                conf_rad = conf_coef/max(1,(cell.visits)**(1/(s_cell.d_S+2)))\n",
    "                Q[cell] = r[cell] + inner_max(p[cell], V_old, conf_rad, state_partition)\n",
    "            V[s_cell] = max(Q.values())\n",
    "            policy[s_cell] = max(Q, key=Q.get)\n",
    "        delta_V = np.array(list(V.values())) - np.array(list(V_old.values()))\n",
    "        if np.max(delta_V) - np.min(delta_V) < tol:\n",
    "            break\n",
    "    return policy\n",
    "\n",
    "def epe(p, r, state_partition, phi_partition, tol=0.1, conf_coef=10):\n",
    "    s_lst = state_partition[-1]\n",
    "    V = {}\n",
    "    for s_cell in state_partition:\n",
    "        V[s_cell] = 0\n",
    "    policy = {}\n",
    "    k = state_partition[-1]\n",
    "    count = 0\n",
    "    while True:\n",
    "        count += 1\n",
    "        V_old = V.copy()\n",
    "        for s_cell in state_partition:\n",
    "            cell = phi_partition[s_cell]\n",
    "            conf_rad = conf_coef/max(1,np.sqrt(cell.visits))\n",
    "            V[s_cell] = r[cell] + inner_max(p[cell], V_old, conf_rad, state_partition)\n",
    "        if (np.max(abs(np.array(list(V.values())) - np.array(list(V_old.values()))))\n",
    "        - np.min(abs(np.array(list(V.values())) - np.array(list(V_old.values()))))) < tol*(abs(V[s_lst] - V_old[s_lst])):\n",
    "            break\n",
    "    return abs(V[s_lst] - V_old[s_lst])\n",
    "\n",
    "\n",
    "def inner_max(p, V, conf_rad, state_partition):\n",
    "    V_sort = dict(sorted(V.items(), key=lambda item: item[1]))\n",
    "    \n",
    "    p_ = p.copy()\n",
    "    \n",
    "    remain_conf_rad = 0.5*conf_rad\n",
    "    for s_cell in list(V_sort.keys())[::-1]:\n",
    "        p_[s_cell] = min(1, p[s_cell] + remain_conf_rad)\n",
    "        remain_conf_rad -= p_[s_cell] - p[s_cell]\n",
    "        if remain_conf_rad == 0:\n",
    "            break\n",
    "    \n",
    "    for s_cell in list(V_sort.keys()):\n",
    "        p_[s_cell] = max(0, 1 - sum(p_.values()) + p_[s_cell])\n",
    "        if sum(p_.values(), 0.0) == 1:\n",
    "            break\n",
    "    \n",
    "    maximized_expt_reward = 0\n",
    "    for s_cell in state_partition:\n",
    "        maximized_expt_reward += p_[s_cell]*V[s_cell]\n",
    "    \n",
    "    return maximized_expt_reward"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "71c9a2b0",
   "metadata": {},
   "outputs": [],
   "source": [
    "class active_policy_mf:\n",
    "    def __init__(self, param, key, actv_pols, C_d=1, C_i=1.1):\n",
    "        self.factor = C_i/C_d\n",
    "        self.C_d = C_d\n",
    "        self.key = key\n",
    "        self.param = param\n",
    "        self.avg_rew = 0\n",
    "        self.visits = 0\n",
    "        self.diam = C_d/np.sqrt(max(self.visits,1))\n",
    "        self.last_diam = C_d/np.sqrt(max(self.visits,1))\n",
    "        self.index = self.avg_rew + self.factor*self.diam\n",
    "        self.neighbors = actv_pols\n",
    "    \n",
    "    def update(self, reward):\n",
    "        self.visits += 1\n",
    "        self.diam = self.C_d/np.sqrt(self.visits)\n",
    "        self.avg_rew += (reward - self.avg_rew)/self.visits\n",
    "        self.index = self.avg_rew + self.factor*self.diam\n",
    "    \n",
    "    def update_neighbor(self):\n",
    "        for neighbor in self.neighbors:\n",
    "            if self.diam + neighbor.diam < np.linalg.norm(self.param - neighbor.param):\n",
    "                self.neighbors.remove(neighbor)\n",
    "\n",
    "class active_policy_mb:\n",
    "    def __init__(self, param, key, actv_pols, C_d=1, C_i=1.1):\n",
    "        self.factor = C_i/C_d\n",
    "        self.C_d = C_d\n",
    "        self.key = key\n",
    "        self.param = param\n",
    "        self.avg_rew = 0\n",
    "        self.visits = 0\n",
    "        self.diam = 1\n",
    "        self.last_diam = 1\n",
    "        self.index = self.avg_rew + self.factor*self.diam\n",
    "        self.neighbors = actv_pols\n",
    "    \n",
    "    def update(self, reward):\n",
    "        self.visits += 1\n",
    "        self.avg_rew += (reward - self.avg_rew)/self.visits\n",
    "        self.index = self.avg_rew + self.factor*self.diam\n",
    "    \n",
    "    def diam_update(self, diam):\n",
    "        self.diam = diam\n",
    "    \n",
    "    def last_diam_update(self):\n",
    "        self.last_diam = self.diam\n",
    "    \n",
    "    def update_neighbor(self):\n",
    "        for neighbor in self.neighbors:\n",
    "            if self.diam + neighbor.diam < np.linalg.norm(self.param - neighbor.param):\n",
    "                self.neighbors.remove(neighbor)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "bccf9ffb",
   "metadata": {},
   "outputs": [],
   "source": [
    "def update_active_policies_mf(actv_pols, key, C_d=5, C_i=10):\n",
    "    d_w = len(actv_pols[1].param)\n",
    "    n_pol = len(actv_pols)\n",
    "    \n",
    "    if d_w == 3:\n",
    "        n_r = 5\n",
    "        n_te = 10\n",
    "        found_flag = False\n",
    "        r = actv_pols[key].diam + (actv_pols[key].last_diam - actv_pols[key].diam)*np.linspace(0.1, 1, n_r)\n",
    "        te = np.linspace(0, 2*np.pi, n_te)\n",
    "        for x, y, z in itertools.product(r,te,te):\n",
    "            pt = actv_pols[key].param + x*np.array([np.cos(y)*np.cos(z), np.sin(y)*np.cos(z), np.sin(z)])\n",
    "            if pt[0] > 0.5 or pt[0] < -0.5 or pt[1] > 0.5 or pt[1] < -0.5 or pt[2] > 1 or pt[2] < 0:\n",
    "                continue\n",
    "            pt_covered = False\n",
    "            for neighbor in actv_pols[key].neighbors.values():\n",
    "                if np.linalg.norm(pt - neighbor.param) <= neighbor.diam:\n",
    "                    pt_covered = True\n",
    "                    break\n",
    "            if pt_covered == False:\n",
    "                found_flag = True\n",
    "                break\n",
    "    \n",
    "    if found_flag:\n",
    "        new_policy = active_policy_mf(pt, n_pol+1, actv_pols, C_d, C_i)\n",
    "        actv_pols[n_pol+1] = new_policy\n",
    "    \n",
    "    return actv_pols, found_flag\n",
    "\n",
    "def update_active_policies_mb(actv_pols, key, C_d=5, C_i=10):\n",
    "    d_w = len(actv_pols[1].param)\n",
    "    n_pol = len(actv_pols)\n",
    "    \n",
    "    if d_w == 3:\n",
    "        n_r = 10\n",
    "        found_flag = False\n",
    "        pts_1 = np.linspace(0,1,n_r)\n",
    "        pts_2 = np.linspace(-0.5,0.5,n_r)\n",
    "        for x, y, z in itertools.product(pts_2,pts_2,pts_1):\n",
    "            pt = np.array([x,y,z])\n",
    "            pt_covered = False\n",
    "            for key in actv_pols.keys():\n",
    "                if np.linalg.norm(pt - actv_pols[key].param) <= actv_pols[key].last_diam:\n",
    "                    pt_covered = True\n",
    "                    break\n",
    "            if pt_covered == False:\n",
    "                new_policy = active_policy_mb(pt, n_pol+1, actv_pols, C_d, C_i)\n",
    "                actv_pols[n_pol+1] = new_policy\n",
    "                found_flag = True\n",
    "        return actv_pols, found_flag"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "372db5ad",
   "metadata": {},
   "outputs": [],
   "source": [
    "def pzrlmf(env, T, hp, seed, verbose=False):\n",
    "    d_w = hp[0]\n",
    "    C_d = hp[1]\n",
    "    C_i = hp[2]\n",
    "    n_pol = 1\n",
    "    \n",
    "    if d_w == 3:\n",
    "        param = [np.random.uniform(-1,1), np.random.uniform(-1,1), np.random.uniform(0,1)]\n",
    "    \n",
    "    actv_pols = {}\n",
    "    actv_pols[n_pol] = active_policy_mf(param, n_pol, actv_pols, C_d, C_i)\n",
    "    \n",
    "    last_pol = None\n",
    "    \n",
    "    h, H_k, k, sum_rewards = 0, 0, 0, 0\n",
    "    cumul_rewards = []\n",
    "    np.random.seed(seed)\n",
    "    next_state = env.init()\n",
    "    for t in range(T):\n",
    "        if h == H_k:\n",
    "            h = 0\n",
    "            update_flag = False\n",
    "            if t != 0:\n",
    "                last_pol_key = policy_key\n",
    "                last_pol = actv_pols[policy_key]\n",
    "            ## update the set of active policies\n",
    "            \n",
    "            if last_pol is not None and last_pol.diam != last_pol.last_diam:\n",
    "                actv_pols, update_flag = update_active_policies_mf(actv_pols, last_pol_key, C_d, C_i)\n",
    "                actv_pols[last_pol_key].update_neighbor\n",
    "            \n",
    "            ## compute the indices of the active policies\n",
    "            \n",
    "            indices = {pol.key: pol.index for pol in actv_pols.values()}\n",
    "            policy_key = max(indices, key=indices.get)\n",
    "            policy_param = actv_pols[policy_key].param\n",
    "            k += 1\n",
    "            if verbose:\n",
    "                print(\"Episode: {} | Stage: {}\".format(k, t+1))\n",
    "            H_k = max(1,actv_pols[policy_key].visits)\n",
    "        h += 1\n",
    "        \n",
    "        state = next_state.copy()\n",
    "        if d_w == 3:\n",
    "            action = np.array([np.minimum(1, np.maximum(0,state[0]*policy_param[0] + state[1]*policy_param[1] \n",
    "                                                        + policy_param[2]))])\n",
    "        next_state, reward = env.step(action)\n",
    "        actv_pols[policy_key].update(reward)\n",
    "        sum_rewards += reward\n",
    "        cumul_rewards.append(sum_rewards)\n",
    "    return cumul_rewards"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "57798d7e",
   "metadata": {},
   "outputs": [],
   "source": [
    "def pzrlmb(env, T, hp, seed, verbose=False):\n",
    "    d_w = hp[0]\n",
    "    C_d = hp[1]\n",
    "    C_i = hp[2]\n",
    "    C_a = 1\n",
    "    L_r = 0.2\n",
    "    \n",
    "    active_cover = [Cell(env.state_space[0]+env.action_space[0], \n",
    "                         env.state_space[1]+env.action_space[1],\n",
    "                         d_S=env.d_S, factor=env.scaling_factor, part_scheme='adapt'),]\n",
    "    state_partition = [active_cover[0].s_proj,]\n",
    "    visit_snap = {}\n",
    "    for cell in active_cover:\n",
    "        cell.visits = 0\n",
    "        visit_snap[cell] = 1\n",
    "    transitions = []\n",
    "    \n",
    "    n_pol = 1\n",
    "    \n",
    "    if d_w == 3:\n",
    "        param = [np.random.uniform(-0.5,0.5), np.random.uniform(-0.5,0.5), np.random.uniform(0,1)]\n",
    "    \n",
    "    actv_pols = {}\n",
    "    actv_pols[n_pol] = active_policy_mb(param, n_pol, actv_pols, C_d, C_i)\n",
    "    \n",
    "    last_pol = None\n",
    "    \n",
    "    h, H_k, k, sum_rewards = 0, 0, 0, 0\n",
    "    cumul_rewards = []\n",
    "    np.random.seed(seed)\n",
    "    next_state = env.init()\n",
    "    for t in range(T):\n",
    "        if h == H_k:\n",
    "            h = 0\n",
    "            update_flag = False\n",
    "            if t != 0:\n",
    "                last_pol_key = policy_key\n",
    "                last_pol = actv_pols[policy_key]\n",
    "                \n",
    "            state_partition_k = state_partition.copy()\n",
    "            transition_counter = {}\n",
    "            for cell in active_cover:\n",
    "                transition_counter[cell] = {}\n",
    "                for s_cell in state_partition_k:\n",
    "                    transition_counter[cell][s_cell] = 0\n",
    "            for cell in active_cover:\n",
    "                if t-1 in cell.visit_times:\n",
    "                    cell.visit_times.remove(t-1)\n",
    "                for i in cell.visit_times:\n",
    "                    next_cell = find_cell(transitions[i+1][:env.d_S],state_partition_k)\n",
    "                    transition_counter[cell][next_cell] += 1\n",
    "            p_hat = {}\n",
    "            r_hat = {}\n",
    "            diam = {}\n",
    "            visit_snap = {}\n",
    "            for cell in active_cover:\n",
    "                p_hat[cell] = {k: v / max(1,cell.visits) for k, v in transition_counter[cell].items()}\n",
    "                r_hat[cell] = env.get_reward(cell.center) + L_r*cell.diam\n",
    "                diam[cell] = cell.diam\n",
    "                visit_snap[cell] = max(1,cell.visits)\n",
    "            if t != 0:\n",
    "                policy_cells = {}\n",
    "                diameters = {}\n",
    "                for key in actv_pols.keys():\n",
    "                    policy_cells[key] = {}\n",
    "                    for st_cell in state_partition_k:\n",
    "                        st = st_cell.center\n",
    "                        if d_w == 3:\n",
    "                            acn = np.array([np.minimum(1, np.maximum(0,st[0]*actv_pols[key].param[0]\n",
    "                                                                     + st[1]*actv_pols[key].param[1]\n",
    "                                                                     + actv_pols[key].param[2]))])\n",
    "                        cl = find_cell(np.concatenate((st,acn)), active_cover)\n",
    "                        policy_cells[key][st_cell] = cl\n",
    "                    actv_pols[key].diam_update(2*epe(p_hat, diam, state_partition_k, policy_cells[key], 1/np.sqrt(max(t,1)), 1))\n",
    "                    if key == last_pol_key:\n",
    "                        actv_pols[key].last_diam_update()\n",
    "                \n",
    "                ## update the set of active policies\n",
    "                actv_pols, update_flag = update_active_policies_mb(actv_pols, last_pol_key, C_d, C_i)\n",
    "            \n",
    "            ## compute the indices of the active policies\n",
    "            \n",
    "            indices = {pol.key: pol.index for pol in actv_pols.values()}\n",
    "            policy_key = max(indices, key=indices.get)\n",
    "            policy_param = actv_pols[policy_key].param\n",
    "            k += 1\n",
    "            if verbose:\n",
    "                print(\"Episode: {} | Stage: {}\".format(k, t+1))\n",
    "            H_k = max(2,actv_pols[policy_key].visits)\n",
    "            #print(actv_pols[policy_key].diam, actv_pols[policy_key].last_diam)\n",
    "        h += 1\n",
    "        \n",
    "        state = next_state.copy()\n",
    "        state_cell = find_cell(state, state_partition_k)\n",
    "        if d_w == 3:\n",
    "            action = np.array([np.minimum(1, np.maximum(0,state[0]*policy_param[0] + state[1]*policy_param[1] \n",
    "                                                        + policy_param[2]))])\n",
    "        next_state, reward = env.step(action)\n",
    "        \n",
    "        actv_pols[policy_key].update(reward)\n",
    "        sum_rewards += reward\n",
    "        cumul_rewards.append(sum_rewards)\n",
    "        \n",
    "        sa = np.concatenate((state, action))\n",
    "        transitions.append(sa)\n",
    "        \n",
    "        sa_cell, active_cover, state_partition, update_flag, update_s_part = update_partition(sa, C_a, t, active_cover, state_partition)\n",
    "    return cumul_rewards"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "c149a214",
   "metadata": {},
   "outputs": [],
   "source": [
    "def zorl(env, T, hyperparams, seed, verbose=False):\n",
    "    C_a = hyperparams[0]                                  # cell activation coefficient\n",
    "    L_r = hyperparams[1]                                  # bonus coefficient\n",
    "    C_c = hyperparams[2]                                  # confidence coefficient\n",
    "    C_H = hyperparams[3]                                  # episode duration parameter\n",
    "    eps_bd = hyperparams[4]                               # base discretization parameter\n",
    "    gamma = 0.05\n",
    "    delta = 0.1\n",
    "    \n",
    "    active_cover = [Cell(env.state_space[0]+env.action_space[0], \n",
    "                         env.state_space[1]+env.action_space[1],\n",
    "                         d_S=env.d_S, factor=env.scaling_factor, part_scheme='adapt'),]\n",
    "    \n",
    "    state_partition = [active_cover[0].s_proj,]\n",
    "    \n",
    "    # The next block will be executed\n",
    "    max_diam = 1\n",
    "    now = time.time()\n",
    "    while max_diam > eps_bd:\n",
    "        diams = {}\n",
    "        for cell in active_cover:\n",
    "            diams[cell] = cell.diam\n",
    "        max_diam = max(diams.values())\n",
    "        for cell in active_cover:\n",
    "            if diams[cell] > eps_bd:\n",
    "                while cell.visits <= C_a*(cell.diam**(-(d_S+2))):\n",
    "                    cell.visits += 1\n",
    "                cell.get_children()\n",
    "                active_cover = active_cover + cell.children\n",
    "                active_cover.remove(cell)\n",
    "                if cell.s_proj in state_partition:\n",
    "                    state_partition.remove(cell.s_proj)\n",
    "                    state_partition = state_partition + cell.s_proj.children\n",
    "    visit_snap = {}\n",
    "    for cell in active_cover:\n",
    "        cell.visits = 0\n",
    "        visit_snap[cell] = 1\n",
    "    \n",
    "    state_partition_k = state_partition.copy()\n",
    "    transitions = []\n",
    "    episode_start = False\n",
    "    \n",
    "    episode_count = 0\n",
    "    \n",
    "    sum_rewards = 0\n",
    "    cumul_rewards = []\n",
    "    \n",
    "    h = 0\n",
    "    \n",
    "    np.random.seed(seed)\n",
    "    next_state = env.init()\n",
    "    for t in range(T):\n",
    "        if t == 0 or episode_start:\n",
    "            h = 0\n",
    "            episode_start = False\n",
    "            episode_count += 1\n",
    "            if verbose:\n",
    "                print(\"Episode: {} | Stage: {}\".format(episode_count, t+1))\n",
    "            state_partition_k = state_partition.copy()\n",
    "            transition_counter = {}\n",
    "            for cell in active_cover:\n",
    "                transition_counter[cell] = {}\n",
    "                for s_cell in state_partition:\n",
    "                    transition_counter[cell][s_cell] = 0\n",
    "            for cell in active_cover:\n",
    "                if t-1 in cell.visit_times:\n",
    "                    cell.visit_times.remove(t-1)\n",
    "                for i in cell.visit_times:\n",
    "                    next_cell = find_cell(transitions[i+1][:env.d_S],state_partition)\n",
    "                    transition_counter[cell][next_cell] += 1\n",
    "            p_hat = {}\n",
    "            r_hat = {}\n",
    "            d_hat = {}\n",
    "            visit_snap = {}\n",
    "            for cell in active_cover:\n",
    "                p_hat[cell] = {k: v / max(1,cell.visits) for k, v in transition_counter[cell].items()}\n",
    "                r_hat[cell] = env.get_reward(cell.center) + L_r*cell.diam\n",
    "                d_hat[cell] = cell.diam\n",
    "                visit_snap[cell] = max(1,cell.visits)\n",
    "            start = time.time()\n",
    "            policy = evi(p_hat, r_hat, active_cover, state_partition_k, 1/np.sqrt(max(1,t)), C_c)\n",
    "            \n",
    "            policy_cells = {}\n",
    "            for st_cell in state_partition_k:\n",
    "                st = st_cell.center\n",
    "                acn = policy[st_cell].center[env.d_S:]\n",
    "                stacn = np.concatenate((st, acn))\n",
    "                cl = find_cell(stacn, active_cover)\n",
    "                policy_cells[st_cell] = cl\n",
    "            diam_pol = epe(p_hat, d_hat, state_partition_k, policy_cells, gamma, C_c)\n",
    "            H = C_H*np.log(T)*(diam_pol**(-2*env.d_S - 2))\n",
    "        h += 1\n",
    "        \n",
    "        state = next_state.copy()\n",
    "        state_cell = find_cell(state, state_partition_k)\n",
    "        action = policy[state_cell].center[env.d_S:]\n",
    "        \n",
    "        next_state, reward = env.step(action)\n",
    "        sum_rewards += reward\n",
    "        cumul_rewards.append(sum_rewards)\n",
    "        sa = np.concatenate((state, action))\n",
    "        transitions.append(sa)\n",
    "        old_active_cover = active_cover.copy()\n",
    "        sa_cell, active_cover, state_partition, _, _ = update_partition(sa, C_a, t, active_cover, state_partition)\n",
    "        \n",
    "        if h >= H: \n",
    "            episode_start = True\n",
    "    return cumul_rewards"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "0e5e9d03",
   "metadata": {},
   "outputs": [],
   "source": [
    "M = Cont_gridworld()\n",
    "d_S = M.d_S\n",
    "d_A = M.d_A\n",
    "d = d_S + d_A\n",
    "T = 4000\n",
    "\n",
    "### Hyperparameters ###\n",
    "## PZRL ##\n",
    "C_d = 1\n",
    "C_i = 1.2\n",
    "hp = [3, C_d, C_i]\n",
    "\n",
    "## ZoRL ##\n",
    "C_a = 1\n",
    "L_r = 0.001\n",
    "C_c = 0.1\n",
    "C_H = 1e-5\n",
    "eps_bd = 1\n",
    "\n",
    "zorl_hps = [C_a, L_r, C_c, C_H, eps_bd]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "377f6a21",
   "metadata": {},
   "outputs": [],
   "source": [
    "repeats = 50\n",
    "expts = ['pmf', 'pmb', 'zorl']\n",
    "rewards, regrets = {}, {}\n",
    "colors = {'pmf':rgblist[8], 'pmb':rgblist[6], 'zorl':rgblist[2]}\n",
    "expt_names = {'pmf':'PZRL-MF', 'pmb':'PZRL-MB', 'zorl':'ZoRL'}\n",
    "for expt in expts:\n",
    "    rewards[expt] = np.zeros((repeats, T))\n",
    "    regrets[expt] = np.zeros((repeats, T))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "2f4d08b5",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run:  50\r"
     ]
    }
   ],
   "source": [
    "verbose = False\n",
    "for run in range(repeats):\n",
    "    print(\"Run: \", run+1, end='\\r', flush=True)\n",
    "    for expt in expts:\n",
    "        start = time.time()\n",
    "        if expt == 'pmf':\n",
    "            rewards[expt][run] = pzrlmf(M, T, hp, run, verbose)\n",
    "        elif expt == 'pmb':\n",
    "            rewards[expt][run] = pzrlmb(M, T, hp, run, verbose)\n",
    "        elif expt == 'zorl':\n",
    "            rewards[expt][run] = zorl(M, T, zorl_hps, run, verbose)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "0d18a8fe",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAk4AAAG0CAYAAADEuKgXAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy81sbWrAAAACXBIWXMAAA9hAAAPYQGoP6dpAADTrUlEQVR4nOzdd5xU1f34/9e9d/rM9r5Ll2YBGyj2Eks0wUJEk2BMSCwxRFM+MSbGFH9Ro8knRT9+Y0zUWPMxH1FjjWLXKIKAAoKUpcOyfXf6zC3n/P6YZWQFZFmWnd2d8/SxD5k7d+68z+7szntOeR9NSilRFEVRFEVR9krPdQCKoiiKoiiDhUqcFEVRFEVRekglToqiKIqiKD2kEidFURRFUZQeUomToiiKoihKD6nESVEURVEUpYdU4qQoiqIoitJDrlwHMNAIIWhubiYYDKJpWq7DURRFURSlB6SUxONxKisr0fUD1y+kEqdPaW5u5pRTTsl1GIqiKIqi9MKbb75JdXX1Abu+Spw+JRgMAplvfCgU2uv5juOwbNkyJk+ejGEYBzq8nMu39kL+tTnf2gv51+Z8ay/kX5vzrb0A4XCY008/Pfs+fqCoxOlTdgzPhUKhHidOgUCAUCiUFy/OfGsv5F+b8629kH9tzrf2Qv61Od/aC5k2Awd8mo2aHK4oiqIoitJDKnFSFEVRFEXpIZU4KYqiKIqi9JCa46QoiqLkLcdxsCwr12H0uR3zfVKp1JCZ4+R2uwdEW1TipCiKouQdKSWNjY10dnbmOpQDQkqJy+Vi06ZNQ6omYXFxMdXV1Tltk0qcFEVRlLyzI2mqrKwkEAgMqeQCMolTMpnE7/cPibZJKUkkEjQ3NwNQU1OTs1hU4qQoiqLkFcdxsklTWVlZrsM5IKSUCCHw+XxDInEC8Pv9QKZQdWVlZc6G7dTkcEVRFCWv7JjTFAgEchyJsq92/MxyOS9NJU6KoihKXhoqPTH5ZCD8zFTipCiKoiiK0kMqcVIURVEURekhNTlcURRFUQaJ008/nZaWFlyuzNu3lJJQKMT06dO57rrruPLKK1m8eHH2Pk3TEEKQSqW47bbbuPDCC5kwYQJerzc7uVpKidvt5ogjjuAXv/gFw4cPB2DChAk89NBDHHvssT2K7Wtf+xoLFy7kpptu4stf/nK3+1auXMmFF17IMcccw8MPP8zWrVv53Oc+t9tVf5dffjlz5szZr+/TgaQSJ0VRFEVhx0q0ZL89n673rlTATTfdxIwZM7K3V69ezTe+8Q38fj/33nsv8MnyfY/HwzXXXMOWLVv43Oc+l33M3/72t24J0datW/nhD3/I9ddfzz/+8Y9et6mkpISnnnpql8Rp7ty5hEKhXc5/7rnnGDZsWK+fb2dxK94n19kblTgpiqIoeU9KyeIlFxMOL+m35ywqOpqjj/rnfk94njBhAlOnTmXlypW73PerX/2K5cuX889//pPCwsI9XmPYsGGcd955/P73v9+vWM455xwef/xxNmzYwOjRowEwTZMXXniBz3/+82zevHm/rr87pmPSnGhmVduqPr/27qg5ToqiKIoCQO5XbO0ry7JYsGAB7733HieccEK3++69916ef/557r777r326qxfv54nnniCk08+eb/iKS0t5eSTT+app57KHnv55ZeZNGkS1dXV+3VtIQWWY2EJi22xbWyKbGJtx1qWtizl47aPiZmx/bp+T6keJ0VRFCXvaZrG0Uf9c9AM1d16663Z29XV1cyePZtLL700e+y5557jnnvu4Y477mDy5Mm7XOPb3/42hmFgWRaWZTFmzBjOPvtsLr/88t41ZiczZszg17/+Nd///vfRdZ25c+dyySWXsHbt2l3OPe+889D1T/pwDj74YB5++OFu5zjCwZEOlrBIO2kc4bApvAnpkui6jkt3UR2qps1s2+/Ye0IlToqiKIpCJnkyjIFfFPOXv/xltzlOn7Zo0SJuuOEGfvCDH3DGGWfs9py//OUvHHvsscTjce644w5eeOEFzjrrrGx17r35whe+QENDAwC1tbU8//zz2ftOPfVUfvGLXzB//nxGjx7N6tWrOf3003ebOD3zzDO79IZJKZFIHOngCAdb2AgpADA0A0MzqAhUoHtyM2g26BKnZ555hl/+8pfdju2oIPrRRx+xdOlSbr75Zurr6ykpKeHqq69m5syZuQhVURRFUfrVhg0bmDNnDpdccglf/epX93p+MBjkhhtuoLW1lW9961s88cQTVFVV7fVxOydKn+ZyuZg+fTpPPfUUo0aNYvr06Xg8nr1eU0qJkIK0k0ZIgURmVwa6dFdmhaAm9nqdA23QzXE677zz+OCDD7JfL774IsXFxdxyyy2Ew2GuvPJKLrjgAt5//31uueUWfvOb37Bs2bJch60o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GWdw9tln87d/+7dUq1Vgdl5j2PucZ+t1hmR8V199NZ/61Kcay6b9GhvLAfMHf/AH5uMf/7gpl8tmy5Yt5h3veIf5l3/5l+ke1gHzuc99znzqU5+asHxoaMiceeaZ5vbbbzdRFJlHHnnErFq1yjz77LPGGGMee+wxs2rVKvPkk0+aMAzNbbfdZtasWWPK5fLhnkJTPPnkk+aCCy4wy5cvN4899pgx5uDn+JWvfMVceumlZtu2baZQKJiPfvSj5o//+I+nbY67M9mcjTHmPe95j/ne97436T4zcc6VSsWcffbZ5stf/rIJgsAMDAyYP/7jPzbXXnvtrLzGe5uvMbPv+hpjTH9/vzn11FPN3XffbZRSpre317zzne80X/7yl2flNTZm73M2ZnZe5zpf+tKXzIknnmg++clPGmOOjHu1FU4HyKZNm8zy5cvNjh07Gst+/OMfm/POO28aR3VwXHXVVeb222+fsPw73/mOueiii8Yt+5//83+aT3ziE8YYYz7+8Y+bT3/60+PWv/3tbzd33XXX1A32APne975nzjvvPPPjH/94nIg42Dm+5S1vMf/+7//eWLdr1y6zYsUKs2XLlqmcTlPsac5BEJiTTz7ZrFu3btL9ZuKcN27caD70oQ+ZOI4by37605+aM844Y1Ze473NdzZe3zqFQsEYY4zW2qxdu9ZceOGF5pvf/OasvMZ19jTn2XydH3nkEXPJJZeY66+/viGcjoRrbF11B8j69etpb2+np6enseyEE05g27ZtjQ7NMwmtNS+++CK//OUveetb38pb3vIW/vqv/5rh4WHWr1/P8uXLx22/dOlSXn75ZSBpa7O39UcS55xzDvfffz+XXHLJuOUHM8dCocCOHTvGre/u7qatre2A+y4eSvY055dffpk4jrnxxhs566yzuPjii7nlllvQWgMzc87HH388X//618d1g//P//xPTj755Fl5jfc239l4fevUW4ice+65XHrppcybN4/LLrtsVl7jOnua82y9zv39/fzVX/0VX/jCF8hkMo3lR8I1tsLpACmVSuMuJtB4XS6Xp2NIB8XAwAAnnXQSF198Mffeey933nknmzZt4oYbbph0rul0ujHPfa0/kpg3b16jj+FYDmaOpVIJSJpM776+vm462dOcC4UCZ555JldffTUPPPAAn//85/nmN7/JrbfeCszsOQMYY/ji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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "reward_mean, reward_std = {}, {}\n",
    "for expt in expts:\n",
    "    reward_mean[expt] = np.mean(rewards[expt],axis=0)\n",
    "    reward_std[expt] = np.std(rewards[expt],axis=0)\n",
    "np.save('GriWorld_data.npy', [reward_mean, reward_std])\n",
    "\n",
    "plt.figure()\n",
    "plt.tight_layout()\n",
    "for expt in expts:\n",
    "    plt.plot(np.arange(1,T+1),reward_mean[expt], color=colors[expt],label=expt_names[expt])\n",
    "    plt.fill_between(np.arange(1,T+1),reward_mean[expt]-reward_std[expt],\n",
    "                     reward_mean[expt]+reward_std[expt], color=colors[expt], alpha=0.2)\n",
    "    plt.legend(fontsize=10,loc='best')\n",
    "plt.grid()\n",
    "plt.xlabel('Time',fontsize=16)\n",
    "plt.ylabel('Cumulative reward',fontsize=16)\n",
    "plt.xlim(-100,T)\n",
    "plt.ylim(-10)\n",
    "plt.savefig(\"GridWorld_cumul_reward.pdf\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "dec57da9",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.9.18"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
