{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "3e359376-8cd8-4abe-8e32-e7734e27ad4b",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_585534/1136553350.py:4: DeprecationWarning: Please import `gaussian_filter1d` from the `scipy.ndimage` namespace; the `scipy.ndimage.filters` namespace is deprecated and will be removed in SciPy 2.0.0.\n",
      "  from scipy.ndimage.filters import gaussian_filter1d\n"
     ]
    }
   ],
   "source": [
    "from nesim.utils.json_stuff import load_json_as_dict\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "from scipy.ndimage.filters import gaussian_filter1d\n",
    "from nesim.utils.figure.figure_1 import apply_ratan_matplotlib_thing\n",
    "apply_ratan_matplotlib_thing()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "3580e430-e9f9-4507-a762-34b590dd05a2",
   "metadata": {},
   "outputs": [],
   "source": [
    "raw_data = load_json_as_dict(\"raw_data.json\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "893cb73c-2c24-4a1f-800d-1b6b3d666029",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "dict_keys(['baseline_scale_None_shrink_factor_3.0', 'all_topo_scale_1_shrink_factor_3.0', 'all_topo_scale_30_shrink_factor_3.0'])"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "raw_data.keys()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "3c3a4b00-4548-4702-9b32-39ba1bceb28e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "dict_keys(['layer1.0.conv1', 'layer1.0.conv2', 'layer1.0.conv3', 'layer1.1.conv1', 'layer1.1.conv2', 'layer1.1.conv3', 'layer1.2.conv1', 'layer1.2.conv2', 'layer1.2.conv3', 'layer2.0.conv1', 'layer2.0.conv2', 'layer2.0.conv3', 'layer2.0.downsample.0', 'layer2.1.conv1', 'layer2.1.conv2', 'layer2.1.conv3', 'layer2.2.conv1', 'layer2.2.conv2', 'layer2.2.conv3', 'layer2.3.conv1', 'layer2.3.conv2', 'layer2.3.conv3', 'layer3.0.conv1', 'layer3.0.conv2', 'layer3.0.conv3', 'layer3.0.downsample.0', 'layer3.1.conv1', 'layer3.1.conv2', 'layer3.1.conv3', 'layer3.2.conv1', 'layer3.2.conv2', 'layer3.2.conv3', 'layer3.3.conv1', 'layer3.3.conv2', 'layer3.3.conv3', 'layer3.4.conv1', 'layer3.4.conv2', 'layer3.4.conv3', 'layer3.5.conv1', 'layer3.5.conv2', 'layer3.5.conv3', 'layer4.0.conv1', 'layer4.0.conv2', 'layer4.0.conv3', 'layer4.0.downsample.0', 'layer4.1.conv1', 'layer4.1.conv2', 'layer4.1.conv3', 'layer4.2.conv1', 'layer4.2.conv2', 'layer4.2.conv3'])"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "raw_data[\"all_topo_scale_1_shrink_factor_3.0\"].keys()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "4d0d72a1-a040-434a-8eee-cb595771f52a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABecAAAH/CAYAAADdUWYgAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8hTgPZAAAACXBIWXMAAA9hAAAPYQGoP6dpAACD3klEQVR4nOzdeVxUZf//8TegrAqKbKKGipZLKolrqViRaJZ5p6belYqm5XKXcZdli0sbqWW0uJSlacudX7VsN5NbW01zq1wzU0wTRFFGUVnP749+zO0EKjMMZxh4PR+Peeic5TrXmRnmfeYzZ67jYRiGIQAAAAAAAAAAYBpPV3cAAAAAAAAAAIDqhuI8AAAAAAAAAAAmozgPAAAAAAAAAIDJKM4DAAAAAAAAAGAyivMAAAAAAAAAAJiM4jwAAAAAAAAAACajOA8AAAAAAAAAgMkozgMAAAAAAAAAYDKK8wAAAAAAAAAAmIzifDU0bdo0eXh46NixY67uSgk9e/ZUz549rfcPHDggDw8Pvfnmmy7rkyu8+eab8vDw0IEDB1zdlSqhZ8+euvLKK8vVxrp16+Th4aF169Y5vO7y5cvL1QdJOn36tO666y5FRETIw8NDEydOLHebAFBWpb0XjhgxQo0bN3ZZn6oyDw8PTZs2zdXdKLfi47nnnnuuXO2U57U2YsQI1apVq1zbL/bjjz/q6quvVkBAgDw8PLRt2zantAsAFYHsNldVyW57OCNjy1P7cdZxhiQVFBRo0qRJatSokTw9PdW/f/9ytwlcCsV5oJopDi4PDw+tWLGixPzK/OUNpGeeeUZvvvmmxo4dq7feekt33nlnhWxj5cqVTm+3rO6//361b99ewcHB8vf3V8uWLTVt2jSdPn26zG288cYbatmypXx9fdW8eXO9/PLLFdhjAPZ69913lZKS4upuVGsbN27UuHHjFBsbq5o1a8rDw8PVXXIL+fn5GjRokLKysvTCCy/orbfeUlRUlFO3sXPnTk2bNs1lJ2ns2LFDgwYNUtOmTeXv76+QkBD16NFDH3/8cZnbOHnypMaMGaPQ0FAFBATo2muv1ZYtWyqw1wAqGtntegsWLFBcXJzCw8Pl4+OjJk2aKDEx8YJ5wWci+y1cuFCzZs3SwIEDtXjxYt1///1O38bcuXNdegLqM888oy5duig0NNT62pg4caIyMzPL3MZHH32k9u3by9fXV5dddpmmTp2qgoKCCux11VbD1R0ALiYqKkpnz55VzZo1Xd2VKumJJ57QrbfeygfyMujRo4fOnj0rb29vl/bjv//9r7p06aKpU6dW2DaeeeYZDRw40GVnCfz444/q3r27EhMT5evrq61bt+rZZ5/VmjVr9PXXX8vT8+LfK7/66qu65557NGDAACUlJembb77RvffeqzNnzuihhx4yaS8AXMy7776r7du38+sfF/rss8/0+uuvq23btmratKl+/fVXV3fpkhYsWKCioiKX9mHfvn1KS0vTggULdNddd1XINnbu3Knp06erZ8+eLjmzNS0tTadOndLw4cMVGRmpM2fOaMWKFerXr59effVVjRkz5qLrFxUVqW/fvvrpp5/04IMPKiQkRHPnzlXPnj21efNmNW/e3KQ9AeBMZLfrbd26VU2aNFG/fv1Ut25d7d+/XwsWLNAnn3yin376SZGRkdZl3e0zUWWp/fz3v/9VgwYN9MILL1TYNubOnauQkBCNGDGiwrZxMZs3b1ZMTIyGDBmi2rVra9euXVqwYIE+/fRTbdu2TQEBARdd//PPP1f//v3Vs2dPvfzyy/rll1/01FNP6ejRo5o3b55Je1G1UJxHpebh4SFfX19Xd6NKiomJ0bZt2/TBBx/o1ltvdXV3Kq1z587J29tbnp6eleK1ePToUbVq1crV3bBbTk7OJUO+2LfffltiWnR0tB544AFt3LhRXbp0ueC6Z8+e1aOPPqq+fftahxEaPXq0ioqK9OSTT2rMmDGqW7euYzsBAFXI2LFj9dBDD8nPz08TJkyo1MX54gxx9Qd26a8clqQ6deq4tiMOOHPmjPz9/S+53I033qgbb7zRZtqECRMUGxur2bNnX7I4v3z5cn3//fdatmyZBg4cKEm67bbbdPnll2vq1Kl69913Hd8JAKjG5s6dW2Ja//791aFDBy1ZskQPP/ywJPf6TFRQUKCioiJ5e3tXms/b7pjx59ctLqW0ERS6du2qgQMH6uOPP9aQIUMuuv4DDzygtm3bavXq1apR46+ycmBgoJ555hndd999atGihWM7UY0xrE01duzYMd12220KDAxUvXr1dN999+ncuXPW+YsWLdJ1112nsLAw+fj4qFWrVqV+C7Zp0yYlJCQoJCREfn5+atKkiUaOHGmzTFFRkVJSUtS6dWv5+voqPDxcd999t06cOHHRPpY27ljxeGaHDx9W//79VatWLYWGhuqBBx5QYWGhU7b7d6dOndLEiRPVuHFj+fj4KCwsTDfccEOJn+du2LBBN954o+rWrauAgAC1bdtWL774onX+zz//rBEjRqhp06by9fVVRESERo4cqePHj5epH59//rm6d++ugIAA1a5dW3379tWOHTvs2pdiQ4YM0eWXX64nnnhChmFccvlly5YpNjZWfn5+CgkJ0R133KHDhw/bLFOZnxvprzPRrr32Wvn7+6tBgwaaOXOmzfzi8Rjfe+89PfbYY2rQoIH8/f1lsVhKHauxeCz7S7VbmtzcXN10000KCgrS999/f8nli7e/f/9+ffrpp9ahiQ4cOKC8vDxNmTJFsbGxCgoKUkBAgLp37661a9eWaKeoqEgvvvii2rRpI19fX4WGhqp3797atGmTpL++EMvJydHixYut2zj/G/2tW7eqT58+CgwMVK1atXT99dfrhx9+sNlG8TUTvvrqK40bN05hYWFq2LDhJffxYorPHDx58uRFl1u7dq2OHz+ucePG2UwfP368cnJy9Omnn5arH0BVlZaWpnHjxumKK66Qn5+f6tWrp0GDBlXIsBo9e/bUp59+qrS0NOv7zPlnBx89elSjRo1SeHi4fH191a5dOy1evNimjfPHFn3hhRcUFRUlPz8/xcXFafv27SW2+d///tean3Xq1NEtt9yiXbt22d339957T7Gxsapdu7YCAwPVpk0bm5yX/nqfuv/++6251LBhQw0bNsw6XJw979mlOXz4sEaOHGn9SXvr1q21cOFCu/clPDxcfn5+dq9XmrIcCxZ77bXXFB0dLR8fH3Xs2FE//vijzfziY4l9+/bpxhtvVO3atXX77bdb553/Wjn/dXCpdkuzbds2hYaGqmfPnmUaOm3EiBGKi4uTJA0aNEgeHh7WayXZc4x3+PBhjRo1SpGRkdZhCcaOHau8vDy9+eabGjRokCTp2muvtf6NnH/8MXfuXLVu3Vo+Pj6KjIzU+PHjS+Rj8THK5s2b1aNHD/n7++uRRx655D5eiJeXlxo1anTJHJb+Ks6Hh4fbnPwRGhqq2267TR9++KFyc3Md7geA/yG7y6YqZXdpSvuc5MzPRPn5+Zo+fbqaN28uX19f1atXT926ddOXX35ZYtlL1QHOfw2kpKRYc3vnzp3lrv38nWEYGjNmjLy9vfX+++9fcj+Lt7927Vrt2LGjRP4+99xzuvrqq1WvXj35+fkpNjb2gteUe/vtt9WpUyf5+/urbt266tGjh1avXi3pr+drx44d+uqrr6zbOP+6i7///rsGDRpkHeK1S5cuJZ6vi9UtHFXWz9s7d+7Uzp07NWbMGGthXpLGjRsnwzCccp296ogz56ux2267TY0bN1ZycrJ++OEHvfTSSzpx4oSWLFkiSZo3b55at26tfv36qUaNGvr44481btw4FRUVafz48ZL+CuFevXopNDRUDz/8sOrUqaMDBw6UePO7++679eabbyoxMVH33nuv9u/fr1deeUVbt27Vd999Z/eZUIWFhUpISFDnzp313HPPac2aNXr++ecVHR2tsWPHOn2799xzj5YvX64JEyaoVatWOn78uL799lvt2rVL7du3lyR9+eWXuummm1S/fn3dd999ioiI0K5du/TJJ5/ovvvusy7z+++/KzExUREREdqxY4dee+017dixQz/88MNFh5d56623NHz4cCUkJGjGjBk6c+aM5s2bp27dumnr1q12/+zZy8tLjz32mIYNG3bJs+eLH8OOHTsqOTlZGRkZevHFF/Xdd99p69atNt8sV8bnRpJOnDih3r1769Zbb9Vtt92m5cuX66GHHlKbNm3Up08fmzaffPJJeXt764EHHlBubu5Fh7Kxp91iZ8+e1S233KJNmzZpzZo16tix4yX3s2XLlnrrrbd0//33q2HDhvr3v/8t6a8PuxaLRa+//rqGDh2q0aNH69SpU3rjjTeUkJCgjRs3KiYmxtrOqFGj9Oabb6pPnz666667VFBQoG+++UY//PCDOnTooLfeekt33XWXOnXqZD0zLjo6WtJfY9B2795dgYGBmjRpkmrWrKlXX31VPXv21FdffaXOnTvb9HncuHEKDQ3VlClTlJOTc8l9PF9BQYFOnjypvLw8bd++XY899phq166tTp06XXS9rVu3SpI6dOhgMz02Nlaenp7aunWr7rjjDrv6AlQHP/74o77//nsNGTJEDRs21IEDBzRv3jz17NlTO3fuLNPZtmX16KOPKjs7W4cOHbL+ZLj4ImJnz55Vz5499dtvv2nChAlq0qSJli1bphEjRujkyZPWPC22ZMkSnTp1SuPHj9e5c+f04osv6rrrrtMvv/yi8PBwSdKaNWvUp08fNW3aVNOmTdPZs2f1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a3bBsefT0tIkSVdccUWJeS1atLDOL1bZnptiDRs2LBGIf+9XseLnpCzsaXfixIn68ccftWbNGrVu3brM2yiLxYsXq23bttZxAENDQ/Xpp5/avK727dunyMhIm4PcssrMzNSZM2dKfR20bNlSRUVF+uOPP2ym2/M4/l1gYKDi4+N1yy23aMaMGfr3v/+tW265RT/99NNF1/Pz87tg4eDcuXNOG18ZqGrOnj2rKVOmqFGjRvLx8VFISIhCQ0N18uTJi+aTs6Wlpal58+YlPtAU/6T475nz92MZSbr88sutxzIXy7CWLVvq2LFjZR52a9y4cbr88svVp08fNWzYUCNHjtSqVatsltm3b98ljwWksr1n/11mZqZOnjyp1157rUR2Fhdgy3M84KiyHAsWu+yyy2zuFxfU/56ZNWrUsOtaJWVt99y5c+rbt6+uuuoq/d///Z9dP/++lLIc42VmZspisZTpNVKaC72evb291bRp0xJ/Hw0aNCjXPrZo0ULx8fEaNmyYPvnkE50+fdpaYLoYPz+/Up//4mtbkcWAc5Ddl1ZVs/vaa69Vnz59lJSUpGXLlmn69Ol65ZVXrPOd+ZnoiSee0MmTJ3X55ZerTZs2evDBB/Xzzz+XWK4sdYBi9nxOtKfd5ORkrVy5UsuXL7/k8Cz2+uSTT9SlSxf5+voqODhYoaGhmjdvXonP256enmrVqpVD20hLS7vg6754/vnK83nb29tb8fHxuummm/T4449rzpw5GjVqlD755JOLrlf82rlQzpPxjmHMeVidX2Dct2+frr/+erVo0UKzZ89Wo0aN5O3trc8++0wvvPCCdTwwDw8PLV++XD/88IM+/vhjffHFFxo5cqSef/55/fDDD6pVq5aKiooUFhamd955p9Tt2vONabGynI3rzO3edttt6t69uz744AOtXr1as2bN0owZM/T+++9fcFzxC7Xz/fff68EHH1RMTIz18endu/cFx1gr3hfpr3HnIyIiSsw//0Ic9io+e37EiBH68MMPHW7n/PYuxRXPzYX6VdoHTHsCxZ52b7nlFr333nt69tlntWTJkjJdSb0s3n77bY0YMUL9+/fXgw8+qLCwMHl5eSk5Odn6xZErODOYb731Vt15551677331K5duwsuV79+fRUWFuro0aMKCwuzTs/Ly9Px48cVGRnptD4BVcm//vUvLVq0SBMnTlTXrl0VFBQkDw8PDRky5KL5VJ2EhYVp27Zt+uKLL/T555/r888/16JFizRs2LASF727GEffs4ufhzvuuEPDhw8vdZm2bdvat1NOUJZjwWJlzUwfHx+7MtKedm+88UZ9+OGHWrVqlW666aYyb+NSHD3Gq0jO/oA8cOBA3X333fr1119LLR4Uq1+/vo4cOVJievE0shhwDrL70qpDdkdHR+uqq67SO++8owkTJkhy7meiHj16aN++ffrwww+1evVqvf7663rhhRc0f/583XXXXdbl7PnFtDM+b5cmISFBq1at0syZM9WzZ0+bX/6XxzfffKN+/fqpR48emjt3rurXr6+aNWtq0aJFevfdd52yDUc4M+evvvpq1a9fX++8885Fj4/q168v6a9Mb9Sokc28I0eOXPIacSgdxflqbO/evTbftP32228qKipS48aN9fHHHys3N1cfffSRzdlIFxpupEuXLurSpYuefvppvfvuu7r99tv13nvv6a677lJ0dLTWrFmja665xtRv0Zy93fr162vcuHEaN26cjh49qvbt2+vpp59Wnz59rBfM3L59u+Lj40td/8SJE0pNTdX06dM1ZcoU6/Sy/DysuP2wsLALtl8ed9xxh5566ilNnz5d/fr1s5kXFRUlSdqzZ4+uu+46m3l79uyxzreHmc9NZdK/f3/16tVLI0aMUO3atTVv3jyntLt8+XI1bdpU77//vs2XbH8fviY6OlpffPGFsrKyLnr2fGk/uQsNDZW/v7/27NlTYt7u3bvl6elZIpydKTc3V0VFRZc8C6h4qKBNmzbpxhtvtE7ftGmTioqKnDaUEFDVLF++XMOHD9fzzz9vnXbu3DmdPHmyQrZ3oZ/2RkVF6eeff1ZRUZFNcXb37t3W+ecrLUN//fVX64Xizs+wv9u9e7dCQkIUEBBQ5n57e3vr5ptv1s0336yioiKNGzdOr776qh5//HE1a9ZM0dHR2r59+0XbKOt79t+Fhoaqdu3aKiwsrJBjgfK62LFgZeHh4aF33nlHt9xyiwYNGqTPP//cKWfWlfUYLzQ0VIGBgZd8jVzs70P66/V8/hBzeXl52r9/f4W/Lop/ql6WLP7mm29K/B1v2LBB/v7+uvzyyyu0n0B1QXaXTXXI7rNnz9qcyezsz0TBwcFKTExUYmKiTp8+rR49emjatGmVKuOlv45F7rnnHt10000aNGiQPvjgg3KdyFhsxYoV8vX11RdffGEznMuiRYtslouOjlZRUZF27tx50cf4Yn9LF3rdF8+vSOfOnbPr8/b5hfg///xThw4d0pgxYyqyi1UWw9pUY3PmzLG5//LLL0uS+vTpY/128vwzjrKzs0u8+Zw4caLEWUnFf6zF4XDbbbepsLBQTz75ZIk+FBQUVNjBg7O2W1hYWOINKiwsTJGRkdZ9bN++vZo0aaKUlJQS7RY/PqU9ppKUkpJyyT4kJCQoMDBQzzzzTKnjuWZmZpZpXy6k+Oz5bdu26aOPPrKZ16FDB4WFhWn+/Pk2gf/5559r165dZbry+d+Z+dxUNsOGDdNLL72k+fPn66GHHnJKm6W9tjZs2KD169fbLDdgwAAZhqHp06eXaOP8dQMCAko8B15eXurVq5c+/PBD609Opb+uKP/uu++qW7duCgwMLPe+nDx5stTX+Ouvvy7J9qrwZ86c0e7du3Xs2DHrtOuuu07BwcElvviYN2+e/P39HXq9AtWBl5dXiXx6+eWXVVhYWCHbCwgIKPXg/8Ybb1R6erqWLl1qnVZQUKCXX35ZtWrVUlxcnM3yK1eu1OHDh633N27cqA0bNli/nK1fv75iYmK0ePFim/e17du3a/Xq1TYfWC/l+PHjNvc9PT2tZ7sVZ86AAQP0008/6YMPPiix/sWOB0p7z/47Ly8vDRgwQCtWrCi1iFDeYwFHleVYsDLx9vbW+++/r44dO+rmm2/Wxo0by91mWY/xPD091b9/f3388cfatGlTiXaK1y8uOv09i+Pj4+Xt7a2XXnrJZltvvPGGsrOznZZxpQ2xkJ+fryVLlsjPz8/m5/pHjhzR7t27bbJ74MCBysjI0Pvvv2+dduzYMS1btkw333yz08b5B6o7svvSqlJ2FxQUlDqUy8aNG/XLL7/YfE5y5meivz+GtWrVUrNmzSplxkt/ZeV7772nVatW6c4773TKr0i8vLzk4eFh87d14MCBEtft69+/vzw9PfXEE0+U2O6lPm9Lf/0tbdy40eZ1lZOTo9dee02NGzd2eLic8+Xk5OjMmTMlpq9YsUInTpyweR3l5+dr9+7dNr+Ga926tVq0aKHXXnvN5vGYN2+ePDw8NHDgwHL3sTrizPlqbP/+/erXr5969+6t9evX6+2339Y///lPtWvXTr6+vtZvmO+++26dPn1aCxYsUFhYmM0f5uLFizV37lz94x//UHR0tE6dOqUFCxYoMDDQGppxcXG6++67lZycrG3btqlXr16qWbOm9u7dq2XLlunFF1+skD9gZ2331KlTatiwoQYOHKh27dqpVq1aWrNmjX788UfrWQqenp6aN2+ebr75ZsXExCgxMVH169fX7t27tWPHDn3xxRcKDAxUjx49NHPmTOXn56tBgwZavXq19u/ff8k+BAYGat68ebrzzjvVvn17DRkyRKGhoTp48KA+/fRTXXPNNTZjzDni9ttv15NPPqlt27bZTK9Zs6ZmzJihxMRExcXFaejQocrIyNCLL76oxo0b6/7777d7W2Y+N5XRhAkTZLFY9OijjyooKMh6LQdH3XTTTXr//ff1j3/8Q3379tX+/fs1f/58tWrVyuaiLtdee63uvPNOvfTSS9q7d6/1p/bffPONrr32WuvPIGNjY7VmzRrNnj1bkZGRatKkiTp37qynnnpKX375pbp166Zx48apRo0aevXVV5Wbm6uZM2eWax+KrVu3Tvfee68GDhyo5s2bKy8vT998843ef/99dejQwebiuxs3btS1116rqVOnatq0aZL++mnfk08+qfHjx2vQoEFKSEjQN998o7fffltPP/20Q+PtA9XBTTfdpLfeektBQUFq1aqV1q9frzVr1qhevXoVsr3Y2FgtXbpUSUlJ6tixo2rVqqWbb75ZY8aM0auvvqoRI0Zo8+bNaty4sZYvX67vvvtOKSkpql27tk07zZo1U7du3TR27Fjl5uYqJSVF9erV06RJk6zLzJo1S3369FHXrl01atQonT17Vi+//LKCgoKs7x1lcddddykrK0vXXXedGjZsqLS0NL388suKiYmxjgX64IMPavny5Ro0aJBGjhyp2NhYZWVl6aOPPtL8+fPVrl27Mr9nl+bZZ5/V2rVr1blzZ40ePVqtWrVSVlaWtmzZojVr1igrK6vM+5OWlqa33npLkqyF4qeeekrSX2dm3XnnnWVqpyzHgpWNn5+fPvnkE1133XXq06ePvvrqK4fHgZdk1zHeM888o9WrVysuLk5jxoxRy5YtdeTIES1btkzffvut6tSpo5iYGHl5eWnGjBnKzs6Wj4+PrrvuOoWFhWny5MmaPn26evfurX79+mnPnj2aO3euOnbsaJOR5XH33XfLYrGoR48eatCggdLT0/XOO+9o9+7dev75522GKpo8ebIWL16s/fv3W896HThwoLp06aLExETt3LlTISEhmjt3rgoLC0s9QQCAY8juS6tK2X369Gk1atRIgwcPVuvWrRUQEKBffvlFixYtUlBQkB5//HHrss78TNSqVSv17NlTsbGxCg4O1qZNm7R8+XLrZ8fKqH///tbhiwIDA/Xqq6+Wq72+fftq9uzZ6t27t/75z3/q6NGjmjNnjpo1a2Yz/n6zZs306KOP6sknn1T37t116623ysfHRz/++KMiIyOVnJws6a+/pXnz5umpp55Ss2bNFBYWpuuuu04PP/yw/vOf/6hPnz669957FRwcbM3YFStWOGVY3L179yo+Pl6DBw9WixYt5OnpqU2bNuntt99W48aNdd9991mXPXz4sFq2bKnhw4frzTfftE6fNWuW+vXrp169emnIkCHavn27XnnlFd11113WvyvYyUC1M3XqVEOSsXPnTmPgwIFG7dq1jbp16xoTJkwwzp49a13uo48+Mtq2bWv4+voajRs3NmbMmGEsXLjQkGTs37/fMAzD2LJlizF06FDjsssuM3x8fIywsDDjpptuMjZt2lRiu6+99poRGxtr+Pn5GbVr1zbatGljTJo0yfjzzz+ty8TFxRlxcXHW+/v37zckGYsWLbJOGz58uBEQEHDB/XJkuxeTm5trPPjgg0a7du2M2rVrGwEBAUa7du2MuXPnllj222+/NW644Qbrcm3btjVefvll6/xDhw4Z//jHP4w6deoYQUFBxqBBg4w///zTkGRMnTrVutyiRYtsHudia9euNRISEoygoCDD19fXiI6ONkaMGFHq430hxY/prFmzSswr3q4kIzMz02be0qVLjauuusrw8fExgoODjdtvv904dOiQzTKV9bmJi4szWrduXWL94cOHG1FRUdb7a9euNSQZy5YtK7Fs8by1a9c6rd1JkyYZkoxXXnmlTPtrGIYRFRVl9O3b12ZaUVGR8cwzzxhRUVGGj4+PcdVVVxmffPJJiX4YhmEUFBQYs2bNMlq0aGF4e3sboaGhRp8+fYzNmzdbl9m9e7fRo0cPw8/Pz5BkDB8+3Dpvy5YtRkJCglGrVi3D39/fuPbaa43vv//eZhvFr6Mff/yxzPtV7LfffjOGDRtmNG3a1PDz8zN8fX2N1q1bG1OnTjVOnz5ts2zx43r+306x1157zbjiiisMb29v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",
      "text/plain": [
       "<Figure size 1500x500 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "def group_by_bins(c, d, B):\n",
    "    # Find the bin edges based on the range of d and bin size B\n",
    "    min_d, max_d = np.min(d), np.max(d)\n",
    "    bin_edges = np.arange(min_d, max_d + B, B)\n",
    "    \n",
    "    # Digitize d into the bins\n",
    "    bin_indices = np.digitize(d, bin_edges)\n",
    "    \n",
    "    # Group the values of c based on the bin indices of d\n",
    "    grouped_c = {}\n",
    "    for i in range(1, len(bin_edges)):\n",
    "        grouped_c[bin_edges[i-1]] = c[bin_indices == i]\n",
    "    \n",
    "    return grouped_c\n",
    "\n",
    "def plot_grouped_data(ax, grouped_c, B, name):\n",
    "    # Extract bin centers and the mean of grouped values for plotting\n",
    "    bins = list(grouped_c.keys())\n",
    "    means = [np.mean(group) if len(group) > 0 else 0 for group in grouped_c.values()]\n",
    "    \n",
    "    # Plot on the specified subplot axis\n",
    "    ax.bar(bins, means, width=B, align='edge', edgecolor='black', alpha=0.7)\n",
    "    \n",
    "    # Set xticks at 0% and 100%\n",
    "    ax.set_xticks([bins[0], bins[-1]])\n",
    "    ax.set_xticklabels(['0%', '100%'])\n",
    "    \n",
    "    # Set axis labels and title\n",
    "    ax.set_xlabel('Distance')  # Set xlabel for each subplot\n",
    "    ax.set_ylabel('Pairwise Correlation')\n",
    "    ax.set_title(f'{name}')\n",
    "    ax.set_ylim(0, 0.4)\n",
    "    \n",
    "    # Disable upper and right spines\n",
    "    ax.spines['right'].set_visible(False)\n",
    "    ax.spines['top'].set_visible(False)\n",
    "\n",
    "# List of model names\n",
    "model_names = [\n",
    "    \"baseline_scale_None_shrink_factor_3.0\",\n",
    "    \"all_topo_scale_1_shrink_factor_3.0\",\n",
    "    \"all_topo_scale_30_shrink_factor_3.0\"\n",
    "]\n",
    "\n",
    "B = 3\n",
    "\n",
    "# Create a figure with a horizontal row of subplots\n",
    "fig, axes = plt.subplots(1, len(model_names), figsize=(15, 5), constrained_layout=True)\n",
    "\n",
    "for i, model_name in enumerate(model_names):\n",
    "    all_corr, all_dist = [], []\n",
    "    \n",
    "    for layer_name in raw_data[model_name].keys():\n",
    "        correlations = raw_data[model_name][layer_name][\"lower_triangle_correlations\"]\n",
    "        distances = raw_data[model_name][layer_name][\"lower_triangle_distances\"]\n",
    "        all_corr.extend(correlations)\n",
    "        all_dist.extend(distances)\n",
    "    \n",
    "    all_corr = np.array(all_corr)\n",
    "    all_dist = np.array(all_dist)\n",
    "    \n",
    "    # Group the correlation data by distance bins\n",
    "    grouped_data = group_by_bins(c=all_corr, d=all_dist, B=B)\n",
    "    \n",
    "    # Plot the data in the corresponding subplot\n",
    "    plot_grouped_data(axes[i], grouped_data, B, model_name)\n",
    "\n",
    "# Display the final figure with all subplots\n",
    "plt.show()\n",
    "fig.savefig(\"resnet50_distance_vs_corr.pdf\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f7898044-55f1-462a-af70-a012a92bb120",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.9.19"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
