{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 332,
   "id": "e0081617-0b6b-47d6-8d62-8b687a76c8cf",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import os\n",
    "import matplotlib.pyplot as plt\n",
    "from PIL import Image\n",
    "\n",
    "def load_map(\n",
    "    checkpoint_name,\n",
    "    layer_index,\n",
    "    category = \"science\"\n",
    "):\n",
    "    filename = os.path.join(\n",
    "        \"assets\",\n",
    "        checkpoint_name,\n",
    "        f\"transformer.h.{layer_index}.mlp.c_fc/dprime\",\n",
    "        f\"{category}.npy\"\n",
    "    )\n",
    "    return np.load(filename)\n",
    "\n",
    "def threshold_map_binary(x, threshold):\n",
    "    x[x<threshold] = 0.\n",
    "    x[x!=0] = 1.\n",
    "    return x"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 333,
   "id": "1f247065-06e8-49d1-a46a-64f354b9bb00",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 334,
   "id": "0cd431d3-5268-4314-a752-45e8dc07f51f",
   "metadata": {},
   "outputs": [],
   "source": [
    "names = [\n",
    "    \"science\",\n",
    "    \"physics\",\n",
    "    \"chemistry\",\n",
    "    \"biology\",\n",
    "    \"quantum_mechanics\",\n",
    "    \"classical_mechanics\"\n",
    "]\n",
    "\n",
    "all_maps = {}\n",
    "\n",
    "for name in names:\n",
    "    all_maps[name] =  load_map(\n",
    "        checkpoint_name = \"topo_50\",\n",
    "        layer_index = 11,\n",
    "        category = name\n",
    "    )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 335,
   "id": "bcd03902-c944-448a-a601-f3f93172b3c6",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.colorbar.Colorbar at 0x7671bab0c770>"
      ]
     },
     "execution_count": 335,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.imshow(all_maps[\"science\"])\n",
    "plt.colorbar()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 336,
   "id": "21d0927b-f506-48ce-b980-040531384277",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.colorbar.Colorbar at 0x7671bd59b740>"
      ]
     },
     "execution_count": 336,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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hUxHR4cyMjJUWVnZ7etPPfWUnnvuOVVVVemtt97S1Vdfrby8PF24cGGAexpadXV1Kioq0oEDB7Rv3z5dvHhRd911lzo6OgLnrFixQrt379aOHTtUV1enU6dO6d577w1jr+2bOHGi1qxZo4aGBh06dEhz587VPffcoz/84Q+SBuczf9bbb7+tn//855oxY4apfTA/95e//GV99NFHgeONN94IvDZYn/u///u/NWfOHA0dOlS/+c1v9F//9V965plnNGrUqMA5Ufu77XLmwM4RLYwINWvWLKOoqCjwtc/nM1JTU43y8vIw9qr/SDJ27twZ+Nrv9xspKSnG008/HWg7d+6c4XQ6jX//938PQw/7z+nTpw1JRl1dnWEYl55z6NChxo4dOwLnvPPOO4Yko76+Plzd7BejRo0yXnzxxUH/zO3t7cbUqVONffv2GV/96leNZcuWGYYxuH/WZWVlRkZGRrevDebnXrlypXHbbbf1+Ho0/m5rbW01JBm51ywx/pfrkT4fudcsMSQZra2t4X6kLxSRmYOuri41NDQoNzc30BYXF6fc3FzV19eHsWcD5+TJk/J6vabvQXJysnJycgbd96C1tVWSNHr0aElSQ0ODLl68aHr29PR0TZo0adA8u8/n07Zt29TR0SG32z3on7moqEh333236fmkwf+zfu+995SamqovfelLeuCBB9TU1CRpcD/3r3/9a2VnZ+vv/u7vNG7cOM2cOVMbNmwIvB7Vv9tiKHMQkcHB2bNn5fP55HK5TO0ul0terzdMvRpYl59zsH8P/H6/li9frjlz5mj69OmSLj17QkKCRo4caTp3MDz7kSNHNHz4cDmdTj388MPauXOnpk2bNqifedu2bTp8+LDKy8uveG0wP3dOTo62bNmi6upqrVu3TidPntTtt9+u9vb2Qf3c77//vtatW6epU6dq7969euSRR/TP//zP+sUvfiEpyn+3+Q37R5RgtgLCqqioSEePHjWNxQ5mN9xwgxobG9Xa2qqXXnpJBQUFqqurC3e3+k1zc7OWLVumffv2KTExMdzdGVDz588P/PeMGTOUk5Oja6+9Vr/61a80bNiwMPasf/n9fmVnZ+vJJ5+UJM2cOVNHjx5VVVWVCgoKwtw7WBWRmYOxY8cqPj7+isrdlpYWpaSkhKlXA+vycw7m70FxcbFeffVVvf7664FtuqVLz97V1aVz586Zzh8Mz56QkKDrrrtOWVlZKi8vV0ZGhn76058O2mduaGjQ6dOndfPNN2vIkCEaMmSI6urq9Nxzz2nIkCFyuVyD8rm7M3LkSF1//fU6ceLEoP15S9L48eM1bdo0U9uNN94YGFKJ5t9thuG3fUSLiAwOEhISlJWVpZqamkCb3+9XTU2N3G53GHs2cKZMmaKUlBTT96CtrU1vvfVW1H8PDMNQcXGxdu7cqd/97neaMmWK6fWsrCwNHTrU9OzHjx9XU1NT1D/75/n9fnV2dg7aZ543b56OHDmixsbGwJGdna0HHngg8N+D8bm7c/78ef3xj3/U+PHjB+3PW5LmzJlzxdTkd999V9dee62kKP/dZtgcUoiimoOIHVbweDwqKChQdna2Zs2apYqKCnV0dKiwsDDcXQuZ8+fP68SJE4GvT548qcbGRo0ePVqTJk3S8uXL9cQTT2jq1KmaMmWKVq1apdTUVC1cuDB8nQ6BoqIibd26Va+88opGjBgRGGdMTk7WsGHDlJycrCVLlsjj8Wj06NFKSkrS0qVL5Xa7NXv27DD3vu9KSko0f/58TZo0Se3t7dq6datqa2u1d+/eQfvMI0aMCNSSXHb11VdrzJgxgfbB+NyS9L3vfU8LFizQtddeq1OnTqmsrEzx8fG67777Bu3PW7o0RfPWW2/Vk08+qb//+7/XwYMHtX79eq1fv16SAutcDMbfbYNKuKdL9OZnP/uZMWnSJCMhIcGYNWuWceDAgXB3KaRef/31y/t/mo6CggLDMC5N+Vm1apXhcrkMp9NpzJs3zzh+/Hh4Ox0C3T2zJGPz5s2Bc/7yl78Y3/nOd4xRo0YZV111lfGNb3zD+Oijj8LX6RD4p3/6J+Paa681EhISjGuuucaYN2+e8R//8R+B1wfjM3fns1MZDWPwPnd+fr4xfvx4IyEhwZgwYYKRn59vnDhxIvD6YH1uwzCM3bt3G9OnTzecTqeRnp5urF+/3vR6tP1uuzyVcV7yg0beyCV9PuYlPxg1UxnZshkAgF5c3rJ53ogHNMSR0Of3+cToUk37L6Niy+aIrDkAAADhE7E1BwAARJTAqKid66MDwQEAABYYfr8MR9+nI0bTVEaCAwAArIihzAE1BwAAwITMAQAAVvgNyREbmQOCAwAArDAMSTbqBqIoOGBYAQAAmJA5AADAAsNvyLAxrBBNaw4SHAAAYIXhl71hheiZysiwAgAAEayyslKTJ09WYmKicnJydPDgwV7P37Fjh9LT05WYmKibbrpJe/bsCfqeBAcAAFhg+A3bR7C2b98uj8ejsrIyHT58WBkZGcrLy9Pp06e7Pf/NN9/UfffdpyVLlug///M/tXDhQi1cuFBHjx4N6r5svAQAQC8ub7x0h+7REMfQPr/PJ8ZF1eqVoDZeysnJ0S233KLnn39ekuT3+5WWlqalS5fq0UcfveL8/Px8dXR06NVXXw20zZ49W5mZmaqqqrLcVzIHAABY8Iku6hPDxqGLki4FG589Ojs7u71fV1eXGhoalJubG2iLi4tTbm6u6uvru72mvr7edL4k5eXl9Xh+TyhIBACgFwkJCUpJSdEb3uDH7j9v+PDhSktLM7WVlZVp9erVV5x79uxZ+Xw+uVwuU7vL5dKxY8e6fX+v19vt+V6vN6h+EhwAANCLxMREnTx5Ul1dXbbfyzAMORwOU5vT6bT9vqFGcAAAwBdITExUYmLigN5z7Nixio+PV0tLi6m9paVFKSkp3V6TkpIS1Pk9oeYAAIAIlJCQoKysLNXU1ATa/H6/ampq5Ha7u73G7Xabzpekffv29Xh+T8gcAAAQoTwejwoKCpSdna1Zs2apoqJCHR0dKiwslCQtXrxYEyZMUHl5uSRp2bJl+upXv6pnnnlGd999t7Zt26ZDhw5p/fr1Qd2X4AAAgAiVn5+vM2fOqLS0VF6vV5mZmaqurg4UHTY1NSku7n8GAW699VZt3bpVjz32mH7wgx9o6tSp2rVrl6ZPnx7UfVnnAAAAmFBzAAAATAgOAACACcEBAAAwITgAAAAmBAcAAMCE4AAAAJgQHAAAABOCAwAAYEJwAAAATAgOAACACcEBAAAw+f9VsRiBSsoxvgAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "science_area = threshold_map_binary(all_maps[\"science\"], threshold = -0.22)\n",
    "plt.imshow(science_area)\n",
    "plt.colorbar()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 337,
   "id": "896da830-593d-47fe-b888-3f5a84e8df2a",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "\n",
    "def process_vis(im, crop_x: tuple, crop_y: tuple, color: tuple = (0, 1, 0), exponent = 3):\n",
    "    # Crop the image\n",
    "    im = im[crop_y[0]:crop_y[1], crop_x[0]:crop_x[1]]\n",
    "    \n",
    "    # Replace 0 values with the minimum non-zero value\n",
    "    im[im == 0] = im.min()\n",
    "    \n",
    "    # Normalize the image to range [0, 1]\n",
    "    im = im - im.min()\n",
    "    im = im / im.max()\n",
    "    \n",
    "    # Convert the 2D image to RGB using stack\n",
    "    im_rgb = np.stack([im] * 3, axis=-1)\n",
    "    \n",
    "    # Apply the specified color where im != 0\n",
    "    color_mask = im != 0\n",
    "    im_rgb[color_mask] = (im_rgb[color_mask] * np.array(color))**exponent\n",
    "    \n",
    "    # Apply white (1, 1, 1) where im == 0\n",
    "    im_rgb[~color_mask] = np.array([1,1,1])\n",
    "    im_rgb = (im_rgb * 255).astype(np.uint8)\n",
    "    \n",
    "    return im_rgb\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 338,
   "id": "9949bcba-a586-4c44-8ff7-9bcbbca1006d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAWgAAAGdCAYAAAA/uul/AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8hTgPZAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAZT0lEQVR4nO3da2wU972H8e/artcOspdbsXExwc1BIlxCaQyIOGqDsIIsQqE9TUuP07pEanpSU3CQEqCtoRUlC7RFCIIgQSpQlUvyIpAUKVTI4SIULgZDGpSWywkCN9SmqZIdMGGh9v+84MQ9LibgMDvz8/J8pFHk2YHffwN+GK1nZyPOOScAgDkZYS8AANA5Ag0ARhFoADCKQAOAUQQaAIwi0ABgFIEGAKMINAAYlRX2Av5dW1ubzp8/r7y8PEUikbCXAwC+cs7p4sWLKioqUkbGp58jmwv0+fPnVVxcHPYyACClGhsbNWDAgE89xlyg8/LyJF1ffH5+fsirAQB/eZ6n4uLi9tZ9GnOB/uRljfz8fAINIG3dzku4/JAQAIwi0ABgFIEGAKMINAAYRaABwCgCDQBGEWgAMCplgV61apUGDRqknJwcjR07VocOHUrVKABISykJ9Msvv6zZs2drwYIFamho0MiRIzVx4kRduHAhFeMAIC2lJNDLli3TD37wA02fPl1Dhw7VmjVrdM899+i3v/1tKsYBQFryPdBXr17VkSNHVF5e/q8hGRkqLy/X/v37bzg+mUzK87wOGwAgBYH+4IMP1NraqoKCgg77CwoK1NTUdMPx8XhcsVisfeNOdgBwXehXccybN0+JRKJ9a2xsDHtJAGCC73ez69u3rzIzM9Xc3Nxhf3NzswoLC284PhqNKhqN+r0MAOj2fD+Dzs7O1oMPPqi6urr2fW1tbaqrq9O4ceP8HgcAaSsl94OePXu2qqqqVFpaqjFjxmj58uVqaWnR9OnTUzEOANJSSgL97W9/W3//+981f/58NTU16Utf+pJ27Nhxww8OAQA3F3HOubAX8f95nqdYLKZEIsEnqgBIO11pXOhXcQAAOkegAcAoAg0ARhFoADCKQAOAUQQaAIwi0ABgFIEGAKMINAAYRaABwCgCDQBGEWgAMIpAA4BRBBoAjCLQAGAUgQYAowg0ABhFoAHAKAINAEYRaAAwikADgFEEGgCMItAAYBSBBgCjCDQAGEWgAcAoAg0ARhFoADCKQAOAUQQaAIwi0ABgFIEGAKMINAAYRaABwCgCDQBGZYW9AAsyIpHAZ0YDnlcU8DxJ+h/nQpgKpA/OoAHAKAINAEYRaAAwikADgFEEGgCMItAAYBSBBgCjCDQAGEWgAcAoAg0ARvke6Hg8rtGjRysvL0/9+vXT1KlTdeLECb/HAEDa8z3Qe/bsUXV1tQ4cOKCdO3fq2rVrevTRR9XS0uL3KABIa77fLGnHjh0dvl6/fr369eunI0eO6Ctf+Yrf4wAgbaX8bnaJREKS1Lt3704fTyaTSiaT7V97npfqJQFAt5DSHxK2tbWppqZGZWVlGj58eKfHxONxxWKx9q24uDiVSwKAbiOlga6urtbx48e1ZcuWmx4zb948JRKJ9q2xsTGVSwKAbiNlL3HMmDFD27dv1969ezVgwICbHheNRhWNBn37egCwz/dAO+f04x//WFu3btXu3btVUlLi9wgAuCv4Hujq6mpt2rRJr732mvLy8tTU1CRJisViys3N9XscAKStiHP+fnBc5Caf77du3Tp9//vfv+Wv9zxPsVhMiURC+fn5fi7tpvhMwtTgMwmBG3WlcSl5iQMAcOe4FwcAGEWgAcAoAg0ARhFoADCKQAOAUQQaAIxK+d3sPqtYLBb2ElLqasDz/hHwPEn6csDXlw8NdNp1wwKedyngeZK0iEtnQ8MZNAAYRaABwCgCDQBGEWgAMIpAA4BRBBoAjCLQAGAUgQYAowg0ABhFoAHAKAINAEYRaAAwikADgFEEGgCMItAAYBSBBgCjCDQAGEWgAcAoAg0ARhFoADCKQAOAUQQaAIwi0ABgFIEGAKMINAAYRaABwCgCDQBGEWgAMCor7AXcTCKRUH5+fiCzIpFIIHP+PxfwvNaA50nStYDnBf3/VJLeC3heGGdU/x3w98caF8afpE2cQQOAUQQaAIwi0ABgFIEGAKMINAAYRaABwCgCDQBGEWgAMIpAA4BRKQ/04sWLFYlEVFNTk+pRAJBWUhro+vp6vfjii3rggQdSOQYA0lLKAn3p0iVVVlZq7dq16tWrV6rGAEDaSlmgq6urNWnSJJWXl6dqBACktZTczW7Lli1qaGhQfX39LY9NJpNKJpPtX3uel4olAUC34/sZdGNjo2bNmqWNGzcqJyfnlsfH43HFYrH2rbi42O8lAUC3FHHO35uvbtu2TV//+teVmZnZvq+1tVWRSEQZGRlKJpMdHuvsDLq4uDjt7wcd9MQeAc+TpEEBzwvjR9H3BDwvjOtig/67mu73g/Y8T7FY7LYa5/tLHBMmTNA777zTYd/06dM1ZMgQzZkzp0OcJSkajSoajfq9DADo9nwPdF5enoYPH95hX48ePdSnT58b9gMAbo53EgKAUYF8JuHu3buDGAMAaYUzaAAwikADgFEEGgCMItAAYBSBBgCjCDQAGEWgAcCoQK6Dxo2CvtvAtYDnSdLVgOf9PeB5kjQg4HmZtz7Ed30Dnlcb8L1xFhq+9wdn0ABgFIEGAKMINAAYRaABwCgCDQBGEWgAMIpAA4BRBBoAjCLQAGAUgQYAowg0ABhFoAHAKAINAEYRaAAwikADgFEEGgCMItAAYBSBBgCjCDQAGEWgAcAoAg0ARhFoADCKQAOAUQQaAIwi0ABgFIEGAKMINAAYRaABwKissBdggXMu8JkZkUig8zIDnXbd5YDnJQOeJ0mXAp4XC3ieJH0U8Lzgvxvt4gwaAIwi0ABgFIEGAKMINAAYRaABwCgCDQBGEWgAMIpAA4BRBBoAjEpJoN9//3098cQT6tOnj3JzczVixAgdPnw4FaMAIG35/lbvDz/8UGVlZRo/frzeeOMNff7zn9epU6fUq1cvv0cBQFrzPdBLlixRcXGx1q1b176vpKTE7zEAkPZ8f4nj9ddfV2lpqR5//HH169dPo0aN0tq1a296fDKZlOd5HTYAQAoC/d5772n16tUaPHiw/vjHP+rpp5/WzJkztWHDhk6Pj8fjisVi7VtxcbHfSwKAbinifL7XZnZ2tkpLS/XWW2+175s5c6bq6+u1f//+G45PJpNKJv91o0jP81RcXKxEIqH8/Hw/l2ZK0LcbzQ102nW9A573xYDnSVJBwPPCuN1oNOB5Qd9udFXAtxv2PE+xWOy2Guf7GXT//v01dOjQDvvuv/9+nTt3rtPjo9Go8vPzO2wAgBQEuqysTCdOnOiw7+TJk7r33nv9HgUAac33QD/zzDM6cOCAnn/+eZ0+fVqbNm3SSy+9pOrqar9HAUBa8z3Qo0eP1tatW7V582YNHz5cCxcu1PLly1VZWen3KABIayn5TMLHHntMjz32WCp+awC4a3AvDgAwikADgFEEGgCMItAAYBSBBgCjCDQAGEWgAcColFwHjVu7G/7HB33Tm2sBz5OktoDn/TXgeZL0QMDzPh/wvH8EfOOyi104ljNoADCKQAOAUQQaAIwi0ABgFIEGAKMINAAYRaABwCgCDQBGEWgAMIpAA4BRBBoAjCLQAGAUgQYAowg0ABhFoAHAKAINAEYRaAAwikADgFEEGgCMItAAYBSBBgCjCDQAGEWgAcAoAg0ARhFoADCKQAOAUQQaAIwi0ABgVFbYC0AwIiHMbAt4ngt4niTlBjzvnwHPk6TzAc8bEPC8PgHP+1wXjuUMGgCMItAAYBSBBgCjCDQAGEWgAcAoAg0ARhFoADCKQAOAUQQaAIzyPdCtra2qra1VSUmJcnNzdd9992nhwoVyLoz3eQFA9+X7W72XLFmi1atXa8OGDRo2bJgOHz6s6dOnKxaLaebMmX6PA4C05Xug33rrLU2ZMkWTJk2SJA0aNEibN2/WoUOH/B4FAGnN95c4HnroIdXV1enkyZOSpLffflv79u1TRUVFp8cnk0l5ntdhAwCk4Ax67ty58jxPQ4YMUWZmplpbW7Vo0SJVVlZ2enw8HtcvfvELv5cBAN2e72fQr7zyijZu3KhNmzapoaFBGzZs0K9//Wtt2LCh0+PnzZunRCLRvjU2Nvq9JADolnw/g3722Wc1d+5cTZs2TZI0YsQInT17VvF4XFVVVTccH41GFY1G/V4GAHR7vp9BX758WRkZHX/bzMxMtbUFfft2AOjefD+Dnjx5shYtWqSBAwdq2LBhOnr0qJYtW6Ynn3zS71EAkNZ8D/TKlStVW1urH/3oR7pw4YKKior0wx/+UPPnz/d7FACktYgz9hY/z/MUi8WUSCSUn58f9nJSJjsS7KcEZgc67bqg//TuDXieJP1HwPMuBjxPkvICnjcm4Hk/DnieJykm3VbjuBcHABhFoAHAKAINAEYRaAAwikADgFEEGgCMItAAYJTvb1TB7bkb3vge7JXe4fxl/ijgefcEPE+Segc8r2fA864anscZNAAYRaABwCgCDQBGEWgAMIpAA4BRBBoAjCLQAGAUgQYAowg0ABhFoAHAKAINAEYRaAAwikADgFEEGgCMItAAYBSBBgCjCDQAGEWgAcAoAg0ARhFoADCKQAOAUQQaAIwi0ABgFIEGAKMINAAYRaABwCgCDQBGEWgAMCor7AVYkBuJhL2EtOQCntcW8Dwp+Od4KeB5ktQn4HkfBzzvquF5nEEDgFEEGgCMItAAYBSBBgCjCDQAGEWgAcAoAg0ARhFoADCKQAOAUV0O9N69ezV58mQVFRUpEolo27ZtHR53zmn+/Pnq37+/cnNzVV5erlOnTvm1XgC4a3Q50C0tLRo5cqRWrVrV6eNLly7VihUrtGbNGh08eFA9evTQxIkTdeXKlTteLADcTbp8L46KigpVVFR0+phzTsuXL9fPfvYzTZkyRZL0u9/9TgUFBdq2bZumTZt2Z6sFgLuIr69BnzlzRk1NTSovL2/fF4vFNHbsWO3fv7/TX5NMJuV5XocNAOBzoJuamiRJBQUFHfYXFBS0P/bv4vG4YrFY+1ZcXOznkgCg2wr9Ko558+YpkUi0b42NjWEvCQBM8DXQhYWFkqTm5uYO+5ubm9sf+3fRaFT5+fkdNgCAz4EuKSlRYWGh6urq2vd5nqeDBw9q3Lhxfo4CgLTX5as4Ll26pNOnT7d/febMGR07dky9e/fWwIEDVVNTo1/+8pcaPHiwSkpKVFtbq6KiIk2dOtXPdQNA2utyoA8fPqzx48e3fz179mxJUlVVldavX6/nnntOLS0teuqpp/TRRx/p4Ycf1o4dO5STk+PfqgHgLhBxzgX9sWqfyvM8xWIxJRKJwF6PDuMzCa8FPC+Mfx6D/mlCScDzJKlXwPPC+GYdG/C8zn9alTr/FfA8T9IXpNtqXOhXcQAAOkegAcAoAg0ARhFoADCKQAOAUQQaAIwi0ABgVJffqJKOPg7hUvBYwNdetwU6LRxXQ5gZ9BlOGM/x44Dn5QU8L+gIdmUeZ9AAYBSBBgCjCDQAGEWgAcAoAg0ARhFoADCKQAOAUQQaAIwi0ABgFIEGAKMINAAYRaABwCgCDQBGEWgAMIpAA4BRBBoAjCLQAGAUgQYAowg0ABhFoAHAKAINAEYRaAAwikADgFEEGgCMItAAYBSBBgCjCDQAGJUV9gIsyIlEAp/5z4DnZQc8LwyZIcy8GvC8/IDnhSHo78ag/950ZR5n0ABgFIEGAKMINAAYRaABwCgCDQBGEWgAMIpAA4BRBBoAjCLQAGAUgQYAo7oc6L1792ry5MkqKipSJBLRtm3b2h+7du2a5syZoxEjRqhHjx4qKirS9773PZ0/f97PNQPAXaHLgW5padHIkSO1atWqGx67fPmyGhoaVFtbq4aGBr366qs6ceKEvva1r/myWAC4m3T5ZkkVFRWqqKjo9LFYLKadO3d22PfCCy9ozJgxOnfunAYOHPjZVgkAd6GU380ukUgoEomoZ8+enT6eTCaVTCbbv/Y8L9VLAoBuIaU/JLxy5YrmzJmj73znO8rP7/xGifF4XLFYrH0rLi5O5ZIAoNtIWaCvXbumb33rW3LOafXq1Tc9bt68eUokEu1bY2NjqpYEAN1KSl7i+CTOZ8+e1ZtvvnnTs2dJikajikajqVgGAHRrvgf6kzifOnVKu3btUp8+ffweAQB3hS4H+tKlSzp9+nT712fOnNGxY8fUu3dv9e/fX9/85jfV0NCg7du3q7W1VU1NTZKk3r17Kzv7bvjgJQDwR8Q557ryC3bv3q3x48ffsL+qqko///nPVVJS0umv27Vrlx555JFb/v6e5ykWiymRSHzqSyN+4jMJU6NnwPPCuIizZ8DzwvhMwvsCnjcy4Hn/GfA8T1Jf6bYa1+Uz6EceeUSf1vQu9h4AcBPciwMAjCLQAGAUgQYAowg0ABhFoAHAKAINAEal/G52XfXJZXpB3tUujAsDg54ZxnNsC3he0NeWhzHzWsDzJCl560N8dTngeUHfP/Pi//33di5J7vIbVVLtr3/9K3e0A5D2GhsbNWDAgE89xlyg29radP78eeXl5SnSxXf4eZ6n4uJiNTY2BvYuxCCl+/OTeI7pgud4c845Xbx4UUVFRcrI+PRXmc29xJGRkXHLf1VuJT8/P23/Ukjp//wknmO64Dl2LhaL3dZx/JAQAIwi0ABgVFoFOhqNasGCBWn7AQDp/vwknmO64Dn6w9wPCQEA16XVGTQApBMCDQBGEWgAMIpAA4BRaRPoVatWadCgQcrJydHYsWN16NChsJfkm3g8rtGjRysvL0/9+vXT1KlTdeLEibCXlVKLFy9WJBJRTU1N2Evx1fvvv68nnnhCffr0UW5urkaMGKHDhw+HvSzftLa2qra2ViUlJcrNzdV9992nhQsXduuPwtu7d68mT56soqIiRSIRbdu2rcPjzjnNnz9f/fv3V25ursrLy3Xq1ClfZqdFoF9++WXNnj1bCxYsUENDg0aOHKmJEyfqwoULYS/NF3v27FF1dbUOHDignTt36tq1a3r00UfV0tIS9tJSor6+Xi+++KIeeOCBsJfiqw8//FBlZWX63Oc+pzfeeEPvvvuufvOb36hXr15hL803S5Ys0erVq/XCCy/oz3/+s5YsWaKlS5dq5cqVYS/tM2tpadHIkSO1atWqTh9funSpVqxYoTVr1ujgwYPq0aOHJk6cqCtXrtz5cJcGxowZ46qrq9u/bm1tdUVFRS4ej4e4qtS5cOGCk+T27NkT9lJ8d/HiRTd48GC3c+dO99WvftXNmjUr7CX5Zs6cOe7hhx8OexkpNWnSJPfkk0922PeNb3zDVVZWhrQif0lyW7dubf+6ra3NFRYWul/96lft+z766CMXjUbd5s2b73hetz+Dvnr1qo4cOaLy8vL2fRkZGSovL9f+/ftDXFnqJBIJSVLv3r1DXon/qqurNWnSpA5/nuni9ddfV2lpqR5//HH169dPo0aN0tq1a8Nelq8eeugh1dXV6eTJk5Kkt99+W/v27VNFRUXIK0uNM2fOqKmpqcPf11gsprFjx/rSH3M3S+qqDz74QK2trSooKOiwv6CgQH/5y19CWlXqtLW1qaamRmVlZRo+fHjYy/HVli1b1NDQoPr6+rCXkhLvvfeeVq9erdmzZ+snP/mJ6uvrNXPmTGVnZ6uqqirs5fli7ty58jxPQ4YMUWZmplpbW7Vo0SJVVlaGvbSUaGpqkqRO+/PJY3ei2wf6blNdXa3jx49r3759YS/FV42NjZo1a5Z27typnJycsJeTEm1tbSotLdXzzz8vSRo1apSOHz+uNWvWpE2gX3nlFW3cuFGbNm3SsGHDdOzYMdXU1KioqChtnmOQuv1LHH379lVmZqaam5s77G9ublZhYWFIq0qNGTNmaPv27dq1a9cd35LVmiNHjujChQv68pe/rKysLGVlZWnPnj1asWKFsrKy1NraGvYS71j//v01dOjQDvvuv/9+nTt3LqQV+e/ZZ5/V3LlzNW3aNI0YMULf/e539cwzzygej4e9tJT4pDGp6k+3D3R2drYefPBB1dXVte9ra2tTXV2dxo0bF+LK/OOc04wZM7R161a9+eabKikpCXtJvpswYYLeeecdHTt2rH0rLS1VZWWljh07pszMzLCXeMfKyspuuDzy5MmTuvfee0Nakf8uX758w03oMzMz1dYW9AegBaOkpESFhYUd+uN5ng4ePOhPf+74x4wGbNmyxUWjUbd+/Xr37rvvuqeeesr17NnTNTU1hb00Xzz99NMuFou53bt3u7/97W/t2+XLl8NeWkql21Uchw4dcllZWW7RokXu1KlTbuPGje6ee+5xv//978Nemm+qqqrcF77wBbd9+3Z35swZ9+qrr7q+ffu65557LuylfWYXL150R48edUePHnWS3LJly9zRo0fd2bNnnXPOLV682PXs2dO99tpr7k9/+pObMmWKKykpcR9//PEdz06LQDvn3MqVK93AgQNddna2GzNmjDtw4EDYS/KNrn/m6w3bunXrwl5aSqVboJ1z7g9/+IMbPny4i0ajbsiQIe6ll14Ke0m+8jzPzZo1yw0cONDl5OS4L37xi+6nP/2pSyaTYS/tM9u1a1en339VVVXOueuX2tXW1rqCggIXjUbdhAkT3IkTJ3yZze1GAcCobv8aNACkKwINAEYRaAAwikADgFEEGgCMItAAYBSBBgCjCDQAGEWgAcAoAg0ARhFoADCKQAOAUf8LLZe7wzcp7FUAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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K4Ne2ufW0tKikSNHatWqVZ0+vnTpUq1YsUJr1qzRwYMH1aNHD02cOFGXLl26/eEuBYwZM8ZVVla2329tbXUFBQUuGo0GuKrkOX/+vJPk9uzZE/RSPNfc3OwGDx7sdu7c6b72ta+52bNnB70kz8yZM8c9/PDDQS8jqSZNmuSefPLJDse++c1vuvLy8oBW5C1JbsuWLe3329raXH5+vvv1r3/dfuzjjz924XDYbdq06bbndfsr6MuXL+vIkSMqLS1tP5aWlqbS0lLt378/wJUlTywWkyT17t074JV4r7KyUpMmTerw55kqtm3bpuLiYj3++OPq16+fRo0apbVr1wa9LE899NBDqq2t1YkTJyRJb731lvbt26eysrKAV5Ycp0+fVmNjY4e/r5FIRGPHjvWkP+Y2S+qqDz/8UK2trcrLy+twPC8vT3/9618DWlXytLW1qaqqSiUlJRo+fHjQy/HU5s2bVV9fr7q6uqCXkhTvvfeeVq9ererqav30pz9VXV2dZs2apczMTFVUVAS9PE/MnTtX8XhcQ4YMUXp6ulpbW7Vo0SKVl5cHvbSkaGxslKRO+3P1sdvR7QN9p6msrNQ777yjffv2Bb0UTzU0NGj27NnauXOnsrKygl5OUrS1tam4uFjPPfecJGnUqFF65513tGbNmpQJ9CuvvKINGzZo48aNGjZsmI4dO6aqqioVFBSkzHP0U7d/iaNv375KT09XU1NTh+NNTU3Kz88PaFXJMXPmTG3fvl27du267S1ZrTly5IjOnz+vr3zlK8rIyFBGRob27NmjFStWKCMjQ62tQXxbirf69++voUOHdjh233336ezZswGtyHvPPPOM5s6dq2nTpmnEiBH63ve+p6efflrRaDTopSXF1cYkqz/dPtCZmZl68MEHVVtb236sra1NtbW1GjduXIAr845zTjNnztSWLVv0xhtvqKioKOgleW7ChAl6++23dezYsfZbcXGxysvLdezYMaWnpwe9xNtWUlJyzdsjT5w4oXvuuSegFXnv4sWL12xCn56erra2IL6qK/mKioqUn5/foT/xeFwHDx70pj+3/WNGAzZv3uzC4bB76aWX3Lvvvuueeuop17NnT9fY2Bj00jwxY8YMF4lE3O7du93f/va39tvFixeDXlpSpdq7OA4dOuQyMjLcokWL3MmTJ92GDRvc3Xff7f7whz8EvTTPVFRUuC996Utu+/bt7vTp0+7VV191ffv2dc8++2zQS/vcmpub3dGjR93Ro0edJLds2TJ39OhRd+bMGeecc4sXL3Y9e/Z0r732mvvzn//spkyZ4oqKitwnn3xy27NTItDOObdy5Uo3cOBAl5mZ6caMGeMOHDgQ9JI8o8++RfOa27p164JeWlKlWqCdc+6Pf/yjGz58uAuHw27IkCHuxRdfDHpJnorH42727Nlu4MCBLisry335y192P/vZz1wikQh6aZ/brl27Ov33V1FR4Zz77K12NTU1Li8vz4XDYTdhwgR3/PhxT2az3SgAGNXtX4MGgFRFoAHAKAINAEYRaAAwikADgFEEGgCMItAAYBSBBgCjCDQAGEWgAcAoAg0ARhFoADDqfwFla+CkuqfWrAAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "crop_x = (17,28)\n",
    "crop_y = (35, None)\n",
    "\n",
    "color_map = {\n",
    "    \"physics\": (1,0,0),\n",
    "    \"biology\": (0,1,0),\n",
    "    \"chemistry\": (0,0,1),\n",
    "}\n",
    "images  = []\n",
    "\n",
    "for name, color in color_map.items():\n",
    "    im_numpy = process_vis(\n",
    "        all_maps[name]*science_area,\n",
    "        crop_x=crop_x,\n",
    "        crop_y=crop_y,\n",
    "        color=color\n",
    "    )\n",
    "\n",
    "    # if name == \"physics\":\n",
    "    #     im[2,1] = 0.\n",
    "\n",
    "    # if name == \"chemistry\":\n",
    "    #     im[3, 8] = 0.\n",
    "\n",
    "    # if name == \"biology\":\n",
    "    #     im[5, 8] = 0.\n",
    "    \n",
    "    plt.imshow(im_numpy)\n",
    "    plt.show()\n",
    "    \n",
    "    images.append(im_numpy/255.)\n",
    "    \n",
    "    im = Image.fromarray(im_numpy)\n",
    "    im = im.resize((512,512), Image.NEAREST)\n",
    "    im.save(\n",
    "        os.path.join(\n",
    "            \"figure_assets\",\n",
    "            f\"{name}.png\"\n",
    "        )\n",
    "    )\n",
    "\n",
    "common_mask = np.logical_and(\n",
    "    (images[0][:,:,0] != 1),\n",
    "(images[1][:,:,0] != 1), \n",
    "(images[2][:,:,0] != 1))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 339,
   "id": "7c8dfa82-2803-495d-9aea-d532987e36b3",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Clipping input data to the valid range for imshow with RGB data ([0..1] for floats or [0..255] for integers). Got range [0.0..3.0].\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "(np.float64(-0.5), np.float64(10.5), np.float64(12.5), np.float64(-0.5))"
      ]
     },
     "execution_count": 339,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "merged = sum(images)\n",
    "# merged[merged>2.5] = 1\n",
    "merged = merged - merged.min()\n",
    "merged = merged \n",
    "plt.imshow(merged)\n",
    "plt.axis(\"off\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "4e542f6d-07e6-4a4e-8ab7-b3ff379bfdfd",
   "metadata": {},
   "source": [
    "# Stage 2, subsets of physics"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 345,
   "id": "a6baebc9-df04-49bc-9107-98b93654d2ba",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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aJEikYhmzJgR9lJ8debMGT399NPq3r278vLyNHjwYB08eDDsZfmmublZc+fOVXFxsfLy8vTAAw9owYIFHfqj8Hbv3q3x48erqKhIkUhEW7ZsafW853maN2+eevfurby8PJWWlur48eO+zM6IQL/++uuaOXOm5s+fr9raWg0ZMkRjx47VuXPnwl6aL3bt2qXKykrt27dP27dv1+XLl/XEE0+oqakp7KUFoqamRq+88ooefvjhsJfiq88++0yjRo3SXXfdpW3btumjjz7SH//4R3Xt2jXspflm8eLFWrVqlVasWKG///3vWrx4sZYsWaLly5eHvbSvrampSUOGDNHKlSvbfH7JkiVatmyZVq9erf3796tz584aO3asLl704fZdXgYYPny4V1lZ2fJ1c3OzV1RU5FVVVYW4quCcO3fOk+Tt2rUr7KX4rrGx0evfv7+3fft27zvf+Y43ffr0sJfkm1mzZnmPPfZY2MsI1Lhx47xnnnmm1bbvf//7Xnl5eUgr8pckb/PmzS1fp9Npr1evXt7vf//7lm2ff/65F41GvY0bN972vA5/BH3p0iUdOnRIpaWlLds6deqk0tJS7d27N8SVBSeRSEiSunXrFvJK/FdZWalx48a1+vvMFG+//bZKSkr01FNPqWfPnho6dKjWrFkT9rJ89eijj6q6ulrHjh2TJL3//vvas2ePysrKQl5ZME6ePKn6+vpWP6+xWEwjRozwpT/mbpbUXp9++qmam5tVWFjYanthYaH+8Y9/hLSq4KTTac2YMUOjRo3SoEGDwl6OrzZt2qTa2lrV1NSEvZRAfPzxx1q1apVmzpypX/7yl6qpqdG0adOUk5OjioqKsJfni9mzZyuZTGrAgAHKyspSc3OzFi5cqPLy8rCXFoj6+npJarM/V5+7HR0+0HeayspKffjhh9qzZ0/YS/FVXV2dpk+fru3btys3Nzfs5QQinU6rpKREL730kiRp6NCh+vDDD7V69eqMCfQbb7yh9evXa8OGDRo4cKCOHDmiGTNmqKioKGNeo0sd/hRHjx49lJWVpYaGhlbbGxoa1KtXr5BWFYypU6dq69at2rFjx23fktWaQ4cO6dy5c/rWt76l7OxsZWdna9euXVq2bJmys7PV3OzyIxyC0bt3bz300EOttj344IM6ffp0SCvy3wsvvKDZs2dr0qRJGjx4sH7yk5/o+eefV1VVVdhLC8TVxgTVnw4f6JycHD3yyCOqrq5u2ZZOp1VdXa2RI0eGuDL/eJ6nqVOnavPmzXr33XdVXFwc9pJ8N2bMGH3wwQc6cuRIy6OkpETl5eU6cuSIsrKywl7ibRs1atR1l0ceO3ZM9913X0gr8t+FCxeuuwl9VlaW0ul0SCsKVnFxsXr16tWqP8lkUvv37/enP7f9a0YDNm3a5EWjUe+1117zPvroI+/ZZ5/1unTp4tXX14e9NF9MmTLFi8Vi3s6dO71//vOfLY8LFy6EvbRAZdpVHAcOHPCys7O9hQsXesePH/fWr1/v3X333d6f//znsJfmm4qKCu/ee+/1tm7d6p08edJ78803vR49engvvvhi2Ev72hobG73Dhw97hw8f9iR5L7/8snf48GHv1KlTnud53qJFi7wuXbp4b731lve3v/3NmzBhgldcXOx98cUXtz07IwLteZ63fPlyr2/fvl5OTo43fPhwb9++fWEvyTe68hm61z3Wrl0b9tIClWmB9jzP+8tf/uINGjTIi0aj3oABA7xXX3017CX5KplMetOnT/f69u3r5ebmevfff7/3q1/9ykulUmEv7WvbsWNHm//+VVRUeJ535VK7uXPneoWFhV40GvXGjBnjHT161JfZ3G4UAIzq8OegASBTEWgAMIpAA4BRBBoAjCLQAGAUgQYAowg0ABhFoAHAKAINAEYRaAAwikADgFEEGgCM+h+5N+bWKrRVMgAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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KAINAEYRaAAwKumBXrJkiUKhkKqrq5M9CgBSSlID3dDQoJdeekn33XdfMscAQEpKWqAvXLigiooKrVmzRn379k3WGABIWUkLdFVVlaZMmaKysrJkjQCAlJaUq9lt2rRJjY2NamhouOW+8Xhc8fjX15OLxWLJWBIA9Di+H0E3NTVp9uzZWr9+vbKysm65f21trSKRSMetqKjI7yUBQI8U8jzP18vobt26VT/5yU+Unv71lWvb29sVCoWUlpameDze6b6ujqCLiorUX+7OAXR9PVjJ/bWSg+D6HM4gLm7u+hrUQVwP2vX3McfxvP90PO9LSfskRaNR5ebm3nRf33+mH3roIb3//vudts2YMUPDhg3T3LlzO8VZksLhsMLhsN/LAIAez/dA5+TkaOTIkZ229e7dW/37979uOwDgxngnIQAY5eRpu127drkYAwAphSNoADCKQAOAUQQaAIwi0ABgFIEGAKMINAAYRaABwKggLl/wjSTk7joHIUdzruX6WhxBPEbX16mI33oX3/VyPO9Lx/Mk9z87nzme5/rntDu/+xxBA4BRBBoAjCLQAGAUgQYAowg0ABhFoAHAKAINAEYRaAAwikADgFEEGgCMItAAYBSBBgCjCDQAGEWgAcAoAg0ARhFoADCKQAOAUQQaAIwi0ABgFIEGAKMINAAYRaABwCgCDQBGEWgAMIpAA4BRBBoAjCLQAGAUgQYAozKCXsCN/FBSL0ez3nc051rHA5jpWsLxvJDjeZLU7nie53heEFz/3LiOYHceH0fQAGAUgQYAowg0ABhFoAHAKAINAEYRaAAwikADgFEEGgCMItAAYFRSAn327Fk9/vjj6t+/v7KzszVq1CgdOnQoGaMAIGX5/i7Hzz//XKWlpZo0aZLefvttfec739HJkyfVt29fv0cBQErzPdBLly5VUVGRXnnllY5txcXFfo8BgJTn+1Mcb731lkpKSvTII49o4MCBGjNmjNasWXPD/ePxuGKxWKcbACAJgf7oo49UV1enoUOH6u9//7ueeuopzZo1S+vWrety/9raWkUikY5bUVGR30sCgB4p5Hmer1cwzMzMVElJid59992ObbNmzVJDQ4P27dt33f7xeFzxeLzj61gspqKiIk0Tlxv1UxCX4nQtiMfoeiaXG/XfIMfzEpLOSYpGo8rNzb3pvr4fQRcUFGj48OGdtt177706c+ZMl/uHw2Hl5uZ2ugEAkhDo0tJSHT/e+fjwxIkTuvvuu/0eBQApzfdAP/3009q/f7+ee+45nTp1Shs2bNDLL7+sqqoqv0cBQErzPdBjx47Vli1btHHjRo0cOVKLFi3SihUrVFFR4fcoAEhpvr9IeLtisZgikQgvEvqMFwlTY6apX9Yk4UXCr3EtDgAwikADgFEEGgCMItAAYBSBBgCjCDQAGEWgAcAo368H7Zejcve/x3lHc67F+bP+uxPO9XZ9jrCU+v+unzqe153fRY6gAcAoAg0ARhFoADCKQAOAUQQaAIwi0ABgFIEGAKMINAAYRaABwCgCDQBGEWgAMIpAA4BRBBoAjCLQAGAUgQYAowg0ABhFoAHAKAINAEYRaAAwikADgFEEGgCMItAAYBSBBgCjCDQAGEWgAcAoAg0ARhFoADCKQAOAURlBL+BGvP9/c8HsPwK6xdXPy7Vc/+y0O54nSQnP7b9sKBRyOu9Lp9O693PKETQAGEWgAcAoAg0ARhFoADCKQAOAUQQaAIwi0ABgFIEGAKMINAAY5Xug29vbVVNTo+LiYmVnZ+uee+7RokWL5Dl+NxIA9HS+v1N16dKlqqur07p16zRixAgdOnRIM2bMUCQS0axZs/weBwApy/dAv/vuu5o2bZqmTJkiSRoyZIg2btyogwcP+j0KAFKa709xPPDAA6qvr9eJEyckSe+995727t2r8vLyLvePx+OKxWKdbgCAJBxBz5s3T7FYTMOGDVN6erra29u1ePFiVVRUdLl/bW2t/vSnP/m9DADo8Xw/gn799de1fv16bdiwQY2NjVq3bp3+/Oc/a926dV3uP3/+fEWj0Y5bU1OT30sCgB4p5Pl8ekVRUZHmzZunqqqqjm3PPvusXnvtNX344Ye3/POxWEyRSESD5e4cwM8dzbmW6ydy7oRzaNxeRfgrvRzPu+x4niTnZ2C5vh50utNpX/0uJiRFo1Hl5ubedF/fG3jx4kWlpXX+a9PT05VIJPweBQApzffnoKdOnarFixdr8ODBGjFihI4cOaLly5friSee8HsUAKQ035/iaG1tVU1NjbZs2aLz58+rsLBQjz32mBYsWKDMzMxb/nme4kgOnuJIDp7i8B9PcXzN90DfLgKdHKa+yUlCoJODQPsr0OegAQD+INAAYBSBBgCjCDQAGEWgAcAoAg0ARhFoADDK93cS+uUVSf/haNZ/OZpzrTvhvOQ7QbvjeUGc6+36vGTXXEfQ0zc/n50jaAAwikADgFEEGgCMItAAYBSBBgCjCDQAGEWgAcAoAg0ARhFoADCKQAOAUQQaAIwi0ABgFIEGAKMINAAYRaABwCgCDQBGEWgAMIpAA4BRBBoAjCLQAGAUgQYAowg0ABhFoAHAKAINAEYRaAAwikADgFEEGgCMItAAYFRG0Au4kVclZTqaddHRnGuFHM/zHM+7UyQczwvi+5jueJ7rf1PLOIIGAKMINAAYRaABwCgCDQBGEWgAMIpAA4BRBBoAjCLQAGAUgQYAo7od6D179mjq1KkqLCxUKBTS1q1bO93veZ4WLFiggoICZWdnq6ysTCdPnvRrvQBwx+h2oNva2jR69GitWrWqy/uXLVumlStXavXq1Tpw4IB69+6tyZMn69KlS7e9WAC4k3T7Whzl5eUqLy/v8j7P87RixQr94Q9/0LRp0yRJr776qvLy8rR161Y9+uijt7daALiD+Poc9OnTp9Xc3KyysrKObZFIROPHj9e+ffu6/DPxeFyxWKzTDQDgc6Cbm5slSXl5eZ225+Xlddz372praxWJRDpuRUVFfi4JAHqswM/imD9/vqLRaMetqakp6CUBgAm+Bjo/P1+S1NLS0ml7S0tLx33/LhwOKzc3t9MNAOBzoIuLi5Wfn6/6+vqObbFYTAcOHNCECRP8HAUAKa/bZ3FcuHBBp06d6vj69OnTOnr0qPr166fBgwerurpazz77rIYOHari4mLV1NSosLBQ06dP93PdAJDyuh3oQ4cOadKkSR1fz5kzR5JUWVmptWvX6plnnlFbW5uefPJJffHFF3rwwQe1fft2ZWVl+bdqALgDhDzPM/VxdbFYTJFIRJVy95mErzqac63LjueZ+iYnievPeQwCn0noP1educrTV7//0Wj0lq+5BX4WBwCgawQaAIwi0ABgFIEGAKMINAAYRaABwCgCDQBGdfuNKq7kSwo7nOXaWcfzvnQ8LwhBnCPs+ggniMfo+rxk1/+mccfzuoMjaAAwikADgFEEGgCMItAAYBSBBgCjCDQAGEWgAcAoAg0ARhFoADCKQAOAUQQaAIwi0ABgFIEGAKMINAAYRaABwCgCDQBGEWgAMIpAA4BRBBoAjCLQAGAUgQYAowg0ABhFoAHAKAINAEYRaAAwikADgFEEGgCMygh6ATdyVlKmo1mfOJpzrfYAZsJ/XtALcMD1Y3Q9z1VnrvIkXfmG+3IEDQBGEWgAMIpAA4BRBBoAjCLQAGAUgQYAowg0ABhFoAHAKAINAEYRaAAwqtuB3rNnj6ZOnarCwkKFQiFt3bq1474rV65o7ty5GjVqlHr37q3CwkL96le/0rlz5/xcMwDcEbod6La2No0ePVqrVq267r6LFy+qsbFRNTU1amxs1BtvvKHjx4/rxz/+sS+LBYA7SbcvllReXq7y8vIu74tEItqxY0enbS+++KLGjRunM2fOaPDgwd9ulQBwB0r61eyi0ahCoZD69OnT5f3xeFzxeLzj61gsluwlAUCPkNQXCS9duqS5c+fqscceU25ubpf71NbWKhKJdNyKioqSuSQA6DGSFugrV67o5z//uTzPU11d3Q33mz9/vqLRaMetqakpWUsCgB4lKU9xXI3zxx9/rHfeeeeGR8+SFA6HFQ6Hk7EMAOjRfA/01TifPHlSO3fuVP/+/f0eAQB3hG4H+sKFCzp16lTH16dPn9bRo0fVr18/FRQU6Gc/+5kaGxu1bds2tbe3q7m5WZLUr18/ZWa6/nAZAOi5Qp7ndesjwHbt2qVJkyZdt72yslJ//OMfVVxc3OWf27lzpyZOnHjLvz8WiykSiehxufussNcczbnWN/1MMr/cCZ+dF4SQ43l3wvfR9dubXX8w69XPJIxGozd9+lf6FmubOHGibtb0bvYeAHADXIsDAIwi0ABgFIEGAKMINAAYRaABwCgCDQBGuT4F8JaunqZ32eVMh7OCnAn/8X30n+t/06DmfZNTks0FurW1VZL0esDrABAM18F0/aaxq1pbWxWJRG66T7ffSZhsiURC586dU05OjkKh7r1PKxaLqaioSE1NTbd8h05PlOqPT+Ixpgoe4415nqfW1lYVFhYqLe3mzzKbO4JOS0vToEGDbuvvyM3NTdkfCin1H5/EY0wVPMau3erI+SpeJAQAowg0ABiVUoEOh8NauHBhyn4AQKo/PonHmCp4jP4w9yIhAOArKXUEDQCphEADgFEEGgCMItAAYFTKBHrVqlUaMmSIsrKyNH78eB08eDDoJfmmtrZWY8eOVU5OjgYOHKjp06fr+PHjQS8rqZYsWaJQKKTq6uqgl+Krs2fP6vHHH1f//v2VnZ2tUaNG6dChQ0Evyzft7e2qqalRcXGxsrOzdc8992jRokU9+qPw9uzZo6lTp6qwsFChUEhbt27tdL/neVqwYIEKCgqUnZ2tsrIynTx50pfZKRHozZs3a86cOVq4cKEaGxs1evRoTZ48WefPnw96ab7YvXu3qqqqtH//fu3YsUNXrlzRww8/rLa2tqCXlhQNDQ166aWXdN999wW9FF99/vnnKi0tVa9evfT222/rgw8+0F/+8hf17ds36KX5ZunSpaqrq9OLL76of/7zn1q6dKmWLVumF154IeilfWttbW0aPXq0Vq1a1eX9y5Yt08qVK7V69WodOHBAvXv31uTJk3Xp0qXbH+6lgHHjxnlVVVUdX7e3t3uFhYVebW1tgKtKnvPnz3uSvN27dwe9FN+1trZ6Q4cO9Xbs2OH96Ec/8mbPnh30knwzd+5c78EHHwx6GUk1ZcoU74knnui07ac//alXUVER0Ir8JcnbsmVLx9eJRMLLz8/3nn/++Y5tX3zxhRcOh72NGzfe9rwefwR9+fJlHT58WGVlZR3b0tLSVFZWpn379gW4suSJRqOSpH79+gW8Ev9VVVVpypQpnb6fqeKtt95SSUmJHnnkEQ0cOFBjxozRmjVrgl6Wrx544AHV19frxIkTkqT33ntPe/fuVXl5ecArS47Tp0+rubm5089rJBLR+PHjfemPuYsldddnn32m9vZ25eXlddqel5enDz/8MKBVJU8ikVB1dbVKS0s1cuTIoJfjq02bNqmxsVENDQ1BLyUpPvroI9XV1WnOnDn63e9+p4aGBs2aNUuZmZmqrKwMenm+mDdvnmKxmIYNG6b09HS1t7dr8eLFqqioCHppSdHc3CxJXfbn6n23o8cH+k5TVVWlY8eOae/evUEvxVdNTU2aPXu2duzYoaysrKCXkxSJREIlJSV67rnnJEljxozRsWPHtHr16pQJ9Ouvv67169drw4YNGjFihI4eParq6moVFhamzGN0qcc/xTFgwAClp6erpaWl0/aWlhbl5+cHtKrkmDlzprZt26adO3fe9iVZrTl8+LDOnz+vH/zgB8rIyFBGRoZ2796tlStXKiMjQ+3t7UEv8bYVFBRo+PDhnbbde++9OnPmTEAr8t9vf/tbzZs3T48++qhGjRqlX/7yl3r66adVW1sb9NKS4mpjktWfHh/ozMxM3X///aqvr+/YlkgkVF9frwkTJgS4Mv94nqeZM2dqy5Yteuedd1RcXBz0knz30EMP6f3339fRo0c7biUlJaqoqNDRo0eVnp4e9BJvW2lp6XWnR544cUJ33313QCvy38WLF6+7CH16eroSiURAK0qu4uJi5efnd+pPLBbTgQMH/OnPbb/MaMCmTZu8cDjsrV271vvggw+8J5980uvTp4/X3Nwc9NJ88dRTT3mRSMTbtWuX98knn3TcLl68GPTSkirVzuI4ePCgl5GR4S1evNg7efKkt379eu+uu+7yXnvttaCX5pvKykrvu9/9rrdt2zbv9OnT3htvvOENGDDAe+aZZ4Je2rfW2trqHTlyxDty5IgnyVu+fLl35MgR7+OPP/Y8z/OWLFni9enTx3vzzTe9f/zjH960adO84uJi71//+tdtz06JQHue573wwgve4MGDvczMTG/cuHHe/v37g16Sb/TVx7Rdd3vllVeCXlpSpVqgPc/z/va3v3kjR470wuGwN2zYMO/ll18Oekm+isVi3uzZs73Bgwd7WVlZ3ve+9z3v97//vRePx4Ne2re2c+fOLn//KisrPc/76lS7mpoaLy8vzwuHw95DDz3kHT9+3JfZXG4UAIzq8c9BA0CqItAAYBSBBgCjCDQAGEWgAcAoAg0ARhFoADCKQAOAUQQaAIwi0ABgFIEGAKMINAAY9f8AEazvUJm9FiMAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "x=process_vis(\n",
    "    all_maps[\"quantum_mechanics\"],\n",
    "    crop_x=crop_x,\n",
    "    crop_y=crop_y,\n",
    "    color=(1,0,0)\n",
    ")\n",
    "plt.imshow(x)\n",
    "plt.show()\n",
    "\n",
    "x=process_vis(\n",
    "    all_maps[\"classical_mechanics\"],\n",
    "    crop_x=crop_x,\n",
    "    crop_y=crop_y,\n",
    "    color=(1,0,0)\n",
    ")\n",
    "plt.imshow(x)\n",
    "plt.show()\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9c69a9dc-19ff-4905-9103-2e8da9f79c6b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bc80714b-08fb-4634-a4f5-e2a453226f4b",
   "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.12.4"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
