{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "num_iters = 4000\n",
    "env_num = 5\n",
    "spec_num = 0\n",
    "use_gpu = True"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "from agents.baseline_var_estim import baseline_var_estim\n",
    "from agents.bucketed_var import bucketed_var\n",
    "from agents.dirl_agent_graphs import DIRLCumRewardAgentGraph, DIRLTimeTakenAgentGraph\n",
    "from spectrl.hierarchy.construction import adj_list_from_task_graph, automaton_graph_from_spec\n",
    "from spectrl.hierarchy.reachability import HierarchicalPolicy, ConstrainedEnv\n",
    "from spectrl.main.spec_compiler import ev, seq, choose, alw\n",
    "from spectrl.rl.ddpg.ddpg import DDPGParams\n",
    "from spectrl.util.io import parse_command_line_options, save_log_info, save_object\n",
    "from spectrl.util.rl import print_performance, get_rollout\n",
    "from spectrl.rl.ars import HyperParams\n",
    "\n",
    "from spectrl.examples.rooms_envs import (\n",
    "    GRID_PARAMS_LIST,\n",
    "    MAX_TIMESTEPS,\n",
    "    START_ROOM,\n",
    "    FINAL_ROOM,\n",
    ")\n",
    "from spectrl.envs.rooms import RoomsEnv\n",
    "\n",
    "import os"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Drawing samples for [0] -> 1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/10000 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10000/10000 [01:28<00:00, 113.61it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Drawing samples for [0] -> 2\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10000/10000 [01:28<00:00, 113.36it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Drawing samples for [0, 1] -> 3\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10000/10000 [01:27<00:00, 113.76it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Drawing samples for [0, 2] -> 3\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10000/10000 [01:27<00:00, 114.22it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Drawing samples for [0] -> 2\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10000/10000 [01:28<00:00, 113.50it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Drawing samples for [0, 2] -> 3\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10000/10000 [01:27<00:00, 114.19it/s]\n"
     ]
    }
   ],
   "source": [
    "from agents.baseline_var_estim import baseline_var_estim\n",
    "from agents.bucketed_var import bucketed_var\n",
    "from agents.calculate_coverage import calculate_coverage\n",
    "from agents.dirl_agent_graphs import DIRLCumRewardAgentGraph\n",
    "\n",
    "import dill as pickle\n",
    "import json\n",
    "\n",
    "with open(\"experiments_data/mousenav-policies/path_policies.pkl\", \"rb\") as f:\n",
    "    path_policies = pickle.load(f)\n",
    "\n",
    "with open(\"experiments_data/mousenav-policies/adj_list.pkl\", \"rb\") as f:\n",
    "    adj_list = pickle.load(f)\n",
    "\n",
    "with open(\"experiments_data/mousenav-policies/terminal_vertices.pkl\", \"rb\") as f:\n",
    "    terminal_vertices = pickle.load(f)\n",
    "\n",
    "cum_reward_score_graph = DIRLCumRewardAgentGraph(adj_list, path_policies, cum_reward_type=\"cum_safety_reach_reward\")\n",
    "n_samples = 10000\n",
    "n_samples_coverage = 10000\n",
    "es = [0.2, 0.1, 0.05]\n",
    "total_buckets = [5, 10, 15, 20]\n",
    "\n",
    "data_cum_reward = dict()\n",
    "data_cum_reward[\"metadata\"] = {\"es\": es, \"total_buckets\": total_buckets, \"scores\": \"cum-reward\", \"env\": \"9-rooms\", \"spec\": spec_num, \"n_samples\": n_samples}\n",
    "\n",
    "for e in es:\n",
    "    e_data = dict()\n",
    "    for buckets in total_buckets:\n",
    "        bucket_data = dict()\n",
    "        vbs = bucketed_var(cum_reward_score_graph, e, buckets, n_samples)\n",
    "        min_path, min_path_scores = baseline_var_estim(cum_reward_score_graph, e, n_samples)\n",
    "        vb = vbs.buckets[(terminal_vertices[0], buckets)]\n",
    "\n",
    "        bucket_data[\"bucketed\"] = {\"path\": vb.path, \n",
    "                                   \"path_buckets\": vb.path_buckets, \n",
    "                                   \"path_score_quantiles\": vb.path_score_quantiles, \n",
    "                                   \"max_path_score_quantile\": max(vb.path_score_quantiles)}\n",
    "        bucket_data[\"all-paths\"] = {\"path\": min_path, \"min_path_scores\": min_path_scores, \"max_min_path_scores\": max(min_path_scores)}\n",
    "\n",
    "        bucket_data[\"bucketed-coverage\"] = calculate_coverage(\n",
    "            cum_reward_score_graph, vb.path, vb.path_score_quantiles, n_samples_coverage\n",
    "        )\n",
    "        bucket_data[\"all-paths-coverage\"] = calculate_coverage(\n",
    "            cum_reward_score_graph, \n",
    "            min_path, \n",
    "            [max(min_path_scores) for _ in range(len(min_path)-1)], \n",
    "            n_samples_coverage,\n",
    "        )\n",
    "        e_data[buckets] = bucket_data\n",
    "    data_cum_reward[str(e)] = e_data\n",
    "\n",
    "# Convert the Python object to a JSON string\n",
    "json_data = json.dumps(data_cum_reward, indent=2)\n",
    "\n",
    "# Store the JSON string in a file\n",
    "with open(\"experiments_data/mousenav-cum-reward.json\", \"w\") as json_file:\n",
    "    json_file.write(json_data)\n",
    "\n",
    "with open(\"experiments_data/mousenav-policies/cum-rew-score-graph.pkl\", \"wb\") as f:\n",
    "    pickle.dump(cum_reward_score_graph, f)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Drawing samples for [0] -> 1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10000/10000 [01:28<00:00, 113.21it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Drawing samples for [0, 1] -> 3\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10000/10000 [01:28<00:00, 113.39it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "path 1 success prob 1.0\n",
      "path 2 success prob 1.0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "trajectories_scores1 = cum_reward_score_graph.sample_full_path_cached([0, 1, 3], n_samples)\n",
    "trajectories_scores2 = cum_reward_score_graph.sample_full_path_cached([0, 2, 3], n_samples)\n",
    "\n",
    "# trajectories_scores1 = cum_reward_score_graph.sample_full_path_cached([0, 1], n_samples)\n",
    "# trajectories_scores2 = cum_reward_score_graph.sample_full_path_cached([0, 1], n_samples)\n",
    "\n",
    "successful_trajs1, successful_trajs2 = 0, 0\n",
    "\n",
    "for i in range(n_samples):\n",
    "    if all(trajectories_scores1[i][j] <= 0 for j in range(2)):\n",
    "        successful_trajs1 += 1\n",
    "    if all(trajectories_scores2[i][j] <= 0 for j in range(2)):\n",
    "        successful_trajs2 += 1\n",
    "\n",
    "print(\"path 1 success prob \" + str(successful_trajs1/n_samples))\n",
    "print(\"path 2 success prob \" + str(successful_trajs2/n_samples))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "with open(\"experiments_data/mousenav-policies/cum-rew-score-graph.pkl\", \"wb\") as f:\n",
    "    pickle.dump(cum_reward_score_graph, f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.collections.PathCollection at 0x7f7fac4f9190>"
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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Pf3001q5cuWgN5bH+7EtKytTS0uL5fexxMpg7e3s7NTSpUuVl5enBx98cMBtpcrrP+nPjFxp7NixuuGGG/T+++/3+3xOTk6fu7lPnz6tnJycWFQvKo4fP669e/fqO9/5TkTrjR49WjfffHPI/5t41nt8Ijl211xzjdLT0xP2ePcGkePHj2vPnj0RT0E+2HshXn3mM5/RNddcE7LeiX5ce/32t7/VsWPHIn4fS/F1bO+55x79z//8j/bv368pU6YElufk5OjChQs6e/ZsUPmBjtNQ3uexFqq9vbq6ulRUVKSsrCzt2LFDo0ePjmj7g73+E1XKhZFPPvlEH3zwgVwuV7/Pu91u7du3L2jZnj17gs4gxLtnnnlGEyZM0NKlSyNaz+fzqbm5OeT/TTybNm2acnJygo5dZ2enDh48GPLYZWRkaO7cuUHr+P1+7du3L+6Pd28Qee+997R3716NHz8+4m0M9l6IV3/605/08ccfh6x3Ih/Xyz311FOaO3euZs+eHfG68XBsjTG65557tGPHDr3++uuaNm1a0PNz587V6NGjg47TsWPHdOLEiZDHaSjv81gZrL3SpbouXrxYGRkZ+vWvfz2koRQGe/0nLItvoB1xP/zhD019fb1pa2szv/vd70xhYaG55pprTEdHhzHGmDvuuMPcd999gfK/+93vzKhRo8ymTZvMO++8YyoqKszo0aNNc3OzVU2IiM/nM1OnTjXr1q3r89yVba2srDR1dXXmgw8+MIcPHza33367sdvt5u23345llcPW1dVljhw5Yo4cOWIkmSeeeMIcOXIk0INkw4YNZuzYseaVV14x//u//2uWLVtmpk2bZv785z8HtnHrrbean/70p4HHNTU1JjMz0zz77LOmtbXV3HXXXWbs2LGmvb095u273EBtvXDhgvnKV75ipkyZYo4ePWo8Hk/gr6enJ7CNK9s62HvBKgO1taury/zoRz8yDQ0Npq2tzezdu9fMmTPHXH/99aa7uzuwjUQ5rsYM/jo2xhiv12s+9alPmerq6n63kQjHtrS01DidTlNfXx/0Gj1//nygzN13322mTp1qXn/9dfPWW28Zt9tt3G530HZmzJhhXn755cDjcN7nVhisvV6v18yfP9/MmjXLvP/++0Fl/vKXvwS2c3l7w339J4OkDyPf/OY3jcvlMhkZGWby5Mnmm9/8pnn//fcDz3/pS18yq1evDlrnxRdfNDfccIPJyMgwN910k3n11VdjXOuhq6urM5LMsWPH+jx3ZVvvvfdeM3XqVJORkWEmTpxovvzlL5umpqYY1jYy+/fvN5L6/PW2ye/3m/Xr15uJEyeazMxMs3Dhwj7/D9dee62pqKgIWvbTn/408P8wb9488+abb8aoRaEN1Na2trZ+n5Nk9u/fH9jGlW0d7L1glYHaev78ebN48WLz6U9/2owePdpce+215rvf/W6fUJEox9WYwV/HxhizefNmc9VVV5mzZ8/2u41EOLahXqPPPPNMoMyf//xn873vfc+MGzfOfOpTnzJf/epXjcfj6bOdy9cJ531uhcHaG+q4SzJtbW1B2+ldJ9zXfzKwGWNMlE+2AAAAhC3l7hkBAADxhTACAAAsRRgBAACWIowAAABLEUYAAIClCCMAAMBShBEAAGApwggAALAUYQQAAFiKMAIAACxFGAEAAJYijAAAAEv9f8bCwfwgafpYAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "\n",
    "pp = cum_reward_score_graph.path_policies.get_vertex_path_policy([0])\n",
    "sarss = get_rollout(\n",
    "    pp.reach_envs[1],\n",
    "    pp.policies[1],\n",
    "    False,\n",
    "    init_state=None\n",
    ")\n",
    "states = [state for state, _, _, _ in sarss] + [sarss[-1][-1]]\n",
    "x_coords = [state[0] for state in states]\n",
    "y_coords = [state[1] for state in states]\n",
    "\n",
    "# Plot the points\n",
    "plt.scatter(y_coords, x_coords)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[8.951920929984633, 7.954876804469033, 6.961256615436351, 5.970793757694742, 4.973419671880259, 3.974164561890137, 2.9745106095520564, 1.974657679830174, 0.9746586994152873, -0.025341300032347525, 0.4920079666983836, 1.4920079666983836, 2.4920079666983836, 3.4920079666983836, 4.492007966698384, 5.492007966698384, 6.492007966698384, 7.492007966698384, 8.492007966698383, 9.492007966698383, 10.492007966698383, 11.492007966698383, 12.492007966698383, 13.492007966698383, 13.492007966698383, 13.492007966698383, 13.492007966698383, 13.492007966698383, 13.492007966698383, 13.492007966698383, 13.492007966698383, 13.492007966698383, 13.492007966698383, 13.492007966698383, 13.492007966698383, 13.492007966698383, 13.492007966698383, 13.492007966698383, 13.492007966698383, 13.492007966698383, 13.492007966698383, 13.492007966698383]\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x7f07ce545b50>]"
      ]
     },
     "execution_count": 32,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "reach_env = pp.reach_envs[1]\n",
    "safety_rewards = []\n",
    "for s in states:\n",
    "    safety_rewards.append(reach_env.constraints[0](s, None))\n",
    "\n",
    "print(safety_rewards)\n",
    "plt.plot(safety_rewards)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "venv",
   "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.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
