{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 41,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The autoreload extension is already loaded. To reload it, use:\n",
      "  %reload_ext autoreload\n"
     ]
    }
   ],
   "source": [
    "# Python Path non-sense\n",
    "%load_ext autoreload\n",
    "%autoreload 2\n",
    "\n",
    "import sys\n",
    "import os\n",
    "\n",
    "# remove any paths that contains 'bayes_gsl' in the sys.path\n",
    "sys.path = [x for x in sys.path if 'bayes_gsl' not in x]\n",
    "new_path = '/Users/maxw/projects/gsl-bnn/'\n",
    "if new_path not in sys.path:\n",
    "    sys.path.append(new_path)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import pickle\n",
    "import multiprocessing\n",
    "import matplotlib.pyplot as plt\n",
    "from matplotlib.gridspec import GridSpec\n",
    "import seaborn as sns\n",
    "from sklearn.linear_model import LinearRegression\n",
    "\n",
    "### THIS MUST OCCUR BEFORE JAX IS IMPORTED ###\n",
    "# for parallelization for multiple chains. Must be done before jax import:\n",
    "# Blackjax tutorial: https://blackjax-devs.github.io/blackjax/examples/howto_sample_multiple_chains.html\n",
    "os.environ[\"XLA_FLAGS\"] = \"--xla_force_host_platform_device_count={}\".format(\n",
    "    multiprocessing.cpu_count()\n",
    ")\n",
    "import jax\n",
    "import jax.numpy as jnp\n",
    "from jax import random\n",
    "\n",
    "from numpyro.infer import MCMC, NUTS, Predictive\n",
    "\n",
    "from src.utils import adj2vec, vec2adj, degrees_from_upper_tri, edge_density, edge_density_vmap\n",
    "from experiments.predictive_checking.config import dpg_hyperparameters, experiment_settings\n",
    "from src.config import original_prior, altered_prior\n",
    "from src.config import num_samples_to_generate, w_init_scale, lam_init_scale\n",
    "from src.models import dpg_bnn\n",
    "from src import FIGURES_PATH"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(5, 190) (5, 190)\n"
     ]
    }
   ],
   "source": [
    "def load_data():\n",
    "    data_dict = pickle.load(open(experiment_settings['data_path'], \"rb\"))\n",
    "\n",
    "    # data is pairs of adjacency matrices and euclidean distance matrices\n",
    "    adjacencies = data_dict['adjacencies'].astype(np.float32)\n",
    "    dataset_key = 'expected' if experiment_settings['num_signals'] == float('inf') else str(experiment_settings['num_signals'])\n",
    "    euclidean_distance_matrices = data_dict[dataset_key]\n",
    "\n",
    "    # convert to vectors\n",
    "    adjacencies = adj2vec(adjacencies)\n",
    "    euclidean_distance_matrices = adj2vec(euclidean_distance_matrices)\n",
    "    num_edges = adjacencies.shape[-1]\n",
    "\n",
    "    # concatenate for easier processing\n",
    "    data = np.concatenate([euclidean_distance_matrices, adjacencies], axis=1)\n",
    "\n",
    "    # predetermine train/val/test split\n",
    "    num_train, num_val, num_test = num_samples_to_generate['train'], num_samples_to_generate['val'], num_samples_to_generate['test']\n",
    "    train, val, test = data[:num_train], data[num_train:num_train + num_val], data[num_train + num_val:]\n",
    "    data =  {\"train\": (train[:, :num_edges], train[:, num_edges:]), \n",
    "            \"val\": (val[:, :num_edges], val[:, num_edges:]),\n",
    "            \"test\": (test[:, :num_edges], test[:, num_edges:])}\n",
    "\n",
    "    # unpack data\n",
    "    x_train, y_train = jnp.array(data['train'][0]), jnp.array(data['train'][1])\n",
    "    x_train, y_train = x_train[:experiment_settings['num_train_samples']], y_train[:experiment_settings['num_train_samples']]\n",
    "\n",
    "    x_val, y_val = jnp.array(data['val'][0]), jnp.array(data['val'][1])\n",
    "    x_val, y_val = x_val[:experiment_settings['num_val_samples']], y_val[:experiment_settings['num_val_samples']]\n",
    "    \n",
    "    x_test, y_test = jnp.array(data['test'][0]), jnp.array(data['test'][1])\n",
    "    x_test, y_test = x_test[:experiment_settings['num_test_samples']], y_test[:experiment_settings['num_test_samples']]\n",
    "\n",
    "    return (x_train, y_train), (x_val, y_val), (x_test, y_test)\n",
    "\n",
    "(x_train, y_train), (x_val, y_val), (x_test, y_test) = load_data()\n",
    "print(x_val.shape, y_val.shape)"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Prior Predictive Check"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "metadata": {},
   "outputs": [],
   "source": [
    "num_edges = x_val.shape[-1]\n",
    "n = int(0.5*(np.sqrt(8 * num_edges + 1) + 1))\n",
    "S = jnp.array(degrees_from_upper_tri(n))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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xo8fX2xdRo8erbFjx6pu3bp68cUXNXToUJ177rnq2rVrhbdNoaioKPXo0UNz5szRrl27Sr1C8stf/lKrV6/WI488oubNm+vgwYNavXq1MjMzJZ285T58+HB98803euedd4rNb72uu3fvVvv27ZWbm6tx48apbdu2yszM1KJFi/T999+rbt26Onr0qLp166Zdu3aFptmwYYPGjx+vdevWafHixeX6jGuPHj3UuHFjTZ8+XY8//rikkwN8165d9fOf/7zY9N99950k6cEHH1S9evWUnZ2td955R6mpqVqyZIlSU1NVv359LVy4UFdddZWGDh2qYcOGSVJo0CnUt29f3XTTTbrjjjtKfXPs0qWLJk2apLFjx6pr167q3bu3NmzYoLvvvlsDBgwocgXudElJSTr33HM1ZcoU1alTR9dcc41atGhR6nap6H68//779cADD6hGjRqaMGGC+vbtq/vvv19LlizRf/3Xf8nn8+m+++5Tr169tHXrVkVFRYXmz83N1TXXXKMRI0Zo7NixWr58uSZNmqTt27dr3rx5pa6Tl/1+7NgxffPNN+rTp0+x37Vt21bHjh3Tli1b1Lx581KXD/wYjh07pv/93/9V+/bt1bp1aw0ZMkTDhg3TG2+8oUGDBoWm27hxo9LS0tSkSRPNnDlT0dHRmjJlimbPnl2u5ZT3nB8/frwefvhh9e3bV6NHj1aNGjW0fv16bd++PTTNK6+8ooEDB+q6667TSy+9pPDwcD3//PNKT0/XokWLlJaWVmTZv/jFL9S/f38NHTpU69at0/333y9JRS48DR48WK+88oqGDh2qiRMnKhgMavXq1aHvntxzzz2aPn26Zs+eHXqfLdwuS5cu1Z/+9KdybQfGgX9jHGAcKBdXxcyYMcNJKvHH7/eHptu6dauT5GbMmFGshiT34IMPhv7dvXt3V7NmTXfgwIFSl7t06VInyS1dujT02oMPPuhO3URffPGFk+TuvffeIvO++uqrTpIbNGhQ6LURI0a42NhYt3379iLTPvnkk06S27BhQ4l95Ofnu9zcXDdx4kSXmJjoCgoKQr9r3Lixi4yMLFLz2LFjLiEhwY0YMaLUdSskyd19992l/v6+++5zktw//vEP51zJ2zg2NtaNGjXqjMvp2bOna9y4cZn9WKzrkCFDXHh4uNu4cWOpy3n00UddWFiYW7VqVZHX33zz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oD179ujxxx8v8Q+t1q1b649//KOmTZumXr166fe//73mzp2r7t27a/z48YqOjtaf/vSncj3is7znfJMmTTRu3Dg9/PDDOnbsWOiRtBs3btS3336rCRMmKDY2Vs8++6wGDRqk7777Tv369VOdOnWUkZGhtWvXKiMjo1yB4VSXXXaZfvnLX2rSpEnav3+/evXqpYiICP3rX/9SdHS0fvWrX4WmrVmzpgYOHKipU6eqcePGuvbaayu0rEKMA4wDjAPlVFnfQi/NmZ46Jcm98MILoWkPHTrkhg0b5urWretiYmLctdde67Zt21bikxs2btzobrjhBpeYmOiCwaBr1KiRGzx4sMvJyXHOle+pU845d/z4cTd69GhXp04dFxkZ6S655BK3YsWKYk86cO7kUyR+/etfu6ZNm7rw8HCXkJDgLr74YvfAAw8UefrD9OnTXYsWLVxERIT72c9+5h599FE3bdq0Yk8Cady4sevZs2exbVbWE0IKnbodw8LCXHx8vGvTpo0bPny4W7FiRbHpT3/qVE5Ojrvjjjtc27ZtXXx8vIuKinItWrRwDz74YJGnRnz33XeuX79+rmbNms7n8xXZhmdjXXfu3OmGDBni6tWr58LDw11ycrK78cYb3f79+0PTZGdnu9///veuRYsWLhgMuho1arg2bdq4e++9t8hTWEpy6tNGSlPSE0OOHz/uxowZ48455xwXGRnpLrroIvfuu++6QYMGFXsq1+LFi92FF17oIiIiijzBrPAYzMjIKLbM04/PBx54wIWFhbklS5YUmW758uUuEAi4e+65p9T+jx8/7p588kl39dVXu0aNGrmIiAgXGRnpWrVq5X73u9+5zMzMItN73Y8q4QlohcfbE088EXqtcNt//vnnLjU11UVFRbmEhAR35513FnuCSknnoJf97pxzX3/9tbv++utdfHy8i46Odmlpae6f//xnmfMBZ9v111/vgsHgGZ+meNNNN7lAIBA61j/55BN3ySWXuIiICFevXj3329/+1v35z38u8alTqampRWqV95x37uSTsNq3b+8iIyNdbGysu/DCC4s9IfKDDz5wPXv2dAkJCS48PNydc845rmfPnu6NN94ITVPa+1/h3wmnLjc/P9/9z//8j2vdunXoXO/UqZObN29ese2ybNkyJ8k99thjpW670zEOMA4wDvwwPufK8aghAKgEgwcP1ptvvqns7OzKbgX4j3HhhReqWbNm5bpi/1M0evRoTZ06VTt37jzj5/tRNTAO/LRV2Y9OAQCAH8/mzZv10Ucfad26dRowYEBlt2Nu5cqV2rx5s6ZMmaIRI0YQMoAfAUEDAADo0Ucf1bx58zRw4EDdddddld2OuU6dOik6Olq9evXSpEmTKrsd4D8CH50CAAAAYO4n+3hbAAAAAFUXQQMAAACAOYIGAAAAAHPl+jJ4QUGB9uzZo7i4OPl8vrPdEwDg/7n//881k5OTFRbGtaFTMTYBQOUo79hUrqCxZ88eNWzY0Kw5AEDF7Ny5Uw0aNKjsNqoUxiYAqFxljU3lChpxcXGSpC66RgGFe+uo/fne5pd09wtve65R1UwZdL1JHV9uvkmdsXNe91xjwr23GXQihR887rlGQZTNk5zzI/wmddpP+KfnGp1jvzLoRLow4nuTOrfcN9JzjUmTXjToRBr6/jCTOkmrvN9BiM7I9TR/Xl6O/vHBY6H3Yfyb6diEEr2zeV1lt1BEn+ZtKruFEIttU5XWB6iIPOXqY/21zLGpXH99Fd6SDihcAZ/HN/NApLf5JUXH2fyxV5UE/BEmdXwFNkEjJs77H1gBg319so73j0QUBGyChi9gc+xFxHr/o8jqPIiLsPk4TiDc+/62OO4kKSzK5tjzBy3OA5v9xEeDijMdm1CieKNz0kpV2s8W26YqrQ9QIf//n2OUNTZVrXcQAAAAANUCQQMAAACAOYIGAAAAAHMEDQAAAADmCBoAAAAAzBE0AAAAAJgjaAAAAAAwR9AAAAAAYI6gAQAAAMAcQQMAAACAOYIGAAAAAHMEDQAAAADmCBoAAAAAzBE0AAAAAJgLVGjq9udLgUhvS1z5ubf5Jc3O6Oi5hiT5fc6kjoX8+KBJnUDmMZM6r2Re6rlG1Kb9Bp1IKvC+n/KTahg0IgW/zzKps2hXS8819ta2Wacv43aa1In74jvPNSyOO0mK3eK3qbP7uOcakd8c8DR/XoH3HoAfKj05xaTOoj1rTOpYoJfSWe3vqsRiG7NdijucVaBazcuejjsaAAAAAMwRNAAAAACYI2gAAAAAMEfQAAAAAGCOoAEAAADAHEEDAAAAgDmCBgAAAABzBA0AAAAA5ggaAAAAAMwRNAAAAACYI2gAAAAAMEfQAAAAAGCOoAEAAADAHEEDAAAAgDmCBgAAAABzBA0AAAAA5gIVmfjuF95WdJzf0wJnZ3T0NL8k7e902HMNSQrUr2dSx8Jjy583qfPVibomdV5O9b6fEt8+ZNCJlBA86rnGFTUWG3QiLTvcyqSOftHIc4kDOTEGjUh/i29nUmfHo0HPNXy9axl0IoX1MymjcS/M9FzjpQOdPc2fe+SElOa5DfyELNqzprJbCElPTqlSdSy2jVUv1VFVOvasWOxvq+1SlY49r73kuVxJW8qcjjsaAAAAAMwRNAAAAACYI2gAAAAAMEfQAAAAAGCOoAEAAADAHEEDAAAAgDmCBgAAAABzBA0AAAAA5ggaAAAAAMwRNAAAAACYI2gAAAAAMEfQAAAAAGCOoAEAAADAHEEDAAAAgDmCBgAAAABzBA0AAAAA5ggaAAAAAMwFfuwF+n3Oc41A/XoGnUh5e/eZ1Amck2xSx0KYr8CmkN/vvYTBvpYkv4zWqboJs7lO4KKCJnVMGBx3kiSfTRkLXs+DfNmcRzj7Fu1ZY1InPTnFpI5VP0BlsDoPULm4owEAAADAHEEDAAAAgDmCBgAAAABzBA0AAAAA5ggaAAAAAMwRNAAAAACYI2gAAAAAMEfQAAAAAGCOoAEAAADAHEEDAAAAgDmCBgAAAABzBA0AAAAA5ggaAAAAAMwRNAAAAACYI2gAAAAAMEfQAAAAAGCOoAEAAADAXKCyG6hMgXOSTerk7d5jUgcAgEV71pjUSU9OMakDAD8UdzQAAAAAmCNoAAAAADBH0AAAAABgjqABAAAAwBxBAwAAAIA5ggYAAAAAcwQNAAAAAOYIGgAAAADMETQAAAAAmCNoAAAAADBH0AAAAABgjqABAAAAwBxBAwAAAIA5ggYAAAAAcwQNAAAAAOYIGgAAAADMBSoy8ZRB1yvgj/C0wPz4oKf5Jemx5c97rlHVjGvawaSO//wWJnWe/WSa5xq33fMbg06kbccKPNfYcKCVQSfSkSaxJnX6zHvfc41uMV8adCJdHOH9nJSkTmPu8FzjmU9szu0e748yqfPbJ4d7rhG7N9/T/Hm5OZ57qO7e2bxO8XHerpulJ6d47sOiRnW1aM8akzrVbRtXte1S3bavFbbLD8cdDQAAAADmCBoAAAAAzBE0AAAAAJgjaAAAAAAwR9AAAAAAYI6gAQAAAMAcQQMAAACAOYIGAAAAAHMEDQAAAADmCBoAAAAAzBE0AAAAAJgjaAAAAAAwR9AAAAAAYI6gAQAAAMAcQQMAAACAOYIGAAAAAHMEDQAAAADmAhWZ2JebL19BvrcFZh7zNL8kfXWirucakhTmKzCpY8F/fguTOvkbNpnU+So30XON4KE8g06ksBxvx5wkhZ2w6cVqnbYcq+25RoNgpkEnUkLYbpM6wcPezyeL406SwrIq9NZWqvBs7zW8HjNheTbHHM5s0Z41nmukJ6d4rlHVWGwXqXpuGwBl444GAAAAAHMEDQAAAADmCBoAAAAAzBE0AAAAAJgjaAAAAAAwR9AAAAAAYI6gAQAAAMAcQQMAAACAOYIGAAAAAHMEDQAAAADmCBoAAAAAzBE0AAAAAJgjaAAAAAAwR9AAAAAAYI6gAQAAAMAcQQMAAACAOYIGAAAAAHM+55wra6LDhw+rRo0a+tvnjRUT5y2bvJJ5qaf5JWlr71qea0iS/H6bOgae+eQ1kzpf5Saa1Pmfc1t5rvHzVREGnUiJwWzPNa6MW2fQibQ0+zyTOsv7t/Fcw5d11KATycVEmdTZ/6T36xb17vC+ryVp501NTOrMGDnZe41vL/M0/4nsXE1LfV2HDh1SfHy8536qk8KxKVXXKeALr+x2tGjPmspuwVx6ckplt4CfmKp2Hlgcw1brVJ3OpzyXq2V6r8yxiTsaAAAAAMwRNAAAAACYI2gAAAAAMEfQAAAAAGCOoAEAAADAHEEDAAAAgDmCBgAAAABzBA0AAAAA5ggaAAAAAMwRNAAAAACYI2gAAAAAMEfQAAAAAGCOoAEAAADAHEEDAAAAgDmCBgAAAABzBA0AAAAA5gIVmXjCvbcpEIj0tMCoTfs9zS9JiW8f8lxDkvw+Z1LHwm33/MakTvBQnkmdlqs2eK7xVfvjBp1IW5s081zjwxadDDqRojdnmNTZ/4zPc422tQ8bdCJdEOd9X0vS3/q191yj6buZBp1IO15rYlLnt7ff6blG1FcHPM2fV2BzHuHMFu1Z47lGenKK5xr46ahKx4xFL5JNP1XtPKhK+6kq8bpdDmcVqFbzsqfjjgYAAAAAcwQNAAAAAOYIGgAAAADMETQAAAAAmCNoAAAAADBH0AAAAABgjqABAAAAwBxBAwAAAIA5ggYAAAAAcwQNAAAAAOYIGgAAAADMETQAAAAAmCNoAAAAADBH0AAAAABgjqABAAAAwBxBAwAAAIA5ggYAAAAAc4GKTBx+8LgCAZ+3JRY4b/NLSgge9VxDkvwqMKljYdsxm17CcvJN6iQGsz3X2NqkmUEnUt62HZ5r+JsmGXQiqcBmP8VFnPBcIyH8iEEnUu1Alkmdguig5xoWx50k5UeYlFHw4HHvRXwe3zO9zv8f4J3N6xQfx3UzlM+iPWtM6qQnp5jUwdlVHfeT1TH8Y+CdGQAAAIA5ggYAAAAAcwQNAAAAAOYIGgAAAADMETQAAAAAmCNoAAAAADBH0AAAAABgjqABAAAAwBxBAwAAAIA5ggYAAAAAcwQNAAAAAOYIGgAAAADMETQAAAAAmCNoAAAAADBH0AAAAABgjqABAAAAwFygIhMXRAVUEKjQLMXkJ9XwNL8kXVFjsecaVc2GA61M6oSdyDOpc2XcOs81PmzRyaATyd80yXuNpasNOpGOXtXepE7H2qs81+ga96VBJ1LHiEyTOs81jvVcw+K4k6SX63cxqfPtBXGea8TtivQ0f15ejrTdcxvVWp/mbRTwhXuqsWjPGptmqpmqtl3Sk1OqRI2qpjquE0pXFfZ3nsuVtKXM6bijAQAAAMAcQQMAAACAOYIGAAAAAHMEDQAAAADmCBoAAAAAzBE0AAAAAJgjaAAAAAAwR9AAAAAAYI6gAQAAAMAcQQMAAACAOYIGAAAAAHMEDQAAAADmCBoAAAAAzBE0AAAAAJgjaAAAAAAwR9AAAAAAYI6gAQAAAMBcoCIT50f45Qv4PS0w+H2Wp/kladnhVp5rVDVHmsSa1AkeyjOpszT7PM81ojdnGHQiqaDAc4mjV7U3aEQKLlxlUuezMY081yhwPoNOpKyYbSZ1YnYc8VzD4riTpMh93t6nCiWtPey5hj/T23teXsFxzz0AP1R6ckplt2Bu0Z41ld1CSHXcvjj7qsIxfDirQLWalz0ddzQAAAAAmCNoAAAAADBH0AAAAABgjqABAAAAwBxBAwAAAIA5ggYAAAAAcwQNAAAAAOYIGgAAAADMETQAAAAAmCNoAAAAADBH0AAAAABgjqABAAAAwBxBAwAAAIA5ggYAAAAAcwQNAAAAAOYIGgAAAADMETQAAAAAmAtUZOL2E/6piNhwTwtctKulp/klSb9o5L1GFdNn3vsmdbYcq21SZ3n/Np5r7H/GZ9CJFBdxwnONjrVXGXQifTbG5tgL9NjhucbGpo0NOpHW1m9rUuerYRGea4QZHHeSVKt1vkmdjtP+5bnG/B3ne5o//6ikGz23gTKkJ6d4rrFozxrPNaoai+1S1VTHdapKrM6D6rifqtO2yXO5kraUOR13NAAAAACYI2gAAAAAMEfQAAAAAGCOoAEAAADAHEEDAAAAgDmCBgAAAABzBA0AAAAA5ggaAAAAAMwRNAAAAACYI2gAAAAAMEfQAAAAAGCOoAEAAADAHEEDAAAAgDmCBgAAAABzBA0AAAAA5ggaAAAAAMwFKjJx59ivFB3n97TAvbVreJpfkg7kxHiuIUkKqzo5q1vMlyZ1GgQzTepszUryXKNt7cMGnUgJ4Uc81+gaZ7N9C5zPpM7Gpo0918jbut2gE8lfw+Z8iqmT57mGL+uoQSfSkfq1Tep0jfV+3OyoneBp/hPZJ7TOcxdA9bBozxrPNdKTUzzXqK7YviWz2C5S9dw2Zak6f2kDAAAAqDYIGgAAAADMETQAAAAAmCNoAAAAADBH0AAAAABgjqABAAAAwBxBAwAAAIA5ggYAAAAAcwQNAAAAAOYIGgAAAADMETQAAAAAmCNoAAAAADBH0AAAAABgjqABAAAAwBxBAwAAAIA5ggYAAAAAcwQNAAAAAOYCFZn4wojvFRfhLZt8GbfT0/yS9Lf4dp5rSJKLCprUsXBxhE0vCWG7TerMjInyXOOCuA0GnUi1A1mea3SMyDToRMqK2WZSZ239tp5r+GvEGHQiFazZaFKnSUJ9zzUKYmzWKSfRpIzaRWR7rrHO43teji9Pczx3gZ+S9OSUym4B/6E49mCNOxoAAAAAzBE0AAAAAJgjaAAAAAAwR9AAAAAAYI6gAQAAAMAcQQMAAACAOYIGAAAAAHMEDQAAAADmCBoAAAAAzBE0AAAAAJgjaAAAAAAwR9AAAAAAYI6gAQAAAMAcQQMAAACAOYIGAAAAAHMEDQAAAADmCBoAAAAAzPmcc66siQ4fPqwaNWqoQ++HFQiP9LTAuC++8zS/JO14JOi5RlUT92acSZ3g4QKTOtkjDnquUfd3ZR5a5VIQ7X1/H2kca9CJFLPjiEmdTcOiPdeIqWPTS5ME7+ekJOWm7vVc49t5zQ06kSJn1TKp4zM4hOM3eNu+efnHtWTT0zp06JDi4+O9N1SNFI5NqbpOAV+4p1qL9qzx3E96cornGjj7LPa1xP5GxVWlY89rL4ezClSr+ZYyxybuaAAAAAAwR9AAAAAAYI6gAQAAAMAcQQMAAACAOYIGAAAAAHMEDQAAAADmCBoAAAAAzBE0AAAAAJgjaAAAAAAwR9AAAAAAYI6gAQAAAMAcQQMAAACAOYIGAAAAAHMEDQAAAADmCBoAAAAAzBE0AAAAAJgLVGTiSZNeVEyct2zySualnuaXJF/vWp5rSJL8fps6Bp755HmTOl/lJprUebZbmucaTd/NNOhESgxme65xZdw6g06kpdnnmdQJ69/Gcw1f1lGDTqSCmBiTOt/Oa+65RtK1mw06kfaO9v4+I0kzRk72XuPbyzzNfyI7V0r13AbKkJ6c4rnGoj1rPNeoaiy2iyWLbVzV1qm6qWrnQVXa39WplzyXK2lLmdNxRwMAAACAOYIGAAAAAHMEDQAAAADmCBoAAAAAzBE0AAAAAJgjaAAAAAAwR9AAAAAAYI6gAQAAAMAcQQMAAACAOYIGAAAAAHMEDQAAAADmCBoAAAAAzBE0AAAAAJgjaAAAAAAwR9AAAAAAYI6gAQAAAMAcQQMAAACAOZ9zzpU10eHDh1WjRg01fOphhUVFelpg7Ba/p/klKeyE5xIn+YzqGDjU1malwrICJnVidnnPoM5o++ZHeK+RUz/fexFJkfu8H7+SVGuT936O1LfpJSfRpIwS13tfp6xGNutU/6nlJnU2T+3guUbsN97OyfzjOdr0zDgdOnRI8fHxnvupTgrHplRdp4AvvLLbAX7yFu1Z47lGenKK5xqWquM6VQV5LlfL9F6ZYxN3NAAAAACYI2gAAAAAMEfQAAAAAGCOoAEAAADAHEEDAAAAgDmCBgAAAABzBA0AAAAA5ggaAAAAAMwRNAAAAACYI2gAAAAAMEfQAAAAAGCOoAEAAADAHEEDAAAAgDmCBgAAAABzBA0AAAAA5ggaAAAAAMwRNAAAAACYC1Rk4qRVYfIHvWWT2N3HPc0vSeNemOm5RlXz2yeHm9QJzzYpoykTJ3uu8dvb7/TeiKTgQe/HzLcXxBl0IiWtPWxSp+O0f3mu0TX2S4NOpHYRNgdNz1GjPNeYMXKy5xqS1O/ckSZ1mt/5qecauT0u9jR/Xt5xbfLcBQBri/as8VwjPTnFcw3JphfJrp+qpDqu008JdzQAAAAAmCNoAAAAADBH0AAAAABgjqABAAAAwBxBAwAAAIA5ggYAAAAAcwQNAAAAAOYIGgAAAADMETQAAAAAmCNoAAAAADBH0AAAAABgjqABAAAAwBxBAwAAAIA5ggYAAAAAcwQNAAAAAOYIGgAAAADMBSoycXRGrgIBv6cFRn5zwNP8kvTSgc6ea0iS3+dM6liI3ZtvUid4KM+kzoxvL/NcI+or7/takuTzeS4RtyvSoBHJn5llUmf+jvM919hRO8GgE2ld3E6TOvEbvvNcw+K4k6TYbyr01laq3B4Xe64Rvvifnub3uVzPPaBsi/as8VwjPTnFcw2cfRb7Gj8dnNuVizsaAAAAAMwRNAAAAACYI2gAAAAAMEfQAAAAAGCOoAEAAADAHEEDAAAAgDmCBgAAAABzBA0AAAAA5ggaAAAAAMwRNAAAAACYI2gAAAAAMEfQAAAAAGCOoAEAAADAHEEDAAAAgDmCBgAAAABzBA0AAAAA5gLlmcg5J0nKy8vxvMC8guOea+QeOeG5hiTly5nUsZCX633bSlJYXp5JnRPZuZ5rWOxrSZLP57mExbEr2a1T/lHvNU5k25wHOT6bYyYv3/u2sTjuJCn/uNH+zvO+Tj7nbZ3ydHL+wvdh/FtobFKuvL6dH84q8NxPnsd9jR+Hxb62YnXMWK1TdTyGObfPjvKOTT5XjtFr165datiwoU1nAIAK27lzpxo0aFDZbVQpjE0AULnKGpvKFTQKCgq0Z88excXFyWdwdRkAUD7OOWVlZSk5OVlhYXza9VSMTQBQOco7NpUraAAAAABARXB5DAAAAIA5ggYAAAAAcwQNAAAAAOYIGgAAAADMETQAAAAAmCNoAAAAADBH0AAAAABg7v8APJkAW0f+ndAAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 1000x500 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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SY899pjeeustrVy5UhMmTJB04Lb4wQ6dj3TgS9uHjvs2yg/snJycasc8++yzGjVqlB5//HHl5eUpKytLI0eO1JYtW45Y/2gs67Zt2464bbdu3ar333+/0rbIyMiQcy6+LWqiTZs2GjBggKZPn67p06frkksuqfAmebCHHnpIV111lU499VQ999xzWrFihVauXKlzzjmn1turus/MVqVJkya64IILVFxcrHPOOUfdunWr8bThcFj5+fm69957tXjxYm3atEn9+/fXggUL4ifz2m7HrKysCv9OTk4+7OvFxcUVXq/q+Co/BsuPyapYbncgEX388cd6/fXXNWjQIDnntGPHDu3YsUPDhg2TVPGjRYWFhZXOXVLl81lVanrMb9u2TZIO+55c/t25YcOGVTo277//fjnn4h83Knfo8V/+ceeD5xsMBo+4LBdeeKHatm0b/5jUzJkztXfv3iMGlENxHuA8gJpL2O9oHEkkEpGkSl/mPnSHy8rKUjAY1ObNm73nWb6Tb9mypUIyLysrqzTfpk2b6qSTTtK9995bZa3yP+Znz56tcDisBQsWxJdJkp5//nnvfmujqKhIS5YsUfv27Q97kmjatKkefvhhPfzww/r88881f/583Xbbbfrqq6+0aNGiw87jaCxrs2bNjrhtmzZtqtTU1Gq/NN+0adNazXPMmDEaMWKEYrGYpk6dWu24p556Sv3796805tDv89REbT5D+vLLL2vq1Kk65ZRTNG/ePD333HM1vhJ2qCZNmujGG2/Uq6++qjVr1ui88877zvfZ8uPr4JNMebCtKoyWs97uQKKZPn26nHOaO3eu5s6dW+n3TzzxhCZPnqxgMKgmTZpUeUGoJheJanrMl39qYPPmzWrVqlWVtcqPu0ceeaTapxoefNelJpo1a6ZoNKotW7Yc9o/xpKQkXXPNNbrjjjv04IMPasqUKRowYIA6depUq/lJnAc4D6CmjtmgkZ2drUgkovfff7/C64c+5zk1NVX9+vXTnDlzdO+993rtVOVP4Xj66acr3F3505/+VOmL64MHD9ZLL72k9u3bq3HjxtXWDAQCCoVCFb7kXlRUpCeffPJb91lb0WhU1157rQoLC3XffffVeLrWrVvr2muv1dKlS+O3oqXq77AcjWU999xz9eSTT+qjjz6q9mQxePBg/eIXv1CTJk3Url27bz2vckOGDNGQIUPUsGHDwz7+NxAIVHrQwPvvv6/ly5dXOAkfenXOx5dffqkRI0aoX79+evnllzV06FCNHTtWPXv2POyyl5aWateuXVW+YZff3i8Px3Wxzz799NO6/vrr4/8u/wLr4f5TMevtDiSSaDSqJ554Qu3bt6/yP1JbsGCBHnzwQS1cuFCDBw/WWWedpfnz52vr1q3xP+Sj0WiV/yfEoWp6zP/gBz9QMBjU1KlTlZeXV2Wt008/XY0aNdK6det07bXX1maRq3Xuuefqvvvu09SpUzVp0qTDjr3yyit111136fLLL9dHH30U/0J3bXEe4DyAmknYoLFmzZpKf7xLUvv27dWsWTMFAgGNGDFC06dPV/v27dW9e3e9/fbbVT5B46GHHlLfvn116qmn6rbbblOHDh20detWzZ8/X3/4wx9q/J/sdOnSRSNGjNDDDz+scDisgQMHas2aNXrggQeUmZlZYeykSZP08ssvq0+fPrr++uvVqVMnFRcXa8OGDXrppZf06KOPqmXLlho0aJAeeughXXbZZRo3bpwKCwv1wAMP1OpJWLWxdetWrVixQs457d69W2vWrNGsWbP03nvv6aabbtKPf/zjaqfduXOnzjrrLF122WXq3LmzMjIytHLlSi1atEhDhw6Nj+vWrZv+/Oc/a+rUqTr55JOVlJSkXr16HZVlnTRpkhYuXKgzzzxTd9xxh7p166YdO3Zo0aJF+ulPf6rOnTvrxhtv1HPPPaczzzxTN910k0466STFYjF9/vnn+utf/6qbb765Vs+cj0QiVV49PNTgwYN1zz336M4771S/fv300UcfadKkSWrXrl2FfTsjI0Nt2rTRCy+8oAEDBigrK0tNmzZV27Zta7UuotGoLr30UgUCAT3zzDMKBoOaOXOmcnNzdfHFF+vNN9+M35Y+1M6dO9W2bVtddNFFGjhwoFq1aqU9e/bo1Vdf1W9+8xt16dIlvo2/6302OTlZDz74oPbs2aPevXvHnzZy7rnnqm/fvtVO57vd9+3bp5deeknSgaepSAe+W/X111+rQYMG8e9bAXVh4cKFKigo0P3331/lH1pdu3bV7373O02bNk2DBw/Wz3/+c82fP19nn322Jk6cqLS0NP3+97+v0SM+a3rMt23bVnfccYfuueceFRUVxR9Ju27dOn399de6++67lZ6erkceeUSjRo3S9u3bNWzYMDVv3lzbtm3Te++9p23bth32DkFVzjjjDF1xxRWaPHmytm7dqsGDByslJUX/+Mc/lJaWpuuuuy4+tlGjRho5cqSmTp2qNm3a6Pzzz6/VvMpxHuA8wHmghurqW+jVOdxTpyS5xx57LD52586d7sorr3TZ2dmuQYMG7vzzz3cbNmyo8skN69atcxdddJFr0qSJS05Odq1bt3ajR492xcXFzrmaPXXKOedKSkrczTff7Jo3b+4ikYg77bTT3PLlyys96cC5A0+RuP766127du1cOBx2WVlZ7uSTT3YTJkyo8PSH6dOnu06dOrmUlBT3ve99z913331u2rRplZ4E0qZNGzdo0KBK6+xITwgpd/B6TEpKcpmZma5bt25u3Lhxbvny5ZXGH/rUqeLiYveTn/zEnXTSSS4zM9Olpqa6Tp06uTvvvLPCUyO2b9/uhg0b5ho1auQCgUCFdXg0lnXTpk1uzJgxrkWLFi4cDrucnBw3fPhwt3Xr1viYPXv2uJ///OeuU6dOLjk52TVs2NB169bN3XTTTRWewlKVg582Up2qnhhSUlLibrnlFnf88ce7SCTievbs6Z5//nk3atSoSk/lWrJkievRo4dLSUmp8ASz8n1w27ZtleZ56P45YcIEl5SU5JYuXVph3LJly1woFHI33HBDtf2XlJS4Bx54wJ177rmudevWLiUlxUUiEdelSxd36623usLCwgrjfbejqngCWvn+9qtf/Sr+Wvm6f//9913//v1damqqy8rKcldddVWlJ6hUdQz6bPfyfqr6qclT1YCj6Yc//KFLTk4+7NMUL7nkEhcKheL7+ltvveVOO+00l5KS4lq0aOH+67/+y/3xj3+s8qlT/fv3r1Crpse8cweehNW7d28XiURcenq669GjR6UnRL722mtu0KBBLisry4XDYXf88ce7QYMGuTlz5sTHVPf+V/53wsHzjUaj7te//rXr2rVr/FjPy8tzL774YqX18uqrrzpJ7pe//GW16+5QnAc4D3Ae+HYCztXgUUMAUAdGjx6tuXPnas+ePXXdCvBvo0ePHmrfvn2Nrtgfi26++WZNnTpVmzZtOuzn+5EYOA8c2xL2o1MAAOC7s379er3xxhtavXq1RowYUdftmFuxYoXWr1+vKVOmaPz48YQM4DtA0AAAALrvvvv04osvauTIkbr66qvruh1zeXl5SktL0+DBgzV5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",
      "text/plain": [
       "<Figure size 1000x500 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAxoAAAGICAYAAADGcZYzAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8g+/7EAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAw6klEQVR4nO3deXxU5dn/8e9kZpJJyAIJa2QtylbAyCZUFBTaiIAKD+4UKFgpal1+Wjd8gSJurfpgrWAVEHF5rGK1iAKPULCiIFREBSxYBQQDIQbZSUgy9+8PnqSEJJB4X5iAn/frxR9MzrnOddY73zkzJwHnnBMAAAAAGIqp7gYAAAAAnHwIGgAAAADMETQAAAAAmCNoAAAAADBH0AAAAABgjqABAAAAwBxBAwAAAIA5ggYAAAAAcwQNAAAAAOZqXNCYMWOGAoFAhf8WL158XJa7ePHiMvXvueceBQKBSs3fvHlzjRgx4rj0ZuXw7RgMBlWnTh2dfvrpGj16tJYtW1Zm+o0bNyoQCGjGjBlVWs5LL72kSZMm2TRdA4wYMUKBQEBJSUnau3dvmZ9v2rRJMTExCgQCuueee6pcf//+/brnnnuqfGxX5fisDOecXn75ZZ199tmqX7++IpGIGjdurMzMTE2dOtVsOceL9Tk4depUXXzxxWrevLni4+N16qmnasyYMdq6davZMgArf/zjHxUIBNS+ffsqzVc85m7cuLHktd69e6t37962DZ7gGAcYBxgHvp8aFzSKPfvss1q6dGmZf506dfrBerj66qu1dOnSH2x5P4QhQ4Zo6dKlWrJkiV5++WUNGzZMy5YtU48ePXTjjTeWmrZRo0ZaunSp+vfvX6VlnGxBQ5LC4bAKCwv1l7/8pczPnn32WSUlJX3v2vv379e9995b5QHG+vi88847dcUVV6ht27aaOnWq5s6dq4kTJ6pBgwb629/+ZracE8X48eOVmJioBx54QPPmzdNtt92mOXPmqHPnzsrOzq7u9oBSpk+fLklas2aNPvzwQ69akydP1uTJky3aOqkwDjAOMA5UXai6G6hI+/bt1aVLl2rtoXHjxmrcuHG19mCtQYMG6t69e8n/MzMzddNNN+maa67RH//4R7Vp00ZjxoyRJMXFxZWa9scsNjZWAwcO1PTp0zVq1KiS151zmjFjhi677DI988wzP0gv+/fvV0JCgunxeeDAAU2aNEnDhg3T008/XepnI0aMUDQaNVnOieTjjz9W/fr1S/7fq1cvderUSV27dtUzzzyju+++uxq7A/7jn//8pz755BP1799fb731lqZNm6Yzzzzze9dr166dYXcnD8YBxgHGgaqrsXc0juVoH+sp79blv/71L11xxRVq0KCB4uLi1LRpUw0bNkz5+fkVLqO8W5IFBQW67bbb1LBhQyUkJKhnz55avnx5ufNv27ZNo0ePVuPGjRUbG6sWLVro3nvvVWFhYanp7r33Xp155plKTU1VcnKyOnXqpGnTpsk5V2q65s2ba8CAAZo3b546deqk+Ph4tWnTpuSdrO8rGAzqT3/6k+rWras//OEPJa+Xt41zcnJ0zTXXqEmTJoqLi1O9evV01llnacGCBZIO3XJ/6623tGnTplIf1Tqe6/rNN9+U9BQbG6v09HQNGTKk1LsNu3fv1q233qoWLVooNjZWp5xyim666Sbt27ev0ttp5MiR+uCDD7Ru3bqS1xYsWKBNmzbpV7/6VZnpc3JydO2116pdu3ZKTExU/fr1dd555+m9994rtY3r1atXsm2Kt1fxrd/iY3DlypUaMmSI6tSpo5YtW5b6WbElS5YoHA7r1ltvLdVH8Ucjpk2bVuG67du3T/n5+WrUqFG5P4+JKX2pqOp+nDNnjs444wzFx8erbdu2mjNnTklvbdu2Va1atdStWzf985//LDX/iBEjlJiYqDVr1qhPnz6qVauW6tWrp+uvv1779++vcH2K+ez3wweXYp07d1YwGNTmzZuPOT/wQyk+tx966CH97Gc/08svv1zu+bFs2TKdddZZikQiSk9P15133qmCgoIy05X30anKnvPSobvaPXr0UGJiohITE5WRkVHm+rNgwQL16dNHycnJSkhI0FlnnaWFCxeWmqb4GrdmzRpdccUVSklJUYMGDTRy5Ejt2rWr1LTRaFRPPPGEMjIyFB8fr9q1a6t79+6aPXu2JGnUqFFKTU0td7ucd955+ulPf1rOli2LceA/GAcYByqjxt7RKCoqKvMLefF3C6rqk08+Uc+ePVW3bl1NmDBBp512mrZu3arZs2fr4MGDiouLq3StX//615o5c6ZuvfVW/fznP9fq1as1ePBg7dmzp9R027ZtU7du3RQTE6Nx48apZcuWWrp0qSZOnKiNGzfq2WefLZl248aNGj16tJo2bSrp0GDw29/+Vt98843GjRtXZl1uueUW3XHHHWrQoIGmTp2qUaNG6dRTT9U555xT5W1TLD4+Xn379tXLL7+sLVu2VPgOyS9/+UutXLlS999/v1q1aqWdO3dq5cqVys3NlXTolvs111yjL7/8Uq+//nqZ+a3X9ZtvvlHXrl1VUFCgu+66Sx07dlRubq7mz5+v7777Tg0aNND+/fvVq1cvbdmypWSaNWvWaNy4cfrss8+0YMGCSn3GtW/fvmrWrJmmT5+uhx9+WNKhAf6cc87RaaedVmb6HTt2SDp067Vhw4bau3evXn/9dfXu3VsLFy5U79691ahRI82bN0/nn3++Ro0apauvvlqSSgadYoMHD9bll1+u3/zmNxVeHHv27KmJEyfqjjvu0DnnnKMLL7xQa9as0XXXXaehQ4eWegfuSHXr1tWpp56qyZMnq379+rrgggvUunXrCrdLVffjnXfeqbFjxyolJUX33nuvBg8erDvvvFMLFy7UAw88oEAgoNtvv10DBgzQhg0bFB8fXzJ/QUGBLrjgAo0ePVp33HGHPvjgA02cOFGbNm3Sm2++WeE6We33w7377rsqKiqq9C8lwPF24MAB/c///I+6du2q9u3ba+TIkbr66qv16quvavjw4SXTrV27Vn369FHz5s01Y8YMJSQkaPLkyXrppZcqtZzKnvPjxo3Tfffdp8GDB+uWW25RSkqKVq9erU2bNpVM88ILL2jYsGG66KKL9NxzzykcDuvPf/6zMjMzNX/+fPXp06fUsv/rv/5Ll112mUaNGqXPPvtMd955pySVeuNpxIgReuGFFzRq1ChNmDBBsbGxWrlyZcl3T2688UZNnz5dL730Usl1tni7LFq0SE8++WSltgPjwH8wDjAOVIqrYZ599lknqdx/wWCwZLoNGzY4Se7ZZ58tU0OSGz9+fMn/zzvvPFe7dm23ffv2Cpe7aNEiJ8ktWrSo5LXx48e7wzfR559/7iS5m2++udS8L774opPkhg8fXvLa6NGjXWJiotu0aVOpaR955BEnya1Zs6bcPoqKilxBQYGbMGGCS0tLc9FotORnzZo1c5FIpFTNAwcOuNTUVDd69OgK162YJHfddddV+PPbb7/dSXIffvihc678bZyYmOhuuummoy6nf//+rlmzZsfsx2JdR44c6cLhsFu7dm2Fy3nwwQddTEyMW7FiRanXZ82a5SS5t99++6h9Dh8+3NWqVcs5d+iYaNiwoSsoKHC5ubkuLi7OzZgxw+Xk5JQ57o5UWFjoCgoKXJ8+fdygQYNKXj/avMXH4Lhx4yr82eGi0ai74IILXO3atd3q1atdu3btXJs2bdzevXuPuo7OObd8+XLXtGnTkvMtKSnJDRgwwM2cObPUvjnSsfZjfHy827JlS8lrq1atcpJco0aN3L59+0pef+ONN5wkN3v27JLXhg8f7iS5xx9/vNQy77//fifJLVmypNSyDj8Hfff7kXbv3u3atm3rmjRp4vbs2VOleYHjZebMmU6Se+qpp5xzzu3Zs8clJia6s88+u9R0l112mYuPj3fbtm0rea2wsNC1adPGSXIbNmwoeb1Xr16uV69eFS6zonP+q6++csFg0F111VUVzrtv3z6XmprqBg4cWKbm6aef7rp161byWvE17ve//32paa+99loXiURKlvuPf/zDSXJjx46tcLnF65WRkVHqtTFjxrjk5ORjntOMA4wDzjEOfB819qNTM2fO1IoVK0r9+z5fcNu/f7/effddXXrppWXeHaiqRYsWSZKuuuqqUq9feumlCoVK3xyaM2eOzj33XKWnp6uwsLDkX79+/SQdSsTF/v73v6tv375KSUlRMBhUOBzWuHHjlJubq+3bt5eqm5GRUfLugSRFIhG1atWq1LtF35cr5xb4kbp166YZM2Zo4sSJWrZsWbm33Y/Gel3nzp2rc889V23btq1wmXPmzFH79u2VkZFRal9kZmZW+Ulmv/rVr5Sdna25c+fqxRdfVGxsrC655JIKp3/qqafUqVMnRSIRhUIhhcNhLVy4UJ9//nmllykdekevMgKBgGbOnKmkpCR16dJFGzZs0CuvvKJatWodc96uXbvq3//+t+bNm6e77rpLPXr00MKFCzVs2DBdeOGFpY6Pqu7HU045peT/xfuqd+/eSkhIKPN6ecfykefclVdeKek/52R5LPd7Xl6eBg8erE2bNunVV19VYmJipecFjqdp06YpPj5el19+uSQpMTFRl1xyid577z198cUXJdMtWrRIffr0UYMGDUpeCwaDuuyyyyq1nMqc8++8846Kiop03XXXVVjngw8+0I4dOzR8+PBS52U0GtX555+vFStWlHm3/sILLyz1/44dOyovL69kuXPnzpWkoy5XOnRXY9WqVXr//fclHfpIzfPPP6/hw4dX6ZxmHDiEcYBxoDJqbNBo27atunTpUupf586dq1znu+++U1FRkcmXpYo/HtSwYcNSr4dCIaWlpZV6LTs7W2+++abC4XCpf8W32r799ltJ0vLly/WLX/xCkvTMM8/o/fff14oVKzR27FhJh26LH+7I5UiHvrR95HTfR/GJnZ6eXuE0f/nLXzR8+HBNnTpVPXr0UGpqqoYNG6Zt27Yds/7xWNecnJxj7tvs7Gx9+umnZfZFUlKSnHMl+6IymjVrpj59+mj69OmaPn26Lr/88lIXycM99thjGjNmjM4880y99tprWrZsmVasWKHzzz+/yvuros/MlictLU0XXnih8vLydP7556tDhw6VnjccDiszM1P333+/5s+fr82bN6t3796aM2dOyWBe1f2Ymppa6v+xsbFHfT0vL6/U6+WdX8XnYPE5WR6r/Z6fn69BgwZpyZIlmj17tteXbAFL//73v/WPf/xD/fv3l3NOO3fu1M6dOzVkyBBJpT9alJubW2bsksqOZ+Wp7Dmfk5MjSUe9Jhd/d27IkCFlzs2HH35YzrmSjxsVO/L8L/648+HLDQaDx1yXiy66SM2bNy/5mNSMGTO0b9++YwaUIzEOMA4wDlRejf2OxrFEIhFJKvNl7iMPuNTUVAWDQW3ZssV7mcUH+bZt20ol88LCwjLLrVu3rjp27Kj777+/3FrFv8y//PLLCofDmjNnTsk6SdIbb7zh3W9VHDhwQAsWLFDLli2POkjUrVtXkyZN0qRJk/T1119r9uzZuuOOO7R9+3bNmzfvqMs4Hutar169Y+7bunXrKj4+vsIvzdetW7dKyxw5cqSGDh2qaDSqKVOmVDjdCy+8oN69e5eZ5sjv81RGVT5D+s4772jKlCnq1q2bXn/9db322muVfifsSGlpabrpppu0ePFirV69WhdccMEPfswWn1+HDzLFwba8MFrMYr/n5+fr4osv1qJFi/S3v/2tzGfHgeo0ffp0Oec0a9YszZo1q8zPn3vuOU2cOFHBYFBpaWnlviFUmTeJKnvOF39qYMuWLWrSpEm5tYrPuyeeeKLCpxoeftelMurVq6eioiJt27btqL+Mx8TE6LrrrtNdd92lRx99VJMnT1afPn3UunXrKi1PYhxgHEBlnbBBo0GDBopEIvr0009LvX7kc57j4+PVq1cvvfrqq7r//vur/Evl4YqfwvHiiy+WurvyyiuvlPni+oABA/T222+rZcuWqlOnToU1A4GAQqFQqS+5HzhwQM8///z37rOqioqKdP311ys3N1cPPvhgpedr2rSprr/+ei1cuLDkVrRU8R2W47Gu/fr10/PPP69169ZVOFgMGDBADzzwgNLS0tSiRYvvvaxigwYN0qBBg5SSknLUx/8GAoEyDxr49NNPtXTp0lKD8JHvzvnYunWrhg4dql69eumdd97R4MGDNWrUKHXq1Omo615QUKDdu3eXe8Euvr1fHI6r45h98cUXdcMNN5T8v/gLrEf7o2K++734Hay///3v+utf/6rMzMwq1wCOl6KiIj333HNq2bJluX9Ibc6cOXr00Uc1d+5cDRgwQOeee65mz56t7Ozskl/ki4qKyv2bEEeq7Dn/i1/8QsFgUFOmTFGPHj3KrXXWWWepdu3aWrt2ra6//vqqrHKF+vXrpwcffFBTpkzRhAkTjjrt1VdfrXvuuUdXXXWV1q1bV/KF7qpiHGAcQOXU2KCxevXqMr+8S1LLli1Vr149BQIBDR06VNOnT1fLli11+umna/ny5eU+QeOxxx5Tz549deaZZ+qOO+7QqaeequzsbM2ePVt//vOfK/1Hdtq2bauhQ4dq0qRJCofD6tu3r1avXq1HHnlEycnJpaadMGGC3nnnHf3sZz/TDTfcoNatWysvL08bN27U22+/raeeekqNGzdW//799dhjj+nKK6/UNddco9zcXD3yyCNVehJWVWRnZ2vZsmVyzmnPnj1avXq1Zs6cqU8++UQ333yzfv3rX1c4765du3TuuefqyiuvVJs2bZSUlKQVK1Zo3rx5Gjx4cMl0HTp00F//+ldNmTJFnTt3VkxMjLp06XJc1nXChAmaO3euzjnnHN11113q0KGDdu7cqXnz5un//b//pzZt2uimm27Sa6+9pnPOOUc333yzOnbsqGg0qq+//lr/+7//q1tuuaVKt0EjkUi57x4eacCAAbrvvvs0fvx49erVS+vWrdOECRPUokWLUsd2UlKSmjVrVvJOSWpqqurWravmzZtXaVsUFRXpiiuuUCAQ0EsvvaRgMKgZM2YoIyNDl112mZYsWVJyW/pIu3btUvPmzXXJJZeob9++atKkifbu3avFixfr8ccfV9u2bUv28Q99zMbGxurRRx/V3r171bVr15KnjfTr1089e/ascD7f/T5kyBDNnTtXY8eOVVpampYtW1bys+TkZP7WAKrV3LlzlZWVpYcffrjcX7Tat2+vP/3pT5o2bZoGDBigu+++W7Nnz9Z5552ncePGKSEhQU8++WSlHvFZ2XO+efPmuuuuu3TffffpwIEDJY+kXbt2rb799lvde++9SkxM1BNPPKHhw4drx44dGjJkiOrXr6+cnBx98sknysnJOeodgvKcffbZ+uUvf6mJEycqOztbAwYMUFxcnD7++GMlJCTot7/9bcm0tWvX1rBhwzRlyhQ1a9ZMAwcOrNKyijEOMA4wDlRSdX0LvSJHe+qUJPfMM8+UTLtr1y539dVXuwYNGrhatWq5gQMHuo0bN5b75Ia1a9e6Sy65xKWlpbnY2FjXtGlTN2LECJeXl+ecq9xTp5xzLj8/391yyy2ufv36LhKJuO7du7ulS5eWedKBc4eeInHDDTe4Fi1auHA47FJTU13nzp3d2LFjSz39Yfr06a5169YuLi7O/eQnP3EPPvigmzZtWpkngTRr1sz179+/zDY71hNCih2+HWNiYlxycrLr0KGDu+aaa9zSpUvLTH/kU6fy8vLcb37zG9exY0eXnJzs4uPjXevWrd348eNLPTVix44dbsiQIa527douEAiU2obHY103b97sRo4c6Ro2bOjC4bBLT093l156qcvOzi6ZZu/eve7uu+92rVu3drGxsS4lJcV16NDB3XzzzaWewlKew582UpHynhiSn5/vbr31VnfKKae4SCTiOnXq5N544w03fPjwMk/lWrBggTvjjDNcXFxcqSeYFR+DOTk5ZZZ55PE5duxYFxMT4xYuXFhqug8++MCFQiF34403Vth/fn6+e+SRR1y/fv1c06ZNXVxcnItEIq5t27butttuc7m5uaWm992PKucJaMXH2x/+8IeS14q3/aeffup69+7t4uPjXWpqqhszZkyZJ6iUdw767PejXYcqc74Bx9PFF1/sYmNjj/o0xcsvv9yFQqGSY/3999933bt3d3Fxca5hw4bud7/7nXv66afLfepU7969S9Wq7Dnv3KEnYXXt2tVFIhGXmJjozjjjjDJPiHz33Xdd//79XWpqqguHw+6UU05x/fv3d6+++mrJNBVd/4p/Tzh8uUVFRe6///u/Xfv27UvO9R49erg333yzzHZZvHixk+QeeuihCrfdkRgHGAcYB76fgHOVeNQQ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",
      "text/plain": [
       "<Figure size 1000x500 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Inspect a few input/label pairs\n",
    "# use matplotlib to plot the euclidean distance matrices in x_val\n",
    "x_val_adj = vec2adj(x_val, n=n)\n",
    "y_val_adj = vec2adj(y_val, n=n)\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "for idx in range(3):\n",
    "    fig, ax = plt.subplots(1, 2, figsize=(10, 5))\n",
    "    ax[0].imshow(x_val_adj[idx])\n",
    "    ax[1].imshow(y_val_adj[idx])\n",
    "    for ax_ in ax:\n",
    "        ax_.set_xticks([])\n",
    "        ax_.set_yticks([])\n",
    "    # add title\n",
    "    ax[0].set_title('Euclidean Distance Matrix Sample {}'.format(idx))\n",
    "    ax[1].set_title('Adjacency Matrix Sample {}'.format(idx))\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Set up the Prior Predictive Check for the original prior and the altered prior. Note in the modeling process \n",
    "#   we started with the original prior, saw that it did not match prior beliefs about sparsity characterictics, \n",
    "#   and then adjust the prior via independently interpretable parameter \\theta\n",
    "num_edges = x_val.shape[-1]\n",
    "n = int(0.5*(np.sqrt(8 * num_edges + 1) + 1))\n",
    "S = jnp.array(degrees_from_upper_tri(n))\n",
    "\n",
    "original_prior_model_args = \\\n",
    "    {'x': x_val, 'y': None,\n",
    "     'depth': dpg_hyperparameters['depth'],\n",
    "     'w_init': w_init_scale * jnp.ones((len(x_val), num_edges)), \n",
    "     'lam_init': lam_init_scale * jnp.ones((len(x_val), n)),\n",
    "     'S': S,\n",
    "     'prior_settings': original_prior}\n",
    "\n",
    "altered_prior_model_args = original_prior_model_args.copy()\n",
    "altered_prior_model_args['prior_settings'] = altered_prior\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Perform the Prior Predictive Check here.\n",
    "rng_key = random.PRNGKey(experiment_settings['random_seed'])\n",
    "rng_key, rng_key_ = random.split(rng_key)\n",
    "\n",
    "prior_predictive_original = Predictive(dpg_bnn.model, num_samples=experiment_settings['num_prior_samples'])\n",
    "prior_predictions_original = prior_predictive_original(rng_key=rng_key_, **original_prior_model_args)['obs'] # shape: num_prior_samples x num_val_samples x num_edges\n",
    "\n",
    "prior_predictive_altered = Predictive(dpg_bnn.model, num_samples=experiment_settings['num_prior_samples'])\n",
    "prior_predictions_altered = prior_predictive_altered(rng_key=rng_key_, **altered_prior_model_args)['obs']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(10000, 5, 190)"
      ]
     },
     "execution_count": 48,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "prior_predictions_original.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Inspecting prior predictive samples for validation sample 1 from the original prior\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAxoAAAGICAYAAADGcZYzAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8g+/7EAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAgfklEQVR4nO3de5RV5Xk/8GdghvsAIhgcQIaaYg0KaAJRSApKdBSUlqiJlwJqTKzGpXZpoqkXjOSyjK3VUEvaVcW6EFcSG5JoTAghFPKLuKorRVESMVUoZoKimAgUCJf9+8POhIEZGJlHzmH8fNaaP2affd7z7Nv7znfvffZUFEVRBAAAQKIOpS4AAABofwQNAAAgnaABAACkEzQAAIB0ggYAAJBO0AAAANIJGgAAQDpBAwAASCdoAAAA6QSNJA888EBUVFQ0/lRWVsbAgQPjkksuid/85jetauPiiy+O2trad7fQ3T5r93o7d+4cxxxzTMyYMSO2bt36rn/+6tWro6KiIh544IHGabfddltUVFS847bmzZsXd999d7OvVVRUxG233XZgRbbB5s2b44477ogRI0ZEz549o7q6Oo4++uj4xCc+EUuWLDno9bwTzW2bDD/5yU/i5JNPjm7dukXfvn3j4osvjtdeey31MwB2H9v29fMf//EfJa1z/Pjxcdxxx6W01fA3yNNPP53S3u5trl69Oq1N3nsqS11AezNnzpz4sz/7s9iyZUssXbo0vvrVr8aSJUtixYoV0b17932+95ZbbolrrrnmIFUa0bVr1/jpT38aERFvvvlmPPzww3H77bfHr371q/jmN7950OpocNlll8UZZ5zxjt83b968eO655+Laa6/d67Vly5bFwIEDE6prvZ07d8bpp58eK1asiM997nMxevToiIh48cUX49FHH42f/exnMW7cuINaU6ktWbIkzjzzzJg0aVJ873vfi9deey1uuOGGmDBhQjz99NPRuXPnUpcItBPLli1r8vvMmTNj8eLFjeNdgw984AMHsyx4TxI0kh133HHxoQ99KCIiTjnllNi5c2fMnDkzvvvd78ZFF13U7Hv+93//N7p16xZHH310ai1btmyJrl27tvh6hw4d4qSTTmr8/cwzz4zVq1fHt771rbjrrrtiwIABB9TugRo4cGB6KNh9+Q6WpUuXxhNPPBH3339/XHLJJY3T6+rq4qqrropdu3Yd9JpK7XOf+1wMHTo0HnnkkaisfLvbGTJkSIwdOzbuv//+uOKKK0pcIdBe7Nnv9+vXb6/xrjkNYzGQx61T77KGjm3NmjUR8fYtSz169IgVK1bE6aefHtXV1TFhwoTG1/a8dWrr1q3xhS98IYYMGRKdOnWKAQMGxGc/+9n43e9+12S+2traOOuss+I73/lOnHDCCdGlS5f44he/2OZ699XuunXr4vLLL4+BAwdGp06dYsiQIfHFL34xduzY0aTN+vr6+MQnPhHV1dXRq1ev+OQnPxnr1q3b67NbunVq3rx5cfLJJ0ePHj2iR48eMXLkyLjvvvsi4u1Lzz/4wQ9izZo1TS6JN9j91qlnnnkmKioqGt+7ux/+8IdRUVER3//+9xunvfjii3HhhRfGEUccEZ07d45jjz027r333v2uwzfeeCMiIo488shmX+/Q4Y+H3fr16+PKK6+MD3zgA9GjR4844ogj4tRTT42f/exnTd7TcDvTnXfeGXfccUfU1tZG165dY/z48bFq1arYvn173HjjjVFTUxO9evWKKVOm7HVbUsO2nD9/fgwfPjy6dOkSf/InfxJf//rX97tMbVkfv/nNb+Kpp56KqVOnNoaMiIgxY8bE0KFDY/78+a36fIAsDbctLV26NMaMGRPdunWLSy+9NCJavuW2trY2Lr744ibTWjsOHqinn346zj///MY+v7a2Ni644ILGMXpPb775ZlxyySXRp0+f6N69e5x99tnx0ksv7TXfT37yk5gwYUL07NkzunXrFmPHjo1Fixal1Ay7c0XjXfbrX/86It4+o9LgD3/4Q0yePDkuv/zyuPHGG1vskIqiiL/8y7+MRYsWxRe+8IX46Ec/Gs8++2zMmDEjli1bFsuWLWtyy8kvfvGL+OUvfxk333xzDBkyZL+3arW23ubaXbduXYwePTo6dOgQt956axx99NGxbNmy+NKXvhSrV6+OOXPmRMTbVz8+9rGPRX19fXz1q1+NoUOHxg9+8IP45Cc/2ap6br311pg5c2Z8/OMfj+uuuy569eoVzz33XGMn+0//9E/xmc98Jv77v/97v3+wjhgxIk444YSYM2dOfOpTn2ry2gMPPBBHHHFETJw4MSIiVq5cGWPGjImjjjoq/v7v/z769+8fCxYsiKuvvjpef/31mDFjRouf86EPfSiqqqrimmuuiVtvvTVOPfXUFkPHhg0bIiJixowZ0b9//9i0aVPMnz8/xo8fH4sWLYrx48c3mf/ee++N4cOHx7333hu/+93v4rrrrouzzz47PvzhD0dVVVXcf//9sWbNmrj++uvjsssuaxKcIiKWL18e1157bdx2223Rv3//eOihh+Kaa66JP/zhD3H99de3uExtWR/PPfdcREQMHz58r9eGDx8eP//5z1t8L8C75be//W381V/9VXz+85+Pr3zlK01OArVGa8fBtli9enUcc8wxcf7550efPn3it7/9bcyePTtGjRoVK1eujL59+zaZ/1Of+lScdtppMW/evFi7dm3cfPPNMX78+Hj22Wejd+/eERExd+7cmDZtWvzFX/xF/Nu//VtUVVXFP//zP0ddXV0sWLCg8eQnpChIMWfOnCIiiieffLLYvn17sXHjxuKxxx4r+vXrV1RXVxfr1q0riqIopk+fXkREcf/99+/VxvTp04vBgwc3/v6jH/2oiIjia1/7WpP5vvnNbxYRUfzLv/xL47TBgwcXHTt2LF544YVW1Tt9+vSie/fuxfbt24vt27cX69evL+65556ioqKiGDVq1H7bvfzyy4sePXoUa9asaTL97/7u74qIKJ5//vmiKIpi9uzZRUQU3/ve95rM9+lPf7qIiGLOnDmN02bMmFHsvku+9NJLRceOHYuLLrpon8syadKkJuttdxFRzJgxo/H3r3/960VENFmeDRs2FJ07dy6uu+66xml1dXXFwIEDi9///vdN2rvqqquKLl26FBs2bNhnTffdd1/Ro0ePIiKKiCiOPPLIYtq0acXSpUv3+b4dO3YU27dvLyZMmFBMmTKlcfrLL79cREQxYsSIYufOnY3T77777iIiismTJzdp59prry0iokn9gwcPLioqKorly5c3mfe0004revbsWWzevLnJZ+2+bdqyPh566KEiIoply5bt9dpnPvOZolOnTvtYIwBt0zDe7W7cuHFFRBSLFi3aa/49x40GgwcPLqZPn974e2vHwZaMGzeuGDZsWOsXpHh7jNi0aVPRvXv34p577mmc3vA3yO7jRlEUxc9//vMiIoovfelLRVEUxebNm4s+ffoUZ599dpP5du7cWYwYMaIYPXr0Xm2+/PLL76hG2J1bp5KddNJJUVVVFdXV1XHWWWdF//7944c//GG8733vazLfOeecs9+2Gr64tuel2vPO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",
      "text/plain": [
       "<Figure size 1000x500 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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b34T11xzTZx99tnxnve8J2pqauLee++NdevWxbXXXhuXXnppq+AUEbFy5cq4+uqr45ZbbolBgwbFV77ylbjqqqvit7/9bVx77bXt9qkz4wFQRr/85S/jj//4j+PTn/50/OVf/uVBfyHS0XmwM9auXRvHHXdcnHfeeTFgwID45S9/GXPnzo3x48fH6tWr48gjj2y1/sc//vE47bTTYsGCBbF+/fq48cYbY/LkyfHkk09Gv379IiJi/vz5MWPGjPjgBz8Y//zP/xw1NTXx93//99HY2BiLFy9u+fITUhSkmDdvXhERxaOPPlrs2LGj2LJlS7Fo0aJi4MCBRW1tbbFhw4aiKIpi5syZRUQU99577z5tzJw5sxg2bFjLz9///veLiCi++MUvtlrvq1/9ahERxT/8wz+0LBs2bFjRvXv34mc/+1mH6p05c2Zx+OGHFzt27Ch27NhRbNy4sbjrrruKqqqqYvz48Qds97LLLiv69OlTrFu3rtXyv/qrvyoionj66aeLoiiKuXPnFhFRfPvb32613ic+8YkiIop58+a1LJs1a1ax5y757LPPFt27dy8uvPDC/fZl6tSprcZtTxFRzJo1q+XnL33pS0VEtOrPpk2bih49ehTXXHNNy7LGxsZiyJAhxcsvv9yqvSuuuKLo2bNnsWnTpv3WdM899xR9+vQpIqKIiOLoo48uZsyYUSxfvny/r9u5c2exY8eO4tRTTy2mT5/esvy5554rIqIYM2ZMsWvXrpbld955ZxERxbRp01q1c/XVVxcR0ar+YcOGFVVVVcXKlStbrXvaaacVdXV1xbZt21q9157bprPjsafLL7+8cOoBDpXm+W5PkyZNKiKiWLp06T7r7z1vNBs2bFgxc+bMlp87Og+2Z9KkScXIkSM73pHitTli69atxeGHH17cddddLcubP4PsOW8URVH8+7//exERxec+97miKIpi27ZtxYABA4qzzz671Xq7du0qxowZU0yYMGGfNp977rmDqhH25H6GZO9973ujpqYmamtr46yzzopBgwbF9773vXjb297War1zzjnngG01/+Ha3pdqP/zhD8fhhx++z2XO0aNHx4gRIzpc67Zt26KmpiZqampi4MCBcfXVV8eZZ565z5WBttpdtGhRnHzyyVFfXx87d+5s+XfmmWdGRLQ8WWnZsmVRW1sb06ZNa/X6Cy644ID1LVmyJHbt2hWXX355h/t0IBdeeGH06NGj1ROVHnjggXj11Vdb/p7ilVdeiaVLl8b06dOjd+/erfo3ZcqUeOWVV+LRRx/d7/tccskl8fzzz8eCBQviyiuvjKFDh8b8+fNj0qRJcfvtt7da98tf/nKceOKJ0bNnz6iuro6amppYunRp/OQnP9mn3SlTprT61u3444+PiIipU6e2Wq95+X//93+3Wj5y5MgYM2ZMq2UXXHBBbN68OX784x+32ZeM8QAom/79+8cpp5zyul/f0XmwM7Zu3RrXXXddvOMd74jq6uqorq6OPn36xLZt29qcI/b+W9CJEyfGsGHDYtmyZRER8cgjj8SmTZti5syZrWrevXt3nHHGGfHYY4/Ftm3bOl03NHPrVLL7778/jj/++Kiuro63ve1tbd4y07t376irqztgWy+++GJUV1e3uo0p4rX7RwcNGtTytwDN2rs9pz29evWK5cuXR0REjx49YtiwYW3W1Va7v/rVr+LBBx+MmpqaNtt+4YUXWvqwd8iKiBg0aNAB69u4cWNEROofiA8YMCCmTZsW999/f8yePTu6d+8e9913X0yYMCFGjhzZUvPOnTtjzpw5MWfOnDbbae7f/vTt2zfOP//8OP/88yMi4umnn44PfOADccMNN8QnPvGJ6NevX9xxxx1xzTXXxJ/+6Z/G7Nmz48gjj4zu3bvHTTfd1OYkMmDAgFY/H3bYYftdvvejitsa9+Zle+9PzbLGA6BMDnbO3FtH58HOuOCCC2Lp0qVx0003xfjx46Ouri6qqqpiypQpsX379n3Wb+8c33x+/9WvfhUREeeee26777lp06bXdes1tEXQSHb88ce3PHWqPR39PwSOOOKI2LlzZ2zcuLFV2CiKIjZs2BDjx49/Xe0269at2wFrba/dI488MkaPHh2f//zn23xNfX19RLzWh//4j//Y5/dt/TH43pr7/Pzzz8fQoUMPuH5HXXzxxfH1r389lixZEsccc0w89thjMXfu3Jbf9+/fP7p37x4XXXRRu1dThg8fftDvO3LkyDjvvPPizjvvjDVr1sSECRNi/vz5MXny5FbvHxGxZcuWg26/I9oa9+ZlRxxxRJuveaPGA6ArtTdn9ujRI1599dV9lu/9ZUxH58HX6+WXX45FixbFrFmz4vrrr29Z/uqrr7b8fd/e2jvHv+Md72ipOSJizpw57T6Fq60vB+H1EjRK7NRTT40vfvGLMX/+/PizP/uzluX/8i//Etu2bevSP9g666yz4qGHHopjjz02+vfv3+56J598cnzta1+L73znO61un1qwYMEB3+P000+P7t27x9y5c+N973tfu+v16NGjzW929tfu4MGDY968eXHMMcdEz549W646RLx2xenkk0+O//qv/4rRo0e3XB3oqBdffDFqa2vbfN1Pf/rTiPjdBNT8nyXu6cknn4wVK1akhqtmTz/9dDzxxBOtbp9asGBB1NbWxoknntjmazo7HgBvJg0NDfHkk0+2WvaDH/wgtm7d2mpZR+fB16uqqiqKothnjvinf/qn2LVrV5uv+cpXvtLq1uxHHnkk1q1bF5deemlERJx00knRr1+/WL16dVxxxRXpNcPeBI0SO+2006KxsTGuu+662Lx5c5x00kktT50aN25cXHTRRV1W26233hpLliyJiRMnxpVXXhnHHXdcvPLKK7F27dp46KGH4stf/nIMGTIkZsyYEX/zN38TM2bMiM9//vPxe7/3e/HQQw/F4sWLD/geDQ0N8Rd/8Rcxe/bs2L59e5x//vnRt2/fWL16dbzwwgstj9kdNWpUfPOb34y5c+fGu971rgNeqenevXvMmDEj7rjjjqirq4sPfehD0bdv31br3HXXXfEHf/AH8f73vz8++clPRkNDQ2zZsiV+/vOfx4MPPrjPf/y0p2XLlsVVV10VF154YUycODGOOOKI+PWvfx0PPPBAfP/7348ZM2a03A521llnxezZs2PWrFkxadKk+NnPfha33nprDB8+PO3xiHuqr6+PadOmxS233BJHH310zJ8/P5YsWRK33Xbbfp8f35nxiHjtccmPPfZYRET84he/iIiIb3zjGxHx2nbuyJU1gEPhoosuiptuuiluvvnmmDRpUqxevTr+9m//dp95oqPz4P5s3ry55Vy4p4EDB8akSZPiD//wD+P222+PI488MhoaGuLhhx+Oe+65p+UJUnt7/PHH49JLL40Pf/jDsX79+rjhhhti8ODB8alPfSoiIvr06RNz5syJmTNnxqZNm+Lcc8+No446KjZu3BhPPPFEbNy4cZ8r7NApXf3X6JWi+ekMjz322H7Xa+vpF3v+bu+nJ23fvr247rrrimHDhhU1NTXF0UcfXXzyk58sXnrppVbrDRs2rJg6dWqH691fHR1t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",
      "text/plain": [
       "<Figure size 1000x500 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAxoAAAGICAYAAADGcZYzAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8g+/7EAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAibklEQVR4nO3de5RW5Xk34HtgRkBmBsFDcAAZaoo1iqKJJsGkgEZHAU2JJvFQIRpTm8Sltppo6gEisVnG1mqoJe2KYl0EVw4NSTQmlBJPXySrulIUNQmmCsGORBQjh6phYH9/2JkwMAOD7w2zfb2utfiDPXs/7/08+/Dwe/eeTU1RFEUAAAAk6tPbBQAAANVH0AAAANIJGgAAQDpBAwAASCdoAAAA6QQNAAAgnaABAACkEzQAAIB0ggYAAJBO0Ehyxx13RE1NTcef2traGD58eJx33nnxP//zPz1q4xOf+EQ0Nzfv3kK3+qyt6+3Xr18ccsghMWPGjHjttdd2++evWLEiampq4o477uhYNnPmzKipqdnltubPnx8333xzlz+rqamJmTNnvrkiK7Bx48a44YYb4sgjj4zGxsZoaGiIgw8+OD72sY/FAw88sMfr2RVd7ZtKrFu3Lq6//vqYMGFCDB06NOrr62PMmDFxww037JFjDXh72Xpu29Gf+++/v1frnDBhQhx++OEpbbX/G+TRRx9NaW/rNlesWJHWJm8/tb1dQLWZO3du/Mmf/Em8+uqr8eCDD8aXv/zleOCBB2LZsmUxcODAHW57zTXXxCWXXLKHKo0YMGBA/OQnP4mIiJdffjnuuuuuuO666+KXv/xlfPOb39xjdbS74IIL4uSTT97l7ebPnx9PPPFEXHrppdv9bMmSJTF8+PCE6npu8+bNcdJJJ8WyZcvic5/7XBx77LEREfH000/H3XffHQ899FCMHz9+j9bUm37zm9/EzTffHOeee2789V//ddTX18dDDz0UM2fOjEWLFsWiRYveVMAE6MqSJUs6/X3WrFlx3333dcx37d71rnftybLgbUnQSHb44YfHe97znoiImDhxYmzevDlmzZoV3/ve9+Kcc87pcpv//d//jb333jsOPvjg1FpeffXVGDBgQLc/79OnT7zvfe/r+Pspp5wSK1asiG9961tx0003xbBhw95Uu2/W8OHD00PB1v3bUx588MF4+OGH4/bbb4/zzjuvY3lLS0tcdNFFsWXLlj1eU28aNWpUrFixolPQPv7442PgwIHxuc99Ln7605/GBz7wgV6sEKgm2173999//+3mu660z8VAHo9O7WbtF7aVK1dGxBuPLNXX18eyZcvipJNOioaGhjjhhBM6frbto1OvvfZafOELX4hRo0bFXnvtFcOGDYvPfvaz8bvf/a7Tes3NzTFlypT47ne/G0cddVT0798/vvjFL1Zc747aXb16dVx44YUxfPjw2GuvvWLUqFHxxS9+Mdra2jq12draGh/72MeioaEhBg0aFB//+Mdj9erV2312d49OzZ8/P97//vdHfX191NfXx9ixY+O2226LiDduPf/whz+MlStXdrol3m7rR6cee+yxqKmp6dh2az/60Y+ipqYmfvCDH3Qse/rpp+Pss8+OAw44IPr16xeHHnpo3HrrrTsdw5deeikiIg488MAuf96nzx9OuzVr1sRnPvOZeNe73hX19fVxwAEHxPHHHx8PPfRQp23aH2e68cYb44Ybbojm5uYYMGBATJgwIZYvXx6bNm2KK6+8MpqammLQoEExderUeOGFFzq10b4vFyxYEEcccUT0798//uiP/ii++tWv7rRPlYzHwIEDu7yb136nZ9WqVT36fIAs7Y8tPfjggzFu3LjYe++94/zzz4+I7h+5bW5ujk984hOdlvV0HnyzHn300TjzzDM7rvnNzc1x1llndczR23r55ZfjvPPOiyFDhsTAgQPj1FNPjWeeeWa79f7jP/4jTjjhhGhsbIy99947jjvuuFi8eHFKzbA1dzR2s1//+tcR8cY3Ku1+//vfx2mnnRYXXnhhXHnlld1ekIqiiD/7sz+LxYsXxxe+8IX44Ac/GI8//njMmDEjlixZEkuWLIl+/fp1rP/zn/88fvGLX8TVV18do0aN2umjWj2tt6t2V69eHccee2z06dMnrr322jj44INjyZIl8aUvfSlWrFgRc+fOjYg37n586EMfitbW1vjyl78co0ePjh/+8Ifx8Y9/vEf1XHvttTFr1qz4yEc+EpdddlkMGjQonnjiiY6L7D/90z/FX/zFX8R///d/x4IFC3bY1pFHHhlHHXVUzJ07Nz75yU92+tkdd9wRBxxwQEyaNCkiIp566qkYN25cHHTQQfH3f//3MXTo0Fi4cGFcfPHF8eKLL8aMGTO6/Zz3vOc9UVdXF5dccklce+21cfzxx3cbOtauXRsRETNmzIihQ4fGhg0bYsGCBTFhwoRYvHhxTJgwodP6t956axxxxBFx6623xu9+97u47LLL4tRTT433vve9UVdXF7fffnusXLkyLr/88rjgggs6BaeIiKVLl8all14aM2fOjKFDh8Y3vvGNuOSSS+L3v/99XH755d32qZLx6E77YwyHHXbYLm8LUKnnn38+/vzP/zw+//nPx9/+7d92+hKoJ3o6D1ZixYoVccghh8SZZ54ZQ4YMieeffz7mzJkTxxxzTDz11FOx3377dVr/k5/8ZJx44okxf/78WLVqVVx99dUxYcKEePzxx2OfffaJiIh58+bFtGnT4sMf/nD867/+a9TV1cU///M/R0tLSyxcuLDjy09IUZBi7ty5RUQUP/vZz4pNmzYV69evL+65555i//33LxoaGorVq1cXRVEU06dPLyKiuP3227drY/r06cXIkSM7/v7jH/+4iIjiK1/5Sqf1vvnNbxYRUfzLv/xLx7KRI0cWffv2LX71q1/1qN7p06cXAwcOLDZt2lRs2rSpWLNmTXHLLbcUNTU1xTHHHLPTdi+88MKivr6+WLlyZaflf/d3f1dERPHkk08WRVEUc+bMKSKi+P73v99pvU996lNFRBRz587tWDZjxoxi60PymWeeKfr27Vucc845O+zL5MmTO43b1iKimDFjRsffv/rVrxYR0ak/a9euLfr161dcdtllHctaWlqK4cOHF6+88kqn9i666KKif//+xdq1a3dY02233VbU19cXEVFERHHggQcW06ZNKx588MEdbtfW1lZs2rSpOOGEE4qpU6d2LH/22WeLiCiOPPLIYvPmzR3Lb7755iIiitNOO61TO5deemkREZ3qHzlyZFFTU1MsXbq007onnnhi0djYWGzcuLHTZ229byodj2099thjxYABAzr1EWB3aJ/vtjZ+/PgiIorFixdvt/6280a7kSNHFtOnT+/4e0/nwe6MHz++OOyww3rekeKNOWLDhg3FwIEDi1tuuaVjefu/Qba9pv70pz8tIqL40pe+VBRFUWzcuLEYMmRIceqpp3Zab/PmzcWRRx5ZHHvssdu1+eyzz+5SjbA1j04le9/73hd1dXXR0NAQU6ZMiaFDh8aPfvSjeMc73tFpvdNPP32nbbV/47vtrdqPfvSjMXDgwO1ucx5xxBExevToHte6cePGqKuri7q6uth///3j0ksvjVNOOWW7OwNdtXvPPffExIkTo6mpKdra2jr+nHLKKRERHW9Wuu+++6KhoSFOO+20TtufffbZO61v0aJFsXnz5vjsZz/b4z7tzDnnnBP9+vXr9Ealu+66K15//fWO36d47bXXYvHixTF16tTYe++9O/Vv0qRJ8dprr8XPfvazHX7O+eefH88991zMnz8/Lr744hgxYkTMmzcvxo8fHzfeeGOndb/2ta/F0UcfHf3794/a2tqoq6uLxYsXxy9+8Yvt2p00aVKnb90OPfTQiIiYPHlyp/Xal//mN7/ptPywww6LI488stOys88+O9atWxc///nPu+xLxnhsbcWKFTFlypQYMWJEfP3rX+/xdgCZBg8eHMcff/yb3r6n82AlNmzYEFdccUW8853vjNra2qitrY36+vrYuHFjl3PEtr8LOm7cuBg5cmTcd999ERHx8MMPx9q1a2P69Omdat6yZUucfPLJ8cgjj8TGjRsrrhvaeXQq2Z133hmHHnpo1NbWxjve8Y4uH5nZe++9o7GxcadtvfTSS1FbW9vpMaaIN54fHTp0aMfvArTr7vGc7gwYMCAefPDBiIjo169fjBw5ssu6umr3t7/9bdx9991RV1fXZdsvvvhiRx+2DVkREUOHDt1pfWvWrImISP0F8SFDhsRpp50Wd955Z8yaNSv69u0bd9xxRxx77LEdj/C89NJL0dbWFrNnz47Zs2d32U57/3Zk0KBBcdZZZ8VZZ50VERFPPvlkfOhDH4qrrroqPvWpT8U+++wTN910U1x22WXxl3/5lzFr1qzYb7/9om/fvnHNNdd0OYkMGTKk09/32muvHS7f9vWxXY17+7Jtj6d2WeMR8cbv/kycODFqa2tj8eLF29UNsKfs6py5rZ7Og5U4++yzY/HixXHNNdfEMcccE42NjVFTUxOTJk2KV199dbv1u7vGt1/ff/vb30ZExBlnnNHtZ65du/ZNPXoNXRE0kh166KEdb53qTk9f5bnvvvtGW1tbrFmzplPYKIoiVq9eHcccc8ybarddnz59dlprd+3ut99+ccQRR8T111/f5TZNTU0R8UYf/vM//3O7n3f1y+Dbau/zc889FyNGjNjp+j113nnnxbe//e1YtGhRHHTQQfHII4/EnDlzOn4+ePDg6Nu3b5x77rnd3k0ZNWrULn/uYYcdFmeeeWbcfPPNsXz58jj22GNj3rx5MWHChE6fHxGxfv36XW6/J7oa9/Zl++67b5fbZI3HypUrY8KECVEURdx///17/LXDAFvrbs7s169fvP7669st3/bLmJ7Og2/WK6+8Evfcc0/MmDEjrrzyyo7lr7/+esfv922ru2v8O9/5zo6aIyJmz57d7Vu4uvpyEN4sQaPETjjhhPjKV74S8+bNi7/6q7/qWP5v//ZvsXHjxl79ha0pU6bEvffeGwcffHAMHjy42/UmTpwY3/rWt+IHP/hBp8en5s+fv9PPOOmkk6Jv374xZ86ceP/739/tev369evym50dtTts2LCYO3duHHTQQdG/f/+Ouw4Rb9xxmjhxYvzXf/1XHHHEER13B3rqpZdeioaGhi63++UvfxkRf5iA2v+zxK09/vjjsWTJktRw1e7JJ5+Mxx57rNPjU/Pnz4+GhoY4+uiju9ym0vGIeOMRrgkTJsTmzZvj/vvvj5EjR77pPgDsTs3NzfH44493WvaTn/wkNmzY0GlZT+fBN6umpiaKothujvj6178emzdv7nKbb3zjG50ezX744Ydj5cqVccEFF0RExHHHHRf77LNPPPXUU3HRRRel1wzbEjRK7MQTT4yWlpa44oorYt26dXHcccd1vHXqqKOOinPPPbfXarvuuuti0aJFMW7cuLj44ovjkEMOiddeey1WrFgR9957b3zta1+L4cOHx7Rp0+If/uEfYtq0aXH99dfHH//xH8e9994bCxcu3OlnNDc3x9/8zd/ErFmz4tVXX42zzjorBg0aFE899VS8+OKLHa/ZHTNmTHz3u9+NOXPmxLvf/e6d3qnp27dvTJs2LW666aZobGyMj3zkIzFo0KBO69xyyy3xgQ98ID74wQ/Gpz/96Whubo7169fHr3/967j77ru3+4+ftnbffffFJZdcEuecc06MGzcu9t1333jhhRfirrvuih//+Mcxbdq0jm/zp0yZErNmzYoZM2bE+PHj41e/+lVcd911MWrUqLTXI26tqakpTjvttJg5c2YceOCBMW/evFi0aFHccMMNO3x/fCXj8cILL8TEiRPj+eefj9tuuy1eeOGFTq/e3R3/fwrAm3XuuefGNddcE9dee22MHz8+nnrqqfjHf/zH7eaJns6DO7Ju3br4zne+s93y/fffP8aPHx9/+qd/GjfeeGPst99+0dzcHA888EDcdtttHW+Q2tajjz4aF1xwQXz0ox+NVatWxVVXXRXDhg2Lz3zmMxERUV9fH7Nnz47p06fH2rVr44wzzogDDjgg1qxZE4899lisWbNmuzvsUJFe/mX0qtH+doZHHnlkh+t19faLrX+27duTXn311eKKK64oRo4cWdTV1RUHHnhg8elPf7p4+eWXO603cuTIYvLkyT2ud0d19LTdNWvWFBdffHExatSooq6urhgyZEjx7ne/u7jqqquKDRs2dKz33HPPFaeffnpRX19fNDQ0FKeffnrx8MMP7/StU+3uvPPO4phjjin69+9f1NfXF0cddVSn7dauXVucccYZxT777FPU1NR0aiO6eXvI8uXLO94ItWjRoi779+yzzxbnn39+MWzYsKKurq7Yf//9i3HjxnW8vaM7q1atKq6++uriuOOOK4YOHVrU1tYWDQ0NxXvf+95i9uzZRVtbW8e6r7/+enH55ZcXw4YNK/r3718cffTRxfe+973tjoX2N0HdeOONnT7rvvvuKyKi+Pa3v91peVfHY/u+/M53vlMcdthhxV577VU0NzcXN91003b93nbfVDIe7TV296er/QOQpbu3TnX3xqfXX3+9+PznP1+MGDGiGDBgQDF+/Phi6dKl2711qih6Pg92pf3NV139GT9+fFEUf5g/Bw8eXDQ0NBQnn3xy8cQTT2xXS/s1/9///d+Lc889t9hnn32KAQMGFJMmTSqefvrp7T77gQceKCZPnlwMGTKkqKurK4YNG1ZMnjy501zirVNkqCmKothToQboPc3NzXH44YfHPffc09ulAABvA15vCwAApBM0AACAdB6dAgAA0rmjAQAApBM0AACAdIIGAACQrkf/Yd+WLVuitbU1GhoaoqamZnfXBMD/KYoi1q9fH01NTdGnj++GtmZuAugdPZ2behQ0WltbY8SIEWnFAbBrVq1a5X9Q34a5CaB37Wxu6lHQaGhoiIiID8SkqI26igpasHxZRdtHREwdPabiNjKVqU8ZtUSUa4yz+pShbPspQ5n6VKZaslTap7bYFP8v7u24DvMH1To3lek6XqZayqYaj5kyccx0rwzn9roNW2Lk0St2Ojf1KGi035KujbqoransYt7YUPmt/0pryFamPmXUElGuMc7qU4ay7acMZepTmWrJUnGf/u8F5B4N2l61zk1luo6XqZayqcZj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",
      "text/plain": [
       "<Figure size 1000x500 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAxoAAAGICAYAAADGcZYzAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8g+/7EAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAh1UlEQVR4nO3de5xXdZ0/8PfAjFyHm2I4gAza4hLKxRILawFNR0FpUSvRBDXLLj7UHrpp6wUT29bcNY11bS+K68Pw0WWj1CyWJZJa6bH6aBGUDF3FsJFCUbksGAPn94e/mRiYgYF5w3z9+nw+HvwxZ875nPf5nMvn+/qeM4eKoiiKAAAASNSpowsAAADKj6ABAACkEzQAAIB0ggYAAJBO0AAAANIJGgAAQDpBAwAASCdoAAAA6QQNAAAgnaCR5N57742Kioqmf5WVlTFo0KC48MIL43e/+12b2rjggguitrZ2/xa6w7p2rLdLly5x1FFHxcyZM2PLli37ff2rVq2KioqKuPfee5um3XjjjVFRUbHXbc2dOzduv/32Fn9XUVERN954474V2Q6bNm2KW265JUaNGhW9evWK6urqOPLII+NjH/tYPProowe8nr3R0r5pr2uvvTbGjBkT/fr1i65du8YRRxwRn/70p+PFF19MWwdARDQb23b372c/+1mH1jlhwoQ4+uijU9pq/AzyxBNPpLS3Y5urVq1Ka5N3nsqOLqDczJkzJ/78z/88Nm/eHIsXL46vfvWr8eijj8by5cujR48eu132+uuvj8svv/wAVRrRrVu3+OlPfxoREa+99lo88MADcdNNN8UzzzwT3/72tw9YHY0uvvjiOPXUU/d6ublz58ZTTz0VV1xxxS6/W7JkSQwaNCihurbbtm1bnHLKKbF8+fL4q7/6qxg7dmxERDz77LPx0EMPxc9//vMYP378Aa2po73++usxbdq0GD58eFRXV8eKFSvi5ptvjgcffDCefvrpOPjggzu6RKBMLFmypNnPs2bNikWLFjWNd43e8573HMiy4B1J0Eh29NFHx/ve976IiJg4cWJs27YtZs2aFT/4wQ/ivPPOa3GZ//u//4vu3bvHkUcemVrL5s2bo1u3bq3+vlOnTvH+97+/6efTTjstVq1aFd/5znfitttui4EDB+5Tu/tq0KBB6aFgx+07UBYvXhyPPfZY3HPPPXHhhRc2Ta+rq4tLL700tm/ffsBr6mh33nlns58nTJgQQ4cOjUmTJsUPf/jDuOiiizqoMqDc7Hzd79+//y7jXUsax2Igj0en9rPGC1vjIyIXXHBB9OzZM5YvXx6nnHJKVFdXx0knndT0u50fndqyZUt86UtfiqFDh8ZBBx0UAwcOjM9//vPx+uuvN5uvtrY2Tj/99Pj+978fY8aMia5du8aXv/zldte7u3bXrFkTl1xySQwaNCgOOuigGDp0aHz5y1+OhoaGZm3W19fHxz72saiuro7evXvHxz/+8VizZs0u627t0am5c+fGBz7wgejZs2f07NkzRo8eHXfffXdEvPWB9Uc/+lG8+OKLzW6JN9rx0aknn3wyKioqmpbd0Y9//OOoqKiIBx98sGnas88+G+eee24ceuih0aVLlxg+fPguH5hb8uqrr0ZExGGHHdbi7zt1+tNpt3bt2vjc5z4X73nPe6Jnz55x6KGHxoknnhg///nPmy3T+DjTrbfeGrfcckvU1tZGt27dYsKECbFy5crYunVrXHPNNVFTUxO9e/eOqVOnxh/+8IdmbTTuy3nz5sXIkSObHmH6xje+scdtak9/tKZ///4REVFZ6fsO4MBqfGxp8eLFMW7cuOjevXvTFx6tPXJbW1sbF1xwQbNpbR0H99UTTzwR55xzTtM1v7a2NqZNm9bqY6evvfZaXHjhhdGvX7/o0aNHnHHGGfH888/vMt9//ud/xkknnRS9evWK7t27xwknnBALFy5MqRl2ZITfz5577rmI+NOHqoiIP/7xjzFlypS45JJL4pprrmn1glQURfzlX/5lLFy4ML70pS/Fhz70oVi2bFnMnDkzlixZEkuWLIkuXbo0zf+rX/0qfv3rX8d1110XQ4cO3eOjWm2tt6V216xZE2PHjo1OnTrFDTfcEEceeWQsWbIkbr755li1alXMmTMnIt66+/HhD3846uvr46tf/WoMGzYsfvSjH8XHP/7xNtVzww03xKxZs+LMM8+MK6+8Mnr37h1PPfVU00X2H//xH+PTn/50/O///m/Mmzdvt22NGjUqxowZE3PmzIlPfvKTzX537733xqGHHhqTJk2KiIgVK1bEuHHj4vDDD4+///u/jwEDBsT8+fPjsssui1deeSVmzpzZ6nre9773RVVVVVx++eVxww03xIknnthq6Fi3bl1ERMycOTMGDBgQGzdujHnz5sWECRNi4cKFMWHChGbz33nnnTFy5Mi488474/XXX48rr7wyzjjjjDj++OOjqqoq7rnnnnjxxRfjqquuiosvvrhZcIqIWLp0aVxxxRVx4403xoABA+Jb3/pWXH755fHHP/4xrrrqqla3qT39saOGhobYunVrPPPMM3HFFVfEsGHD4swzz2zTsgCZXn755fjEJz4RX/ziF+Nv/uZvmn0J1BZtHQfbY9WqVXHUUUfFOeecE/369YuXX3457rrrrjjuuONixYoVccghhzSb/5Of/GScfPLJMXfu3Fi9enVcd911MWHChFi2bFn06dMnIiLuv//+mD59enzkIx+Jf/u3f4uqqqr4p3/6p6irq4v58+c3ffkJKQpSzJkzp4iI4pe//GWxdevWYsOGDcXDDz9c9O/fv6iuri7WrFlTFEVRzJgxo4iI4p577tmljRkzZhRDhgxp+vknP/lJERHF1772tWbzffvb3y4iovjnf/7npmlDhgwpOnfuXPzmN79pU70zZswoevToUWzdurXYunVrsXbt2uKOO+4oKioqiuOOO26P7V5yySVFz549ixdffLHZ9L/7u78rIqJ4+umni6IoirvuuquIiOKHP/xhs/k+9alPFRFRzJkzp2nazJkzix0Pyeeff77o3Llzcd555+12WyZPntys33YUEcXMmTObfv7GN75RRESz7Vm3bl3RpUuX4sorr2yaVldXVwwaNKh44403mrV36aWXFl27di3WrVu325ruvvvuomfPnkVEFBFRHHbYYcX06dOLxYsX73a5hoaGYuvWrcVJJ51UTJ06tWn6Cy+8UEREMWrUqGLbtm1N02+//fYiIoopU6Y0a+eKK64oIqJZ/UOGDCkqKiqKpUuXNpv35JNPLnr16lVs2rSp2bp23Dft7Y+iKIqXX365qT8iojj++OOL3/3ud3tcDqA9Gse7HY0fP76IiGLhwoW7zL/zuNFoyJAhxYwZM5p+bus42Jrx48cXI0aMaPuGFG+NERs3bix69OhR3HHHHU3TGz+D7DhuFEVR/Nd//VcREcXNN99cFEVRbNq0qejXr19xxhlnNJtv27ZtxahRo4qxY8fu0uYLL7ywVzXCjjw6lez9739/VFVVRXV1dZx++ukxYMCA+PGPfxzvete7ms131lln7bGtxj9c2/lW7Uc/+tHo0aPHLrc5R44cGcOGDWtzrZs2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Dona2tp49NFH4+677256g9TOnnjiibj44ovjox/9aKxevTquvfbaGDhwYHzuc5+LiIiePXvG7NmzY8aMGbFu3bo4++yz49BDD421a9fGk08+GWvXrt3lDju0S0f/NXq5aHw7w+OPP77b+Vp6+8WOv9v57UmbN28urr766mLIkCFFVVVVcdhhhxWf/exni9dee63ZfEOGDCkmT57c5np3V0db2127dm1x2WWXFUOHDi2qqqqKfv36Fe9973uLa6+9tti4cWPTfC+99FJx1llnFT179iyqq6uLs846q3jsscf2+NapRvfdd19x3HHHFV27di169uxZjBkzptly69atK84+++yiT58+RUVFRbM2opW3h6xcubLp7UcLFixocfteeOGF4qKLLioGDhxYVFVVFf379y/GjRvX9PaO1qxevbq47rrrihNOOKEYMGBAUVlZWVRXVxfHH398MXv27KKhoaFp3jfffLO46qqrioEDBxZdu3Ytjj322OIHP/jBLsdC45ugbr311mbrWrRoURERxXe/+91m01s6Hhv35fe+971ixIgRxUEHHVTU1tYWt9122y7bvfO+aU9/rFmzpvjEJz5RHHnkkUX37t2Lgw46qDjiiCOKz3zmM8Vvf/vb3S4L0F6tvXWqtTc+vfnmm8UXv/jFYvDgwUW3bt2K8ePHF0uXLt3lrVNF0fZxsCWNb75q6d/48eOLovjT+Nm3b9+iurq6OPXUU4unnnpql1oar/n/8R//UZx//vlFnz59im7duhWTJk0qnn322V3W/eijjxaTJ08u+vXrV1RVVRUDBw4sJk+e3Gws8dYpMlQURVEc4GwDdIDa2to4+uij4+GHH+7oUgCAdwCvtwUAANIJGgAAQDqPTgEAAOnc0QAAANIJGgAAQDpBAwAASNem/7Bv+/btUV9fH9XV1VFRUbG/awLg/yuKIjZs2BA1NTXRqZPvhnZkbALoGG0dm9oUNOrr62Pw4MFpxQGwd1avXr3H/2X4ncbYBNCx9jQ2tSloVFdXR0TEB2NSVEZVuwqat3J5u5aPiJg67Jh2twH7IuP4LTWldD6VWv+WQt80xNb4RTzSdB3mT8p1bMo6DzLqKaVaSk05HjOlxDHTulI4t9dv3B5Djl21x7GpTUGj8ZZ0ZVRFZUX7Lua9qtt/67+9NcC+yjh+S00pnU+l1r8l0Tf//wXkHg3aVbmOTVnnQUY9pVRLqSnHY6aUOGZaV0rn9p7GpvI7MgEAgA4naAAAAOkEDQAAIJ2gAQAApBM0AACAdIIGAACQTtAAAADSCRoAAEA6QQMAAEgnaAAAAOkEDQAAIJ2gAQAApBM0AACAdIIGAACQrnJvZp63cnn0qm5fNqmrGd2u5UvR/Pql7W4jq18yaslSjvu6lPZTOfZvFvvpncXYtP/oF6A93NEAAADSCRoAAEA6QQMAAEgnaAAAAOkEDQAAIJ2gAQAApBM0AACAdIIGAACQTtAAAADSCRoAAEA6QQMAAEgnaAAAAOkEDQAAIJ2gAQAApBM0AACAdIIGAACQrnJvZp467JiorKjaX7VQZubXL01pp65mdEo7paQctyljf2f1S9axx9uDsall5XhOZtRTSrVkKaVaSk0pnQeltJ/aW0tDsTUint/jfO5oAAAA6QQNAAAgnaABAACkEzQAAIB0ggYAAJBO0AAAANIJGgAAQDpBAwAASCdoAAAA6QQNAAAgnaABAACkEzQAAIB0ggYAAJBO0AAAANIJGgAAQDpBAwAASCdoAAAA6So7uoByUFczut1tzK9f2u42InJqyZK1TdBRSul8onXzVi6PXtXl871ZKR135Tg2lSP76e3hnbifyufKDAAAlAxBAwAASCdoAAAA6QQNAAAgnaABAACkEzQAAIB0ggYAAJBO0AAAANIJGgAAQDpBAwAASCdoAAAA6QQNAAAgnaABAACkEzQAAIB0ggYAAJBO0AAAANIJGgAAQLrKA73C+fVLD/QqW1VXM7qjS0iX1b/l2DflppTOpQjHDB1n6rBjorKiqqPLKLlzMkPWeV2OfVNKXH/fHt6J+8kdDQAAIJ2gAQAApBM0AACAdIIGAACQTtAAAADSCRoAAEA6QQMAAEgnaAAAAOkEDQAAIJ2gAQAApBM0AACAdIIGAACQTtAAAADSCRoAAEA6QQMAAEgnaAAAAOkqD/QK62pGH+hVtmp+/dKOLqFJKfVLlnLcpqxjJqNvyrF/YV/MW7k8elW373uzUjonS+k6k6WUaoGOUo7n9p64owEAAKQTNAAAgHSCBgAAkE7QAAAA0gkaAABAOkEDAABIJ2gAAADpBA0AACCdoAEAAKQTNAAAgHSCBgAAkE7QAAAA0gkaAABAOkEDAABIJ2gAAADpBA0AACCdoAEAAKSrPNArnF+/9ECvslV1NaNT2imlbcqSsU1Z/VtKynGbypH99M4yddgxUVlR1dFlpI0FpTQ2ldq5VErjban1TbkptfMpQynVcqC4owEAAKQTNAAAgHSCBgAAkE7QAAAA0gkaAABAOkEDAABIJ2gAAADpBA0AACCdoAEAAKQTNAAAgHSCBgAAkE7QAAAA0gkaAABAOkEDAABIJ2gAAADpBA0AACCdoAEAAKSr7OgCykFdzeiOLqHJ/PqlKe2U2zaV0vaUmqxjJkOp7SfHHnvDvm5dKY1NpXTNK6V+4e3j7TQ2uaMBAACkEzQAAIB0ggYAAJBO0AAAANIJGgAAQDpBAwAASCdoAAAA6QQNAAAgnaABAACkEzQAAIB0ggYAAJBO0AAAANIJGgAAQDpBAwAASCdoAAAA6QQNAAAgXUVRFMWeZlq/fn307t07JsRHorKi6kDUtVvz65d2dAnp6mpGd3QJ0C6ldF6W0vnU3n5Zv2F79B32fLzxxhvRq1evnKLKhLFp/8s6l0qpb0rp+sD+l3HsOWZ21VBsjZ/FD/c4NrmjAQAApBM0AACAdIIGAACQTtAAAADSCRoAAEA6QQMAAEgnaAAAAOkEDQAAIJ2gAQAApBM0AACAdIIGAACQTtAAAADSCRoAAEA6QQMAAEgnaAAAAOkEDQAAIJ2gAQAApKvs6AL2RV3N6I4uoezNr1/a7jbsp9Zl9G+WrP1kf9NR5q1cHr2qO/57M+dA6/TN24Ox6Z2jvft6/Ybt0XfYnufr+CszAABQdgQNAAAgnaABAACkEzQAAIB0ggYAAJBO0AAAANIJGgAAQDpBAwAASCdoAAAA6QQNAAAgnaABAACkEzQAAIB0ggYAAJBO0AAAANIJGgAAQDpBAwAASFfZ0QVQmupqRnd0CexB1j6aX780pZ1yPGYy+qa9/dJQbI2I59tdRzmbOuyYqKyo6ugyOABK4ZwsZ6XUN8am1pXCedDWsckdDQAAIJ2gAQAApBM0AACAdIIGAACQTtAAAADSCRoAAEA6QQMAAEgnaAAAAOkEDQAAIJ2gAQAApBM0AACAdIIGAACQTtAAAADSCRoAAEA6QQMAAEgnaAAAAOkEDQAAIF3l3sw8b+Xy6FXdvmxSVzO6XcuXq/n1S1Pa0b9vDxn7qRyPmaxtylJKfUPrMsamDFnHSzme21nKcZtKScaxl7WPynFfl9oYdyB0/JUZAAAoO4IGAACQTtAAAADSCRoAAEA6QQMAAEgnaAAAAOkEDQAAIJ2gAQAApBM0AACAdIIGAACQTtAAAADSCRoAAEA6QQMAAEgnaAAAAOkEDQAAIJ2gAQAApBM0AACAdJUHeoXz65e2u426mtHtbqPUlOM2Zck4ZrKU0n4qpVqylOM2tff4Xb9he/QdllMLbw/leB6Uo1L6PJM1TmbUU0q1ZCmlzyERpbGf2jo2uaMBAACkEzQAAIB0ggYAAJBO0AAAANIJGgAAQDpBAwAASCdoAAAA6QQNAAAgnaABAACkEzQAAIB0ggYAAJBO0AAAANIJGgAAQDpBAwAASCdoAAAA6QQNAAAgXeWBXmFdzegDvcr9bn790na3UY79Ukqy+jdjX0eU5/4ux/Mga38D7E+lNMaV2nU8Qzlu04HijgYAAJBO0AAAANIJGgAAQDpBAwAASCdoAAAA6QQNAAAgnaABAACkEzQAAIB0ggYAAJBO0AAAANIJGgAAQDpBAwAASCdoAAAA6QQNAAAgnaABAACkEzQAAIB0ggYAAJCucm9mnjrsmKisqNpftVBC5tcvbXcbdTWj291GVjsZ2xORt03lSN/QUYxNpS/rGpzB2LT/22H/KoXPaA3F1oh4fo/zuaMBAACkEzQAAIB0ggYAAJBO0AAAANIJGgAAQDpBAwAASCdoAAAA6QQNAAAgnaABAACkEzQAAIB0ggYAAJBO0AAAANIJGgAAQDpBAwAASCdoAAAA6QQNAAAgnaABAACkq+zoAvbF/PqlHV1CM3U1ozu6hJKUtZ8y+rcc91Ep9W+5KoW+aSi2RsTzHV0GbVBqY1MpKYVzqVEpXTtLqV94+3g7HTfuaAAAAOkEDQAAIJ2gAQAApBM0AACAdIIGAACQTtAAAADSCRoAAEA6QQMAAEgnaAAAAOkEDQAAIJ2gAQAApBM0AACAdIIGAACQTtAAAADSCRoAAEA6QQMAAEhXuTczz1u5PHpVd3w2qasZ3dEllL2MPp5fv7TdbZSarG3K6F/nAZQW5+Tbg/3UuowxTv+yo45PDQAAQNkRNAAAgHSCBgAAkE7QAAAA0gkaAABAOkEDAABIJ2gAAADpBA0AACCdoAEAAKQTNAAAgHSCBgAAkE7QAAAA0gkaAABAOkEDAABIJ2gAAADpBA0AACCdoAEAAKSrPNArrKsZ3e425tcvbXcb5Sqjf7OUUi3QUdp7vVq/YXv0HZZTS7mat3J59Kru+O/Nsq55WWNcKY23xoP9y+ciSlXHX5kBAICyI2gAAADpBA0AACCdoAEAAKQTNAAAgHSCBgAAkE7QAAAA0gkaAABAOkEDAABIJ2gAAADpBA0AACCdoAEAAKQTNAAAgHSCBgAAkE7QAAAA0gkaAABAOkEDAABIV7k3M08ddkxUVlS1a4Xz65e2a/lMdTWjO7qEkpWxn0qpf7OOu3Lcpiyl1DelpL390lBsjYjnU2opVxljUykppXOplGqJMDbtb+XYN6W0Te9E7mgAAADpBA0AACCdoAEAAKQTNAAAgHSCBgAAkE7QAAAA0gkaAABAOkEDAABIJ2gAAADpBA0AACCdoAEAAKQTNAAAgHSCBgAAkE7QAAAA0gkaAABAOkEDAABIV3mgV1hXM/pAr5J9kLGf5tcvbXcbWUrtuCulvilHWf1bascNLZu3cnn0qu74780cL/tfKfVxxnWmlLYnorTGplLrG/ZNx1+ZAQCAsiNoAAAA6QQNAAAgnaABAACkEzQAAIB0ggYAAJBO0AAAANIJGgAAQDpBAwAASCdoAAAA6QQNAAAgnaABAACkEzQAAIB0ggYAAJBO0AAAANIJGgAAQLrKtsxUFEVERDTE1ohiv9ZDGVm/YXtHl9Ckodja0SU0U0p9k6WU+jirf0thmxrirRoar8P8SWOfrN9YGudTKRwvHDgZ15lSO2ZKaWwqtb6hubaOTRVFG0avl156KQYPHpxTGQB7bfXq1TFo0KCOLqOkGJsAOtaexqY2BY3t27dHfX19VFdXR0VFRWqBALSuKIrYsGFD1NTURKdOnnbdkbEJoGO0dWxqU9AAAADYG74eAwAA0gkaAABAOkEDAABIJ2gAAADpBA0AACCdoAEAAKQTNAAAgHT/D5Gs/sP9OgZIAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 1000x500 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAxoAAAGICAYAAADGcZYzAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8g+/7EAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAh7klEQVR4nO3de5RV5Xk/8GdgRhCYGcFLcESBGPCuYxqpwaSgRkeNl5rGeIsQjKlJdIld5mKiiIEYl5daDbXYriI2QWxsG5JojCyLF7IqWYlLUdQkmBqsdmJEUQaJKAP794e/mTIwAwPzwGyPn89a88fss897nv3uvd93vmfvc6aqKIoiAAAAEvXp7QIAAIDKI2gAAADpBA0AACCdoAEAAKQTNAAAgHSCBgAAkE7QAAAA0gkaAABAOkEDAABIJ2gkueOOO6Kqqqr9p7q6OoYNGxaTJk2K//3f/+1WG5/73OdixIgR27fQDV5rw3r79esX++23X0ydOjXWrFmz3V9/2bJlUVVVFXfccUf7squvvjqqqqq2uq25c+fGzTff3OljVVVVcfXVV29bkT2wevXquO666+Kwww6Lurq6qK2tjX333Tc+85nPxCOPPLLD69kane2bTG+99VaMHj06qqqq4sYbb9wurwG8f204t23u5+GHH+7VOsePHx8HH3xwSlttf4M89thjKe1t2OayZcvS2uT9p7q3C6g0s2fPjv333z/eeuutWLhwYVx77bXxyCOPxJIlS2LgwIGbfe6UKVNi8uTJO6jSiJ133jkefPDBiIh4/fXX46677opp06bFb37zm/jBD36ww+poc8EFF8QJJ5yw1c+bO3duPP3003HppZdu8tiiRYti2LBhCdV137p16+L444+PJUuWxFe/+tUYM2ZMREQ899xzcc8998TPf/7zGDdu3A6tqUymTJkSq1ev7u0ygAq1aNGiDr9Pnz49Hnroofb5rs2BBx64I8uC9yVBI9nBBx8cH/nIRyIi4uijj45169bF9OnT40c/+lGce+65nT7nT3/6UwwYMCD23Xff1Freeuut2Hnnnbt8vE+fPnHkkUe2/37iiSfGsmXL4u67746bbrop9tprr21qd1sNGzYsPRRsuH07ysKFC+PRRx+N22+/PSZNmtS+vKmpKS6++OJYv379Dq+pLH75y1/GjBkz4s4774wzzjijt8sBKtDG4/7uu+++yXzXmba5GMjj1qntrG1ge+GFFyLi3VuWBg0aFEuWLInjjz8+amtr49hjj21/bONbp9asWRPf+MY3YuTIkbHTTjvFXnvtFRdddFG88cYbHdYbMWJEnHzyyfHDH/4wDj/88Ojfv39861vf6nG9m2v35ZdfjgsvvDCGDRsWO+20U4wcOTK+9a1vRWtra4c2m5ub4zOf+UzU1tZGfX19nHnmmfHyyy9v8tpd3To1d+7c+OhHPxqDBg2KQYMGRWNjY8yaNSsi3r30/NOf/jReeOGFDpfE22x469STTz4ZVVVV7c/d0M9+9rOoqqqKn/zkJ+3LnnvuuTjnnHNijz32iH79+sUBBxwQt9566xb78LXXXouIiD333LPTx/v0+b/Tbvny5fHlL385DjzwwBg0aFDsscceccwxx8TPf/7zDs9pu53phhtuiOuuuy5GjBgRO++8c4wfPz6WLl0aa9eujcsvvzwaGhqivr4+Tj/99HjllVc6tNG2L+fNmxeHHnpo9O/fPz74wQ/Gd7/73S1uU0/6o80777wT559/flx00UXtYRygN7TdtrRw4cIYO3ZsDBgwIM4///yI6PqW2xEjRsTnPve5Dsu6Ow9uq8ceeyzOOuus9jF/xIgRcfbZZ7fP0Rt7/fXXY9KkSTFkyJAYOHBgnHLKKfH8889vst5//ud/xrHHHht1dXUxYMCAOOqoo2LBggUpNcOGXNHYzn73u99FxLvvqLR555134tRTT40LL7wwLr/88i4HpKIo4i//8i9jwYIF8Y1vfCM+/vGPx1NPPRVTp06NRYsWxaJFi6Jfv37t6z/++OPx61//Oq688soYOXLkFm/V6m69nbX78ssvx5gxY6JPnz5x1VVXxb777huLFi2Kb3/727Fs2bKYPXt2RLx79eMTn/hENDc3x7XXXhujR4+On/70p3HmmWd2q56rrroqpk+fHp/61Kfisssui/r6+nj66afbB9l/+Id/iL/+67+O//7v/4558+Zttq3DDjssDj/88Jg9e3Z8/vOf7/DYHXfcEXvssUecdNJJERHx7LPPxtixY2OfffaJv/3bv42hQ4fG/Pnz45JLLolXX301pk6d2uXrfOQjH4mampqYPHlyXHXVVXHMMcd0GTpWrFgRERFTp06NoUOHxptvvhnz5s2L8ePHx4IFC2L8+PEd1r/11lvj0EMPjVtvvTXeeOONuOyyy+KUU06JP//zP4+ampq4/fbb44UXXoivfOUrccEFF3QIThERixcvjksvvTSuvvrqGDp0aNx5550xefLkeOedd+IrX/lKl9vUk/5oM23atFi9enVMnz49li9fvsX1AbanP/zhD/HZz342vva1r8V3vvOdDm8CdUd358GeWLZsWey3335x1llnxZAhQ+IPf/hDzJw5M4444oh49tlnY7fdduuw/uc///k47rjjYu7cufHiiy/GlVdeGePHj4+nnnoqdtlll4iImDNnTkyYMCFOO+20+Jd/+ZeoqamJf/zHf4ympqaYP39++5ufkKIgxezZs4uIKH7xi18Ua9euLVatWlXce++9xe67717U1tYWL7/8clEURTFx4sQiIorbb799kzYmTpxYDB8+vP33+++/v4iI4vrrr++w3g9+8IMiIop/+qd/al82fPjwom/fvsVvf/vbbtU7ceLEYuDAgcXatWuLtWvXFsuXLy9uueWWoqqqqjjiiCO22O6FF15YDBo0qHjhhRc6LL/xxhuLiCieeeaZoiiKYubMmUVEFD/+8Y87rPeFL3yhiIhi9uzZ7cumTp1abHhIPv/880Xfvn2Lc889d7Pb8slPfrJDv20oIoqpU6e2//7d7363iIgO27NixYqiX79+xWWXXda+rKmpqRg2bFixcuXKDu1dfPHFRf/+/YsVK1ZstqZZs2YVgwYNKiKiiIhizz33LCZMmFAsXLhws89rbW0t1q5dWxx77LHF6aef3r7897//fRERxWGHHVasW7euffnNN99cRERx6qmndmjn0ksvLSKiQ/3Dhw8vqqqqisWLF3dY97jjjivq6uqK1atXd3itDfdNT/vjiSeeKGpqaor777+/w2vccMMNm30eQE+1zXcbGjduXBERxYIFCzZZf+N5o83w4cOLiRMntv/e3XmwK+PGjSsOOuig7m9I8e4c8eabbxYDBw4sbrnllvblbX+DbDhvFEVR/Nd//VcREcW3v/3toiiKYvXq1cWQIUOKU045pcN669atKw477LBizJgxm7T5+9//fqtqhA25dSrZkUceGTU1NVFbWxsnn3xyDB06NH72s5/FBz7wgQ7r/dVf/dUW22r74NrGl2rPOOOMGDhw4CaXOQ899NAYPXp0t2tdvXp11NTURE1NTey+++5x6aWXxoknnrjJlYHO2r333nvj6KOPjoaGhmhtbW3/OfHEEyMi2r9Z6aGHHora2to49dRTOzz/nHPO2WJ9DzzwQKxbty4uuuiibm/Tlpx77rnRr1+/Dt+odNddd8Xbb7/d/nmKNWvWxIIFC+L000+PAQMGdNi+k046KdasWRO/+MUvNvs6559/frz00ksxd+7cuOSSS2LvvfeOOXPmxLhx4+KGG27osO5tt90WH/7wh6N///5RXV0dNTU1sWDBgvj1r3+9SbsnnXRSh3fdDjjggIiI+OQnP9lhvbbl//M//9Nh+UEHHRSHHXZYh2XnnHNOtLS0xOOPP97ptvS0P1pbW+P888+PM888M5qamrpcD2BHGjx4cBxzzDHb/PzuzoM98eabb8bXv/71+NCHPhTV1dVRXV0dgwYNitWrV3c6R2z8WdCxY8fG8OHD46GHHoqIiEcffTRWrFgREydO7FDz+vXr44QTTohf/epXvqyDVG6dSva9730vDjjggKiuro4PfOADnd4yM2DAgKirq9tiW6+99lpUV1d3uI0p4t37R4cOHdr+WYA2Xd2e05Wdd945Fi5cGBER/fr1i+HDh3daV2ft/vGPf4x77rknampqOm371Vdfbd+GjUNWRMTQoUO3WF/b7TWZHxAfMmRInHrqqfG9730vpk+fHn379o077rgjxowZEwcddFB7za2trTFjxoyYMWNGp+20bd/m1NfXx9lnnx1nn312REQ888wz8YlPfCKuuOKK+MIXvhC77LJL3HTTTXHZZZfFF7/4xZg+fXrstttu0bdv35gyZUqnk8iQIUM6/L7TTjttdvnGX1XcWb+3Ldv4eGrT0/64+eab4/nnn4+77767/bNFLS0t7fW98cYbUVtbG3379u2yDYBsWztnbqy782BPnHPOObFgwYKYMmVKHHHEEVFXVxdVVVVx0kknxVtvvbXJ+l2N8W3j+x//+MeIiPj0pz/d5WuuWLFim269hs4IGskOOOCALX7Qtbv/K2LXXXeN1tbWWL58eYewURRFvPzyy3HEEUdsU7tt+vTp060P5XbW7m677RaHHnpoXHPNNZ0+p6GhISLe3YZf/vKXmzze2YfBN9a2zS+99FLsvffeW1y/uyZNmhT/9m//Fg888EDss88+8atf/SpmzpzZ/vjgwYOjb9++cd5553V5NWXkyJFb/boHHXRQnHXWWXHzzTfH0qVLY8yYMTFnzpwYP358h9ePiFi1atVWt98dnfV727Jdd9210+f0tD+efvrpWLlyZYwaNWqTx6ZMmRJTpkyJJ554IhobG7uxBQA5upoz+/XrF2+//fYmyzd+M6a78+C2WrlyZdx7770xderUuPzyy9uXv/322+2f79tYV2P8hz70ofaaIyJmzJjR5bdwdfbmIGwrQaPEjj322Lj++utjzpw58Td/8zfty//jP/4jVq9e3asf2Dr55JPjvvvui3333TcGDx7c5XpHH3103H333fGTn/ykw+1Tc+fO3eJrHH/88dG3b9+YOXNmfPSjH+1yvX79+nX6zs7m2t1rr71i9uzZsc8++0T//v3brzpEvHvF6eijj44nnngiDj300ParA9312muvRW1tbafP+81vfhMR/zcBtf2zxA099dRTsWjRotRw1eaZZ56JJ598ssPtU3Pnzo3a2tr48Ic/3Olzetofl19+eaff1HL22WfHF7/4xTjzzDPbJ0GA3jZixIh46qmnOix78MEH48033+ywrLvz4LaqqqqKoig2mSP++Z//OdatW9fpc+68884Ot2Y/+uij8cILL8QFF1wQERFHHXVU7LLLLvHss8/GxRdfnF4zbEzQKLHjjjsumpqa4utf/3q0tLTEUUcd1f6tU4cffnicd955vVbbtGnT4oEHHoixY8fGJZdcEvvtt1+sWbMmli1bFvfdd1/cdtttMWzYsJgwYUL83d/9XUyYMCGuueaaGDVqVNx3330xf/78Lb7GiBEj4pvf/GZMnz493nrrrTj77LOjvr4+nn322Xj11Vfbv2b3kEMOiR/+8Icxc+bM+LM/+7MtXqnp27dvTJgwIW666aaoq6uLT33qU1FfX99hnVtuuSU+9rGPxcc//vH40pe+FCNGjIhVq1bF7373u7jnnns2+cdPG3rooYdi8uTJce6558bYsWNj1113jVdeeSXuuuuuuP/++2PChAntt4OdfPLJMX369Jg6dWqMGzcufvvb38a0adNi5MiRaV+PuKGGhoY49dRT4+qrr44999wz5syZEw888EBcd911m/3++J70x/777x/7779/h2Vt/2l233333eSbtQB603nnnRdTpkyJq666KsaNGxfPPvts/P3f//0m80R358HNaWlpiX//93/fZPnuu+8e48aNi7/4i7+IG264IXbbbbcYMWJEPPLIIzFr1qz2b5Da2GOPPRYX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",
      "text/plain": [
       "<Figure size 1000x500 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Inspect some prior predictive samples from the original prior\n",
    "val_sample_idx = 1\n",
    "print(f\"Inspecting prior predictive samples for validation sample {val_sample_idx} from the original prior\")\n",
    "for idx in range(5):\n",
    "    fig, ax = plt.subplots(1, 2, figsize=(10, 5))\n",
    "    first_samples_pps = prior_predictions_original[idx, val_sample_idx]\n",
    "    first_sample_pps_adj = vec2adj(first_samples_pps.reshape(1, -1), n=n)[0]\n",
    "    ax[0].imshow(first_sample_pps_adj)\n",
    "    ax[1].imshow(y_val_adj[val_sample_idx])\n",
    "    ax[0].set_title(f'Prior Predictive Sample {idx}')\n",
    "    ax[1].set_title('True Label')\n",
    "    # remove all xticks and yticks\n",
    "    for a in ax:\n",
    "        a.set_xticks([])\n",
    "        a.set_yticks([])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " ** Note how the altered prior shifts some probability mass over higher density outputs. **\n",
      "Fraction of edge densities in [0.00, 0.25] o.g.: 28.5 | alter: 20.8 | abs change: 7.7\n",
      "Fraction of edge densities in [0.25, 0.50] o.g.: 42.2 | alter: 35.0 | abs change: 7.1\n",
      "Fraction of edge densities in [0.50, 0.75] o.g.: 22.5 | alter: 29.3 | abs change: 6.7\n",
      "Fraction of edge densities in [0.75, 1.00] o.g.: 4.1 | alter: 11.1 | abs change: 7.0\n"
     ]
    }
   ],
   "source": [
    "\"\"\"\n",
    "    Edge Density\n",
    "\"\"\"\n",
    "edge_densities_original = jnp.mean(edge_density_vmap(prior_predictions_original), axis=1)\n",
    "edge_densities_altered = jnp.mean(edge_density_vmap(prior_predictions_altered), axis=1)\n",
    "#edge_densities_posterior = jnp.mean(edge_density_vmap(posterior_predictions), axis=1)\n",
    "\n",
    "edge_density_observed_data = np.mean(edge_density(y_val))\n",
    "\n",
    "def freq_interval(metric, low, high):\n",
    "    return np.mean((metric > low) & (metric < high))\n",
    "print(f\" ** Note how the altered prior shifts some probability mass over higher density outputs. **\")\n",
    "intervals = np.linspace(0, 1, 5)\n",
    "for low, high in zip(intervals[:-1], intervals[1:]):\n",
    "    print(f'Fraction of edge densities in [{low:.2f}, {high:.2f}] ', end='')\n",
    "    print(f'o.g.: {freq_interval(edge_densities_original, low, high)*100:.1f} | ', end='')\n",
    "    print(f'alter: {freq_interval(edge_densities_altered, low, high)*100:.1f} | ', end='')\n",
    "    print(f'abs change: {np.abs(freq_interval(edge_densities_original, low, high) - freq_interval(edge_densities_altered, low, high))*100:.1f}')\n",
    "    #print(f'posterior: {freq_interval(edge_densities_posterior, low, high):.3f}')\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 300x200 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "def predictive_check_combined_hist(edge_densities_original, edge_densities_altered, edge_density_observed_data, edge_density_posterior=None):\n",
    "    fig, axes = plt.subplots(1, 1, figsize=(3, 2))\n",
    "    alpha = 0.5\n",
    "    # edge densities\n",
    "    colors = sns.color_palette('bright', 4)\n",
    "    axes.hist(np.array(edge_densities_original).flatten(), color=colors[0], alpha=alpha, density=True, bins=100, label='original prior')\n",
    "    axes.hist(np.array(edge_densities_altered).flatten(), color=colors[1], alpha=alpha, density=True, bins=100, label='altered prior')\n",
    "    \n",
    "    # Twin the x-axis for posterior if it exists\n",
    "    if edge_density_posterior is not None:\n",
    "        axes2 = axes.twinx()\n",
    "        axes2.hist(np.array(edge_density_posterior).flatten(), color=colors[2], alpha=alpha, density=True, bins=100, label='posterior')\n",
    "        # remove yticks and labels for the twin x-axis\n",
    "        axes2.set_yticks([])\n",
    "\n",
    "    # place an 'x' at x=.25 on the x axis\n",
    "    axes.plot(edge_density_observed_data, 0, 'x', color=colors[3], label='labels', markersize=8, markeredgewidth=2, clip_on=False)\n",
    "\n",
    "    # remove yticks and labels for the main axis\n",
    "    axes.set_yticks([])\n",
    "    axes.set_ylabel('')\n",
    "    \n",
    "    # remove frame on all sides for both axes\n",
    "    for ax in [axes, axes2] if edge_density_posterior is not None else [axes]:\n",
    "        for side in ['top', 'right', 'bottom', 'left']:\n",
    "            ax.spines[side].set_visible(False)\n",
    "\n",
    "    # set xticks manually to be 0, 0.25, 0.5, 0.75, 1 without leading 0\n",
    "    axes.set_xticks([0, 0.25, 0.5, 0.75, 1])\n",
    "    axes.set_xticklabels(['0', '.25', '.5', '.75', '1'])\n",
    "    #axes.set_xlabel('Average Edge Density')\n",
    "    # set title\n",
    "    axes.set_title('Mean Edge Density')\n",
    "\n",
    "    # Collect handles and labels from both axes\n",
    "    handles, labels = axes.get_legend_handles_labels()\n",
    "    if edge_density_posterior is not None:\n",
    "        handles2, labels2 = axes2.get_legend_handles_labels()\n",
    "        handles.extend(handles2)\n",
    "        labels.extend(labels2)\n",
    "\n",
    "    # Order legend manually\n",
    "    ordered_labels = ['original prior', 'altered prior', 'posterior', 'labels']\n",
    "    ordered_handles = [h for l, h in sorted(zip(labels, handles), key=lambda pair: ordered_labels.index(pair[0]))]\n",
    "\n",
    "    # Set the legend with the ordered handles and labels\n",
    "    axes.legend(ordered_handles, ordered_labels, loc='upper right', frameon=False, fontsize=8)\n",
    "    \n",
    "\n",
    "    # Adjust subplot parameters\n",
    "    plt.subplots_adjust(wspace=0, hspace=0, bottom=0.0, top=1, left=0.0, right=1.0)\n",
    "    return\n",
    "\n",
    "predictive_check_combined_hist(edge_densities_original, edge_densities_altered, edge_density_observed_data)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 52,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 300x200 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "\n",
    "def predictive_check_combined_hist(edge_densities_original, edge_densities_altered, edge_density_observed_data, edge_density_posterior=None):\n",
    "    fig, axes = plt.subplots(1, 1, figsize=(3, 2))\n",
    "    alpha = 0.5\n",
    "    # edge densities\n",
    "    colors = sns.color_palette('bright', 4)\n",
    "    axes.hist(np.array(edge_densities_original).flatten(), color=colors[0], alpha=alpha, density=True, bins=100, label='original prior')\n",
    "    axes.hist(np.array(edge_densities_altered).flatten(), color=colors[1], alpha=alpha, density=True, bins=100, label='altered prior')\n",
    "    \n",
    "    # Twin the x-axis for posterior if it exists\n",
    "    if edge_density_posterior is not None:\n",
    "        axes2 = axes.twinx()\n",
    "        axes2.hist(np.array(edge_density_posterior).flatten(), color=colors[2], alpha=alpha, density=True, bins=100, label='posterior')\n",
    "        # remove yticks and labels for the twin x-axis\n",
    "        axes2.set_yticks([])\n",
    "\n",
    "    # place an 'x' at x=.25 on the x axis\n",
    "    axes.plot(edge_density_observed_data, 0, 'x', color=colors[3], label='labels', markersize=8, markeredgewidth=2, clip_on=False)\n",
    "\n",
    "    # remove yticks and labels for the main axis\n",
    "    axes.set_yticks([])\n",
    "    axes.set_ylabel('')\n",
    "    \n",
    "    # remove frame on all sides for both axes\n",
    "    for ax in [axes, axes2] if edge_density_posterior is not None else [axes]:\n",
    "        for side in ['top', 'right', 'bottom', 'left']:\n",
    "            ax.spines[side].set_visible(False)\n",
    "\n",
    "    # set xticks manually to be 0, 0.25, 0.5, 0.75, 1 without leading 0\n",
    "    axes.set_xticks([0, 0.25, 0.5, 0.75, 1])\n",
    "    axes.set_xticklabels(['0', '.25', '.5', '.75', '1'], fontsize=6)\n",
    "    #axes.set_xlabel('Average Edge Density')\n",
    "    # set title\n",
    "    #axes.set_title('Mean Edge Density')\n",
    "\n",
    "    # Collect handles and labels from both axes\n",
    "    handles, labels = axes.get_legend_handles_labels()\n",
    "    if edge_density_posterior is not None:\n",
    "        handles2, labels2 = axes2.get_legend_handles_labels()\n",
    "        handles.extend(handles2)\n",
    "        labels.extend(labels2)\n",
    "\n",
    "    # Order legend manually\n",
    "    ordered_labels = ['original prior', 'altered prior', 'posterior', 'labels']\n",
    "    ordered_handles = [h for l, h in sorted(zip(labels, handles), key=lambda pair: ordered_labels.index(pair[0]))]\n",
    "\n",
    "    # Set the legend with the ordered handles and labels\n",
    "\n",
    "    if edge_density_posterior is not None:\n",
    "        axes.legend(ordered_handles, ordered_labels, loc='upper right', bbox_to_anchor=(.95, 0.9), frameon=False, fontsize=5)\n",
    "\n",
    "        #axes.legend(ordered_handles, ordered_labels, loc='center left', bbox_to_anchor=(1, 0.5), frameon=False, fontsize=8)\n",
    "        fig.text(0.57, 0.78, 'Mean Edge Density', ha='center', fontsize=7)\n",
    "    else:\n",
    "        # Manually specify the location of the title\n",
    "        axes.legend(ordered_handles, ordered_labels, loc='upper right', frameon=False, fontsize=5)  # Changed line\n",
    "        fig.suptitle('Mean Edge Density', y=0.95, fontsize=8)\n",
    "\n",
    "    # Adjust subplot parameters to remove extra space\n",
    "    #plt.subplots_adjust(left=0.1, right=0.9, top=0.85, bottom=0.15)  # Changed line\n",
    "    plt.subplots_adjust(left=0.1, right=0.9, top=0.8, bottom=0.2)\n",
    "\n",
    "predictive_check_combined_hist(edge_densities_original, edge_densities_altered, edge_density_observed_data)\n"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Posterior Predictive Check"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 53,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "5f532fdd0430464d88576193386d139d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/1500 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "49ecbbc7f2724485b18a70ad209a1c64",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/1500 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "5b96e3ab0d7047d6b19ce37bcdcdf4d7",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/1500 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "57390aed2d52496899df631e2c3e26c8",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/1500 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Time taken for inference using 4 with 500 warmup samples and 1000 samples: 11.214177131652832\n",
      "\n",
      "                mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "         b      6.62      0.92      6.54      5.24      8.09   1581.90      1.00\n",
      "     delta     60.04      7.75     59.38     46.85     72.07   1461.87      1.00\n",
      "     theta      0.17      0.01      0.17      0.15      0.19   1621.35      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "^^********** Finished  **********^^\n",
      "\n",
      "\n"
     ]
    }
   ],
   "source": [
    "# Run inference using the altered prior and inspect the posterior predictive\n",
    "\n",
    "altered_prior_model_args['y'] = y_val\n",
    "import time\n",
    "kernel = NUTS(dpg_bnn.model, forward_mode_differentiation=True)\n",
    "mcmc = MCMC(kernel,\n",
    "            num_warmup=experiment_settings['num_warmup_samples'], num_samples=experiment_settings['num_posterior_samples'],\n",
    "            progress_bar=True,\n",
    "            num_chains=experiment_settings['num_chains'], chain_method='parallel')\n",
    "start_time = time.time()\n",
    "mcmc.run(rng_key_, **altered_prior_model_args)\n",
    "end_time = time.time()\n",
    "print(f\"Time taken for inference using {experiment_settings['num_chains']} with {experiment_settings['num_warmup_samples']} warmup samples and {experiment_settings['num_posterior_samples']} samples: {end_time - start_time}\")\n",
    "mcmc.print_summary()\n",
    "print(f\"^^********** Finished  **********^^\\n\\n\")\n",
    "samples = mcmc.get_samples()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "metadata": {},
   "outputs": [],
   "source": [
    "posterior_model_args = altered_prior_model_args.copy() # nothing changes here, but now we use the posterior samples\n",
    "predictive_obj = Predictive(dpg_bnn.model, posterior_samples=samples)\n",
    "posterior_predictions = predictive_obj(rng_key=rng_key_, **posterior_model_args)['obs']\n",
    "edge_densities_posterior = jnp.mean(edge_density_vmap(posterior_predictions), axis=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 55,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 300x200 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "predictive_check_combined_hist(edge_densities_original, edge_densities_altered, edge_density_observed_data, edge_densities_posterior)\n",
    "plt.savefig(FIGURES_PATH + 'predictive_check_histogram', dpi=300, bbox_inches='tight', pad_inches=0.01)\n",
    "# MANUALLY CROPPED EXTRA WHITE SPACE IN PREVIEW (TOOLS > Select manually >> CROP)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 56,
   "metadata": {},
   "outputs": [],
   "source": [
    "sample_idx = 3\n",
    "logits = \\\n",
    "    dpg_bnn.forward_pass_vmap()( #compute_edge_logits_vmap(\n",
    "        samples['theta'], \n",
    "        samples['delta'],\n",
    "        samples['b'], \n",
    "        posterior_model_args['x'], \n",
    "        posterior_model_args['w_init'],\n",
    "        posterior_model_args['lam_init'],\n",
    "        posterior_model_args['depth'],\n",
    "        posterior_model_args['S'])\n",
    "probs = jax.nn.sigmoid(logits)\n",
    "probs = jax.nn.sigmoid(logits)\n",
    "mean_prob, stdv_prob = np.array(probs.mean(axis=0)), np.array(probs.std(axis=0))\n",
    "mean_prob_adj, stdv_prob_adj, y_adj = vec2adj(mean_prob, n), vec2adj(stdv_prob, n), vec2adj(y_val, n)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 65,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 1000x112.5 with 4 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "fig = plt.figure(figsize=(10, 1.125))\n",
    "gs = GridSpec(1, 4, width_ratios=[1, 1, 1, 2], figure=fig) #, wspace=0.001, hspace=0.001)\n",
    "\n",
    "# Label, Mean, Std Deviation plots\n",
    "label_ax = fig.add_subplot(gs[0, 0])\n",
    "mean_ax = fig.add_subplot(gs[0, 1])\n",
    "stdv_ax = fig.add_subplot(gs[0, 2])\n",
    "error_ax = fig.add_subplot(gs[0, 3])\n",
    "\n",
    "# Display images for label, mean, and std deviation\n",
    "label_ax.imshow(y_adj[sample_idx], cmap=\"gray\", vmin=0, vmax=1)\n",
    "mean_ax.imshow(mean_prob_adj[sample_idx], cmap=\"gray\", vmin=0, vmax=1)\n",
    "stdv_norm = stdv_prob / np.max(stdv_prob, axis=1, keepdims=True)\n",
    "stdv_norm_adj = vec2adj(stdv_norm[sample_idx], n)\n",
    "expected_error = np.abs((mean_prob - np.array(y_val)))\n",
    "stdv_ax.imshow(stdv_norm_adj[sample_idx], cmap=\"gray\", vmin=0, vmax=1)\n",
    "\n",
    "# Scatter plot for error vs std deviation\n",
    "error_ax.scatter(stdv_norm[sample_idx].flatten(), expected_error[sample_idx].flatten(), color=\"r\", s=1)\n",
    "\n",
    "# Linear regression fit\n",
    "reg = LinearRegression().fit(stdv_norm[sample_idx].flatten().reshape(-1, 1), expected_error[sample_idx].flatten().reshape(-1, 1))\n",
    "error_ax.plot(stdv_norm[sample_idx].flatten(), reg.predict(stdv_norm[sample_idx].flatten().reshape(-1, 1)), color=\"k\")\n",
    "ccs = [jnp.corrcoef(stdv_prob[i].flatten(), expected_error[i].flatten())[0, 1].item() for i in range(len(y_val))]\n",
    "error_ax.text(0.02, 0.5, r\"$\\rho = $\" + f\"{ccs[sample_idx]:.2f}\", transform=error_ax.transAxes, fontsize=11)\n",
    "\n",
    "# Customizing the subplots\n",
    "rhs_axes = [label_ax, mean_ax, stdv_ax, error_ax]\n",
    "titles = ['label', 'pred. mean', 'pred. stdv']\n",
    "\n",
    "for ax, title in zip(rhs_axes[:-1], titles):\n",
    "    #ax.set_title(title, fontsize=10, pad=0)\n",
    "    ax.set_xlabel(title, fontsize=10, labelpad=2)\n",
    "\n",
    "for ax in rhs_axes:\n",
    "    ax.set_xticks([])\n",
    "    ax.set_yticks([])\n",
    "    ax.set_xticklabels([])\n",
    "    ax.set_yticklabels([])\n",
    "    for side in [\"top\", \"right\", \"bottom\", \"left\"]:\n",
    "        ax.spines[side].set_visible(False)\n",
    "\n",
    "# Customizing the scatter plot\n",
    "error_ax.tick_params(axis='x', which='major', pad=0, length=0, width=0.5)\n",
    "error_ax.set_xticks([0, .25, .75, 1])\n",
    "error_ax.set_xticklabels([r'$0$', r'$.25$', r'$.75$', r'$1$'], fontsize=8)\n",
    "error_ax.set_yticks([0, .25, .5, .75, 1])\n",
    "error_ax.set_yticklabels([r'$0$', r'', r'$\\frac{1}{2}$', r'', r'$1$'], fontsize=8)\n",
    "error_ax.tick_params(axis='y', which='major', pad=0, length=0, width=0.5)\n",
    "error_ax.yaxis.set_ticks_position('right')\n",
    "error_ax.set_xlabel(r'pred. stdv', fontsize=10, labelpad=-8)\n",
    "error_ax.set_ylabel(r'$|a_i - \\mathbb{E}_{\\boldsymbol{\\Theta}|\\mathcal{T}}[\\tilde{a}_i\\mid e, \\mathcal{T}]|$', fontsize=8, labelpad=0)\n",
    "error_ax.grid(True, which=\"both\", linestyle='--', linewidth=0.25, color='k', alpha=0.5)\n",
    "error_ax.set_xlim(0, 1.01)\n",
    "error_ax.set_ylim(0, 1)\n",
    "\n",
    "# Adjusting subplot spaces manually\n",
    "label_pos = label_ax.get_position()\n",
    "mean_pos = mean_ax.get_position()\n",
    "stdv_pos = stdv_ax.get_position()\n",
    "error_pos = error_ax.get_position()\n",
    "\n",
    "# Adjusting positions to make them closer\n",
    "label_ax.set_position([label_pos.x0, label_pos.y0, label_pos.width * 1.1, label_pos.height])\n",
    "mean_ax.set_position([label_pos.x0 + label_pos.width * 1.05, mean_pos.y0, mean_pos.width * 1.1, mean_pos.height])\n",
    "stdv_ax.set_position([label_pos.x0 + 2 * label_pos.width * 1.05, stdv_pos.y0, stdv_pos.width * 1.1, stdv_pos.height])\n",
    "error_ax.set_position([label_pos.x0 + 3.25 * label_pos.width * 1.05, error_pos.y0, error_pos.width * 1.1, error_pos.height])\n",
    "plt.savefig(FIGURES_PATH + 'synthetic_label_predMean_predStdv', dpi=350, bbox_inches='tight', pad_inches=0.01)\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 58,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "correlation coefficients. mean:  {0.7804767489433289} std:  {0.1655624637970237} [0.8680791854858398, 0.5535215139389038, 0.9566145539283752, 0.9140228629112244, 0.610145628452301]\n"
     ]
    },
    {
     "data": {
      "image/png": "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mKy7bt069O7dG82aNTP5bFhxoaGheO+99zBgwAD4+vpKOwnJadSoEaZOnYrExERMnz691B1N3n//fTz++OMAgClTppRYEJqIiMjeuI6pQlzHlJTKz8+HWq3G119/jbS0NMyePdtibRsmUTkLR5qEZMl2KrPK0peVJc7KwNp9aeoPdFOTmZROfjJV3xRLteNITN0JMzW5ylQfmHqvTL23lpj8VHl7naiSGDx4MDIzM6HRaEqdyERERFTVMTElsrKtW7darW1nGi0lIiLirAciIiIicghMTImIiIjIITAxJSIiIiKHwGdMichhWGo2sKW2JFXajhLWbLu09u3VjinO+p7LzX42tZybqbZNlZvaetSc5ejMobTvla6FbO1Z85aaxa+0H2rVqlWiLC0tTdE5Tb2HTZs2lS0/deqUbLnSbW5NxWPqGvTx8VHUvqJYrNYykb3siap4G72UtZGamopZs2Zhw4YNWLVqFUaMGFFiF6jyeu2119CvXz+Eh4crOm769OmYP38+1yslIqJKg7fyiSxs1apVyMvLM6uu0r9qzaXX6/Hxxx+blZRaKwYiIiKlmJgSKXTjxg307t0bPXv2xNNPP210W+3w4cNISEhA//798cknn+D27dsYMmQIevXqheeffx6FhYXYt28fnnjiCQwaNAjfffcdtm/fjocffhjdunXDunXrAAAJCQkICQnBwIEDkZiYWCKGyMhITJ48GX369MEzzzwj2254eDgyMzNx9+5dDBw4EGFhYXjmmWeQl5dXoi4REZEjYGJKpFDNmjWxY8cO7N+/H40bN8aePXuk73Xt2hVBQUHYtm0bpk2bhgULFmDq1KnYs2cPgoODsWnTJgDAP//8g19++QWjRo3CO++8g927d+OPP/7AV199hcLCQrzxxhtYs2YNNm/ejPT0dNk42rdvj127dqF58+b4+eefjdodPXq0VG/ZsmV4/PHHER0djbZt20rJr1xdIiIie7JaYhqWHoWw9ChrNU9kN+np6Xj66acRFhaGLVu24OrVqybrnjlzBnPnzkV4eDh+/PFHXL9+HUDRVqIqlQq3b99GcnIyHnvsMfTq1Qu3b9/GrVu3cOPGDbRs2RIqlQqdOnWSbbtjx44AgM6dO+PcuXNG7RZ3/vx5hISEAABCQkJKrUtERGRPnPxEpNDatWvx2GOP4aWXXsLLL79cYtaiWq2W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",
      "text/plain": [
       "<Figure size 650.127x225 with 5 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\"\"\"\n",
    "    Combine Edge Density of Prior Predictive and Posterior Predictive with Label, Mean, and Stdv of posterior predictive\n",
    "\"\"\"\n",
    "fig = plt.figure(figsize=(6.50127, 2.25))\n",
    "num_grid_rows, num_grid_cols = 100, 100\n",
    "gs = GridSpec(num_grid_rows, num_grid_cols, figure=fig,  wspace=20, hspace=0.1)\n",
    "end_hist_col = 40\n",
    "\n",
    "\n",
    "\"\"\" Edge Density Histogram \"\"\"\n",
    "# edge densities: first two columns\n",
    "density_ax = fig.add_subplot(gs[:, :end_hist_col])\n",
    "\n",
    "alpha = 0.5\n",
    "colors = sns.color_palette('bright', 4)\n",
    "density_ax.hist(np.array(edge_densities_original).flatten(),\n",
    "                bins=100,\n",
    "                color=colors[0],\n",
    "                alpha=alpha, density=True, label='original prior')\n",
    "density_ax.hist(np.array(edge_densities_altered).flatten(),\n",
    "                bins=100,\n",
    "                color=colors[1],\n",
    "                alpha=alpha, density=True, label='altered prior')\n",
    "# make custom bins for posterior predictive: .2 to .3\n",
    "posterior_bins = np.linspace(.2, .3, 10)\n",
    "density_ax.hist(np.array(edge_densities_posterior).flatten(),\n",
    "                bins=posterior_bins,\n",
    "                color=colors[2],\n",
    "                alpha=alpha, density=True, label='posterior')\n",
    "# place 'x' where the mean of the labels are\n",
    "density_ax.plot(np.mean(edge_density(y_val)), 0, 'x', color=colors[3], label=r'labels', zorder=10) #r'labels $\\mathcal{T}_y$'\n",
    "# remove yticks and labels\n",
    "for ax in [density_ax]: #, density_ax2]:\n",
    "    ax.set_yticks([])\n",
    "    ax.set_ylabel('')\n",
    "    # remove frame on all sides\n",
    "    for side in ['top', 'right', 'bottom', 'left']:\n",
    "        ax.spines[side].set_visible(False)\n",
    "density_ax.set_xticks([0, .25, .5, .75, 1])\n",
    "density_ax.set_xticklabels([r'$0$', r'$.25$', r'$.5$', r'$.75$', r'$1$'], fontsize=8)\n",
    "density_ax.set_title('average edge density', fontsize=10, pad=2)\n",
    "\n",
    "# make a common legend\n",
    "density_ax.legend(loc='upper right', frameon=False, fontsize=6)\n",
    "density_ax.set_ylim([0, 3.8])\n",
    "\n",
    "\"\"\" Label | Posterior Pred. Mean | Posterior Pred. Stdv | Error vs Stdv \"\"\"\n",
    "\n",
    "# label / posterior mean / stdv / error vs stdv scatter plot\n",
    "sample_idx = 3\n",
    "logits = \\\n",
    "    dpg_bnn.forward_pass_vmap()( #compute_edge_logits_vmap(\n",
    "        samples['theta'], \n",
    "        samples['delta'],\n",
    "        samples['b'], \n",
    "        posterior_model_args['x'], \n",
    "        posterior_model_args['w_init'],\n",
    "        posterior_model_args['lam_init'],\n",
    "        posterior_model_args['depth'],\n",
    "        posterior_model_args['S'])\n",
    "probs = jax.nn.sigmoid(logits)\n",
    "probs = jax.nn.sigmoid(logits)\n",
    "mean_prob, stdv_prob = np.array(probs.mean(axis=0)), np.array(probs.std(axis=0))\n",
    "mean_prob_adj, stdv_prob_adj, y_adj = vec2adj(mean_prob, n), vec2adj(stdv_prob, n), vec2adj(y_val, n)\n",
    "\n",
    "# add subplots for label, mean, stdv, error vs stdv in the last 4 columns\n",
    "# label: rows from 0 to 60, cols from 40 to 100\n",
    "end_row = 61\n",
    "end_hist_col += 3\n",
    "width = (100 - end_hist_col)//3\n",
    "label_ax = fig.add_subplot(gs[:end_row, end_hist_col:end_hist_col+width])\n",
    "mean_ax = fig.add_subplot(gs[:end_row, end_hist_col+width:end_hist_col+2*width])\n",
    "stdv_ax = fig.add_subplot(gs[:end_row, end_hist_col+2*width:end_hist_col+3*width])\n",
    "\n",
    "error_ax = fig.add_subplot(gs[end_row:, end_hist_col:])\n",
    "rhs_axes = [label_ax, mean_ax, stdv_ax, error_ax]\n",
    "label_ax.imshow(y_adj[sample_idx], cmap=\"gray\", vmin=0, vmax=1)\n",
    "mean_ax.imshow(mean_prob_adj[sample_idx], cmap=\"gray\", vmin=0, vmax=1)\n",
    "stdv_norm = stdv_prob/np.max(stdv_prob, axis=1, keepdims=True)\n",
    "stdv_norm_adj = vec2adj(stdv_norm[sample_idx], n)\n",
    "expected_error = np.abs((mean_prob - np.array(y_val)))\n",
    "stdv_ax.imshow(stdv_norm_adj[sample_idx], cmap=\"gray\", vmin=0, vmax=1)\n",
    "#axes[3].scatter(expected_error[sample_idx].flatten(), (stdv_prob/stdv_prob.max(axis=0))[sample_idx].flatten(), color=\"k\", s=1)\n",
    "error_ax.scatter(stdv_norm[sample_idx].flatten(),\n",
    "                 expected_error[sample_idx].flatten(), color=\"r\", s=1)\n",
    "# find the correlation coefficient between stdv and expected_error\n",
    "ccs = [jnp.corrcoef(stdv_prob[i].flatten(), expected_error[i].flatten())[0,1].item() for i in range(len(y_val))]\n",
    "print('correlation coefficients. mean: ', {np.mean(ccs)}, 'std: ', {np.std(ccs)}, ccs)\n",
    "\n",
    "\n",
    "# fit a line to expected error abs vs stdv norm\n",
    "from sklearn.linear_model import LinearRegression\n",
    "reg = LinearRegression().fit(stdv_norm[sample_idx].flatten().reshape(-1, 1),\n",
    "                             expected_error[sample_idx].flatten().reshape(-1, 1))\n",
    "error_ax.plot(stdv_norm[sample_idx].flatten(), reg.predict(stdv_norm[sample_idx].flatten().reshape(-1, 1)), color=\"k\")\n",
    "# place text indicating details of the fit line\n",
    "#error_ax.text(0.02, 0.51, r\"$\\rho = $\" + f\"{reg.score(stdv_norm[sample_idx].flatten().reshape(-1, 1), expected_error[sample_idx].flatten().reshape(-1, 1)):.2f}\", transform=error_ax.transAxes, fontsize=11)\n",
    "error_ax.text(0.02, 0.51, r\"$\\rho = $\" + f\"{ccs[sample_idx]:.2f}\", transform=error_ax.transAxes, fontsize=11)\n",
    "\n",
    "for ax in rhs_axes:\n",
    "    ax.set_xticks([])\n",
    "    ax.set_yticks([])\n",
    "    ax.set_xticklabels([])\n",
    "    ax.set_yticklabels([])\n",
    "    # remove the frame\n",
    "    for side in [\"top\", \"right\", \"bottom\", \"left\"]:\n",
    "        ax.spines[side].set_visible(False)\n",
    "\n",
    "# make titles closer to the plots\n",
    "titles = ['label', 'pred. mean', 'pred. stdv']#, 'error vs stdv']\n",
    "for ax, title in zip(rhs_axes[:-1], titles):\n",
    "    ax.set_title(title, fontsize=10, pad=0)\n",
    "\n",
    "# customize scatter plot\n",
    "error_ax.tick_params(axis='x', which='major', pad=0, length=0, width=0.5)\n",
    "error_ax.set_xticks([0, .25, .75, 1])\n",
    "error_ax.set_xticklabels([r'$0$', r'$.25$', r'$.75$', r'$1$'], fontsize=8)\n",
    "error_ax.set_yticks([0, .25, .5, .75, 1])\n",
    "error_ax.set_yticklabels([r'$0$', r'', r'$\\frac{1}{2}$', r'', r'$1$'], fontsize=8)\n",
    "error_ax.tick_params(axis='y', which='major', pad=0, length=0, width=0.5)\n",
    "# move yticks and labels to the right\n",
    "error_ax.yaxis.set_ticks_position('right')\n",
    "error_ax.set_xlabel(r'pred. stdv', fontsize=10, labelpad=-8)\n",
    "#error_ax.set_ylabel(r'$|y_i - \\mathbb{E}_{\\Theta|\\mathcal{T}}[\\tilde{y}_i]|$', fontsize=10, labelpad=2) #, labelpad=10, rotation=270,)\n",
    "error_ax.set_ylabel(r'$|a_i - \\mathbb{E}_{\\boldsymbol{\\Theta}|\\mathcal{T}}[\\tilde{a}_i;e]|$', fontsize=9, labelpad=2) #, labelpad=10, rotation=270,)\n",
    "error_ax.grid(True, which=\"both\", linestyle='--', linewidth=0.25, color='k', alpha=0.5)\n",
    "\n",
    "# manually set the space between the subplots\n",
    "delta = 0.01\n",
    "error_ax.set_xlim(0, 1+delta)\n",
    "error_ax.set_ylim(0-delta, 1+delta)\n",
    "space = 0.01\n",
    "plt.subplots_adjust(wspace=space, hspace=0, bottom=0.0, top=1, left=0.0, right=1.0)\n",
    "#plt.savefig(FIGURES_PATH + 'predictive_check', dpi=1000, bbox_inches='tight', pad_inches=0.01)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# How useful is the stdv in predicting errors?\n",
    "errors_idxs = np.where(y_val[sample_idx] != (mean_prob[sample_idx] >= 0.5))[0]\n",
    "for k in range(1, 21):\n",
    "    # compute percentage of the k largest stdv values that are errors\n",
    "    k_largest_stdv_idxs = np.argsort(stdv_prob[sample_idx].flatten())[-k:]\n",
    "    #k_largest_stdv_idxs_2d = [[idx % n, idx // n] for idx in k_largest_stdv_idxs]\n",
    "    # how many of the k largest stdv values are errors?\n",
    "    num_errors = 0\n",
    "    for idx in k_largest_stdv_idxs:\n",
    "        if idx in errors_idxs:\n",
    "            num_errors += 1\n",
    "    print(f\"Percentage of the {k} largest stdv values that are errors: {(num_errors / len(k_largest_stdv_idxs))*100:.2f}%\")\n"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "gsl-bnn-mac-m2",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.9.18"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
