{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Checking all presentations solved by GS"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "## Imports\n",
    "from collections import defaultdict\n",
    "from importlib import resources\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from ac_solver.envs.ac_env import ACEnv\n",
    "from ast import literal_eval\n",
    "\n",
    "## Load data\n",
    "filename = \"greedy_search_paths.txt\"\n",
    "with resources.open_text('ac_solver.search.miller_schupp.data', filename) as file:\n",
    "    gs_paths = [literal_eval(path) for path in file]\n",
    "\n",
    "filename = \"greedy_solved_presentations.txt\"\n",
    "with resources.open_text('ac_solver.search.miller_schupp.data', filename) as file:\n",
    "    gs_solved = [np.array(literal_eval(presentation)) for presentation in file]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "All pahs checked with success!\n"
     ]
    }
   ],
   "source": [
    "## Check that greedy paths are correct\n",
    "\n",
    "from ac_solver.envs.ac_moves import ACMove\n",
    "\n",
    "for i, (state, AC_path) in enumerate(zip(gs_solved, gs_paths)):\n",
    "    max_relator_length = len(state) // 2\n",
    "    len1 = np.count_nonzero(state[:max_relator_length])\n",
    "    len2 = np.count_nonzero(state[max_relator_length:])\n",
    "    lengths = [len1, len2]\n",
    "\n",
    "    for move_id, _ in AC_path[1:]:\n",
    "        state, lengths = ACMove(move_id=move_id-1, # minus one as ACMove \n",
    "                                presentation=state,\n",
    "                                max_relator_length=max_relator_length,\n",
    "                                lengths=lengths,\n",
    "                                cyclical=False,\n",
    "                                )\n",
    "    assert np.count_nonzero(state) == 2 and state[0] !=0 and state[max_relator_length] !=0, f\"path is incorrect, got {state} for i={i}\"\n",
    "\n",
    "print(\"All pahs checked with success!\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Checking two presentations solved by PPO with variable horizon length"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Here we also check the AC-paths for the two presentations solved by PPO with variable horizon length schedule. \n",
    "\n",
    "$$\\langle x, y \\mid x^{-1} y^3 x y^{-4} , \\ x^{-1} y^{-1} x y^{-3} x^{-1} y^{-1} \\rangle$$\n",
    "$$\\langle x, y \\mid x^{-1} y^4 x y^{-5} , \\ x^{-1} y x y^{-1} x^{-1} y^{-3} \\rangle$$\n",
    "\n",
    "We refer to these presentations as presentations # 636 and # 700 as they are listed at these numbers in [this file](https://github.com/Anonymous/AC-Solver/blob/main/ac_solver/search/miller_schupp/data/all_presentations.txt) containing Miller-Schupp presentations."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "from ac_solver.envs.utils import convert_relators_to_presentation\n",
    "from ac_solver.envs.ac_moves import ACMove\n",
    "\n",
    "def check_paths_loaded_from_text_files(rel1, rel2, max_relator_length, filename, cyclical):\n",
    "    with open(filename, \"r\") as f:\n",
    "        AC_path = f.read()\n",
    "        AC_path = AC_path[1:-1].split(\",\")\n",
    "        AC_path = [int(move_id) for move_id in AC_path]\n",
    "    \n",
    "    lengths = [len(rel1), len(rel2)]\n",
    "    state = convert_relators_to_presentation(relator1=rel1, relator2=rel2, max_relator_length=max_relator_length)\n",
    "\n",
    "    max_total_length = sum(lengths)\n",
    "\n",
    "    print(f\"Checking the provided path of length {len(AC_path)}...\")\n",
    "    for move_id in AC_path:\n",
    "        state, lengths = ACMove(move_id=move_id, # minus one as ACMove \n",
    "                                presentation=state,\n",
    "                                max_relator_length=max_relator_length,\n",
    "                                lengths=lengths,\n",
    "                                cyclical=cyclical,\n",
    "                                )\n",
    "        \n",
    "        max_total_length = max(max_total_length, sum(lengths))\n",
    "            \n",
    "    assert np.count_nonzero(state) == 2 and state[0] !=0 and state[max_relator_length] !=0, \"path is incorrect\"\n",
    "    print(f\"Solved with success!\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Presentation 1"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Paths are stored in text files \"paths/AC_paths_636.txt\" and \"paths/AC_paths_636_reduced.txt\"."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Checking the provided path of length 205...\n",
      "Solved with success!\n",
      "Checking the provided path of length 195...\n",
      "Solved with success!\n"
     ]
    }
   ],
   "source": [
    "rel1 = [-1, 2, 2, 2, 1, -2, -2, -2, -2] # 9\n",
    "rel2 = [-1, -2, 1, -2, -2, -2, -1, -2] # 8\n",
    "max_relator_length = 36\n",
    "\n",
    "check_paths_loaded_from_text_files(rel1=rel1, rel2=rel2, \n",
    "                                max_relator_length=max_relator_length, \n",
    "                                filename=\"paths/AC_path_636.txt\", \n",
    "                                cyclical=False)\n",
    "\n",
    "check_paths_loaded_from_text_files(rel1=rel1, rel2=rel2, \n",
    "                                max_relator_length=max_relator_length, \n",
    "                                filename=\"paths/AC_path_636_reduced.txt\", \n",
    "                                cyclical=False)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Presentation 2"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Paths are stored in text files \"paths/AC_paths_700.txt\" and \"paths/AC_paths_700_reduced.txt\"."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Checking the provided path of length 1085...\n",
      "Solved with success!\n",
      "Checking the provided path of length 381...\n",
      "Solved with success!\n"
     ]
    }
   ],
   "source": [
    "rel1 = [-1, 2, 2, 2, 2, 1, -2, -2, -2, -2, -2] # 11\n",
    "rel2 = [-1, 2, 1, -2, -1, -2, -2, -2] # 8\n",
    "max_relator_length = 36\n",
    "\n",
    "check_paths_loaded_from_text_files(rel1=rel1, rel2=rel2, \n",
    "                                max_relator_length=max_relator_length, \n",
    "                                filename=\"paths/AC_path_700.txt\", \n",
    "                                cyclical=False)\n",
    "\n",
    "check_paths_loaded_from_text_files(rel1=rel1, rel2=rel2, \n",
    "                                max_relator_length=max_relator_length, \n",
    "                                filename=\"paths/AC_path_700_reduced.txt\", \n",
    "                                cyclical=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "env",
   "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.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
