{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "70a31e05",
   "metadata": {},
   "source": [
    "# Cardinal & Rotation Grid"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "8a0383c3",
   "metadata": {},
   "source": [
    "## Cardinal Grid"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "7058c812",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "from matplotlib import pyplot as plt\n",
    "from utils.treexplore import *\n",
    "from utils.explorers import *\n",
    "import pandas as pd\n",
    "import seaborn as sns\n",
    "\n",
    "\n",
    "class TabularGrid:\n",
    "\n",
    "    def __init__(self, h, w, t_max):\n",
    "        self.h = h\n",
    "        self.w = w\n",
    "        self.t_max = t_max\n",
    "        self.action_map = {0: (-1, 0), 1: (1, 0), 2: (0, -1), 3: (0, 1)}\n",
    "        self.num_states = h * w\n",
    "        self.reset()\n",
    "\n",
    "    @property\n",
    "    def state(self):\n",
    "        x, y = self.pos\n",
    "        return self.w * x + y\n",
    "\n",
    "    def step(self, action):\n",
    "        x, y = self.pos\n",
    "        # Player move.\n",
    "        dx, dy = self.action_map[action]\n",
    "        x = min(max(0, x + dx), self.h - 1)\n",
    "        y = min(max(0, y + dy), self.w - 1)\n",
    "\n",
    "        self.pos = (x, y)\n",
    "        reward = 0.\n",
    "        done = False\n",
    "        info = {}\n",
    "        self.timer += 1\n",
    "        # if self.pos[0] == self.h - 1:\n",
    "        #   reward = -1.\n",
    "        #   done = True\n",
    "        if self.pos[1] == self.w - 1 and self.pos[0] == self.h - 1:\n",
    "            reward = 1.\n",
    "            done = True\n",
    "        elif self.timer == self.t_max:\n",
    "            done = True\n",
    "        return self.state, reward, done, info\n",
    "\n",
    "    def reset(self):\n",
    "        self.pos = (int(self.h / 2), int(self.w / 2))\n",
    "        self.timer = 0\n",
    "        return self.state\n",
    "\n",
    "def collect_states(env, explorer, n_traj):\n",
    "    states = []\n",
    "    for _ in range(n_traj):\n",
    "        explorer.reset()\n",
    "        done = False\n",
    "        obs = env.reset()\n",
    "        states.append(obs)\n",
    "        while not done:\n",
    "            action = explorer.get_action()[0]\n",
    "            explorer._add_single_action(action)\n",
    "            obs, _, done, _ = env.step(action)\n",
    "            states.append(obs)\n",
    "    return len(np.unique(states))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "9cb91974",
   "metadata": {},
   "outputs": [],
   "source": [
    "EQUALITIES = {\n",
    "    'baseline': [],\n",
    "    'left_right_commute': [([0, 1], [1, 0])],\n",
    "    'all_commute': [([0, 1], [1, 0]), ([0, 2], [2, 0]), ([1, 2], [2, 1]),\n",
    "              ([0, 3], [3, 0]), ([3, 1], [1, 3]), ([3, 2], [2, 3])],\n",
    "    'left_right_inv': [([0, 1], []), ([1, 0], []), ([0, 2], [2, 0]), ([1, 2], [2, 1]),\n",
    "                       ([0, 3], [3, 0]), ([3, 1], [1, 3]), ([3, 2], [2, 3])],\n",
    "    'all_inv': [([0, 1], []), ([1, 0], []), ([0, 2], [2, 0]), ([1, 2], [2, 1]),\n",
    "                       ([0, 3], [3, 0]), ([3, 1], [1, 3]), ([3, 2], []), ([2, 3], [])],\n",
    "}\n",
    "nb_actions = 4"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "b1e036b8",
   "metadata": {},
   "outputs": [],
   "source": [
    "env = TabularGrid(100, 100, 100)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "f89b0ee8",
   "metadata": {},
   "outputs": [],
   "source": [
    "df = pd.DataFrame(columns=list(['equality', 'nb of states', 'depth', 'n_traj']), dtype=object)\n",
    "# for faster compute, only one seed here\n",
    "# for _ in range(30):\n",
    "for _ in range(1):\n",
    "#     for n_traj in [100]:\n",
    "    for n_traj in [10]:\n",
    "        # depths = [4]\n",
    "        depths = [2, 3, 4, 5, 6, 7]\n",
    "        for depth in depths:\n",
    "            for k, v in EQUALITIES.items():\n",
    "                if len(v) == 0:\n",
    "                    explorer = NaiveExplorer(actions=list(range(nb_actions)), depth=4)\n",
    "                else:\n",
    "                    explorer = GraphExplorer(actions=list(range(nb_actions)), depth=depth, equalities=v, verbose=False)\n",
    "                nstates = collect_states(env, explorer, n_traj=n_traj)\n",
    "                df.loc[-1] = [k, nstates, depth, n_traj]\n",
    "                df.index += 1\n",
    "\n",
    "df.to_csv('dataframes/graph_nb_states_grid_one_seed.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "3735c6ff",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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f/NVTrjnu6zvbZ8UkdrTpoVjHfeLX/yClStXcsQRR/C+970PgC9+8Yts2rSJVatW8bnPfQ4YHpldf/31LF++nOXLlxd7QW3evJnDDjuMD33oQyxbtoyzzz6bTCZDKpXibW97G0cccQTLly/n1ltvHXV8o41jrOssXbqUD37wgyxfvpz3vve9PPjgg5x44oksWrSIp59+esL7LV++vDiO6667jmuuuWbU9+Dmm28uNl/8yEc+MqK31Vjv81jvTYGvfvWrLFmyhDPPPJPXXnutzN+oxwsvvFAstDsaruty9913T+ic5ZJMJnnyySf53ve+t1cCNVjMdcCzjWsaqkzbeKETrtmxESfVgxatIti4kEBlw4TyRE6mH2egk0BVE7GlpxBqWYpmhMY/0OfARERKfgHzgbuBLqADuAuYP95x++LryCOPlN15+eWXiz9/+qk75bR7vzfm10PbN8i8X18r2k8+U/ya9+tr5aHtG8Y85tNP3TnimqPR3d0tIiLpdFqWLVsmXV1dIiISi8WGfS/nuPXr18vixYuls7Nz2D5vvvmmLFu2bNjxhfOuXbtWli9fLslkUgYGBuTwww+XZ555Rt58803RdV2effZZERG55JJL5KabbpLbbrtNPvjBDxbPk0gkRoxttHGMd50XXnhBHMeRNWvWyFVXXSWu68qdd94p73znO4uvodz9hr7Wb37zm/KVr3xlxPaXX35Z3v72t4tpmiIi8nd/93fy85//vKz3eaz3Zuj7mUqlpK+vTxYsWCDf/OY3R/0djsZTTz0lK1askDfeeGPEc47jyBVXXCGf//znyz7fRLjpppvkb//2b0VE5MQTT5R169ZN+ByubYmd6Rc7lRA7MyBONlnWl51Jitm7QzJtz0n6jb9KdvsrYg10l328k03KSy88J8mXH5H+5+6R9Bt/FTvdN9lvkc9+Blgro9zjy8lm/hL4Hl7jQoB3A7cAx062WO5rYkaQtmTvsG1tyV5ixt6XPtnTpoWjHffXv/6Viy++mPr6emD8hoXgNRK88MILicW89l0XXXQRjz32GOeffz7z5s1j1apVwGDTwksvvZTPfvazfOELX+Dtb387b3nLW0ac849//OOIcdx0000lr7NixQoAli1bxhlnnIFSakTDwnL3K4eHHnqIdevWcfTRRwOQyWRobBzZPmW097m5uXnU9wbgscce48IL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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "df = pd.read_csv('dataframes/graph_nb_states_grid.csv')\n",
    "\n",
    "for i in range(30):\n",
    "    df.loc[i*30:(i+1)*(30),'seeds'] = i\n",
    "\n",
    "df_new = df.pivot(index=['depth', 'seeds'], columns='equality', values='nb of states').rename_axis(None, axis=1).reset_index() \n",
    "\n",
    "EQUALITIES = ['all_commute', 'all_inv', 'left_right_commute', 'left_right_inv']\n",
    "ratio_list = [key + '_ratio' for key in EQUALITIES]\n",
    "for key in EQUALITIES:\n",
    "    col_name = key + '_ratio'\n",
    "    df_new[col_name] = df_new[key] / df_new['baseline']\n",
    "\n",
    "df_new = df_new[['depth', 'seeds', 'left_right_commute_ratio', 'all_commute_ratio', 'left_right_inv_ratio', 'all_inv_ratio']]\n",
    "df_new = df_new.melt(id_vars=['depth', 'seeds'])\n",
    "df_new['ratio_percent'] = df_new['value'] * 100\n",
    "\n",
    "df_plot = df_new.loc[df_new['depth'] < 8]\n",
    "g = sns.lineplot(data=df_plot, x='depth', y='ratio_percent', hue='variable', marker='.', markersize=12,\n",
    "            palette=sns.color_palette('colorblind')[:4])\n",
    "g.set(ylim=(100, None))\n",
    "plt.xlabel('DAG depth')\n",
    "plt.ylabel('Unique visited states: ratio over baseline (%)')\n",
    "plt.legend(title='$\\Omega$', labels=[r\"$\\rightarrow$ and $\\leftarrow$ commute\",\n",
    "                                     r\"all actions commute\",\n",
    "                                     r\"all actions commute and $\\rightarrow \\leftarrow \\sim \\Lambda$\",\n",
    "                                     r\"all actions commute and $\\rightarrow \\leftarrow \\sim \\uparrow \\downarrow \\sim \\Lambda$\"],\n",
    "          )\n",
    "# plt.title('GraphExplorer')\n",
    "plt.tight_layout()\n",
    "plt.savefig('images/graph_grid_states_equality.pdf')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "d1b8c874",
   "metadata": {},
   "source": [
    "## Rotation Grid"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "2ccaef73",
   "metadata": {},
   "outputs": [],
   "source": [
    "class TabularGridRotation:\n",
    "\n",
    "    def __init__(self, h, w, t_max, random_rotation=True):\n",
    "        self.h = h\n",
    "        self.w = w\n",
    "        self.t_max = t_max\n",
    "        self.rotation = 0\n",
    "        self.action_map = {0: (1, 0), 1: (0, 1), 2: (-1, 0), 3: (0, -1)}\n",
    "        self.num_states = h * w\n",
    "        self.random_rotation = random_rotation\n",
    "        self.reset()\n",
    "\n",
    "    @property\n",
    "    def state(self):\n",
    "        x, y = self.pos\n",
    "        return self.w * x + y\n",
    "\n",
    "    def step(self, action):\n",
    "        x, y = self.pos\n",
    "        # Player move.\n",
    "        if action == 0:\n",
    "            self.rotation += 1\n",
    "            self.rotation = self.rotation % 4\n",
    "        elif action == 1:\n",
    "            self.rotation -= 1\n",
    "            self.rotation = self.rotation % 4\n",
    "        else:\n",
    "            dx, dy = self.action_map[self.rotation]\n",
    "            x = min(max(0, x + dx), self.h - 1)\n",
    "            y = min(max(0, y + dy), self.w - 1)\n",
    "            self.pos = (x, y)\n",
    "\n",
    "        reward = 0.\n",
    "        done = False\n",
    "        info = {}\n",
    "        self.timer += 1\n",
    "        # if self.pos[0] == self.h - 1:\n",
    "        #   reward = -1.\n",
    "        #   done = True\n",
    "        if self.pos[1] == self.w - 1 and self.pos[0] == self.h - 1:\n",
    "            reward = 1.\n",
    "            done = True\n",
    "        elif self.timer == self.t_max:\n",
    "            done = True\n",
    "        return self.state, reward, done, info\n",
    "\n",
    "    def reset(self):\n",
    "        self.pos = (int(self.h / 2), int(self.w / 2))\n",
    "        self.timer = 0\n",
    "        if self.random_rotation:\n",
    "            self.rotation = np.random.randint(0, 4)\n",
    "        else:\n",
    "            self.rotation = 0\n",
    "        return self.state\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "6569493e",
   "metadata": {},
   "outputs": [],
   "source": [
    "EQUALITIES = {\n",
    "    'baseline': [],\n",
    "    'inverse1': [([0, 1], [])],\n",
    "    'inverse2': [([0, 1], []), ([1, 0], [])],\n",
    "    'double_rotation': [([0, 1], []), ([1, 0], []), ([0, 0], [1, 1])],\n",
    "}\n",
    "nb_actions = 3"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "684c7af9",
   "metadata": {},
   "outputs": [],
   "source": [
    "env = TabularGridRotation(100, 100, 100, random_rotation=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "7a0a44cc",
   "metadata": {},
   "outputs": [],
   "source": [
    "df = pd.DataFrame(columns=list(['equality', 'nb of states', 'depth', 'n_traj']), dtype=object)\n",
    "# for _ in range(30):\n",
    "for _ in range(1):\n",
    "#     for n_traj in [100]:\n",
    "    for n_traj in [10]:    \n",
    "        depths = [2, 3, 4, 5, 6, 7]\n",
    "        for depth in depths:\n",
    "            for k, v in EQUALITIES.items():\n",
    "                if len(v) == 0:\n",
    "                    explorer = NaiveExplorer(actions=list(range(nb_actions)), depth=4)\n",
    "                else:\n",
    "                    explorer = GraphExplorer(actions=list(range(nb_actions)), depth=depth, equalities=v, verbose=False)\n",
    "                nstates = collect_states(env, explorer, n_traj=n_traj)\n",
    "                df.loc[-1] = [k, nstates, depth, n_traj]\n",
    "                df.index += 1\n",
    "\n",
    "df.to_csv('dataframes/graph_nb_states_rotation_one_seed.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "583d6c97",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "df = pd.read_csv('dataframes/graph_nb_states_rotation.csv')\n",
    "df['seeds'] = 0\n",
    "df['seeds'] = df['seeds'].astype(int)\n",
    "for i in range(30):\n",
    "    df.loc[i*24:(i+1)*(24),'seeds'] = i\n",
    "\n",
    "df_new = df.pivot(index=['depth', 'seeds'], columns='equality', values='nb of states').rename_axis(None, axis=1).reset_index()\n",
    "\n",
    "\n",
    "EQUALITIES = ['inverse1', 'inverse2', 'double_rotation']\n",
    "ratio_list = [key + '_ratio' for key in EQUALITIES]\n",
    "for key in EQUALITIES:\n",
    "    col_name = key + '_ratio'\n",
    "    df_new[col_name] = df_new[key] / df_new['baseline']\n",
    "\n",
    "df_new = df_new[['depth', 'seeds'] + ratio_list]\n",
    "df_new = df_new.melt(id_vars=['depth', 'seeds'])\n",
    "df_new['ratio_percent'] = df_new['value'] * 100\n",
    "\n",
    "df_plot = df_new.loc[df_new['depth'] < 8]\n",
    "g = sns.lineplot(data=df_plot, x='depth', y='ratio_percent', hue='variable', marker='.', markersize=12,\n",
    "            palette=sns.color_palette('colorblind')[:3])\n",
    "g.set(ylim=(100, None))\n",
    "plt.xlabel('DAG depth')\n",
    "plt.ylabel('Unique visited states: ratio over baseline (%)')\n",
    "plt.legend(title='$\\Omega$', labels=[r\"$\\curvearrowright \\curvearrowleft \\sim \\Lambda$\",\n",
    "                                     \"$\\curvearrowright \\curvearrowleft \\sim \\curvearrowleft \\curvearrowright \\sim \\Lambda$\",\n",
    "                                     r\"$\\curvearrowright \\curvearrowleft \\sim \\curvearrowleft \\curvearrowright \\sim \\Lambda$ and $\\curvearrowright \\curvearrowright \\sim \\curvearrowleft\\curvearrowleft$\",],\n",
    "          )\n",
    "plt.tight_layout()\n",
    "plt.savefig('images/graph_rotation_states_equality.pdf')"
   ]
  }
 ],
 "metadata": {
  "interpreter": {
   "hash": "0051b4cd805f3ded47e3c56f25b95d701f613ce8602f545fb15c8dba2005c110"
  },
  "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.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
