{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pickle\n",
    "import numpy as np\n",
    "import os\n",
    "from pathlib import Path\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "def dict2array(my_dict):\n",
    "    first_outer_key = next(iter(my_dict))\n",
    "    first_inner_key = next(iter(my_dict[first_outer_key]))\n",
    "\n",
    "    # Transposing the dictionary\n",
    "    transposed_dict = {\n",
    "        third_key: {\n",
    "            outer_key: {inner_key: my_dict[outer_key][inner_key][third_key]\n",
    "                        for inner_key in my_dict[outer_key].keys()}\n",
    "            for outer_key in my_dict.keys()\n",
    "        }\n",
    "        for third_key in my_dict[first_outer_key][first_inner_key].keys()\n",
    "    }\n",
    "    \n",
    "    dict_of_arrays = {}\n",
    "    for third_key, outer_dict in transposed_dict.items():\n",
    "        # Get the list of second-level keys (e.g., 'A', 'B') and third-level keys (e.g., 'X1', 'X2')\n",
    "        outer_keys = list(outer_dict.keys())  # 'A', 'B'\n",
    "        inner_keys = list(next(iter(outer_dict.values())).keys())  # 'X1', 'X2'\n",
    "        \n",
    "        # Initialize a 2D numpy array with dimensions (len(outer_keys), len(inner_keys))\n",
    "        array = np.zeros((len(outer_keys), len(inner_keys)))\n",
    "        \n",
    "        # Fill the numpy array with the values from the dictionary\n",
    "        for i, outer_key in enumerate(outer_keys):\n",
    "            for j, inner_key in enumerate(inner_keys):\n",
    "                array[i, j] = outer_dict[outer_key][inner_key]\n",
    "        \n",
    "        # Assign the numpy array to the third-level key in the new dictionary\n",
    "        dict_of_arrays[third_key] = array\n",
    "\n",
    "    return dict_of_arrays"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "beta_vae\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAXQAAAFuCAYAAACRLuOuAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuNSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/xnp5ZAAAACXBIWXMAAA9hAAAPYQGoP6dpAAATf0lEQVR4nO3de2yUhZrH8d87M6Ut9AJIUSo9iohHkF2gWrWw3BR0TTZr1ICuEpcNiRJXMSdRXBOjaIIY4/X8gycmJEZNFq+JKxyI7uoaoF6IXNwG8FRAexg9cm2Lvc3l3T+wo8W2dJ4pLTz9fpImQ/s+fd/evh2n7WMQhmEoAMBZLzLQFwAA6BsEHQCcIOgA4ARBBwAnCDoAOEHQAcAJgg4ATsQG+gL6WjqdVjweV3FxsYIgGOjLAYCchWGopqYmlZeXKxLp/n64u6DH43FVVFQM9GUAQJ+rr6/X2LFju325u6AXFxdLkmaX3qpYMCTr+dSxRtN5oyXFprlche3t5tl0a5t5NojZPnXCZNJ8zuioUebZ1KFD5tmzTU7vpyNHbecsGWY+Z/p4s3k2iEXNswPB+jWXVEKbtD7Tt+64C3rHwyyxYIgp6EGQZzpv1HCuvhDm8KhSOkibZ4PAGPQcHgaLRuzvY+vH9Ww0EO+nXD7/00HCPGv9PBwo5q+5nxe0nOphZH4oCgBOEHQAcIKgA4ATBB0AnCDoAOAEQQcAJwg6ADhB0AHACYIOAE4QdABwgqADgBMEHQCcOLs222QhyC9QYFhSFB1le5ekjzWY5qTcNhBatx5KUrSkxDybbrZvyLNKHT7S7+ccKLEx55lnk9//YJ6NjhhhmksdtW1plCRF7BsTI+MvMM+mdtWZ5qIjh5vPGS0sNM2FYbvUi3cx99ABwAmCDgBOEHQAcIKgA4ATBB0AnCDoAOAEQQcAJwg6ADhB0AHACYIOAE4QdABwgqADgBMEHQCccLttMX3OcKWj+dkP1u03nS8Ykv1mx76ZzTPPhu0J+3mNWx4jw0vN50wdOmyeHQjWzYWSFA6zbeXL9bzWrYm5bO4M29vts/vqzbPRomGmuXRDk/2c5402zQXpGNsWAWAwIegA4ARBBwAnCDoAOEHQAcAJgg4AThB0AHCCoAOAEwQdAJwg6ADgBEEHACcIOgA4QdABwAmCDgBOuF2fq4hM366CsWNMpwsSSdOcJCW/ta8AjY0oN8+GrUfMs1ZBvmGl8c+iEy4yz6b+stc8G+TZ1htbV9FKUqStzTxrXW2ci3RLq322aqJ5Nrr9L+ZZGVdPh42N5lMm6/9qmwt7t+qae+gA4ARBBwAnCDoAOEHQAcAJgg4AThB0AHCCoAOAEwQdAJwg6ADgBEEHACcIOgA4QdABwAmCDgBOEHQAcMLx+tzIiacstVw8ynS6oxNsqzglKUhVmGeLvk/Zz5sea54tONRummseYVtFK0ltpfb7HyPNk1J6v23laS6Sl//ePBv7YlcfXknvREqLzbPhlh322RxWBYftts/hWIX96yYssH3+h6k26ZtTH8c9dABwgqADgBMEHQCcIOgA4ARBBwAnCDoAOEHQAcAJgg4AThB0AHCCoAOAEwQdAJwg6ADgBEEHACfcbls88mhC0aHZf7+aVvZ/pvPVPv33pjlJ+luV/ftqoiRqnh29tc08e/g/mk1z6Q1DzefMb0ibZ8NC+5bHxlsqTXOxVvv1Fu/80TybqMxhU+PXts2Syd/bN4bG2hPm2TCVw7bRPFv+jk63b1ssXvupaS4V9u59xD10AHCCoAOAEwQdAJwg6ADgBEEHACcIOgA4QdABwAmCDgBOEHQAcIKgA4ATBB0AnCDoAOAEQQcAJwg6ADgRhGEYDvRF9KXGxkaVlpbqi9pzVVSc/fer8qhtHe1rjeNNc5K07fjvzLMXD7WvWa05cpF59qdEvmlu3+f2NavJMe3mWTXaN0UXnn/cNNfaYl/Zm7e3wDybKLJ/SaeH2lb+jnvLvsY2jAbm2ZYy+8d15Lo9prn2KePM54y0295PyWSr/vezlWpoaFBJSUn3r996YQCAMwtBBwAnCDoAOEHQAcAJgg4AThB0AHCCoAOAEwQdAJwg6ADgBEEHACcIOgA4QdABwAmCDgBOEHQAcMK+e/IMVxqRDNtzVRSxrS1dUvqdaU6SIqX15tnjYZt59t+H7zLPJmRbA5q4xLaeVZL2JArNswdT3a8cPZU//M+/mOYWXvmF+Zz/tXu6eTb/qH0dbXDQdh/v+B+Oms/Z+t9l5tnz/7TDPLv76cmmuYo/29cTh1FbcpOJ3p2Te+gA4ARBBwAnCDoAOEHQAcAJgg4AThB0AHCCoAOAEwQdAJwg6ADgBEEHACcIOgA4QdABwAmCDgBOuN22ODJSqJJI/32/ygui5tnmdLt5tjRi30CYCG0bEyUpT7a317qlUZJmFNg/np+0HjfPfv1PL5nmDqVazOes/tc682x9+znm2fI829bEn9JDzOdccfifzbONb59rnh31n7bPp5ZR5lOq8SLbXKo1Kq079XHcQwcAJwg6ADhB0AHACYIOAE4QdABwgqADgBMEHQCcIOgA4ARBBwAnCDoAOEHQAcAJgg4AThB0AHCCoAOAE27X50aDiKLB2fH9amjEvno0F7ms/D2bzilJswpymbZdc2kOH9e5hQfNszVBwjxbYJ4tMp/zHybYVwX/rtC27leSdv5bs2musc3+yTTznO9Mc23HE1q98tTHnR3FAwCcEkEHACcIOgA4QdABwAmCDgBOEHQAcIKgA4ATBB0AnCDoAOAEQQcAJwg6ADhB0AHACYIOAE6Yty0eOHBABw4cUFFRkcaNG6fCwsK+vC4AQJayDvqePXu0ZMkS1dTU/PJKYjFVVVXpxhtv1NKlS1VcXNxpprm5Wa+++qq++OILhWGoSy65RHPnzlVVVZWCIMj9rQDOQLmsRU6FafPsPw5tM882p9tNc2nZVtFK0t/l/9k8eyxtfx//ra3ENFdbP8Z8zhvG1JrmWof0bq1xVkE/duyY5s2bp3g8rjAMM89PJBKqqalRTU2NVq1apeeee06LFy+WJO3fv1/z5s3Tvn37fvP6KioqtGzZMi1btkyxmNvV7ADQL7J6DH316tU6cODAicFIRNXV1Zo/f77Ky8sVhqHCMNSxY8e0ZMkSrVx5Yhv7woULtXfvXknKHNPxVF9frwcffFBXXHGF9u/f37dvGQAMMlndLd6wYYMkKQgCrV+/Xtddd13mZV9++aVWrlypd999V2EY6rHHHlNDQ4O2bt2aeVjllltuUWVlpX788Ud99NFH2rlzpyRp586dmjNnjmpqajRmjP0/ZwBgMMvqHvquXbsUBIFmzJjRKeaSVFlZqbffflsvvviipBP3xp999tnMy1955RW9+eabevjhh/X8889r+/bt2rx5s6ZOnSpJqq+v1913353jmwMAg1dWQW9oaJAkXXrppd0ec99992nx4sWZh1WCINDMmTO1aNGi3xxbXV2tzZs366qrrlIYhlq3bp22bduW5ZsAAJCyDHrHryYmEj3/xPWxxx5TEASZh1puvfXWHl/nmjVrMse+9tpr2VwSAOBnWQW944ef27dv7/G4Cy64QJMnT878JkxVVVWPx0+cOFGXX365wjDs9OuQAIDeyyro1dXVkqQdO3Zoy5YtPR572WWXZW6PGzfulK+74/hvvvkmm0sCAPwsq6Dfeeedmdu333676urquj126tSpmT8wOvkPjboSjUYl/fI4PQAgO1kFffbs2brhhhsyv0M+bdo0PfLII5nfM/+15cuXq6GhQbW1tRoy5NR/zdXxe+gdYQcAZCfr5VyvvPKKLrvsMoVhqObmZq1atUoTJkzQhRdeqAULFmjVqlXauHGjDh48KKnn34jpcODAAX3yyScKgkCjR4/O/q0AAGS/y2XUqFHatGmT7r33Xr3++uuZ59fX16u+vl7vvPNO5nnl5eWqrKzs9HT++ed3en3JZFJ33nmnksmkgiDQlVdemcObAwCDl2mBSmlpqV599VU98MADWr16tdatW5dZCfBr8Xhc8Xhc77//fuZ5ZWVlmjZtmiorKzV+/Hi98MILqq39ZWHN0qVLLZcEAINeEP56y1YO9u7dq61bt2rbtm2Zp46HXTqd8KTtih2nD4JAF198sR599FFNmTJFEydOND2e3tjYqNLSUh39+iKVFLPuHegPuWyHjAb2r9NEmDLP/jXZYpori9oXCX6btOX2eFNa0yd/r4aGBpWUdL8lss+C3pV4PN4p8Nu2betyCVdXK3SHDBmiiRMnaurUqZoyZUrmacSIET2ek6AD/Y+g985ZHfSuHDt2TNu3b+8U+d27dyuV+u0H5uTQB0GgZDLZ4+sn6ED/I+i9c7qD3u9LyIcPH645c+Zozpw5mee1trbqq6++6hT5r776Si0ttnc4AAxGZ8T/VaKgoEBVVVWdVgSk02nt3r27U+RPtXIAAAazMyLoXYlEIpo0aZImTZqkO+64Y6AvBwDOeDzIDABOEHQAcIKgA4ATBB0AnCDoAOAEQQcAJwg6ADhB0AHACYIOAE6csX8pCuDskcuCrVzkBfb/ZeXYWKFp7lDKvmNqbMx2vY29LDX30AHACYIOAE4QdABwgqADgBMEHQCcIOgA4ARBBwAnCDoAOEHQAcAJgg4AThB0AHCCoAOAEwQdAJwg6ADgBOtzAQxK1tW70SAwn3NoMMQ0lwzSvTqOe+gA4ARBBwAnCDoAOEHQAcAJgg4AThB0AHCCoAOAEwQdAJwg6ADgBEEHACcIOgA4QdABwAmCDgBOsG0RALIwOjqs38+Z18sNj9xDBwAnCDoAOEHQAcAJgg4AThB0AHCCoAOAEwQdAJwg6ADgBEEHACcIOgA4QdABwAmCDgBOEHQAcIKgA4ATBB0AnCDoAOAEQQcAJwg6ADhB0AHACYIOAE4QdABwgqADgBMEHQCcIOgA4ARBBwAnCDoAOEHQAcAJgg4AThB0AHCCoAOAEwQdAJwg6ADgBEEHACcIOgA4QdABwAmCDgBOEHQAcIKgA4ATBB0AnCDoAOAEQQcAJwg6ADhB0AHACYIOAE4QdABwgqADgBMEHQCcIOgA4ARBBwAnCDoAOEHQAcAJgg4AThB0AHCCoAOAEwQdAJwg6ADgBEEHACcIOgA4QdABwAmCDgBOEHQAcIKgA4ATBB0AnCDoAOAEQQcAJwg6ADhB0AHACYIOAE4QdABwgqADgBMEHQCcIOgA4ARBBwAnCDoAOEHQAcAJgg4AThB0AHCCoAOAEwQdAJwg6ADgBEEHACcIOgA4QdABwAmCDgBOEHQAcIKgA4ATBB0AnCDoAOAEQQcAJwg6ADhB0AHACYIOAE4QdABwgqADgBMEHQCcIOgA4ARBBwAnCDoAOEHQAcAJgg4AThB0AHAiNtAX0NfCMJQkNR5PD/CVAEDf6OhZR9+64y7oTU1NkqQLKvcP7IUAQB9rampSaWlpty8PwlMl/yyTTqcVj8dVXFysIAgG+nIAIGdhGKqpqUnl5eWKRLp/pNxd0AFgsOKHogDgBEEHACcIOgA4QdABwAmCDgBOEHQAcIKgA4ATBB0AnCDoAOAEQQcAJwg6ADhB0IEsHDx4UE8++aSmT5+usrIy5efnq6KiQosWLVJtbW2nY9esWaMgCBQEgTZu3DhAV4zBhOVcQC+EYahnnnlGTzzxhI4fP97lMYWFhfrggw80Y8YMpVIpXXrppaqrq1N1dbW2bNnSz1eMwcjdPnSgr7W3t2vBggV67733Ms+rqqrS5MmTFY/H9fHHH6utrU0tLS265557tGPHDq1du1Z1dXWSpBUrVgzQlWOw4R46cAq33Xab1q5dK0kqKyvTG2+8oTlz5mRe/tlnn2nWrFlqb2+XJNXV1enGG29UbW2tpk+frs2bNw/EZWMQ4jF0oAdvvPFGJuZ5eXlat25dp5hL0lVXXaWFCxdm/v3ss89mHk/n3jn6E0EHupFKpbR8+fLMvx966CFVVVV1eewVV1yRuf3yyy9LkmbMmKH58+ef3osEfoWgA93YsGGDvv32W0nSiBEjOsX9ZOedd17mdjKZlCQ9/vjjp/cCgZMQdKAbr7/+eub2okWLVFxc3O2xJ/9/HmfOnKlrr732tF0b0BWCDnTjo48+yty++eabezz25N8t4LFzDASCDnShrq5OP/zwgyQpFovp6quv7vH4Xwd91qxZuuaaa07r9QFdIehAF/bs2ZO5PX78eBUUFPR4/HfffZe5ff/995+26wJ6QtCBLuzbty9zu6KiosdjGxoa9PTTT2f+PXLkyNN2XUBPCDrQhZaWlsztvLy8Ho9duXKlDh06lPl3NBo9bdcF9ISgA12IxX7ZihGPx7s9bteuXfrjH//Y7SzQnwg60IUJEyZkbu/cuVN79+79zTGtra1avHix2traOj2/u+VdwOlG0IEuVFdXKz8/X9KJ32BZvHixGhsbMy8/fPiwbrrpJn3++eeSTvzgtMOvf38d6E8s5wK6cdddd2X+jF+SRo0apeuvv16JREIffvihjhw5IunEn/g/+eSTmj17dubYm2++WWPGjNFTTz2loqKifr92DE4EHejGTz/9pHnz5unTTz/t9pj58+frrbfeUlFRkSorK7Vjx47My0aOHKnDhw/3x6UCknjIBejWsGHDtGnTJr300kuaO3euzj33XMViMRUWFmrSpElasWKF1q9fr5KSEkUiEW3cuFELFizQ0KFDJUnTpk0b4LcAgw330AHACe6hA4ATBB0AnCDoAOAEQQcAJwg6ADhB0AHACYIOAE4QdABwgqADgBMEHQCcIOgA4ARBBwAnCDoAOEHQAcAJgg4ATvw/O4yYsxxGqhcAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "factor_vae\n"
     ]
    },
    {
     "data": {
      "image/png": "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QhiGeuqpp/SDH/xA58+fH/KYkpISvfHGG1q5cqUymYwWLFig1tZWNTQ06K233hrnK8Zk5O4fuAAut/7+fq1bt06//vWvc++rr6/XzTffrEQiod/97nfq6+tTT0+Pvv71r6u5uVnPP/+8WltbJUmbN2+eoCvHZMMdOnAJX/7yl/X8889LkqqqqvTCCy+osbEx9/E9e/botttuU39/vySptbVVa9euVUtLi1asWKHdu3dPxGVjEuI5dGAEL7zwQi7mBQUF2rFjx6CYS9Ly5cu1fv363M+ffvrp3PPp3J1jPBF0YBiZTEaPPvpo7uff+c53VF9fP+Sxy5Yty739i1/8QpK0cuVKrVmz5speJHARgg4M4/XXX9f7778vSZo2bdqguH/ctddem3s7nU5Lkr7//e9f2QsEPoagA8N47rnncm9v2LBB8Xh82GM//u88rlq1SnfdddcVuzZgKAQdGMabb76Ze/v+++8f8diPv7aA584xEQg6MITW1lZ9+OGHkqRYLKZbb711xOMvDvptt92mO++884peHzAUgg4M4ciRI7m3b7jhBhUXF494/IkTJ3Jvf/Ob37xi1wWMhKADQzh27Fju7ZqamhGPTSaT+uEPf5j7+fTp06/YdQEjIejAEHp6enJvFxQUjHjsli1bdPr06dzPo9HoFbsuYCQEHRhCLPb3rRiJRGLY4w4dOqSf/exnw84C44mgA0OYP39+7u0DBw7o6NGj/3BMb2+vNm7cqL6+vkHvH255F3ClEXRgCA0NDSoqKpL00StYNm7cqM7OztzHz5w5o/vuu0/vvPOOpI/+4HTAxa9fB8YTy7mAYXz1q1/N/TV+SaqsrNQ999yjVCql3/72tzp79qykj/6K/xNPPKHbb789d+z999+vWbNm6cknn1R5efm4XzsmJ4IODOPChQtavXq13n777WGPWbNmjV566SWVl5errq5Ozc3NuY9Nnz5dZ86cGY9LBSTxlAswrLKyMu3atUs///nPdccdd2jmzJmKxWIqKSnRwoULtXnzZr322muqqKhQJBLRzp07tW7dOpWWlkqSli5dOsFfASYb7tABwAnu0AHACYIOAE4QdABwgqADgBMEHQCcIOgA4ARBBwAnCDoAOEHQAcAJgg4AThB0AHCCoAOAEwQdAJwg6ADgBEEHACf+H4vPocFN0zUvAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "modularity\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "dci_disentanglement\n"
     ]
    },
    {
     "data": {
      "image/png": "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6g70t956S3fffbf6+vr+9UlyOfX09Oi2227TPffco/b29kkzR48e1ZNPPqlXX31VIQRdeumlWrdunXp6euJqN2eQNmeV5mavHTipRFTgZiIqcNOIqtRsxP+gGR+2mDWj6nOb7OtWWm2zacTTLzthn41ivZsiKnuViXgeBvvXXSMkubxtLkgqnfq4up5yhw4d0vr161UoFBROegBLpZL6+vrU19enn/zkJ/r5z3+uzZs3S5LeeecdrV+/Xvv27fvE5+vq6tK9996re++9V7lZDF8A8Kiub42PPvqo9u/ff2wwk1Fvb682bNigzs5OhRAUQtChQ4d09913a8uWLZKkjRs3au/evZJUPebEf0NDQ/r+97+vq666Su+8887pvWUAMM/UdVr8/PPPSzr210m2bdumL3/5y9WP/e1vf9OWLVv07LPPKoSgBx54QMPDw3rttdeql1W+8pWvqLu7Wx988IG2b9+u3bt3S5J2796ttWvXqq+vT8uWLTtdtw0A5pUkhNovfp133nk6ePCgrr/+ev3pT3+a8phf/epXuu+++6ohHkJQkiR64okntGnTpknH9vX16dvf/rZ27dqlJEl066236rnnnou4OdLIyIg6Ojq05ur/Vi7XEvW56hFzDV3GP3EmiWvoNaq02H9OUT7Htudyi32/2Qn749ryUQ0XW6eRG7FdvM+MjJnXTI6Om2fDkSP22aL9fjKvWSqb5sqhpO2l/9Hw8LAWLlw47XF1PVOHh4clSZdddtm0x3z3u9/V5s2bq5dVkiTRDTfc8Ikwl6Te3l69/PLLuuaaaxRC0NatW7Vz5856tgQAOK6uQD/x0sRSaebvbA888ICSJKmepX/1q1+d8XM+/vjj1WN/85vf1LMlAMBxdQX6iR9+7tq1a8bjLrroIl1++eXVV8L09PTMePzKlSv1hS98QSGESS+HBADUrq5A7+3tlST19/frlVdemfHYz33uc9W3ly9ffsrPfeL4t99+u54tAQCOqyvQ77rrrurbX//61zU4ODjtsVdeeWX1F4w+/otGU8lmj/3Q6sR1egBAfeoK9DVr1uiWW26pvoZ89erV+uEPf1h9nfnJ7r//fg0PD2tgYEBNTU2n/NwnXod+ItgBAPWp62WLkvThhx9q3bp1GhgYmPRr+11dXerp6VF3d3f1v6VLl9b0Offv36/ly5erUqnoM5/5zJS/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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "irs\n"
     ]
    },
    {
     "data": {
      "image/png": "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bdy4UZL06aefau3atfrkk0++9/W6urp0//336/7771c67baaHQBmREOXd08//bQOHDhwfGAcq7e3V+vWrVNnZ6eSJFGSJDp8+LA2bdqkrVu3SpJuueUW7du3T5Jq24z92b9/vx588EGtXLlSn3766fQ+MwCYYxq6LN6xY4ckKYoibd++Xb/4xS9qn3v//fe1detWvfrqq0qSRI888oiGhob03nvv1W6r3HTTTeru7taXX36pN998U3v37pUk7d27V6tXr1ZfX58WL148Xc8NAOaUKPnuvZOTOOecc3To0CFdddVV+sc//jHhNn/+85+1efPmWognSaIoivSXv/xFGzZsGLdtX1+f7rnnHu3Zs0dRFOmGG27Qa6+9FvB0pCNHjqijo0Mr1/+f0pnG783Z76EbxynsHnqqZB8bdg/dNi7kHno1zT30upyi70tNOWXIPfSA99rNlXvo5UpBf9/3lIaGhjR//vxJt2toVw4NDUmSLrrookm3ue+++7Rx48babZUoinT11Vd/L8wlqbe3V2+//bYuv/xyJUmibdu2affu3Y0sCQDwjYYCfeytiaWT/HLVRx55RFEU1a7Sf/3rX0/5NZ977rnati+88EIjSwIAfKOhQB/75ueePXum3O7888/X8uXLa++E6enpmXL7pUuX6rLLLlOSJOPeDgkAqF9Dgd7b2ytJ6u/v1zvvvDPlthdffHHt8ZIlS076tce2//jjjxtZEgDgGw0F+h133FF7fNttt2lwcHDSbS+99NLaDxid+INGE0mljn+zYOw+PQCgMQ0F+rXXXqtf/vKXtfeQr1ixQg8//HDtfebftWXLFg0NDWlgYEDZbPakX3vsfehjwQ4AaExDb1uUpIMHD2rNmjUaGBgY92P7XV1d6unpUXd3d+3PokWL6vqaBw4c0JIlS1SpVPSjH/1owp8qrRdvW2xgXt62WBfetljHlLxtsS6n+m2LDf+8/dlnn61du3bp3nvv1Ysvvlj7+P79+7V//3799a9/rX2ss7NzXMB3d3frBz/4wfiFlsu64447VC6XFUWRfvaznzW6JACAjG2LHR0dev755/XAAw/o6aef1rZt22qVAN+Vy+WUy+X0+uuv1z62aNEirVixQt3d3brgggv05JNPamBgoPb5u+66y7IkAJjzGr7lMpl9+/bpvffe0+7du2t/vvrqq+9PeMJ/B8em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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "ind_modularity\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "ind_minimality\n"
     ]
    },
    {
     "data": {
      "image/png": "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ADhBoAOAEwQ6ADhBoAOAEwQ6ADhBoAOAEwQ6ADhBoAOAEwQ6ADhBoAOAE27rc8d7Y+Vamn++io3tlrK3wqplNKB6t8W+blyzP59nxtF82X5dzbeNpFqnvT43ygIOslGubK/AjWv22fyE7SCn7bY6ZUnKOuzHNzdpr97Ncrb7RGStwJWkdls9cZYUpNLZt+MMHQCcINABwAkCHQCcINABwAkCHQCcINABwAkCHQCcINABwAkCHQCcINABwAkCHQCcINABwAkCHQCcMLctnjhxQidOnFBnZ6fWrl2rtra2c7lfAIAmNR3or7/+uu666y4dPHjwvR+Sz6u/v1+33Xab7r77bnV1dc2YmZyc1GOPPaZ//OMfyrJM11xzjW699Vb19/criqLwazGLSk+muLX5qtYsttW75ir261FdaZ+NEvOoInvLqvJl21y93X5d42pIzbD9H6PW41SYCKgK7rTvbz6genfqIwXbmhX7miFVwbUV9tpea1VwXLHX52YFW2Vvvb6w+0NTgT4yMqJt27apVCopy967s9ZqNR08eFAHDx7U3r179bOf/Uy7d++WJB0/flzbtm3TG2+88aGft2bNGt1zzz265557lM+7rWYHgEXR1GnAQw89pBMnTpwZjGMNDAxo+/bt6u3tVZZlyrJMIyMjuuuuu7Rnzx5J0s6dO3Xs2DFJamwz/Wd4eFjf/e53dcMNN+j48ePn9poBwDLT1Gnxs88+K0mKokjPPPOMPvvZzza+989//lN79uzR008/rSzLdN9992l0dFQvv/xy42WVL37xi+rr69Nbb72l559/XkeOHJEkHTlyRFu3btXBgwd16aWXnqvrBgDLSlNn6K+++qqiKNLmzZtnhLkk9fX16Xe/+51++ctfSjpzNv7ggw82vv/oo4/qt7/9rb7//e/r5z//uQ4fPqwDBw5o48aNkqTh4WF9/etfD7w6ALB8NRXoo6OjkqRrr712zm2+9a1vaffu3Y2XVaIo0s0336xdu3Z9aNuBgQEdOHBAN954o7Is0759+3To0KEmrwIAQGoy0Kffmlir1ebd7r777lMURY2XWr70pS/N+zMfeeSRxra/+c1vmtklAMC7mgr06f/8PHz48LzbXX755br++usb74Tp7++fd/t169bpE5/4hLIsm/F2SADAwjUV6AMDA5KkwcFBvfTSS/Nue9111zUur127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CHRgDo8//njj8q5du9TV1TXnth/8PY8333yzPvOZz5y3fQNmQ6ADc3j++ecbl++44455t/3gewt47RxLgUAHZjE0NKT//ve/kqR8Pq9PfepT827//kDfsmWLPv3pT5/X/QNmQ6ADs3j99dcbl6+88kq1trbOu/1//vOfxuVvf/vb522/gPkQ6MAs3njjjcblNWvWzLvt6OiofvKTnzT+vnr16vO2X8B8CHRgFuVyuXG5UCjMu+2ePXv09ttvN/6ey+XO234B8yHQgVnk8++1YpRKpTm3e/XVV/WrX/1qzllgMRHowCyuvvrqxuUjR47o2LFjH9pmampKu3fvVqVSmfH1ucq7gPONQAdmMTAwoJaWFkln3sGye/dunT59uvH9U6dO6fbbb9ff//53SWf+43Ta+9+/DiwmyrmAOXzta19rfIxfki666CJ97nOfU61W05///Ge98847ks58xP+BBx7QLbfc0tj2jjvu0KWXXqof//jH6uzsXPR9x/JEoANzmJiY0LZt2/TXv/51zm22b9+up556Sp2dnerr69Pg4GDje6tXr9apU6cWY1cBSbzkAsypo6NDL774oh5++GHdeuutuvjii5XP59XW1qb169fr/vvv1zPPPKPu7m7Fcaz9+/drx44dam9vlyRt2rRpia8BlhvO0AHACc7QAcAJAh0AnCDQAcAJAh0AnCDQAcAJAh0AnCDQAcAJAh0AnCDQAcAJAh0AnCDQAcAJAh0AnCDQAcAJAh0AnCDQAcCJ/we9YJ5qFKxXhAAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# 5.1. Minimality with Independent FoV Dataset\n",
    "alphas = np.arange(0., 0.5001, 0.025)\n",
    "betas = np.arange(0., 1.001, 0.05)\n",
    "\n",
    "fname = os.path.join(Path.cwd(), 'minimality_independent.pkl')\n",
    "fig_dir = Path(os.path.join(Path.cwd(), 'minimality_independent'))\n",
    "fig_dir.mkdir(exist_ok=True)\n",
    "\n",
    "with open(fname, 'rb') as file:\n",
    "    scores = pickle.load(file)\n",
    "scores_array = dict2array(scores)\n",
    "\n",
    "for key, array in scores_array.items():\n",
    "    print(key)\n",
    "    fig_name = os.path.join(fig_dir, \"{}.pdf\".format(key))\n",
    "    plt.figure(figsize=(4,4))\n",
    "    plt.imshow(\n",
    "        array.T, \n",
    "        extent=[alphas[0], alphas[-1], betas[0], betas[-1]],\n",
    "        cmap='viridis', \n",
    "        aspect='auto',\n",
    "        vmin=0,\n",
    "        vmax=1,\n",
    "        origin='lower'\n",
    "    ) \n",
    "    plt.tick_params(axis='both', which='major', labelsize=16)  # Major ticks\n",
    "    plt.xlabel(r'$\\alpha$', fontsize=24)\n",
    "    plt.ylabel(r'$\\beta$', fontsize=24)\n",
    "    plt.xticks([], [])\n",
    "    plt.yticks([], [])\n",
    "    plt.savefig(fig_name, bbox_inches='tight', pad_inches=0)\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "mig\n"
     ]
    },
    {
     "data": {
      "image/png": "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5x2MwbmzC173/Eurq4538Llzq9ZFRMSgYaZayyS3ZXi67hoG5XUNEwX7M/UHbpkqWH/MXBMFOTM4AwdISsABkhJwgKQEHCApAQdISsABkhJwgKQEHCApAQdISsABkhJwgKQEHCApAQdIKv00wlKOTo6bf2nhkwgjIoaH657DRof7VesiIroj9WtHR+qfc4cz9ZMMh3U3bwxn6yf7zc8Nq9f25+eq15bhfNW63rD+mN1opnptjCrvnIgolWtLqf9ao2FtKfWPieq15fRPp5yPuWOHPvWxu/J61zjD/etf/4r169cv9zYAFt0zzzwTF1100Un/PH3AR6NR7N+/P6anp6NrmJUNcKYopcTBgwdj3bp10eud/G/d6QMOcLbyQ0yApAQcICkBB0hKwAGSEnCApAQcICkBB0hKwAGSEnCApAQcICkBB0hKwOEU/vOf/8Stt94aW7ZsiQsuuCAmJydj/fr1cf3118eePXtOuO5PfvKT6Louuq6L++67b5l2zNnEMCt4DaWU+M53vhO33HJLvPjii695ndWrV8dvfvObuPrqq2M4HMY73/nO2LdvX2zevDkeeuih07xjzkbpf6EDLLbZ2dnYsWNH3HPPPeP/d9VVV8Xll18e+/fvjwceeCBmZmbi8OHDccMNN8Tu3bvjrrvuin379kVExM0337xMO+ds4wwcXuHTn/503HXXXRERccEFF8Tdd98dW7duHf/5rl274pprronZ2aO/zWbfvn3x8Y9/PPbs2RNbtmyJP/zhD8uxbc5CXgOHl7n77rvH8Z6YmIhf/vKXJ8Q7IuL9739/fOpTnxp//t3vfnf8erizb04nAYdjhsNhfOlLXxp//uUvfzmuuuqq17zu+973vvHlH//4xxERcfXVV8e11167tJuElxFwOObXv/51/OMf/4iIiPPOO++EmL/ShRdeOL48P3/0lyB/9atfXdoNwisIOBxz5513ji9ff/31MT09fdLrvvL3FH7gAx+ID3/4w0u2N3gtAg7H/P73vx9f3r59+ymv+8qf/Xvtm+Ug4BBH/yXJgQMHIiJiMBjEpk2bTnn9lwf8mmuuiW3bti3p/uC1CDhExN69e8eX3/GOd8TU1NQpr//Pf/5zfPnGG29csn3BqQg4RMRTTz01vrx+/fpTXvd///tffPvb3x5/vnbt2iXbF5yKgENEHD58eHx5YmLilNf9+te/Hs8+++z4836/v2T7glMRcIijr3sft3///pNe729/+1vcdtttJ10Lp5OAQ0Rs2LBhfPnRRx+NJ5988lXXOXLkSOzcuTNmZmZO+P8nG3YFS03AISI2b94ck5OTEXH0X5js3LkzXnjhhfGfP/fcc3HdddfFI488EhFHf9B53Mv//TicToZZwTGf+9znxm+Lj4g4//zz42Mf+1jMzc3F/fffH88//3xEHH3L/K233hof/OAHx9fdvn17vPWtb41vfvObsWbNmtO+d85OAg7HHDp0KD7ykY/Eww8/fNLrXHvttfGzn/0s1qxZE+95z3ti9+7d4z9bu3ZtPPfcc6djqxARXkKBsXPPPTcefPDBuP322+NDH/pQvOUtb4nBYBCrV6+Oyy67LG6++ea49957401velP0er247777YseOHXHOOedERMSVV165zF8BZxtn4ABJOQMHSErAAZIScICkBBwgKQEHSErAAZIScICkBBwgKQEHSErAAZIScICkBBwgKQEHSErAAZIScICk/j8hOBkkda6KUAAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "sap\n"
     ]
    },
    {
     "data": {
      "image/png": "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pNd97ff+ffbNchBwiGP/kuTQoUMREdHpdGLLli0nvf4rA37VVVfFjh07lvT44PUIOETE/v37R5ff/va3x8TExEmv/49//GN0+frrr1+y44KTEXCIiCeeeGJ0eePGjSe97osvvhjf+ta3Rl+vW7duyY4LTkbAISKOHj06utztdk963a997WvxzDPPjL5ut9tLdlxwMgIOcexz75cdPHjwhNf761//GrfccssJ18LpJOAQEZs2bRpdfvjhh+Pxxx//t+vMzs7G7t27Y25u7lV/fqJhV7DUBBwiYuvWrTE+Ph4Rx/6Fye7du+Oll14a/f2zzz4b11xzTTz00EMRcewbnS975b8fh9PJMCs47rOf/ezox+IjItavXx8f/ehHo9frxb333hvPPfdcRBz7kfmbb745PvCBD4yuu3Pnzjj//PPjG9/4RqxZs+a0HztnJgGH42ZmZuLDH/5wPPjggye8ztVXXx0//elPY82aNfHud7879u7dO/q7devWxbPPPns6DhUiwkcoMLJ69eq4//7749Zbb40PfvCD8Za3vCU6nU5MTk7GJZdcEjfeeGPcfffdcdZZZ0Wr1Yp77rkndu3aFatWrYqIiMsvv3yZbwFnGmfgAEk5AwdISsABkhJwgKQEHCApAQdISsABkhJwgKQEHCApAQdISsABkhJwgKQEHCApAQdISsABkhJwgKT+HxTVP+9bdqUDAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "dci_completeness\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "explicitness\n"
     ]
    },
    {
     "data": {
      "image/png": "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KyiKQq+++qpWr16ts2fPXvE2w4YN02effaa5c+cqyzLdfPPNOnz4sGbPnq0dO3YM8I5xNXL/Ax2Avlar1bRkyRJt3ry58WszZ87UtGnT1N7erm3btqlaraqjo0PLly/Xnj17tHHjRh0+fFiStGrVqkHaOa42XIEDl3nkkUe0ceNGSdLYsWO1adMmzZ8/v/H7u3bt0rx581SrXfhxK4cPH9aDDz6offv2ac6cOfrqq68GY9u4CvEaOHCJTZs2NcK7XC7ro48++lt4S9Kdd96phx9+uPH5a6+91ng9nKtvDCQCHLgoyzI9/fTTjc+feeYZzZw584q3veOOOxofv/POO5KkuXPnauHChf27SeASBDhw0aeffqqffvpJkjRq1Ki/hfnlxo0b1/g4TS/8ZOznnnuufzcIXIYABy7asGFD4+OlS5eqpaWly9te/nMK77rrLt177739tjfgSghw4KIvv/yy8fHixYu7ve3l3/vntW8MBgIc0IV/SXLixAlJUqlU0qxZs7q9/aUBPm/ePC1YsKBf9wdcCQEOSDp48GDj45tuuknNzc3d3v7nn39ufLxixYp+2xfQHQIckHT06NHGx62trd3e9o8//tArr7zS+Hz06NH9ti+gOwQ4IKmjo6Pxcblc7va2L7zwgk6ePNn4PEmSftsX0B0CHNCF173/0t7e3uXtfvjhB61du7bLWWAgEeCApEmTJjU+3rt3r44cOfKP23R2dmrZsmWqVqt/+/Wuyq6A/kaAA5Jmz56tSqUi6cK/MFm2bJn+/PPPxu+fOnVKixYt0u7duyVd+EbnXy799+PAQKLMCrjo8ccfb7wtXpLGjBmjBx54QPV6XVu3btXp06clXXjL/Jo1a3T33Xc3brt48WJdf/31eumllzRy5MgB3zuuTgQ4cNG5c+d03333aefOnV3eZuHChXr//fc1cuRI3XbbbdqzZ0/j90aPHq1Tp04NxFYBSbyEAjSMGDFC27dv17p163TPPffouuuuU6lU0rBhwzR16lStWrVKH3/8sa655hrFcawtW7ZoyZIlGj58uCRpxowZg3wPcLXhChwAnOIKHACcIsABwCkCHACcIsABwCkCHACcIsABwCkCHACcIsABwCkCHACcIsABwCkCHACcIsABwCkCHACcIsABwCkCHACc+j80r99sfcMoYQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "irs\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "ind_compactness\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAXAAAAFuCAYAAACYxUPUAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuNSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/xnp5ZAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAUc0lEQVR4nO3dWYxU5brG8WetVdVdDd0gHIzKsSXG0IpDjFMEjIg4XSoYjCZetDcmDolXRxPjhUMcj15oNBpNvDFegEYTEqc4caEGMFExgqAdQc1pSRSnHmpca52LhtqKdO+q9+thv93/X7KzC6jX76tVq59aVFNPR3me5wIAuBPP9AYAADYEOAA4RYADgFMEOAA4RYADgFMEOAA4RYADgFOFmd5AqCzLNDg4qJ6eHkVRNNPbAYBgeZ5raGhIS5cuVRyPf53tPsAHBwfV29s709sAgEn3448/6sQTTxz3z90HeE9PjySp9+n/UdzV2fZ8UkhN6zaq9kMXJ/YPvxY6GubZkL+gVIbbP7ahojizzwYc49i4bpYm9jUT23koSfVyh3nWKum0n4d5NjN/U7ae/1nD/k5zXLQ9r1m5qh9v/99mvo3HfYAfftsk7upUPK/U9rw1wLNkZgI8CQrwgFBL2z+2oaLEV4BrhgI81vQHeFyaOwGuekCAd9ifV0n/9m1hvokJAE4R4ADgFAEOAE4R4ADgFAEOAE4R4ADgFAEOAE4R4ADgFAEOAE4R4ADgFAEOAE4R4ADglPsyq8OSQmoqpkobtgKikLKkPLeX+aSp/TXX+lglKSrYCp6CiotmZjToOFk1agFfivbOL8l6Hgecw3lqnw35ususpVRxwNe68bG2OscVOAA4RYADgFMEOAA4RYADgFMEOAA4RYADgFMEOAA4RYADgFMEOAA4RYADgFMEOAA4RYADgFMEOAA4NWvaCOM4V2xoDYs7Gqb1QloB6+WieTYLaHILYi2tszbA2Zccm+2wV/TlFWMbYUBrnUJaGwsB61ZtjzUN2W8t4JwIeF6tjZohz01mzIms3trzwhU4ADhFgAOAUwQ4ADhFgAOAUwQ4ADhFgAOAUwQ4ADhFgAOAUwQ4ADhFgAOAUwQ4ADhFgAOAUwQ4ADhFgAOAU7OmTrZQyJQU0rbnGg1bnWax2P5ah4VU0eYh1ZYB1a7mSs2ANePuunk2q9hP7ahke27z0YA1A2qC8yykxtY4F1JrnNj3G/9hP8a5sXY3LwYc36LxALe4JFfgAOAUAQ4AThHgAOAUAQ4AThHgAOAUAQ4AThHgAOAUAQ4AThHgAOAUAQ4AThHgAOAUAQ4AThHgAOAUAQ4ATs2aOtlikipJ2q8BLcS2usdytcM0J0lZw/662TW/ap6txkXzrLWKNqj+NqCeNURetlUMt1oBetTRgrXXVYoqxv1KkrFiVeWAaz/rmpLygIcq42xUsz/WyHqcWqxD5gocAJwiwAHAKQIcAJwiwAHAKQIcAJwiwAHAKQIcAJwiwAHAKQIcAJwiwAHAKQIcAJwiwAHAKQIcAJyaNW2EpUJDhWL7dWONzPYa1lkcNc1JUq1kr1Sr1OyNgklib7xTbmsVTNOQij57k2FIM6C5fS6geTFqv0izKW4ErFu2zWYBjYIK2G9cDTnGxsdqLx5Vccj4dVNt7RzkChwAnCLAAcApAhwAnCLAAcApAhwAnCLAAcApAhwAnCLAAcApAhwAnCLAAcApAhwAnCLAAcApAhwAnCLAAcCpWVMnu7BUUbHUfl1qNbUdAmsNrSSlAbPzOuv2dYsN8+zwaKdpLu6yV9g2qvbTMy/bK3vzoq0qNQqoOg0R208JZcZ24pAK2xCx/RQ2S6r2WWtNcKtzXIEDgFMEOAA4RYADgFMEOAA4RYADgFMEOAA4RYADgFMEOAA4RYADgFMEOAA4RYADgFMEOAA4RYADgFMEOAA4NWvqZOMoVxy1XwM6v1AzrTfS6DDNSVKpYO/EzHJ7jedvI13m2WN6yqa534fsayq21bpKkkrGHk9JqtqqaPMu+5rRiL3+1loJOzZsnAt4akJm45DKXutowH4j4/FtdY4rcABwigAHAKcIcABwigAHAKcIcABwigAHAKcIcABwigAHAKcIcABwigAHAKcIcABwigAHAKcIcABwata0ERaiVIWo/Ta4jsTWINeR2BsFKwV7fVy5YZ/N55tHzUqlunm2ErBuo2o/tfOCtaLPznDqNgUUVNoLH0MaBev2DVvb/SQpN54SScCJmNjKThVVW7sfV+AA4BQBDgBOEeAA4BQBDgBOEeAA4BQBDgBOEeAA4BQBDgBOEeAA4BQBDgBOEeAA4BQBDgBOEeAA4BQBDgBOzZo62XmFuoqF9msq45B+SqNGZn/dbGSd5tkksneA1o17LhXttbv1uv30TBP7Y40Ltm7XdDhgvz32Ptmokphn49RY7RpQYRtSnRuiOGybi42VsJIUZbbzMG+0NscVOAA4RYADgFMEOAA4RYADgFMEOAA4RYADgFMEOAA4RYADgFMEOAA4RYADgFMEOAA4RYADgFPmAK9Wq5O5DwBAm8wBvmLFCr322muTuRcAQBvM/Zf79+/Xxo0btXbtWj355JM688wzJ3NfbfuvjhF1dAb0PrYpkb2GNssD6mRz+998YtkrViup7VT5o1oyr1nqqJtnk8T+/IwOGSt7C/bjq5r9nIjth0lZ0bbnwoi9Tzag1Vh5QAG2tRY2brHa9aiz1uemxb0Gvwe+detWnXPOObrtttv066+/hv7nAAAtMgf4e++9p9NPP115nitNUz333HNavny5nn76aWXZ9P+QBACYa8wBvm7dOu3cuVNPPfWUFi9erDzP9dtvv+mOO+7Q2Wefrffff38y9wkAOELQWyhxHOv222/Xt99+q1tuuUVJkijPc+3evVtXXnml1q9fr++++26y9goA+ItJ+XfgixYt0jPPPKPPPvtMa9euVZ7nyvNcW7Zs0RlnnKG7775bIyMjk7EUAOCQSf0gz1lnnaUPPvhAr7zyik4++WTlea5qtapHH31UfX19eumllyZzOQCY06bkk5jXXnutdu/erfvvv1/z589Xnuf66aef1N/fr1WrVunTTz+dimUBYE6Zso/Sd3Z26p577tHevXt1ww03SJLyPNf27du1atUq9ff368CBA1O1PADMelPehbJ06VK9/PLL+uijj3TeeedJkrIs00svvaS+vj49/PDD+uabb6Z6GwAw60xLmdWBAwdUq9V00003qbe3V1EUKc9zDQ8P65577tGKFSvU09Oj1atX69Zbb9Xzzz+vHTt2qFKpTMf2AMClgA+m/l29Xte3336rPXv2aO/evdqzZ0/z9tDQ0D/uH0VjH8XN87GPqY6MjGj79u3avn178z5JkqhWm76PxwOAJ0EBvm3bNj377LP65JNPtH///qN+AvNwQB/NkiVL1NfXp19++UUDAwP/mE/TNGR7ADCrmQP8rbfe0jXXXKNGoyFp/KAulUpavny5+vr6dOqppzb//9RTT9UxxxzTvN/o6Ki+/PJLffHFF83/ffXVV9btAcCsZw7wBx54QPX6v6q2jj/+eJ111ll/C+m+vj6ddNJJzbdLJjJv3jytXLlSK1eu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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "ind_sufficiency\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# 5.2. Sufficiency with Independent FoV Dataset\n",
    "alphas = np.arange(0., 0.5001, 0.025)\n",
    "gammas = np.arange(1., 2.001, 0.05)\n",
    "\n",
    "fname = os.path.join(Path.cwd(), 'sufficiency_independent.pkl')\n",
    "fig_dir = Path(os.path.join(Path.cwd(), 'sufficiency_independent'))\n",
    "fig_dir.mkdir(exist_ok=True)\n",
    "\n",
    "\n",
    "with open(fname, 'rb') as file:\n",
    "    scores = pickle.load(file)\n",
    "scores_array = dict2array(scores)\n",
    "\n",
    "for key, array in scores_array.items():\n",
    "    print(f\"{key}\")\n",
    "    fig_name = os.path.join(fig_dir, \"{}.pdf\".format(key))\n",
    "    plt.figure(figsize=(4,4))\n",
    "    plt.imshow(\n",
    "        (array[:,:21].T)**2, \n",
    "        extent=[alphas[0], alphas[-1], gammas[0], gammas[-1]],\n",
    "        cmap='viridis', \n",
    "        aspect='auto',\n",
    "        vmin=0,\n",
    "        vmax=1,\n",
    "        origin='lower',\n",
    "    ) \n",
    "    plt.tick_params(axis='both', which='major', labelsize=16)  # Major ticks\n",
    "    plt.xlabel(r'$\\alpha$', fontsize=24)\n",
    "    plt.ylabel(r'$\\gamma$', fontsize=24)\n",
    "    plt.xticks([], [])\n",
    "    plt.yticks([], [])\n",
    "    plt.savefig(fig_name, bbox_inches='tight', pad_inches=0)\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "beta_vae\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "factor_vae\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAXAAAAFuCAYAAACYxUPUAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuNSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/xnp5ZAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAXVklEQVR4nO3de4yV9Z3H8c9zbnPOMGcGhhlQYKBgSK3FbmkZEdRRtJTdbE0dstqmoa1tbZs0Gxu7RpN1Ta3d0tbo/kE0tdq13YtuYEm3IYIYbWiVm5qKsIJrCuNldLgOc2cu5/LsH4MnooDnfB8u/c68XwnJYeb58Huec57zmYczZ74ThGEYCgDgTux87wAAwIYCBwCnKHAAcIoCBwCnKHAAcIoCBwCnKHAAcCpxvncgqmKxqI6ODmWzWQVBcL53BwAiC8NQfX19mjZtmmKxU19nuy/wjo4ONTU1ne/dAIAzrr29XTNmzDjl590XeDablSQ13f1PiqXTFeerOm2vIhXjpthoNm3/4ddi0r5uqsv+P5SRSef+B3bDCC/wZQ7aj/XYjKIpFxu2r5kYsGeDvDmqkXrbsSq072+YtJ9L6QP2k2K4wXasUc7D1FFjvwwPqW3VvaV+OxX3Bf7eyyaxdNpU4PEq2x0cRChwRShwRSjweJX9SReLss9GUZ440Y7VWOARXsKL5yMUeIRz0Xqs56vArc9XyX6s0c7DaN9m/KiXhfkmJgA4RYEDgFMUOAA4RYEDgFMUOAA4RYEDgFMUOAA4RYEDgFMUOAA4RYEDgFMUOAA4RYEDgFPuh1m9586//p0yNZUfTnP6bdN6jXH7QJ6Ogn360JruZnP2qfZPmLMD70405ZLd9mPNTyiYs0ON9nWt0/1iOfOSCiMMpIoyjTDVY7uGS/bZ16xedsic7e6aas7Gm46Zcv+98BHzmjf+522mXDEor1+4AgcApyhwAHCKAgcApyhwAHCKAgcApyhwAHCKAgcApyhwAHCKAgcApyhwAHCKAgcApyhwAHCKAgcAp8bMNMIlmbeVra7869GFiZqzsDen11EYMmf/ecr/mrNLsnvM2fQnbaP25iRsE+Ak6R87/sac/buGl8zZv//9V23BafZxhIV3M+Zs1aW95uxQf5UpF381bV6z95g9e/9XHzNn/7ba9rx7Ixdh3ONZxhU4ADhFgQOAUxQ4ADhFgQOAUxQ4ADhFgQOAUxQ4ADhFgQOAUxQ4ADhFgQOAUxQ4ADhFgQOAUxQ4ADhFgQOAU2NmnOwFiRrVJir/enSkMGBaryE+wZSTpE+l7OM038j1m7MtafvI0r25YVMuyrjeFY1bzdnGuO1xlaQHr/sPUy4d2MfJ7huZas6mgxFz9pE3W0y5uR8/bF7zlil/NGef7Ztnzv7gTwtMuRrjGFpJSgwEplxhuLwcV+AA4BQFDgBOUeAA4BQFDgBOUeAA4BQFDgBOUeAA4BQFDgBOUeAA4BQFDgBOUeAA4BQFDgBOUeAA4BQFDgBOjZlxslZt+ZQp1xC3r/nisH3s6OaBT5mzP6hvM2fTQdGU25+3j7/91wPXm7N/VfuOOfvYnkWm3MixpHnNT87uMGcb0/b7+JoL/mzKbXzoSvOaX71yrjlbs8s+irmuMzTlUn32McxT99jG7uYLwyrnkeEKHACcosABwCkKHACcosABwCkKHACcosABwCkKHACcosABwCkKHACcosABwCkKHACcosABwCkKHACcGvfTCC+rsk2Q2zUyZF5zfso+tS4d7DFnJfskt//ps09BtKqK583Zh1+82pzNtNkmVE77s21ioyTl99Wbs29Nnm7OHjg4YMpN7bVPT5z6rDkq5eznRHFyrSkXdBwxr6mJWVuuUChrM67AAcApChwAnKLAAcApChwAnKLAAcApChwAnKLAAcApChwAnKLAAcApChwAnKLAAcApChwAnKLAAcApChwAnBoz42T/q69embDyw7kq86ZpvU8kM6acJPUU7aNoXxmaZc42xt40Z1uzu0y5f3ir1bxm13C1ORtLlTeO82Qm7A9NuYlb281rKgjM0czRfnM2jDDa2Lxm0l47wUjOnI0d7TPlwoaJ5jXzE23ncD6flPZ99HZcgQOAUxQ4ADhFgQOAUxQ4ADhFgQOAUxQ4ADhFgQOAUxQ4ADhFgQOAUxQ4ADhFgQOAUxQ4ADhFgQOAUxQ4ADg1ZsbJ1scHVJ2IV5xb0zvftN68jH10aGd+qjn7u0O2/ZWk56s+bs7uH6w15V5rv8C8ZmqffWTvlNeL5mz99g5TrnDBJPOaUcbJxg/32JcdGDTlipNt54MkxXqPmbMq2h9XWUfn5u2jiRPdxmMtDJe1GVfgAOAUBQ4ATlHgAOAUBQ4ATlHgAOAUBQ4ATlHgAOAUBQ4ATlHgAOAUBQ4ATlHgAOAUBQ4ATlHgAODUmJlGeG3mmGozlX89uiS5w7Te7GSNKSdJ/3J0mjl7XcP/mbP/9sbl5qxV9iX7RMGqrtCcrd03YM4qlzfF4kf7zUuGMfs0wiiTDK3ZMGWvjtAwNbSkptqeNU4jLFanzEvGO/tMuaCYK2s7rsABwCkKHACcosABwCkKHACcosABwCkKHACcosABwCkKHACcosABwCkKHACcosABwCkKHACcosABwCkKHACcGjPjZJNBXMmg8q9He3INpvX2lDft8aSO5ieYs0+1f8K+bvtEcza713aqRLlCqNt3zJyNMtq1ODFrysUGBs1rKmYfsRpW2cedBj22+yl+uMe8ZpiMUDtRRtGO2J608QiPa2gcYRsWyjtOrsABwCkKHACcosABwCkKHACcosABwCkKHACcosABwCkKHACcosABwCkKHACcosABwCkKHACcosABwKmyx4IVCgWtXLlSF198sRYuXKiZM2eectuuri61t7draGhIF154oWbMmKEgCM7IDgMARpVd4KtXr9YPf/hDBUGgRx99VN/85jc/tM327dt1xx13aNu2bSoWi6WPp1IpLVy4UJ///Of19a9/XdOnTz8ze/8+b+b6lc1V/h+KvsIk03pPd80z5aIaGrGNp5Sk2Ij9P1zT/mgbHxoUQvOawXCEmb3GMZ6SpLjtYqNYW21eMhgYMmejCLO2fQ5T9pGwsb4IY3ePRbifjBeRIx9rNC+Z2nfAlAuKI2VtV/Yzet26dZKkTCajr3zlKx/6/Jo1a3TVVVdpy5YtKhQKCsOw9Gd4eFjPP/+87r77bs2ZM0df+9rXdPDgwXKXBgCcRNkFvmvXLgVBoEsvvVTpdPqEz7W3t+tb3/pWqbhP5r0yz+Vyevzxx3XJJZdo/fr10fYeAMaxsgu8o6NDkjR79uwPfe7nP/+5BgYGFASB5s+fr3Xr1qmrq0v5fF6HDx/Wli1b9NOf/lSf/exnJY2WeVdXl1pbW7V69eozdCgAML6UXeADAwOSpJqamhM+XiwW9cQTTygIArW0tGjLli36whe+oLq6OsViMU2ePFmLFi3SnXfeqZdeekmbN2/WggULJEn5fF7f+MY3tHPnzjN4SAAwPpRd4Mnk6DeF4vETf1fbjh071N3drXg8rt/85jcfennlgxYvXqytW7fq29/+tiRpaGhIt9xyS6X7DQDjXtkFXldXJ0nq7u4+4ePbtm2TJDU3N2vWrFll/VuJREK//OUvdcMNN0iSXn75ZW3cuLHcXQEAqIICnz17tsIw1Ouvv37Cxzdt2lR67btSDz74oBKJ0bcj/fa3v604DwDjWdkF3tzcLGn03ShtbW2SpCNHjuipp56SJM2bV/n7oqdNm6aWlhaFYajNmzdXnAeA8azsAm9tbZU0+g6S1tZWrV27VitWrNDQ0Ogb6zds2GDagTlz5kiS9u/fb8oDwHhVdoFfc801Wrx4scIw1KuvvqovfelLeuaZZxQEgcIw1Pr16/WLX/yi4h3o6+uTpNIXAgBAeSr62eonnnii9Fr4e38k6bvf/a6uv/563XrrrVq1alXZ/14ul9OmTZskSQ0NDZXsCgCMexUV+MyZM7Vz5079+Mc/1pVXXqkFCxZo5cqVeuihh/TAAw+opqZGt912m5YsWaLnnnvutP9WGIa69dZbdejQIQVBoE9/+tNRjgMAxp2KJ9LU1NTorrvu0l133XXCxy+66CKtXbtWN9xwg5577jktWbJEs2bN0tKlS3XZZZdp7ty5qqur0+DgoF555RX96le/0o4dO0r5m266KfrRAMA4EoSnGl5i9MILL2j58uXav39/WSNkwzBUc3Oztm/fbho529vbq7q6Ou3YPUXZbOXT9v69+7KKM1G91FXe++VP5rWX7dmqLvs0wqZn+k25xEHbFENJ5ulxkhQm4h+90amWHRw25YqTa+1rjuTNWeUiZK33U9FeG2GVfZJhMGw/1mAkwnRLqyHbuZQvjujZA4+op6dHtbWnPq/O+C90WLhwofbs2aNbbrlFiUTihNfL3/+6+Xu3m5ub9eSTTzIvHAAqdFZ+I09dXZ0eeeQRtbW16b777tOyZcs0a9as0o/h19bWaunSpfr1r3+tbdu2qbHRPm8XAMYr+/9lyjB9+nTdfvvtuv322yWNXnVzpQ0AZ8Y5/Z2YlDcAnDn8UmMAcIoCBwCnKHAAcIoCBwCnKHAAcIoCBwCnKHAAcIoCBwCnKHAAcIoCBwCnzuoslHPpyf55ShsOpytfbVpv59HpppwkDeXPz90+4/cD5mziUK8pV8xmzGuGVUlzNtYf4Vf0GUeshokI10NFezYo2LNh3HasQSzCFOqiPRomIzx3YrZRHoU6+zlsHqdc5n3EFTgAOEWBA4BTFDgAOEWBA4BTFDgAOEWBA4BTFDgAOEWBA4BTFDgAOEWBA4BTFDgAOEWBA4BTFDgAOEWBA4BTY2ac7JuDDUrFKx8/2jFYa1vvnQZTLqp0j/1rbnJ/tzkbZqpMueDdQ+Y1g/qJ9mzBPrO0OME2PjS+/6h5TQW2UaeS/bGRpFhnt23NXM6+ZrbGnLU+NqML25478X37zUuGjZNsuUJ523EFDgBOUeAA4BQFDgBOUeAA4BQFDgBOUeAA4BQFDgBOUeAA4BQFDgBOUeAA4BQFDgBOUeAA4BQFDgBOjZlphG8dm6RkkKo4N5CrPCNJytu/9qUO2u/22WsOm7Nh2nisksJk3JSLpexrKl/mSLYzLCjaJhmGE7P2RXN5czRMVz6Fs5TNGB+fCNMTNThijsYGBs1Z6/kfZCeY19SQ7ViDYnk5rsABwCkKHACcosABwCkKHACcosABwCkKHACcosABwCkKHACcosABwCkKHACcosABwCkKHACcosABwCkKHACcGjPjZFOxvJIxw9cj6yTOWGgMSrM2HDNngz57NorCjMm24JRJ5jVjnb3mbGHqRHM2yNvGyQa5CONv4/ZrqWAoZ88O28adhin7CNugb8CcVcJeWYFxZG/eeu5LUtHWE/l8Unrjo7fjChwAnKLAAcApChwAnKLAAcApChwAnKLAAcApChwAnKLAAcApChwAnKLAAcApChwAnKLAAcApChwAnKLAAcCpMTNOdjCfVC6fqjjXdrDBtN7UTfa7Lj5gH6cZVqfNWYX2EbiJgz2mXLG22rxmlDGeifYj5mxYV2PKBUO20aySVIzyuFbZR7tax9iGybh9zQijaGUcCSvZx8nGO/vNaxZrMqZcUCjvucoVOAA4RYEDgFMUOAA4RYEDgFMUOAA4RYEDgFMUOAA4RYEDgFMUOAA4RYEDgFMUOAA4RYEDgFMUOAA4NWamEWYSOSUTQcW5eKJoWq/+hUOmnKRo09giTBQMqyqf1ljS3WmKxYaGzUsG+YI5a52yJ0lF63S/CFMBg6LtPJSkWI99umWh3jZ5MZ+tMq+Z2t9rzkY5/xVU3g+SFAzaz2HV2adxloMrcABwigIHAKcocABwigIHAKcocABwigIHAKcocABwigIHAKcocABwigIHAKcocABwigIHAKcocABwigIHAKfGzDjZjv46xYuGEZe7s7YFew/acpLCxnpzNhZlxGrSPrK0OHOKKRfrHTSvGWWMZ1hnG5MqSfHuflOumM2Y1wyG8+asBofM0fhRWy721gHzmpoy2RzNTTE+XyWl3rEdbJixj84Ncrbna1Ao77nKFTgAOEWBA4BTFDgAOEWBA4BTFDgAOEWBA4BTFDgAOEWBA4BTFDgAOEWBA4BTFDgAOEWBA4BTFDgAOEWBA4BTY2acbN+fGhRPpyvOzVrfZ1uwvs6WkxQMj5izYdL+kOUmTzBnU+922YIF+/jbKCNhNZKzr2u8j2N99tG5YXXl525J2j7uNEzETbkgEaE6Buz3UzLC42pV7mjXkylkkqZcscyx0VyBA4BTFDgAOEWBA4BTFDgAOEWBA4BTFDgAOEWBA4BTFDgAOEWBA4BTFDgAOEWBA4BTFDgAOEWBA4BTY2Ya4awnu5WIVz6VLRjJm9YrplOmnCTFjGtKUhgE5mzqnaP2dY1T68Ia+5S9YDjC/VRtn9CnQmjLxe3XQ0FPvzkb1tqnTAZ9x0y54pRJ5jUVs99PsZ4B+7rW505oPB8kafsu45rlTV3kChwAnKLAAcApChwAnKLAAcApChwAnKLAAcApChwAnKLAAcApChwAnKLAAcApChwAnKLAAcApChwAnHI/jTA8PiksXxg25YOCcRqhdWKdpJhxTSnaNMJY0XYfSVJYME4jjHA/WR+b0XWL5qx1GmFQKJiXDCI9NvansXXdYiFpXlNhhGmEEe6n8zGNMF/mVMEP5ZQ7vvTp1w7Cj9riL9w777yjpqam870bAHDGtbe3a8aMGaf8vPsCLxaL6ujoUDabVRDh6hQA/lKEYai+vj5NmzZNsdPMT3df4AAwXvFNTABwigIHAKcocABwigIHAKcocABwigIHAKcocABwigIHAKcocABwigIHAKcocABwigIHTuPw4cNauXKlFi9erMbGRlVVVampqUkrVqzQ7t27T9j2scceUxAECoJATz/99HnaY4wnDLMCTiIMQ91///2699571d/ff9JtMpmMnnnmGV1xxRUqFAq6+OKLtXfvXi1atEhbt249x3uM8cj9L3QAzrSRkRHdeOONWrduXeljzc3Nmjdvnjo6OvSHP/xBw8PDGhwc1Pe+9z3t3LlTq1ev1t69eyVJ99xzz3nac4w3XIEDH/DlL39Zq1evliQ1NjZqzZo1uuaaa0qff+GFF9TS0qKRkRFJ0t69e/XFL35Ru3fv1uLFi7Vly5bzsdsYh3gNHHifNWvWlMo7mUxq/fr1J5S3JC1cuFA33XRT6e8PPPBA6fVwrr5xLlHgwHGFQkF33HFH6e933nmnmpubT7rtggULSrcfffRRSdIVV1yhpUuXnt2dBN6HAgeO27hxo9566y1J0qRJk04o8w+64IILSrfz+dFfvvyjH/3o7O4g8AEUOHDc448/Xrq9YsUKZbPZU277wd9TeNVVV+m66647a/sGnAwFDhy3adOm0u3ly5efdtsPfu+f175xPlDggEbfSXLgwAFJUiKR0OWXX37a7d9f4C0tLbr22mvP6v4BJ0OBA5Jef/310u2LLrpI6XT6tNu//fbbpdvf//73z9p+AadDgQOS3njjjdLtpqam027b09Oj++67r/T3+vr6s7ZfwOlQ4ICkwcHB0u1kMnnabX/yk5/oyJEjpb/H4/Gztl/A6VDggEZf935PR0fHKbd77bXXtGrVqlNmgXOJAgckzZ07t3R7165damtr+9A2Q0NDuvnmmzU8PHzCx0817Ao42yhwQNKiRYtUVVUlafQdJjfffLN6e3tLn+/s7FRra6tefPFFSaPf6HzP+98/DpxLDLMCjvvOd75T+rF4SWpoaNCyZcuUy+X07LPP6ujRo5JGf2R+5cqVuvrqq0vbLl++XBdeeKF+9rOfqaam5pzvO8YnChw4bmBgQJ/73Oe0ffv2U26zdOlSrV27VjU1NfrMZz6jnTt3lj5XX1+vzs7Oc7GrgCReQgFKJkyYoM2bN+vhhx/WkiVLNHXqVCUSCWUyGV1yySW65557tGHDBtXW1ioWi+npp5/WjTfeqOrqaknS/Pnzz/MRYLzhChwAnOIKHACcosABwCkKHACcosABwCkKHACcosABwCkKHACcosABwCkKHACcosABwCkKHACcosABwCkKHACcosABwCkKHACc+n8jg3IbsV96bQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "modularity\n"
     ]
    },
    {
     "data": {
      "image/png": "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AHCKAAcApwhwAHCKAAcApwhwAHCKAAcAp2ZNnexEXlWWl3ueS9u2asu0sFdijqV95tmG4RiPGU+r5tkjdduaC3sjrCqVzDybpfbHpzrQNM2FVKzmmX29IbW7kw3bNVEu2x+bkIrhkP2OHZxnmovSgKrfSdts1OhujjtwAHCKAAcApwhwAHCKAAcApwhwAHCKAAcApwhwAHCKAAcApwhwAHCKAAcApwhwAHCKAAcApwhwAHCq61qwPM+1YcMGXXnllVq+fLkuueSSabc9dOiQ9u3bp0ajoYsuukiLFy9WFNmb2gAAp+o6wDdu3KjvfOc7iqJITz/9tL72ta+dss2uXbv00EMPaefOnWq32533VyoVLV++XDfddJO+8pWv6OKLLz47qz/OZF5RbqhabRsrQEMqYccye63raCtgvy37flvGCtCQ5+2QStharWWeLSW5aS7L7ettmCelrGXfb9ZlbenJin7zLlUqtT98o2k06hX7jmNb7W6U2i/ixNZMLHU51/Wjt2XLFklSrVbTl7/85VM+vmnTJt1www3asWOH8jxXURSdP81mU7///e/17W9/W5dddpnuuusuvfvuu93uGgBwGl0H+JtvvqkoivSJT3xCfX0n3gXu27dPX//61zvBfTrHwjxNUz377LO66qqrtHXr1rDVA8Ac1nWAj4yMSJIuvfTSUz72ox/9SBMTE4qiSNdcc422bNmiQ4cOKcsyHThwQDt27NAPfvADXXfddZKmwvzQoUNau3atNm7ceJYOBQDmlq4DfGJiQpI0MDBwwvvb7baee+45RVGkVatWaceOHfriF7+ooaEhxXGsj33sY1qxYoUefvhh/fGPf9T27du1bNkySVKWZfrqV7+q3bt3n8VDAoC5oesAL5envkCYJCd+weSNN97Q4cOHlSSJfv3rX5/y8srJVq5cqddee03f+MY3JEmNRkP33HNPr+sGgDmv6wAfGhqSJB0+fPiE9+/cuVOSNDw8rKVLl3b1b5VKJf385z/XbbfdJkn605/+pJdeeqnbpQAA1EOAX3rppSqKQm+//fYJ79+2bVvnte9e/eQnP1GpNPXtac8//3zP8wAwl3Ud4MPDw5Kmvhtl7969kqT3339fv/nNbyRJV199dc87X7RokVatWqWiKLR9+/ae5wFgLus6wNeuXStp6jtI1q5dq82bN2v9+vVqNKZ+BOHFF180LeCyyy6TJO3fv980DwBzVdcBfuONN2rlypUqikJ/+ctfdOedd+qVV15RFEUqikJbt27Vz372s54XMDY2JkmdJwIAQHd6+jna5557rvNa+LE/kvTNb35Tt9xyi+6//349+eSTXf97aZpq27ZtkqQLLrigl6UAwJzXU4Bfcskl2r17t773ve/pM5/5jJYtW6YNGzbopz/9qZ544gkNDAzoW9/6llavXq1XX331jP9WURS6//779d577ymKIn3yk58MOQ4AmHN6bigaGBjQI488okceeeSE919++eXavHmzbrvtNr366qtavXq1li5dqjVr1uhTn/qUrrjiCg0NDaler+vPf/6znnnmGb3xxhud+TvuuCP8aABgDomK6cpLjF5//XWtW7dO+/fv76pCtigKDQ8Pa9euXabK2dHRUQ0NDemubXeqMtB7U1nd0GAoSQ3jnBTWKDge0Ch4pG7fb6tlbSO0X161amqerZYz82wS29ry8ra9Xr+V2RsFxyft10Q6apwtndXY6F5AM2DUtD0+pQn741o5Yltv3mzof/77v3TkyBHNnz9/2u3O+i90WL58uf7617/qnnvuUalUOuH18uNfNz/29vDwsF544QX6wgGgR+fkN/IMDQ3pF7/4hfbu3avHH39cN998s5YuXdr5Mfz58+drzZo1+tWvfqWdO3dq4cKF52IZADCr2f5f3KWLL75YDz74oB588EFJU3fd3GkDwNlxXn8nJuENAGcPv9QYAJwiwAHAKQIcAJwiwAHAKQIcAJwiwAHAKQIcAJwiwAHAKQIcAJwiwAHAqXPahXI+jWY1ldPe62QzYwXokVbNNCdJk6m9ina8Ya8ObTbs+40TW8VqtWKvdR3sa5pnayV7FW2rbat2bZn3KEn2OtkioMbWKhq3r1chjRoBs3HLNlyatO80qRsHu7z0uQMHAKcIcABwigAHAKcIcABwigAHAKcIcABwigAHAKcIcABwigAHAKcIcABwigAHAKcIcABwigAHAKcIcABwatbUyR5u1FRKeq9atVaHjgbUurYy+2kPqYTNUnsFaM1YC1ur2Gtd04Ca1LRlf3ysmmnA4xowG8TYlJo07I9NUrfXs+Z9hX2/Ddt+zZWwksoTtvXGre7muAMHAKcIcABwigAHAKcIcABwigAHAKcIcABwigAHAKcIcABwigAHAKcIcABwigAH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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "dci_disentanglement\n"
     ]
    },
    {
     "data": {
      "image/png": "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qz9GrMsrZg31o9Y6zZQKz3JCFWeKlBdR49jYeIp9ygOHzWOVUnfaWRj8ORPqb1OEujrbwJT1trXbx5btz7tQX28aFzs6zHMOtD5fQlm3bp0kqaGhQbfddts/vr927VpdccUV2rJli0qlkmKMlY+Ojg598sknevjhhzVlyhTdcccd+v333/vvXgDAMNTnAP/6668VQtAFF1ygESO6F97v3r1b99xzTyW4T+RomBcKBb355ps677zztH79+rTVA8Aw1ucAb2lpkSRNnjz5H997+umn1draqhCCpk2bpnXr1mn//v0qFovas2ePtmzZoieffFIXX3yxpK4w379/vxYsWKA1a9b0010BgOGlzwHe2toqSWpsbOz29XK5rLfeekshBM2ePVtbtmzRddddp6amJmUyGZ122mmaOXOmli9frs8//1ybN2/W9OnTJUnFYlF33XWXduzY0Y93CQCGhz4HeP7I+xNmj/tBzZdffqkDBw4om83qjTfe+MfllePNmjVLn376qe69915JUnt7u5YsWVLtugFg2OtzgDc1NUmSDhw40O3rW7dulSQ1Nzdr0qRJffq3crmcXnrpJd14442SpC+++EIbN27s61IAAKoiwCdPnqwYo3744YduX9+0aVPl2ne1nnvuOeWOvMv6f/7zn6rHA8Bw1ucAb25ultT12yi7du2SJO3du1fvvvuuJOn888+vevLx48dr9uzZijFq8+bNVY8HgOGszwG+YMECSV2/QbJgwQK9/fbbWrRokdrbu34pf8OGDaYFTJkyRZL066+/msYDwHDV5wCfM2eOZs2apRijvvnmG91yyy16//33FUJQjFHr16/XCy+8UPUCDh/u+mu7oy8EAIC+qarM6q233qpcCz/6IUn333+/rr/+ei1dulSrV6/u879XKBS0adMmSdLpp59ezVIAYNirKsDPPvts7dixQ48//rguv/xyTZ8+XStXrtTzzz+vVatWqbGxUQ899JDmzp2rjz/+uNd/K8aopUuX6o8//lAIQRdeeGHK/QCAYSfEnv723eDDDz/UjTfeqL///luSNGnSJM2bN0+XXHKJzj33XDU1NamtrU1fffWVXn31VX355ZeKMSqEoDfeeEO333571XMeOnRITU1NunrKUuWyhrKampRZJYxNUYsyqwZbgZCUVmYVi0XzWHOZVSZh/yaUQ8WEYzHk+txn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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "irs\n"
     ]
    },
    {
     "data": {
      "image/png": "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N7kVtdw2WLefYlHDvt88ZNb61AY8N3Fqny0DZpUaG/oye91jnBnPJUlREXCMc9vHXVTYMkJqv1XwuDmNzB3Jt9FE5X+6x7fcJ598orlz5072NgDglOvv79ecOXNGfb/7AC+KQgMDA+rp6VEU0hUMAN8SZVlqaGhIs2fPVhyP/kq3+wAHgOmKL2ICgFMEOAA4RYADgFMEOAA4RYADgFMEOAA4RYADgFMEOAA4RYADgFMEOAA4RYADgFMEOHASX3zxhdauXavFixdr1qxZ6uzs1Ny5c7Vy5Up98MEHR933T3/6k6IoUhRFeuWVVyZpx5hOKLMCTqAsSz3xxBP6zW9+o4MHD57wPl1dXdq8ebOuvPJK5Xmuiy++WHv27NGiRYu0ffv2Cd4xpiP3v9ABONWazaZuuukmbdy4sfW2vr4+XXrppRoYGNBrr72mRqOhWq2mX/ziF9q1a5fWrVunPXv2SJIefvjhSdo5phuuwIFj3HrrrVq3bp0kadasWVq/fr2uueaa1vvffPNNLVmyRM3myK/u2bNnj2644QZ98MEHWrx4sbZt2zYZ28Y0xGvgwDesX7++Fd7ValWbNm06KrwlaeHChbr55ptbf3/yySdbr4dz9Y2JRIADh+V5rgcffLD19zVr1qivr++E912wYEHr9nPPPSdJuvLKK7Vs2bLx3STwDQQ4cNjLL7+sf/7zn5KkM84446gwP9Z3v/vd1u3s8C/4/fWvfz2+GwSOQYADh73wwgut2ytXrlRPT8+o9z329xReddVVuvbaa8dtb8CJEODAYVu2bGndXrFixUnve+zX/nntG5OBAAc08p0k//73vyVJlUpFP/jBD056/28G+JIlS/SjH/1oXPcHnAgBDkjavXt36/aFF16oGTNmnPT+//rXv1q377vvvnHbF3AyBDgg6eOPP27dnjt37knve+DAAT3++OOtv5955pnjti/gZAhwQFKtVmvdrlarJ73v7373O3355ZetvydJMm77Ak6GAAc08rr3EQMDA6Pe76OPPtJTTz016iwwkQhwQNJFF13Uuv3+++9r7969x92nXq9r1apVajQaR719tLIrYLwR4ICkRYsWqbOzU9LId5isWrVKg4ODrfd/9dVXWr58ud566y1JI1/oPOKb3z8OTCTKrIDD7r777taPxUvS2Wefreuvv15pmurVV1/V119/LWnkR+bXrl2rq6++unXfFStW6JxzztGjjz6q7u7uCd87picCHDhseHhY1113nXbu3DnqfZYtW6YNGzaou7tb3//+97Vr167W+84880x99dVXE7FVQBIvoQAtp59+urZu3apnnnlGS5cu1Xe+8x1VKhV1dXXpkksu0cMPP6yXXnpJM2fOVBzHeuWVV3TTTTfptNNOkyTNnz9/kh8BphuuwAHAKa7AAcApAhwAnCLAAcApAhwAnCLAAcApAhwAnCLAAcApAhwAnCLAAcApAhwAnCLAAcApAhwAnCLAAcApAhwAnCLAAcCp/wM+vYkANliI2QAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "ind_modularity\n"
     ]
    },
    {
     "data": {
      "image/png": "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wAHAKQIcAJwiwAHAKQIcAJxy30aY51NNbKPjmWl+LLHNTRjnJKkW2xoQJanRiM2zcc3e5JZM2uryUuOcJGWT9pa9rGavvAvqtoq+tFGkAdE8qiCyP06B9ZSIC6wZ2187YWJ/oPLU+Nop0kaY2l7rSTp1Pw/l23TcB/jY2JgkafFF/5rbjczIv+Z6AwAcGBsbU39//7SfD/Kvi/j/cFmWaXBwUL29vQoKfKUEgP8UeZ5rbGxMCxcuVKk0/Tvd7gMcANoV38QEAKcIcABwigAHAKcIcABwigAHAKcIcABwigAHAKcIcABwigAHAKcIcABwigAHAKcIcOAo9u/frw0bNmjFihVasGCBOjs7tWjRIq1bt07vvPPOYcf+9a9/VRAECoJAzz777BztGO2EMivgCPI81+9//3v9+te/1vj4+BGP6e7u1nPPPadLLrlEaZrq3HPP1Z49e7R8+XK9/PLLs7xjtCP3feDAsRZFka677jpt2bKl+bGBgQGdf/75Ghwc1AsvvKBGo6Faraaf/exn2r17tzZu3Kg9e/ZIku6999452jnaDVfgwJfceOON2rhxoyRpwYIF2rRpky677LLm51955RWtXLlSUTT162z27Nmja665Ru+8845WrFihHTt2zMW20YZ4Dxz4gk2bNjXDu1KpaOvWrYeFtyQtW7ZM119/ffPPDz30UPP9cK6+MZsIcOBzaZrq7rvvbv75nnvu0cDAwBGPXbp0afP2Y489Jkm65JJLtHr16uO7SeALCHDgc88884w+/PBDSdKJJ554WJh/2amnntq8nSRTv7j2vvvuO74bBL6EAAc+9/jjjzdvr1u3Tr29vdMe++XfU3jppZfq8ssvP257A46EAAc+t23btubttWvXHvXYL3/vn/e+MRcIcEBTP0ny8ccfS5LK5bIuvvjiox7/xQBfuXKlfvCDHxzX/QFHQoADkt5///3m7bPPPltdXV1HPf7f//538/bPf/7z47Yv4GgIcEDSBx980Ly9aNGiox47MjKiBx98sPnn+fPnH7d9AUdDgAOSarVa83alUjnqsb/97W81NDTU/HMYhsdtX8DREOCApt73PmRwcHDa49577z09/PDD084Cs4kABySdc845zdtvvfWW9u7d+5Vj6vW6br31VjUajcM+Pl3ZFXC8EeCApOXLl6uzs1PS1E+Y3HrrrRodHW1+/sCBA1qzZo1effVVSVPf6Dzkiz8/DswmyqyAz/3kJz9p/rN4STr55JN15ZVXKo5jPf/88/rss88kTf2T+Q0bNuj73/9+89i1a9fqtNNO0/33369qtTrre0d7IsCBz01MTOiKK67Qrl27pj1m9erV2rx5s6rVqi666CLt3r27+bn58+frwIEDs7FVQBJvoQBN8+bN0/bt2/Xoo49q1apVOuWUU1Qul9Xd3a3zzjtP9957r5566in19fWpVCrp2Wef1XXXXaeenh5J0oUXXjjH9wDthitwAHCKK3AAcIoABwCnCHAAcIoABwCnCHAAcIoABwCnCHAAcIoABwCnCHAAcIoABwCnCHAAcIoABwCnCHAAcIoABwCnCHAAcOr/AIjejeTS8ztPAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "ind_minimality\n"
     ]
    },
    {
     "data": {
      "image/png": "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vgHbuu73t9i+wrZsPN/KoV4nu3TpUknShAkTdMMNN+zz/iVLluj888/XqlWrlCSJsiyr/Vcul/Xpp5/qwQcf1IwZM3TTTTfpt99+q/fQAID9qDvg3377raIo0mmnnaa2tj2Xz2/cuFG33357Ldz7szvmcRzrzTff1MyZM7Vs2bKwsweAcazugA8MDEiSpk+fvs/7nnrqKRWLRUVRpDPOOENLly7V4OCgqtWqNm/erFWrVumJJ57QWWedJWlnzAcHB9Xf36/FixcforsCAONL3QEvFouSpPb2Pf8ppTRN9dZbbymKIvX29mrVqlW64oor1NXVpVwup6OOOkpz5szRggUL9OWXX2rlypWaNWuWJKlarerWW2/V2rVrD+FdAoDxoe6ANzc3S5Ly+T3/0uPrr7/W0NCQ8vm8Fi1atM/LK3vr6enRZ599pjvvvFOSVCqVdMcddxzseQPAuFd3wLu6uiRJQ0NDe/z+6tWrJUnd3d2aNm1aXX9WU1OTXn75ZV199dWSpK+++krvv/9+vacCANBBBHz69OnKskw//vjjHr+/YsWK2mvfB+v5559XU9POb7P55z//edDzADCe1R3w7u5uSTu/G2XDhg2SpC1btui9996TJJ166qkHffApU6aot7dXWZZp5cqVBz0PAONZ3QHv7++XtPM7SPr7+/X2229r3rx5KpVKkqR3333XdAIzZsyQJG3atMk0DwDjVd0Bv/DCC9XT06Msy/Tdd9/puuuu0/LlyxVFkbIs07Jly/Tiiy8e9AkUCgVJqn0hAADU56B+0vmtt96qvRa++z9Juvvuu3XllVfq3nvv1XPPPVf3nxfHsVasWCFJOvroow/mVABg3DuogJ944olau3atHnvsMZ133nmaNWuWFi5cqBdeeEHPPvus2tvbdf/99+uiiy7SJ598csA/K8sy3Xvvvfr9998VRZFOP/30kPsBAONOlI32s+8GH330ka6++moNDw9LkqZNm6a+vj6dffbZOvnkk9XV1aWRkRF98803eu211/T1118ryzJFUaRFixbpxhtvPOhjbt++XV1dXRr83xnq7PCxHTfOkobMlrOqebZkXA5lP1tpOLNvsEwCZv9ID/yzDGNhKJ1on00mmWcbscxqc7XDPDtullntiPVy739r27Zt6uwc/fiHNOCS9Pnnn2vu3LnatGlTXStksyxTd3e31qxZ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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# 5.3. Minimality with Dependent FoV Dataset\n",
    "alphas = np.arange(0., 0.5001, 0.1)\n",
    "deltas = np.arange(0., 0.5001, 0.1)\n",
    "\n",
    "fname = os.path.join(Path.cwd(), 'minimality_dependent.pkl')\n",
    "fig_dir = Path(os.path.join(Path.cwd(), 'minimality_dependent'))\n",
    "fig_dir.mkdir(exist_ok=True)\n",
    "\n",
    "with open(fname, 'rb') as file:\n",
    "    scores = pickle.load(file)\n",
    "scores_array = dict2array(scores)\n",
    "\n",
    "for key, array in scores_array.items():\n",
    "    print(f\"{key}\")\n",
    "    fig_name = os.path.join(fig_dir, \"{}.pdf\".format(key))\n",
    "    plt.figure(figsize=(4,4))\n",
    "    plt.imshow(\n",
    "        array.T, \n",
    "        extent=[alphas[0], alphas[-1], deltas[0], deltas[-1]],\n",
    "        cmap='viridis', \n",
    "        aspect='auto',\n",
    "        vmin=0,\n",
    "        vmax=1,\n",
    "        origin='lower',\n",
    "        interpolation='nearest'\n",
    "    ) \n",
    "    plt.tick_params(axis='both', which='major', labelsize=16)  # Major ticks\n",
    "    plt.xlabel(r'$\\alpha$', fontsize=24)\n",
    "    plt.ylabel(r'$\\delta$', fontsize=24)\n",
    "    plt.xticks([], [])\n",
    "    plt.yticks([], [])\n",
    "    plt.savefig(fig_name, bbox_inches='tight', pad_inches=0)\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "mig\n"
     ]
    },
    {
     "data": {
      "image/png": "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rzvN+2zXNdbqUEmKKZdSSU20tsExs0+aUs9aqtsrhqOxijYkPK/B+HINzfb2kytwAHCKAAcApwhwAHCKAAcApwhwAHCKAAcApwhwAHCKAAcApwhwAHCKAAcApwhwAHCKAAcApwhwAHCq7TbCPM81MjKipUuXauXKlTr33HOn3Xb//v3at2+fqtWqzjrrLJ1zzjkKIaEyDQBwjLYDfOPGjbrnnnsUQtDDDz+sW2655Zhtdu3apTvvvFM7d+5UUfy7MrKnp0crV67U17/+dX3rW9/S2WeffXJW/zEht1XDVsZtfY9ZQktquZpQRWusdZWk8rixO1dSqWofa5VUCZswNqUqtSvsp5OypvH8r9nPwxRZ3X4exmBcc8p9isw2OMvb28+2v/rmzZslSf39/brhhhuO+fymTZt02WWXaceOHcrzXDHG1p9arabnnntOd999t84//3zddNNN+sc//tHu1ACA42g7wF977TWFEPS5z31OfX19R31u3759uvXWW1vBfTxHwrzRaOjRRx/VsmXLtGXLlrTVA8A81naAj46OSpLOO++8Yz73s5/9TOPj4woh6OKLL9bmzZu1f/9+NZtNvf/++9qxY4fuv/9+feELX5A0Feb79+/XunXrtHHjxpO0KwAwv7Qd4OPj45KkgYGBoz5eFIUee+wxhRC0Zs0a7dixQ9/4xjc0NDSkLMt0xhlnaNWqVbrrrrv00ksvafv27VqxYoUkqdls6tvf/rZ27959EncJAOaHtgO8UqlIkkqlo3849Morr+jAgQMqlUp65JFHjrm98kmrV6/W888/r+985zuSpGq1qttuu63TdQPAvNd2gA8NDUmSDhw4cNTHd+7cKUkaHh7WkiVL2vpa5XJZv/nNb3TNNddIkl5++WU9+eST7S4FAKAOAvy8885TjFFvvfXWUR/ftm1b6953p37xi1+oXJ76TcYnnnii4/EAMJ+1HeDDw8OSpn4bZe/evZKkDz74QH/6058kScuXL+948kWLFmnNmjWKMWr79u0djweA+aztAF+3bp2kqd8gWbdunR5//HFt2LBB1WpVkrR161bTAs4//3xJ0nvvvWcaDwDzVdsBfvnll2v16tWKMer111/Xddddp6efflohBMUYtWXLFv3qV7/qeAFjY2OS1PpGAABoT0fv83zsscda98KP/JGk733ve7rqqqt0++2366GH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Sdu1tcsrAYCTa2xsTENDQ9N+PsRPi/j/54qi0OjoqAYHBxVC6PZyACBZjFFjY2NatGiRsmz6O93uAxwA5it+iAkAThHgAOAUAQ4AThHgAOAUAQ4AThHgAOAUAQ4AThHgAOAUAQ4AThHgAOAUAQ4AThHgwAm8//77GhkZ0erVq7Vw4UL19vZq8eLF2rBhg954442jtv3973+vEIJCCHrqqae6tGLMJ5RZAccRY9TPf/5z/fjHP9ZHH3103G36+/v19NNP69JLL1We51q6dKn27NmjVatW6fnnn5/lFWM+ct8HDpxs9Xpd1157rTZv3tz62PDwsJYvX67R0VH99a9/Va1W0+TkpL7//e9r9+7d2rhxo/bs2SNJuvfee7u0csw3XIEDn3D99ddr48aNkqSFCxdq06ZNuvzyy1uff+GFF7RmzRrV63VJ0p49e3T11VfrjTfe0OrVq7Vjx45uLBvzEPfAgY/ZtGlTK7wrlYq2bNlyVHhL0sqVK/XNb36z9fcHH3ywdT+cq2/MJgIcOCzPc915552tv991110aHh4+7rYrVqxoPX744YclSZdeeqnWrl07s4sEPoYABw578skn9c4770iSTjvttKPC/JM++9nPth43m01J0o9+9KOZXSDwCQQ4cNijjz7aerxhwwYNDg5Ou+0n/5/Cyy67TF/96ldnbG3A8RDgwGHbtm1rPV6/fv0Jt/3kz/65941uIMABTf0myd///ndJUrlc1iWXXHLC7T8e4GvWrNFXvvKVGV0fcDwEOCDprbfeaj2+4IIL1NfXd8Lt33333dbjH/zgBzO2LuBECHBA0ttvv916vHjx4hNue/DgQT3wwAOtv59++ukzti7gRAhwQNLk5GTrcaVSOeG29913nz744IPW30ul0oytCzgRAhzQ1H3vI0ZHR6fd7m9/+5seeuihaccCs4kAByRdeOGFrcevvfaa9u7de8w21WpVN998s2q12lEfn67sCphpBDggadWqVert7ZU09RsmN998sw4dOtT6/Icffqh169bpxRdflDT1g84jPv7748BsoswKOOy73/1u623xknTmmWfqyiuvVKPR0J///Gf961//kjT1lvmRkRF9+ctfbm27fv16nXXWWfrpT3+qgYGBWV875icCHDhsfHxcX/va17Rr165pt1m7dq0ef/xxDQwM6POf/7x2797d+tzpp5+uDz/8cDaWCkjiFgrQcuqpp2r79u369a9/rSuuuEKf+cxnVC6X1d/fr2XLlunee+/V1q1btWDBAmVZpqeeekrXXnutTjnlFEnSxRdf3OU9wHzDFTgAOMUVOAA4RYADgFMEOAA4RYADgFMEOAA4RYADgFMEOAA4RYADgFMEOAA4RYADgFMEOAA4RYADgFMEOAA4RYADgFMEOAA49X/0J58KyW0oMwAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "sap\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "dci_completeness\n"
     ]
    },
    {
     "data": {
      "image/png": "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K7tB4AIEOHDWM88803x7w4YN6urqGvfYC39P4a233qrPfvazV2xvwMUQ4MBZO3fubL69fv36Sx574df+ee0bVwMBDujMd5K88847kqRMJqObb775kse/P8BXrVqlz3zmM1d0f8DFEOCApIMHDzbfXrJkiQqFwiWPf/vtt5tvf/vb375i+wIuhQAHJL355pvNt+fPn3/JYwcHB/XEE080/z5jxowrti/gUghwQFK5XG6+nc1mL3nsY489puPHjzf/nk6nr9i+gEshwAGded37nP7+/nGP+9vf/qannnpq3FlgIhHggKTrrruu+farr76qw4cPf+CYSqWie++9V9Vq9bz3j1d2BVxpBDggacWKFcrn85LOfIfJvffeq6GhoebHT5w4oXXr1ukvf/mLpDNf6Dzn/d8/DkwkyqyAs77xjW80fyxekmbNmqXbb79d9Xpdf/zjH3Xy5ElJZ35kftOmTfr0pz/dPHb9+vWaPXu2Hn/8cZVKpQnfO6YmAhw4a3R0VLfddpv27ds37jFr167V1q1bVSqV9IlPfEIHDhxofmzGjBk6ceLERGwVkMRLKEBTZ2endu3apZ///Odas2aNrrnmGmUyGRWLRd1www169NFH9dxzz6m7u1upVEo7duzQXXfdpY6ODknS0qVLr/ItwFTDFTgAOMUVOAA4RYADgFMEOAA4RYADgFMEOAA4RYADgFMEOAA4RYADgFMEOAA4RYADgFMEOAA4RYADgFMEOAA4RYADgFMEOAA49f8c/pXPK5DdYQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "explicitness\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "irs\n"
     ]
    },
    {
     "data": {
      "image/png": "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WSeccMKRWT1GJKTG01qxmjPWaUph1bkhVbTWitWQ9YYIqb8tJraxScB/3psC7ptywDHuT5rNY636jHOW4rim7Wq+F1avXi1Jmjx5sm644YZ/fH3VqlW66KKLtH79eiVJoizLqv9KpZK++OILPfjggzrllFN000036ffff691agDAIdQc4Fu3blUURTrzzDPV3Hzgs8rOnTt1++23V4P7UP4K8ziO9dZbb2nOnDlas2ZN2OoBYAKrOcC7u7slSSeffPI/vvbUU09pYGBAURTp7LPP1urVq7V3715VKhXt2rVL69ev1xNPPKFzzz1X0lCY7927V4sWLdLKlSuP0K4AwMRSc4APDAxIklpaDnxLozRN9fbbbyuKInV1dWn9+vW66qqr1NbWplwup2OOOUbz5s3T8uXL9fXXX2vdunWaO3euJKlSqejWW2/Vli1bjuAuAcDEUHOANzYO/bAjnz/wvfA2b96sffv2KZ/P68033/zHyysH6+zs1Jdffqk777xTklQsFnXHHXeMdN0AMOHVHOBtbW2SpH379h3w+Q0bNkiS2tvbNXv27Jq+V0NDg15++WUtXLhQkvTNN9/oww8/rHUpAACNIMBPPvlkZVmmH3/88YDPr127tvra90g9//zzamgY+rWgd999d8TjAWAiqznA29vbJQ39NsqOHTskSbt379YHH3wgSTrjjDNGPPnMmTPV1dWlLMu0bt26EY8HgIms5gBftGiRpKHfIFm0aJHeeecdLV26VMViUZL0/vvvmxZwyimnSJJ+/fVX03gAmKhqDvD58+ers7NTWZbpu+++03XXXaePP/5YURQpyzKtWbNGL7744ogX0NfXJ0nVJwIAQG1G9Pewb7/9dvW18L/+SdLdd9+tq6++Wvfee6+ee+65mr9fHMdau3atJGn69OkjWQoATHgjCvCTTjpJW7Zs0WOPPaYLL7xQc+fO1YoVK/TCCy/o2WefVUtLi+6//35dcskl+vzzzw/7vbIs07333qs//vhDURTprLPOCtkPAJhwomy4v303+PTTT7Vw4UIVCgVJ0uzZs7VgwQKdd955Ou2009TW1qbBwUF9++23eu2117R582ZlWaYoivTmm2/qxhtvHPGcvb29amtr0+Zt/6PW1pEX7MSytSQWs/y/bzQKYwvppIB5A0qP6lBmlQYUJoWUWVmFlFklmX1fg+7XlDKr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nCLAAcApAhwAnCLAAcApAhwAnCLAAcApAhwAnCLAAcApAhw4jF27dmnFihXq7OzUjBkzNGnSJM2aNUtLly7Vtm3bDtj29ddfVxRFiqJIH330UZ1WjImEMivgELIs0zPPPKNHH31U/f39h9xm8uTJ+vjjj3XBBRcoSRKdfvrp2r59u+bNm6cvv/xyjFeMich9HzhwpJXLZS1ZskSrV6+ufq69vV1nnHGGuru79dlnn6lUKmlwcFD33HOPtmzZopUrV2r79u2SpIcffrhOK8dEwxU4cJDrr79eK1eulCTNmDFDq1at0vz586tf37Rpk7q6ulQuD73rz/bt23XNNddo27Zt6uzs1Pr16+uxbExAvAYO/M2qVauq4d3Y2Kg1a9YcEN6S1NHRoWuvvbb68bPPPlt9PZyrb4wlAhzYL0kSLVu2rPrx8uXL1d7efsht586dW7396quvSpIuuOACLViwYHQXCfwNAQ7s9+GHH+rnn3+WJB111FEHhPnBjjvuuOrtyv43fH7kkUdGd4HAQQhwYL+33nqrenvp0qVqbW0ddtuD36fwoosu0mWXXTZqawMOhQAH9lu7dm319uLFiw+77cE/++e1b9QDAQ5o6DdJfvvtN0lSQ0ODzj///MNu//cA7+rq0qWXXjqq6wMOhQAHJP3444/V26eeeqqam5sPu/0vv/xSvX3fffeN2rqAwyHAAUk//fRT9fasWbMOu21PT4+efvrp6sdHH330qK0LOBwCHJA0ODhYvd3Y2HjYbR9//HHt3r27+nE+nx+1dQGHQ4ADGnrd+y/d3d3DbvfDDz/oueeeG3YsMJYIcEDSaaedVr29detW7dix4x/bFItF3XLLLSqVSgd8friyK2C0EeCApHnz5mnSpEmShn7D5JZbblFvb2/163v27NGiRYv01VdfSRr6Qedf/v7748BYoswK2O+uu+6q/lm8JE2fPl1XXnml4jjWJ598oj///FPS0J/Mr1ixQhdffHF128WLF+v444/Xk08+qZaWljFfOyYmAhzYb2BgQJdffrk2btw47DYLFizQO++8o5aWFp1zzjnasmVL9WtHH3209uzZMxZLBSTxEgpQNXXqVK1bt04vvfSSLrnkEh177LFqaGjQ5MmTNWfOHD388MN6//33NW3aNOVyOX300UdasmSJpkyZIkk6++yz67wHmGi4AgcAp7gCBwCnCHAAcIoABwCnCHAAcIoABwCnCHAAcIoABwCnCHAAcIoABwCnCHAAcIoABwCnCHAAcIoABwCnCHAAcIoABwCn/g/auIa5QzE+SwAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "ind_compactness\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAXAAAAFuCAYAAACYxUPUAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuNSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/xnp5ZAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAVaUlEQVR4nO3db4xU9b3H8c+Z2T8s7J9q4aoocsXrjTE2qcpKQUWtUp+0UbjxTxpqtbVt0gc2Jl59ZNQ2pa2pyb1GY1ub6hNNIKYPiPgn2tAoCGqqYmqNNwSvJVltBVl2dv6eOed3HyBzBdl19vtjd/rtvF8Jyezu+fI7M3PmM4ezux+SEEIQAMCdQqd3AABgQ4ADgFMEOAA4RYADgFMEOAA4RYADgFMEOAA41dPpHYiV57nGxsY0NDSkJEk6vTsAEC2EoFKppMWLF6tQmPo8232Aj42NacmSJZ3eDQA47vbu3avTTjttyq+7D/ChoSFJ0vuv/6uGB2d+RSgNmWld65wkNULTPJvK/ouztYhfuq0H279u0mC/SlcLRfNsJfTZ181tL4t66LWvGTFbjbivVr2J/fhPI57XLOJ46k3srzur3HiVujqZ6T8v/VMr36biPsAPXzYZHixoeMgS4LZQs85JUj3iIIwJ8N6Ife7tQID3RMwmEbPF3BYwxYhgKkTMyviGE6M34nJlT8cC3DxqZg3wwz7vsjDfxAQApwhwAHCKAAcApwhwAHCKAAcApwhwAHCKAAcApwhwAHCKAAcApwhwAHCKAAcApwhwAHDKfZlVp6Syt7HVQh4xax5VLaIIqG4sIKoF+yGWyd4+VMn753zdmDXLEbMx6xYS27FYz+3tiTFNhjHSMN8014nmxVqzveZEzsABwCkCHACcIsABwCkCHACcIsABwCkCHACcIsABwCkCHACcIsABwCkCHACcIsABwCkCHACcIsABwKmubyPMZW8G7IQ0oqEvjXi/Lgdb+1wa0UZYDn322Q60+9UiGvpiGgVL2TzzrDcxzYC9hfYa/o5Wi3h8rW2E9SxtazvOwAHAKQIcAJwiwAHAKQIcAJwiwAHAKQIcAJwiwAHAKQIcAJwiwAHAKQIcAJwiwAHAKQIcAJwiwAHAKQIcAJzq+jrZgvE9LA/BvKa9EDNOHuxVtFbeKmFjxFTnFhJ7rXE9t69rnc06dO43v9CwD2e2Y8JaCSvZX3P1ZntrcgYOAE4R4ADgFAEOAE4R4ADgFAEOAE4R4ADgFAEOAE4R4ADgFAEOAE4R4ADgFAEOAE4R4ADgFAEOAE4R4ADgVNfXyeay1XgWEns1a25vou2YWug1zcVUrMbMNiJm96VDprmY2tFiRJ1sjP5C0zS3P10w52vGrltMbC+8NLc/r9b72mjzcOAMHACcIsABwCkCHACcIsABwCkCHACcIsABwCkCHACcIsABwCkCHACcIsABwCkCHACcIsABwCkCHACc6vo2Qqs82CsFs4g2wizYWxBrEQ19WbC911vnpLh2v3pua0+U7M2AB7MB85rVzL6/BWPLniTlEceTfU37MWFtFJSkgULDNFeQ/bnJZXt82z0COQMHAKcIcABwigAHAKcIcABwigAHAKcIcABwigAHAKcIcABwigAHAKcIcABwigAHAKcIcABwigAHAKcIcABwijpZo0z2WstiRINnGlHFmRmrLSUpN77Xx6zZiKi/jamirRmraGOqWYd7aubZmCra/qKtOjdGudlvnv1Cb8U8219omuayTpznFrL2Npvl3QAAzBICHACcIsABwCkCHACcIsABwCkCHACcIsABwCkCHACcIsABwCkCHACcIsABwCkCHACcIsABwCkCHACcok62A1J7E62KETW2nZBGVMJ6s7B30jwbU3/bm7RXPXoslbzPPGtVSOzH8ERzwDzb22ZF69H6jDW0kjRYrJvm6sW0re04AwcApwhwAHCKAAcApwhwAHCKAAcApwhwAHCKAAcApwhwAHCKAAcApwhwAHCKAAcApwhwAHCKAAcAp7qnKu44yyNmY941MyURs/aVa6HXPGsV09BXSOzP0FCxNudrFoJ9tp7bnxtrk2FV9jXruf15zYP9GLau21+w7281sz1OjUajre04AwcApwhwAHCKAAcApwhwAHCKAAcApwhwAHCKAAcApwhwAHCKAAcApwhwAHCKAAcApwhwAHCKAAcApwhwAHCq6+tksxDmfM2YKto0ok4zpp41M66bBXv97bwkNc8uKNTNs41ge1nEPL4xKqHfPDuZ2WZjal1jTKb2+9pXbM75mk3jMZHWqJMFgH9qBDgAOEWAA4BTBDgAOEWAA4BTBDgAOEWAA4BTBDgAOEWAA4BTBDgAOEWAA4BTBDgAOEWAA4BTbdeuZVmmDRs26Oyzz9aKFSt0+umnT7nt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S+3HRNawPTeSlFdtczFthDGnjSEJ5tkkt7VMhoL98Z0o2Z7Xw3l2ON+m4j7AS6WSJGnp+f/b2R0BgKO0Uwk7nVKppJGRkSm/noTPi/h/cHmea2xsTENDQ0oS2zssAPwjCSGoVCpp8eLFKhSm/ieL+wAHgG7FNzEBwCkCHACcIsABwCkCHACcIsABwCkCHACcIsABwCkCHACcIsABwCkCHACcIsABwCkCHJjGRx99pA0bNmjVqlVatGiR+vv7tWTJEq1fv15vv/32Edv+7ne/U5IkSpJEzz33XIf2GN2EMivgGEII+uUvf6kf//jHmpycPOY2AwMDev7553XRRRcpyzKdffbZ2r17t1auXKmXX355jvcY3ch9HzhwvDUaDV177bXavHlz63Ojo6M699xzNTY2pj/+8Y+q1+uqVqv64Q9/qF27dmnjxo3avXu3JOmee+7p0J6j23AGDhzlhhtu0MaNGyVJixYt0qZNm3TZZZe1vv7KK69o9erVajQakqTdu3fr6quv1ttvv61Vq1Zp+/btndhtdCGugQOfsmnTplZ49/b2asuWLUeEtyStWLFC1113Xevj+++/v3U9nLNvzCUCHPhElmW64447Wh/feeedGh0dPea2y5cvb91+5JFHJEkXXXSR1qxZM7s7CXwKAQ584tlnn9X7778vSTrhhBOOCPOjnXzyya3bzeah//T23nvvnd0dBI5CgAOfePzxx1u3169fr6GhoSm3Pfr/Kbzkkkt0xRVXzNq+AcdCgAOf2Lp1a+v2unXrpt326O/9c+0bnUCAAzr0kyQffvihJKmnp0df+cpXpt3+0wG+evVqffWrX53V/QOOhQAHJL377rut22eeeabmzZs37fZ//etfW7d/9KMfzdp+AdMhwAFJ7733Xuv2kiVLpt324MGDuu+++1ofn3jiibO2X8B0CHBAUrVabd3u7e2ddtuf/vSn2rdvX+vjYrE4a/sFTIcAB3TouvdhY2NjU273zjvv6IEHHphyFphLBDgg6ayzzmrdfuutt7Rnz57PbFOr1XTTTTepXq8f8fmpyq6A2UaAA5JWrlyp/v5+SYd+wuSmm27SxMRE6+v79+/X2rVr9eqrr0o69I3Owz798+PAXKLMCvjE97///davxUvSwoULddVVVylNU73wwgv6+OOPJR36lfkNGzbo0ksvbW27bt06nXLKKfr5z3+uwcHBOd93dCcCHPhEuVzWlVdeqZ07d065zZo1a/Tkk09qcHBQ559/vnbt2tX62oknnqj9+/fPxa4CkriEArQsWLBA27Zt069+9StdfvnlOumkk9TT06OBgQGdc845uueee/T0009reHhYhUJBzz33nK699lrNnz9fknTeeed1+B6g23AGDgBOcQYOAE4R4ADgFAEOAE4R4ADgFAEOAE4R4ADgFAEOAE4R4ADgFAEOAE4R4ADgFAEOAE4R4ADgFAEOAE4R4ADgFAEOAE79H4OB4Wxt6PdgAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "ind_sufficiency\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAXAAAAFuCAYAAACYxUPUAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuNSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/xnp5ZAAAACXBIWXMAAA9hAAAPYQGoP6dpAAATlklEQVR4nO3dW2xU5bvH8d/qtJRCD1uEKMjhD4aEEExEqZUiFdTKjUYgQY1BRUVNvMC4L+DKiBqrErkhGg8Y5QaSEuIFEYSgwShHTcQS0bBDcCtJUTm3tJ3pmrXWvijM5tQ6fd+242O/n8RkoPOy3jn02+WifQiSJEkEADCnqNAbAAC4IeAAYBQBBwCjCDgAGEXAAcAoAg4ARhFwADCquNAb8BXHsZqbm1VRUaEgCAq9HQDwliSJWltbNWbMGBUVdX+ebT7gzc3NGjduXKG3AQB97tixYxo7dmy3Hzcf8IqKCknSbz/8R5XlXBHqSZTEzmtjDfwP7IZJ5Lw2lvtjzTo+T6HHcxR5/EB0h8dL4/r/rCmD/7NrqQ7nz8e6846Tub51x3zAL142qSwvUmWFpZdo4EUen+iFCbj7Md3zLYWOhy1UwFMeL43rZwwBHxh/d1nY4mMCAIiAA4BZBBwAjCLgAGAUAQcAowg4ABhFwAHAKAIOAEYRcAAwioADgFEEHACMIuAAYJT5YVaDjc9EwULwmQpojc/ZUGeBjhs6ziOMPYZv+ezX591k6Ww134Fqlh4TAOASBBwAjCLgAGAUAQcAowg4ABhFwAHAKAIOAEYRcAAwioADgFEEHACMIuAAYBQBBwCjCDgAGMU0wkEklvsEuTCJ+nAn+fGZZBh6TG2MHJ+ntMeEvnynz11zreNEwa7jup3DpT2OWeLxuqYC9ydq4N/B7rJ5Pr+cgQOAUQQcAIwi4ABgFAEHAKMIOAAYRcABwCgCDgBGEXAAMIqAA4BRBBwAjCLgAGAUAQcAowg4ABhFwAHAKMbJIi+pwG18qM8YWp+RsKHH6NzIcSys+279uI6E9Vkb+Yyw9Thv9BlF6yrlNYbZ7bG2x/k9Ts7AAcAoAg4ARhFwADCKgAOAUQQcAIwi4ABgFAEHAKMIOAAYRcABwCgCDgBGEXAAMIqAA4BRBBwAjCLgAGAU42QLIPIYk1ooriNWI5+xrh5rfaQdDxt6jFj14TPatShwe7AtcanzMX0M8RhPXBS4fd7FHuN6SwK3/eb7mnIGDgBGEXAAMIqAA4BRBBwAjCLgAGAUAQcAowg4ABhFwAHAKAIOAEYRcAAwioADgFEEHACMIuAAYBTTCAeRWPamILrqdJyeKMn5WYoS96mAoce5VOgxLa8QfKb7yXG6nw/XiYKS+6TImGmEAPDvRsABwCgCDgBGEXAAMIqAA4BRBBwAjCLgAGAUAQcAowg4ABhFwAHAKAIOAEYRcAAwioADgFEEHACMYpysMbHcx6T6HXfgR9H6HNFnretZTSrweG0S9x37HDedpJzWDZH7iNU2uR1Tkjo91qYcx/36fM65jpMN89wrZ+AAYBQBBwCjCDgAGEXAAcAoAg4ARhFwADCKgAOAUQQcAIwi4ABgFAEHAKMIOAAYRcABwCgCDgBGEXAAMIpxssYUOY6nlPxGrDofMynM+FufMxPXQaklPqN+3V9WxY5jUiUp5bjn0PmIUpS4vzqu+5Wk2PFdEQUeo377+bOOM3AAMIqAA4BRBBwAjCLgAGAUAQcAowg4ABhFwAHAKAIOAEYRcAAwioADgFEEHACMIuAAYBQBBwCjmEZoTOwz8c6YyGOSYcrnwI7D/XzmzvlMbYwK8J6IvKZiup83tsQlzmuHBG5zJosS91fW9bG2x/ntlTNwADCKgAOAUQQcAIwi4ABgFAEHAKMIOAAYRcABwCgCDgBGEXAAMIqAA4BRBBwAjCLgAGAUAQcAowg4ABjFOFn8Yw0N3M8vfEasuo6i7fQYCVuoMynXsbCRx459RtGejYY5r/2vVLvTuljuI2xdpZP8nl/OwAHAKAIOAEYRcAAwioADgFEEHACMIuAAYBQBBwCjCDgAGEXAAcAoAg4ARhFwADCKgAOAUQQcAIzKexphFEVqaGjQlClTVFNTo/Hjx3d73zNnzujYsWNKp9MaPXq0xo4dqyBwn0AGALha3gFvbGzUK6+8oiAItHbtWj399NNX3Wffvn1avny59u7dqziOc78/ZMgQ1dTU6P7779eTTz6pm266qW92j3+8okJ94Xaf7KrYZ7ExYeI2PNd1Xdda9ynWPmtPR+VO64oU//2dupFOhjit64iyed0v70somzdvliSVlZXpscceu+rjGzdu1OzZs7V7925FUaQkSXL/ZTIZffvtt3r55Zc1adIkPfHEE/rzzz/zPTQA4BryDvjBgwcVBIFuueUWDR069LKPHTt2TM8880wu3NdyMeZhGGr9+vWaOnWqtmzZ4rd7ABjE8g54c3OzJGnixIlXfeztt99WW1ubgiDQ9OnTtXnzZp05c0bZbFYnTpzQ7t279eabb+r222+X1BXzM2fOaMGCBWpsbOyjhwIAg0veAW9ra5MklZdffh0pjmNt2LBBQRCorq5Ou3fv1gMPPKCqqioVFRXp+uuv18yZM7VixQp9//332rVrl2bMmCFJymazeuqpp9TU1NSHDwkABoe8A15S0vXvwqVSl//lxYEDB3T27FmlUimtW7fuqssrV6qtrdWePXv07LPPSpLS6bSWLl3a230DwKCXd8CrqqokSWfPnr3s9/fu3StJqq6u1oQJE/L6s4qLi/Xhhx9q/vz5kqQffvhB27Zty3crAAD1IuATJ05UkiQ6fPjwZb+/c+fO3LXv3nr33XdVXNz1bUGfffZZr9cDwGCWd8Crq6sldX03ytGjRyVJJ0+e1BdffCFJmjZtWq8PPmbMGNXV1SlJEu3atavX6wFgMMs74AsWLJDU9R0kCxYs0KZNm7R48WKl02lJ0tatW502MGnSJEnS8ePHndYDwGCVd8DnzJmj2tpaJUmin376SY888oh27NihIAiUJIm2bNmi999/v9cbaG1tlaTcFwIAQH56Ncxqw4YNuWvhF/+TpOeff14PPvigli1bpjVr1uT954VhqJ07d0qSRo4c2ZutAMCg16uAjx8/Xk1NTXr99dd11113acaMGWpoaNB7772n1atXq7y8XC+99JLmzp2rb775psc/K0kSLVu2TH/99ZeCINCtt97q8zgAYNAJku5+9t3BV199pfnz56u9vV2SNGHCBNXX1+uOO+7Q5MmTVVVVpY6ODv3444/6+OOPdeDAASVJoiAItG7dOj3++OO9PmZLS4uqqqp05n8mqbLCxnTcKHEfjuMzaCn2GMoTJpHTuqhAg6Fij7d16LjnTp9jejxN6cT9fX8uLnVa1+Y4pEmSWuMy57Wnsm4DqSQpFbi9/wsyzOp8Vv89Y4/OnTunysrKbu/XpwGXpP3792vhwoU6fvx4XiNkkyRRdXW19u3b5zRyloDnzzXCPny+aPjE31rAMx6fhW0eE/rOxj3/4F132h3DL0mnHKcCStLZaJjzWtcJirHHF8jSotBpXcf5rFZUf/u3Ae/z4tXU1Ojnn3/W0qVLVVxcfNn18kuvm1+8XV1drc8//5x54QDQS/1yylpVVaWPPvpIR48e1apVqzRv3jxNmDAh92P4lZWVqq+v16effqq9e/dq1KhR/bENAPhX6/NLKD25eL27L3EJJX9cQskPl1D+HpdQ8mPuEkpPuEwCAH3HxikrAOAqBBwAjCLgAGAUAQcAowg4ABhFwAHAKAIOAEYRcAAwioADgFEEHACMch+iAHNShRhl4DFHQh5zVHxmxrgf012nx/MUJ+6va8px120es1BcZ5JI0rms+yyU9thtNrfrHHFJCkO3uS+ZTH4zVDgDBwCjCDgAGEXAAcAoAg4ARhFwADCKgAOAUQQcAIwi4ABgFAEHAKMIOAAYRcABwCgCDgBGEXAAMIqAA4BRjJMdRIo8vl7HXsNSbYkSt1G0kccE21juI2E7PV7X1rjMaZ3PSNhCjaI9G7qPoh1ondn80swZOAAYRcABwCgCDgBGEXAAMIqAA4BRBBwAjCLgAGAUAQcAowg4ABhFwAHAKAIOAEYRcAAwioADgFFMIzSmyGNqXSyPcXnGRB6PNXJcF3q8NmHifi6VTkoGfK3PMTOx+9qW7FCP47rlriNy36+rMJvf1EXOwAHAKAIOAEYRcAAwioADgFEEHACMIuAAYBQBBwCjCDgAGEXAAcAoAg4ARhFwADCKgAOAUQQcAIwi4ABgFONk8Y/lMxI29jhu6HhYn5GwnR7nUmmP8axtcemArpOkc1GZ89qWrPvaTJzfiNYrnUwPdz5mUeD2ZspmGCcLAP9qBBwAjCLgAGAUAQcAowg4ABhFwAHAKAIOAEYRcAAwioADgFEEHACMIuAAYBQBBwCjCDgAGEXAAcAoxskWQCpw/7oZJT6DUgde7DHYNU7cx8l2eqwNFbit8xgnm07cR8L6rA0TtxGr7fEQ92M6jnWVpLas+3HPdrqNoj3dMcz5mK7jZKMOxskCwL8aAQcAowg4ABhFwAHAKAIOAEYRcAAwioADgFEEHACMIuAAYBQBBwCjCDgAGEXAAcAoAg4ARjGNEHmJHKf7RfKZCui+1mdmo+tUwchximHXMd0n9LXGblP2JKktLnVaF8bu6ch4rG33mEbYkXWb2tjaPtT5mKmU2zsxyuR3P87AAcAoAg4ARhFwADCKgAOAUQQcAIwi4ABgFAEHAKMIOAAYRcABwCgCDgBGEXAAMIqAA4BRBBwAjCLgAGAU42QHkdhjyKrr2thxDK3kPsJWkkL3pc7jZNOJ+6eTz0jYKHEfY5uJ3Uasno/cxtBK0vF0lfPa2GNkb0fo9liDwP3NlO5wG38bd+T3+cYZOAAYRcABwCgCDgBGEXAAMIqAA4BRBBwAjCLgAGAUAQcAowg4ABhFwAHAKAIOAEYRcAAwioADgFEEHACMYpxsAUSJz1hXjzmpHiLH47qu61rrrtNxJKwkdTqe14Qe42Qjj/36jKJtj93GnbZk3Y85vLjTee1vrdc5r+3MppzWhZ0er2ub29q4I791nIEDgFEEHACMIuAAYBQBBwCjCDgAGEXAAcAoAg4ARhFwADCKgAOAUQQcAIwi4ABgFAEHAKMIOAAYxTTCQSRK3CcDxo5rQ49jhh6DF0OPc5MwcZta15a4TfaTpDbHqYCSlIlLnNeeCYc5rWvJljof83RmuPPakiL3SZ6nM27PcTbtkcko6Nd1nIEDgFEEHACMIuAAYBQBBwCjCDgAGEXAAcAoAg4ARhFwADCKgAOAUQQcAIwi4ABgFAEHAKMIOAAYZX4aYXJh2l3LefcpZQMtStz3Gstnup/7cTsd16Y9jpn2mEZ43uO4bbHb2vY4cj5mR5R1XpvOuq/NZEKndWHY6XzMMOM+PTHrflhF7W7HjTs83ogZt3PkOJ2W9P996475gLe2tkqSJtz2v4XdCAD0sdbWVlVVVXX78SD5u8T/w8VxrObmZlVUVCgIHGfvAsA/SJIkam1t1ZgxY1RU1P1ZvPmAA8BgxV9iAoBRBBwAjCLgAGAUAQcAowg4ABhFwAHAKAIOAEYRcAAwioADgFEEHACMIuAAYBQBB3pw4sQJNTQ0qLa2VqNGjVJpaanGjRunxYsX69ChQ5fd95NPPlEQBAqCQNu3by/QjjGYMMwKuIYkSfTOO+/otdde0/nz5695n7KyMu3YsUOzZs1SFEWaMmWKjhw5opkzZ2rPnj0DvGMMRubngQN9rbOzU4sWLdLmzZtzv1ddXa1p06apublZX3/9tTKZjDo6OvTCCy+oqalJjY2NOnLkiCRp5cqVBdo5BhvOwIErPProo2psbJQkjRo1Shs3btScOXNyH9+/f7/q6urU2dn1z8McOXJEDz30kA4dOqTa2lrt3r27ENvGIMQ1cOASGzduzMW7pKREW7ZsuSzeklRTU6OHH3449+vVq1fnrodz9o2BRMCBC6Io0vLly3O/XrFihaqrq6953xkzZuRur127VpI0a9Ys1dfX9+8mgUsQcOCCbdu26bfffpMkXXfddZfF/Eo33nhj7nb2wj8q/Oqrr/bvBoErEHDggvXr1+duL168WBUVFd3e98p/p3D27Nm69957+21vwLUQcOCCnTt35m4vXLiwx/te+Xf/XPtGIRBwQF3fSfLHH39IkoqLi3XnnXf2eP9LA15XV6d77rmnX/cHXAsBByQdPnw4d/vmm2/W0KFDe7z/77//nrv94osv9tu+gJ4QcEDSr7/+mrs9bty4Hu977tw5rVq1KvfrESNG9Nu+gJ4QcEBSR0dH7nZJSUmP933jjTd08uTJ3K9TqVS/7QvoCQEH1HXd+6Lm5uZu7/fLL79ozZo13a4FBhIBByRNnjw5d/vgwYM6evToVfdJp9NasmSJMpnMZb/f3bAroL8RcEDSzJkzVVpaKqnrO0yWLFmilpaW3MdPnTqlBQsW6LvvvpPU9RedF136/ePAQGKYFXDBc889l/uxeEkaOXKk5s2bpzAM9eWXX+r06dOSun5kvqGhQXfffXfuvgsXLtTo0aP11ltvqby8fMD3jsGJgAMXtLW16b777tO+ffu6vU99fb02bdqk8vJy3XbbbWpqasp9bMSIETp16tRAbBWQxCUUIGf48OHatWuXPvjgA82dO1c33HCDiouLVVZWpqlTp2rlypXaunWrKisrVVRUpO3bt2vRokUaNmyYJGn69OkFfgQYbDgDBwCjOAMHAKMIOAAYRcABwCgCDgBGEXAAMIqAA4BRBBwAjCLgAGAUAQcAowg4ABhFwAHAKAIOAEYRcAAwioADgFEEHACM+j8M5nqI7IR+GgAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# 5.4. Sufficiency with Dependent FoV Dataset\n",
    "alphas = np.arange(0., 0.5001, 0.025)\n",
    "deltas = np.arange(0., 0.5001, 0.025)\n",
    "\n",
    "fname = os.path.join(Path.cwd(), 'sufficiency_dependent.pkl')\n",
    "fig_dir = Path(os.path.join(Path.cwd(), 'sufficiency_dependent'))\n",
    "fig_dir.mkdir(exist_ok=True)\n",
    "\n",
    "with open(fname, 'rb') as file:\n",
    "    scores = pickle.load(file)\n",
    "scores_array = dict2array(scores)\n",
    "\n",
    "for key, array in scores_array.items():\n",
    "    print(f\"{key}\")\n",
    "    fig_name = os.path.join(fig_dir, \"{}.pdf\".format(key))\n",
    "    plt.figure(figsize=(4,4))\n",
    "    plt.imshow(\n",
    "        array.T, \n",
    "        extent=[alphas[0], alphas[-1], deltas[0], deltas[-1]],\n",
    "        cmap='viridis', \n",
    "        aspect='auto',\n",
    "        vmin=0,\n",
    "        vmax=1,\n",
    "        origin='lower'\n",
    "    ) \n",
    "    plt.tick_params(axis='both', which='major', labelsize=16)  # Major ticks\n",
    "    plt.xlabel(r'$\\alpha$', fontsize=24)\n",
    "    plt.ylabel(r'$\\delta$', fontsize=24)\n",
    "    plt.xticks([], [])\n",
    "    plt.yticks([], [])\n",
    "    plt.savefig(fig_name, bbox_inches='tight', pad_inches=0)\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "ind_fi\n"
     ]
    },
    {
     "data": {
      "image/png": "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Rf4JJkkS9fT0qKmpSVH03+0tBoBKpWmqvr4+NTc3K5MZ/ScLd4EOAJMVvxQFACcIdABwgkAHACcIdABwgkAHACcIdABwgkAHACcIdABwgkAHACcIdABwgkAHACcIdKAKe/bs0TPPPKMrrrhCs2bN0pQpU9TS0qJVq1aps7Nz2LFvvPGGoihSFEX6+OOPa7RiTCaUcwEVSNNUzz//vJ5++mkdPHhwxGOmTp2qTz75RFdeeaXiONYFF1ygrq4utbe366uvvprgFWMycteHDhxvg4ODuu222/TBBx+UP9bW1qYFCxaop6dHn3/+uQqFggYGBnT//fero6NDGzduVFdXlyRp3bp1NVo5Jht26MAx3Hnnndq4caMkadasWXrnnXe0dOnS8ue/+eYbXX311RocPPy/53R1dWnlypXq7OzUFVdcoS+//LIWy8YkxHPowBjeeeedcpjncjlt2rRpWJhL0uLFi3X77beX//3CCy+Un09nd46JRKADo4jjWI899lj5348//rja2tpGPHbRokXly6+//rok6corr9Ty5cvHd5HAEQh0YBQfffSRfvvtN0nSySefPCzcj3bGGWeUL5f+/o+Wn3rqqfFdIHAUAh0YxYYNG8qXV61apaamplGPPfr/eVyyZImuu+66cVsbMBICHRjFZ599Vr58yy23jHns0a8t4Llz1AKBDoygq6tLf/zxhySprq5Ol19++ZjHHxnoV199ta699tpxXR8wEgIdGMHPP/9cvjx37lw1NDSMefzvv/9evvzII4+M27qAsRDowAh+/fXX8uWWlpYxj+3t7dVzzz1X/vcpp5wybusCxkKgAyMYGBgoX87lcmMeu379eu3du7f872w2O27rAsZCoAMjqKv7pxWjp6dn1ON++uknvfzyy6OOBSYSgQ6M4Lzzzitf3r59u3bu3PmvY/L5vFavXq1CoTDs46OVdwHjjUAHRtDe3q4pU6ZIOvwKltWrV+vAgQPlz+/bt08333yzvv32W0mHf3E65MjXrwMTiXIuYBT33ntv+W38knTqqafqxhtvVLFY1Keffqq//vpL0uG3+D/zzDO65pprysfecsstmj17tp599lk1NjZO+NoxORHowCj6+/t1/fXX6+uvvx71mOXLl+vdd99VY2OjWltb1dHRUf7cKaecon379k3EUgFJPOUCjGr69OnavHmzXnvtNS1btkynn3666urqNHXqVM2fP1/r1q3Thx9+qBkzZiiTyejjjz/WbbfdpmnTpkmSFi5cWONrgMmGHToAOMEOHQCcINABwAkCHQCcINABwAkCHQCcINABwAkCHQCcINABwAkCHQCcINABwAkCHQCcINABwAkCHQCcINABwAkCHQCc+H//FiDEwC6QTwAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "ind_ri\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAXQAAAFuCAYAAACRLuOuAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuNSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/xnp5ZAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAVo0lEQVR4nO3df2hd9f3H8dc5596bmzRJbb92zmxFW39gq2CbmblY1OpaRQZfUWkVV6QgbDI298/mGAx1g9ox/LXBFwVBEPUP3S8QKxYHjtFaf2GbSlEhq3X59jJW9Zs0zY/765zvH12upkvS3PenTfSd5wMCNzfnk8/nnHvyuoebm1eiLMsyAQC+9OL5XgAA4NQg0AHACQIdAJwg0AHACQIdAJwg0AHACQIdAJzIzfcCTrU0TVUqldTR0aEoiuZ7OQAQLMsyDQ8Pq6urS3E8/XW4u0AvlUpavnz5fC8DAE65gYEBff3rX5/26+4CvaOjQ5L00TvnqrOdV5QAfPkdPZbqnO5DjXybjrtAn3iZpbM9VmcHgQ7Aj5O9jEziAYATBDoAOEGgA4ATBDoAOEGgA4ATBDoAOEGgA4ATBDoAOEGgA4ATBDoAOEGgA4ATBDoAOOGunGvCiyOL1BYnTY+rZ7bnuCRKTeMkKR/VzGPnS6LMNC6W/TilAdcfIfMWorp5rFUccD4VZF9vyLxW1nNpvtRl/z8L1n09Vp7d48IVOgA4QaADgBMEOgA4QaADgBMEOgA4QaADgBMEOgA4QaADgBMEOgA4QaADgBMEOgA4QaADgBMEOgA44bZt8ZXB1SrUCnM2X2dufM7mOlXiaO5b7vIBzYUhY0dT+7nQkcz9Y9sWV8xjQ9oAi8bmz5CWxmJUNY8NYW1IbYvL5jlTY5vraLUu6X9Puh1X6ADgBIEOAE4Q6ADgBIEOAE4Q6ADgBIEOAE4Q6ADgBIEOAE4Q6ADgBIEOAE4Q6ADgBIEOAE4Q6ADgBIEOAE64rc/tP7pMuXpL0+NaElt9aIhCYq+FTTN7VWohtu9rLrZVj9ZS+zVESN1vyFjrmq3HSJKKib1StiW2n0/lNDGN68zZK2WrxkrZ4/Paq42t50RItbG1sne8PLvzgSt0AHCCQAcAJwh0AHCCQAcAJwh0AHCCQAcAJwh0AHCCQAcAJwh0AHCCQAcAJwh0AHCCQAcAJwh0AHCCQAcAJ9zW5/7faJsSNV+fWw+od7VqLdirUutpQH1uzl6zWq3bjlPInPmAOtqQ+txy3VYpW8zZ64lDzsMk4DhZ523N2c/hfEB99JGACmjrObGkMGae06oyNrvKXq7QAcAJAh0AnCDQAcAJAh0AnCDQAcAJAh0AnCDQAcAJAh0AnCDQAcAJAh0AnCDQAcAJAh0AnCDQAcAJt22L42N5xVGh6XFJztZUl9nL/DRUbjWPjWL7xGMBY5PEdpyqxuZCSapW7adrPm9v5UuMrXxHR4vmOXPG4ytJaRbSwGk7TtWAdshawDnRWRw3j83HtpbHSmo/D2PZzqVqmbZFAFhQCHQAcIJABwAnCHQAcIJABwAnCHQAcIJABwAnCHQAcIJABwAnCHQAcIJABwAnCHQAcIJABwAnCHQAcMJtfW4UZ6Zq2chYlVqvBzw3GueUwmp7Q8ZWyrZTJ6TuN5+31Z1KUqViP9VrNVu9a8h6qwEVuGlqH2s9/8crefOcIVXBg2P2iuKisVK5aKwYDlGrzm47rtABwAkCHQCcINABwAkCHQCcINABwAkCHQCcINABwAkCHQCcINABwAkCHQCcINABwAkCHQCcINABwAkCHQCccFufqygzVYFmxtrSXM5eAWqtLJWkctleWxrH9nrX2Fh5mgbUDI+NFMxjo8R+jOPYtq/1ur3GNkttlb2SlAuo7R0fsx3jkFrkJKA+t1q3H6fY+PAkAT+v+cT+2MwGV+gA4ASBDgBOEOgA4ASBDgBOEOgA4ASBDgBOEOgA4ASBDgBOEOgA4ASBDgBOEOgA4ASBDgBOEOgA4ITbtsXORWUlbc2Pq6e2CrZKbX4OZbFYNY/N7KVxAXPaGwhbF1XMY1Pj4ypJlYrtsQ1pEUwDjlPIvibG1tCQfQ05Jwq5mnmsVSWg4TExNnfO9nzgCh0AnCDQAcAJAh0AnCDQAcAJAh0AnCDQAcAJAh0AnCDQAcAJAh0AnCDQAcAJAh0AnCDQAcAJAh0AnCDQAcAJt/W5/9U6olxb89Wa1dRWjVlL7c+N1YA6zpAqz3xSN4+1rtlaTyyFVRQnib0ruFCY+4rWLOA4xbF9X3M52zkRUtmbD6jeDZEznv9xNA+907PEFToAOEGgA4ATBDoAOEGgA4ATBDoAOEGgA4ATBDoAOEGgA4ATBDoAOEGgA4ATBDoAOEGgA4ATBDoAOGGurzt8+LAOHz6s9vZ2rVixQq2tradyXQCAJjUd6B988IHuvPNO7dmz57Nvksupp6dHN954o+666y51dHRMGjM6Oqqnn35ab731lrIs04UXXqhrrrlGPT09iiJ77eZMzioOq9BaPi3feyrDtRbz2JDq3ZAqz+FK0Ty2lrOtuR6wr2mhah4bUjM8VsmbxoWUrIZU4EYB54T1fMrn7VXMBWNlrxS2ry3G+txqwDncktiqmJNZjmsq0AcHB7VhwwaVSiVl2WcHslqtas+ePdqzZ4+2b9+uhx9+WFu3bpUkHTp0SBs2bNCHH374H99v+fLluvvuu3X33Xcrl3NbzQ4Ac6Kpp5rHHntMhw8fPj4wjtXb26uNGzeqq6tLWZYpyzINDg7qzjvv1LZt2yRJmzdv1sGDByWpsc3Ex8DAgH7605/qsssu06FDh07tngHAAtPUZfHLL78sSYqiSC+99JKuu+66xtfeeecdbdu2TX/+85+VZZnuu+8+DQ0N6e233268rHLLLbeou7tb//rXv/Tqq69q//79kqT9+/dr/fr12rNnj84+++xTtW8AsKA0dYX+3nvvKYoirVu3blKYS1J3d7f++Mc/6re//a2k41fjDz30UOPrTz31lH7/+9/r5z//uR555BHt27dPu3fv1po1ayRJAwMD+v73vx+4OwCwcDUV6ENDQ5Kkiy66aNptfvSjH2nr1q2Nl1WiKNKVV16pLVu2/Me2vb292r17ty6//HJlWaYdO3Zo7969Te4CAEBqMtAn3ppYrc78boP77rtPURQ1Xmq59dZbZ/yeTz75ZGPbZ555ppklAQD+ralAn/jl5759+2bc7pxzztEll1zSeCdMT0/PjNuvWrVK3/jGN5Rl2aS3QwIAZq+pQO/t7ZUk9fX16bXXXptx24svvrhxe8WKFSf93hPb//3vf29mSQCAf2sq0O+4447G7dtvv139/f3TbrtmzZrGHxid+IdGU0mS43/4MfE6PQCgOU0F+tVXX60bbrih8R7ytWvX6he/+EXjfeafd88992hoaEgHDhxQoVA46feeeB/6RLADAJrT9N+wPvXUU7r44ouVZZlGR0e1fft2XXDBBTr33HO1adMmbd++XTt37tSRI0ckzfyOmAmHDx/W3/72N0VRpK985SvN7wUAoPkulzPPPFO7du3SD3/4Qz377LON+wcGBjQwMKA//elPjfu6urrU3d096eNr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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "e_val\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# FRE Minimality with Independent FoV Dataset\n",
    "alphas = np.arange(0., 0.5001, 0.025)\n",
    "betas = np.arange(0., 1.001, 0.05)\n",
    "\n",
    "fname = os.path.join(Path.cwd(), 'minimality_fre.pkl')\n",
    "fig_dir = Path(os.path.join(Path.cwd(), 'minimality_fre'))\n",
    "fig_dir.mkdir(exist_ok=True)\n",
    "\n",
    "with open(fname, 'rb') as file:\n",
    "    scores = pickle.load(file)\n",
    "scores_array = dict2array(scores)\n",
    "\n",
    "for key, array in scores_array.items():\n",
    "    print(key)\n",
    "    fig_name = os.path.join(fig_dir, \"{}.pdf\".format(key))\n",
    "    plt.figure(figsize=(4,4))\n",
    "    plt.imshow(\n",
    "        array.T, \n",
    "        extent=[alphas[0], alphas[-1], betas[0], betas[-1]],\n",
    "        cmap='viridis', \n",
    "        aspect='auto',\n",
    "        vmin=0,\n",
    "        vmax=1,\n",
    "        origin='lower'\n",
    "    ) \n",
    "    plt.tick_params(axis='both', which='major', labelsize=16)  # Major ticks\n",
    "    plt.xlabel(r'$\\alpha$', fontsize=24)\n",
    "    plt.ylabel(r'$\\beta$', fontsize=24)\n",
    "    plt.xticks([], [])\n",
    "    plt.yticks([], [])\n",
    "    plt.savefig(fig_name, bbox_inches='tight', pad_inches=0)\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "ind_fi\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "ind_ri\n"
     ]
    },
    {
     "data": {
      "image/png": "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reb2r9fFyNaxmgXU304uDJhny7mtxlOyV+eGSHJ7ZWkpsteznttiO8aVzH58a5m9/jbkfKpmtmN8eKDDvGY5sUVsOtjYa5UrcABwigAHAKcIcABwigAHAKcIcABwigAHAKcIcABwigAHAKcIcABwigAHAKcIcABwigAHAKfMAV6pVEZzHwCAETIH+Jw5c/Tuu++O5l4AACNgrpM9cOCAVqxYoSVLluiVV17RFVdcMZr7GrHWKFJrNPKqyTS39cJ2xfZaS1sx60n2Hts4YGXrZH9ubywuBDzWQsBjtdazFuPUvOaRtNM8601bbK9EjgPOiWpmOxdbW+z7rdRsFbZR1NjjDH4PfOvWrbr66qv14IMP6siRI6H/OQBAg8wBvmXLFs2dO1d5nitNU61du1azZs3Sq6++qiwLu8YEAPw7c4AvXbpUO3bs0Jo1azRlyhTlea4///xTDz/8sK666ip98skno7lPAMBpgt5CieNYDz30kPbt26cHHnhAhUJBeZ5r9+7duvXWW3XnnXfqp59+Gq29AgBOMSr/Dvy8887Ta6+9pm+++UZLlixRnufK81ybNm3S5Zdfrscee0z9/f2jsRQA4IRR/SDPlVdeqU8//VRvv/22LrnkEuV5rkqlohdeeEHd3d1at27daC4HAGe1Mfkk5l133aXdu3frqaeeUkdHh/I81++//65Vq1ZpwYIF+vrrr8diWQA4q4zZR+nb2tr0+OOPa+/evbr33nslSXmea/v27VqwYIFWrVqlgwcPjtXyADDhjXkXyvTp07V+/Xpt27ZN1157rSQpyzKtW7dO3d3deu655/Tjjz+O9TYAYMIZlzKrgwcPqlqt6r777tOMGTMURZHyPFdfX58ef/xxzZkzR11dXVq4cKFWr16tN954Q1999ZXK5fJ4bA8AXLJ/zvk0SZJo37592rNnj/bu3as9e/bUb/f29v7j/tGJj73nJz7K3t/fr+3bt2v79u31+xQKBVWr1dHaIgBMKEEB/uWXX+r111/XF198oQMHDpzxE5j5MF0j559/vrq7u3Xo0CHt37//H/Npau+WAICJzhzgH374oe644w7VaseLXoYK6lKppFmzZqm7u1uzZ8+u///s2bM1efLk+v0GBga0c+dOfffdd/X/ff/999btAcCEZw7wp59+Wknyn9a2adOm6corr/xbSHd3d+viiy+uv10y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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "e_val\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# FRE Sufficiency with Independent FoV Dataset\n",
    "alphas = np.arange(0., 0.5001, 0.025)\n",
    "gammas = np.arange(1., 2.001, 0.05)\n",
    "\n",
    "fname = os.path.join(Path.cwd(), 'sufficiency_fre.pkl')\n",
    "fig_dir = Path(os.path.join(Path.cwd(), 'sufficiency_fre'))\n",
    "fig_dir.mkdir(exist_ok=True)\n",
    "\n",
    "\n",
    "with open(fname, 'rb') as file:\n",
    "    scores = pickle.load(file)\n",
    "scores_array = dict2array(scores)\n",
    "\n",
    "for key, array in scores_array.items():\n",
    "    print(f\"{key}\")\n",
    "    fig_name = os.path.join(fig_dir, \"{}.pdf\".format(key))\n",
    "    plt.figure(figsize=(4,4))\n",
    "    plt.imshow(\n",
    "        (array[:,:21].T)**2, \n",
    "        extent=[alphas[0], alphas[-1], gammas[0], gammas[-1]],\n",
    "        cmap='viridis', \n",
    "        aspect='auto',\n",
    "        vmin=0,\n",
    "        vmax=1,\n",
    "        origin='lower',\n",
    "    ) \n",
    "    plt.tick_params(axis='both', which='major', labelsize=16)  # Major ticks\n",
    "    plt.xlabel(r'$\\alpha$', fontsize=24)\n",
    "    plt.ylabel(r'$\\gamma$', fontsize=24)\n",
    "    plt.xticks([], [])\n",
    "    plt.yticks([], [])\n",
    "    plt.savefig(fig_name, bbox_inches='tight', pad_inches=0)\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "ind_fi\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "ind_ri\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAXAAAAFuCAYAAACYxUPUAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuNSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/xnp5ZAAAACXBIWXMAAA9hAAAPYQGoP6dpAAATBUlEQVR4nO3dXYxdZdn44XvPnukHTDsRaZTa0pcaEsIf8wp2rC1SQa2caKRNUGOKoqImHmA8gSMjaqxK5IRo/MAoJ5C0IR40FiFoarSlRROwvKLhn6YG6zuogP2cdjp79l7vQdsdWtqy+6y2uzdzXQnJdGY9Xc/es+fXxerM3UZVVVUAkM5AvzcAQBkBB0hKwAGSEnCApAQcICkBB0hKwAGSGuz3BurqdDoxNjYWc+bMiUaj0e/tANRWVVXs378/5s+fHwMDp77OTh/wsbGxWLhwYb+3AXDW7dq1KxYsWHDKj6cP+Jw5cyIi4oWn/yvmDrsjdDrtqnPez9mJ8h/07UT5fts1fsC49LztGo91qsbnppXsh6mbffo/5X7UofSzeuBAJ64bfanbt1NJH/Bjt03mDg/E3DkCfjrtPnyd1wt4uXoBLzxnjcfaqvG5EfDeZAr4Ma93W1jxAJIScICkBBwgKQEHSErAAZIScICkBBwgKQEHSErAAZIScICkBBwgKQEHSCr9MKvpph8TBbmwtWusLX011bry69fwrcIhWnUGo5Xq9ZyuwAGSEnCApAQcICkBB0hKwAGSEnCApAQcICkBB0hKwAGSEnCApAQcICkBB0hKwAGSMo1wGulE+VS1TvHcunJ1psDV2W+78Hnq1Npvf7QLt1xnAmKrxtpm2UDBI+ftw1TB0ivkXp9fV+AASQk4QFICDpCUgAMkJeAASQk4QFICDpCUgAMkJeAASQk4QFICDpCUgAMkJeAASQk4QFLGyXJOZRsJGxHRqrKNzi3XirL5rO2qfK5rs1Hnc1O8NJo1XhOl2oXP76Een19X4ABJCThAUgIOkJSAAyQl4ABJCThAUgIOkJSAAyQl4ABJCThAUgIOkJSAAyQl4ABJCThAUsbJck5lHAlbunKyTyNh2zWmpJaOhW3VuParMxJ2VqNdvHaiapafuNBA4Wu418+LK3CApAQcICkBB0hKwAGSEnCApAQcICkBB0hKwAGSEnCApAQcICkBB0hKwAGSEnCApEwj5ILVqTHdr4524XnrTNmrNY0wyiYK1tGsMSmyzn7rTBQcqvUsl2k2yp6nXte5AgdISsABkhJwgKQEHCApAQdISsABkhJwgKQEHCApAQdISsABkhJwgKQEHCApAQdISsABkjJOlgvWQKN87GirxijaduG6oRpTXeuMoh2oMdq1dLJrpyp/sHXWDjXO/0jYTo3xt6WPtdfXgytwgKQEHCApAQdISsABkhJwgKQEHCApAQdISsABkhJwgKQEHCApAQdISsABkhJwgKQEHCAp42S5YHVqjISto9mPk/ZpFG0/tOs82CrXNee5Hn+b69kAoEvAAZIScICkBBwgKQEHSErAAZIScICkBBwgKQEHSErAAZIScICkBBwgKQEHSMo0QnrS7tNkwFJDNSbeDRQurTV3rsbz26px2maUnXeixvNbaxphDX05b+GntdcJk67AAZIScICkBBwgKQEHSErAAZIScICkBBwgKQEHSErAAZIScICkBBwgKQEHSErAAZIScICkjJPlgjXQKB//2akxnrVZOHa0Uzo7tKZmjSmprapscekY2oiITlV+3XiwGipeO9SYKlpX57HuqWYWrRvvtHs6zhU4QFICDpCUgAMkJeAASQk4QFICDpCUgAMkJeAASQk4QFICDpCUgAMkJeAASQk4QFI9TyNst9uxdu3auOqqq2Lp0qVx+eWXn/LY3bt3x65du2JiYiIuu+yyWLBgQTRqTJYD4LV6Dvi6devia1/7WjQajXjggQfis5/97GuO2bZtW9x1112xdevW6HQ63ffPmDEjli5dGh/60Ifi05/+dLztbW87O7vngjdQ63/yOq9/yKnUuF4oHUVb55FO1ljbrjHFtl04TnaiahafczLK19axp3NR0bqLG+WfnXbhC7HXdT2/5jZs2BAREbNnz45PfvKTr/n4+vXr44YbbogtW7ZEu92Oqqq6/x0+fDh+//vfx1e/+tVYvHhxfOpTn4p//etfvZ4agJPoOeDPPvtsNBqNeMc73hGzZs067mO7du2Kz33uc91wn8yxmLdarXjooYfi6quvjo0bN9bbPcA01nPAx8bGIiLiiiuueM3Hvvvd78b4+Hg0Go249tprY8OGDbF79+6YmpqKl156KbZs2RLf/va3413veldEHIn57t27Y9WqVbFu3bqz9FAAppeeAz4+Ph4REcPDw8e9v9PpxMMPPxyN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xjmHite2o/y8450ZxWtL7W/PKl47c6C3Masns2+q7LzNofKRyP9v5v8WrRufbPd0nCtwgKQEHCApAQdISsABkhJwgKQEHCApAQdISsABkhJwgKQEHCApAQdISsABkhJwgKRMI+yDdlU+3axTY0JfJ+qct2xtp3CKYUT5BMQja4uXRqvwumaiKv9yqjNRcH97dvHaTuFjPVhjiuGB9szitVOd8mvOoUZvE/5OdNHAZPE5b5xd9nWzb6q3F7ArcICkBBwgKQEHSErAAZIScICkBBwgKQEHSErAAZIScICkBBwgKQEHSErAAZIScICk0k8jrI5OrNt3oHzS3vmWcRphq3DPUzUe60SttcVL40DheQ91yvc7XpVNyouIONguX3u4KpuCODE1VX7OVqt8bafGJ7bQxIzy/e6bUTiN8GjPqteZyNmoXu+IC9w//vGPWLhwYb+3AXDW7dq1KxYsWHDKj6cPeKfTibGxsZgzZ040GuUzlQEuFFVVxf79+2P+/PkxMHDqO93pAw4wXflLTICkBBwgKQEHSErAAZIScICkBBwgKQEHSErAAZIScICkBBwgKQEHSErA4TReeumlWLt2bSxfvjzmzZsXM2fOjIULF8aaNWviueeeO+7Yn/3sZ9FoNKLRaMTjjz/epx0znRhmBSdRVVV873vfi2984xtx4MCBkx4ze/bseOKJJ+L666+PdrsdV111VezYsSOWLVsWTz755HneMdNR+n/QAc62ycnJuPXWW2PDhg3d942OjsY111wTY2Nj8dvf/jYOHz4chw4dii996Uuxffv2WLduXezYsSMiIu65554+7ZzpxhU4nOATn/hErFu3LiIi5s2bF+vXr48bb7yx+/GnnnoqVqxYEZOTkxERsWPHjvjoRz8azz33XCxfvjy2bNnSj20zDbkHDq+yfv36bryHhoZi48aNx8U7ImLp0qXxsY99rPvr++67r3s/3NU355OAw1Htdjvuuuuu7q/vvvvuGB0dPemxS5Ys6b79wAMPRETE9ddfHytXrjy3m4RXEXA46rHHHosXXnghIiLe9KY3HRfzE731rW/tvj119B/4/frXv35uNwgnEHA46qGHHuq+vWbNmpgzZ84pjz3x3ym84YYb4gMf+MA52xucjIDDUZs2beq+vXr16tMee+Lf/bv3TT8IOMSR7yT55z//GRERg4OD8Z73vOe0x7864CtWrIj3v//953R/cDICDhHx/PPPd99++9vfHrNmzTrt8X//+9+7b3/5y18+Z/uC0xFwiIi//e1v3bcXLlx42mP37t0b9957b/fXl1xyyTnbF5yOgENEHDp0qPv20NDQaY/91re+FS+//HL3181m85ztC05HwCGO3Pc+Zmxs7JTH/fWvf43777//lGvhfBJwiIgrr7yy+/azzz4bO3fufM0xExMTcfvtt8fhw4ePe/+phl3BuSbgEBHLli2LmTNnRsSR7zC5/fbbY9++fd2Pv/LKK7Fq1ar4wx/+EBFH/qLzmFd//zicT4ZZwVFf+MIXuj8WHxFx6aWXxs033xytVit+/etfx3/+85+IOPIj82vXro33ve993WNXr14dl112WXznO9+J4eHh8753picBh6PGx8fjgx/8YGzbtu2Ux6xcuTIeeeSRGB4ejuuuuy62b9/e/dgll1wSr7zyyvnYKkSEWyjQdfHFF8fmzZvjRz/6Udx0003xlre8JQYHB2P27Nlx9dVXxz333BOPPvpozJ07NwYGBuLxxx+PW2+9NS666KKIiLj22mv7/AiYblyBAyTlChwgKQEHSErAAZIScICkBBwgKQEHSErAAZIScICkBBwgKQEHSErAAZIScICkBBwgKQEHSErAAZL6PyniPiLkB4yfAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "e_val\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAXAAAAFuCAYAAACYxUPUAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuNSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/xnp5ZAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAOYElEQVR4nO3dW4zcdd3H8c+020BxD+FQlKalUIIhBBKLXWuLrEVtuNHINkGJKQQCauIFxhvJc2FEjasSuSEaj1FuIGlDvGgsQsDUYAtFEqCN1fCkKQ9UF+VU6IFuD7vzXLSd0NJdZrfbLl/29Uqa/Hfm99/5zkXf/ee/s782ms1mMwCUM2OqBwBgYgQcoCgBByhKwAGKEnCAogQcoCgBByiqY6oHOFkjIyMZHBxMV1dXGo3GVI8DcNKazWZ2796duXPnZsaM0a+zywd8cHAw8+fPn+oxACbdjh07Mm/evFGfLx/wrq6uJMmLz1yU7k53hID6du0ZyYKr/q/Vt9GUD/jR2ybdnTPS3SXgwAfHe90WVjyAogQcoCgBByhKwAGKEnCAogQcoCgBByhKwAGKEnCAogQcoCgBByhKwAGKEnCAogQcoCgBByhKwAGKEnCAogQcoCgBByhKwAGKEnCAogQcoCgBByhKwAGKEnCAogQcoCgBByhKwAGKEnCAogQcoCgBByhKwAGKEnCAogQcoCgBByhKwAGKEnCAogQcoCgBByhKwAGKEnCAogQcoCgBByhKwAGKEnCAogQcoCgBByhKwAGKEnCAogQcoCgBByhKwAGKEnCAogQcoCgBByhKwAGKEnCAogQcoCgBByhKwAGKEnCAogQcoCgBByhKwAGKEnCAogQcoCgBByhKwAGKEnCAogQcoCgBByhKwAGKEnCAogQcoCgBByhKwAGKEnCAogQcoCgBByhKwAGKEnCAogQcoCgBByhKwAGKEnCAogQcoCgBByhKwAGKEnCAogQcoCgBByhKwAGKEnCAogQcoCgBByhKwAGKEnCAogQcoCgBByhKwAGKEnCAogQcoCgBByhKwAGKEnCAogQcoCgBByhKwAGKEnCAogQcoCgBByhKwAGKEnCAogQcoCgBByhKwAGKEnCAogQcoCgBByhKwAGKEnCAogQcoCgBByhKwAGKEnCAogQcoCgBByhKwAGKEnCAogQcoCgBByhKwAGKEnCAogQcoCgBByhKwAGKEnCAogQcoCgBByhKwAGKEnCAogQcoCgBByiqo92Fw8PDGRgYyGWXXZYlS5bkwgsvHHXtzp07s2PHjgwNDeWCCy7IvHnz0mg0JmVgAA5r+wp89erV+e53v5sbb7wxjz322AnXbNq0KX19fTn//POzaNGiLF26NBdddFHOOuusLF++PAMDA/n3v/89acMDTGdtB3zt2rVJktmzZ+crX/nKu55fs2ZNrrnmmmzcuDHDw8NpNputP/v3789f//rXfOc738nChQtz880357///e/kvQuAaajtgG/ZsiWNRiNXXnllzjzzzGOe27FjR2677bZWuE/kaMwPHjyY+++/P5dffnnWrVt3ctMDTGNtB3xwcDBJcvHFF7/ruZ/85CfZu3dvGo1GFi1alLVr12bnzp05dOhQXn311WzcuDE/+tGP8vGPfzzJ4Zjv3Lkz/f39Wb169SS9FYDppe2A7927N0nS2dl5zOMjIyN54IEH0mg00tfXl40bN+bzn/98enp6MmPGjJx77rlZunRp7rzzzjz99NPZsGFDFi9enCQ5dOhQbr311mzevHkS3xLA9NB2wGfNmpUkmTlz5jGPP/vss3nzzTczc+bM3Hfffe+6vXK8ZcuW5YknnshXv/rVJMnQ0FBuv/328c4NMO21HfCenp4kyZtvvnnM408++WSSpLe3NwsWLGjre3V0dORXv/pVrr/++iTJM888k4cffrjdUQDIOAJ+8cUXp9ls5vnnnz/m8fXr17fufY/Xz372s3R0HP4o+h/+8Idxnw8wnbUd8N7e3iSHP42yffv2JMlrr72WP/3pT0mSK664YtwvPnfu3PT19aXZbGbDhg3jPh9gOms74P39/UkOf4Kkv78/Dz74YFatWpWhoaEkyUMPPTShARYuXJgkefnllyd0PsB01XbAly9fnmXLlqXZbObvf/97vvzlL+fRRx9No9FIs9nMunXr8otf/GLcA+zevTtJWv8QANCecW1m9cADD7TuhR/9kyRf//rX84UvfCF33HFH7r333ra/38GDB7N+/fokyXnnnTeeUQCmvXEF/MILL8zmzZvzgx/8IJ/61KeyePHiDAwM5Oc//3nuueeedHZ25lvf+lauvfbaPP7442N+r2azmTvuuCOvvPJKGo1GPvaxj53M+wCYdhrN0X73fQL+/Oc/5/rrr8/bb7+dJFmwYEFWrFiRT3ziE7n00kvT09OTffv25bnnnstvf/vbPPvss2k2m2k0Grnvvvty0003jfs1d+3alZ6enuz834Xp7rI7LlDfrt0jOfuj2/PWW2+lu7t71HWTGvAkeeqpp7Jy5cq8/PLLbW0h22w209vbm02bNk1oy1kBBz5o2g34pBdvyZIl+cc//pHbb789HR0dx9wvf+d986PHvb29+eMf/2i/cIBxOiWXrD09Pfn1r3+d7du35+677851112XBQsWtH4Nv7u7OytWrMjvf//7PPnkk5kzZ86pGAPgA23Sb6GM5ej97snkFgrwQTNlt1DG4jYJwORxyQpQlIADFCXgAEUJOEBRAg5QlIADFCXgAEUJOEBRAg5QlIADFNUx1QMAnA7DzZGpHqFt7c7qChygKAEHKErAAYoScICiBBygKAEHKErAAYoScICiBBygKAEHKErAAYoScICiBBygKAEHKErAAYoScICiBBygKAEHKErAAYoScICiBBygKAEHKErAAYoScICiBBygKAEHKErAAYoScICiOqZ6AIB2DTdHpnqE9xVX4ABFCThAUQIOUJSAAxQl4ABFCThAUQIOUJSAAxQl4ABFCThAUQIOUJSAAxQl4ABFCThAUbaTBRjDSJrv29d0BQ5QlIADFCXgAEUJOEBRAg5QlIADFCXgAEUJOEBRAg5QlIADFCXgAEUJOEBRAg5QlIADFGU7WWBamOi2sAebw5M8STuvOdLWOlfgAEUJOEBRAg5QlIADFCXgAEUJOEBRAg5QlIADFCXgAEUJOEBRAg5QlIADFCXgAEXZjRA4rYbb3Gnv/WIkE5+33V0Fj3fAboQAH2wCDlCUgAMUJeAARQk4QFECDlCUgAMUJeAARQk4QFECDlCUgAMUJeAARQk4QFECDlCU7WSBaWGi28JOdEvYJHljZGLn7mnzPFfgAEUJOEBRAg5QlIADFCXgAEUJOEBRAg5QlIADFCXgAEUJOEBRAg5QlIADFCXgAEUJOEBRtpMFxm34JLZYrWboJN7r1gPnT+i8tw8MJ3nlPde5AgcoSsABihJwgKIEHKAoAQcoSsABihJwgKIEHKAoAQcoSsABihJwgKIEHKAoAQcoym6EQBkjaU743OHmxM59e+Ivmf/Z0j+h84bf3p9k63uucwUOUJSAAxQl4ABFCThAUQIOUJSAAxQl4ABFCThAUQIOUJSAAxQl4ABFCThAUQIOUFT53QibR3YY27VnZIongeljuDk1f99OZjfCgxOcec/wxN/r4V0FJ35e8z12UGw032vF+9y//vWvzJ8/f6rHAJh0O3bsyLx580Z9vnzAR0ZGMjg4mK6urjQajakeB+CkNZvN7N69O3Pnzs2MGaPf6S4fcIDpyg8xAYoScICiBBygKAEHKErAAYoScICiBBygKAEHKErAAYoScICiBBygKAGHMbz66qsZGBjIsmXLMmfOnJxxxhmZP39+Vq1ala1btx6z9ne/+10ajUYajUYeeeSRKZqY6cRmVnACzWYzP/3pT/P9738/e/bsOeGa2bNn59FHH83VV1+d4eHhXHbZZdm2bVuWLl2aJ5544jRPzHRU/j90gMl24MCB3HDDDVm7dm3rsd7e3lxxxRUZHBzMX/7yl+zfvz/79u3LN77xjWzevDmrV6/Otm3bkiR33XXXFE3OdOMKHI5z4403ZvXq1UmSOXPmZM2aNVm+fHnr+aeeeip9fX05cOBAkmTbtm354he/mK1bt2bZsmXZuHHjVIzNNOQeOLzDmjVrWvGeNWtW1q1bd0y8k2TJkiX50pe+1Pr6nnvuad0Pd/XN6STgcMTw8HC+/e1vt76+884709vbe8K1ixcvbh3/5je/SZJcffXVWbFixakdEt5BwOGIhx9+OC+++GKS5Oyzzz4m5sf7yEc+0jo+dOhQkuR73/veqR0QjiPgcMT999/fOl61alW6urpGXXv8/1N4zTXX5LOf/ewpmw1ORMDhiPXr17eOV65cOeba43/27943U0HAIYc/SfKf//wnSdLR0ZFPfvKTY65/Z8D7+vrymc985pTOByci4JDk+eefbx1fcsklOfPMM8dc/9JLL7WOv/nNb56yuWAsAg5JXnjhhdbx/Pnzx1z71ltv5e677259fc4555yyuWAsAg5J9u3b1zqeNWvWmGt/+MMf5rXXXmt9PXPmzFM2F4xFwCGH73sfNTg4OOq6f/7zn7n33ntHPRdOJwGHJJdeemnreMuWLdm+ffu71gwNDeWWW27J/v37j3l8tM2u4FQTcEiydOnSnHHGGUkOf8Lklltuya5du1rPv/766+nv78/f/va3JId/0HnUOz8/DqeTzazgiK997WutX4tPkvPOOy/XXXddDh48mMceeyxvvPFGksO/Mj8wMJBPf/rTrbUrV67MBRdckB//+Mfp7Ow87bMzPQk4HLF379587nOfy6ZNm0Zds2LFijz44IPp7OzMVVddlc2bN7eeO+ecc/L666+fjlEhiVso0PKhD30oGzZsyC9/+ctce+21+fCHP5yOjo7Mnj07l19+ee6666489NBD6e7uzowZM/LII4/khhtuyFlnnZUkWbRo0RS/A6YbV+AARbkCByhKwAGKEnCAogQcoCgBByhKwAGKEnCAogQcoCgBByhKwAGKEnCAogQcoCgBByhKwAGKEnCAov4fX9dHxWlDqmcAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# FRE with Dependent FoV Dataset\n",
    "alphas = np.arange(0., 0.5001, 0.025)\n",
    "deltas = np.arange(0., 0.5001, 0.025)\n",
    "\n",
    "fname = os.path.join(Path.cwd(), 'dependent_fre.pkl')\n",
    "fig_dir = Path(os.path.join(Path.cwd(), 'dependent_fre'))\n",
    "fig_dir.mkdir(exist_ok=True)\n",
    "\n",
    "with open(fname, 'rb') as file:\n",
    "    scores = pickle.load(file)\n",
    "scores_array = dict2array(scores)\n",
    "\n",
    "for key, array in scores_array.items():\n",
    "    print(f\"{key}\")\n",
    "    fig_name = os.path.join(fig_dir, \"{}.pdf\".format(key))\n",
    "    plt.figure(figsize=(4,4))\n",
    "    plt.imshow(\n",
    "        array.T, \n",
    "        extent=[alphas[0], alphas[-1], deltas[0], deltas[-1]],\n",
    "        cmap='viridis', \n",
    "        aspect='auto',\n",
    "        vmin=0,\n",
    "        vmax=1,\n",
    "        origin='lower'\n",
    "    ) \n",
    "    plt.tick_params(axis='both', which='major', labelsize=16)  # Major ticks\n",
    "    plt.xlabel(r'$\\alpha$', fontsize=24)\n",
    "    plt.ylabel(r'$\\delta$', fontsize=24)\n",
    "    plt.xticks([], [])\n",
    "    plt.yticks([], [])\n",
    "    plt.savefig(fig_name, bbox_inches='tight', pad_inches=0)\n",
    "    plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "venv",
   "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.8.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
