{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "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": [
    "print(f'Cuda {torch.cuda.is_available()}')\n",
    "exp_dir = None  # experiment path\n",
    "print(exp_dir)\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))\n",
    "print(affinity_dir)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 104,
   "id": "streaming-career",
   "metadata": {},
   "outputs": [],
   "source": [
    "model_index = {}\n",
    "for n in sorted(os.listdir(os.path.join(affinity_dir, 'ep_1_'))):\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": 105,
   "id": "dd012a21",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{0: [0, 1, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 2, 3, 4, 5, 6, 7, 8, 9],\n",
       " 10: [0, 1, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 2, 3, 4, 5, 6, 7, 8, 9],\n",
       " 11: [0, 1, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 2, 3, 4, 5, 6, 7, 8, 9],\n",
       " 12: [0, 1, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 2, 3, 4, 5, 6, 7, 8, 9],\n",
       " 13: [0, 1, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 2, 3, 4, 5, 6, 7, 8, 9],\n",
       " 14: [0, 1, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 2, 3, 4, 5, 6, 7, 8, 9],\n",
       " 15: [0, 1, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 2, 3, 4, 5, 6, 7, 8, 9],\n",
       " 16: [0, 1, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 2, 3, 4, 5, 6, 7, 8, 9],\n",
       " 17: [0, 1, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 2, 3, 4, 5, 6, 7, 8, 9],\n",
       " 18: [0, 1, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 2, 3, 4, 5, 6, 7, 8, 9],\n",
       " 19: [0, 1, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 2, 3, 4, 5, 6, 7, 8, 9],\n",
       " 1: [0, 1, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 2, 3, 4, 5, 6, 7, 8, 9],\n",
       " 2: [0, 1, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 2, 3, 4, 5, 6, 7, 8, 9],\n",
       " 3: [0, 1, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 2, 3, 4, 5, 6, 7, 8, 9],\n",
       " 4: [0, 1, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 2, 3, 4, 5, 6, 7, 8, 9],\n",
       " 5: [0, 1, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 2, 3, 4, 5, 6, 7, 8, 9],\n",
       " 6: [0, 1, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 2, 3, 4, 5, 6, 7, 8, 9],\n",
       " 7: [0, 1, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 2, 3, 4, 5, 6, 7, 8, 9],\n",
       " 8: [0, 1, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 2, 3, 4, 5, 6, 7, 8, 9],\n",
       " 9: [0, 1, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 2, 3, 4, 5, 6, 7, 8, 9]}"
      ]
     },
     "execution_count": 105,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "model_index"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 106,
   "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": 145,
   "id": "grave-smith",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.8994997\n"
     ]
    }
   ],
   "source": [
    "ep = 10\n",
    "corr_mat = np.load(os.path.join(affinity_dir, f'ep_{ep}_', 'corr_2_13.npy'))\n",
    "corr_mat = np.abs(corr_mat)\n",
    "# aligned_corr_mat = align(corr_mat)\n",
    "print(corr_mat.max())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 146,
   "id": "ebd87a48",
   "metadata": {},
   "outputs": [],
   "source": [
    "sns.set_palette(\"mako\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 147,
   "id": "instant-auction",
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0.5, 1.0, 'Correlation (10k) at ep 10')"
      ]
     },
     "execution_count": 147,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "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(f'Correlation (10k) at ep {ep}', fontsize=23)\n",
    "# plt.savefig(os.path.join(root, f'10_corr.pdf'))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 148,
   "id": "d5fb1c81",
   "metadata": {},
   "outputs": [],
   "source": [
    "# diff_norm = []\n",
    "# prev_corr_mat = np.load(os.path.join(affinity_dir, 'ep_10_', 'corr_2_13.npy'))\n",
    "# for ep in 10 * np.arange(2, 18):\n",
    "#     corr_mat = np.load(os.path.join(affinity_dir, f'ep_{ep}_', 'corr_2_13.npy'))\n",
    "#     diff_norm.append(np.linalg.norm(corr_mat - prev_corr_mat))\n",
    "#     prev_corr_mat = corr_mat"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 149,
   "id": "39a809bb",
   "metadata": {},
   "outputs": [],
   "source": [
    "# plt.plot(np.arange(len(diff_norm)), diff_norm)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 150,
   "id": "bda799fe",
   "metadata": {},
   "outputs": [],
   "source": [
    "# norm = []\n",
    "# for ep in 10 * np.arange(1, 18):\n",
    "#     corr_mat = np.load(os.path.join(affinity_dir, f'ep_{ep}_', 'corr_2_13.npy'))\n",
    "#     norm.append(np.linalg.norm(corr_mat))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 151,
   "id": "06cf7cb2",
   "metadata": {},
   "outputs": [],
   "source": [
    "# plt.plot(np.arange(len(norm)), norm)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 152,
   "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": 153,
   "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": 154,
   "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": 155,
   "id": "strategic-arnold",
   "metadata": {},
   "outputs": [],
   "source": [
    "# self_corr_mat[0,0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 156,
   "id": "alien-satellite",
   "metadata": {},
   "outputs": [],
   "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": 157,
   "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": 158,
   "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": 159,
   "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'ep_{ep}_', 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": 160,
   "id": "recovered-stake",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.48049347432036155"
      ]
     },
     "execution_count": 160,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "avg_90_pct = np.mean(percentile)\n",
    "avg_90_pct"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 161,
   "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": 162,
   "id": "veterinary-meaning",
   "metadata": {},
   "outputs": [],
   "source": [
    "ep = 10\n",
    "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'ep_{ep}_', f'corr_{i}_{j}.npy'))\n",
    "        all_corr_mat[i][j] = corr_mat"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 163,
   "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": 164,
   "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 1 50\n",
      "1 1 None 50\n",
      "1 1 50 51\n",
      "========================================\n",
      "1 2 2 51\n",
      "1 3 3 51\n",
      "1 4 None 51\n",
      "1 4 51 52\n",
      "========================================\n",
      "1 5 6 52\n",
      "1 6 5 52\n",
      "1 7 8 52\n",
      "1 8 7 52\n",
      "1 9 None 52\n",
      "1 9 52 53\n",
      "========================================\n",
      "1 10 11 53\n",
      "1 11 10 53\n",
      "1 12 None 53\n",
      "1 12 53 54\n",
      "========================================\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 0 91\n",
      "2 1 0 91\n",
      "2 2 2 91\n",
      "2 3 3 91\n",
      "2 4 4 91\n",
      "2 5 5 91\n",
      "2 6 6 91\n",
      "2 7 8 91\n",
      "2 8 7 91\n",
      "2 9 11 91\n",
      "2 10 9 91\n",
      "2 11 None 91\n",
      "2 11 91 92\n",
      "========================================\n",
      "2 12 None 92\n",
      "2 12 92 93\n",
      "========================================\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 None 96\n",
      "2 16 96 97\n",
      "========================================\n",
      "2 17 19 97\n",
      "2 18 None 97\n",
      "2 18 97 98\n",
      "========================================\n",
      "2 19 17 98\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 None 100\n",
      "2 22 100 101\n",
      "========================================\n",
      "2 23 None 101\n",
      "2 23 101 102\n",
      "========================================\n",
      "2 24 None 102\n",
      "2 24 102 103\n",
      "========================================\n",
      "2 25 None 103\n",
      "2 25 103 104\n",
      "========================================\n",
      "2 26 None 104\n",
      "2 26 104 105\n",
      "========================================\n",
      "2 27 None 105\n",
      "2 27 105 106\n",
      "========================================\n",
      "2 28 None 106\n",
      "2 28 106 107\n",
      "========================================\n",
      "2 29 None 107\n",
      "2 29 107 108\n",
      "========================================\n",
      "2 30 None 108\n",
      "2 30 108 109\n",
      "========================================\n",
      "2 31 None 109\n",
      "2 31 109 110\n",
      "========================================\n",
      "2 32 None 110\n",
      "2 32 110 111\n",
      "========================================\n",
      "2 33 None 111\n",
      "2 33 111 112\n",
      "========================================\n",
      "2 34 None 112\n",
      "2 34 112 113\n",
      "========================================\n",
      "2 35 None 113\n",
      "2 35 113 114\n",
      "========================================\n",
      "2 36 None 114\n",
      "2 36 114 115\n",
      "========================================\n",
      "2 37 None 115\n",
      "2 37 115 116\n",
      "========================================\n",
      "2 38 None 116\n",
      "2 38 116 117\n",
      "========================================\n",
      "2 39 None 117\n",
      "2 39 117 118\n",
      "========================================\n",
      "2 40 None 118\n",
      "2 40 118 119\n",
      "========================================\n",
      "2 41 None 119\n",
      "2 41 119 120\n",
      "========================================\n",
      "2 42 None 120\n",
      "2 42 120 121\n",
      "========================================\n",
      "2 43 None 121\n",
      "2 43 121 122\n",
      "========================================\n",
      "2 44 None 122\n",
      "2 44 122 123\n",
      "========================================\n",
      "2 45 None 123\n",
      "2 45 123 124\n",
      "========================================\n",
      "2 46 None 124\n",
      "2 46 124 125\n",
      "========================================\n",
      "2 47 None 125\n",
      "2 47 125 126\n",
      "========================================\n",
      "2 48 None 126\n",
      "2 48 126 127\n",
      "========================================\n",
      "2 49 None 127\n",
      "2 49 127 128\n",
      "========================================\n",
      "3 0 0 128\n",
      "3 1 1 128\n",
      "3 2 2 128\n",
      "3 3 3 128\n",
      "3 4 4 128\n",
      "3 5 6 128\n",
      "3 6 5 128\n",
      "3 7 8 128\n",
      "3 8 7 128\n",
      "3 9 9 128\n",
      "3 10 11 128\n",
      "3 11 12 128\n",
      "3 12 None 128\n",
      "3 12 128 129\n",
      "========================================\n",
      "3 13 92 129\n",
      "3 14 None 129\n",
      "3 14 129 130\n",
      "========================================\n",
      "3 15 None 130\n",
      "3 15 130 131\n",
      "========================================\n",
      "3 16 57 131\n",
      "3 17 None 131\n",
      "3 17 131 132\n",
      "========================================\n",
      "3 18 95 132\n",
      "3 19 None 132\n",
      "3 19 132 133\n",
      "========================================\n",
      "3 20 None 133\n",
      "3 20 133 134\n",
      "========================================\n",
      "3 21 None 134\n",
      "3 21 134 135\n",
      "========================================\n",
      "3 22 None 135\n",
      "3 22 135 136\n",
      "========================================\n",
      "3 23 None 136\n",
      "3 23 136 137\n",
      "========================================\n",
      "3 24 None 137\n",
      "3 24 137 138\n",
      "========================================\n",
      "3 25 None 138\n",
      "3 25 138 139\n",
      "========================================\n",
      "3 26 None 139\n",
      "3 26 139 140\n",
      "========================================\n",
      "3 27 None 140\n",
      "3 27 140 141\n",
      "========================================\n",
      "3 28 None 141\n",
      "3 28 141 142\n",
      "========================================\n",
      "3 29 None 142\n",
      "3 29 142 143\n",
      "========================================\n",
      "3 30 None 143\n",
      "3 30 143 144\n",
      "========================================\n",
      "3 31 None 144\n",
      "3 31 144 145\n",
      "========================================\n",
      "3 32 None 145\n",
      "3 32 145 146\n",
      "========================================\n",
      "3 33 None 146\n",
      "3 33 146 147\n",
      "========================================\n",
      "3 34 None 147\n",
      "3 34 147 148\n",
      "========================================\n",
      "3 35 None 148\n",
      "3 35 148 149\n",
      "========================================\n",
      "3 36 None 149\n",
      "3 36 149 150\n",
      "========================================\n",
      "3 37 None 150\n",
      "3 37 150 151\n",
      "========================================\n",
      "3 38 None 151\n",
      "3 38 151 152\n",
      "========================================\n",
      "3 39 None 152\n",
      "3 39 152 153\n",
      "========================================\n",
      "3 40 None 153\n",
      "3 40 153 154\n",
      "========================================\n",
      "3 41 None 154\n",
      "3 41 154 155\n",
      "========================================\n",
      "3 42 None 155\n",
      "3 42 155 156\n",
      "========================================\n",
      "3 43 None 156\n",
      "3 43 156 157\n",
      "========================================\n",
      "3 44 None 157\n",
      "3 44 157 158\n",
      "========================================\n",
      "3 45 None 158\n",
      "3 45 158 159\n",
      "========================================\n",
      "3 46 None 159\n",
      "3 46 159 160\n",
      "========================================\n",
      "3 47 None 160\n",
      "3 47 160 161\n",
      "========================================\n",
      "3 48 None 161\n",
      "3 48 161 162\n",
      "========================================\n",
      "3 49 None 162\n",
      "3 49 162 163\n",
      "========================================\n",
      "4 0 0 163\n",
      "4 1 2 163\n",
      "4 2 1 163\n",
      "4 3 None 163\n",
      "4 3 163 164\n",
      "========================================\n",
      "4 4 4 164\n",
      "4 5 None 164\n",
      "4 5 164 165\n",
      "========================================\n",
      "4 6 5 165\n",
      "4 7 None 165\n",
      "4 7 165 166\n",
      "========================================\n",
      "4 8 8 166\n",
      "4 9 9 166\n",
      "4 10 11 166\n",
      "4 11 92 166\n",
      "4 12 None 166\n",
      "4 12 166 167\n",
      "========================================\n",
      "4 13 12 167\n",
      "4 14 18 167\n",
      "4 15 58 167\n",
      "4 16 None 167\n",
      "4 16 167 168\n",
      "========================================\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 20 172\n",
      "4 22 99 172\n",
      "4 23 None 172\n",
      "4 23 172 173\n",
      "========================================\n",
      "4 24 None 173\n",
      "4 24 173 174\n",
      "========================================\n",
      "4 25 None 174\n",
      "4 25 174 175\n",
      "========================================\n",
      "4 26 None 175\n",
      "4 26 175 176\n",
      "========================================\n",
      "4 27 None 176\n",
      "4 27 176 177\n",
      "========================================\n",
      "4 28 None 177\n",
      "4 28 177 178\n",
      "========================================\n",
      "4 29 None 178\n",
      "4 29 178 179\n",
      "========================================\n",
      "4 30 None 179\n",
      "4 30 179 180\n",
      "========================================\n",
      "4 31 None 180\n",
      "4 31 180 181\n",
      "========================================\n",
      "4 32 None 181\n",
      "4 32 181 182\n",
      "========================================\n",
      "4 33 None 182\n",
      "4 33 182 183\n",
      "========================================\n",
      "4 34 None 183\n",
      "4 34 183 184\n",
      "========================================\n",
      "4 35 None 184\n",
      "4 35 184 185\n",
      "========================================\n",
      "4 36 None 185\n",
      "4 36 185 186\n",
      "========================================\n",
      "4 37 None 186\n",
      "4 37 186 187\n",
      "========================================\n",
      "4 38 None 187\n",
      "4 38 187 188\n",
      "========================================\n",
      "4 39 None 188\n",
      "4 39 188 189\n",
      "========================================\n",
      "4 40 None 189\n",
      "4 40 189 190\n",
      "========================================\n",
      "4 41 None 190\n",
      "4 41 190 191\n",
      "========================================\n",
      "4 42 None 191\n",
      "4 42 191 192\n",
      "========================================\n",
      "4 43 None 192\n",
      "4 43 192 193\n",
      "========================================\n",
      "4 44 None 193\n",
      "4 44 193 194\n",
      "========================================\n",
      "4 45 None 194\n",
      "4 45 194 195\n",
      "========================================\n",
      "4 46 None 195\n",
      "4 46 195 196\n",
      "========================================\n",
      "4 47 None 196\n",
      "4 47 196 197\n",
      "========================================\n",
      "4 48 196 197\n",
      "4 49 None 197\n",
      "4 49 197 198\n",
      "========================================\n",
      "5 0 1 198\n",
      "5 1 50 198\n",
      "5 2 2 198\n",
      "5 3 2 198\n",
      "5 4 4 198\n",
      "5 5 51 198\n",
      "5 6 5 198\n",
      "5 7 8 198\n",
      "5 8 165 198\n",
      "5 9 52 198\n",
      "5 10 11 198\n",
      "5 11 10 198\n",
      "5 12 13 198\n",
      "5 13 92 198\n",
      "5 14 None 198\n",
      "5 14 198 199\n",
      "========================================\n",
      "5 15 None 199\n",
      "5 15 199 200\n",
      "========================================\n",
      "5 16 170 200\n",
      "5 17 None 200\n",
      "5 17 200 201\n",
      "========================================\n",
      "5 18 19 201\n",
      "5 19 None 201\n",
      "5 19 201 202\n",
      "========================================\n",
      "5 20 None 202\n",
      "5 20 202 203\n",
      "========================================\n",
      "5 21 None 203\n",
      "5 21 203 204\n",
      "========================================\n",
      "5 22 None 204\n",
      "5 22 204 205\n",
      "========================================\n",
      "5 23 None 205\n",
      "5 23 205 206\n",
      "========================================\n",
      "5 24 None 206\n",
      "5 24 206 207\n",
      "========================================\n",
      "5 25 None 207\n",
      "5 25 207 208\n",
      "========================================\n",
      "5 26 None 208\n",
      "5 26 208 209\n",
      "========================================\n",
      "5 27 None 209\n",
      "5 27 209 210\n",
      "========================================\n",
      "5 28 None 210\n",
      "5 28 210 211\n",
      "========================================\n",
      "5 29 None 211\n",
      "5 29 211 212\n",
      "========================================\n",
      "5 30 None 212\n",
      "5 30 212 213\n",
      "========================================\n",
      "5 31 None 213\n",
      "5 31 213 214\n",
      "========================================\n",
      "5 32 None 214\n",
      "5 32 214 215\n",
      "========================================\n",
      "5 33 None 215\n",
      "5 33 215 216\n",
      "========================================\n",
      "5 34 None 216\n",
      "5 34 216 217\n",
      "========================================\n",
      "5 35 None 217\n",
      "5 35 217 218\n",
      "========================================\n",
      "5 36 None 218\n",
      "5 36 218 219\n",
      "========================================\n",
      "5 37 None 219\n",
      "5 37 219 220\n",
      "========================================\n",
      "5 38 None 220\n",
      "5 38 220 221\n",
      "========================================\n",
      "5 39 None 221\n",
      "5 39 221 222\n",
      "========================================\n",
      "5 40 None 222\n",
      "5 40 222 223\n",
      "========================================\n",
      "5 41 None 223\n",
      "5 41 223 224\n",
      "========================================\n",
      "5 42 None 224\n",
      "5 42 224 225\n",
      "========================================\n",
      "5 43 None 225\n",
      "5 43 225 226\n",
      "========================================\n",
      "5 44 None 226\n",
      "5 44 226 227\n",
      "========================================\n",
      "5 45 None 227\n",
      "5 45 227 228\n",
      "========================================\n",
      "5 46 None 228\n",
      "5 46 228 229\n",
      "========================================\n",
      "5 47 None 229\n",
      "5 47 229 230\n",
      "========================================\n",
      "5 48 None 230\n",
      "5 48 230 231\n",
      "========================================\n",
      "5 49 None 231\n",
      "5 49 231 232\n",
      "========================================\n",
      "6 0 0 232\n",
      "6 1 1 232\n",
      "6 2 None 232\n",
      "6 2 232 233\n",
      "========================================\n",
      "6 3 3 233\n",
      "6 4 None 233\n",
      "6 4 233 234\n",
      "========================================\n",
      "6 5 4 234\n",
      "6 6 5 234\n",
      "6 7 8 234\n",
      "6 8 7 234\n",
      "6 9 9 234\n",
      "6 10 10 234\n",
      "6 11 11 234\n",
      "6 12 None 234\n",
      "6 12 234 235\n",
      "========================================\n",
      "6 13 None 235\n",
      "6 13 235 236\n",
      "========================================\n",
      "6 14 None 236\n",
      "6 14 236 237\n",
      "========================================\n",
      "6 15 None 237\n",
      "6 15 237 238\n",
      "========================================\n",
      "6 16 None 238\n",
      "6 16 238 239\n",
      "========================================\n",
      "6 17 None 239\n",
      "6 17 239 240\n",
      "========================================\n",
      "6 18 None 240\n",
      "6 18 240 241\n",
      "========================================\n",
      "6 19 None 241\n",
      "6 19 241 242\n",
      "========================================\n",
      "6 20 None 242\n",
      "6 20 242 243\n",
      "========================================\n",
      "6 21 None 243\n",
      "6 21 243 244\n",
      "========================================\n",
      "6 22 None 244\n",
      "6 22 244 245\n",
      "========================================\n",
      "6 23 None 245\n",
      "6 23 245 246\n",
      "========================================\n",
      "6 24 None 246\n",
      "6 24 246 247\n",
      "========================================\n",
      "6 25 None 247\n",
      "6 25 247 248\n",
      "========================================\n",
      "6 26 None 248\n",
      "6 26 248 249\n",
      "========================================\n",
      "6 27 None 249\n",
      "6 27 249 250\n",
      "========================================\n",
      "6 28 None 250\n",
      "6 28 250 251\n",
      "========================================\n",
      "6 29 None 251\n",
      "6 29 251 252\n",
      "========================================\n",
      "6 30 None 252\n",
      "6 30 252 253\n",
      "========================================\n",
      "6 31 None 253\n",
      "6 31 253 254\n",
      "========================================\n",
      "6 32 None 254\n",
      "6 32 254 255\n",
      "========================================\n",
      "6 33 None 255\n",
      "6 33 255 256\n",
      "========================================\n",
      "6 34 None 256\n",
      "6 34 256 257\n",
      "========================================\n",
      "6 35 None 257\n",
      "6 35 257 258\n",
      "========================================\n",
      "6 36 None 258\n",
      "6 36 258 259\n",
      "========================================\n",
      "6 37 None 259\n",
      "6 37 259 260\n",
      "========================================\n",
      "6 38 None 260\n",
      "6 38 260 261\n",
      "========================================\n",
      "6 39 None 261\n",
      "6 39 261 262\n",
      "========================================\n",
      "6 40 None 262\n",
      "6 40 262 263\n",
      "========================================\n",
      "6 41 None 263\n",
      "6 41 263 264\n",
      "========================================\n",
      "6 42 None 264\n",
      "6 42 264 265\n",
      "========================================\n",
      "6 43 None 265\n",
      "6 43 265 266\n",
      "========================================\n",
      "6 44 None 266\n",
      "6 44 266 267\n",
      "========================================\n",
      "6 45 None 267\n",
      "6 45 267 268\n",
      "========================================\n",
      "6 46 None 268\n",
      "6 46 268 269\n",
      "========================================\n",
      "6 47 None 269\n",
      "6 47 269 270\n",
      "========================================\n",
      "6 48 None 270\n",
      "6 48 270 271\n",
      "========================================\n",
      "6 49 None 271\n",
      "6 49 271 272\n",
      "========================================\n",
      "7 0 50 272\n",
      "7 1 None 272\n",
      "7 1 272 273\n",
      "========================================\n",
      "7 2 2 273\n",
      "7 3 3 273\n",
      "7 4 4 273\n",
      "7 5 5 273\n",
      "7 6 5 273\n",
      "7 7 8 273\n",
      "7 8 7 273\n",
      "7 9 9 273\n",
      "7 10 None 273\n",
      "7 10 273 274\n",
      "========================================\n",
      "7 11 11 274\n",
      "7 12 93 274\n",
      "7 13 None 274\n",
      "7 13 274 275\n",
      "========================================\n",
      "7 14 198 275\n",
      "7 15 None 275\n",
      "7 15 275 276\n",
      "========================================\n",
      "7 16 95 276\n",
      "7 17 None 276\n",
      "7 17 276 277\n",
      "========================================\n",
      "7 18 None 277\n",
      "7 18 277 278\n",
      "========================================\n",
      "7 19 None 278\n",
      "7 19 278 279\n",
      "========================================\n",
      "7 20 None 279\n",
      "7 20 279 280\n",
      "========================================\n",
      "7 21 None 280\n",
      "7 21 280 281\n",
      "========================================\n",
      "7 22 None 281\n",
      "7 22 281 282\n",
      "========================================\n",
      "7 23 None 282\n",
      "7 23 282 283\n",
      "========================================\n",
      "7 24 None 283\n",
      "7 24 283 284\n",
      "========================================\n",
      "7 25 None 284\n",
      "7 25 284 285\n",
      "========================================\n",
      "7 26 None 285\n",
      "7 26 285 286\n",
      "========================================\n",
      "7 27 None 286\n",
      "7 27 286 287\n",
      "========================================\n",
      "7 28 None 287\n",
      "7 28 287 288\n",
      "========================================\n",
      "7 29 None 288\n",
      "7 29 288 289\n",
      "========================================\n",
      "7 30 None 289\n",
      "7 30 289 290\n",
      "========================================\n",
      "7 31 None 290\n",
      "7 31 290 291\n",
      "========================================\n",
      "7 32 None 291\n",
      "7 32 291 292\n",
      "========================================\n",
      "7 33 None 292\n",
      "7 33 292 293\n",
      "========================================\n",
      "7 34 None 293\n",
      "7 34 293 294\n",
      "========================================\n",
      "7 35 None 294\n",
      "7 35 294 295\n",
      "========================================\n",
      "7 36 None 295\n",
      "7 36 295 296\n",
      "========================================\n",
      "7 37 None 296\n",
      "7 37 296 297\n",
      "========================================\n",
      "7 38 None 297\n",
      "7 38 297 298\n",
      "========================================\n",
      "7 39 None 298\n",
      "7 39 298 299\n",
      "========================================\n",
      "7 40 None 299\n",
      "7 40 299 300\n",
      "========================================\n",
      "7 41 None 300\n",
      "7 41 300 301\n",
      "========================================\n",
      "7 42 None 301\n",
      "7 42 301 302\n",
      "========================================\n",
      "7 43 None 302\n",
      "7 43 302 303\n",
      "========================================\n",
      "7 44 None 303\n",
      "7 44 303 304\n",
      "========================================\n",
      "7 45 None 304\n",
      "7 45 304 305\n",
      "========================================\n",
      "7 46 None 305\n",
      "7 46 305 306\n",
      "========================================\n",
      "7 47 None 306\n",
      "7 47 306 307\n",
      "========================================\n",
      "7 48 None 307\n",
      "7 48 307 308\n",
      "========================================\n",
      "7 49 None 308\n",
      "7 49 308 309\n",
      "========================================\n",
      "8 0 272 309\n",
      "8 1 0 309\n",
      "8 2 2 309\n",
      "8 3 3 309\n",
      "8 4 6 309\n",
      "8 5 5 309\n",
      "8 6 4 309\n",
      "8 7 5 309\n",
      "8 8 None 309\n",
      "8 8 309 310\n",
      "========================================\n",
      "8 9 9 310\n",
      "8 10 11 310\n",
      "8 11 None 310\n",
      "8 11 310 311\n",
      "========================================\n",
      "8 12 166 311\n",
      "8 13 92 311\n",
      "8 14 None 311\n",
      "8 14 311 312\n",
      "========================================\n",
      "8 15 58 312\n",
      "8 16 None 312\n",
      "8 16 312 313\n",
      "========================================\n",
      "8 17 None 313\n",
      "8 17 313 314\n",
      "========================================\n",
      "8 18 198 314\n",
      "8 19 None 314\n",
      "8 19 314 315\n",
      "========================================\n",
      "8 20 None 315\n",
      "8 20 315 316\n",
      "========================================\n",
      "8 21 None 316\n",
      "8 21 316 317\n",
      "========================================\n",
      "8 22 None 317\n",
      "8 22 317 318\n",
      "========================================\n",
      "8 23 None 318\n",
      "8 23 318 319\n",
      "========================================\n",
      "8 24 None 319\n",
      "8 24 319 320\n",
      "========================================\n",
      "8 25 None 320\n",
      "8 25 320 321\n",
      "========================================\n",
      "8 26 None 321\n",
      "8 26 321 322\n",
      "========================================\n",
      "8 27 None 322\n",
      "8 27 322 323\n",
      "========================================\n",
      "8 28 None 323\n",
      "8 28 323 324\n",
      "========================================\n",
      "8 29 None 324\n",
      "8 29 324 325\n",
      "========================================\n",
      "8 30 None 325\n",
      "8 30 325 326\n",
      "========================================\n",
      "8 31 None 326\n",
      "8 31 326 327\n",
      "========================================\n",
      "8 32 None 327\n",
      "8 32 327 328\n",
      "========================================\n",
      "8 33 None 328\n",
      "8 33 328 329\n",
      "========================================\n",
      "8 34 None 329\n",
      "8 34 329 330\n",
      "========================================\n",
      "8 35 None 330\n",
      "8 35 330 331\n",
      "========================================\n",
      "8 36 None 331\n",
      "8 36 331 332\n",
      "========================================\n",
      "8 37 None 332\n",
      "8 37 332 333\n",
      "========================================\n",
      "8 38 None 333\n",
      "8 38 333 334\n",
      "========================================\n",
      "8 39 None 334\n",
      "8 39 334 335\n",
      "========================================\n",
      "8 40 None 335\n",
      "8 40 335 336\n",
      "========================================\n",
      "8 41 None 336\n",
      "8 41 336 337\n",
      "========================================\n",
      "8 42 None 337\n",
      "8 42 337 338\n",
      "========================================\n",
      "8 43 None 338\n",
      "8 43 338 339\n",
      "========================================\n",
      "8 44 None 339\n",
      "8 44 339 340\n",
      "========================================\n",
      "8 45 None 340\n",
      "8 45 340 341\n",
      "========================================\n",
      "8 46 None 341\n",
      "8 46 341 342\n",
      "========================================\n",
      "8 47 None 342\n",
      "8 47 342 343\n",
      "========================================\n",
      "8 48 None 343\n",
      "8 48 343 344\n",
      "========================================\n",
      "8 49 None 344\n",
      "8 49 344 345\n",
      "========================================\n",
      "9 0 272 345\n",
      "9 1 1 345\n",
      "9 2 2 345\n",
      "9 3 3 345\n",
      "9 4 4 345\n",
      "9 5 6 345\n",
      "9 6 5 345\n",
      "9 7 8 345\n",
      "9 8 165 345\n",
      "9 9 310 345\n",
      "9 10 52 345\n",
      "9 11 234 345\n",
      "9 12 92 345\n",
      "9 13 54 345\n",
      "9 14 170 345\n",
      "9 15 57 345\n",
      "9 16 None 345\n",
      "9 16 345 346\n",
      "========================================\n",
      "9 17 171 346\n",
      "9 18 None 346\n",
      "9 18 346 347\n",
      "========================================\n",
      "9 19 None 347\n",
      "9 19 347 348\n",
      "========================================\n",
      "9 20 19 348\n",
      "9 21 None 348\n",
      "9 21 348 349\n",
      "========================================\n",
      "9 22 None 349\n",
      "9 22 349 350\n",
      "========================================\n",
      "9 23 None 350\n",
      "9 23 350 351\n",
      "========================================\n",
      "9 24 None 351\n",
      "9 24 351 352\n",
      "========================================\n",
      "9 25 None 352\n",
      "9 25 352 353\n",
      "========================================\n",
      "9 26 None 353\n",
      "9 26 353 354\n",
      "========================================\n",
      "9 27 None 354\n",
      "9 27 354 355\n",
      "========================================\n",
      "9 28 None 355\n",
      "9 28 355 356\n",
      "========================================\n",
      "9 29 None 356\n",
      "9 29 356 357\n",
      "========================================\n",
      "9 30 None 357\n",
      "9 30 357 358\n",
      "========================================\n",
      "9 31 None 358\n",
      "9 31 358 359\n",
      "========================================\n",
      "9 32 None 359\n",
      "9 32 359 360\n",
      "========================================\n",
      "9 33 None 360\n",
      "9 33 360 361\n",
      "========================================\n",
      "9 34 None 361\n",
      "9 34 361 362\n",
      "========================================\n",
      "9 35 None 362\n",
      "9 35 362 363\n",
      "========================================\n",
      "9 36 None 363\n",
      "9 36 363 364\n",
      "========================================\n",
      "9 37 None 364\n",
      "9 37 364 365\n",
      "========================================\n",
      "9 38 None 365\n",
      "9 38 365 366\n",
      "========================================\n",
      "9 39 None 366\n",
      "9 39 366 367\n",
      "========================================\n",
      "9 40 None 367\n",
      "9 40 367 368\n",
      "========================================\n",
      "9 41 None 368\n",
      "9 41 368 369\n",
      "========================================\n",
      "9 42 None 369\n",
      "9 42 369 370\n",
      "========================================\n",
      "9 43 None 370\n",
      "9 43 370 371\n",
      "========================================\n",
      "9 44 None 371\n",
      "9 44 371 372\n",
      "========================================\n",
      "9 45 None 372\n",
      "9 45 372 373\n",
      "========================================\n",
      "9 46 None 373\n",
      "9 46 373 374\n",
      "========================================\n",
      "9 47 None 374\n",
      "9 47 374 375\n",
      "========================================\n",
      "9 48 None 375\n",
      "9 48 375 376\n",
      "========================================\n",
      "9 49 None 376\n",
      "9 49 376 377\n",
      "========================================\n",
      "10 0 0 377\n",
      "10 1 272 377\n",
      "10 2 2 377\n",
      "10 3 164 377\n",
      "10 4 4 377\n",
      "10 5 233 377\n",
      "10 6 6 377\n",
      "10 7 8 377\n",
      "10 8 7 377\n",
      "10 9 None 377\n",
      "10 9 377 378\n",
      "========================================\n",
      "10 10 None 378\n",
      "10 10 378 379\n",
      "========================================\n",
      "10 11 91 379\n",
      "10 12 11 379\n",
      "10 13 None 379\n",
      "10 13 379 380\n",
      "========================================\n",
      "10 14 None 380\n",
      "10 14 380 381\n",
      "========================================\n",
      "10 15 None 381\n",
      "10 15 381 382\n",
      "========================================\n",
      "10 16 None 382\n",
      "10 16 382 383\n",
      "========================================\n",
      "10 17 None 383\n",
      "10 17 383 384\n",
      "========================================\n",
      "10 18 None 384\n",
      "10 18 384 385\n",
      "========================================\n",
      "10 19 None 385\n",
      "10 19 385 386\n",
      "========================================\n",
      "10 20 None 386\n",
      "10 20 386 387\n",
      "========================================\n",
      "10 21 None 387\n",
      "10 21 387 388\n",
      "========================================\n",
      "10 22 None 388\n",
      "10 22 388 389\n",
      "========================================\n",
      "10 23 None 389\n",
      "10 23 389 390\n",
      "========================================\n",
      "10 24 None 390\n",
      "10 24 390 391\n",
      "========================================\n",
      "10 25 None 391\n",
      "10 25 391 392\n",
      "========================================\n",
      "10 26 None 392\n",
      "10 26 392 393\n",
      "========================================\n",
      "10 27 None 393\n",
      "10 27 393 394\n",
      "========================================\n",
      "10 28 None 394\n",
      "10 28 394 395\n",
      "========================================\n",
      "10 29 None 395\n",
      "10 29 395 396\n",
      "========================================\n",
      "10 30 None 396\n",
      "10 30 396 397\n",
      "========================================\n",
      "10 31 None 397\n",
      "10 31 397 398\n",
      "========================================\n",
      "10 32 None 398\n",
      "10 32 398 399\n",
      "========================================\n",
      "10 33 None 399\n",
      "10 33 399 400\n",
      "========================================\n",
      "10 34 None 400\n",
      "10 34 400 401\n",
      "========================================\n",
      "10 35 None 401\n",
      "10 35 401 402\n",
      "========================================\n",
      "10 36 None 402\n",
      "10 36 402 403\n",
      "========================================\n",
      "10 37 None 403\n",
      "10 37 403 404\n",
      "========================================\n",
      "10 38 None 404\n",
      "10 38 404 405\n",
      "========================================\n",
      "10 39 None 405\n",
      "10 39 405 406\n",
      "========================================\n",
      "10 40 None 406\n",
      "10 40 406 407\n",
      "========================================\n",
      "10 41 None 407\n",
      "10 41 407 408\n",
      "========================================\n",
      "10 42 None 408\n",
      "10 42 408 409\n",
      "========================================\n",
      "10 43 None 409\n",
      "10 43 409 410\n",
      "========================================\n",
      "10 44 None 410\n",
      "10 44 410 411\n",
      "========================================\n",
      "10 45 None 411\n",
      "10 45 411 412\n",
      "========================================\n",
      "10 46 None 412\n",
      "10 46 412 413\n",
      "========================================\n",
      "10 47 None 413\n",
      "10 47 413 414\n",
      "========================================\n",
      "10 48 None 414\n",
      "10 48 414 415\n",
      "========================================\n",
      "10 49 None 415\n",
      "10 49 415 416\n",
      "========================================\n",
      "11 0 0 416\n",
      "11 1 1 416\n",
      "11 2 2 416\n",
      "11 3 None 416\n",
      "11 3 416 417\n",
      "========================================\n",
      "11 4 3 417\n",
      "11 5 233 417\n",
      "11 6 5 417\n",
      "11 7 8 417\n",
      "11 8 7 417\n",
      "11 9 9 417\n",
      "11 10 380 417\n",
      "11 11 10 417\n",
      "11 12 None 417\n",
      "11 12 417 418\n",
      "========================================\n",
      "11 13 53 418\n",
      "11 14 311 418\n",
      "11 15 None 418\n",
      "11 15 418 419\n",
      "========================================\n",
      "11 16 59 419\n",
      "11 17 None 419\n",
      "11 17 419 420\n",
      "========================================\n",
      "11 18 14 420\n",
      "11 19 None 420\n",
      "11 19 420 421\n",
      "========================================\n",
      "11 20 None 421\n",
      "11 20 421 422\n",
      "========================================\n",
      "11 21 None 422\n",
      "11 21 422 423\n",
      "========================================\n",
      "11 22 None 423\n",
      "11 22 423 424\n",
      "========================================\n",
      "11 23 None 424\n",
      "11 23 424 425\n",
      "========================================\n",
      "11 24 None 425\n",
      "11 24 425 426\n",
      "========================================\n",
      "11 25 None 426\n",
      "11 25 426 427\n",
      "========================================\n",
      "11 26 None 427\n",
      "11 26 427 428\n",
      "========================================\n",
      "11 27 None 428\n",
      "11 27 428 429\n",
      "========================================\n",
      "11 28 None 429\n",
      "11 28 429 430\n",
      "========================================\n",
      "11 29 None 430\n",
      "11 29 430 431\n",
      "========================================\n",
      "11 30 None 431\n",
      "11 30 431 432\n",
      "========================================\n",
      "11 31 None 432\n",
      "11 31 432 433\n",
      "========================================\n",
      "11 32 None 433\n",
      "11 32 433 434\n",
      "========================================\n",
      "11 33 None 434\n",
      "11 33 434 435\n",
      "========================================\n",
      "11 34 None 435\n",
      "11 34 435 436\n",
      "========================================\n",
      "11 35 None 436\n",
      "11 35 436 437\n",
      "========================================\n",
      "11 36 None 437\n",
      "11 36 437 438\n",
      "========================================\n",
      "11 37 None 438\n",
      "11 37 438 439\n",
      "========================================\n",
      "11 38 None 439\n",
      "11 38 439 440\n",
      "========================================\n",
      "11 39 None 440\n",
      "11 39 440 441\n",
      "========================================\n",
      "11 40 None 441\n",
      "11 40 441 442\n",
      "========================================\n",
      "11 41 None 442\n",
      "11 41 442 443\n",
      "========================================\n",
      "11 42 None 443\n",
      "11 42 443 444\n",
      "========================================\n",
      "11 43 None 444\n",
      "11 43 444 445\n",
      "========================================\n",
      "11 44 None 445\n",
      "11 44 445 446\n",
      "========================================\n",
      "11 45 None 446\n",
      "11 45 446 447\n",
      "========================================\n",
      "11 46 None 447\n",
      "11 46 447 448\n",
      "========================================\n",
      "11 47 None 448\n",
      "11 47 448 449\n",
      "========================================\n",
      "11 48 None 449\n",
      "11 48 449 450\n",
      "========================================\n",
      "11 49 None 450\n",
      "11 49 450 451\n",
      "========================================\n",
      "12 0 1 451\n",
      "12 1 2 451\n",
      "12 2 233 451\n",
      "12 3 232 451\n",
      "12 4 3 451\n",
      "12 5 51 451\n",
      "12 6 5 451\n",
      "12 7 165 451\n",
      "12 8 8 451\n",
      "12 9 378 451\n",
      "12 10 11 451\n",
      "12 11 12 451\n",
      "12 12 None 451\n",
      "12 12 451 452\n",
      "========================================\n",
      "12 13 13 452\n",
      "12 14 92 452\n",
      "12 15 None 452\n",
      "12 15 452 453\n",
      "========================================\n",
      "12 16 382 453\n",
      "12 17 None 453\n",
      "12 17 453 454\n",
      "========================================\n",
      "12 18 None 454\n",
      "12 18 454 455\n",
      "========================================\n",
      "12 19 None 455\n",
      "12 19 455 456\n",
      "========================================\n",
      "12 20 None 456\n",
      "12 20 456 457\n",
      "========================================\n",
      "12 21 None 457\n",
      "12 21 457 458\n",
      "========================================\n",
      "12 22 None 458\n",
      "12 22 458 459\n",
      "========================================\n",
      "12 23 None 459\n",
      "12 23 459 460\n",
      "========================================\n",
      "12 24 None 460\n",
      "12 24 460 461\n",
      "========================================\n",
      "12 25 None 461\n",
      "12 25 461 462\n",
      "========================================\n",
      "12 26 None 462\n",
      "12 26 462 463\n",
      "========================================\n",
      "12 27 None 463\n",
      "12 27 463 464\n",
      "========================================\n",
      "12 28 None 464\n",
      "12 28 464 465\n",
      "========================================\n",
      "12 29 None 465\n",
      "12 29 465 466\n",
      "========================================\n",
      "12 30 None 466\n",
      "12 30 466 467\n",
      "========================================\n",
      "12 31 None 467\n",
      "12 31 467 468\n",
      "========================================\n",
      "12 32 None 468\n",
      "12 32 468 469\n",
      "========================================\n",
      "12 33 None 469\n",
      "12 33 469 470\n",
      "========================================\n",
      "12 34 None 470\n",
      "12 34 470 471\n",
      "========================================\n",
      "12 35 None 471\n",
      "12 35 471 472\n",
      "========================================\n",
      "12 36 None 472\n",
      "12 36 472 473\n",
      "========================================\n",
      "12 37 None 473\n",
      "12 37 473 474\n",
      "========================================\n",
      "12 38 None 474\n",
      "12 38 474 475\n",
      "========================================\n",
      "12 39 None 475\n",
      "12 39 475 476\n",
      "========================================\n",
      "12 40 None 476\n",
      "12 40 476 477\n",
      "========================================\n",
      "12 41 None 477\n",
      "12 41 477 478\n",
      "========================================\n",
      "12 42 None 478\n",
      "12 42 478 479\n",
      "========================================\n",
      "12 43 None 479\n",
      "12 43 479 480\n",
      "========================================\n",
      "12 44 None 480\n",
      "12 44 480 481\n",
      "========================================\n",
      "12 45 None 481\n",
      "12 45 481 482\n",
      "========================================\n",
      "12 46 None 482\n",
      "12 46 482 483\n",
      "========================================\n",
      "12 47 None 483\n",
      "12 47 483 484\n",
      "========================================\n",
      "12 48 None 484\n",
      "12 48 484 485\n",
      "========================================\n",
      "12 49 None 485\n",
      "12 49 485 486\n",
      "========================================\n",
      "13 0 0 486\n",
      "13 1 1 486\n",
      "13 2 2 486\n",
      "13 3 3 486\n",
      "13 4 51 486\n",
      "13 5 6 486\n",
      "13 6 None 486\n",
      "13 6 486 487\n",
      "========================================\n",
      "13 7 309 487\n",
      "13 8 7 487\n",
      "13 9 273 487\n",
      "13 10 10 487\n",
      "13 11 91 487\n",
      "13 12 12 487\n",
      "13 13 93 487\n",
      "13 14 94 487\n",
      "13 15 56 487\n",
      "13 16 None 487\n",
      "13 16 487 488\n",
      "========================================\n",
      "13 17 383 488\n",
      "13 18 None 488\n",
      "13 18 488 489\n",
      "========================================\n",
      "13 19 None 489\n",
      "13 19 489 490\n",
      "========================================\n",
      "13 20 None 490\n",
      "13 20 490 491\n",
      "========================================\n",
      "13 21 None 491\n",
      "13 21 491 492\n",
      "========================================\n",
      "13 22 None 492\n",
      "13 22 492 493\n",
      "========================================\n",
      "13 23 None 493\n",
      "13 23 493 494\n",
      "========================================\n",
      "13 24 None 494\n",
      "13 24 494 495\n",
      "========================================\n",
      "13 25 None 495\n",
      "13 25 495 496\n",
      "========================================\n",
      "13 26 None 496\n",
      "13 26 496 497\n",
      "========================================\n",
      "13 27 None 497\n",
      "13 27 497 498\n",
      "========================================\n",
      "13 28 None 498\n",
      "13 28 498 499\n",
      "========================================\n",
      "13 29 None 499\n",
      "13 29 499 500\n",
      "========================================\n",
      "13 30 None 500\n",
      "13 30 500 501\n",
      "========================================\n",
      "13 31 None 501\n",
      "13 31 501 502\n",
      "========================================\n",
      "13 32 None 502\n",
      "13 32 502 503\n",
      "========================================\n",
      "13 33 None 503\n",
      "13 33 503 504\n",
      "========================================\n",
      "13 34 None 504\n",
      "13 34 504 505\n",
      "========================================\n",
      "13 35 None 505\n",
      "13 35 505 506\n",
      "========================================\n",
      "13 36 None 506\n",
      "13 36 506 507\n",
      "========================================\n",
      "13 37 None 507\n",
      "13 37 507 508\n",
      "========================================\n",
      "13 38 None 508\n",
      "13 38 508 509\n",
      "========================================\n",
      "13 39 None 509\n",
      "13 39 509 510\n",
      "========================================\n",
      "13 40 None 510\n",
      "13 40 510 511\n",
      "========================================\n",
      "13 41 None 511\n",
      "13 41 511 512\n",
      "========================================\n",
      "13 42 None 512\n",
      "13 42 512 513\n",
      "========================================\n",
      "13 43 None 513\n",
      "13 43 513 514\n",
      "========================================\n",
      "13 44 None 514\n",
      "13 44 514 515\n",
      "========================================\n",
      "13 45 None 515\n",
      "13 45 515 516\n",
      "========================================\n",
      "13 46 None 516\n",
      "13 46 516 517\n",
      "========================================\n",
      "13 47 None 517\n",
      "13 47 517 518\n",
      "========================================\n",
      "13 48 None 518\n",
      "13 48 518 519\n",
      "========================================\n",
      "13 49 None 519\n",
      "13 49 519 520\n",
      "========================================\n",
      "14 0 0 520\n",
      "14 1 1 520\n",
      "14 2 2 520\n",
      "14 3 3 520\n",
      "14 4 4 520\n",
      "14 5 5 520\n",
      "14 6 486 520\n",
      "14 7 8 520\n",
      "14 8 7 520\n",
      "14 9 9 520\n",
      "14 10 91 520\n",
      "14 11 11 520\n",
      "14 12 10 520\n",
      "14 13 53 520\n",
      "14 14 383 520\n",
      "14 15 16 520\n",
      "14 16 56 520\n",
      "14 17 456 520\n",
      "14 18 None 520\n",
      "14 18 520 521\n",
      "========================================\n",
      "14 19 491 521\n",
      "14 20 None 521\n",
      "14 20 521 522\n",
      "========================================\n",
      "14 21 None 522\n",
      "14 21 522 523\n",
      "========================================\n",
      "14 22 None 523\n",
      "14 22 523 524\n",
      "========================================\n",
      "14 23 None 524\n",
      "14 23 524 525\n",
      "========================================\n",
      "14 24 None 525\n",
      "14 24 525 526\n",
      "========================================\n",
      "14 25 None 526\n",
      "14 25 526 527\n",
      "========================================\n",
      "14 26 None 527\n",
      "14 26 527 528\n",
      "========================================\n",
      "14 27 None 528\n",
      "14 27 528 529\n",
      "========================================\n",
      "14 28 None 529\n",
      "14 28 529 530\n",
      "========================================\n",
      "14 29 None 530\n",
      "14 29 530 531\n",
      "========================================\n",
      "14 30 None 531\n",
      "14 30 531 532\n",
      "========================================\n",
      "14 31 None 532\n",
      "14 31 532 533\n",
      "========================================\n",
      "14 32 None 533\n",
      "14 32 533 534\n",
      "========================================\n",
      "14 33 None 534\n",
      "14 33 534 535\n",
      "========================================\n",
      "14 34 None 535\n",
      "14 34 535 536\n",
      "========================================\n",
      "14 35 None 536\n",
      "14 35 536 537\n",
      "========================================\n",
      "14 36 None 537\n",
      "14 36 537 538\n",
      "========================================\n",
      "14 37 None 538\n",
      "14 37 538 539\n",
      "========================================\n",
      "14 38 None 539\n",
      "14 38 539 540\n",
      "========================================\n",
      "14 39 None 540\n",
      "14 39 540 541\n",
      "========================================\n",
      "14 40 None 541\n",
      "14 40 541 542\n",
      "========================================\n",
      "14 41 None 542\n",
      "14 41 542 543\n",
      "========================================\n",
      "14 42 None 543\n",
      "14 42 543 544\n",
      "========================================\n",
      "14 43 None 544\n",
      "14 43 544 545\n",
      "========================================\n",
      "14 44 None 545\n",
      "14 44 545 546\n",
      "========================================\n",
      "14 45 None 546\n",
      "14 45 546 547\n",
      "========================================\n",
      "14 46 None 547\n",
      "14 46 547 548\n",
      "========================================\n",
      "14 47 None 548\n",
      "14 47 548 549\n",
      "========================================\n",
      "14 48 None 549\n",
      "14 48 549 550\n",
      "========================================\n",
      "14 49 None 550\n",
      "14 49 550 551\n",
      "========================================\n",
      "15 0 272 551\n",
      "15 1 50 551\n",
      "15 2 2 551\n",
      "15 3 3 551\n",
      "15 4 4 551\n",
      "15 5 5 551\n",
      "15 6 6 551\n",
      "15 7 8 551\n",
      "15 8 165 551\n",
      "15 9 11 551\n",
      "15 10 9 551\n",
      "15 11 12 551\n",
      "15 12 379 551\n",
      "15 13 None 551\n",
      "15 13 551 552\n",
      "========================================\n",
      "15 14 None 552\n",
      "15 14 552 553\n",
      "========================================\n",
      "15 15 57 553\n",
      "15 16 278 553\n",
      "15 17 None 553\n",
      "15 17 553 554\n",
      "========================================\n",
      "15 18 454 554\n",
      "15 19 None 554\n",
      "15 19 554 555\n",
      "========================================\n",
      "15 20 None 555\n",
      "15 20 555 556\n",
      "========================================\n",
      "15 21 None 556\n",
      "15 21 556 557\n",
      "========================================\n",
      "15 22 None 557\n",
      "15 22 557 558\n",
      "========================================\n",
      "15 23 None 558\n",
      "15 23 558 559\n",
      "========================================\n",
      "15 24 None 559\n",
      "15 24 559 560\n",
      "========================================\n",
      "15 25 None 560\n",
      "15 25 560 561\n",
      "========================================\n",
      "15 26 351 561\n",
      "15 27 None 561\n",
      "15 27 561 562\n",
      "========================================\n",
      "15 28 None 562\n",
      "15 28 562 563\n",
      "========================================\n",
      "15 29 None 563\n",
      "15 29 563 564\n",
      "========================================\n",
      "15 30 None 564\n",
      "15 30 564 565\n",
      "========================================\n",
      "15 31 None 565\n",
      "15 31 565 566\n",
      "========================================\n",
      "15 32 None 566\n",
      "15 32 566 567\n",
      "========================================\n",
      "15 33 None 567\n",
      "15 33 567 568\n",
      "========================================\n",
      "15 34 None 568\n",
      "15 34 568 569\n",
      "========================================\n",
      "15 35 None 569\n",
      "15 35 569 570\n",
      "========================================\n",
      "15 36 None 570\n",
      "15 36 570 571\n",
      "========================================\n",
      "15 37 None 571\n",
      "15 37 571 572\n",
      "========================================\n",
      "15 38 None 572\n",
      "15 38 572 573\n",
      "========================================\n",
      "15 39 None 573\n",
      "15 39 573 574\n",
      "========================================\n",
      "15 40 None 574\n",
      "15 40 574 575\n",
      "========================================\n",
      "15 41 None 575\n",
      "15 41 575 576\n",
      "========================================\n",
      "15 42 None 576\n",
      "15 42 576 577\n",
      "========================================\n",
      "15 43 None 577\n",
      "15 43 577 578\n",
      "========================================\n",
      "15 44 None 578\n",
      "15 44 578 579\n",
      "========================================\n",
      "15 45 None 579\n",
      "15 45 579 580\n",
      "========================================\n",
      "15 46 None 580\n",
      "15 46 580 581\n",
      "========================================\n",
      "15 47 None 581\n",
      "15 47 581 582\n",
      "========================================\n",
      "15 48 None 582\n",
      "15 48 582 583\n",
      "========================================\n",
      "15 49 None 583\n",
      "15 49 583 584\n",
      "========================================\n",
      "16 0 50 584\n",
      "16 1 0 584\n",
      "16 2 1 584\n",
      "16 3 416 584\n",
      "16 4 4 584\n",
      "16 5 3 584\n",
      "16 6 5 584\n",
      "16 7 8 584\n",
      "16 8 7 584\n",
      "16 9 None 584\n",
      "16 9 584 585\n",
      "========================================\n",
      "16 10 11 585\n",
      "16 11 273 585\n",
      "16 12 417 585\n",
      "16 13 166 585\n",
      "16 14 57 585\n",
      "16 15 None 585\n",
      "16 15 585 586\n",
      "========================================\n",
      "16 16 None 586\n",
      "16 16 586 587\n",
      "========================================\n",
      "16 17 58 587\n",
      "16 18 56 587\n",
      "16 19 None 587\n",
      "16 19 587 588\n",
      "========================================\n",
      "16 20 None 588\n",
      "16 20 588 589\n",
      "========================================\n",
      "16 21 None 589\n",
      "16 21 589 590\n",
      "========================================\n",
      "16 22 None 590\n",
      "16 22 590 591\n",
      "========================================\n",
      "16 23 101 591\n",
      "16 24 None 591\n",
      "16 24 591 592\n",
      "========================================\n",
      "16 25 None 592\n",
      "16 25 592 593\n",
      "========================================\n",
      "16 26 None 593\n",
      "16 26 593 594\n",
      "========================================\n",
      "16 27 None 594\n",
      "16 27 594 595\n",
      "========================================\n",
      "16 28 None 595\n",
      "16 28 595 596\n",
      "========================================\n",
      "16 29 None 596\n",
      "16 29 596 597\n",
      "========================================\n",
      "16 30 None 597\n",
      "16 30 597 598\n",
      "========================================\n",
      "16 31 None 598\n",
      "16 31 598 599\n",
      "========================================\n",
      "16 32 None 599\n",
      "16 32 599 600\n",
      "========================================\n",
      "16 33 None 600\n",
      "16 33 600 601\n",
      "========================================\n",
      "16 34 None 601\n",
      "16 34 601 602\n",
      "========================================\n",
      "16 35 None 602\n",
      "16 35 602 603\n",
      "========================================\n",
      "16 36 None 603\n",
      "16 36 603 604\n",
      "========================================\n",
      "16 37 None 604\n",
      "16 37 604 605\n",
      "========================================\n",
      "16 38 None 605\n",
      "16 38 605 606\n",
      "========================================\n",
      "16 39 None 606\n",
      "16 39 606 607\n",
      "========================================\n",
      "16 40 None 607\n",
      "16 40 607 608\n",
      "========================================\n",
      "16 41 None 608\n",
      "16 41 608 609\n",
      "========================================\n",
      "16 42 None 609\n",
      "16 42 609 610\n",
      "========================================\n",
      "16 43 None 610\n",
      "16 43 610 611\n",
      "========================================\n",
      "16 44 None 611\n",
      "16 44 611 612\n",
      "========================================\n",
      "16 45 None 612\n",
      "16 45 612 613\n",
      "========================================\n",
      "16 46 None 613\n",
      "16 46 613 614\n",
      "========================================\n",
      "16 47 None 614\n",
      "16 47 614 615\n",
      "========================================\n",
      "16 48 None 615\n",
      "16 48 615 616\n",
      "========================================\n",
      "16 49 615 616\n",
      "17 0 272 616\n",
      "17 1 1 616\n",
      "17 2 2 616\n",
      "17 3 164 616\n",
      "17 4 486 616\n",
      "17 5 51 616\n",
      "17 6 5 616\n",
      "17 7 309 616\n",
      "17 8 8 616\n",
      "17 9 417 616\n",
      "17 10 9 616\n",
      "17 11 None 616\n",
      "17 11 616 617\n",
      "========================================\n",
      "17 12 166 617\n",
      "17 13 92 617\n",
      "17 14 380 617\n",
      "17 15 None 617\n",
      "17 15 617 618\n",
      "========================================\n",
      "17 16 None 618\n",
      "17 16 618 619\n",
      "========================================\n",
      "17 17 None 619\n",
      "17 17 619 620\n",
      "========================================\n",
      "17 18 98 620\n",
      "17 19 None 620\n",
      "17 19 620 621\n",
      "========================================\n",
      "17 20 None 621\n",
      "17 20 621 622\n",
      "========================================\n",
      "17 21 None 622\n",
      "17 21 622 623\n",
      "========================================\n",
      "17 22 None 623\n",
      "17 22 623 624\n",
      "========================================\n",
      "17 23 None 624\n",
      "17 23 624 625\n",
      "========================================\n",
      "17 24 None 625\n",
      "17 24 625 626\n",
      "========================================\n",
      "17 25 None 626\n",
      "17 25 626 627\n",
      "========================================\n",
      "17 26 None 627\n",
      "17 26 627 628\n",
      "========================================\n",
      "17 27 None 628\n",
      "17 27 628 629\n",
      "========================================\n",
      "17 28 None 629\n",
      "17 28 629 630\n",
      "========================================\n",
      "17 29 None 630\n",
      "17 29 630 631\n",
      "========================================\n",
      "17 30 None 631\n",
      "17 30 631 632\n",
      "========================================\n",
      "17 31 None 632\n",
      "17 31 632 633\n",
      "========================================\n",
      "17 32 None 633\n",
      "17 32 633 634\n",
      "========================================\n",
      "17 33 None 634\n",
      "17 33 634 635\n",
      "========================================\n",
      "17 34 None 635\n",
      "17 34 635 636\n",
      "========================================\n",
      "17 35 None 636\n",
      "17 35 636 637\n",
      "========================================\n",
      "17 36 None 637\n",
      "17 36 637 638\n",
      "========================================\n",
      "17 37 None 638\n",
      "17 37 638 639\n",
      "========================================\n",
      "17 38 None 639\n",
      "17 38 639 640\n",
      "========================================\n",
      "17 39 None 640\n",
      "17 39 640 641\n",
      "========================================\n",
      "17 40 None 641\n",
      "17 40 641 642\n",
      "========================================\n",
      "17 41 None 642\n",
      "17 41 642 643\n",
      "========================================\n",
      "17 42 None 643\n",
      "17 42 643 644\n",
      "========================================\n",
      "17 43 None 644\n",
      "17 43 644 645\n",
      "========================================\n",
      "17 44 None 645\n",
      "17 44 645 646\n",
      "========================================\n",
      "17 45 None 646\n",
      "17 45 646 647\n",
      "========================================\n",
      "17 46 None 647\n",
      "17 46 647 648\n",
      "========================================\n",
      "17 47 None 648\n",
      "17 47 648 649\n",
      "========================================\n",
      "17 48 None 649\n",
      "17 48 649 650\n",
      "========================================\n",
      "17 49 None 650\n",
      "17 49 650 651\n",
      "========================================\n",
      "18 0 272 651\n",
      "18 1 50 651\n",
      "18 2 2 651\n",
      "18 3 6 651\n",
      "18 4 164 651\n",
      "18 5 3 651\n",
      "18 6 5 651\n",
      "18 7 8 651\n",
      "18 8 7 651\n",
      "18 9 52 651\n",
      "18 10 None 651\n",
      "18 10 651 652\n",
      "========================================\n",
      "18 11 10 652\n",
      "18 12 53 652\n",
      "18 13 92 652\n",
      "18 14 None 652\n",
      "18 14 652 653\n",
      "========================================\n",
      "18 15 93 653\n",
      "18 16 167 653\n",
      "18 17 None 653\n",
      "18 17 653 654\n",
      "========================================\n",
      "18 18 None 654\n",
      "18 18 654 655\n",
      "========================================\n",
      "18 19 None 655\n",
      "18 19 655 656\n",
      "========================================\n",
      "18 20 None 656\n",
      "18 20 656 657\n",
      "========================================\n",
      "18 21 None 657\n",
      "18 21 657 658\n",
      "========================================\n",
      "18 22 None 658\n",
      "18 22 658 659\n",
      "========================================\n",
      "18 23 None 659\n",
      "18 23 659 660\n",
      "========================================\n",
      "18 24 None 660\n",
      "18 24 660 661\n",
      "========================================\n",
      "18 25 None 661\n",
      "18 25 661 662\n",
      "========================================\n",
      "18 26 None 662\n",
      "18 26 662 663\n",
      "========================================\n",
      "18 27 None 663\n",
      "18 27 663 664\n",
      "========================================\n",
      "18 28 None 664\n",
      "18 28 664 665\n",
      "========================================\n",
      "18 29 None 665\n",
      "18 29 665 666\n",
      "========================================\n",
      "18 30 None 666\n",
      "18 30 666 667\n",
      "========================================\n",
      "18 31 None 667\n",
      "18 31 667 668\n",
      "========================================\n",
      "18 32 None 668\n",
      "18 32 668 669\n",
      "========================================\n",
      "18 33 None 669\n",
      "18 33 669 670\n",
      "========================================\n",
      "18 34 None 670\n",
      "18 34 670 671\n",
      "========================================\n",
      "18 35 None 671\n",
      "18 35 671 672\n",
      "========================================\n",
      "18 36 None 672\n",
      "18 36 672 673\n",
      "========================================\n",
      "18 37 None 673\n",
      "18 37 673 674\n",
      "========================================\n",
      "18 38 None 674\n",
      "18 38 674 675\n",
      "========================================\n",
      "18 39 None 675\n",
      "18 39 675 676\n",
      "========================================\n",
      "18 40 None 676\n",
      "18 40 676 677\n",
      "========================================\n",
      "18 41 None 677\n",
      "18 41 677 678\n",
      "========================================\n",
      "18 42 None 678\n",
      "18 42 678 679\n",
      "========================================\n",
      "18 43 None 679\n",
      "18 43 679 680\n",
      "========================================\n",
      "18 44 None 680\n",
      "18 44 680 681\n",
      "========================================\n",
      "18 45 None 681\n",
      "18 45 681 682\n",
      "========================================\n",
      "18 46 None 682\n",
      "18 46 682 683\n",
      "========================================\n",
      "18 47 None 683\n",
      "18 47 683 684\n",
      "========================================\n",
      "18 48 None 684\n",
      "18 48 684 685\n",
      "========================================\n",
      "18 49 None 685\n",
      "18 49 685 686\n",
      "========================================\n",
      "19 0 50 686\n",
      "19 1 272 686\n",
      "19 2 2 686\n",
      "19 3 3 686\n",
      "19 4 51 686\n",
      "19 5 6 686\n",
      "19 6 486 686\n",
      "19 7 8 686\n",
      "19 8 165 686\n",
      "19 9 11 686\n",
      "19 10 9 686\n",
      "19 11 451 686\n",
      "19 12 379 686\n",
      "19 13 128 686\n",
      "19 14 None 686\n",
      "19 14 686 687\n",
      "========================================\n",
      "19 15 586 687\n",
      "19 16 170 687\n",
      "19 17 241 687\n",
      "19 18 58 687\n",
      "19 19 None 687\n",
      "19 19 687 688\n",
      "========================================\n",
      "19 20 18 688\n",
      "19 21 None 688\n",
      "19 21 688 689\n",
      "========================================\n",
      "19 22 None 689\n",
      "19 22 689 690\n",
      "========================================\n",
      "19 23 None 690\n",
      "19 23 690 691\n",
      "========================================\n",
      "19 24 None 691\n",
      "19 24 691 692\n",
      "========================================\n",
      "19 25 None 692\n",
      "19 25 692 693\n",
      "========================================\n",
      "19 26 None 693\n",
      "19 26 693 694\n",
      "========================================\n",
      "19 27 None 694\n",
      "19 27 694 695\n",
      "========================================\n",
      "19 28 None 695\n",
      "19 28 695 696\n",
      "========================================\n",
      "19 29 None 696\n",
      "19 29 696 697\n",
      "========================================\n",
      "19 30 None 697\n",
      "19 30 697 698\n",
      "========================================\n",
      "19 31 None 698\n",
      "19 31 698 699\n",
      "========================================\n",
      "19 32 None 699\n",
      "19 32 699 700\n",
      "========================================\n",
      "19 33 None 700\n",
      "19 33 700 701\n",
      "========================================\n",
      "19 34 None 701\n",
      "19 34 701 702\n",
      "========================================\n",
      "19 35 None 702\n",
      "19 35 702 703\n",
      "========================================\n",
      "19 36 None 703\n",
      "19 36 703 704\n",
      "========================================\n",
      "19 37 None 704\n",
      "19 37 704 705\n",
      "========================================\n",
      "19 38 None 705\n",
      "19 38 705 706\n",
      "========================================\n",
      "19 39 None 706\n",
      "19 39 706 707\n",
      "========================================\n",
      "19 40 None 707\n",
      "19 40 707 708\n",
      "========================================\n",
      "19 41 None 708\n",
      "19 41 708 709\n",
      "========================================\n",
      "19 42 None 709\n",
      "19 42 709 710\n",
      "========================================\n",
      "19 43 None 710\n",
      "19 43 710 711\n",
      "========================================\n",
      "19 44 None 711\n",
      "19 44 711 712\n",
      "========================================\n",
      "19 45 None 712\n",
      "19 45 712 713\n",
      "========================================\n",
      "19 46 None 713\n",
      "19 46 713 714\n",
      "========================================\n",
      "19 47 None 714\n",
      "19 47 714 715\n",
      "========================================\n",
      "19 48 None 715\n",
      "19 48 715 716\n",
      "========================================\n",
      "19 49 None 716\n",
      "19 49 716 717\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": 165,
   "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",
       "       [  1,  50,   2,   3,  51,   6,   5,   8,   7,  52,  11,  10,  53,\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",
       "       [  0,   0,   2,   3,   4,   5,   6,   8,   7,  11,   9,  91,  92,\n",
       "         93,  94,  95,  96,  19,  97, 169,  98,  99, 100, 101, 102, 103,\n",
       "        104, 105, 106, 107, 108, 109, 110, 111, 112, 113, 114, 115, 116,\n",
       "        117, 118, 119, 120, 121, 122, 123, 124, 125, 126, 127],\n",
       "       [  0,   1,   2,   3,   4,   6,   5,   8,   7, 377,  11, 310, 128,\n",
       "        239, 129, 130,  57, 131,  95, 132, 133, 134, 135, 136, 137, 138,\n",
       "        139, 140, 141, 142, 143, 144, 145, 146, 147, 148, 149, 150, 151,\n",
       "        152, 153, 154, 155, 156, 157, 158, 159, 160, 161, 162],\n",
       "       [  0,   2,   1, 163,   4, 164, 416, 165,   8,   9,  11,  92, 166,\n",
       "        310,  18,  58, 167, 168, 169, 170, 171,  20,  99, 172, 173, 174,\n",
       "        175, 176, 177, 178, 179, 180, 181, 182, 183, 184, 185, 186, 187,\n",
       "        188, 189, 190, 191, 192, 193, 194, 195, 196, 196, 197],\n",
       "       [  1,  50,   2,   2, 232,  51,   5,   8, 165,  52,  11,  10,  13,\n",
       "         92, 198, 199, 452, 200,  19, 201, 202, 203, 204, 205, 206, 207,\n",
       "        208, 209, 210, 211, 212, 213, 214, 215, 216, 217, 218, 219, 220,\n",
       "        221, 222, 223, 224, 225, 226, 227, 228, 229, 230, 231],\n",
       "       [  0,   1, 232,   3, 233, 416,   5,   8,   7,   9,  10,  11, 234,\n",
       "        235, 236, 237, 238, 239, 240, 241, 242, 243, 244, 245, 246, 247,\n",
       "        248, 249, 250, 251, 252, 253, 254, 255, 256, 257, 258, 259, 260,\n",
       "        261, 262, 263, 264, 265, 266, 267, 268, 269, 270, 271],\n",
       "       [ 50, 272,   2,   3,   4, 416,   5,   8,   7,   9, 273,  11,  93,\n",
       "        274, 380, 275,  95, 276, 277, 278, 279, 280, 281, 282, 283, 284,\n",
       "        285, 286, 287, 288, 289, 290, 291, 292, 293, 294, 295, 296, 297,\n",
       "        298, 299, 300, 301, 302, 303, 304, 305, 306, 307, 308],\n",
       "       [272,   0,   2,   3,   6,   5,   4,   5, 309,   9,  11, 310, 166,\n",
       "         92, 311, 382, 312, 313, 551, 314, 315, 316, 317, 318, 319, 320,\n",
       "        321, 322, 323, 324, 325, 326, 327, 328, 329, 330, 331, 332, 333,\n",
       "        334, 335, 336, 337, 338, 339, 340, 341, 342, 343, 344],\n",
       "       [272,   1,   2,   3,   4,   6,   5,   8, 165, 310,  52, 234,  92,\n",
       "         54, 170,  57, 345, 171, 346, 347,  19, 348, 349, 350, 351, 352,\n",
       "        353, 354, 355, 356, 357, 358, 359, 360, 361, 362, 363, 364, 365,\n",
       "        366, 367, 368, 369, 370, 371, 372, 373, 374, 375, 376],\n",
       "       [  0, 272,   2, 164,   4, 486,   6,   8,   7, 377, 378,  91,  11,\n",
       "        379, 380, 381, 382, 383, 384, 385, 386, 387, 388, 389, 390, 391,\n",
       "        392, 393, 394, 395, 396, 397, 398, 399, 400, 401, 402, 403, 404,\n",
       "        405, 406, 407, 408, 409, 410, 411, 412, 413, 414, 415],\n",
       "       [  0,   1,   2, 416,   3, 233,   5,   8,   7,   9, 584,  10, 417,\n",
       "         53, 311, 418,  59, 419,  14, 420, 421, 422, 423, 424, 425, 426,\n",
       "        427, 428, 429, 430, 431, 432, 433, 434, 435, 436, 437, 438, 439,\n",
       "        440, 441, 442, 443, 444, 445, 446, 447, 448, 449, 450],\n",
       "       [  1,   2, 233, 232,   3,  51,   5, 165,   8, 378,  11,  12, 451,\n",
       "        617,  92, 452, 382, 453, 454, 455, 456, 457, 458, 459, 460, 461,\n",
       "        462, 463, 464, 465, 466, 467, 468, 469, 470, 471, 472, 473, 474,\n",
       "        475, 476, 477, 478, 479, 480, 481, 482, 483, 484, 485],\n",
       "       [  0,   1,   2,   3,  51,   6, 486, 309,   7, 273,  10,  91,  12,\n",
       "         93,  94,  56, 487, 383, 488, 489, 490, 491, 492, 493, 494, 495,\n",
       "        496, 497, 498, 499, 500, 501, 502, 503, 504, 505, 506, 507, 508,\n",
       "        509, 510, 511, 512, 513, 514, 515, 516, 517, 518, 519],\n",
       "       [  0,   1,   2,   3,   4,   5, 486,   8,   7,   9,  91,  11,  10,\n",
       "         53, 383,  16,  56, 456, 520, 491, 521, 522, 523, 524, 525, 526,\n",
       "        527, 528, 529, 530, 531, 532, 533, 534, 535, 536, 537, 538, 539,\n",
       "        540, 541, 542, 543, 544, 545, 546, 547, 548, 549, 550],\n",
       "       [272,  50,   2,   3,   4,   5,   6,   8, 165,  11,   9,  12, 379,\n",
       "        551, 552,  57, 278, 553, 454, 554, 555, 556, 557, 558, 559, 560,\n",
       "        351, 561, 562, 563, 564, 565, 566, 567, 568, 569, 570, 571, 572,\n",
       "        573, 574, 575, 576, 577, 578, 579, 580, 581, 582, 583],\n",
       "       [ 50,   0,   1, 416,   4,   3,   5,   8,   7, 584,  11, 273, 417,\n",
       "        166,  57, 585, 586,  58,  56, 587, 588, 589, 590, 101, 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, 614, 615, 615],\n",
       "       [272,   1,   2, 164, 486,  51,   5, 309,   8, 417,   9, 616, 166,\n",
       "         92, 380, 617, 618, 619,  98, 620, 621, 622, 623, 624, 625, 626,\n",
       "        627, 628, 629, 630, 631, 632, 633, 634, 635, 636, 637, 638, 639,\n",
       "        640, 641, 642, 643, 644, 645, 646, 647, 648, 649, 650],\n",
       "       [272,  50,   2,   6, 164,   3,   5,   8,   7,  52, 651,  10,  53,\n",
       "         92, 652,  93, 167, 653, 654, 655, 656, 657, 658, 659, 660, 661,\n",
       "        662, 663, 664, 665, 666, 667, 668, 669, 670, 671, 672, 673, 674,\n",
       "        675, 676, 677, 678, 679, 680, 681, 682, 683, 684, 685],\n",
       "       [ 50, 272,   2,   3,  51,   6, 486,   8, 165,  11,   9, 451, 379,\n",
       "        128, 686, 586, 170, 241,  58, 687,  18, 688, 689, 690, 691, 692,\n",
       "        693, 694, 695, 696, 697, 698, 699, 700, 701, 702, 703, 704, 705,\n",
       "        706, 707, 708, 709, 710, 711, 712, 713, 714, 715, 716]])"
      ]
     },
     "execution_count": 165,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "neuron_feature_pairing = np.array(neuron_feature_pairing)\n",
    "neuron_feature_pairing"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 166,
   "id": "outside-document",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(20, 50)"
      ]
     },
     "execution_count": 166,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "neuron_feature_pairing.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 167,
   "id": "c81e24e7",
   "metadata": {},
   "outputs": [],
   "source": [
    "# save_name = f'neuron_feature_pairing_p{pct}_v2'\n",
    "# save_path = os.path.join(affinity_dir, f'ep_{ep}_', save_name)\n",
    "# print(save_path)\n",
    "# np.save(save_path, neuron_feature_pairing)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 168,
   "id": "thermal-forth",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "717"
      ]
     },
     "execution_count": 168,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "feature_idx"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 169,
   "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": 170,
   "id": "practical-petersburg",
   "metadata": {},
   "outputs": [],
   "source": [
    "c = Counter()\n",
    "c.update(np.array(neuron_feature_pairing).reshape(-1))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 171,
   "id": "closed-vault",
   "metadata": {},
   "outputs": [],
   "source": [
    "count_dist = []\n",
    "for i in c:\n",
    "    count_dist.append(c[i])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 172,
   "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": 173,
   "id": "a0c5d25b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "641\n",
      "674\n",
      "717\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": "iVBORw0KGgoAAAANSUhEUgAAAXcAAAD4CAYAAAAXUaZHAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/YYfK9AAAACXBIWXMAAAsTAAALEwEAmpwYAAAPQElEQVR4nO3df6xfd13H8eeL1YEgsEGvy2w3b5UiFoIBr3OGhCBDrRtuMyxLF9EOqw1kAgoJFDEZ0RA7MSDGSVIZrhgcLBOz6gCdYwuB0MkdGxvt+FFGxzq39YIMFCIwfPvHPYtf7m53v/d77r3fbz97PpKbe37e88r33r567ud8z7mpKiRJbXncuANIklae5S5JDbLcJalBlrskNchyl6QGrRt3AID169fX9PT0uGNI0nHllltu+WpVTS22biLKfXp6mtnZ2XHHkKTjSpK7j7XOYRlJapDlLkkNstwlqUGWuyQ1yHKXpAZZ7pLUIMtdkhq0ZLkneU+So0k+O7DsbUk+l+T2JP+Y5KSBdW9KcijJ55P8yirlliQ9imHO3K8Eti5Ydj3wnKp6LvAF4E0ASbYA24Bnd/v8dZITViytJGkoS96hWlUfSzK9YNm/DszuBy7ops8D3l9V3wG+nOQQcAbwyZWJq8eq6V3Xjbzv4d3nrGAS6fiwEmPuvw18uJveANwzsO5It+wRkuxMMptkdm5ubgViSJIe1qvck7wZeAh433L3rao9VTVTVTNTU4s+90aSNKKRHxyW5GLgpcBZ9f9/iPVe4LSBzTZ2yyRJa2ikM/ckW4E3AOdW1bcHVu0DtiV5fJJNwGbg3/vHlCQtx5Jn7kmuAl4ErE9yBLiU+XfHPB64PgnA/qp6ZVUdSHI1cJD54ZpLqur7qxVekrS4Yd4tc9Eii694lO3fCry1TyhJUj/eoSpJDbLcJalBlrskNchyl6QGWe6S1CDLXZIaZLlLUoMsd0lqkOUuSQ2y3CWpQZa7JDXIcpekBlnuktQgy12SGmS5S1KDLHdJapDlLkkNstwlqUGWuyQ1yHKXpAZZ7pLUIMtdkhpkuUtSgyx3SWqQ5S5JDVqy3JO8J8nRJJ8dWPa0JNcn+WL3+eRueZL8ZZJDSW5P8vzVDC9JWtwwZ+5XAlsXLNsF3FBVm4EbunmAXwU2dx87gXetTExJ0nIsWe5V9THgPxcsPg/Y203vBc4fWP7emrcfOCnJqSuUVZI0pFHH3E+pqvu66fuBU7rpDcA9A9sd6ZZJktZQ7wuqVVVALXe/JDuTzCaZnZub6xtDkjRg1HJ/4OHhlu7z0W75vcBpA9tt7JY9QlXtqaqZqpqZmpoaMYYkaTGjlvs+YHs3vR24dmD5b3XvmjkT+MbA8I0kaY2sW2qDJFcBLwLWJzkCXArsBq5OsgO4G7iw2/xDwNnAIeDbwCtWIbMkaQlLlntVXXSMVWctsm0Bl/QNJUnqxztUJalBlrskNWjJYRnpeDe967pe+x/efc4KJZHWjmfuktQgy12SGmS5S1KDLHdJapDlLkkNstwlqUGWuyQ1yHKXpAZZ7pLUIMtdkhpkuUtSgyx3SWqQ5S5JDbLcJalBlrskNchyl6QGWe6S1CDLXZIaZLlLUoMsd0lqkOUuSQ1aN+4AeuyY3nXduCNIjxmeuUtSg3qVe5I/SHIgyWeTXJXkCUk2Jbk5yaEkH0hy4kqFlSQNZ+RyT7IBeA0wU1XPAU4AtgGXAe+oqmcAXwd2rERQSdLw+g7LrAN+OMk64InAfcCLgWu69XuB83seQ5K0TCOXe1XdC/w58BXmS/0bwC3Ag1X1ULfZEWDDYvsn2ZlkNsns3NzcqDEkSYvoMyxzMnAesAn4MeBJwNZh96+qPVU1U1UzU1NTo8aQJC2iz7DMS4AvV9VcVX0P+CDwAuCkbpgGYCNwb8+MkqRl6lPuXwHOTPLEJAHOAg4CNwIXdNtsB67tF1GStFx9xtxvZv7C6aeBO7qvtQd4I/C6JIeApwNXrEBOSdIy9LpDtaouBS5dsPgu4Iw+X1eS1I93qEpSgyx3SWqQ5S5JDbLcJalBlrskNchyl6QGWe6S1CDLXZIaZLlLUoMsd0lqkOUuSQ2y3CWpQZa7JDXIcpekBlnuktQgy12SGmS5S1KDLHdJalCvP7MnPRZM77pu5H0P7z5nBZNIw/PMXZIaZLlLUoMsd0lqkOUuSQ2y3CWpQZa7JDWoV7knOSnJNUk+l+TOJL+Q5GlJrk/yxe7zySsVVpI0nL5n7u8EPlJVzwJ+BrgT2AXcUFWbgRu6eUnSGhq53JM8FXghcAVAVX23qh4EzgP2dpvtBc7vF1GStFx9ztw3AXPA3ya5Ncm7kzwJOKWq7uu2uR84ZbGdk+xMMptkdm5urkcMSdJCfcp9HfB84F1V9TzgWywYgqmqAmqxnatqT1XNVNXM1NRUjxiSpIX6lPsR4EhV3dzNX8N82T+Q5FSA7vPRfhElScs1crlX1f3APUl+qlt0FnAQ2Ads75ZtB67tlVCStGx9nwr5auB9SU4E7gJewfx/GFcn2QHcDVzY8xiSpGXqVe5VdRsws8iqs/p8XUlSP96hKkkNstwlqUGWuyQ1yHKXpAZZ7pLUIMtdkhpkuUtSgyx3SWqQ5S5JDbLcJalBlrskNchyl6QGWe6S1CDLXZIaZLlLUoMsd0lqkOUuSQ2y3CWpQZa7JDXIcpekBlnuktQgy12SGmS5S1KDLHdJapDlLkkN6l3uSU5IcmuSf+7mNyW5OcmhJB9IcmL/mJKk5ViJM/fXAncOzF8GvKOqngF8HdixAseQJC1Dr3JPshE4B3h3Nx/gxcA13SZ7gfP7HEOStHzreu7/F8AbgCd3808HHqyqh7r5I8CGxXZMshPYCXD66af3jKG1Mr3runFHkDSEkc/ck7wUOFpVt4yyf1XtqaqZqpqZmpoaNYYkaRF9ztxfAJyb5GzgCcBTgHcCJyVZ1529bwTu7R9TkrQcI5+5V9WbqmpjVU0D24CPVtVvADcCF3SbbQeu7Z1SkrQsq/E+9zcCr0tyiPkx+CtW4RiSpEfR94IqAFV1E3BTN30XcMZKfF1J0mi8Q1WSGmS5S1KDLHdJapDlLkkNstwlqUGWuyQ1aEXeCilpcX2exXN49zkrmESPNZ65S1KDLHdJapDlLkkNstwlqUGWuyQ1yHKXpAZZ7pLUIMtdkhpkuUtSgyx3SWqQ5S5JDbLcJalBlrskNchyl6QGWe6S1CDLXZIaZLlLUoMsd0lq0MjlnuS0JDcmOZjkQJLXdsufluT6JF/sPp+8cnElScPoc+b+EPD6qtoCnAlckmQLsAu4oao2Azd085KkNTRyuVfVfVX16W76v4A7gQ3AecDebrO9wPk9M0qSlmlFxtyTTAPPA24GTqmq+7pV9wOnrMQxJEnD613uSX4E+Afg96vqm4PrqqqAOsZ+O5PMJpmdm5vrG0OSNKBXuSf5IeaL/X1V9cFu8QNJTu3WnwocXWzfqtpTVTNVNTM1NdUnhiRpgT7vlglwBXBnVb19YNU+YHs3vR24dvR4kqRRrOux7wuA3wTuSHJbt+wPgd3A1Ul2AHcDF/ZKKD1GTe+6buR9D+8+ZwWT6Hg0crlX1ceBHGP1WaN+XUlSf96hKkkN6jMso+NUn1/3JR0fPHOXpAZZ7pLUIMtdkhpkuUtSgyx3SWqQ5S5JDbLcJalBlrskNchyl6QGWe6S1CDLXZIaZLlLUoMsd0lqkE+FPA75VEctxT/0Ic/cJalBlrskNchyl6QGWe6S1CAvqEr6AX0v2HtBdjJ45i5JDbLcJalBlrskNegxP+Y+rps9vBFJ0mpKVY07AzMzMzU7OzvSvpak1I5xnTD1vQg8rmMnuaWqZhZbt2rDMkm2Jvl8kkNJdq3WcSRJj7QqwzJJTgAuB34JOAJ8Ksm+qjq4GseT1IZx/Sbe4gjAap25nwEcqqq7quq7wPuB81bpWJKkBVbrguoG4J6B+SPAzw9ukGQnsLOb/e8kn1+lLOuBr67S114J5uvHfP1Mej6Y/Iy98uWyXsf+8WOtGNu7ZapqD7BntY+TZPZYFxwmgfn6MV8/k54PJj/jpOZbrWGZe4HTBuY3dsskSWtgtcr9U8DmJJuSnAhsA/at0rEkSQusyrBMVT2U5PeAfwFOAN5TVQdW41hDWPWhn57M14/5+pn0fDD5GScy30TcxCRJWlk+W0aSGmS5S1KDmin3pR53kOSFST6d5KEkF0xgvtclOZjk9iQ3JDnm+1fHlO+VSe5IcluSjyfZMkn5BrZ7WZJKsqZvTRvi9bs4yVz3+t2W5HcmKV+3zYXdz+CBJH8/SfmSvGPgtftCkgcnLN/pSW5Mcmv3b/jstcy3qKo67j+Yv2j7JeAngBOBzwBbFmwzDTwXeC9wwQTm+0Xgid30q4APTFi+pwxMnwt8ZJLydds9GfgYsB+YmaR8wMXAX63lz90y820GbgVO7uZ/dJLyLdj+1cy/SWNi8jF/UfVV3fQW4PA4vteDH62cuS/5uIOqOlxVtwP/O6H5bqyqb3ez+5m/N2CS8n1zYPZJwFpeiR/2cRZ/AlwG/M8aZoPJf9zGMPl+F7i8qr4OUFVHJyzfoIuAq9Yk2bxh8hXwlG76qcB/rGG+RbVS7os97mDDmLIsZrn5dgAfXtVEP2iofEkuSfIl4M+A16xRNhgiX5LnA6dV1TieADXs9/dl3a/s1yQ5bZH1q2WYfM8EnpnkE0n2J9m6ZumW8e+jG67cBHx0DXI9bJh8bwFenuQI8CHmf7sYq1bKvRlJXg7MAG8bd5aFquryqvpJ4I3AH407z8OSPA54O/D6cWd5FP8ETFfVc4Hrgb1jzrPQOuaHZl7E/Jnx3yQ5aZyBjmEbcE1VfX/cQRa4CLiyqjYCZwN/1/1cjk0r5T7pjzsYKl+SlwBvBs6tqu+sUTZY/uv3fuD81Qy0wFL5ngw8B7gpyWHgTGDfGl5UXfL1q6qvDXxP3w387Bplg+G+v0eAfVX1var6MvAF5st+UvI9bBtrOyQDw+XbAVwNUFWfBJ7A/APFxmfcg/4rdMFjHXAX87+uPXzB49nH2PZK1v6C6pL5gOcxf9Fm8yS+foO5gF8DZicp34Ltb2JtL6gO8/qdOjD968D+Ccu3FdjbTa9nfhji6ZOSr9vuWcBhupsvJ+z1+zBwcTf908yPua9pzkfkHufBV/gbcDbzZxtfAt7cLftj5s+CAX6O+bOTbwFfAw5MWL5/Ax4Abus+9k1YvncCB7psNz5auY4j34Jt17Tch3z9/rR7/T7TvX7PmrB8YX5o6yBwB7BtkvJ1828Bdq9lrmW8fluAT3Tf39uAXx5HzsEPHz8gSQ1qZcxdkjTAcpekBlnuktQgy12SGmS5S1KDLHdJapDlLkkN+j857XbK2ZqQfQAAAABJRU5ErkJggg==",
      "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": 65,
   "id": "391573e1",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.image.AxesImage at 0x7f7df1b49ac0>"
      ]
     },
     "execution_count": 65,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "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.imshow(x)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "e22a9a54",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "d42df8df",
   "metadata": {},
   "outputs": [],
   "source": [
    "path_10k = None  # path to 10k experiments\n",
    "path_45k = None  # path to 45k experiments"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 140,
   "id": "df220ee6",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([  0,   1, 432,   3,   4,   5, 650,   6, 128, 127,   9, 333, 197,\n",
       "       625, 651, 652, 494,  17, 653,  14, 654, 201, 655, 656, 103, 657,\n",
       "       658, 659, 131, 660, 661, 662, 663, 664, 665, 666, 667, 668, 669,\n",
       "       670, 671, 672, 673, 674, 675, 676, 677, 678, 679, 680])"
      ]
     },
     "execution_count": 140,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "pairing_10k = np.load(path_10k)\n",
    "pairing_10k[-1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 142,
   "id": "b53e1e3c",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([  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": 142,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "pairing_45k = np.load(path_45k)\n",
    "pairing_45k[-1]"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "697b4910",
   "metadata": {},
   "source": [
    "## All epoch"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4460cbc1",
   "metadata": {},
   "outputs": [],
   "source": [
    "# for ep in np.arange(1, 19)*10:\n",
    "for ep in np.arange(30):\n",
    "    print(f'>>>>>>> epoch {ep}')\n",
    "    all_corr_mat = [[None for _ in range(20)] for _ in range(20)]\n",
    "\n",
    "    # Loading all correlation matrices\n",
    "    for i in range(20):\n",
    "        for j in range(20):\n",
    "            corr_mat = np.load(os.path.join(affinity_dir, f'ep_{ep}_', f'corr_{i}_{j}.npy'))\n",
    "            all_corr_mat[i][j] = corr_mat\n",
    "\n",
    "    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)]\n",
    "\n",
    "    # iterate features of each model to assign cluster\n",
    "    feature_idx = 0\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)\n",
    "\n",
    "    neuron_feature_pairing = np.array(neuron_feature_pairing)\n",
    "\n",
    "    print(neuron_feature_pairing.shape)\n",
    "\n",
    "    save_name = f'neuron_feature_pairing_p{pct}'\n",
    "    save_path = os.path.join(affinity_dir, f'ep_{ep}_', save_name)\n",
    "    print(save_path)\n",
    "    np.save(save_path, neuron_feature_pairing)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 102,
   "id": "96e763c3",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "================================================================================\n",
      "553\n",
      "633\n",
      "686\n",
      "================================================================================\n",
      "770\n",
      "800\n",
      "831\n",
      "================================================================================\n",
      "702\n",
      "748\n",
      "787\n",
      "================================================================================\n",
      "618\n",
      "677\n",
      "727\n",
      "================================================================================\n",
      "565\n",
      "627\n",
      "684\n",
      "================================================================================\n",
      "570\n",
      "626\n",
      "680\n",
      "================================================================================\n",
      "534\n",
      "595\n",
      "657\n",
      "================================================================================\n",
      "540\n",
      "610\n",
      "665\n",
      "================================================================================\n",
      "536\n",
      "597\n",
      "653\n",
      "================================================================================\n",
      "530\n",
      "584\n",
      "644\n",
      "================================================================================\n",
      "541\n",
      "598\n",
      "653\n",
      "================================================================================\n",
      "563\n",
      "612\n",
      "663\n",
      "================================================================================\n",
      "569\n",
      "622\n",
      "670\n",
      "================================================================================\n",
      "567\n",
      "614\n",
      "659\n",
      "================================================================================\n",
      "582\n",
      "631\n",
      "675\n",
      "================================================================================\n",
      "573\n",
      "625\n",
      "673\n",
      "================================================================================\n",
      "580\n",
      "629\n",
      "678\n",
      "================================================================================\n",
      "573\n",
      "629\n",
      "675\n",
      "================================================================================\n",
      "566\n",
      "626\n",
      "671\n",
      "================================================================================\n",
      "575\n",
      "624\n",
      "676\n",
      "================================================================================\n",
      "591\n",
      "631\n",
      "681\n",
      "================================================================================\n",
      "594\n",
      "631\n",
      "680\n",
      "================================================================================\n",
      "590\n",
      "629\n",
      "678\n",
      "================================================================================\n",
      "584\n",
      "626\n",
      "675\n",
      "================================================================================\n",
      "581\n",
      "626\n",
      "675\n",
      "================================================================================\n",
      "576\n",
      "623\n",
      "672\n",
      "================================================================================\n",
      "582\n",
      "624\n",
      "674\n",
      "================================================================================\n",
      "578\n",
      "620\n",
      "671\n",
      "================================================================================\n",
      "575\n",
      "620\n",
      "670\n",
      "================================================================================\n",
      "575\n",
      "620\n",
      "670\n"
     ]
    }
   ],
   "source": [
    "# for ep in np.arange(1, 19)*10:\n",
    "for ep in np.arange(30):\n",
    "    print('='* 80)\n",
    "    save_name = f'neuron_feature_pairing_p{pct}.npy'\n",
    "    save_path = os.path.join(affinity_dir, f'ep_{ep}_', save_name)\n",
    "    neuron_feature_pairing = np.load(save_path)\n",
    "    c = Counter()\n",
    "    c.update(np.array(neuron_feature_pairing).reshape(-1))\n",
    "    count_dist = []\n",
    "    for i in c:\n",
    "        count_dist.append(c[i])\n",
    "    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": "code",
   "execution_count": null,
   "id": "db32f61e",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "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.12 (main, Mar 26 2022, 15:51:13) \n[Clang 12.0.0 (clang-1200.0.32.29)]"
  },
  "vscode": {
   "interpreter": {
    "hash": "aee8b7b246df8f9039afb4144a1f6fd8d2ca17a180786b69acc140d282b71a49"
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
