{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 143,
   "id": "delayed-chemical",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os, sys\n",
    "dir2 = os.path.abspath('')\n",
    "dir1 = os.path.dirname(dir2)\n",
    "if not dir1 in sys.path:\n",
    "    sys.path.append(dir1)\n",
    "import json\n",
    "import numpy as np\n",
    "from models.model_utils import get_model\n",
    "from data.data_utils import get_dataloader\n",
    "import torch\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "import time\n",
    "from collections import Counter"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "hearing-register",
   "metadata": {},
   "outputs": [],
   "source": [
    "root = None  # path to the experiments\n",
    "exp_name = 'Resnet18_CIFAR10_10k_100_COPIES'\n",
    "# exp_name = 'Resnet18_CIFAR10_45k_30X_ALL_DIFF'\n",
    "exp_dir = root.format(exp_name)\n",
    "# affinity_dir = os.path.join(exp_dir, 'neuron_correlation')\n",
    "affinity_dir = os.path.join(exp_dir, 'neuron_correlation_pca')\n",
    "print(os.listdir(affinity_dir)[0])\n",
    "print(affinity_dir)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 181,
   "id": "streaming-career",
   "metadata": {},
   "outputs": [],
   "source": [
    "model_index = {}\n",
    "for n in sorted(os.listdir(affinity_dir)):\n",
    "    if 'corr' not in n: continue\n",
    "    name, _ = n.split('.')\n",
    "    _, i, j = name.split('_')\n",
    "    i, j = int(i), int(j)\n",
    "    if i not in model_index:\n",
    "        model_index[i] = []\n",
    "    model_index[i].append(j)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 182,
   "id": "active-timber",
   "metadata": {},
   "outputs": [],
   "source": [
    "def align(corr_mat):\n",
    "    copy = corr_mat.copy()\n",
    "    for i in range(corr_mat.shape[0]):\n",
    "        match_idx = np.argmax(copy[i])\n",
    "        temp = copy[:, match_idx].copy()\n",
    "        copy[:, match_idx] = copy[:, i]\n",
    "        copy[:, i] = temp\n",
    "    return copy"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 239,
   "id": "grave-smith",
   "metadata": {},
   "outputs": [],
   "source": [
    "corr_mat = np.load(os.path.join(affinity_dir, 'corr_2_13.npy'))\n",
    "corr_mat = np.abs(corr_mat)\n",
    "# aligned_corr_mat = align(corr_mat)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 240,
   "id": "ebd87a48",
   "metadata": {},
   "outputs": [],
   "source": [
    "sns.set_palette(\"mako\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 241,
   "id": "instant-auction",
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAcwAAAHZCAYAAAALwAuuAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/YYfK9AAAACXBIWXMAAAsTAAALEwEAmpwYAAA8B0lEQVR4nO3deZSk+VXe+fvLyFhz36qy9q5eqrvV3dqFNoR7QLIHLFnyMEIDx2ANwoexZbA8Osh4hIwAY0DGPhgNXpA9yHDQDEa2hAZhDMK0QGptLanVavVeXdW1ZFXlvkVmZERmvPNHRE6XSpnv81R2ihbS93NOneyuePKNyFjeW5GZ996UZVkAAIB8Pc/2DQAA4C8DCiYAAAYKJgAABgomAAAGCiYAAAYKJgAABgomAAAGCiZwjZTS3SmlLKV09i/4eu/pXu+b/yKv95lIKb2te5t/+BvgttzQvS12c3lKqSel9GBKaSalNPT1vH34y4+CCUtK6Y6U0r9MKX0hpTSbUmqllOZSSp9KKf1CSunWZ/s2fiNLKb05pfTulNLzn+3bsl9SSqMR8U8i4omI+M0dLr87pfSPUkq/m1I6s13MUkpvMI9/V0rpAymlqZTSRkrpXErp11NKx/fra8iyrB0RPxMR4xHxrv06Lr459T7bNwDf2FJKxYj4lYj436LzD6x2RJzu/hmJiJdExMsi4h0ppV/IsuynnqWb+o3uzRHxVyLibETcv0vmXEQ8GhFLfyG36Jl7Z3SeA2/Psmxzh8s/HBF7eteWUvobEfG7EVGKiNmI+HJE3BIRfycivi+l9J1Zln1hL8fewQcj4isR8WMppfdmWfbUPh0X32R4h4ldpZR6IuJDEfH3IqIREf9HRExkWXYqy7KXZll2KiIORKeYXoyIb3/Wbuw3gSzLfijLstuyLPvQs31blJRSX0T8SESsRsTv7BJ7KDrvPH88Il4RERfMYx+KiA9Ep1j+UkQczrLsxRFxKCJ+OzpF+EMppcoz+Rq2ZZ35oL/Rvb6/ux/HxDcnCibyvCMi/npEbETEq7Ms+4Usy+avDmRZNp9l2b+LiOdExH9+Fm4jnh0/EBGDEfFfsixb2ymQZdkrsiz721mWvTfLsk9FxJZ57J+IiL6I+GSWZT+ZZVmre7y1iHhLRJyJiOPd/94vH+jevv81pVTax+PimwgFEztKKfVHp2BGRPx894S3qyzLVrMse+8OxxlIKb0rpXR/Smk1pVRPKX05pfSzu/2SxdW//JJSOpZSel/351etlNL7u5l3dzPvTylVu///UEpp7dpf1kkpnUgpvTel9Gj38uWU0mdSSn8vpXRdP5ZIKZ1KKf3j7m081/3Z2nxK6eMppbd035Vfnb+7+0sof6X7V79x1c/ysu2v59qve5fr/vaU0n9OKV1KKTVTSldSSh9OKX3nLvmv+uWllNL3pZTuTSmtdO+Dj6WUXnk9X/9Vvr/78SN7/Pw8b+x+/LfXXpBl2UZEvL/7v2+6noOmlH4kpbTZfQ689prjXoqIz0XnOyavvu5bjG8JFEzs5nui8/OprYj4N3s5QErpaHROQj8bEc+NzjuDJ6LzbvRdEfHFlNKNOYe4JTo/7/vbETEXEQ/H175LqUTExyPipyOiEJ1vA9avug2vjc7Pp/5+RBzrXv9cdH72+msR8dHrfEfxz7p/XhQR6xHxQPf6viMi/n1E/D/X5Jci4pMRsdz9/8e7/7/95zHnSlNK74iIP4+I/ykiihHxpe5Fr4+IP0kpvVt8/s9F51unx7q3oRAR3xUR//16i2ZKqRwRL+/+72ev53ONYx+LiKPd//2zXWIf7358SUqpYB73nRHxvug8Dq/Jsuz3d4h9pvvxfzBvLr7VZFnGH/58zZ+I+NWIyCLiS8/gGB/vHuPLEXHLVX9/MiK+0L3svojouebz7ulethkRH43Oz023L6t2P777qszpiHjuDpnbo1PMtiLiH0VE+arM86JTgLOI+KfXXP/d3b8/u8PX9PqIeHFEpGv+/oXR+YWdLCK+f4fP2/6a3pxzf+2YiU5ha3cve0dEFLp/3xOdnw9uX/Y3dvk6WhGxcvXl0fk54J92L//kdT6ur+x+3pXr/Lyz3c97Q07mu7qZjWvv46syR7uZLCJuvOrvb9j++6v+Ll31XL4QEXfmXPcPdHOf+Yt+vfHnL8cf3mFiN0e6H5/cyyenlL4jOu+6tgvI49uXZVl2JjrfdtuKzju179nlMLMR8aYsy2au+tz1azKFbuaBHTLvjohaRPxilmW/lHW+nbed+VJ0vq2YRee3I61fIMmy7PeyLLsvy7Lsmr//QkS8tfu/P+Qc6zq8Mzon/t/Nsuw9WZZtda+znWXZr8bTLR3/ZJfP742In82y7P//9mmWZUsR8bbu/74ipTRyHbfnhu7Hqev4HNdo9+PCtffxVa7+Ofqut7v7nYMPRMSPRecfM6/MsuzBnOve/npOmrcV32IomNjNYPfj6h4/f7sIfmynk1SWZacj4veuyV7rg1mWqev/SpZl9137l92T5eu6//vrO31ilmX3R+ddz2B03iFaUkqTKaV/2O0R/FhK6RMppU9ExC90Iy9wj2VcV190/uER0Wnv2cm/6H58UUrpwC6Zr7kPuv9oaHT/N+9b49favo753NTebP/DpZmTaVz139WdAt2fwX80Iv6X6PxY4Nsz3S6y/fWMXfuzaCCCPkzsbvtnbv17/PztQQZ5/6L/cnR+JnfbLpc/bFzPbplbonMyzSLit1NKu33+ePfj0d0CV0spvSki/kN0fotzN2POsUw3R+dddMTu9+X2z3YL0bkvp6+5fLb7jnInM9H5ueb1PM7bRa2Rm9qb7WPm/Vz56u8GXPsdh21/Gp1vnf9RRHyv8Q+vq4/V073+r8fXh7/EKJjYzcXux71+e2qg+/FKTubyNdlr1Xf5eycz3P2YovMzN6WmAimlk9H59mcpOv2AvxYRj0TEcpZlW91fYDod+/u62r5vGlmWLe8UyLJsM6U0GxEHY+f7Mu9+bHc/7vovih3MdT9ez7dxXQvbx04ppV2+LTu6Q/5at3Q/PmIWy6uPW8+yjGKJr8G3HbCbT3Q/3plSGs9N7myl+/FgTmbymux+2j5JNrMsS8af9xvHfFN0iuWnI+IHsyz7VJZlC9s/U4z9fWe5bfu+qaSUBncKdFtjxq/Jfz1t/yPo6/H1Ptr9WIpOr+VObup+bETEbt9m/avR+Q3lH08p/Yp53dtfz7Xv0IGIoGBid/81Ihaj822+vUw/2T7x3ZmT2b7skT0cX3k8Oj8HK6WUblFh0/a77Xt3eefzspzPtQeCX+OJeLqVZrf78rZ4+tu2X4/78lpf7H48uV/TdrZlWXY+nv7uxnfsEtvuaf3cVf9YufY4n42I10TnOfwPUkr/yrj653Q/ft67tfhWQ8HEjrIsW4mIf97933emlF6el08p9aeU/v5Vf/UH3Y+vTindsUP+xoh4Q/d/P/oMb+7XyDpTYbaP+/Z9Ouz2RJvJay/o9ia+9dq/v8r2z8d2/CWV3WRZVo+n+xHftkvsf+9+vC/Lsq/7u6Msy85F55elinEdvyx1HT7Y/fij117QvZ/f3P3f/5R3kCzLPhedorkQnXeavyqu96Xdj/e4NxTfWiiYyPOLEfGHEVGOiI+lzuaJq39+FCmloZTSW6LzCyn/8/bfZ1n2Z9E50aeI+L+vfpeXUjoRnZNdITr/mv+vX6fb/1PR+fndj6aU/sW1rRMppVpK6W+mlN5nHm+7cL0xpfTXrjrOWHS+nhM5n3u6+/HulPMbSLv4+ei8Q31jSukntpv1U2c11VujM9ghIuLnrvO4z8T2Y7bbu8Bn4j3R+cfJK1NKv5g6CwAipVSLznCIkxFxPjq/fJWr+xvUr45O0fyxlNLXTKPqHrsnnu4v/cP9+CLwTejZbgTlzzf2n+j8LOnfxdPN8VvR+XbrZ7ofW/H0AIGfueZzj8bTzfxb0ZmKc383m0Wnx/PGHa7zntBN/u/uZt4vbv/2O4ztBv4Ho/MzyEevuh1nr/mcu3f5+0J0iuZ20/zp6BT8RnQa7f/O9mU73I5XXHUfnovO1J57IuInna87OgMLtq93JjoTdi5f9Xc/s8Pn7Ph1XJM5283cfZ3Pi+d3P++BnMx7o9NLu/1nq/s5y1f//S6f+4bofEt9++u9Lzo/k8y6H1+8w+fckHP/vyA6v6yURcT/ucPl2wMTPvZsv+b48437h3eYyJVlWTPLsh+Nzmi7X4lOK8hEdL4VNxGdE9k/i4jbsyz76Ws+90J0frX/p6NTqG6KiFPR+Tnbz0XEC7Ms29NghOu4/X8cnZ/x/Xz3th+PzrCE0eiMpvvH0fkFEedYWxHx3RHxy9EpeseiM+Dho9EZFffHOZ97b3SGNXwiOlN2Xhmdn8Xt1lJz7ee/Jzrv5j4UncLz/Oh8h+gj0RmM/9O7f/b+yzo9rJ+OiLtSSs/dJTYQnV+k2f7Ts8vf73T8D0fnufM70fmHzV3RKbT/PjpTnb6m91bc3i9GpyjORcRbU0q/ds07/R/sfvya+bXAtpRle/1dBADfyrrflv7DiPiPWZa9+Vm+OXuWUjocne8WPBYRL8g6S6WBr8E7TAB7kmXZf4tOwfxb+/ibyM+Gd0ZnGMLbKZbIQ8EE8Ez8g4j4p2FOSvpG0/1lnwsR8WNZln3s2b49+MbGt2QBADDwDhMAAEPuzMsza1Py7ecP/83flldSP7vbHtinnZv6jMxsNPVo0bbxI4hib1lmapUdp5B9lUJPUWbWGrvNvO5otnabHf20rfamzDhf0+ZWS2Z6C/prcm7PppFxFIz9wD3GYgnnNreNYTzlXj3YRt3PWzsPp/kqvT16HK1zHzv3334pGLe5t6B3dTeaevRrqajnPzRaazLj3M+OHnE/O623zoKUza28JS4d7bZ+fjnP9f167jjP9/26Luc56NyHy62NHR8w3mECAGCgYAIAYKBgAgBgoGACAGCgYAIAYKBgAgBgoGACAGCgYAIAYMjt8nzLd/+6PMDGj98lM4V36aEEx96tlqFHNH9VZ6ZmHta3x2jOdxqs55YuykxfdTj38sxorq6U+mWmuakHIDgN/hubDZlxFI2hDs6QiWp5QF+XMbRhuT6rr8sYStA07h/VPJ1t6a/bGUrQV9bDNZzBGK22HmjhDGxwnjtW473RVK8GBUR4z8H9GmjRX8l/jTrDGJzH3Bm04NzeSrEmM84QgPrGsswMVEdkZr8GuDiz851z+254hwkAgIGCCQCAgYIJAICBggkAgIGCCQCAgYIJAICBggkAgCG30WZt+n55gIe//5dk5q1f+oDMfOrtZ2VmXiYient1j83mpu4FW1qdlhlnKay6LqcnqL+m+5iW63pJa2tzQ2aG+yZkpr6+KDNOj2XZ6AXr6dH9dk5/lrMYu20suh3uPygzCyuXci8fGTj0jI8R4S0crhqL0FtrczLj3McO5/EsGa8JZ8H77PKKzDj9iE6fb5bp3kdlv/oVnR7VSqlPZspFnXH6pNc39OPgnAed+7i5pc9x/ZVhmdkN7zABADBQMAEAMFAwAQAwUDABADBQMAEAMFAwAQAwUDABADBQMAEAMOQOLtg0lhvf9n/9lszc+44LMlN/7RGZmf7EaZm5/QV/V2a+9Nl/KTODRgP/zNJ5mVELogdqo/IYztLdhvFY9YQetOAsWnaajLeMpcSFgl5Q22rppcROU71zH6pl3xERy/UZmRmojeVevlTXQzGcZvm1xpLM7Jd2Ww91cBrCncZ7JzNvZJwF0s7rJhmvG/X8cu4/p8Hf4VxXo1mXGWdQwNKaPl845x3nnOK8PkvGcBZnyfRueIcJAICBggkAgIGCCQCAgYIJAICBggkAgIGCCQCAgYIJAICBggkAgCHlNaeemnyO7FxdWNab4W84+jKZWV7WQwBe9yc/KzO/8eI3y8zmlm6q38p08++3veInZWb2zB/nXn5x5ivyGA6n8be+sSwzTpNxO3RD87Ax+MFpnu43ttBvGM3nK+sLMtPbowcpONvsC+I4PT36GPs1jMFR6q3KzFpTN9UP1cZlxml0r5UGZMZ5zHuSfj8w0Jc/ZCIiYn7lssxMjpzMvXxx9Yo8hnreRHjDDZLxdTuc29Pc0oMCnHOKo1ysyYzztTvP5dVWc8cbzTtMAAAMFEwAAAwUTAAADBRMAAAMFEwAAAwUTAAADBRMAAAMuX2YQ6WqbLg7euAOeSWrRu/VDTe/VmYe/PJvysyp3/wNmSm9509kZnX+MZk5d+nzMpOJnkVnUfDmpu63q1Z075rTQ1gtD8rM+ZmHZabi9EwZ/VmFgl4CnJI+TstYLOssLnZ609Rtdq6nVNS9kc6iYOc41bJ+7qyszcmMcx8/k+W9V6uU+mVmbOiozFyae3w/bo7k9Ek7r8/mpn7ubBo9vAXjuhyVUp/MlEv6XFBfX5QZ5/k11H9AZjaauod3uj5HHyYAAHtFwQQAwEDBBADAQMEEAMBAwQQAwEDBBADAQMEEAMBAwQQAwJA7uGCsOigHFzjNpH3VYZlxmknvuusHZaaxckHfnoMvlJn1mQdlZnPTWIB843flXp4tXpTHuPDkH8jM/PKUzDhLiY+M3yYzi3W9ULfXGDjgNJ/PLDwlM8cOPldmnjSGTPQZQxucYQHrrfznRbWom70nxELiiIiLxgCJieHjMlNvLMqMM2BjraEXlI8OHpaZK/Nn9uX2OAu2nQXli/UZmRkdmMw/xopeIH1g5AaZubyg75tyb0VnjIED1gJpYwiHUyMczuJ15/FcWp2WmYWNOoMLAADYKwomAAAGCiYAAAYKJgAABgomAAAGCiYAAAYKJgAABgomAACG3M5UZxO7s0ncaTJ2jtNa11vfZ+Yekpn4qR+Skdpv6yb21sUvyMz5L7wv/xhGU++y0ThdKlZlpqetG3+X6rrB2uE8ns5QgkpZDzdYMIZVTBqDABZWLslMoUcPZOgVDd8bLT2ko9HUQwAczrCKzU3d4J834OR6rK4vGNfV3pdMqVe/JhpNPXxkfPCIcXvy75+U9HuTuSX9PC4k/Rp2HquB6pi+Pcv69mxttWRmqP+AzOzX88tRrehz+254hwkAgIGCCQCAgYIJAICBggkAgIGCCQCAgYIJAICBggkAgIGCCQCAIeU1jJ4cv0l2kzoN6ltt3dzqbCQ/dvB5MjMy+WKZmZ26Vx/n5W+RmY0TujG69cH/kHv5hSsPyGNMjp2SmXPGcW488m0yc2n2YZlpbTaMjB7I0F8blZnegh4UML9yWWb6yrpZ2RmwUTWOU28s5l6+3tBDCZzX1XpLN90P1cZlxtlk325vyYwzlMC5jwf79G2eXjwnM45KsSYzm1t6sIMaklAp98ljLK3qASXOwIb9GiYzMnBYZmaX9OPgDDdwOF+XMxRkoKaHNlxcmko7/T3vMAEAMFAwAQAwUDABADBQMAEAMFAwAQAwUDABADBQMAEAMORuunUWmjpLpp3emGJB9wVdnntEZsZOvU5mWk8Zt+fyeZmZ/rMPy8zI69+ee/nt931aHuORRz4oM4fGbpGZHmP58eGJu2RmbvG0zKhexIiIasl57uhew5pxnGZrXWacXsNNo6dsQywlrlWG5DHWN1ZkxpHSju1kX2Vy4k6ZuXBZL0sf7j8oM2uNJZlZWp2WmZJxvnD69gqF/GXfEd7z4vDEHbmXX5rVi+23Mn09ziL02SV97nL6pC/PPyEzPcZCa2eJeaWkF8U7tcZZ1O2cm3bDO0wAAAwUTAAADBRMAAAMFEwAAAwUTAAADBRMAAAMFEwAAAwUTAAADLkLpEfKfXKB9JED+Q27EREXph/UNyR0g3VfdVhmnAW/RbHsNSKiVNSNtAvLennqYF9+M3fbaFY+cMNrZObS6Y/KTKmol9iO3/xamVm/cr/MPPLEH8hMsbciM85yY6c5v68yLDPTC2dlxmmwbjRXcy93lvc6jeXtkC/P6DFeV0cmbpOZS3OPy4yzmNcZSjAycEhmrGEoxv1cX1+UGef5NdR/QGaUYkG/HtY29OAHZ+iFM4yhVtHnUmdpeF6NuR7OYIyVtTmZOTh6o8w8PPUlFkgDALBXFEwAAAwUTAAADBRMAAAMFEwAAAwUTAAADBRMAAAMFEwAAAy5gwvGqoOy49RpSi2XajLjNGo7xoeOy8zM4lmZOeBsNl/UgwvUJvZqTTc8r9UvyUxvr76PNzd1s/fAkP66H3rs92Tmjtu+V2YeefwjMtNbKMnM0YPPl5lLM3p4hvMcdK6rVwxkqK9dkcdYXJmSGadpfKh/QmZKxiCPEeN58eSFe2XmhsPfJjMXjMEYTuP9YJ/+2hdXL8vMVntTZtRAC2f4gTNwwDnfVkp6QIkzgKPeWJQZZ+DMQJ8eaLGwrM9x7awtM85wg82tpsxcXJpicAEAAHtFwQQAwEDBBADAQMEEAMBAwQQAwEDBBADAQMEEAMDQm3dhrTIkD+As7HR6h5qtdZk5efhFMjO/fF5mjh54rszMLj4pM3c+74dlZrMxn3v5xuu+Sx6j+b73yMz6xqLMzC9flJlT/UdkxumHeujRDxnH0b10zhLgJy98Smac3qtbT36nzFw0egRHBvLvQ+c5umL0WBZ7isZtOSozzu1ZW5+VmZ6kl31fnn1IZpy+R6cP0+nh3a/lxmrZ8tySfu0VenJPxxERUS7rfmvHcn1GZpzXeU/S77n2q8d+yzhfOL2src3Gnm8D7zABADBQMAEAMFAwAQAwUDABADBQMAEAMFAwAQAwUDABADBQMAEAMOQukB4u1/ZlgbSzPLW/OiIzzsLcgZpeVrrR1IuUG81VmemvjcpMuZjfaLy0Oi2P4bj5H/5rmXnol98iMxNDx2TGuW9uOPoqmVla0sMhzk3rxc8HhvXScGdwgbdA+gUyc2Uuvznfabp3GrCdBcnO4If6+qLMHJq4U2YeP/fnMuMsN3a+LmfQycKKXkrc06OHLYwMHJIZ9Xg550BHf1Wfc67M69fVUL9eXO/cx5Njp2RmYeWCzDjnZIczbMc55843VlggDQDAXlEwAQAwUDABADBQMAEAMFAwAQAwUDABADBQMAEAMFAwAQAw5A4u6C+W5FSCgrFlPTM2d7dDD0AoFXQTttOI7HCa2J2m8PGh/Kb6cil/U3tExPzyUzLjNOafuvtdMnP2E78sMydO/jWZeeDB35KZG4+8VGYeO/9JmRkdmJSZZPzbsFrWj8Xymt5Uv95Yzr38kNHsPbd8XmaOHHiezDx2Xg8TcF5XwwMHZWZ+eUpmBvvGZaZc1MMN6o1FnTEGMvRVh2XmwMgtxnXlPy9W1+flMZxhFZvtTZkp91ZkZr8GzuyXUrEqM6ODeqjK5bnHZKZsDM+YWrrE4AIAAPaKggkAgIGCCQCAgYIJAICBggkAgIGCCQCAgYIJAIAhtw9zsFiWzTpO/+SgsdR5v3qmnJ7PFWMRtdPbt97QfVMbrfzFqM4S6pPH75aZBx/9sMyUjP6s22//PplZXzknM32n/keZufBZvfTaWRp++/N/RGaeMPpCHTff+YMyc+XJP8y9fHV9Vh6jv6JfM42Wfv45/cTOomAn4yx+dpaPFwpFmdmv88VGsy4zW0bv41Bf/kLm1pZ+HGpGH3CpN38hfUTExdlHZEYtto+IaGd60blzvt3YbMiM0wtc6OmVmYE+/bpZE33SERGXV6bpwwQAYK8omAAAGCiYAAAYKJgAABgomAAAGCiYAAAYKJgAABgomAAAGHI7QZ1GUWddc7utG2B7kq7dq2t6Cevh8VtlprGhm6ed5taJ4RP6ukSjttP4u/kqvbD5xNJZmTl/5QGZScYC7ubGksxsPfRhmXGW2I4MHJKZsw//jswcmniuzGwZzeVPfuUDMrO4eiX38qF+3eDvNJ97y5h1g/rooH4en7v8RZlxFiBvtVsy0zCGCThfl3O+ODH5fJl56vL9MqMe82MH75LHaBivq6m5R2XGOW87551aRQ9ScIa3OAute5I+7xSL+jhLq9My01soycxueIcJAICBggkAgIGCCQCAgYIJAICBggkAgIGCCQCAgYIJAICBggkAgCHlNY8f7B+XneVOE2i5pJuMnU3il+efkBmnGX5s6IjMOE3YznADdV3OUIfjN/xVmbly8ZMys7quG7lLxarM9Fd1w3yv0az85MXPysztb/7XMnPmAz+hb4/xPHUyK2tzMnPs4PNyLz89pb/uoZq+j5fWZmWmYjT4O8MhFlYuyUyxtywzjlp5SGaW6rpB3eE0+Tuv0XaWn3Ea81vG4IxaRd83zlCC1qa+LufrHuo/IDP19UWZcZ471fKAzDguL5yRmdVWM+3097zDBADAQMEEAMBAwQQAwEDBBADAQMEEAMBAwQQAwEDBBADAkNuHOVLuk02NI4O6h8vpw3F6fhwbrTWZcfp5nP6i3h7dO9TczL890wtn5TGcZbnO7R3sPywzm5sNmanW9ALkJ566R2ae921vk5nPf+qfy8xNR18hM/NLT8rMxKhePl5f0/1/S6uXcy8fHTwmj9HTU5SZS7MPy4zTYzk6epvMnL3w5zKzudmUmd5eo2/beL4nY+G8Wt4e4fUjOren3ljMvbxY2J8eVavvUdyWCK/XdX75osxkofvenfOtUyOeyeLnqzWNflf6MAEAeAYomAAAGCiYAAAYKJgAABgomAAAGCiYAAAYKJgAABgomAAAGHIHFxwdPiK7Upst3ejuLAd1mm2dBlinedppeh6ojcnMVrslM5MH8pcJbxqDFh4/p5vG77r9jTJzwWg+d5qDN7f0fXz06Kv25fbUysMys7KuFymfvPF7ZOaBB39LZpznhbp/jk6+UB7j0TP/XWZuOvoymTkz9TmZcYaGOIuLnefF1pZ+zVTK/fq6jNe5M8TEGQTQVxmRmYWVqdzLnXNX3rl42+LqFZlxlmL39OiF1o5ma11mKiX9eLaMgSnOkATneeo83y+vTDO4AACAvaJgAgBgoGACAGCgYAIAYKBgAgBgoGACAGCgYAIAYKBgAgBgyB1ccGTosO4UNThbzZubugHWaap3Gmmdxt7jk/kDByIizl76osyMDh7OvXygphunL80+IjPOJvtTt36vzDzwwH+UmVKxKjNOs/LJl79NZs5++l/JzIGx58jMyuoFmalWRvXtmbpPZtRG92qxTx/DaOQ+euAOmRkeuUVmGmszMjO/dEZmZpbOy8zE0DGZcQaCLNf1sApnyMSCMQjgwPBxmVHnpnJRDy5YWZuWGedcurSm75ue2LEv/6uMD+vHynkcnEEBzmO1VNf3TzK+Luf8dWV1lsEFAADsFQUTAAADBRMAAAMFEwAAAwUTAAADBRMAAAMFEwAAAwUTAABD7uCCoVJVDi5ISTeK9lWGZaad6ebW+vqizDgG+8ZlptnSjeP9Nb2JPYl/k6w3V+QxVtfmZeaGQy+UmanZh2Umy9oy42yprxiN2hXjeVE3muqP3Pm3ZOaBe39RZm45+RqZ+cpjH5GZ59z813MvT0n/O/XLj+vruWHy+TJTq07IzNmLn5aZkYFDMtPbW5GZ1uaazKxv6NdEuViTmaVV3ejuPJcH+iZl5pJ4bR058Fx5jCfOf1JmKiU99MJpzHcGDlTL+jXsnP+dYTKbW3pYhTNwxjl/Oa+/+cYKgwsAANgrCiYAAAYKJgAABgomAAAGCiYAAAYKJgAABgomAACG3D7MwWJZ9mE6vTrO4mdnMarTY9PTU5AZZ6Gps5B5rbEsM4rTT+bcx1no+2alPiczk2M3y8ylucdl5o5Tb5CZx5/8bzIzPqSX907NPSozTg/XbTe/VmYW5vUy73Ip//FKSd+Wi9Nfkpm81+42p3/S0WiuysxGS/dYHj/8Upk5e+HefbkutbzdtbBySWYOjtyYe3lzU/ciLtd1z3F/VS85X13Xfds9SZ8nK2W9BL7Uq3s+55b18vbN9qbMjA7oflinV39y7JTMfOXCffRhAgCwVxRMAAAMFEwAAAwUTAAADBRMAAAMFEwAAAwUTAAADBRMAAAMuR3UzqLNRrOur6TQlBnnupxmW+f2FHvLMrOyviAzvUYzvGrILRX10t2VNT1wwFka21cdNo6jhyQcmXiOzFy58nmZcQYyLNYvy4wziGK4/6DMTF36jMw4zeXq61o1nlvHDtwlM5WKXmBeX9NLlBdXdWN+rTwoM859UzCWTDtDCZyBH0P9R2Tm7KX7ZCaFXpJcb+Q/ps6CZCfTZzzm7Uy/Hpwl3ZPjd8jMOeP+q5T0AARn4Ixz/nfOBRemvyIzu96GPX8mAADfQiiYAAAYKJgAABgomAAAGCiYAAAYKJgAABgomAAAGCiYAAAYcjvvt4wG2D6jodkZSuA00jq3p2w0RjtN7HNLekv4yKDeZl8u9uVevtXWzcrqGG6maAw3WDUa3a8snpWZ8UHdNL65pQdaHD/8UplZWHhCZqoVval+o7kkM0eOvFJmzj71J7mXHx67VR5jxXgcqtVxmbk0+6jMtLO2zGRGZtR4zJ+68AmZOTR2i8wMD98oM2cv3Cszk6M3y8zquh4coprznee6o7mphzrU1xdlZmL4hMxsbOjXgzMEZq2xLDMjA/pcap0rS/o8uGEMt9kN7zABADBQMAEAMFAwAQAwUDABADBQMAEAMFAwAQAwUDABADDk9mEWe4ryAM7CzizylyhHRJSM/slqRS8cLhb0cZwFqy2j58fpd2q21nMvLxj3sbOYd3z4uMwcPPGdMrP6xP8rM06v63J9VmZuPnG3zJyb0kudxwb1195r3OZLsw/JzFJd90eqnsXZpXPyGI3mqsxUjR7oLDKZqRi9a87C5tGRm2Tm0vQDMnN5XvfVOpmbj327zCwuPyUzzut8ZOBo7uWX5nQ/7JaxQHpi+KTMpKQXgi+u6sXsKennutNfOtin+4Vnl87LjLNw3ukXLhT0OXc3vMMEAMBAwQQAwEDBBADAQMEEAMBAwQQAwEDBBADAQMEEAMBAwQQAwJCybPfG5uFyTXY9Fwt6gehGSy89dZZMO83TzpLRwb4JmVlY0c2/vYWSzKhG2lplSB7jyORLZGZu/mGZ6UkFmXEakZ1l1U5j+U3HdWP5xSv3y8zyml7we+rYq2SmbTx3lutTMtMQC2r7KsPyGMdue5PMzJ39I5kZPfxymZmf+pTMNDb0EuDphTMyc8dt3yszDzz0OzLjvPYcW209VGV08LDMrIjnoDPgpadHvz6dxvz+ql6WnoU+zkZTn7edBdLOcZxhMs7ggtbmhsw457i59eW009/zDhMAAAMFEwAAAwUTAAADBRMAAAMFEwAAAwUTAAADBRMAAAMFEwAAQ+7ggqFSVQ4uKPT0yitxGkXHh4/JzMKyHibQMprPJ0f01vLLRhN21Wjg76/lNxHPGJvGC8bAgVM33C0zl2celBnH0qrexO4MonD0GMfpqw7LTKFHb1mvlPplZm75gswcGLkx9/JySTdgp6RfV4Ve3by/tdmQmdnF0zLjDL2YXb4oMxVj+MjB0ZtlZq2xIDPHb/xumXny8d+TmWZrXWZUU70zaMEZ8FJfX5QZZ5iA8zWVilWZcQY/pNhxBsBXUefJCO/rujynn8vOAJyZtQUGFwAAsFcUTAAADBRMAAAMFEwAAAwUTAAADBRMAAAMFEwAAAy5zV69Bd27trml+x6d/hmnx7LYW5GZrabuC1quz8rMYG1MZhyqB3VsQC+nHTYy07N6gXRjY1VmDo7dIjNOD5fTn+Ucp1YdkZm1hl5uXKsMyky1onvBJowlvyOjt+Ze/vDjvy+PcfLIS2WmXr8iM5fnHpeZ5pZeunvq2Cv17TF6BMsl3QPXVzsoM1Mz+vm+9cRHZMa5zc5y47pYsH1k7JQ8Rl9FP9fVouqIiNHBIzIzNfuYzDjLmJ3nzoDxGi716p7P5qZxvqgMyYxT13bDO0wAAAwUTAAADBRMAAAMFEwAAAwUTAAADBRMAAAMFEwAAAwUTAAADLkLpMdrw3KBtLMculjQgwuykFcVWdaWGYezTNi5LmfB6tJa/pCEonFbJkZOyEytMi4z0wu6iX11bV5mBoyhDs59Uy3pYQKzS+dkxlk4XDSWxjZbdZkpG7f5zMXP5F5+cDR/wXRExIp43kREbDT1wuEbj79KZs6c/6TMOEu6nSXTq+v6+eVclzNwwHmezi3pheDlkl4UrwZjVIp6aXhrSy/7XljRA14G+/S5YHVNL+BuGcvHTxx6kcwsrpyXmfnlKZlxltIfGb9NZqbmHpWZxY01FkgDALBXFEwAAAwUTAAADBRMAAAMFEwAAAwUTAAADBRMAAAMFEwAAAy5gwvGqoNymsCG0dza29MrM+223mreNoYbFIzm6ZR27En9KpNGM/yV+dMyMz58PPdyZ4N6wbj/nAESQ/0HZKZaHpWZmUX9dbda+nnhDKtwmrAdTqP2xMhJmZk2HvNbT70+9/KNtSvyGOemPiczzmPuDOkYGTgkM3PLusG/vzoiM8t1PZCht1CSmXamzxfO7Vlddxr4N2RmZGAy9/LZ5YvyGEM1/VxfayzJjNPg79iv4S09PfqcPFibkJlLc3rwinO+cG7PuflzDC4AAGCvKJgAABgomAAAGCiYAAAYKJgAABgomAAAGCiYAAAYKJgAABhyBxcMlaqys7zYW5ZX4mxib26uy8z40DGZcTaoO822Gy29zd5RqwzlX0+zLo/h3H9OE7u6LRHeIAWn0X144KjMnL/yJeM4B2Vma2tTZkaHTsjMxekHZcZp5u6rDudePjZ8kzxGxWjkfvjx35eZ/ppu3i/16tfD4qoetuA0jQ8P6Nfw6QuflpmxoSMy02zpc4rzmuir6sdiYflc7uWTB14gjzE3/7DM9Nf08JHFFX0OdAYglEs1mWls6PPXVrslMycOvURmIvRrb3r+MZlxhmcstzYYXAAAwF5RMAEAMFAwAQAwUDABADBQMAEAMFAwAQAwUDABADDk9mEOFsuyD9PpY3J6BJ1ew5axrLq/phcg19cXZcbpQVoxls+O9Of3EW61dQ9htTQgM+vNFZlZXZuXGWdJd195UGacpbuTY7fIzIXpr8iM0wt807FXyUwYi3cXl/QC6d5CJffyhRW9TNi5/1LoRejOomVnYfOJwy+VmbqxGPv8lS/LzNEDd8iMsyT58pzuyXOeF48/dY/MqN7u9Q39+hwb0r3LiyuXZaZa0a/PxsaqzDh9taNDN8hMfW1GZpzHc3FVf+3ttn6+O6+J2bVF+jABANgrCiYAAAYKJgAABgomAAAGCiYAAAYKJgAABgomAAAGCiYAAIbevAvVItwIrwHWaUpttXWjttOg7gxJcIYFOM3cpYK+PRvN/EXUo4N6Ee5SXTeEO49DoSf34Y6IiLLxdff06CETxw7eJTNVYxlumtFLdQdqYzLTaOihDZdmH5GZG47oBv7Ls/nDFk4cebk8xvmpz8rMxMjN+jhX7peZ4f5JmTl7US91doZ9jA/rBdJLRoP6wbFbZcZ5bTlDCZzhLEN9+QNKzs3oARyHD+nn1vrGx2Rm2VgCX+7NH64RETG7rAdsLK1Oy4zzOMwt66XXzjn5xqOvlJmFpSdlZje8wwQAwEDBBADAQMEEAMBAwQQAwEDBBADAQMEEAMBAwQQAwEDBBADAkNvJ7jTDt7O2zDhNss4wAWfDvDMkwdkknhlfl5Opie3nM4tn5TE2NhsyMzlyUmYuL5yRmSwyment1Q3EU8bAgf6aHsgw1D8hM85zp7BPAxkWlvR9ONR/KPdy53mzur4gM0trepjA6IAeSjA+8VyZuTj3mMw0mvp84QwuqDcWZWZuUT8O1XL+ay/Ca6ovF/tk5srC6dzLDw7fII9x7sKfy0y1PCAzzvPLOU9OGLfZGari6En6tTfcnz8cIiJiZl4PH1ld00NMdsM7TAAADBRMAAAMFEwAAAwUTAAADBRMAAAMFEwAAAwUTAAADCnLdu+76y+WZFNesacor8Tpb2u3t2Sm1W7JjKNg9PxUSrr3qtGsy0yP6Hca6tdLlJ37r9lal5lKqV9mnP6s1XXdx7Ri9BEO1XQ/rNOPqHpdI/SC34iIXqNfeLmulxuvNZZzL++rDMtjOL2IB4Z1763qD4yIODhyk8xcMvowraXrxarMDBkLrYeG9W0+c+7jMjMykN8zGxHRV9PPnY2NpdzLZ4y+0bVG/jEiIu645XUyMzf/kM4s6YXNRw/cKTPOEnhnGXqxtywzK8ZibGcZurOsenFjbcemf95hAgBgoGACAGCgYAIAYKBgAgBgoGACAGCgYAIAYKBgAgBgoGACAGDIXSDtNJY7DfMbrTWZcRajFtp6SELDuC5Ha3NDZpxm262t/GEL/TW9IHmlPm3cFt10P71wVmacx8EZ2DAxpBcFzy9PyUy5WJMZ5zaPjd8hM19+5L/IzPPu/AGZefCh/5R7+UHjtpw+r5cJO4MWnMW8K+uzMjMyqBv8+6v6udxs6efO1lZTZmZmHpAZZ0DEQP9Rmblw5Qsy01vIPzep80BExOjgYZlpNfOHYkRELNf14+ksXT8z9XmZcYZVpLTjDICv4gyrWFrV58FN47lT6Mkte7l4hwkAgIGCCQCAgYIJAICBggkAgIGCCQCAgYIJAICBggkAgIGCCQCAIWVZtuuFQ6Xq7hd2OY3lvb26udUZgPBMGk6vlpL+d8KqsfG+J3RDrmrszbK2PMZgn24IX1i5JDPOtntnYEPJaJjvqw7LjDO4wDmO05x//OgrZeb8xXtlZmRAN7pvtfOb1GcXn5LHaG02jOvRzecDtTGZGRs6YVyXbrwvl/QAiYvTX5YZh/OauDR/WmYqxvnLG1CS/1iUS/p6+iojMnNh9hGZcc5Lzrm0p0e/rpyhIfX1RX2cyqDMbG7qoQSHJ/RQkCzTr5svPXXvjnci7zABADBQMAEAMFAwAQAwUDABADBQMAEAMFAwAQAwUDABADDk9mFO1EZkH2Y725JXsmH0lB0cvkFmnF7DSrlfZtYaSzJTLOjeK6e/dH1jJffycWPRcqlX93BdmntMZg6MnJSZGaNHsL+m+8WaLf2YO72G/dVRmWk0V43r0v2lzv1TbyzIjOq9dZbuOs/1dlu/9pxezZrRA+f07anneoR3Lhio6ueX6nuMiKiU+2RmraEXMju9huoxHRu+SR7j8XN6aXiP0UM+0Kd7b5PxXsk5T1Yr+9OHeXBE3z/Ti2dkxnkuO6+/J2eeoA8TAIC9omACAGCgYAIAYKBgAgBgoGACAGCgYAIAYKBgAgBgoGACAGDIHVzQXyzJwQV9Zd0o2mjWZcZpyC0ai4udhczOwAFnybSzSLkmlsKem35QHmNs4LDMLNWnZWa4/6DMTIzeKjPLKxdk5qIxSOHUsVfJTH3tisw4nOXGm1t6uIHzeA2L5cbO68GxtaWXOjuDPIb69PPCuW96jWEfzuuzaCx1rq/PyYy1lL6gBzIsrujn4MjAodzLnQXSToO/w1l4nXfe37a46nzdkzJT6CnKjDOoIyW9GNsZjOEs2F5ubTC4AACAvaJgAgBgoGACAGCgYAIAYKBgAgBgoGACAGCgYAIAYKBgAgBgyB1cMFoZkN2t7Uxvfd8vyWg4dQYOOIYHdDO3s/W93ljMvbxsNGmPD9+gr8do5J5fnpIZx4GRkzLjNLpvtfX9t9XWzfkHx++QmcfO3iMzvQXdYO00YavXhPOYD4rhBxER0wt6A73ToO40hLfb+nVeKlZlZnOrKTO9BT1YpFYZkpmDE8+TmfmFR2RmbEw/vx554g9yL3ee65WSHjLR3NTDGA6P3yYzS6uXZWagNi4zc0vnZcZ5zJ37p686LDPOc6cnFWTmqfmzDC4AAGCvKJgAABgomAAAGCiYAAAYKJgAABgomAAAGCiYAAAYKJgAABhyBxeMVQf14AKjoblaGZSZtcaSzGwaza1DRrPt0tqszIwam8TnV3Tzb600kHu509TrNISvb6zIjLPtvtCjN9A7TfXO1nenCXujubYv17WyNi8z1XL+YxURceqW18vM/V/+zdzLnfvYcWjslMxUq2Myc3H6AZk5OKqv6/TUZ2WmYgxtOD75Ipm5cOV+mSkVKzLT2tQDNhyTY/nDAq7MPyaP4byGbz35apl54ql7ZMYxMnBIZmaNwQU9xjCZW298jcw88uQfyYwz0KKxsSoz840VBhcAALBXFEwAAAwUTAAADBRMAAAMFEwAAAwUTAAADBRMAAAMuX2Y/cWS7MMsGMs4ncWfy2t6AXKpYPT2GYuLnR7L1bWFfbkudZvLJd2X5vRnOT2q44NHZKbRrMvMhpFxFHt1n5zTq+l87Q7n/tlo6b5QtaDW6QM+fuBOmVlYuSgzzkLd5bq+Pf3VEZkZHTwmM/PLum/PuY+H+/WCd6fH2fnajxqPxdzSU7mXq0XyrqJxDjxx+CUyc+7S52XGOTc5S6+dBeVOv/WNt71RZqbP/anMVMrDMvP50x+jDxMAgL2iYAIAYKBgAgBgoGACAGCgYAIAYKBgAgBgoGACAGCgYAIAYHjGC6TzPn9bO9NLpp3j9BaKMrNlNLE7zb/9tVF9HGtxcf5AhmZLN+Y7Df7OslynOdgZknDnrW+QmTPn7pEZZ5Gy83g696GzWFYNHIjw7p/xoeO5l88ZzfvOMuv55SmZce5j575xFrxPjt0sM1OzepHyfr3OJ4ZPyMyl+dMy4wxnOTyev2B7cVUvm3eef86ggKX6tMwcHr9dZi7OfEVmnKE0K3U9lKZgPObO6/ykMbRhfjl/yERExPmF8wwuAABgryiYAAAYKJgAABgomAAAGCiYAAAYKJgAABgomAAAGCiYAAAYcgcXjJT75DSBVrslr6RW0k3YznZvp1m51WrIjDNIwWnIXVqdkRnVhO1sc780+6jMrDV1Q32v0cTuNEY3mqsyc+zAXTKzuKob751BAUcmniMzZy99UWZKxoCIza2mzKhBAM7XVCnrx8Fp8K+WBmXGeTyH+g/JzMqabphfXNEN/CePvExmzlz8tMw4DoyclJmFlUsysyXOg6ViVR5jrbEsMwPGQJWU9ud9UGtzQ2acARsOdf9FeOfb4f6DMtNXGZGZh6a+yOACAAD2ioIJAICBggkAgIGCCQCAgYIJAICBggkAgIGCCQCAIbcxz+mxrBSd/kl9HKe/zekvam7qPsxaRfem1crDMtNu635O1Vs1u3hWHsNZVN27qZerbhp9rP1V3aPkfN31hl4au7Sq+/ZGBw/LjNOn6vSLbW0ZPcXGsuWRwaO5l5cb8/IYq2sLMuM8DqVe3f9XLevXw9TswzJTNs4FTn/pU5c+JzNO/6TTb93To5c2Oz3ivYVS7uXOsu8t4/Y6vZGTY/nLrCMinrp8v8w4y8cPT9whM2en7pMZp8feeQ0PD+jzxeU5vcR8N7zDBADAQMEEAMBAwQQAwEDBBADAQMEEAMBAwQQAwEDBBADAQMEEAMCQu0B6rDooF0g7DadOA2xP0g3EznWltOPez6+yYQw3cAYyDNTGZEYtzHWGQziGauP7chyn8Xd++bzM5D2vtjmDAhxO83mzpQc7VI2BFs5zeaA2kXt5fV0PLnA4z3XncXAW6q439XLjuaULMqMa/CO8r8sZYnLs4PNkZnr+cZlRgygiIkrF/Kb6ZksvDV9a1YuqN5prMuMMgXGGMTiDApzb4wxbmDAGUVyZf0JmnCEvK+t6KMhqq8kCaQAA9oqCCQCAgYIJAICBggkAgIGCCQCAgYIJAICBggkAgIGCCQCAIXdwQX+xJLueq8W+fbkhzlACp0HdaYbPQjdzO4MUsqwtM7XKUO7lK2tz8hhOs3dzSzcHHxg+LjPL9VmZce7jtnHfOBvmayXdPN3c1EMJnAZ+p2G+WNCN0Rut/Gbu/Xo8bztxt8wsLJ2VmYnx58jMzOxDMjO/fFFmxob0EIDF1Ssy01/VwxZWjQb1mjGsYq2hhzZMjp3KvXx6/rQ8hjNwwMkcn9QDG+rr+ryzXJ+RmWJvRWYazVWZmRg+ITPO88sZaOGct+fWlxlcAADAXlEwAQAwUDABADBQMAEAMFAwAQAwUDABADBQMAEAMORuw+0r6x4lr3dI9+31GP0zpWK/zKwZtyeFs6BWZ5rG17W+kb84VvVpRkQM90/KTMtYir24mr/M2nX0wJ0ys2Usxr4487DMWH1yy3o5r7MQ3OnP6u3VPZQDffmLxVfXdH9gqViVmdkFvfx4QSwwj/D6WBsbupducuxmmVk1lmc7i4udXs0Tky+UmWnjPnQWxc8tPZV7uerNdTkLkp3nsZMZGTikM0N68bPzPF1and6X2zOzeE5m+qrDMrMb3mECAGCgYAIAYKBgAgBgoGACAGCgYAIAYKBgAgBgoGACAGCgYAIAYMgdXOA02zpDAErGklFnAMLqmm56bhvLoXt7cr/siIgo9BRlZnxQNzSrhtxmSzeNX5h9RGYmho7JTGtTLyU+OHqjzMwsnpGZ/WqebjTrMjNoNJavG0uAnYZmZwjH7OL53MudBdIHh/Tj0G7rBdzOomXnOdg2ln07CsZrb9ZYFDzcNyEzW219Tlkxlkw7r5vxofzl7M7gh8MTt8vMxRm9yLu1qc/b/TV9/00Zg0WcgQOVsh4443DqkTP0YnlNL8/eDe8wAQAwUDABADBQMAEAMFAwAQAwUDABADBQMAEAMFAwAQAwUDABADCkLNON/gAAfKvjHSYAAAYKJgAABgomAAAGCiYAAAYKJgAABgomAACG/w+cmdH2TTAaPgAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 576x576 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "root = './plots'\n",
    "# vis = corr_mat - corr_mat.min() + 1e-6\n",
    "vis = np.abs(corr_mat)\n",
    "# fig, ax = plt.subplots(figsize=(6, 6))\n",
    "plt.figure(figsize=(8, 8))\n",
    "# ax.imshow(vis, interpolation='nearest')\n",
    "plt.tick_params(left = False, right = False , labelleft = False ,\n",
    "                labelbottom = False, bottom = False)\n",
    "sns.heatmap(vis, cmap='mako', cbar=False, linewidths=0)\n",
    "plt.title('Correlation (10k)', fontsize=23)\n",
    "plt.savefig(os.path.join(root, f'10_corr.pdf'))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 123,
   "id": "impressed-learning",
   "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": [
    "_ = plt.hist(np.abs(corr_mat).reshape(-1), bins=20)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 124,
   "id": "sharp-scholarship",
   "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": [
    "# maximum correlation for each neuron\n",
    "_ = plt.hist(corr_mat.max(axis=1), bins=30)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 125,
   "id": "vocational-cattle",
   "metadata": {},
   "outputs": [],
   "source": [
    "self_corr_mat = np.abs(np.load(os.path.join(affinity_dir, 'corr_1_1.npy')))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 126,
   "id": "strategic-arnold",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "1.0000001"
      ]
     },
     "execution_count": 126,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "self_corr_mat[0,0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 127,
   "id": "alien-satellite",
   "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": [
    "# corr_mat_no_diag = corr_mat - np.diag(np.ones(512))\n",
    "_ = plt.hist(self_corr_mat.reshape(-1), bins=30)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 128,
   "id": "wired-government",
   "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": [
    "_ = plt.hist(corr_mat.reshape(-1), bins=30)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 129,
   "id": "attended-fitness",
   "metadata": {},
   "outputs": [],
   "source": [
    "# vis = corr_mat_no_diag\n",
    "# fig, ax = plt.subplots(figsize=(18, 18))\n",
    "# ax.imshow(vis, interpolation='nearest')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 130,
   "id": "controlled-stomach",
   "metadata": {},
   "outputs": [],
   "source": [
    "# compute the 90th percentile of the correlation for semimatching for all neuron\n",
    "pct = 80\n",
    "percentile = []\n",
    "for i in range(1, 20):\n",
    "    # correlation matrix between 0th model and jth model\n",
    "    corr_mat = np.load(os.path.join(affinity_dir, f'corr_0_{i}.npy'))\n",
    "    match = np.max(corr_mat, axis=-1) # find the max correlation for each neuron\n",
    "    match_index = np.argmax(corr_mat, axis=-1) # find the index of the index of the max corr\n",
    "    ps = np.percentile(match, [pct])\n",
    "    percentile.append(ps)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 131,
   "id": "recovered-stake",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.4101520315596933"
      ]
     },
     "execution_count": 131,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "avg_90_pct = np.mean(percentile)\n",
    "avg_90_pct"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 132,
   "id": "improved-cornwall",
   "metadata": {},
   "outputs": [],
   "source": [
    "# avg_90_pct = 0.5"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "brave-junction",
   "metadata": {},
   "source": [
    "## Assigning neurons to features"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 133,
   "id": "veterinary-meaning",
   "metadata": {},
   "outputs": [],
   "source": [
    "all_corr_mat = [[None for _ in range(20)] for _ in range(20)]\n",
    "for i in range(20):\n",
    "    for j in range(20):\n",
    "        corr_mat = np.load(os.path.join(affinity_dir, f'corr_{i}_{j}.npy'))\n",
    "        all_corr_mat[i][j] = corr_mat"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 134,
   "id": "frozen-newman",
   "metadata": {},
   "outputs": [],
   "source": [
    "n_neuron = all_corr_mat[0][0].shape[0]\n",
    "neuron_feature_pairing = [[None for _ in range(n_neuron)] for _ in range(20)]\n",
    "previous_max = [[-1000 for _ in range(n_neuron)] for _ in range(20)]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 135,
   "id": "satellite-synthetic",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 0 None 0\n",
      "0 0 0 1\n",
      "========================================\n",
      "0 1 None 1\n",
      "0 1 1 2\n",
      "========================================\n",
      "0 2 None 2\n",
      "0 2 2 3\n",
      "========================================\n",
      "0 3 None 3\n",
      "0 3 3 4\n",
      "========================================\n",
      "0 4 None 4\n",
      "0 4 4 5\n",
      "========================================\n",
      "0 5 None 5\n",
      "0 5 5 6\n",
      "========================================\n",
      "0 6 None 6\n",
      "0 6 6 7\n",
      "========================================\n",
      "0 7 None 7\n",
      "0 7 7 8\n",
      "========================================\n",
      "0 8 None 8\n",
      "0 8 8 9\n",
      "========================================\n",
      "0 9 None 9\n",
      "0 9 9 10\n",
      "========================================\n",
      "0 10 None 10\n",
      "0 10 10 11\n",
      "========================================\n",
      "0 11 None 11\n",
      "0 11 11 12\n",
      "========================================\n",
      "0 12 None 12\n",
      "0 12 12 13\n",
      "========================================\n",
      "0 13 None 13\n",
      "0 13 13 14\n",
      "========================================\n",
      "0 14 None 14\n",
      "0 14 14 15\n",
      "========================================\n",
      "0 15 None 15\n",
      "0 15 15 16\n",
      "========================================\n",
      "0 16 None 16\n",
      "0 16 16 17\n",
      "========================================\n",
      "0 17 None 17\n",
      "0 17 17 18\n",
      "========================================\n",
      "0 18 None 18\n",
      "0 18 18 19\n",
      "========================================\n",
      "0 19 None 19\n",
      "0 19 19 20\n",
      "========================================\n",
      "0 20 None 20\n",
      "0 20 20 21\n",
      "========================================\n",
      "0 21 None 21\n",
      "0 21 21 22\n",
      "========================================\n",
      "0 22 None 22\n",
      "0 22 22 23\n",
      "========================================\n",
      "0 23 None 23\n",
      "0 23 23 24\n",
      "========================================\n",
      "0 24 None 24\n",
      "0 24 24 25\n",
      "========================================\n",
      "0 25 None 25\n",
      "0 25 25 26\n",
      "========================================\n",
      "0 26 None 26\n",
      "0 26 26 27\n",
      "========================================\n",
      "0 27 None 27\n",
      "0 27 27 28\n",
      "========================================\n",
      "0 28 None 28\n",
      "0 28 28 29\n",
      "========================================\n",
      "0 29 None 29\n",
      "0 29 29 30\n",
      "========================================\n",
      "0 30 None 30\n",
      "0 30 30 31\n",
      "========================================\n",
      "0 31 None 31\n",
      "0 31 31 32\n",
      "========================================\n",
      "0 32 None 32\n",
      "0 32 32 33\n",
      "========================================\n",
      "0 33 None 33\n",
      "0 33 33 34\n",
      "========================================\n",
      "0 34 None 34\n",
      "0 34 34 35\n",
      "========================================\n",
      "0 35 None 35\n",
      "0 35 35 36\n",
      "========================================\n",
      "0 36 None 36\n",
      "0 36 36 37\n",
      "========================================\n",
      "0 37 None 37\n",
      "0 37 37 38\n",
      "========================================\n",
      "0 38 None 38\n",
      "0 38 38 39\n",
      "========================================\n",
      "0 39 None 39\n",
      "0 39 39 40\n",
      "========================================\n",
      "0 40 None 40\n",
      "0 40 40 41\n",
      "========================================\n",
      "0 41 None 41\n",
      "0 41 41 42\n",
      "========================================\n",
      "0 42 None 42\n",
      "0 42 42 43\n",
      "========================================\n",
      "0 43 None 43\n",
      "0 43 43 44\n",
      "========================================\n",
      "0 44 None 44\n",
      "0 44 44 45\n",
      "========================================\n",
      "0 45 None 45\n",
      "0 45 45 46\n",
      "========================================\n",
      "0 46 None 46\n",
      "0 46 46 47\n",
      "========================================\n",
      "0 47 None 47\n",
      "0 47 47 48\n",
      "========================================\n",
      "0 48 None 48\n",
      "0 48 48 49\n",
      "========================================\n",
      "0 49 None 49\n",
      "0 49 49 50\n",
      "========================================\n",
      "1 0 0 50\n",
      "1 1 None 50\n",
      "1 1 50 51\n",
      "========================================\n",
      "1 2 2 51\n",
      "1 3 None 51\n",
      "1 3 51 52\n",
      "========================================\n",
      "1 4 3 52\n",
      "1 5 5 52\n",
      "1 6 6 52\n",
      "1 7 7 52\n",
      "1 8 8 52\n",
      "1 9 None 52\n",
      "1 9 52 53\n",
      "========================================\n",
      "1 10 13 53\n",
      "1 11 None 53\n",
      "1 11 53 54\n",
      "========================================\n",
      "1 12 11 54\n",
      "1 13 None 54\n",
      "1 13 54 55\n",
      "========================================\n",
      "1 14 None 55\n",
      "1 14 55 56\n",
      "========================================\n",
      "1 15 None 56\n",
      "1 15 56 57\n",
      "========================================\n",
      "1 16 None 57\n",
      "1 16 57 58\n",
      "========================================\n",
      "1 17 None 58\n",
      "1 17 58 59\n",
      "========================================\n",
      "1 18 None 59\n",
      "1 18 59 60\n",
      "========================================\n",
      "1 19 None 60\n",
      "1 19 60 61\n",
      "========================================\n",
      "1 20 None 61\n",
      "1 20 61 62\n",
      "========================================\n",
      "1 21 None 62\n",
      "1 21 62 63\n",
      "========================================\n",
      "1 22 None 63\n",
      "1 22 63 64\n",
      "========================================\n",
      "1 23 None 64\n",
      "1 23 64 65\n",
      "========================================\n",
      "1 24 None 65\n",
      "1 24 65 66\n",
      "========================================\n",
      "1 25 None 66\n",
      "1 25 66 67\n",
      "========================================\n",
      "1 26 None 67\n",
      "1 26 67 68\n",
      "========================================\n",
      "1 27 None 68\n",
      "1 27 68 69\n",
      "========================================\n",
      "1 28 None 69\n",
      "1 28 69 70\n",
      "========================================\n",
      "1 29 None 70\n",
      "1 29 70 71\n",
      "========================================\n",
      "1 30 None 71\n",
      "1 30 71 72\n",
      "========================================\n",
      "1 31 None 72\n",
      "1 31 72 73\n",
      "========================================\n",
      "1 32 None 73\n",
      "1 32 73 74\n",
      "========================================\n",
      "1 33 None 74\n",
      "1 33 74 75\n",
      "========================================\n",
      "1 34 None 75\n",
      "1 34 75 76\n",
      "========================================\n",
      "1 35 None 76\n",
      "1 35 76 77\n",
      "========================================\n",
      "1 36 None 77\n",
      "1 36 77 78\n",
      "========================================\n",
      "1 37 None 78\n",
      "1 37 78 79\n",
      "========================================\n",
      "1 38 None 79\n",
      "1 38 79 80\n",
      "========================================\n",
      "1 39 None 80\n",
      "1 39 80 81\n",
      "========================================\n",
      "1 40 None 81\n",
      "1 40 81 82\n",
      "========================================\n",
      "1 41 None 82\n",
      "1 41 82 83\n",
      "========================================\n",
      "1 42 None 83\n",
      "1 42 83 84\n",
      "========================================\n",
      "1 43 None 84\n",
      "1 43 84 85\n",
      "========================================\n",
      "1 44 None 85\n",
      "1 44 85 86\n",
      "========================================\n",
      "1 45 None 86\n",
      "1 45 86 87\n",
      "========================================\n",
      "1 46 None 87\n",
      "1 46 87 88\n",
      "========================================\n",
      "1 47 None 88\n",
      "1 47 88 89\n",
      "========================================\n",
      "1 48 None 89\n",
      "1 48 89 90\n",
      "========================================\n",
      "1 49 None 90\n",
      "1 49 90 91\n",
      "========================================\n",
      "2 0 50 91\n",
      "2 1 0 91\n",
      "2 2 50 91\n",
      "2 3 5 91\n",
      "2 4 None 91\n",
      "2 4 91 92\n",
      "========================================\n",
      "2 5 4 92\n",
      "2 6 None 92\n",
      "2 6 92 93\n",
      "========================================\n",
      "2 7 7 93\n",
      "2 8 8 93\n",
      "2 9 9 93\n",
      "2 10 10 93\n",
      "2 11 12 93\n",
      "2 12 11 93\n",
      "2 13 None 93\n",
      "2 13 93 94\n",
      "========================================\n",
      "2 14 None 94\n",
      "2 14 94 95\n",
      "========================================\n",
      "2 15 None 95\n",
      "2 15 95 96\n",
      "========================================\n",
      "2 16 20 96\n",
      "2 17 15 96\n",
      "2 18 None 96\n",
      "2 18 96 97\n",
      "========================================\n",
      "2 19 None 97\n",
      "2 19 97 98\n",
      "========================================\n",
      "2 20 None 98\n",
      "2 20 98 99\n",
      "========================================\n",
      "2 21 None 99\n",
      "2 21 99 100\n",
      "========================================\n",
      "2 22 21 100\n",
      "2 23 None 100\n",
      "2 23 100 101\n",
      "========================================\n",
      "2 24 None 101\n",
      "2 24 101 102\n",
      "========================================\n",
      "2 25 None 102\n",
      "2 25 102 103\n",
      "========================================\n",
      "2 26 None 103\n",
      "2 26 103 104\n",
      "========================================\n",
      "2 27 None 104\n",
      "2 27 104 105\n",
      "========================================\n",
      "2 28 None 105\n",
      "2 28 105 106\n",
      "========================================\n",
      "2 29 None 106\n",
      "2 29 106 107\n",
      "========================================\n",
      "2 30 None 107\n",
      "2 30 107 108\n",
      "========================================\n",
      "2 31 None 108\n",
      "2 31 108 109\n",
      "========================================\n",
      "2 32 None 109\n",
      "2 32 109 110\n",
      "========================================\n",
      "2 33 None 110\n",
      "2 33 110 111\n",
      "========================================\n",
      "2 34 None 111\n",
      "2 34 111 112\n",
      "========================================\n",
      "2 35 None 112\n",
      "2 35 112 113\n",
      "========================================\n",
      "2 36 None 113\n",
      "2 36 113 114\n",
      "========================================\n",
      "2 37 None 114\n",
      "2 37 114 115\n",
      "========================================\n",
      "2 38 None 115\n",
      "2 38 115 116\n",
      "========================================\n",
      "2 39 None 116\n",
      "2 39 116 117\n",
      "========================================\n",
      "2 40 None 117\n",
      "2 40 117 118\n",
      "========================================\n",
      "2 41 None 118\n",
      "2 41 118 119\n",
      "========================================\n",
      "2 42 None 119\n",
      "2 42 119 120\n",
      "========================================\n",
      "2 43 None 120\n",
      "2 43 120 121\n",
      "========================================\n",
      "2 44 None 121\n",
      "2 44 121 122\n",
      "========================================\n",
      "2 45 None 122\n",
      "2 45 122 123\n",
      "========================================\n",
      "2 46 None 123\n",
      "2 46 123 124\n",
      "========================================\n",
      "2 47 None 124\n",
      "2 47 124 125\n",
      "========================================\n",
      "2 48 None 125\n",
      "2 48 125 126\n",
      "========================================\n",
      "2 49 None 126\n",
      "2 49 126 127\n",
      "========================================\n",
      "3 0 None 127\n",
      "3 0 127 128\n",
      "========================================\n",
      "3 1 1 128\n",
      "3 2 51 128\n",
      "3 3 5 128\n",
      "3 4 6 128\n",
      "3 5 3 128\n",
      "3 6 92 128\n",
      "3 7 None 128\n",
      "3 7 128 129\n",
      "========================================\n",
      "3 8 None 129\n",
      "3 8 129 130\n",
      "========================================\n",
      "3 9 9 130\n",
      "3 10 53 130\n",
      "3 11 12 130\n",
      "3 12 None 130\n",
      "3 12 130 131\n",
      "========================================\n",
      "3 13 95 131\n",
      "3 14 None 131\n",
      "3 14 131 132\n",
      "========================================\n",
      "3 15 None 132\n",
      "3 15 132 133\n",
      "========================================\n",
      "3 16 None 133\n",
      "3 16 133 134\n",
      "========================================\n",
      "3 17 None 134\n",
      "3 17 134 135\n",
      "========================================\n",
      "3 18 None 135\n",
      "3 18 135 136\n",
      "========================================\n",
      "3 19 None 136\n",
      "3 19 136 137\n",
      "========================================\n",
      "3 20 None 137\n",
      "3 20 137 138\n",
      "========================================\n",
      "3 21 None 138\n",
      "3 21 138 139\n",
      "========================================\n",
      "3 22 None 139\n",
      "3 22 139 140\n",
      "========================================\n",
      "3 23 None 140\n",
      "3 23 140 141\n",
      "========================================\n",
      "3 24 None 141\n",
      "3 24 141 142\n",
      "========================================\n",
      "3 25 None 142\n",
      "3 25 142 143\n",
      "========================================\n",
      "3 26 None 143\n",
      "3 26 143 144\n",
      "========================================\n",
      "3 27 None 144\n",
      "3 27 144 145\n",
      "========================================\n",
      "3 28 None 145\n",
      "3 28 145 146\n",
      "========================================\n",
      "3 29 None 146\n",
      "3 29 146 147\n",
      "========================================\n",
      "3 30 None 147\n",
      "3 30 147 148\n",
      "========================================\n",
      "3 31 None 148\n",
      "3 31 148 149\n",
      "========================================\n",
      "3 32 None 149\n",
      "3 32 149 150\n",
      "========================================\n",
      "3 33 None 150\n",
      "3 33 150 151\n",
      "========================================\n",
      "3 34 None 151\n",
      "3 34 151 152\n",
      "========================================\n",
      "3 35 None 152\n",
      "3 35 152 153\n",
      "========================================\n",
      "3 36 None 153\n",
      "3 36 153 154\n",
      "========================================\n",
      "3 37 None 154\n",
      "3 37 154 155\n",
      "========================================\n",
      "3 38 None 155\n",
      "3 38 155 156\n",
      "========================================\n",
      "3 39 None 156\n",
      "3 39 156 157\n",
      "========================================\n",
      "3 40 None 157\n",
      "3 40 157 158\n",
      "========================================\n",
      "3 41 None 158\n",
      "3 41 158 159\n",
      "========================================\n",
      "3 42 None 159\n",
      "3 42 159 160\n",
      "========================================\n",
      "3 43 None 160\n",
      "3 43 160 161\n",
      "========================================\n",
      "3 44 None 161\n",
      "3 44 161 162\n",
      "========================================\n",
      "3 45 None 162\n",
      "3 45 162 163\n",
      "========================================\n",
      "3 46 None 163\n",
      "3 46 163 164\n",
      "========================================\n",
      "3 47 None 164\n",
      "3 47 164 165\n",
      "========================================\n",
      "3 48 None 165\n",
      "3 48 165 166\n",
      "========================================\n",
      "3 49 None 166\n",
      "3 49 166 167\n",
      "========================================\n",
      "4 0 0 167\n",
      "4 1 50 167\n",
      "4 2 2 167\n",
      "4 3 5 167\n",
      "4 4 3 167\n",
      "4 5 51 167\n",
      "4 6 6 167\n",
      "4 7 128 167\n",
      "4 8 129 167\n",
      "4 9 9 167\n",
      "4 10 53 167\n",
      "4 11 11 167\n",
      "4 12 95 167\n",
      "4 13 None 167\n",
      "4 13 167 168\n",
      "========================================\n",
      "4 14 130 168\n",
      "4 15 56 168\n",
      "4 16 94 168\n",
      "4 17 None 168\n",
      "4 17 168 169\n",
      "========================================\n",
      "4 18 None 169\n",
      "4 18 169 170\n",
      "========================================\n",
      "4 19 None 170\n",
      "4 19 170 171\n",
      "========================================\n",
      "4 20 None 171\n",
      "4 20 171 172\n",
      "========================================\n",
      "4 21 None 172\n",
      "4 21 172 173\n",
      "========================================\n",
      "4 22 None 173\n",
      "4 22 173 174\n",
      "========================================\n",
      "4 23 None 174\n",
      "4 23 174 175\n",
      "========================================\n",
      "4 24 None 175\n",
      "4 24 175 176\n",
      "========================================\n",
      "4 25 None 176\n",
      "4 25 176 177\n",
      "========================================\n",
      "4 26 None 177\n",
      "4 26 177 178\n",
      "========================================\n",
      "4 27 None 178\n",
      "4 27 178 179\n",
      "========================================\n",
      "4 28 None 179\n",
      "4 28 179 180\n",
      "========================================\n",
      "4 29 None 180\n",
      "4 29 180 181\n",
      "========================================\n",
      "4 30 None 181\n",
      "4 30 181 182\n",
      "========================================\n",
      "4 31 None 182\n",
      "4 31 182 183\n",
      "========================================\n",
      "4 32 None 183\n",
      "4 32 183 184\n",
      "========================================\n",
      "4 33 None 184\n",
      "4 33 184 185\n",
      "========================================\n",
      "4 34 None 185\n",
      "4 34 185 186\n",
      "========================================\n",
      "4 35 None 186\n",
      "4 35 186 187\n",
      "========================================\n",
      "4 36 None 187\n",
      "4 36 187 188\n",
      "========================================\n",
      "4 37 None 188\n",
      "4 37 188 189\n",
      "========================================\n",
      "4 38 None 189\n",
      "4 38 189 190\n",
      "========================================\n",
      "4 39 None 190\n",
      "4 39 190 191\n",
      "========================================\n",
      "4 40 None 191\n",
      "4 40 191 192\n",
      "========================================\n",
      "4 41 None 192\n",
      "4 41 192 193\n",
      "========================================\n",
      "4 42 None 193\n",
      "4 42 193 194\n",
      "========================================\n",
      "4 43 None 194\n",
      "4 43 194 195\n",
      "========================================\n",
      "4 44 None 195\n",
      "4 44 195 196\n",
      "========================================\n",
      "4 45 None 196\n",
      "4 45 196 197\n",
      "========================================\n",
      "4 46 None 197\n",
      "4 46 197 198\n",
      "========================================\n",
      "4 47 None 198\n",
      "4 47 198 199\n",
      "========================================\n",
      "4 48 None 199\n",
      "4 48 199 200\n",
      "========================================\n",
      "4 49 None 200\n",
      "4 49 200 201\n",
      "========================================\n",
      "5 0 0 201\n",
      "5 1 50 201\n",
      "5 2 2 201\n",
      "5 3 3 201\n",
      "5 4 3 201\n",
      "5 5 4 201\n",
      "5 6 6 201\n",
      "5 7 7 201\n",
      "5 8 129 201\n",
      "5 9 9 201\n",
      "5 10 53 201\n",
      "5 11 12 201\n",
      "5 12 11 201\n",
      "5 13 None 201\n",
      "5 13 201 202\n",
      "========================================\n",
      "5 14 16 202\n",
      "5 15 56 202\n",
      "5 16 20 202\n",
      "5 17 59 202\n",
      "5 18 None 202\n",
      "5 18 202 203\n",
      "========================================\n",
      "5 19 55 203\n",
      "5 20 None 203\n",
      "5 20 203 204\n",
      "========================================\n",
      "5 21 None 204\n",
      "5 21 204 205\n",
      "========================================\n",
      "5 22 None 205\n",
      "5 22 205 206\n",
      "========================================\n",
      "5 23 None 206\n",
      "5 23 206 207\n",
      "========================================\n",
      "5 24 None 207\n",
      "5 24 207 208\n",
      "========================================\n",
      "5 25 None 208\n",
      "5 25 208 209\n",
      "========================================\n",
      "5 26 None 209\n",
      "5 26 209 210\n",
      "========================================\n",
      "5 27 None 210\n",
      "5 27 210 211\n",
      "========================================\n",
      "5 28 None 211\n",
      "5 28 211 212\n",
      "========================================\n",
      "5 29 None 212\n",
      "5 29 212 213\n",
      "========================================\n",
      "5 30 None 213\n",
      "5 30 213 214\n",
      "========================================\n",
      "5 31 None 214\n",
      "5 31 214 215\n",
      "========================================\n",
      "5 32 None 215\n",
      "5 32 215 216\n",
      "========================================\n",
      "5 33 None 216\n",
      "5 33 216 217\n",
      "========================================\n",
      "5 34 None 217\n",
      "5 34 217 218\n",
      "========================================\n",
      "5 35 None 218\n",
      "5 35 218 219\n",
      "========================================\n",
      "5 36 None 219\n",
      "5 36 219 220\n",
      "========================================\n",
      "5 37 None 220\n",
      "5 37 220 221\n",
      "========================================\n",
      "5 38 None 221\n",
      "5 38 221 222\n",
      "========================================\n",
      "5 39 None 222\n",
      "5 39 222 223\n",
      "========================================\n",
      "5 40 None 223\n",
      "5 40 223 224\n",
      "========================================\n",
      "5 41 None 224\n",
      "5 41 224 225\n",
      "========================================\n",
      "5 42 None 225\n",
      "5 42 225 226\n",
      "========================================\n",
      "5 43 None 226\n",
      "5 43 226 227\n",
      "========================================\n",
      "5 44 None 227\n",
      "5 44 227 228\n",
      "========================================\n",
      "5 45 None 228\n",
      "5 45 228 229\n",
      "========================================\n",
      "5 46 None 229\n",
      "5 46 229 230\n",
      "========================================\n",
      "5 47 None 230\n",
      "5 47 230 231\n",
      "========================================\n",
      "5 48 None 231\n",
      "5 48 231 232\n",
      "========================================\n",
      "5 49 None 232\n",
      "5 49 232 233\n",
      "========================================\n",
      "6 0 0 233\n",
      "6 1 50 233\n",
      "6 2 2 233\n",
      "6 3 None 233\n",
      "6 3 233 234\n",
      "========================================\n",
      "6 4 51 234\n",
      "6 5 5 234\n",
      "6 6 6 234\n",
      "6 7 7 234\n",
      "6 8 128 234\n",
      "6 9 9 234\n",
      "6 10 10 234\n",
      "6 11 130 234\n",
      "6 12 11 234\n",
      "6 13 13 234\n",
      "6 14 56 234\n",
      "6 15 55 234\n",
      "6 16 None 234\n",
      "6 16 234 235\n",
      "========================================\n",
      "6 17 None 235\n",
      "6 17 235 236\n",
      "========================================\n",
      "6 18 59 236\n",
      "6 19 None 236\n",
      "6 19 236 237\n",
      "========================================\n",
      "6 20 None 237\n",
      "6 20 237 238\n",
      "========================================\n",
      "6 21 None 238\n",
      "6 21 238 239\n",
      "========================================\n",
      "6 22 None 239\n",
      "6 22 239 240\n",
      "========================================\n",
      "6 23 None 240\n",
      "6 23 240 241\n",
      "========================================\n",
      "6 24 None 241\n",
      "6 24 241 242\n",
      "========================================\n",
      "6 25 None 242\n",
      "6 25 242 243\n",
      "========================================\n",
      "6 26 None 243\n",
      "6 26 243 244\n",
      "========================================\n",
      "6 27 67 244\n",
      "6 28 None 244\n",
      "6 28 244 245\n",
      "========================================\n",
      "6 29 None 245\n",
      "6 29 245 246\n",
      "========================================\n",
      "6 30 None 246\n",
      "6 30 246 247\n",
      "========================================\n",
      "6 31 None 247\n",
      "6 31 247 248\n",
      "========================================\n",
      "6 32 None 248\n",
      "6 32 248 249\n",
      "========================================\n",
      "6 33 None 249\n",
      "6 33 249 250\n",
      "========================================\n",
      "6 34 None 250\n",
      "6 34 250 251\n",
      "========================================\n",
      "6 35 None 251\n",
      "6 35 251 252\n",
      "========================================\n",
      "6 36 None 252\n",
      "6 36 252 253\n",
      "========================================\n",
      "6 37 None 253\n",
      "6 37 253 254\n",
      "========================================\n",
      "6 38 None 254\n",
      "6 38 254 255\n",
      "========================================\n",
      "6 39 None 255\n",
      "6 39 255 256\n",
      "========================================\n",
      "6 40 None 256\n",
      "6 40 256 257\n",
      "========================================\n",
      "6 41 None 257\n",
      "6 41 257 258\n",
      "========================================\n",
      "6 42 None 258\n",
      "6 42 258 259\n",
      "========================================\n",
      "6 43 None 259\n",
      "6 43 259 260\n",
      "========================================\n",
      "6 44 None 260\n",
      "6 44 260 261\n",
      "========================================\n",
      "6 45 None 261\n",
      "6 45 261 262\n",
      "========================================\n",
      "6 46 None 262\n",
      "6 46 262 263\n",
      "========================================\n",
      "6 47 None 263\n",
      "6 47 263 264\n",
      "========================================\n",
      "6 48 None 264\n",
      "6 48 264 265\n",
      "========================================\n",
      "6 49 264 265\n",
      "7 0 0 265\n",
      "7 1 50 265\n",
      "7 2 2 265\n",
      "7 3 233 265\n",
      "7 4 51 265\n",
      "7 5 4 265\n",
      "7 6 6 265\n",
      "7 7 7 265\n",
      "7 8 128 265\n",
      "7 9 9 265\n",
      "7 10 None 265\n",
      "7 10 265 266\n",
      "========================================\n",
      "7 11 53 266\n",
      "7 12 None 266\n",
      "7 12 266 267\n",
      "========================================\n",
      "7 13 None 267\n",
      "7 13 267 268\n",
      "========================================\n",
      "7 14 None 268\n",
      "7 14 268 269\n",
      "========================================\n",
      "7 15 None 269\n",
      "7 15 269 270\n",
      "========================================\n",
      "7 16 None 270\n",
      "7 16 270 271\n",
      "========================================\n",
      "7 17 95 271\n",
      "7 18 None 271\n",
      "7 18 271 272\n",
      "========================================\n",
      "7 19 None 272\n",
      "7 19 272 273\n",
      "========================================\n",
      "7 20 None 273\n",
      "7 20 273 274\n",
      "========================================\n",
      "7 21 None 274\n",
      "7 21 274 275\n",
      "========================================\n",
      "7 22 138 275\n",
      "7 23 None 275\n",
      "7 23 275 276\n",
      "========================================\n",
      "7 24 None 276\n",
      "7 24 276 277\n",
      "========================================\n",
      "7 25 None 277\n",
      "7 25 277 278\n",
      "========================================\n",
      "7 26 None 278\n",
      "7 26 278 279\n",
      "========================================\n",
      "7 27 None 279\n",
      "7 27 279 280\n",
      "========================================\n",
      "7 28 None 280\n",
      "7 28 280 281\n",
      "========================================\n",
      "7 29 None 281\n",
      "7 29 281 282\n",
      "========================================\n",
      "7 30 None 282\n",
      "7 30 282 283\n",
      "========================================\n",
      "7 31 None 283\n",
      "7 31 283 284\n",
      "========================================\n",
      "7 32 None 284\n",
      "7 32 284 285\n",
      "========================================\n",
      "7 33 None 285\n",
      "7 33 285 286\n",
      "========================================\n",
      "7 34 None 286\n",
      "7 34 286 287\n",
      "========================================\n",
      "7 35 None 287\n",
      "7 35 287 288\n",
      "========================================\n",
      "7 36 None 288\n",
      "7 36 288 289\n",
      "========================================\n",
      "7 37 None 289\n",
      "7 37 289 290\n",
      "========================================\n",
      "7 38 None 290\n",
      "7 38 290 291\n",
      "========================================\n",
      "7 39 None 291\n",
      "7 39 291 292\n",
      "========================================\n",
      "7 40 None 292\n",
      "7 40 292 293\n",
      "========================================\n",
      "7 41 None 293\n",
      "7 41 293 294\n",
      "========================================\n",
      "7 42 None 294\n",
      "7 42 294 295\n",
      "========================================\n",
      "7 43 None 295\n",
      "7 43 295 296\n",
      "========================================\n",
      "7 44 None 296\n",
      "7 44 296 297\n",
      "========================================\n",
      "7 45 None 297\n",
      "7 45 297 298\n",
      "========================================\n",
      "7 46 None 298\n",
      "7 46 298 299\n",
      "========================================\n",
      "7 47 None 299\n",
      "7 47 299 300\n",
      "========================================\n",
      "7 48 None 300\n",
      "7 48 300 301\n",
      "========================================\n",
      "7 49 None 301\n",
      "7 49 301 302\n",
      "========================================\n",
      "8 0 0 302\n",
      "8 1 50 302\n",
      "8 2 None 302\n",
      "8 2 302 303\n",
      "========================================\n",
      "8 3 233 303\n",
      "8 4 4 303\n",
      "8 5 5 303\n",
      "8 6 129 303\n",
      "8 7 6 303\n",
      "8 8 8 303\n",
      "8 9 9 303\n",
      "8 10 53 303\n",
      "8 11 11 303\n",
      "8 12 130 303\n",
      "8 13 267 303\n",
      "8 14 None 303\n",
      "8 14 303 304\n",
      "========================================\n",
      "8 15 201 304\n",
      "8 16 201 304\n",
      "8 17 236 304\n",
      "8 18 235 304\n",
      "8 19 None 304\n",
      "8 19 304 305\n",
      "========================================\n",
      "8 20 175 305\n",
      "8 21 None 305\n",
      "8 21 305 306\n",
      "========================================\n",
      "8 22 None 306\n",
      "8 22 306 307\n",
      "========================================\n",
      "8 23 None 307\n",
      "8 23 307 308\n",
      "========================================\n",
      "8 24 None 308\n",
      "8 24 308 309\n",
      "========================================\n",
      "8 25 212 309\n",
      "8 26 None 309\n",
      "8 26 309 310\n",
      "========================================\n",
      "8 27 None 310\n",
      "8 27 310 311\n",
      "========================================\n",
      "8 28 None 311\n",
      "8 28 311 312\n",
      "========================================\n",
      "8 29 None 312\n",
      "8 29 312 313\n",
      "========================================\n",
      "8 30 None 313\n",
      "8 30 313 314\n",
      "========================================\n",
      "8 31 None 314\n",
      "8 31 314 315\n",
      "========================================\n",
      "8 32 None 315\n",
      "8 32 315 316\n",
      "========================================\n",
      "8 33 None 316\n",
      "8 33 316 317\n",
      "========================================\n",
      "8 34 None 317\n",
      "8 34 317 318\n",
      "========================================\n",
      "8 35 None 318\n",
      "8 35 318 319\n",
      "========================================\n",
      "8 36 None 319\n",
      "8 36 319 320\n",
      "========================================\n",
      "8 37 None 320\n",
      "8 37 320 321\n",
      "========================================\n",
      "8 38 None 321\n",
      "8 38 321 322\n",
      "========================================\n",
      "8 39 None 322\n",
      "8 39 322 323\n",
      "========================================\n",
      "8 40 None 323\n",
      "8 40 323 324\n",
      "========================================\n",
      "8 41 None 324\n",
      "8 41 324 325\n",
      "========================================\n",
      "8 42 None 325\n",
      "8 42 325 326\n",
      "========================================\n",
      "8 43 None 326\n",
      "8 43 326 327\n",
      "========================================\n",
      "8 44 None 327\n",
      "8 44 327 328\n",
      "========================================\n",
      "8 45 None 328\n",
      "8 45 328 329\n",
      "========================================\n",
      "8 46 None 329\n",
      "8 46 329 330\n",
      "========================================\n",
      "8 47 None 330\n",
      "8 47 330 331\n",
      "========================================\n",
      "8 48 330 331\n",
      "8 49 None 331\n",
      "8 49 331 332\n",
      "========================================\n",
      "9 0 0 332\n",
      "9 1 2 332\n",
      "9 2 50 332\n",
      "9 3 233 332\n",
      "9 4 4 332\n",
      "9 5 5 332\n",
      "9 6 6 332\n",
      "9 7 7 332\n",
      "9 8 8 332\n",
      "9 9 9 332\n",
      "9 10 265 332\n",
      "9 11 13 332\n",
      "9 12 53 332\n",
      "9 13 266 332\n",
      "9 14 14 332\n",
      "9 15 None 332\n",
      "9 15 332 333\n",
      "========================================\n",
      "9 16 56 333\n",
      "9 17 None 333\n",
      "9 17 333 334\n",
      "========================================\n",
      "9 18 None 334\n",
      "9 18 334 335\n",
      "========================================\n",
      "9 19 171 335\n",
      "9 20 None 335\n",
      "9 20 335 336\n",
      "========================================\n",
      "9 21 63 336\n",
      "9 22 None 336\n",
      "9 22 336 337\n",
      "========================================\n",
      "9 23 None 337\n",
      "9 23 337 338\n",
      "========================================\n",
      "9 24 None 338\n",
      "9 24 338 339\n",
      "========================================\n",
      "9 25 64 339\n",
      "9 26 None 339\n",
      "9 26 339 340\n",
      "========================================\n",
      "9 27 None 340\n",
      "9 27 340 341\n",
      "========================================\n",
      "9 28 None 341\n",
      "9 28 341 342\n",
      "========================================\n",
      "9 29 None 342\n",
      "9 29 342 343\n",
      "========================================\n",
      "9 30 None 343\n",
      "9 30 343 344\n",
      "========================================\n",
      "9 31 None 344\n",
      "9 31 344 345\n",
      "========================================\n",
      "9 32 None 345\n",
      "9 32 345 346\n",
      "========================================\n",
      "9 33 None 346\n",
      "9 33 346 347\n",
      "========================================\n",
      "9 34 None 347\n",
      "9 34 347 348\n",
      "========================================\n",
      "9 35 None 348\n",
      "9 35 348 349\n",
      "========================================\n",
      "9 36 None 349\n",
      "9 36 349 350\n",
      "========================================\n",
      "9 37 None 350\n",
      "9 37 350 351\n",
      "========================================\n",
      "9 38 None 351\n",
      "9 38 351 352\n",
      "========================================\n",
      "9 39 None 352\n",
      "9 39 352 353\n",
      "========================================\n",
      "9 40 None 353\n",
      "9 40 353 354\n",
      "========================================\n",
      "9 41 None 354\n",
      "9 41 354 355\n",
      "========================================\n",
      "9 42 None 355\n",
      "9 42 355 356\n",
      "========================================\n",
      "9 43 None 356\n",
      "9 43 356 357\n",
      "========================================\n",
      "9 44 None 357\n",
      "9 44 357 358\n",
      "========================================\n",
      "9 45 None 358\n",
      "9 45 358 359\n",
      "========================================\n",
      "9 46 None 359\n",
      "9 46 359 360\n",
      "========================================\n",
      "9 47 None 360\n",
      "9 47 360 361\n",
      "========================================\n",
      "9 48 None 361\n",
      "9 48 361 362\n",
      "========================================\n",
      "9 49 None 362\n",
      "9 49 362 363\n",
      "========================================\n",
      "10 0 0 363\n",
      "10 1 127 363\n",
      "10 2 50 363\n",
      "10 3 51 363\n",
      "10 4 3 363\n",
      "10 5 5 363\n",
      "10 6 6 363\n",
      "10 7 7 363\n",
      "10 8 129 363\n",
      "10 9 52 363\n",
      "10 10 265 363\n",
      "10 11 268 363\n",
      "10 12 None 363\n",
      "10 12 363 364\n",
      "========================================\n",
      "10 13 131 364\n",
      "10 14 None 364\n",
      "10 14 364 365\n",
      "========================================\n",
      "10 15 93 365\n",
      "10 16 None 365\n",
      "10 16 365 366\n",
      "========================================\n",
      "10 17 None 366\n",
      "10 17 366 367\n",
      "========================================\n",
      "10 18 None 367\n",
      "10 18 367 368\n",
      "========================================\n",
      "10 19 None 368\n",
      "10 19 368 369\n",
      "========================================\n",
      "10 20 None 369\n",
      "10 20 369 370\n",
      "========================================\n",
      "10 21 None 370\n",
      "10 21 370 371\n",
      "========================================\n",
      "10 22 141 371\n",
      "10 23 None 371\n",
      "10 23 371 372\n",
      "========================================\n",
      "10 24 None 372\n",
      "10 24 372 373\n",
      "========================================\n",
      "10 25 None 373\n",
      "10 25 373 374\n",
      "========================================\n",
      "10 26 None 374\n",
      "10 26 374 375\n",
      "========================================\n",
      "10 27 None 375\n",
      "10 27 375 376\n",
      "========================================\n",
      "10 28 None 376\n",
      "10 28 376 377\n",
      "========================================\n",
      "10 29 None 377\n",
      "10 29 377 378\n",
      "========================================\n",
      "10 30 None 378\n",
      "10 30 378 379\n",
      "========================================\n",
      "10 31 None 379\n",
      "10 31 379 380\n",
      "========================================\n",
      "10 32 None 380\n",
      "10 32 380 381\n",
      "========================================\n",
      "10 33 None 381\n",
      "10 33 381 382\n",
      "========================================\n",
      "10 34 None 382\n",
      "10 34 382 383\n",
      "========================================\n",
      "10 35 None 383\n",
      "10 35 383 384\n",
      "========================================\n",
      "10 36 None 384\n",
      "10 36 384 385\n",
      "========================================\n",
      "10 37 None 385\n",
      "10 37 385 386\n",
      "========================================\n",
      "10 38 None 386\n",
      "10 38 386 387\n",
      "========================================\n",
      "10 39 None 387\n",
      "10 39 387 388\n",
      "========================================\n",
      "10 40 None 388\n",
      "10 40 388 389\n",
      "========================================\n",
      "10 41 None 389\n",
      "10 41 389 390\n",
      "========================================\n",
      "10 42 None 390\n",
      "10 42 390 391\n",
      "========================================\n",
      "10 43 None 391\n",
      "10 43 391 392\n",
      "========================================\n",
      "10 44 None 392\n",
      "10 44 392 393\n",
      "========================================\n",
      "10 45 None 393\n",
      "10 45 393 394\n",
      "========================================\n",
      "10 46 None 394\n",
      "10 46 394 395\n",
      "========================================\n",
      "10 47 None 395\n",
      "10 47 395 396\n",
      "========================================\n",
      "10 48 None 396\n",
      "10 48 396 397\n",
      "========================================\n",
      "10 49 None 397\n",
      "10 49 397 398\n",
      "========================================\n",
      "11 0 0 398\n",
      "11 1 50 398\n",
      "11 2 50 398\n",
      "11 3 91 398\n",
      "11 4 51 398\n",
      "11 5 4 398\n",
      "11 6 6 398\n",
      "11 7 7 398\n",
      "11 8 8 398\n",
      "11 9 9 398\n",
      "11 10 265 398\n",
      "11 11 53 398\n",
      "11 12 11 398\n",
      "11 13 None 398\n",
      "11 13 398 399\n",
      "========================================\n",
      "11 14 234 399\n",
      "11 15 267 399\n",
      "11 16 18 399\n",
      "11 17 333 399\n",
      "11 18 304 399\n",
      "11 19 None 399\n",
      "11 19 399 400\n",
      "========================================\n",
      "11 20 None 400\n",
      "11 20 400 401\n",
      "========================================\n",
      "11 21 None 401\n",
      "11 21 401 402\n",
      "========================================\n",
      "11 22 None 402\n",
      "11 22 402 403\n",
      "========================================\n",
      "11 23 None 403\n",
      "11 23 403 404\n",
      "========================================\n",
      "11 24 None 404\n",
      "11 24 404 405\n",
      "========================================\n",
      "11 25 None 405\n",
      "11 25 405 406\n",
      "========================================\n",
      "11 26 None 406\n",
      "11 26 406 407\n",
      "========================================\n",
      "11 27 275 407\n",
      "11 28 None 407\n",
      "11 28 407 408\n",
      "========================================\n",
      "11 29 None 408\n",
      "11 29 408 409\n",
      "========================================\n",
      "11 30 None 409\n",
      "11 30 409 410\n",
      "========================================\n",
      "11 31 None 410\n",
      "11 31 410 411\n",
      "========================================\n",
      "11 32 None 411\n",
      "11 32 411 412\n",
      "========================================\n",
      "11 33 None 412\n",
      "11 33 412 413\n",
      "========================================\n",
      "11 34 None 413\n",
      "11 34 413 414\n",
      "========================================\n",
      "11 35 None 414\n",
      "11 35 414 415\n",
      "========================================\n",
      "11 36 None 415\n",
      "11 36 415 416\n",
      "========================================\n",
      "11 37 None 416\n",
      "11 37 416 417\n",
      "========================================\n",
      "11 38 None 417\n",
      "11 38 417 418\n",
      "========================================\n",
      "11 39 None 418\n",
      "11 39 418 419\n",
      "========================================\n",
      "11 40 None 419\n",
      "11 40 419 420\n",
      "========================================\n",
      "11 41 None 420\n",
      "11 41 420 421\n",
      "========================================\n",
      "11 42 None 421\n",
      "11 42 421 422\n",
      "========================================\n",
      "11 43 None 422\n",
      "11 43 422 423\n",
      "========================================\n",
      "11 44 None 423\n",
      "11 44 423 424\n",
      "========================================\n",
      "11 45 None 424\n",
      "11 45 424 425\n",
      "========================================\n",
      "11 46 None 425\n",
      "11 46 425 426\n",
      "========================================\n",
      "11 47 None 426\n",
      "11 47 426 427\n",
      "========================================\n",
      "11 48 None 427\n",
      "11 48 427 428\n",
      "========================================\n",
      "11 49 None 428\n",
      "11 49 428 429\n",
      "========================================\n",
      "12 0 0 429\n",
      "12 1 50 429\n",
      "12 2 302 429\n",
      "12 3 233 429\n",
      "12 4 4 429\n",
      "12 5 4 429\n",
      "12 6 6 429\n",
      "12 7 129 429\n",
      "12 8 128 429\n",
      "12 9 9 429\n",
      "12 10 10 429\n",
      "12 11 None 429\n",
      "12 11 429 430\n",
      "========================================\n",
      "12 12 268 430\n",
      "12 13 266 430\n",
      "12 14 303 430\n",
      "12 15 20 430\n",
      "12 16 131 430\n",
      "12 17 134 430\n",
      "12 18 None 430\n",
      "12 18 430 431\n",
      "========================================\n",
      "12 19 None 431\n",
      "12 19 431 432\n",
      "========================================\n",
      "12 20 66 432\n",
      "12 21 None 432\n",
      "12 21 432 433\n",
      "========================================\n",
      "12 22 None 433\n",
      "12 22 433 434\n",
      "========================================\n",
      "12 23 None 434\n",
      "12 23 434 435\n",
      "========================================\n",
      "12 24 None 435\n",
      "12 24 435 436\n",
      "========================================\n",
      "12 25 None 436\n",
      "12 25 436 437\n",
      "========================================\n",
      "12 26 None 437\n",
      "12 26 437 438\n",
      "========================================\n",
      "12 27 None 438\n",
      "12 27 438 439\n",
      "========================================\n",
      "12 28 None 439\n",
      "12 28 439 440\n",
      "========================================\n",
      "12 29 None 440\n",
      "12 29 440 441\n",
      "========================================\n",
      "12 30 None 441\n",
      "12 30 441 442\n",
      "========================================\n",
      "12 31 None 442\n",
      "12 31 442 443\n",
      "========================================\n",
      "12 32 73 443\n",
      "12 33 None 443\n",
      "12 33 443 444\n",
      "========================================\n",
      "12 34 None 444\n",
      "12 34 444 445\n",
      "========================================\n",
      "12 35 None 445\n",
      "12 35 445 446\n",
      "========================================\n",
      "12 36 None 446\n",
      "12 36 446 447\n",
      "========================================\n",
      "12 37 None 447\n",
      "12 37 447 448\n",
      "========================================\n",
      "12 38 None 448\n",
      "12 38 448 449\n",
      "========================================\n",
      "12 39 None 449\n",
      "12 39 449 450\n",
      "========================================\n",
      "12 40 None 450\n",
      "12 40 450 451\n",
      "========================================\n",
      "12 41 None 451\n",
      "12 41 451 452\n",
      "========================================\n",
      "12 42 None 452\n",
      "12 42 452 453\n",
      "========================================\n",
      "12 43 None 453\n",
      "12 43 453 454\n",
      "========================================\n",
      "12 44 None 454\n",
      "12 44 454 455\n",
      "========================================\n",
      "12 45 None 455\n",
      "12 45 455 456\n",
      "========================================\n",
      "12 46 None 456\n",
      "12 46 456 457\n",
      "========================================\n",
      "12 47 None 457\n",
      "12 47 457 458\n",
      "========================================\n",
      "12 48 None 458\n",
      "12 48 458 459\n",
      "========================================\n",
      "12 49 None 459\n",
      "12 49 459 460\n",
      "========================================\n",
      "13 0 0 460\n",
      "13 1 50 460\n",
      "13 2 302 460\n",
      "13 3 91 460\n",
      "13 4 3 460\n",
      "13 5 4 460\n",
      "13 6 6 460\n",
      "13 7 7 460\n",
      "13 8 8 460\n",
      "13 9 9 460\n",
      "13 10 10 460\n",
      "13 11 266 460\n",
      "13 12 11 460\n",
      "13 13 201 460\n",
      "13 14 None 460\n",
      "13 14 460 461\n",
      "========================================\n",
      "13 15 134 461\n",
      "13 16 364 461\n",
      "13 17 None 461\n",
      "13 17 461 462\n",
      "========================================\n",
      "13 18 None 462\n",
      "13 18 462 463\n",
      "========================================\n",
      "13 19 None 463\n",
      "13 19 463 464\n",
      "========================================\n",
      "13 20 None 464\n",
      "13 20 464 465\n",
      "========================================\n",
      "13 21 None 465\n",
      "13 21 465 466\n",
      "========================================\n",
      "13 22 None 466\n",
      "13 22 466 467\n",
      "========================================\n",
      "13 23 None 467\n",
      "13 23 467 468\n",
      "========================================\n",
      "13 24 None 468\n",
      "13 24 468 469\n",
      "========================================\n",
      "13 25 None 469\n",
      "13 25 469 470\n",
      "========================================\n",
      "13 26 None 470\n",
      "13 26 470 471\n",
      "========================================\n",
      "13 27 None 471\n",
      "13 27 471 472\n",
      "========================================\n",
      "13 28 None 472\n",
      "13 28 472 473\n",
      "========================================\n",
      "13 29 443 473\n",
      "13 30 None 473\n",
      "13 30 473 474\n",
      "========================================\n",
      "13 31 None 474\n",
      "13 31 474 475\n",
      "========================================\n",
      "13 32 None 475\n",
      "13 32 475 476\n",
      "========================================\n",
      "13 33 None 476\n",
      "13 33 476 477\n",
      "========================================\n",
      "13 34 None 477\n",
      "13 34 477 478\n",
      "========================================\n",
      "13 35 None 478\n",
      "13 35 478 479\n",
      "========================================\n",
      "13 36 None 479\n",
      "13 36 479 480\n",
      "========================================\n",
      "13 37 None 480\n",
      "13 37 480 481\n",
      "========================================\n",
      "13 38 None 481\n",
      "13 38 481 482\n",
      "========================================\n",
      "13 39 None 482\n",
      "13 39 482 483\n",
      "========================================\n",
      "13 40 None 483\n",
      "13 40 483 484\n",
      "========================================\n",
      "13 41 None 484\n",
      "13 41 484 485\n",
      "========================================\n",
      "13 42 None 485\n",
      "13 42 485 486\n",
      "========================================\n",
      "13 43 None 486\n",
      "13 43 486 487\n",
      "========================================\n",
      "13 44 None 487\n",
      "13 44 487 488\n",
      "========================================\n",
      "13 45 None 488\n",
      "13 45 488 489\n",
      "========================================\n",
      "13 46 None 489\n",
      "13 46 489 490\n",
      "========================================\n",
      "13 47 None 490\n",
      "13 47 490 491\n",
      "========================================\n",
      "13 48 None 491\n",
      "13 48 491 492\n",
      "========================================\n",
      "13 49 None 492\n",
      "13 49 492 493\n",
      "========================================\n",
      "14 0 0 493\n",
      "14 1 50 493\n",
      "14 2 2 493\n",
      "14 3 51 493\n",
      "14 4 233 493\n",
      "14 5 5 493\n",
      "14 6 6 493\n",
      "14 7 7 493\n",
      "14 8 128 493\n",
      "14 9 9 493\n",
      "14 10 53 493\n",
      "14 11 11 493\n",
      "14 12 130 493\n",
      "14 13 398 493\n",
      "14 14 234 493\n",
      "14 15 None 493\n",
      "14 15 493 494\n",
      "========================================\n",
      "14 16 235 494\n",
      "14 17 None 494\n",
      "14 17 494 495\n",
      "========================================\n",
      "14 18 171 495\n",
      "14 19 None 495\n",
      "14 19 495 496\n",
      "========================================\n",
      "14 20 None 496\n",
      "14 20 496 497\n",
      "========================================\n",
      "14 21 None 497\n",
      "14 21 497 498\n",
      "========================================\n",
      "14 22 None 498\n",
      "14 22 498 499\n",
      "========================================\n",
      "14 23 308 499\n",
      "14 24 None 499\n",
      "14 24 499 500\n",
      "========================================\n",
      "14 25 None 500\n",
      "14 25 500 501\n",
      "========================================\n",
      "14 26 None 501\n",
      "14 26 501 502\n",
      "========================================\n",
      "14 27 None 502\n",
      "14 27 502 503\n",
      "========================================\n",
      "14 28 None 503\n",
      "14 28 503 504\n",
      "========================================\n",
      "14 29 None 504\n",
      "14 29 504 505\n",
      "========================================\n",
      "14 30 310 505\n",
      "14 31 None 505\n",
      "14 31 505 506\n",
      "========================================\n",
      "14 32 None 506\n",
      "14 32 506 507\n",
      "========================================\n",
      "14 33 None 507\n",
      "14 33 507 508\n",
      "========================================\n",
      "14 34 None 508\n",
      "14 34 508 509\n",
      "========================================\n",
      "14 35 None 509\n",
      "14 35 509 510\n",
      "========================================\n",
      "14 36 None 510\n",
      "14 36 510 511\n",
      "========================================\n",
      "14 37 None 511\n",
      "14 37 511 512\n",
      "========================================\n",
      "14 38 None 512\n",
      "14 38 512 513\n",
      "========================================\n",
      "14 39 None 513\n",
      "14 39 513 514\n",
      "========================================\n",
      "14 40 None 514\n",
      "14 40 514 515\n",
      "========================================\n",
      "14 41 None 515\n",
      "14 41 515 516\n",
      "========================================\n",
      "14 42 None 516\n",
      "14 42 516 517\n",
      "========================================\n",
      "14 43 None 517\n",
      "14 43 517 518\n",
      "========================================\n",
      "14 44 None 518\n",
      "14 44 518 519\n",
      "========================================\n",
      "14 45 None 519\n",
      "14 45 519 520\n",
      "========================================\n",
      "14 46 None 520\n",
      "14 46 520 521\n",
      "========================================\n",
      "14 47 None 521\n",
      "14 47 521 522\n",
      "========================================\n",
      "14 48 None 522\n",
      "14 48 522 523\n",
      "========================================\n",
      "14 49 None 523\n",
      "14 49 523 524\n",
      "========================================\n",
      "15 0 0 524\n",
      "15 1 50 524\n",
      "15 2 2 524\n",
      "15 3 233 524\n",
      "15 4 51 524\n",
      "15 5 5 524\n",
      "15 6 7 524\n",
      "15 7 6 524\n",
      "15 8 8 524\n",
      "15 9 9 524\n",
      "15 10 53 524\n",
      "15 11 266 524\n",
      "15 12 131 524\n",
      "15 13 460 524\n",
      "15 14 59 524\n",
      "15 15 93 524\n",
      "15 16 15 524\n",
      "15 17 None 524\n",
      "15 17 524 525\n",
      "========================================\n",
      "15 18 None 525\n",
      "15 18 525 526\n",
      "========================================\n",
      "15 19 None 526\n",
      "15 19 526 527\n",
      "========================================\n",
      "15 20 272 527\n",
      "15 21 None 527\n",
      "15 21 527 528\n",
      "========================================\n",
      "15 22 None 528\n",
      "15 22 528 529\n",
      "========================================\n",
      "15 23 21 529\n",
      "15 24 None 529\n",
      "15 24 529 530\n",
      "========================================\n",
      "15 25 None 530\n",
      "15 25 530 531\n",
      "========================================\n",
      "15 26 None 531\n",
      "15 26 531 532\n",
      "========================================\n",
      "15 27 None 532\n",
      "15 27 532 533\n",
      "========================================\n",
      "15 28 None 533\n",
      "15 28 533 534\n",
      "========================================\n",
      "15 29 None 534\n",
      "15 29 534 535\n",
      "========================================\n",
      "15 30 None 535\n",
      "15 30 535 536\n",
      "========================================\n",
      "15 31 None 536\n",
      "15 31 536 537\n",
      "========================================\n",
      "15 32 None 537\n",
      "15 32 537 538\n",
      "========================================\n",
      "15 33 None 538\n",
      "15 33 538 539\n",
      "========================================\n",
      "15 34 None 539\n",
      "15 34 539 540\n",
      "========================================\n",
      "15 35 None 540\n",
      "15 35 540 541\n",
      "========================================\n",
      "15 36 None 541\n",
      "15 36 541 542\n",
      "========================================\n",
      "15 37 None 542\n",
      "15 37 542 543\n",
      "========================================\n",
      "15 38 None 543\n",
      "15 38 543 544\n",
      "========================================\n",
      "15 39 None 544\n",
      "15 39 544 545\n",
      "========================================\n",
      "15 40 None 545\n",
      "15 40 545 546\n",
      "========================================\n",
      "15 41 None 546\n",
      "15 41 546 547\n",
      "========================================\n",
      "15 42 None 547\n",
      "15 42 547 548\n",
      "========================================\n",
      "15 43 None 548\n",
      "15 43 548 549\n",
      "========================================\n",
      "15 44 None 549\n",
      "15 44 549 550\n",
      "========================================\n",
      "15 45 None 550\n",
      "15 45 550 551\n",
      "========================================\n",
      "15 46 None 551\n",
      "15 46 551 552\n",
      "========================================\n",
      "15 47 None 552\n",
      "15 47 552 553\n",
      "========================================\n",
      "15 48 None 553\n",
      "15 48 553 554\n",
      "========================================\n",
      "15 49 None 554\n",
      "15 49 554 555\n",
      "========================================\n",
      "16 0 0 555\n",
      "16 1 50 555\n",
      "16 2 2 555\n",
      "16 3 3 555\n",
      "16 4 5 555\n",
      "16 5 4 555\n",
      "16 6 6 555\n",
      "16 7 7 555\n",
      "16 8 129 555\n",
      "16 9 9 555\n",
      "16 10 53 555\n",
      "16 11 429 555\n",
      "16 12 332 555\n",
      "16 13 11 555\n",
      "16 14 167 555\n",
      "16 15 14 555\n",
      "16 16 171 555\n",
      "16 17 460 555\n",
      "16 18 None 555\n",
      "16 18 555 556\n",
      "========================================\n",
      "16 19 59 556\n",
      "16 20 None 556\n",
      "16 20 556 557\n",
      "========================================\n",
      "16 21 None 557\n",
      "16 21 557 558\n",
      "========================================\n",
      "16 22 None 558\n",
      "16 22 558 559\n",
      "========================================\n",
      "16 23 463 559\n",
      "16 24 None 559\n",
      "16 24 559 560\n",
      "========================================\n",
      "16 25 None 560\n",
      "16 25 560 561\n",
      "========================================\n",
      "16 26 None 561\n",
      "16 26 561 562\n",
      "========================================\n",
      "16 27 None 562\n",
      "16 27 562 563\n",
      "========================================\n",
      "16 28 None 563\n",
      "16 28 563 564\n",
      "========================================\n",
      "16 29 None 564\n",
      "16 29 564 565\n",
      "========================================\n",
      "16 30 None 565\n",
      "16 30 565 566\n",
      "========================================\n",
      "16 31 None 566\n",
      "16 31 566 567\n",
      "========================================\n",
      "16 32 None 567\n",
      "16 32 567 568\n",
      "========================================\n",
      "16 33 None 568\n",
      "16 33 568 569\n",
      "========================================\n",
      "16 34 None 569\n",
      "16 34 569 570\n",
      "========================================\n",
      "16 35 None 570\n",
      "16 35 570 571\n",
      "========================================\n",
      "16 36 None 571\n",
      "16 36 571 572\n",
      "========================================\n",
      "16 37 None 572\n",
      "16 37 572 573\n",
      "========================================\n",
      "16 38 None 573\n",
      "16 38 573 574\n",
      "========================================\n",
      "16 39 None 574\n",
      "16 39 574 575\n",
      "========================================\n",
      "16 40 None 575\n",
      "16 40 575 576\n",
      "========================================\n",
      "16 41 None 576\n",
      "16 41 576 577\n",
      "========================================\n",
      "16 42 None 577\n",
      "16 42 577 578\n",
      "========================================\n",
      "16 43 None 578\n",
      "16 43 578 579\n",
      "========================================\n",
      "16 44 None 579\n",
      "16 44 579 580\n",
      "========================================\n",
      "16 45 None 580\n",
      "16 45 580 581\n",
      "========================================\n",
      "16 46 None 581\n",
      "16 46 581 582\n",
      "========================================\n",
      "16 47 None 582\n",
      "16 47 582 583\n",
      "========================================\n",
      "16 48 None 583\n",
      "16 48 583 584\n",
      "========================================\n",
      "16 49 None 584\n",
      "16 49 584 585\n",
      "========================================\n",
      "17 0 0 585\n",
      "17 1 50 585\n",
      "17 2 2 585\n",
      "17 3 233 585\n",
      "17 4 51 585\n",
      "17 5 5 585\n",
      "17 6 92 585\n",
      "17 7 129 585\n",
      "17 8 129 585\n",
      "17 9 9 585\n",
      "17 10 265 585\n",
      "17 11 11 585\n",
      "17 12 266 585\n",
      "17 13 460 585\n",
      "17 14 None 585\n",
      "17 14 585 586\n",
      "========================================\n",
      "17 15 270 586\n",
      "17 16 18 586\n",
      "17 17 235 586\n",
      "17 18 None 586\n",
      "17 18 586 587\n",
      "========================================\n",
      "17 19 None 587\n",
      "17 19 587 588\n",
      "========================================\n",
      "17 20 None 588\n",
      "17 20 588 589\n",
      "========================================\n",
      "17 21 None 589\n",
      "17 21 589 590\n",
      "========================================\n",
      "17 22 527 590\n",
      "17 23 None 590\n",
      "17 23 590 591\n",
      "========================================\n",
      "17 24 None 591\n",
      "17 24 591 592\n",
      "========================================\n",
      "17 25 None 592\n",
      "17 25 592 593\n",
      "========================================\n",
      "17 26 None 593\n",
      "17 26 593 594\n",
      "========================================\n",
      "17 27 None 594\n",
      "17 27 594 595\n",
      "========================================\n",
      "17 28 None 595\n",
      "17 28 595 596\n",
      "========================================\n",
      "17 29 None 596\n",
      "17 29 596 597\n",
      "========================================\n",
      "17 30 None 597\n",
      "17 30 597 598\n",
      "========================================\n",
      "17 31 None 598\n",
      "17 31 598 599\n",
      "========================================\n",
      "17 32 None 599\n",
      "17 32 599 600\n",
      "========================================\n",
      "17 33 None 600\n",
      "17 33 600 601\n",
      "========================================\n",
      "17 34 None 601\n",
      "17 34 601 602\n",
      "========================================\n",
      "17 35 None 602\n",
      "17 35 602 603\n",
      "========================================\n",
      "17 36 None 603\n",
      "17 36 603 604\n",
      "========================================\n",
      "17 37 None 604\n",
      "17 37 604 605\n",
      "========================================\n",
      "17 38 None 605\n",
      "17 38 605 606\n",
      "========================================\n",
      "17 39 None 606\n",
      "17 39 606 607\n",
      "========================================\n",
      "17 40 None 607\n",
      "17 40 607 608\n",
      "========================================\n",
      "17 41 None 608\n",
      "17 41 608 609\n",
      "========================================\n",
      "17 42 None 609\n",
      "17 42 609 610\n",
      "========================================\n",
      "17 43 None 610\n",
      "17 43 610 611\n",
      "========================================\n",
      "17 44 None 611\n",
      "17 44 611 612\n",
      "========================================\n",
      "17 45 None 612\n",
      "17 45 612 613\n",
      "========================================\n",
      "17 46 None 613\n",
      "17 46 613 614\n",
      "========================================\n",
      "17 47 None 614\n",
      "17 47 614 615\n",
      "========================================\n",
      "17 48 None 615\n",
      "17 48 615 616\n",
      "========================================\n",
      "17 49 None 616\n",
      "17 49 616 617\n",
      "========================================\n",
      "18 0 0 617\n",
      "18 1 50 617\n",
      "18 2 2 617\n",
      "18 3 233 617\n",
      "18 4 51 617\n",
      "18 5 5 617\n",
      "18 6 6 617\n",
      "18 7 7 617\n",
      "18 8 8 617\n",
      "18 9 9 617\n",
      "18 10 10 617\n",
      "18 11 268 617\n",
      "18 12 None 617\n",
      "18 12 617 618\n",
      "========================================\n",
      "18 13 398 618\n",
      "18 14 56 618\n",
      "18 15 None 618\n",
      "18 15 618 619\n",
      "========================================\n",
      "18 16 234 619\n",
      "18 17 494 619\n",
      "18 18 21 619\n",
      "18 19 171 619\n",
      "18 20 None 619\n",
      "18 20 619 620\n",
      "========================================\n",
      "18 21 None 620\n",
      "18 21 620 621\n",
      "========================================\n",
      "18 22 None 621\n",
      "18 22 621 622\n",
      "========================================\n",
      "18 23 None 622\n",
      "18 23 622 623\n",
      "========================================\n",
      "18 24 None 623\n",
      "18 24 623 624\n",
      "========================================\n",
      "18 25 None 624\n",
      "18 25 624 625\n",
      "========================================\n",
      "18 26 None 625\n",
      "18 26 625 626\n",
      "========================================\n",
      "18 27 None 626\n",
      "18 27 626 627\n",
      "========================================\n",
      "18 28 26 627\n",
      "18 29 None 627\n",
      "18 29 627 628\n",
      "========================================\n",
      "18 30 None 628\n",
      "18 30 628 629\n",
      "========================================\n",
      "18 31 None 629\n",
      "18 31 629 630\n",
      "========================================\n",
      "18 32 None 630\n",
      "18 32 630 631\n",
      "========================================\n",
      "18 33 None 631\n",
      "18 33 631 632\n",
      "========================================\n",
      "18 34 None 632\n",
      "18 34 632 633\n",
      "========================================\n",
      "18 35 None 633\n",
      "18 35 633 634\n",
      "========================================\n",
      "18 36 None 634\n",
      "18 36 634 635\n",
      "========================================\n",
      "18 37 None 635\n",
      "18 37 635 636\n",
      "========================================\n",
      "18 38 None 636\n",
      "18 38 636 637\n",
      "========================================\n",
      "18 39 None 637\n",
      "18 39 637 638\n",
      "========================================\n",
      "18 40 None 638\n",
      "18 40 638 639\n",
      "========================================\n",
      "18 41 None 639\n",
      "18 41 639 640\n",
      "========================================\n",
      "18 42 None 640\n",
      "18 42 640 641\n",
      "========================================\n",
      "18 43 None 641\n",
      "18 43 641 642\n",
      "========================================\n",
      "18 44 None 642\n",
      "18 44 642 643\n",
      "========================================\n",
      "18 45 None 643\n",
      "18 45 643 644\n",
      "========================================\n",
      "18 46 None 644\n",
      "18 46 644 645\n",
      "========================================\n",
      "18 47 None 645\n",
      "18 47 645 646\n",
      "========================================\n",
      "18 48 None 646\n",
      "18 48 646 647\n",
      "========================================\n",
      "18 49 None 647\n",
      "18 49 647 648\n",
      "========================================\n",
      "19 0 0 648\n",
      "19 1 50 648\n",
      "19 2 2 648\n",
      "19 3 3 648\n",
      "19 4 51 648\n",
      "19 5 4 648\n",
      "19 6 6 648\n",
      "19 7 7 648\n",
      "19 8 8 648\n",
      "19 9 9 648\n",
      "19 10 None 648\n",
      "19 10 648 649\n",
      "========================================\n",
      "19 11 53 649\n",
      "19 12 11 649\n",
      "19 13 201 649\n",
      "19 14 133 649\n",
      "19 15 None 649\n",
      "19 15 649 650\n",
      "========================================\n",
      "19 16 270 650\n",
      "19 17 56 650\n",
      "19 18 234 650\n",
      "19 19 None 650\n",
      "19 19 650 651\n",
      "========================================\n",
      "19 20 None 651\n",
      "19 20 651 652\n",
      "========================================\n",
      "19 21 None 652\n",
      "19 21 652 653\n",
      "========================================\n",
      "19 22 None 653\n",
      "19 22 653 654\n",
      "========================================\n",
      "19 23 None 654\n",
      "19 23 654 655\n",
      "========================================\n",
      "19 24 None 655\n",
      "19 24 655 656\n",
      "========================================\n",
      "19 25 None 656\n",
      "19 25 656 657\n",
      "========================================\n",
      "19 26 None 657\n",
      "19 26 657 658\n",
      "========================================\n",
      "19 27 None 658\n",
      "19 27 658 659\n",
      "========================================\n",
      "19 28 None 659\n",
      "19 28 659 660\n",
      "========================================\n",
      "19 29 None 660\n",
      "19 29 660 661\n",
      "========================================\n",
      "19 30 None 661\n",
      "19 30 661 662\n",
      "========================================\n",
      "19 31 None 662\n",
      "19 31 662 663\n",
      "========================================\n",
      "19 32 None 663\n",
      "19 32 663 664\n",
      "========================================\n",
      "19 33 None 664\n",
      "19 33 664 665\n",
      "========================================\n",
      "19 34 None 665\n",
      "19 34 665 666\n",
      "========================================\n",
      "19 35 None 666\n",
      "19 35 666 667\n",
      "========================================\n",
      "19 36 None 667\n",
      "19 36 667 668\n",
      "========================================\n",
      "19 37 None 668\n",
      "19 37 668 669\n",
      "========================================\n",
      "19 38 None 669\n",
      "19 38 669 670\n",
      "========================================\n",
      "19 39 None 670\n",
      "19 39 670 671\n",
      "========================================\n",
      "19 40 None 671\n",
      "19 40 671 672\n",
      "========================================\n",
      "19 41 None 672\n",
      "19 41 672 673\n",
      "========================================\n",
      "19 42 None 673\n",
      "19 42 673 674\n",
      "========================================\n",
      "19 43 None 674\n",
      "19 43 674 675\n",
      "========================================\n",
      "19 44 None 675\n",
      "19 44 675 676\n",
      "========================================\n",
      "19 45 None 676\n",
      "19 45 676 677\n",
      "========================================\n",
      "19 46 None 677\n",
      "19 46 677 678\n",
      "========================================\n",
      "19 47 None 678\n",
      "19 47 678 679\n",
      "========================================\n",
      "19 48 None 679\n",
      "19 48 679 680\n",
      "========================================\n",
      "19 49 None 680\n",
      "19 49 680 681\n",
      "========================================\n"
     ]
    }
   ],
   "source": [
    "feature_idx = 0\n",
    "\n",
    "for i in range(20):  # iterating over models\n",
    "    for j in range(n_neuron):  # iterating over neurons\n",
    "        print(i, j, neuron_feature_pairing[i][j], feature_idx)\n",
    "        if neuron_feature_pairing[i][j] is not None:\n",
    "            continue\n",
    "        neuron_feature_pairing[i][j] = feature_idx # setting neuron to current feature\n",
    "        for k in range(20): # iterating over other models\n",
    "            corr_mat = all_corr_mat[i][k]\n",
    "            neuron_row = corr_mat[j]\n",
    "            large_corr_neuron_idx = np.where(neuron_row > avg_90_pct)[0]\n",
    "            for m in large_corr_neuron_idx:\n",
    "                if neuron_row[m] > previous_max[k][m]:\n",
    "                    neuron_feature_pairing[k][m] = feature_idx\n",
    "                    previous_max[k][m] = neuron_row[m]\n",
    "        feature_idx += 1\n",
    "        print(i, j, neuron_feature_pairing[i][j], feature_idx)\n",
    "        print('='*40)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 136,
   "id": "executed-argument",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[  0,   1,   2,   3,   4,   5,   6,   7,   8,   9,  10,  11,  12,\n",
       "         13,  14,  15,  16,  17,  18,  19,  20,  21,  22,  23,  24,  25,\n",
       "         26,  27,  28,  29,  30,  31,  32,  33,  34,  35,  36,  37,  38,\n",
       "         39,  40,  41,  42,  43,  44,  45,  46,  47,  48,  49],\n",
       "       [  0,  50,   2,  51,   3,   5,   6,   7,   8,  52, 265,  53, 266,\n",
       "         54,  55,  56,  57,  58,  59,  60,  61,  62,  63,  64,  65,  66,\n",
       "         67,  68,  69,  70,  71,  72,  73,  74,  75,  76,  77,  78,  79,\n",
       "         80,  81,  82,  83,  84,  85,  86,  87,  88,  89,  90],\n",
       "       [127,   0, 302,   5,  91,   4,  92,   7,   8,   9,  10,  12,  11,\n",
       "         93,  94,  95,  20,  15,  96,  97,  98,  99, 399, 100, 101, 102,\n",
       "        103, 104, 105, 106, 107, 108, 109, 110, 111, 112, 113, 114, 115,\n",
       "        116, 117, 118, 119, 120, 121, 122, 123, 124, 125, 126],\n",
       "       [127,   1,  51,   5,   6,   3,  92, 128, 129,   9,  53,  12, 130,\n",
       "         95, 131, 132, 133, 134, 135, 136, 137, 138, 139, 140, 141, 142,\n",
       "        143, 144, 145, 146, 147, 148, 149, 150, 151, 152, 153, 154, 155,\n",
       "        156, 157, 158, 159, 160, 161, 162, 163, 164, 165, 166],\n",
       "       [  0,  50,   2,   5,   3,  51,   6, 128, 129,   9,  53,  11,  95,\n",
       "        167, 130,  56,  94, 168, 169, 170, 171, 172, 173, 174, 175, 176,\n",
       "        177, 178, 179, 180, 181, 182, 183, 184, 185, 186, 187, 188, 189,\n",
       "        190, 191, 192, 193, 194, 195, 196, 197, 198, 199, 200],\n",
       "       [  0,  50,   2,   3,   3,   4,   6,   7, 129,   9,  53, 648,  11,\n",
       "        201,  16,  56,  20,  59, 202,  55, 203, 204, 205, 206, 207, 208,\n",
       "        209, 210, 211, 212, 213, 214, 215, 216, 217, 218, 219, 220, 221,\n",
       "        222, 223, 224, 225, 226, 227, 228, 229, 230, 231, 232],\n",
       "       [  0,  50,   2, 233,  51,   5,   6,   7, 128,   9,  10, 130,  11,\n",
       "        585,  56,  55, 234, 235,  59, 236, 237, 238, 239, 240, 241, 242,\n",
       "        243,  67, 244, 245, 246, 247, 248, 249, 250, 251, 252, 253, 254,\n",
       "        255, 256, 257, 258, 259, 260, 261, 262, 263, 264, 264],\n",
       "       [  0,  50,   2, 233,  51,   4,   6,   7, 128,   9, 265,  53, 266,\n",
       "        267, 268, 269, 270, 618, 271, 272, 273, 274, 138, 275, 276, 277,\n",
       "        278, 279, 280, 281, 282, 283, 284, 285, 286, 287, 288, 289, 290,\n",
       "        291, 292, 293, 294, 295, 296, 297, 298, 299, 300, 301],\n",
       "       [  0,  50, 302, 233,   4,   5, 129,   6,   8,   9,  53,  11, 130,\n",
       "        493, 303, 201, 201, 236, 235, 304, 370, 305, 306, 307, 308, 212,\n",
       "        309, 310, 311, 312, 313, 314, 315, 316, 317, 318, 319, 320, 321,\n",
       "        322, 323, 324, 325, 326, 327, 328, 329, 330, 330, 331],\n",
       "       [  0,   2,  50, 233,   4,   5,   6,   7,   8,   9, 265, 585,  53,\n",
       "        266,  14, 332, 618, 333, 334, 171, 335,  63, 336, 337, 338,  64,\n",
       "        339, 340, 341, 342, 343, 344, 345, 346, 347, 348, 349, 350, 351,\n",
       "        352, 353, 354, 355, 356, 357, 358, 359, 360, 361, 362],\n",
       "       [  0, 127,  50,  51,   3,   5,   6,   7, 129,  52, 265, 268, 363,\n",
       "        131, 364,  93, 365, 366, 367, 368, 369, 370, 141, 371, 372, 373,\n",
       "        374, 375, 376, 377, 378, 379, 380, 381, 382, 383, 384, 385, 386,\n",
       "        387, 388, 389, 390, 391, 392, 393, 394, 395, 396, 397],\n",
       "       [  0,  50,  50,  91,  51,   4,   6,   7,   8,   9, 265,  53,  11,\n",
       "        398, 234, 267,  18, 333, 524, 399, 400, 401, 402, 403, 404, 405,\n",
       "        406, 275, 407, 408, 409, 410, 411, 412, 413, 414, 415, 416, 417,\n",
       "        418, 419, 420, 421, 422, 423, 424, 425, 426, 427, 428],\n",
       "       [  0,  50, 302, 233,   4,   4,   6, 129, 128,   9,  10, 429, 268,\n",
       "        266, 303,  20, 131, 134, 430, 431,  66, 432, 433, 434, 435, 436,\n",
       "        437, 438, 439, 440, 441, 442,  73, 443, 444, 445, 446, 447, 448,\n",
       "        449, 450, 451, 452, 453, 454, 455, 456, 457, 458, 459],\n",
       "       [  0,  50, 302,  91,   3,   4,   6,   7,   8,   9,  10, 648,  11,\n",
       "        201, 460, 134, 364, 461, 462, 463, 464, 465, 466, 467, 468, 469,\n",
       "        470, 471, 472, 443, 473, 474, 475, 476, 477, 478, 479, 480, 481,\n",
       "        482, 483, 484, 485, 486, 487, 488, 489, 490, 491, 492],\n",
       "       [  0,  50,   2,  51, 233,   5,   6,   7, 128,   9,  53, 648, 130,\n",
       "        398, 234, 493, 618, 494, 171, 495, 496, 497, 498, 308, 499, 500,\n",
       "        501, 502, 503, 504, 310, 505, 506, 507, 508, 509, 510, 511, 512,\n",
       "        513, 514, 515, 516, 517, 518, 519, 520, 521, 522, 523],\n",
       "       [  0,  50,   2, 233,  51,   5,   7,   6,   8,   9,  53, 266, 131,\n",
       "        460,  59,  93,  15, 524, 525, 526, 272, 527, 528,  21, 529, 530,\n",
       "        531, 532, 533, 534, 535, 536, 537, 538, 539, 540, 541, 542, 543,\n",
       "        544, 545, 546, 547, 548, 549, 550, 551, 552, 553, 554],\n",
       "       [  0,  50,   2,   3,   5,   4,   6,   7, 129,   9,  53, 429, 332,\n",
       "         11, 167,  14, 171, 460, 555,  59, 556, 557, 558, 463, 559, 560,\n",
       "        561, 562, 563, 564, 565, 566, 567, 568, 569, 570, 571, 572, 573,\n",
       "        574, 575, 576, 577, 578, 579, 580, 581, 582, 583, 584],\n",
       "       [  0,  50,   2, 233,  51,   5,  92, 129, 129,   9, 265,  11, 266,\n",
       "        460, 585, 270,  18, 235, 586, 587, 588, 589, 527, 590, 591, 592,\n",
       "        593, 594, 595, 596, 597, 598, 599, 600, 601, 602, 603, 604, 605,\n",
       "        606, 607, 608, 609, 610, 611, 612, 613, 615, 615, 616],\n",
       "       [  0,  50,   2, 233,  51,   5,   6,   7,   8,   9,  10, 268, 617,\n",
       "        398,  56, 618, 234, 494,  21, 171, 619, 620, 621, 622, 623, 624,\n",
       "        625, 626,  26, 627, 628, 629, 630, 631, 632, 633, 634, 635, 636,\n",
       "        637, 638, 639, 640, 641, 642, 643, 644, 645, 646, 647],\n",
       "       [  0,  50,   2,   3,  51,   4,   6,   7,   8,   9, 648,  53,  11,\n",
       "        201, 133, 649, 270,  56, 234, 650, 651, 652, 653, 654, 655, 656,\n",
       "        657, 658, 659, 660, 661, 662, 663, 664, 665, 666, 667, 668, 669,\n",
       "        670, 671, 672, 673, 674, 675, 676, 677, 678, 679, 680]])"
      ]
     },
     "execution_count": 136,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "neuron_feature_pairing = np.array(neuron_feature_pairing)\n",
    "neuron_feature_pairing"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 137,
   "id": "outside-document",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(20, 50)"
      ]
     },
     "execution_count": 137,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "neuron_feature_pairing.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c81e24e7",
   "metadata": {},
   "outputs": [],
   "source": [
    "save_name = f'neuron_feature_pairing_p{pct}_v2'\n",
    "save_path = os.path.join(affinity_dir, save_name)\n",
    "print(save_path)\n",
    "np.save(save_path, neuron_feature_pairing)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 87,
   "id": "thermal-forth",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "681"
      ]
     },
     "execution_count": 87,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "feature_idx"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 136,
   "id": "frozen-bennett",
   "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": [
    "_ = plt.hist(np.array(neuron_feature_pairing).reshape(-1), bins=30)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 137,
   "id": "practical-petersburg",
   "metadata": {},
   "outputs": [],
   "source": [
    "c = Counter()\n",
    "c.update(np.array(neuron_feature_pairing).reshape(-1))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 138,
   "id": "closed-vault",
   "metadata": {},
   "outputs": [],
   "source": [
    "count_dist = []\n",
    "for i in c:\n",
    "    count_dist.append(c[i])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 139,
   "id": "juvenile-litigation",
   "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": [
    "_ = plt.hist(count_dist, bins=60)\n",
    "plt.yscale('log')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 140,
   "id": "a0c5d25b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "583\n",
      "627\n",
      "680\n"
     ]
    }
   ],
   "source": [
    "print(len(np.where(np.array(count_dist) <= 1)[0]))\n",
    "print(len(np.where(np.array(count_dist) <= 2)[0]))\n",
    "print(len(count_dist))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c790dec9",
   "metadata": {},
   "source": [
    "## Feature variance"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "muslim-marketing",
   "metadata": {},
   "outputs": [],
   "source": [
    "mean = np.load(os.path.join(affinity_dir, 'mean_0.npy'))\n",
    "std = np.load(os.path.join(affinity_dir, 'std_0.npy'))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "71d48012",
   "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": [
    "_ = plt.hist(mean, bins=20)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "d75e42cd",
   "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": [
    "_ = plt.hist(std, bins=20)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 63,
   "id": "f3e00b5f",
   "metadata": {},
   "outputs": [],
   "source": [
    "x = np.zeros((50, 50))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 64,
   "id": "d42c663b",
   "metadata": {},
   "outputs": [],
   "source": [
    "for i in range(50):\n",
    "    for j in range(50):\n",
    "        x[i, j] = abs(i-j)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d235ec97",
   "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.7"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
