{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 955,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import matplotlib\n",
    "import matplotlib.pyplot as plt\n",
    "from matplotlib.axes import Axes\n",
    "from matplotlib.figure import Figure\n",
    "from collections import Counter\n",
    "matplotlib.rcParams['text.usetex'] = True\n",
    "matplotlib.rcParams['text.latex.preamble'] = r'\\usepackage{amsmath}'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 957,
   "metadata": {},
   "outputs": [],
   "source": [
    "l2s = range(10)\n",
    "borders = range(10)\n",
    "centers = [0, 1, 2, 4, 5, 6, 7, 8, 9]\n",
    "l2_files = [\n",
    "    torch.load(f'./trained_models/distances_l2_border_stl10_perturb_0.{i}.pt')\n",
    "    for i in l2s\n",
    "]\n",
    "border_files = [\n",
    "    torch.load(f'./trained_models/distances_border_stl10_perturb_0.{i}.pt')\n",
    "    for i in borders\n",
    "]\n",
    "center_files = [\n",
    "    torch.load(f'./trained_models/distances_center_stl10_perturb_0.{i}.pt')\n",
    "    for i in centers\n",
    "]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 958,
   "metadata": {},
   "outputs": [],
   "source": [
    "deltas = [0.1, 0.05, 0.005]\n",
    "l2_delta_mems = {delta : [torch.sum(l2_files[i] / 30 < delta) for i in range(len(l2_files))] for delta in deltas}\n",
    "border_delta_mems = {delta : [torch.sum(border_files[i] < delta) for i in range(len(border_files))] for delta in deltas}\n",
    "center_delta_mems = {delta : [torch.sum(center_files[i] < delta) for i in range(len(center_files))] for delta in deltas}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 959,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Delta: 0.1; Border: 1879; Center: 1927\n",
      "L2: 10000\n",
      "Delta: 0.05; Border: 977; Center: 1011\n",
      "L2: 1095\n",
      "Delta: 0.005; Border: 81; Center: 107\n",
      "L2: 0\n"
     ]
    }
   ],
   "source": [
    "for delta in deltas:\n",
    "    print(f\"Delta: {delta}; Border: {border_delta_mems[delta][0]}; Center: {center_delta_mems[delta][0]}\")\n",
    "    print(f\"L2: {l2_delta_mems[delta][0]}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 960,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "for i, delta in enumerate(deltas):\n",
    "    plt.plot(l2s, l2_delta_mems[delta], label=delta)\n",
    "plt.legend(title=\"Delta\")\n",
    "plt.title(\"$\\\\bar{\\ell}_2$ Delta-Eidetic Memorizations over GNI Perturbation\")\n",
    "plt.xlabel(\"Magnitude\")\n",
    "plt.ylabel(\"Memorizations\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 961,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 700x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "deltas = [0.05, 0.005]\n",
    "plt.figure(figsize=(7, 6))\n",
    "for i, delta in enumerate(deltas):\n",
    "    plt.plot([border / 10 for border in borders], border_delta_mems[delta], label=delta)\n",
    "leg=plt.legend(title=r\"$\\boldsymbol{\\delta}$\",fontsize=14)\n",
    "plt.setp(leg.get_title(),fontsize='15')\n",
    "plt.title(r\"$\\textsc{SolidMark}$ $\\boldsymbol{\\delta}$-Eidetic Memorizations over GNI Perturbation\", fontsize=17)\n",
    "plt.xlabel(\"Perturbation Magnitude\", fontsize=15)\n",
    "plt.ylabel(r\"$(\\ell_{\\text{SM}}, \\boldsymbol{\\delta})$-Eidetic Memorizations\", fontsize=15)\n",
    "plt.tick_params(axis='both', which='major', labelsize=15)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 962,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjsAAAHBCAYAAACPN3q5AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuNSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/xnp5ZAAAACXBIWXMAAA9hAAAPYQGoP6dpAAA+YElEQVR4nO3dT3Ab6WH3+R9IkZQoiWyA0vxRRjPDxkycdXY3NkCd3pMtoHLYU8oAVak9bVUIJDmmbGG4h035PYSGag57WguYnPayJQH2cascQsppq7ZKImb8bsWxPcPWeJRIMx4JAEmJEv/2HkC0ABAAQRAQwOb3U4XCn250P90NNH54nqe7PbZt2wIAAHCpoX4XAAAAoJcIOwAAwNUIOwAAwNUIOwAAwNUIOwAAwNUIOwAAwNUIOwAAwNUIOwAAwNUIOwAAwNUIO69BqVRSIpFQMBiUx+OR1+tVNBqVZVn9Llpbbty44ZTb6/XK4/HI7/frxo0b/S5aVzRbvkQicehphcPhjt7Xjko5G93C4bAzXjAYVDwebzqdfD4vj8dzpLIcNI+DpNNpeTweRaPRpuMkEgl5PJ6erc+jOOryD8o8jpN4PF7z/YzH4zX70Mr3IxgM7ntvOp2W3+93nicSCXm93gPneVz2fb3a77jpM3iq3wVwO8uyFA6HZZqmksmkZmZmZFmWUqmUSqVSv4vXNsMwVCwWnef5fF5zc3O6d++eMplMH0vWHY2WL5FIyO/3a3FxUaZp9rF0ZU+fPpVhGHrw4EHL8ebn52UYRk/L0o15GIahbDbbdHg6ne75cnTquKxjN6jeh2YyGc3MzOj+/ftKpVLKZrO6fv26M65hGMrn88rn8woEAl2Zv9v3fa246TNIzU6PhcNhBQIBLS4uKhQKyTAMBQIBpVKprnwZc7lczT+W1yUQCCiTySibzSqfz7f1nmZl7dcytFLZZqZpHumfTS+WzTCMhreKSCSiUCjUlXk1K3835uHz+RQIBBoGnlwuJ5/PNxAhs5Hjso7dIBqNyjTNmn1oKBRSJpOpCTqSZJqmIpFIT2sDO9n31Ru0fd5J+AwSdnoonU7Lsix98skn/S5KT5imKcMwdP/+/X4XpWdSqZRyuZxyuVy/i+JK165dUyqV2vd6JpNRJBLpQ4kwSCqBotFnpJlkMqlcLtdxEGnHSdj3uQ1hp4eq/4kcpNIe7ff7lU6nndej0ahu3LhRM7zywxuNRhUOh2VZltN3o7pprNU00+m0047d6Q+5ZVkqlUqamZmRVN4xVfol+f3+mn/szcra7WVotb46YZqm86+yWrNyVWu1bK3W1VHVt9+XSiWFw2GnP0Oj9dFoeVqVv1EfgRs3bsjv97ecT71IJKJcLrevSTedTjetUTvsd6Xyr7VZH6FKc6XX6903z2afs+rlz2azDftRVcrWyfei2To+qKytPvuVfirtbp9m84rH4/vWY30/sG7te27duqVAIHCoGj7TNBUKhbSwsND2ew6rft93mOU9zDavX6+t1l+pVKopR/XnbFA+g31lo2dM07RjsdiB40UiETsUCtnFYtFeXl62DcOwl5aWbNu27VAoZEuyFxcX7WKxaEciEds0Tee9mUym5nm70wwEArZpmnYmkzmwfMlk0jYMo+a1xcVF2zRNOxKJOK+lUilnHouLi7Yk53mrsnZzGQ5aX+0uX7VQKFSznAeV6/r16wcu20HrqpHr16/bkhreFhcXa8pbXYbKulpeXnbWSfVXv9XyNCt//TxisZgdCATspaUlu1gs2ouLiy0/W6lUypluIBCwU6lUw3UWCARq5nPY74phGHYkErGLxaK9tLRkS6qZV2V61esmFArtW3eNPmfV5aoWi8Vq1lmn34v6ebRT1maf/cr3tVgsOs9bfd5azauyDPXLXPmOdHPfEwgE2tqH2nb5exwIBGzbtp1tvby8bNt27efNtsvfpVbf+eppHrTv62R5293mleWoHt7s81iZb7FYdPYV1cvf789gvxF2eqidsLO8vGxLcnZCtl3+YFY+YJUPd0X9jqbRh7SdaRqGUTO8lWQyue/HNRAI2MlksuX7TNOsGecwYafTZThofTVbvoPCTuUL3U652gk79erXVSPt7qCry1Apb2WnZ9u1O9CDlqednWCxWNw3j4NU//ikUqmabRaJRJx1UR12Ov2uVAfB6ulV1kP9Z8gwDOc9rT5njcJOO8G13e9F9TzaLWuzz34mk2nrs9PuvAzDqPmxrTzv9r7HNM2mobJeddix7dqgdJSw02rf1+nyHiXstPt5bLXu+vEZ7DeOxuqhQCBw4OHllXbl6enpmtcr1aP1j30+34HzbWea7TavVdQfkdBMOp3W4uKiLMs60qH1R1mGw66vg1iW5fQfaadc7erWumoln8/LMIymzQDd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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "for i, delta in enumerate(deltas):\n",
    "    plt.plot(centers, center_delta_mems[delta], label=delta)\n",
    "plt.legend(title=\"Delta\")\n",
    "plt.title(\"Center Pattern Delta-Eidetic Memorizations over GNI Perturbation\")\n",
    "plt.xlabel(\"Perturbation Magnitude\")\n",
    "plt.ylabel(\"Memorizations\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 986,
   "metadata": {},
   "outputs": [],
   "source": [
    "distances_avg = [\n",
    "    torch.load(f'./trained_models/distances_sd_dup_avg_{i}.pt', map_location='cpu') for i in range(1, 10)\n",
    "]\n",
    "distances_nearest = [\n",
    "    torch.load(f'./trained_models/distances_sd_dup_nearest_{i}.pt', map_location='cpu') for i in range(1, 10)\n",
    "]\n",
    "mems = [\n",
    "    torch.load(f'./trained_models/distances_sd_dup_mem_{i}.pt', map_location='cpu') for i in range(1, 10)\n",
    "]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 987,
   "metadata": {},
   "outputs": [],
   "source": [
    "deltas = [0.1, 0.05, 0.005]\n",
    "avgs_deltas = {\n",
    "    delta : [\n",
    "        torch.sum(v < delta) for v in distances_avg\n",
    "    ] for delta in deltas\n",
    "}\n",
    "nrst_deltas = {\n",
    "    delta : [\n",
    "        torch.sum(v < delta) for v in distances_nearest\n",
    "    ] for delta in deltas\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 990,
   "metadata": {},
   "outputs": [],
   "source": [
    "mems_per_delta = {delta: [] for delta in deltas}\n",
    "for delta in deltas:\n",
    "    for i in range(len(mems)):\n",
    "        mems_per_delta[delta].append([mems[i][j].item() if distances_nearest[i][j] < delta else -1 for j in range(mems[i].size(0))])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 992,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[[0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, -1, -1, -1, 0, -1, -1, -1], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [-1, -1, -1, -1, 0, -1, -1, 0, -1, 0], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [0, -1, -1, -1, -1, -1, 0, 0, -1, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [0, 0, 0, -1, 0, -1, 0, 0, -1, -1], [0, -1, -1, -1, -1, -1, -1, -1, -1, 0], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [-1, -1, -1, -1, -1, 0, -1, -1, -1, -1], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [0, -1, -1, -1, -1, -1, -1, 0, -1, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [-1, -1, 0, -1, 0, -1, -1, -1, -1, -1], [0, 0, 0, -1, 0, 0, -1, -1, -1, -1], [0, -1, 0, 0, 0, -1, -1, 0, 0, 0], [-1, -1, -1, 0, 0, 0, -1, -1, 0, -1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [-1, 0, 0, 0, -1, -1, -1, -1, -1, -1], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [0, 0, 0, 0, 0, -1, 0, 0, 0, 0], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [-1, -1, -1, -1, -1, -1, -1, 0, -1, -1], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [0, 0, 0, 0, 0, 0, -1, -1, 0, 0], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [0, -1, -1, -1, -1, -1, -1, 0, -1, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, -1, 0, 0, 0, 0, 0, 0], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [0, 0, 0, 0, 0, 0, 0, 0, -1, -1], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1]], [[0, 0, 0, 0, -1, 0, -1, 0, 0, 0], [0, 0, 0, 0, -1, -1, 0, 0, 0, 0], [0, 0, 0, -1, 0, 0, 0, 0, 0, 0], [-1, -1, -1, -1, -1, 0, -1, -1, -1, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [0, 0, 0, 0, 0, -1, -1, 0, 0, -1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [-1, 0, 0, -1, 0, 0, 0, 0, -1, -1], [-1, -1, 0, -1, -1, -1, -1, -1, -1, -1], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [0, 0, 0, -1, 0, 0, -1, 0, 0, 0], [0, 0, -1, 0, 0, 0, 0, 0, 0, 0], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [-1, 0, -1, 0, 0, 0, -1, 0, -1, 0], [-1, -1, -1, -1, -1, -1, 0, -1, -1, -1], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [0, -1, -1, -1, -1, -1, -1, -1, -1, -1], [-1, 0, -1, 0, 0, 0, 0, 0, -1, 0], [0, -1, -1, -1, -1, -1, -1, -1, 0, -1], [-1, -1, -1, -1, 0, 0, -1, -1, -1, -1], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [-1, -1, -1, -1, -1, 0, 0, -1, -1, 0], [0, 0, 0, -1, -1, -1, 0, 0, -1, -1], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [0, -1, -1, 0, -1, 0, -1, 0, 0, -1], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [0, 0, 0, 0, 0, -1, 0, 0, 0, 0], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [-1, -1, -1, -1, -1, 0, -1, -1, -1, -1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, -1, -1, 0, -1, -1, 0, -1, -1, 0], [-1, -1, -1, -1, -1, -1, -1, -1, 0, -1], [0, 0, -1, 0, -1, 0, -1, 0, 0, 0], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [-1, 0, 0, 0, 0, 0, 0, 0, 0, -1], [0, 0, -1, 0, 0, -1, 0, 0, 0, 0], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [0, 0, -1, 0, 0, 0, 0, -1, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1]], [[0, 0, 0, 0, 0, 0, 0, 0, -1, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, -1, 0, -1, 0, 0, 0, 0, 0, 0], [-1, -1, -1, -1, -1, -1, -1, -1, 0, -1], [0, 0, 0, 0, -1, -1, -1, 0, 0, 0], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, -1, 0, 0, 0, 0, 0, 0, 0, 0], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [-1, -1, -1, -1, 0, -1, -1, -1, 0, -1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [-1, -1, -1, -1, -1, -1, -1, -1, 0, -1], [0, -1, -1, -1, -1, -1, -1, -1, 0, -1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [-1, -1, 0, 0, -1, -1, -1, -1, -1, 0], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [-1, 0, -1, 0, 0, -1, -1, -1, -1, -1], [0, -1, -1, 0, 0, 0, 0, -1, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [-1, -1, 0, 0, 0, 0, 0, 0, 0, 0], [-1, -1, -1, 0, -1, -1, -1, -1, -1, -1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, -1, -1, 0, -1, -1, -1, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [-1, -1, -1, -1, 0, -1, 0, -1, -1, -1], [0, 0, 0, 0, 0, -1, -1, 0, 0, -1], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [-1, -1, -1, -1, -1, -1, -1, 0, -1, -1], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [0, 0, 0, 0, 0, 0, 0, 0, 0, -1], [0, 0, 0, 0, 0, 0, 0, 0, 0, -1], [0, 0, -1, 0, 0, -1, 0, 0, 0, 0], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [-1, -1, -1, -1, -1, -1, -1, 0, -1, -1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [-1, -1, -1, -1, -1, 0, -1, -1, -1, 0], [-1, -1, -1, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0]], [[-1, 0, -1, 0, -1, 0, 0, 0, 0, 0], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [0, 0, 0, -1, 0, -1, 0, 0, 0, -1], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [-1, -1, -1, -1, -1, -1, -1, -1, -1, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [-1, -1, 0, -1, -1, -1, 0, 0, 0, -1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, -1, -1, -1, 0, -1, 0, -1], [0, -1, 0, 0, 0, 0, 0, -1, 0, -1], [-1, -1, -1, -1, -1, 0, -1, -1, -1, -1], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [0, 0, 0, -1, -1, -1, 0, 0, 0, 0], [-1, -1, -1, -1, -1, 0, 0, 0, -1, -1], [-1, -1, -1, -1, -1, -1, -1, -1, -1, 0], [-1, -1, -1, -1, -1, -1, -1, -1, 0, -1], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [0, -1, -1, 0, 0, 0, 0, 0, 0, 0], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [-1, -1, -1, -1, -1, -1, -1, -1, -1, 0], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [0, 0, -1, 0, 0, 0, 0, -1, 0, 0], [-1, -1, -1, -1, -1, -1, -1, 0, -1, -1], [0, -1, -1, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [-1, -1, 0, 0, -1, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, -1, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, -1, -1, 0, 0, -1, 0, 0, -1, -1], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [-1, -1, 0, -1, 0, 0, 0, 0, 0, -1], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0]], [[0, -1, -1, -1, -1, 0, -1, -1, 0, -1], [0, 0, 0, 0, 0, 0, -1, 0, 0, 0], [0, 0, 0, 0, 0, -1, 0, 0, 0, 0], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [0, 0, 0, 0, -1, 0, 0, 0, 0, 0], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [-1, -1, -1, -1, -1, -1, 0, -1, 0, -1], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [0, 0, 0, 0, 0, 0, 0, 0, -1, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, -1], [0, -1, -1, -1, -1, -1, -1, -1, 0, -1], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, -1, 0, -1, 0, 0], [-1, 0, -1, 0, -1, 0, -1, 0, -1, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [-1, 0, -1, -1, -1, -1, -1, -1, -1, -1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [-1, -1, -1, -1, -1, -1, 0, -1, -1, -1], [-1, 0, -1, 0, 0, 0, 0, 0, 0, -1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [-1, -1, -1, -1, -1, -1, -1, -1, 0, -1], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [0, -1, 0, -1, 0, -1, -1, -1, 0, -1], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [-1, -1, -1, 0, 0, -1, 0, 0, 0, 0], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [-1, 0, 0, 0, 0, 0, 0, 0, 0, 0], [-1, 0, 0, -1, 0, 0, 0, 0, 0, 0], [0, 0, 0, -1, 0, -1, 0, 0, 0, 0], [0, 0, -1, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [0, -1, 0, 0, 0, 0, -1, 0, 0, 0], [-1, -1, 0, 0, 0, 0, 0, -1, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, -1], [0, 0, 0, 0, 0, 0, 0, 0, 0, -1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [0, 0, 0, 0, 0, 0, 0, 0, 0, -1], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1]], [[-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [-1, -1, -1, 0, -1, -1, -1, -1, 0, -1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, -1], [-1, -1, -1, -1, -1, -1, -1, 0, -1, 0], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [-1, 0, 0, 0, -1, 0, 0, 0, 0, 0], [0, 0, -1, -1, 0, -1, -1, -1, -1, -1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [-1, -1, -1, 0, -1, -1, 0, -1, -1, 0], [0, 0, -1, 0, 0, 0, 0, 0, 0, 0], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [0, 0, 0, -1, 0, 0, 0, 0, 0, 0], [-1, -1, 0, -1, 0, -1, 0, -1, -1, -1], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, -1, 0, 0, 0, -1, -1, 0, -1, -1], [-1, -1, 0, 0, 0, -1, -1, 0, 0, -1], [0, -1, -1, -1, -1, 0, -1, 0, 0, -1], [-1, 0, 0, 0, 0, 0, 0, -1, 0, -1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, -1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [-1, 0, -1, 0, -1, -1, -1, -1, 0, -1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [-1, -1, -1, -1, 0, -1, -1, -1, -1, -1], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [0, 0, -1, 0, -1, 0, -1, 0, 0, -1], [-1, -1, -1, 0, -1, 0, 0, 0, -1, -1], [-1, -1, 0, -1, 0, -1, -1, -1, 0, 0], [-1, 0, -1, -1, -1, -1, -1, -1, -1, -1], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [0, 0, 0, 0, 0, 0, 0, 0, 0, -1]], [[0, -1, -1, 0, 0, 0, 0, -1, -1, 0], [-1, -1, -1, -1, -1, 0, -1, -1, -1, -1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [-1, 0, -1, 0, 0, -1, 0, 0, 0, 0], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [0, 0, 0, 0, 0, -1, 0, -1, 0, 0], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [-1, -1, -1, -1, 0, -1, 0, -1, -1, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, -1, 0, 0, 0, -1, 0, 0, 0, 0], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [0, 0, 0, 0, -1, 0, 0, -1, 0, 0], [0, 0, -1, 0, -1, 0, -1, -1, -1, -1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [-1, 0, -1, 0, 0, 0, 0, -1, -1, 0], [0, -1, 0, -1, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, -1, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, -1, 0], [-1, -1, -1, 0, -1, -1, -1, 0, 0, -1], [-1, -1, 0, 0, 0, 0, 0, 0, -1, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, -1, 0, -1, -1, 0, 0, 0, 0, 0], [-1, 0, -1, -1, -1, 0, 0, 0, 0, -1], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [0, 0, -1, 0, -1, -1, 0, -1, 0, 0], [0, 0, 0, -1, -1, 0, 0, 0, 0, 0], [-1, -1, 0, -1, -1, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, -1, -1, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [-1, -1, -1, -1, 0, -1, -1, -1, -1, 0], [-1, -1, -1, 0, -1, 0, -1, 0, -1, -1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [0, 0, 0, 0, -1, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, -1, 0], [-1, -1, -1, 0, -1, -1, 0, 0, 0, -1], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [0, -1, -1, -1, -1, -1, -1, 0, -1, -1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [-1, 0, 0, -1, 0, 0, -1, 0, 0, 0], [-1, -1, -1, -1, -1, -1, 0, -1, -1, -1], [0, 0, 0, -1, 0, 0, 0, 0, 0, 0]], [[-1, -1, -1, 0, 0, 0, -1, -1, 0, -1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, -1, 0, 0, 0, -1, 0, 0, -1], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [0, -1, -1, 0, 0, -1, 0, 0, 0, -1], [0, -1, 0, 0, 0, -1, -1, -1, -1, 0], [-1, -1, 0, -1, -1, -1, 0, -1, -1, 0], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [-1, -1, -1, -1, -1, -1, 0, -1, -1, -1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [-1, -1, -1, -1, -1, -1, -1, -1, 0, -1], [0, -1, 0, -1, 0, 0, 0, -1, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [-1, 0, 0, 0, 0, 0, 0, 0, -1, 0], [0, -1, 0, -1, 0, 0, -1, 0, 0, 0], [-1, 0, -1, -1, 0, -1, 0, 0, -1, -1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [-1, 0, 0, -1, 0, -1, 0, 0, 0, 0], [-1, 0, -1, -1, 0, -1, -1, -1, 0, 0], [-1, -1, 0, 0, 0, 0, 0, 0, 0, 0], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [0, 0, -1, 0, 0, 0, 0, -1, 0, -1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, -1, -1, 0, -1, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [-1, 0, 0, 0, 0, -1, -1, 0, -1, 0], [0, -1, -1, -1, 0, -1, -1, -1, 0, -1], [0, -1, 0, -1, 0, -1, 0, 0, 0, -1], [-1, -1, 0, 0, 0, 0, 0, 0, 0, 0], [-1, -1, -1, -1, -1, 0, -1, -1, -1, -1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, -1, 0, 0, 0, 0, 0, 0, 0], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [0, 0, 0, 0, 0, 0, 0, 0, 0, -1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [-1, 0, 0, 0, 0, 0, 0, 0, 0, 0], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1]], [[0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, -1, 0, 0, 0, -1, 0, 0], [0, -1, -1, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [-1, 0, 0, 0, 0, 0, 0, 0, 0, -1], [0, 0, -1, -1, 0, 0, -1, 0, -1, 0], [-1, -1, -1, -1, -1, -1, 0, -1, 0, -1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [-1, -1, 0, 0, -1, 0, -1, -1, -1, 0], [0, 0, -1, -1, 0, -1, -1, -1, 0, -1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, -1, 0, 0, 0, 0, 0], [-1, 0, -1, 0, 0, -1, 0, 0, 0, -1], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [-1, -1, 0, -1, 0, 0, 0, -1, -1, -1], [0, 0, -1, -1, -1, 0, 0, 0, -1, -1], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [-1, -1, -1, -1, -1, 0, -1, -1, -1, -1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [-1, 0, 0, 0, 0, -1, 0, 0, 0, -1], [0, -1, -1, 0, 0, 0, 0, 0, -1, 0], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [0, 0, 0, 0, 0, 0, -1, 0, 0, -1], [-1, -1, -1, 0, -1, 0, 0, 0, -1, -1], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [-1, 0, -1, -1, -1, -1, -1, 0, -1, -1], [-1, 0, -1, -1, 0, -1, -1, -1, -1, 0], [-1, -1, -1, -1, 0, -1, 0, 0, -1, -1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [0, 0, -1, 0, 0, 0, 0, -1, 0, -1], [-1, -1, -1, -1, -1, -1, -1, 0, -1, -1], [0, 0, 0, 0, 0, 0, 0, -1, 0, 0], [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [-1, 0, 0, 0, -1, -1, -1, -1, -1, -1], [-1, 0, 0, -1, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0]]]\n"
     ]
    }
   ],
   "source": [
    "avgs_per_delta = {delta: [] for delta in deltas}\n",
    "for delta in deltas:\n",
    "    for i in range(len(mems)):\n",
    "        avgs_per_delta[delta].append([0 if distances_avg[i][j] < delta else -1 for j in range(mems[i].size(0))])\n",
    "avgs_per_delta = {\n",
    "    k : [[lst[x:x+10] for x in range(0, len(lst), 10)] for lst in v] for k, v in avgs_per_delta.items()\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 993,
   "metadata": {},
   "outputs": [],
   "source": [
    "mems_per_delta = {\n",
    "    k : [[lst[x:x+10] for x in range(0, len(lst), 10)] for lst in v] for k, v in mems_per_delta.items()\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 994,
   "metadata": {},
   "outputs": [],
   "source": [
    "def avg(iterable):\n",
    "    return sum(iterable) / len(iterable)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 995,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{0.1: [6.037037037037037,\n",
       "  7.594594594594595,\n",
       "  7.45945945945946,\n",
       "  8.409090909090908,\n",
       "  7.8,\n",
       "  8.209302325581396,\n",
       "  9.108695652173912,\n",
       "  9.090909090909092,\n",
       "  9.729166666666666],\n",
       " 0.05: [3.7777777777777777,\n",
       "  5.9,\n",
       "  5.714285714285714,\n",
       "  6.102564102564102,\n",
       "  5.868421052631579,\n",
       "  5.9411764705882355,\n",
       "  7.068181818181818,\n",
       "  6.682926829268292,\n",
       "  7.808510638297872],\n",
       " 0.005: [1.2,\n",
       "  1.1538461538461537,\n",
       "  1.8333333333333333,\n",
       "  1.5,\n",
       "  2.0,\n",
       "  1.5333333333333334,\n",
       "  1.8518518518518519,\n",
       "  1.9523809523809523,\n",
       "  2.107142857142857]}"
      ]
     },
     "execution_count": 995,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "conf_per_delta = {\n",
    "    delta: [[sum(instance != -1 for instance in ten) for ten in dup] for dup in mems_per_delta[delta]] for delta in deltas\n",
    "}\n",
    "conf_per_delta = {\n",
    "    delta: [avg([ten for ten in dup if ten != 0]) for dup in conf_per_delta[delta]] for delta in deltas\n",
    "}\n",
    "conf_per_delta"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 996,
   "metadata": {},
   "outputs": [],
   "source": [
    "uniques_per_delta = {\n",
    "    k : [[len(set(keys)) - 1 for keys in dup] for dup in v] for k, v in mems_per_delta.items()\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 997,
   "metadata": {},
   "outputs": [],
   "source": [
    "freqs_per_delta = {\n",
    "    k : [dict(Counter(uniques)) for uniques in v] for k, v in uniques_per_delta.items()\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 999,
   "metadata": {},
   "outputs": [],
   "source": [
    "found_per_delta = {\n",
    "    delta: [sum([instance > 0 for instance in dup]) for dup in uniques_per_delta[delta]] for delta in deltas\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1000,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{0.1: [25, 28, 28, 34, 39, 34, 38, 38, 41],\n",
       " 0.05: [18, 30, 28, 36, 37, 32, 42, 41, 46],\n",
       " 0.005: [5, 13, 12, 18, 16, 15, 27, 21, 28]}"
      ]
     },
     "execution_count": 1000,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "found_per_delta"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1001,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{0.1: [50, 56, 56, 68, 78], 0.05: [36, 60, 56, 72, 74], 0.005: [10, 26, 24, 36, 32]}\n"
     ]
    }
   ],
   "source": [
    "print({\n",
    "    delta: [f * 2 for f in found_per_delta[delta]][:5] for delta in deltas\n",
    "})"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1002,
   "metadata": {},
   "outputs": [],
   "source": [
    "found_avgs_per_delta = {\n",
    "    delta: [sum([0 in instance for instance in dup]) for dup in avgs_per_delta[delta]] for delta in deltas\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1003,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{0.1: [25, 33, 35, 31, 36, 34, 40, 36, 39],\n",
       " 0.05: [17, 25, 28, 24, 31, 25, 31, 27, 31],\n",
       " 0.005: [5, 9, 7, 3, 12, 11, 10, 11, 8]}"
      ]
     },
     "execution_count": 1003,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "found_avgs_per_delta"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1015,
   "metadata": {},
   "outputs": [],
   "source": [
    "distances_crop = [\n",
    "    torch.load(f'./trained_models/distances_sd_crop_{i}_new.pt', map_location='cpu') for i in range(5)\n",
    "]\n",
    "rotation_angles = [350,355,357,358,359,1,2,3,5,10,15,180,270]\n",
    "baseline=distances_crop[0]\n",
    "distances_rotate = [baseline] + [\n",
    "    torch.load(f'./trained_models/distances_sd_rotate_{i}_new.pt', map_location='cpu') for i in rotation_angles\n",
    "]\n",
    "distances_blur = [baseline] + [\n",
    "    torch.load(f'./trained_models/distances_sd_blur_{i}_new.pt', map_location='cpu') for i in range(1, 5)\n",
    "]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1016,
   "metadata": {},
   "outputs": [],
   "source": [
    "deltas = [0.1, 0.05, 0.005]\n",
    "deltas_crop = {\n",
    "    delta: [torch.sum(dist < delta).item() for dist in distances_crop] for delta in deltas\n",
    "}\n",
    "deltas_rotate = {\n",
    "    delta: [torch.sum(dist < delta).item() for dist in distances_rotate] for delta in deltas\n",
    "}\n",
    "deltas_blur = {\n",
    "    delta: [torch.sum(dist < delta).item() for dist in distances_blur] for delta in deltas\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1017,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.1\n",
      "[1085, 1038, 1060, 1035, 1042]\n",
      "['0.00%', '-4.33%', '-2.30%', '-4.61%', '-3.96%']\n",
      "0.05\n",
      "[557, 549, 541, 552, 528]\n",
      "['0.00%', '-1.44%', '-2.87%', '-0.90%', '-5.21%']\n",
      "0.005\n",
      "[68, 58, 48, 49, 50]\n",
      "['0.00%', '-14.71%', '-29.41%', '-27.94%', '-26.47%']\n"
     ]
    }
   ],
   "source": [
    "for delta in deltas:\n",
    "    d = deltas_crop[delta]\n",
    "    print(delta)\n",
    "    print(deltas_crop[delta])\n",
    "    print([f\"{((a / d[0] - 1)) * 100:.2f}%\" for a in d])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1018,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "DELTA: 0.1\n",
      "\tRotation Angle 0 observed 1085 memorizations, a 0.00% reduction from baseline.\n",
      "\tRotation Angle -10 observed 1057 memorizations, a -2.58% reduction from baseline.\n",
      "\tRotation Angle -5 observed 1036 memorizations, a -4.52% reduction from baseline.\n",
      "\tRotation Angle -3 observed 1049 memorizations, a -3.32% reduction from baseline.\n",
      "\tRotation Angle -2 observed 1029 memorizations, a -5.16% reduction from baseline.\n",
      "\tRotation Angle -1 observed 1053 memorizations, a -2.95% reduction from baseline.\n",
      "\tRotation Angle 1 observed 1008 memorizations, a -7.10% reduction from baseline.\n",
      "\tRotation Angle 2 observed 1047 memorizations, a -3.50% reduction from baseline.\n",
      "\tRotation Angle 3 observed 1047 memorizations, a -3.50% reduction from baseline.\n",
      "\tRotation Angle 5 observed 1071 memorizations, a -1.29% reduction from baseline.\n",
      "\tRotation Angle 10 observed 1042 memorizations, a -3.96% reduction from baseline.\n",
      "\tRotation Angle 15 observed 1031 memorizations, a -4.98% reduction from baseline.\n",
      "\tRotation Angle 180 observed 1044 memorizations, a -3.78% reduction from baseline.\n",
      "\tRotation Angle 270 observed 1086 memorizations, a 0.09% reduction from baseline.\n",
      "DELTA: 0.05\n",
      "\tRotation Angle 0 observed 557 memorizations, a 0.00% reduction from baseline.\n",
      "\tRotation Angle -10 observed 531 memorizations, a -4.67% reduction from baseline.\n",
      "\tRotation Angle -5 observed 500 memorizations, a -10.23% reduction from baseline.\n",
      "\tRotation Angle -3 observed 544 memorizations, a -2.33% reduction from baseline.\n",
      "\tRotation Angle -2 observed 506 memorizations, a -9.16% reduction from baseline.\n",
      "\tRotation Angle -1 observed 540 memorizations, a -3.05% reduction from baseline.\n",
      "\tRotation Angle 1 observed 502 memorizations, a -9.87% reduction from baseline.\n",
      "\tRotation Angle 2 observed 528 memorizations, a -5.21% reduction from baseline.\n",
      "\tRotation Angle 3 observed 521 memorizations, a -6.46% reduction from baseline.\n",
      "\tRotation Angle 5 observed 531 memorizations, a -4.67% reduction from baseline.\n",
      "\tRotation Angle 10 observed 513 memorizations, a -7.90% reduction from baseline.\n",
      "\tRotation Angle 15 observed 510 memorizations, a -8.44% reduction from baseline.\n",
      "\tRotation Angle 180 observed 522 memorizations, a -6.28% reduction from baseline.\n",
      "\tRotation Angle 270 observed 532 memorizations, a -4.49% reduction from baseline.\n",
      "DELTA: 0.005\n",
      "\tRotation Angle 0 observed 68 memorizations, a 0.00% reduction from baseline.\n",
      "\tRotation Angle -10 observed 56 memorizations, a -17.65% reduction from baseline.\n",
      "\tRotation Angle -5 observed 59 memorizations, a -13.24% reduction from baseline.\n",
      "\tRotation Angle -3 observed 54 memorizations, a -20.59% reduction from baseline.\n",
      "\tRotation Angle -2 observed 51 memorizations, a -25.00% reduction from baseline.\n",
      "\tRotation Angle -1 observed 59 memorizations, a -13.24% reduction from baseline.\n",
      "\tRotation Angle 1 observed 51 memorizations, a -25.00% reduction from baseline.\n",
      "\tRotation Angle 2 observed 45 memorizations, a -33.82% reduction from baseline.\n",
      "\tRotation Angle 3 observed 47 memorizations, a -30.88% reduction from baseline.\n",
      "\tRotation Angle 5 observed 49 memorizations, a -27.94% reduction from baseline.\n",
      "\tRotation Angle 10 observed 46 memorizations, a -32.35% reduction from baseline.\n",
      "\tRotation Angle 15 observed 57 memorizations, a -16.18% reduction from baseline.\n",
      "\tRotation Angle 180 observed 47 memorizations, a -30.88% reduction from baseline.\n",
      "\tRotation Angle 270 observed 54 memorizations, a -20.59% reduction from baseline.\n"
     ]
    }
   ],
   "source": [
    "for delta in deltas:\n",
    "    print(\"DELTA:\", delta)\n",
    "    d = deltas_rotate[delta]\n",
    "    reds = [f\"{((a / d[0]) - 1) * 100:.2f}%\" for a in d]\n",
    "    angles = [0] + [r if r <= 270 else r - 360 for r in rotation_angles]\n",
    "    for i in range(len(d)):\n",
    "        print(f\"\\tRotation Angle {angles[i]} observed {d[i]} memorizations, a {reds[i]} reduction from baseline.\")\n",
    "        "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1008,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.1\n",
      "[1085, 1049, 1064, 1089, 1033]\n",
      "['0.00%', '-3.32%', '-1.94%', '0.37%', '-4.79%']\n",
      "0.05\n",
      "[557, 516, 503, 534, 506]\n",
      "['0.00%', '-7.36%', '-9.69%', '-4.13%', '-9.16%']\n",
      "0.005\n",
      "[68, 42, 45, 53, 62]\n",
      "['0.00%', '-38.24%', '-33.82%', '-22.06%', '-8.82%']\n"
     ]
    }
   ],
   "source": [
    "for delta in deltas:\n",
    "    d = deltas_blur[delta]\n",
    "    print(delta)\n",
    "    print(d)\n",
    "    print([f\"{((a / d[0]) - 1) * 100:.2f}%\" for a in d])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1009,
   "metadata": {},
   "outputs": [],
   "source": [
    "baseline = torch.load(\"trained_models/distances_sd_RNA_0_new.pt\", map_location='cpu')\n",
    "RNA = torch.load(\"trained_models/distances_sd_RNA_4_new.pt\", map_location='cpu')\n",
    "RT = torch.load(\"trained_models/distances_sd_RWA_4_new.pt\", map_location='cpu')\n",
    "CWR = torch.load(\"trained_models/distances_sd_CWR_4_new.pt\", map_location='cpu')\n",
    "GNI = torch.load(\"trained_models/distances_sd_gaussian_1_new.pt\", map_location='cpu')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1010,
   "metadata": {},
   "outputs": [],
   "source": [
    "deltas = [0.1, 0.05, 0.005]\n",
    "baseline_deltas = {\n",
    "    delta: torch.sum(baseline < delta).item() for delta in deltas\n",
    "}\n",
    "RT_deltas = {\n",
    "    delta: torch.sum(RT < delta).item() for delta in deltas\n",
    "}\n",
    "RT_change = {\n",
    "    delta: f\"{(RT_deltas[delta] * 100 / baseline_deltas[delta]) - 100:.2f}%\" for delta in deltas\n",
    "}\n",
    "RNA_deltas = {\n",
    "    delta: torch.sum(RNA < delta).item() for delta in deltas\n",
    "}\n",
    "RNA_change = {\n",
    "    delta: f\"{(RNA_deltas[delta] * 100 / baseline_deltas[delta]) - 100:.2f}%\" for delta in deltas\n",
    "}\n",
    "CWR_deltas = {\n",
    "    delta: torch.sum(CWR < delta).item() for delta in deltas\n",
    "}\n",
    "CWR_change = {\n",
    "    delta: f\"{(CWR_deltas[delta] * 100 / baseline_deltas[delta]) - 100:.2f}%\" for delta in deltas\n",
    "}\n",
    "GNI_deltas = {\n",
    "    delta: torch.sum(GNI < delta).item() for delta in deltas\n",
    "}\n",
    "GNI_change = {\n",
    "    delta: f\"{(GNI_deltas[delta] * 100 / baseline_deltas[delta]) - 100:.2f}%\" for delta in deltas\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1011,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Baseline:  {0.1: 1066, 0.05: 549, 0.005: 55}\n",
      "RT:  {0.1: 1072, 0.05: 539, 0.005: 58}\n",
      "RNA:  {0.1: 1036, 0.05: 513, 0.005: 55}\n",
      "CWR:  {0.1: 1074, 0.05: 533, 0.005: 56}\n",
      "GNI:  {0.1: 1066, 0.05: 517, 0.005: 53}\n",
      "RT Change:  {0.1: '0.56%', 0.05: '-1.82%', 0.005: '5.45%'}\n",
      "RNA Change:  {0.1: '-2.81%', 0.05: '-6.56%', 0.005: '0.00%'}\n",
      "CWR Change:  {0.1: '0.75%', 0.05: '-2.91%', 0.005: '1.82%'}\n",
      "GNI Change:  {0.1: '0.00%', 0.05: '-5.83%', 0.005: '-3.64%'}\n"
     ]
    }
   ],
   "source": [
    "print(\"Baseline: \", baseline_deltas)\n",
    "print(\"RT: \", RT_deltas)\n",
    "print(\"RNA: \", RNA_deltas)\n",
    "print(\"CWR: \", CWR_deltas)\n",
    "print(\"GNI: \", GNI_deltas)\n",
    "print(\"RT Change: \", RT_change)\n",
    "print(\"RNA Change: \", RNA_change)\n",
    "print(\"CWR Change: \", CWR_change)\n",
    "print(\"GNI Change: \", GNI_change)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1022,
   "metadata": {},
   "outputs": [],
   "source": [
    "celeba = torch.load('trained_models/distances_border_celeba_.pt', map_location='cpu')\n",
    "deltas = [0.1, 0.05, 0.005]\n",
    "celeba_deltas = {\n",
    "    delta: torch.sum(celeba < delta) for delta in deltas\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1023,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{0.1: tensor(924), 0.05: tensor(466), 0.005: tensor(37)}"
      ]
     },
     "execution_count": 1023,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "celeba_deltas"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1025,
   "metadata": {},
   "outputs": [],
   "source": [
    "pretrain_distances = torch.load('trained_models/distances_sd_pretrain_ckpt_562500.pt', map_location='cpu')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1028,
   "metadata": {},
   "outputs": [],
   "source": [
    "deltas = [0.1, 0.05, 0.005]\n",
    "pretrain_deltas = {\n",
    "    delta: torch.sum(pretrain_distances < delta) for delta in deltas\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1029,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{0.1: tensor(1988), 0.05: tensor(989), 0.005: tensor(105)}"
      ]
     },
     "execution_count": 1029,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "pretrain_deltas"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "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.11.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
