{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Import necessary modules\n",
    "\n",
    "import sys\n",
    "import os\n",
    "\n",
    "# Set root folder to project root\n",
    "os.chdir(os.path.dirname(os.getcwd()))\n",
    "\n",
    "# Add root folder to path\n",
    "sys.path.append(os.getcwd())\n",
    "\n",
    "import numpy as np\n",
    "import pickle\n",
    "\n",
    "from src.utils.plotting import plot_mazes\n",
    "from src.utils.plotting import plot_diagram\n",
    "from src.utils.tda import Analysis, get_betti_nums"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Time for analysis: 309.42min\n"
     ]
    }
   ],
   "source": [
    "# Load Analysis object\n",
    "model_name = 'pi_net'\n",
    "file_name = f'outputs/tda/analysis/{model_name}_maze_sizes-[9, 19, 29, 39, 49, 59, 69]_num_mazes-100_iters-3001,3400_embed_dim-0_delay-1.pkl'\n",
    "with open(file_name, 'rb') as f:\n",
    "    analysis = pickle.load(f)\n",
    "\n",
    "analysis.print_time()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "Betti numbers for raw latent iterates with threshold 0.2:\n",
      "[1 0]: 700\n",
      "\n"
     ]
    }
   ],
   "source": [
    "# Count betti numbers\n",
    "threshold = 0.2\n",
    "\n",
    "from collections import Counter\n",
    "\n",
    "# AFTER EXPERIMENT IS FINISHED\n",
    "betti_nums = analysis.get_betti_nums(threshold=threshold)\n",
    "\n",
    "# # BEFORE EXPERIMENT IS FINISHED\n",
    "# completed_maze_sizes = len(analysis.maze_sizes) - 2\n",
    "# betti_nums = np.zeros((completed_maze_sizes, analysis.num_mazes, analysis.max_homo+1), dtype=int)\n",
    "# for i in range(completed_maze_sizes):\n",
    "#     for j in range(analysis.num_mazes):\n",
    "#         betti_nums[i, j] = get_betti_nums(analysis.diagrams[i, j], threshold)\n",
    "\n",
    "\n",
    "# Print betti numbers for raw latent iterates\n",
    "betti_nums_list = []\n",
    "for i in range(len(betti_nums)):\n",
    "    for j in range(len(betti_nums[i])):\n",
    "        betti_nums_list.append(f'[{betti_nums[i,j,0]} {betti_nums[i,j,1]}]')\n",
    "\n",
    "        if betti_nums[i,j,0] == 400 and betti_nums[i,j,1] == 0:\n",
    "            print(f\"{i} {j}: {betti_nums[i,j]}\")\n",
    "counter = Counter(betti_nums_list)\n",
    "print()\n",
    "\n",
    "# Print most common betti numbers in descending order of frequency\n",
    "print(f\"Betti numbers for raw latent iterates with threshold {threshold}:\")\n",
    "for value, count in counter.most_common():\n",
    "    print(f\"{value}: {count}\")\n",
    "print()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "True"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "import numpy as np\n",
    "diagram = [np.array([[0, np.inf]]), np.zeros(shape=(0,2))]\n",
    "\n",
    "(diagram[0] == [[0, np.inf]]).all() and (diagram[1] == np.zeros((0, 2))).all()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAxYAAAMWCAYAAABsvhCnAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8hTgPZAAAACXBIWXMAAA9hAAAPYQGoP6dpAAA+/0lEQVR4nO3de5xU9X34//csd4RdRHBXFESNETVEGiyI2pCGrRhtvURjSo2A4avSqMlD/RHvEtMkmNhUMVFomotRa71Gk6jRULzEy4oK3hAxxqiouFyE3UW5757fH5aJG5bbfmaYXXw+H495MHvmc+Z8Tjmh+/LMOZPLsiwLAACABGWlngAAAND+CQsAACCZsAAAAJIJCwAAIJmwAAAAkgkLAAAgmbAAAACSCQsAACBZx1JP4OOsqakpFi5cGD179oxcLlfq6QAAQDNZlsWKFSuiX79+UVa2+XMSwqKEFi5cGP379y/1NAAAYLPeeuut2GOPPTY7RliUUM+ePSPiw7+o8vLyEs8GAACaa2hoiP79++d/b90cYVFCGz7+VF5eLiwAAGiztuZj+y7eBgAAkgkLAAAgmbAAAACSCQsAACCZsAAAAJIJCwAAIJmwAAAAkgkLAAAgmbAAAACSCQsAACBZx1JPAACAwmlqaor169dHU1NTqadCiZWVlUWnTp0il8ttl+0JCwCAHUB9fX00NDTEypUrRQV5nTp1ip49e0afPn2iQ4cORd2WsAAAaMeyLItFixbF8uXLo3v37tGnT5/o2rVrlJWVbbf/Uk3bk2VZNDY2xvvvvx91dXWxatWq6N+/f1HjQlgAALRjy5cvj+XLl0dVVVXsvPPOpZ4ObUyPHj2ioqIiFixYEEuXLo3KysqibcvF2wAA7VSWZVFXVxc9e/YUFWxSt27dory8PFasWBFZlhVtO8ICAKCdWr9+faxZsyYqKipKPRXauJ49e8a6deti3bp1RduGsAAAaKcaGxsjIqJjR59uZ/M2XFtRzAv7hQUAQDvnIm22ZHscI8ICAABIJiwAAIBkwgIAAEgmLAAAgGTCAgAASCYsAABgKz388MORy+Uil8vFt771ra1aZ/z48fl13njjjU2Omzt3bpxxxhmxzz77RLdu3aJv377xd3/3dzF9+vRYv359YXagiNz0GAAASuy//uu/4qyzzoq1a9fml61evToee+yxeOyxx+IXv/hF3HvvvdGnT58SznLznLEAAIASuu+++2LixImxdu3aqKysjGuuuSZmzZoVv/vd7+KLX/xiREQ89dRTcfzxx+e/FLEtcsYCAABKZN26dXH22WdHU1NTlJeXx+OPPx777LNP/vUjjzwyzjzzzLjuuuviscceixtvvDHGjx9fuglvhjMWAABQInfddVf8+c9/joiICy+8sFlUbHDllVfGzjvvnH/eVgkLAAAokbvvvjv/fFNnIrp37x4nnXRSRETMmzcv/vjHP26HmW07YQEAACXy2GOPRUTEfvvtF1VVVZscN3LkyPzzxx9/vOjzag1hAQAAJfD+++/HW2+9FRERgwYN2uzYj77+8ssvF3VereXibQAAaIXFixfH3Llztziurq6uxeVvv/12/vkee+yx2ffo379//vmGGGlrhAUAALTCtGnTYtq0aa1ef8WKFfnnPXr02OzYnXbaKf/8/fffb/U2i8lHoQAAoARWr16df965c+fNju3SpUv++apVq4o2pxTCAgCAgnrmjWUx7udPxfDv/W+M+/lT8cwby0o9paKYPHlyZFm2xce4ceNaXL9r16755x/9xu2WrFmzJv+8W7duhdmBAvNRKAAACuaZN5bFl3/yZESWRWMWsWTFknjsT0vj1tMPiYMH9i719NqUnj175p9v6eNNH3zwQf75lj42VSrOWAAAUDA/evBP+aiIiGjKIrIs+3A5zey+++755x+9kLslH71g+6MXcrclwgIAgIKZX9uQj4oNmrIPl9Ncz54985Ewf/78zY796Ov7779/UefVWsICAICCGVRVHmW55svKch8uZ2OHH354RES88sorUVtbu8lxjzzySP75YYcdVvR5tYawAACgYM7+/Ccil8vl46IsF5HL5eLroz5R2om1Uccdd1z++fXXX9/imJUrV8Ztt90WEREHHHBAfPKTn9wOM9t2wgIAgII5eGDvuPX0Q+Lv9u0bleVd4u/27Ru3nXFIDN3ThdstOf7442PvvfeOiIgpU6bEa6+9ttGYSZMmxfLly/PP2yp3hQIAoKAOHtg7fvnVYaWeRrvQqVOn+NGPfhT/9E//FA0NDXHYYYfFJZdcEsOGDYvly5fHf/3Xf8Wdd94ZER9+bOqUU04p8Yw3TVgAAEAJHXXUUTF9+vQ466yzYtGiRXH22WdvNGbYsGFx1113RYcOHUoww63jo1AA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LItrr702mpqatjh+3rx5cf3110cul4ujjjqqUNMAAABKoGBh8fWvfz122mmneO2112LixImbvW5ixowZccQRR8Tq1aujd+/ecdpppxVqGgAAQAkU7HazlZWVMX369Bg7dmz87Gc/iwceeCCOPvro/OtTp06NLMvi8ccfj/nz50eWZVFWVhbXX3999OjRo1DTAAAASiCXZVlWyDe87bbb4owzzoj6+vrI5XIbvb5hcz169Ihf/vKXcfzxxxdy8+1KQ0NDVFRURH19fZSXl5d6OgAA0My2/L5asI9CbXDSSSfFn/70p7j88stj6NCh0aFDh8iyLP848MAD48ILL4w//elPH+uoAACAHUnBz1j8taampli2bFk0NjZG7969899dgTMWAAC0bdvy+2rBrrHYlLKysujTp0+xNwMAAJRQwcKisbExnn766Xj00Ufjj3/8YyxfvjxWrFgR5eXl0bt379hvv/3i8MMPj4MPPjjKygr+CSwAAKCEksNi/fr1ce2118a///u/x8KFC7c4vn///jFp0qSYOHFidOjQIXXzAABAG5B0jcV7770Xxx9/fDz++OMR8Zc7Pm12g/93p6jPfe5zcfvtt0fv3r1bu/l2zzUWAAC0ZdvlGovGxsY4+uij4+mnn44syyKXy8URRxwR1dXV8ZnPfCZ22WWX6NGjR6xYsSKWLl0azz77bMyYMSNmzpwZWZbFww8/HMccc0z84Q9/8NEoAABo51p9xuK73/1uXHrppZHL5WLIkCFx4403xgEHHLDF9ebOnRtjx46N5557LnK5XHzve9+L888/vzVTaPecsQAAoC3blt9XWxUW69atiz322COWLl0af/M3fxOPPfZYdO3adavXX716dRx22GHx7LPPxq677hpvv/12dOxY9BtUtTnCAgCAtqzoX5D329/+NpYsWRK5XC5uuummbYqKiIiuXbvGjTfeGLlcLpYsWRL33HNPa6YBAAC0Ea0Ki8ceeywiIqqrq2PQoEGt2vABBxwQ//AP/xAREY8++mir3gMAAGgbWhUWs2fPjlwuF6NGjUra+KhRoyLLspg9e3bS+wAAAKXVqrB46623IiLi05/+dNLGN6z/5ptvJr0PAABQWq0Ki/r6+oiI2HnnnZM2vmH9De8HAAC0T60Ki4aGhoiI6NGjR9LGd9ppp4iIWLFiRdL7AAAApdWqsGhsbCzoJJqamgr6fgAAwPblK68BAIBkSd9Kd91118Wuu+7a6vUXL16csnkAAKCNSAqLadOmFWoeAABAO9bqsMiyrJDzAAAA2rFWhcVDDz1U6HkAAADtWKvCYuTIkYWeBwAA0I65KxQAAJBMWAAAAMmEBQAAkExYAAAAyYQFAACQTFgAAADJhAUAAJBMWAAAAMmEBQAAkExYAAAAyYQFAACQTFgAAADJhAUAAJBMWAAAAMmEBQAAkExYAAAAyYQFAACQTFgAAADJhAUAAJBMWAAAAMmEBQAAkExYAAAAyYQFAACQTFgAAADJhAUAAJBMWAAAAMmEBQAAkExYAAAAyYQFAACQTFgAAADJhAUAAJBMWAAAAMmEBQAAkExYAAAAyYQFAACQTFgAAADJhAUAAJBMWAAAAMmEBQAAkExYAAAAyYQFAACQTFgAAADJhAUAAJBMWAAAAMmEBQAAkExYAAAAyYQFAACQTFgAAADJhAUAAJBMWAAAAMmEBQAAkExYAAAAyYQFAACQTFgAAADJhAUAAJBMWAAAAMmEBQAAkExYAAAAyYQFAACQTFgAAADJhAUAAJBMWAAAAMmEBQAAkExYAAAAyYQFAACQTFgAAADJhAUAAJBMWAAAAMmEBQAAkExYAAAAyYQFAACQTFgAAADJhAUAAJBMWAAAAMmEBQAAkExYAAAAyYQFAACQTFgAAADJhAUAAJBMWAAAAMmEBQAAkExYAAAAyYQFAACQTFgAAADJhAUAAJBMWAAAAMmEBQAAkExYAAAAyYQFAACQTFgAAADJhAUAAJBMWAAAAMmEBQAAkExYAAAAyXb4sFi2bFmcfPLJUV5eHr169YoJEybE+++/v9l1Vq9eHWeeeWbssssu0aNHjzjhhBNi0aJF+deff/75GDNmTPTv3z+6desW+++/f0ydOrXYuwIAAG3WDh8WJ598crz00ksxY8aMuOeee+IPf/hDnH766Ztd55xzzonf/va3cfvtt8cjjzwSCxcujC9+8Yv512fPnh277rpr3HTTTfHSSy/FxRdfHBdeeGH8+Mc/LvbuAABAm5TLsiwr9SSK5eWXX44DDjggnn766Tj44IMjIuL++++Po446Kt5+++3o16/fRuvU19dH37594+abb44TTzwxIiLmz58f+++/f9TU1MQhhxzS4rbOPPPMePnll+PBBx/c6vk1NDRERUVF1NfXR3l5eSv2EAAAimdbfl/doc9Y1NTURK9evfJRERFRXV0dZWVlMWvWrBbXmT17dqxbty6qq6vzywYNGhQDBgyImpqaTW6rvr4+evfuXbjJAwBAO9Kx1BMoptra2th1112bLevYsWP07t07amtrN7lO586do1evXs2WV1ZWbnKdJ554Im699da49957NzufNWvWxJo1a/I/NzQ0bMVeAABA29cuz1hccMEFkcvlNvuYP3/+dpnL3Llz49hjj43JkyfHEUccsdmxU6ZMiYqKivyjf//+22WOAABQbO3yjMV5550X48eP3+yYvffeO6qqqmLx4sXNlq9fvz6WLVsWVVVVLa5XVVUVa9eujbq6umZnLRYtWrTROvPmzYtRo0bF6aefHpdccskW533hhRfGueeem/+5oaFBXAAAsENol2HRt2/f6Nu37xbHjRgxIurq6mL27NkxdOjQiIh48MEHo6mpKYYPH97iOkOHDo1OnTrFzJkz44QTToiIiFdeeSUWLFgQI0aMyI976aWX4vOf/3yMGzcuvvvd727VvLt06RJdunTZqrEAANCe7NB3hYqI+MIXvhCLFi2K6dOnx7p16+LUU0+Ngw8+OG6++eaIiHjnnXdi1KhRccMNN8SwYcMiIuJf//Vf47777ovrr78+ysvL4+yzz46ID6+liPjw40+f//znY/To0XHllVfmt9WhQ4etCp4N3BUKAIC2bFt+X22XZyy2xX//93/HWWedFaNGjYqysrI44YQT4pprrsm/vm7dunjllVdi5cqV+WVXXXVVfuyaNWti9OjRcd111+Vfv+OOO2LJkiVx0003xU033ZRfvueee8Ybb7yxXfYLAADakh3+jEVb5owFAABtme+xAAAAtithAQAAJBMWAABAMmEBAAAkExYAAEAyYQEAACQTFgAAQDJhAQAAJBMWAABAMmEBAAAkExYAAEAyYQEAACQTFgAAQDJhAQAAJBMWAABAMmEBAAAkExYAAEAyYQEAACQTFgAAQDJhAQAAJBMWAABAMmEBAAAkExYAAEAyYQEAACQTFgAAQDJhAQAAJBMWAABAMmEBAAAkExYAAEAyYQEAACQTFgAAQDJhAQAAJBMWAABAMmEBAAAkExYAAEAyYQEAACQTFgAAQDJhAQAAJBMWAABAMmEBAAAkExYAAEAyYQEAACQTFgAAQDJhAQAAJBMWAABA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1NMpuYaGhujfv3+89dZbUV5eXurp0AY5RtgSxwhb4hhhSxwjzWVZFitWrIh+/fpFWdnmr6JwxqKEysrKYo899ij1NNqc8vJy/0NmsxwjbIljhC1xjLAljpG/2NKZig1cvA0AACQTFgAAQDJhQZvRpUuXmDx5cnTp0qXUU6GNcoywJY4RtsQxwpY4RlrPxdsAAEAyZywAAIBkwgIAAEgmLAAAgGTCgu1m2bJlcfLJJ0d5eXn06tUrJkyYEO+///5m11m9enWceeaZscsuu0SPHj3ihBNOiEWLFrU49r333os99tgjcrlc1NXVFWEPKLZiHCPPP/98jBkzJvr37x/dunWL/fffP6ZOnVrsXaFArr322hg4cGB07do1hg8fHk899dRmx99+++0xaNCg6Nq1awwePDjuu+++Zq9nWRaXXXZZ7LbbbtGtW7eorq6OV199tZi7QJEV8hhZt25dnH/++TF48ODYaaedol+/fjF27NhYuHBhsXeDIir0vyMfNXHixMjlcnH11VcXeNbtVAbbyZFHHpkddNBB2ZNPPpk9+uij2Sc+8YlszJgxm11n4sSJWf/+/bOZM2dmzzzzTHbIIYdkhx56aItjjz322OwLX/hCFhHZ8uXLi7AHFFsxjpGf/exn2de//vXs4Ycfzl577bXsxhtvzLp165b96Ec/KvbukOiWW27JOnfunP385z/PXnrppey0007LevXqlS1atKjF8Y8//njWoUOH7Ac/+EE2b9687JJLLsk6deqUvfjii/kxV1xxRVZRUZHdfffd2fPPP58dc8wx2V577ZWtWrVqe+0WBVToY6Suri6rrq7Obr311mz+/PlZTU1NNmzYsGzo0KHbc7cooGL8O7LBr371q+yggw7K+vXrl1111VVF3pP2QViwXcybNy+LiOzpp5/OL/vd736X5XK57J133mlxnbq6uqxTp07Z7bffnl/28ssvZxGR1dTUNBt73XXXZSNHjsxmzpwpLNqpYh8jH/W1r30t+/u///vCTZ6iGDZsWHbmmWfmf25sbMz69euXTZkypcXxJ510Unb00Uc3WzZ8+PDsjDPOyLIsy5qamrKqqqrsyiuvzL9eV1eXdenSJfuf//mfIuwBxVboY6QlTz31VBYR2ZtvvlmYSbNdFesYefvtt7Pdd989mzt3brbnnnsKi//jo1BsFzU1NdGrV684+OCD88uqq6ujrKwsZs2a1eI6s2fPjnXr1kV1dXV+2aBBg2LAgAFRU1OTXzZv3rz49re/HTfccEOUlTmk26tiHiN/rb6+Pnr37l24yVNwa9eujdmzZzf7uy0rK4vq6upN/t3W1NQ0Gx8RMXr06Pz4119/PWpra5uNqaioiOHDh2/2eKFtKsYx0pL6+vrI5XLRq1evgsyb7adYx0hTU1OccsopMWnSpDjwwAOLM/l2ym9hbBe1tbWx6667NlvWsWPH6N27d9TW1m5ync6dO2/0j3llZWV+nTVr1sSYMWPiyiuvjAEDBhRl7mwfxTpG/toTTzwRt956a5x++ukFmTfFsXTp0mhsbIzKyspmyzf3d1tbW7vZ8Rv+3Jb3pO0qxjHy11avXh3nn39+jBkzJsrLywszcbabYh0j3//+96Njx47x9a9/vfCTbueEBUkuuOCCyOVym33Mnz+/aNu/8MILY//994+vfOUrRdsGaUp9jHzU3Llz49hjj43JkyfHEUccsV22CbRP69ati5NOOimyLItp06aVejq0EbNnz46pU6fG9ddfH7lcrtTTaXM6lnoCtG/nnXdejB8/frNj9t5776iqqorFixc3W75+/fpYtmxZVFVVtbheVVVVrF27Nurq6pr9F+lFixbl13nwwQfjxRdfjDvuuCMiPrzjS0REnz594uKLL47LL7+8lXtGoZT6GNlg3rx5MWrUqDj99NPjkksuadW+sP306dMnOnTosNFd4Fr6u92gqqpqs+M3/Llo0aLYbbfdmo0ZMmRIAWfP9lCMY2SDDVHx5ptvxoMPPuhsRTtVjGPk0UcfjcWLFzf7lERjY2Ocd955cfXVV8cbb7xR2J1oZ5yxIEnfvn1j0KBBm3107tw5RowYEXV1dTF79uz8ug8++GA0NTXF8OHDW3zvoUOHRqdOnWLmzJn5Za+88kosWLAgRowYERERd955Zzz//PPx3HPPxXPPPRc//elPI+LD/+GfeeaZRdxztlapj5GIiJdeein+/u//PsaNGxff/e53i7ezFEznzp1j6NChzf5um5qaYubMmc3+bj9qxIgRzcZHRMyYMSM/fq+99oqqqqpmYxoaGmLWrFmbfE/armIcIxF/iYpXX301/vd//zd22WWX4uwARVeMY+SUU06JF154If97x3PPPRf9+vWLSZMmxQMPPFC8nWkvSn31OB8fRx55ZPY3f/M32axZs7LHHnss23fffZvdSvTtt9/O9ttvv2zWrFn5ZRMnTswGDBiQPfjgg9kzzzyTjRgxIhsxYsQmt/HQQw+5K1Q7Voxj5MUXX8z69u2bfeUrX8nefffd/GPx4sXbdd/YdrfcckvWpUuX7Prrr8/mzZuXnX766VmvXr2y2traLMuy7JRTTskuuOCC/PjHH38869ixY/bv//7v2csvv5xNnjy5xdvN9urVK/v1r3+dvfDCC9mxxx7rdrPtWKGPkbVr12bHHHNMtscee2TPPfdcs38z1qxZU5J9JE0x/h35a+4K9RfCgu3mvffey8aMGZP16NEjKy8vz0499dRsxYoV+ddff/31LCKyhx56KL9s1apV2de+9rVs5513zrp3754df/zx2bvvvrvJbQiL9q0Yx8jkyZOziNjoseeee27HPaO1fvSjH2UDBgzIOnfunA0bNix78skn86+NHDkyGzduXLPxt912W/bJT34y69y5c3bggQdm9957b7PXm5qasksvvTSrrKzMunTpko0aNSp75ZVXtseuUCSFPEY2/BvT0uOj/+7QvhT635G/Jiz+Ipdl//ehdAAAgFZyjQUAAJBMWAAAAMmEBQAAkExYAAAAyYQFAACQTFgAAADJhAUAAJBMWAAAAMmEBQBt1sMPPxy5XC5yuVw8/PDDO/x2AdozYQFAwX30F/OWHj169IhPfvKTccopp8SDDz5Y6ukCUADCAoDt7oMPPohXX301brrpphg1alSMGzcuGhsbi77dDWHzrW99q+jbAvi46VjqCQCwY/vXf/3X+NrXvpb/OcuyWLZsWdTU1MRVV10VixcvjhtuuCH69+8f3/nOd5qt+7nPfS6yLNveUwagFYQFAEW16667xqc+9amNlo8cOTKOOeaYGDp0aKxevTquueaauOyyy6Jz584lmCUAqXwUCoCSOeCAA+Loo4+OiIgVK1bE/PnzSzwjAFpLWABQUnvttVf++Zo1a5q9tqW7M40fPz5yuVwMHDgwIiLefffdOP/88+PAAw+Mnj175tcbOHBg5HK5/HqXX375RheUjx8/frPzvO2222LUqFHRt2/f6NatW+y3337xzW9+M5YtW9bqfQfYkfgoFAAl9eabb+afDxgwoNXv8+STT8Y//dM/xdKlSwsxrbympqY45ZRT4qabbmq2/I9//GNceeWVcdddd8Wjjz4aVVVVBd0uQHsjLAAomfnz58c999wTERGHHHJIVFZWtup93n///TjhhBNi9erVcfHFF8c//MM/RPfu3ePFF1+M3XbbLX7/+9/H2rVrY/DgwRGx8QXlERE777xzi+996aWXxhNPPBHHHXdcjB07Nvbcc89YtGhRXHvttXHvvffGn/70pzjnnHPif/7nf1o1d4AdhbAAoKgWL14cc+fOzf+cZVnU1dXl7wq1atWqqKioiKuuuqrV23jvvfeiR48e8dhjj8VBBx2UX/63f/u3LY7f1AXlLXniiSfiO9/5Tlx88cXNlh955JFx5JFHxu9///u444474pprrom+ffu2eh8A2jthAUBRTZs2LaZNm9bia2VlZTFx4sQ455xz4pOf/GTSdr75zW82i4pCGTp0aFx00UUbLc/lcnHuuefG73//+1i/fn3U1NTEMcccU/DtA7QXLt4GoGSamprilltuiWnTpm104fa2Ovnkkws0q+b+5V/+pdmF3x81dOjQ/PM///nPRdk+QHshLAAoqsmTJ0eWZc0eK1eujBdeeCEmTZoU77//flx99dVRXV0dK1eubNU2evToEXvvvXeBZ/6hQYMGbfK13r1755+vWLGiKNsHaC+EBQDbXbdu3WLw4MHxgx/8IK677rqIiHjsscfie9/7Xqver1evXgWcXXPdu3ff5GtlZX/5f6ONjY1FmwNAeyAsACipCRMm5P/L/89//vNWvUeHDh0KOSUAWkFYAFBSZWVlse+++0bEh19w995775V4RgC0hrAAoOTWr1/f4nMA2g9hAUBJrVy5MubNmxcRH1570adPn6Jtq2vXrhERyXegAmBjwgKAkvrWt74Vq1atioiI0aNHF/V6id122y0iIl577bWibQPg48oX5AFQVH/9zdsREatXr45XX301brjhhrj//vsj4sOzCd/+9reLOpdDDz00Xn/99fjNb34T//mf/xmHHXZY/ixGeXl57LrrrkXdPsCOTFgAUFSb++btDfr27Rs33XRTDB48uKhz+f/+v/8v7rjjjlizZk1MnDix2Wvjxo2L66+/vqjbB9iR+SgUANtd586do6qqKkaNGhU//OEP45VXXokjjjii6NsdMmRI1NTUxJgxY2LAgAHRpUuXom8T4OMil2VZVupJAAAA7ZszFgAAQDJhAQAAJBMWAABAMmEBAAAkExYAAEAyYQEAACQTFgAAQDJhAQAAJBMWAABAMmEBAAAkExYAAEAyYQEAACQTFgAAQDJhAQAAJBMWAABAsv8fY9MlxHe+pl8AAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 800x800 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_diagram(analysis.diagrams[4,54], threshold=0.2);"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Plot frequency of betti numbers at each maze size\n"
   ]
  }
 ],
 "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.10.14"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
