{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "1e3635f5",
   "metadata": {},
   "source": [
    "# Execution example of SpinSVAR"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "e6a98055",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "Using device: cpu\n",
      "\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "import time\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "\n",
    "###################### SparseRCT\n",
    "import experiments\n",
    "from experiments.evaluation.evaluation import input_approximation\n",
    "from experiments.data import data_generation\n",
    "from experiments.plot_experiment import visualize\n",
    "from experiments.methods.utils import execute_R\n",
    "from experiments import utils\n",
    "from sparserc.sparserc import sparserc_solver\n",
    "from sparserc.spinsvar import spinsvar_solver\n",
    "\n",
    "############### LiNGAM - VARLiNGAM - DirectLiNGAM #################\n",
    "from experiments.methods.lingam import lingam\n",
    "from experiments.methods.lingam.lingam import ICALiNGAM, DirectLiNGAM\n",
    "\n",
    "############ tsFCI, TiMINO \n",
    "import subprocess # to run R scripts\n",
    "Rscript = 'C:/\"Program Files\"/R/R-4.2.1/bin/Rscript'\n",
    "path_to_tsfci = './experiments/methods/tsFCI/tsfci.R'\n",
    "path_to_data_tsfci = './experiments/methods/tsFCI/data_tsfci'\n",
    "path_to_timino = './experiments/methods/TiMINO/timino.R'\n",
    "path_to_data_timino = './experiments/methods/TiMINO/data_timino'\n",
    "\n",
    "############## DYNOTEARS #################\n",
    "from causalnex.structure import StructureModel\n",
    "from causalnex.structure import dynotears\n",
    "from causalnex.structure.data_generators import wrappers\n",
    "from causalnex.structure.dynotears import from_pandas_dynamic\n",
    "from causalnex.network import BayesianNetwork\n",
    "import pandas as pd\n",
    "from causalnex.evaluation import roc_auc\n",
    "\n",
    "############## NTS-NOTEARS imports ###############\n",
    "from experiments.methods.NTSNOTEARS.notears.locally_connected import LocallyConnected\n",
    "from experiments.methods.NTSNOTEARS.notears.lbfgsb_scipy import LBFGSBScipy\n",
    "from experiments.methods.NTSNOTEARS.notears.trace_expm import trace_expm\n",
    "from experiments.methods.NTSNOTEARS.notears.utils import *\n",
    "import experiments.methods.NTSNOTEARS.notears.utils as ut\n",
    "\n",
    "##################### PCMCI ####################\n",
    "from tigramite.pcmci import PCMCI\n",
    "from tigramite.lpcmci import LPCMCI\n",
    "from tigramite.independence_tests.parcorr import ParCorr\n",
    "from tigramite.independence_tests.cmiknn import CMIknn\n",
    "import tigramite.data_processing as pp\n",
    "# pcmci-Omega\n",
    "from experiments.methods.pcmci_omega.PCMCI_OMEGA_ContinuousData import algorithm_v2_mci_\n",
    "\n",
    "############## only symmary graph #############\n",
    "# GVAR \n",
    "from experiments.methods.GVAR.training import training_procedure_trgc\n",
    "# TCDF \n",
    "from experiments.methods.TCDF.runTCDF import runTCDF\n",
    "###############################################\n",
    "\n",
    "# seed = 42\n",
    "# ut.set_random_seed(seed)\n",
    "\n",
    "device = torch.device('cuda' if torch.cuda.is_available() else 'cpu')\n",
    "print('\\nUsing device: {}\\n'.format(device))\n",
    "\n",
    "result_folder = 'NTS-results'\n",
    "if not os.path.exists(result_folder):\n",
    "    os.mkdir(result_folder)\n",
    "    "
   ]
  },
  {
   "cell_type": "markdown",
   "id": "7dc1234e",
   "metadata": {},
   "source": [
    "## Data generation via a linear SEM with few root causes"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6e8ac4a3",
   "metadata": {},
   "outputs": [],
   "source": [
    "# first we define the experimental setup\n",
    "\n",
    "# random graph parameters\n",
    "series_length = 1000 # total number of timesteps \n",
    "d = 20 # number of nodes of the graph\n",
    "number_of_lags = 2 # data at time t are at mostly dependent from data at time t - number_of_lags\n",
    "algo_lags = 2\n",
    "p = number_of_lags # same\n",
    "k = 5 # equal to average degree of the graph\n",
    "graph_type = \"ER\" # Erdös-Renyi graphs\n",
    "(a, b) = (0.1, 0.5) # bounds for the weights of the adjacency matrix\n",
    "# => the graph will be transformed into a DAG by assigning a random order\n",
    "\n",
    "# Data on the graph parameters\n",
    "N = 10 # number of data samples = number of individual time-sequences \n",
    "fixSup = 'False' # support of the root causes is varying\n",
    "sparsity =  0.05\n",
    "sparsity_type = \"uniform\" # what weights to assign on the non-zero inputs\n",
    "\n",
    "noise_type = 'gauss'\n",
    "noise_std = 0.01\n",
    "\n",
    "# Execution parameters\n",
    "runs = 5 # how many times to repeat the experiment generating a new DAG and run the method each time\n",
    "spinsvar_epochs = 10000 # for how many epochs we let SparseRCT run\n",
    "omega = 0.09\n",
    "\n",
    "# NTS-NOTEARS \n",
    "sem_type = 'AdditiveIndexModel'\n",
    "w_threshold = 0.09"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "9e307f16",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABRQAAAJ1CAYAAACo6XyZAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy81sbWrAAAACXBIWXMAAA9hAAAPYQGoP6dpAABhVElEQVR4nO3deXhU9dk/4GcASRBIUNkXEXBBEbFSpeKCC4rUDbVaqS2IVn1d+mqpS22rgNbS1rUqdWlVtHXf0NZWqygqi1oXrODyAiKLAgpKIiCLyfn94S9TYxI4kWQiyX1f11w6Z3u+c+ZkeOYzZ85kkiRJAgAAAAAghUZ1PQAAAAAAYNMhUAQAAAAAUhMoAgAAAACpCRQBAAAAgNQEigAAAABAagJFAAAAACA1gSIAAAAAkJpAEQAAAABITaAIAAAAAKQmUIQGbL/99ov99tvva6+788471+yAqmn06NGRyWRqvc6JJ54Y22yzTblpmUwmRo8eXeu1qRnjx4+PTCYT7733Xl0PBQAahMr6p+qs26JFi5odUDXlqneorJ/dZptt4sQTT6zVutScSZMmRSaTiUmTJtX1UCCnBIqwkcqagKVLl1Y6f+edd/7aoV198MEHH8To0aNj+vTpdT0U6ok//vGPMX78+LoeBgBscu67777IZDLx8MMPV5jXp0+fyGQy8cwzz1SYt/XWW0f//v1zMcRqWbVqVYwePVqQQ42566674pprrqnrYcAmoUldDwCoO//6179qvcYHH3wQY8aMiW222SZ23XXXWq+XK5999lk0aeIltC788Y9/jNatW1frk/sf/ehHcfzxx0deXl7tDQwAvuH23nvviIiYPHlyHHXUUdnpxcXFMWPGjGjSpElMmTIl9t9//+y8BQsWxIIFC+L444+vVq0//elPUVpaWjMDr8KqVatizJgxERH16gP8d955Jxo1cu5PXbjrrrtixowZcc4556ReZ999943PPvssmjZtWnsDg28g74ahAfOP3teXn59f10MghZUrV0bz5s2jcePG0bhx47oeDgDUqY4dO0a3bt1i8uTJ5aZPmzYtkiSJY489tsK8svtlYWRam2222cYNtgHzAeimYfXq1dG0adNo1KiR9wY0SD72gBwru8bGfffdF5dddll07tw58vPz48ADD4zZs2dnl7v22mujcePGsXz58uy0K6+8MjKZTIwcOTI7raSkJFq2bBkXXHBBdlppaWlcc8010atXr8jPz4927drFaaedFp988km5sVR2DcV58+bFEUccEc2bN4+2bdvGT3/603jiiSeqvC7Im2++Gfvvv39svvnm0alTp/j9739f7rHuvvvuERExYsSIyGQykclkyn1d9cUXX4xDDjkkCgsLY/PNN48BAwbElClTKtSZPHly7L777pGfnx89evSIm266ab37+cuef/75OPbYY2PrrbeOvLy86NKlS/z0pz+Nzz77rMKyEyZMiJ133jny8/Nj5513rvQrQREVr6E4b968OOOMM2KHHXaIZs2axVZbbRXHHntspdfdWb58efz0pz+NbbbZJvLy8qJz584xbNiwcl+bX7NmTYwaNSq23Xbb7JjPP//8WLNmTYVxnHXWWdlx5+XlRa9eveLxxx+vUPf999+Pk08+OTp27Bh5eXnRrVu3OP3002Pt2rXx7rvvRiaTiauvvrrCelOnTo1MJhN33313Vbu43HE9ZsyY6NSpU7Rs2TK+973vRVFRUaxZsybOOeecaNu2bbRo0SJGjBhR4bHcdtttccABB0Tbtm0jLy8vdtppp7jhhhvKLbPNNtvEzJkz49lnn80eT2XHcNm1jp599tk444wzom3bttG5c+dy88qej6effjoaNWoUF198cbnt33XXXZHJZCrUBYD6Yu+9947XXnutXB80ZcqU6NWrVwwePDheeOGFcmcWTpkyJTKZTOy1117ZaX/961+jb9++0axZs9hyyy3j+OOPjwULFpSrU9k1FJctWxY/+tGPoqCgIFq1ahXDhw+P119/vUJ/WOb999+PIUOGRIsWLaJNmzZx7rnnRklJSUREvPfee9GmTZuIiBgzZky2L/hyf/b222/H9773vdhyyy0jPz8/vv3tb8ejjz5aoc7MmTPjgAMOiGbNmkXnzp3j17/+deqzK//zn//EiSeeGN27d4/8/Pxo3759nHTSSbFs2bIKy6btZ796DcWPP/44zj333Ojdu3e0aNEiCgoKYvDgwfH6669XWHf16tUxevTo2H777SM/Pz86dOgQRx99dMyZMye7TNr3Cttss00cdthhMXny5Nhjjz0iPz8/unfvHnfccUeFuuvrb1esWBHNmzePs88+u8J6CxcujMaNG8fYsWOr3MfvvfdeZDKZuOKKK2LcuHHRvXv32HzzzePggw+OBQsWRJIkcemll0bnzp2jWbNmceSRR8bHH39cbhuPPPJIHHroodk+uEePHnHppZdmj6eIL94bPfbYYzFv3rzs8VR2DJf1uvfcc0/86le/ik6dOsXmm28excXFFa6h+NZbb0WzZs1i2LBh5cYwefLkaNy4cbn3bbApc4Yi1JHf/va30ahRozj33HOjqKgofv/738cJJ5wQL774YkRE7LPPPlFaWhqTJ0+Oww47LCK+CMYaNWoUzz//fHY7r732WqxYsSL23Xff7LTTTjstxo8fHyNGjIj//d//jblz58b1118fr732WkyZMqXKT4xXrlwZBxxwQCxatCjOPvvsaN++fdx1112VXksnIuKTTz6JQw45JI4++ug47rjj4oEHHogLLrggevfuHYMHD44dd9wxLrnkkrj44ovj1FNPjX322SciInsNnqeffjoGDx4cffv2jVGjRkWjRo2yodLzzz8fe+yxR0REvPHGG3HwwQdHmzZtYvTo0fH555/HqFGjol27dqn29f333x+rVq2K008/Pbbaaqt46aWX4rrrrouFCxfG/fffn13uX//6VxxzzDGx0047xdixY2PZsmUxYsSIbCi1Pv/+979j6tSpcfzxx0fnzp3jvffeixtuuCH222+/ePPNN2PzzTePiIgVK1bEPvvsE2+99VacdNJJsdtuu8XSpUvj0UcfjYULF0br1q2jtLQ0jjjiiJg8eXKceuqpseOOO8Ybb7wRV199dfzf//1fTJgwoVztyZMnx0MPPRRnnHFGtGzZMq699to45phjYv78+bHVVltFxBdfPd9jjz1i+fLlceqpp0bPnj3j/fffjwceeCBWrVoV3bt3j7322ivuvPPO+OlPf1pu+3feeWe0bNkyjjzyyA3uh7Fjx0azZs3i5z//ecyePTuuu+662GyzzaJRo0bxySefxOjRo+OFF16I8ePHR7du3coFejfccEP06tUrjjjiiGjSpEn87W9/izPOOCNKS0vjzDPPjIiIa665Jn7yk59EixYt4pe//GVERIXj4Iwzzog2bdrExRdfHCtXrqx0nAcccECcccYZMXbs2BgyZEjstttusWjRovjJT34SAwcOjP/5n//Z4GMFgE3R3nvvHX/5y1/ixRdfzH4oN2XKlOjfv3/0798/ioqKYsaMGbHLLrtk5/Xs2TPbU1x22WVx0UUXxXHHHRc//vGP46OPPorrrrsu9t1333jttdeiVatWldYtLS2Nww8/PF566aU4/fTTo2fPnvHII4/E8OHDK12+pKQkBg0aFP369YsrrrginnrqqbjyyiujR48ecfrpp0ebNm3ihhtuiNNPPz2OOuqoOProoyMisuOeOXNm7LXXXtGpU6f4+c9/Hs2bN4/77rsvhgwZEg8++GD2K9+LFy+O/fffPz7//PPscjfffHM0a9Ys1f588skn4913340RI0ZE+/btY+bMmXHzzTfHzJkz44UXXsj+4MrG9LPvvvtuTJgwIY499tjo1q1bLFmyJG666aYYMGBAvPnmm9GxY8fsPjvssMNi4sSJcfzxx8fZZ58dn376aTz55JMxY8aM6NGjR0RU773C7Nmz43vf+16cfPLJMXz48Lj11lvjxBNPjL59+0avXr0iYsP97a677hpHHXVU3HvvvXHVVVeV+9bI3XffHUmSxAknnLDB/XDnnXfG2rVr4yc/+Ul8/PHH8fvf/z6OO+64OOCAA2LSpElxwQUXZPvPc889N2699dbsuuPHj48WLVrEyJEjo0WLFvH000/HxRdfHMXFxXH55ZdHRMQvf/nLKCoqioULF2Y/ZP/qjwNdeuml0bRp0zj33HNjzZo1lX7ja8cdd4xLL700zjvvvPje974XRxxxRKxcuTJOPPHE6NmzZ1xyySUbfKywSUiAjTJq1KgkIpKPPvqo0vm9evVKBgwYkL3/zDPPJBGR7LjjjsmaNWuy0//whz8kEZG88cYbSZIkSUlJSVJQUJCcf/75SZIkSWlpabLVVlslxx57bNK4cePk008/TZIkSa666qqkUaNGySeffJIkSZI8//zzSUQkd955Z7lxPP744xWmDxgwoNzYrrzyyiQikgkTJmSnffbZZ0nPnj2TiEieeeaZcutGRHLHHXdkp61ZsyZp3759cswxx2Sn/fvf/04iIrntttvKjae0tDTZbrvtkkGDBiWlpaXZ6atWrUq6deuWHHTQQdlpQ4YMSfLz85N58+Zlp7355ptJ48aNkzQvY6tWraowbezYsUkmkym3zV133TXp0KFDsnz58uy0f/3rX0lEJF27di23fkQko0aNWm+NadOmVdhHF198cRIRyUMPPVRh+bL98Je//CVp1KhR8vzzz5ebf+ONNyYRkUyZMqXcOJo2bZrMnj07O+31119PIiK57rrrstOGDRuWNGrUKPn3v/9dZd2bbropiYjkrbfeys5bu3Zt0rp162T48OEV1vuysuN65513TtauXZudPnTo0CSTySSDBw8ut/yee+5ZYZ9Wtg8HDRqUdO/evdy0r/5NlbntttuSiEj23nvv5PPPP6903ty5c7PTVq5cmWy77bZJr169ktWrVyeHHnpoUlBQUO6YAID6ZubMmUlEJJdeemmSJEmybt26pHnz5sntt9+eJEmStGvXLhk3blySJElSXFycNG7cODnllFOSJEmS9957L2ncuHFy2WWXldvmG2+8kTRp0qTc9OHDh5f7t/7BBx9MIiK55pprstNKSkqSAw44oEKvOHz48CQikksuuaRcnW9961tJ3759s/c/+uijCj1ZmQMPPDDp3bt3snr16uy00tLSpH///sl2222XnXbOOeckEZG8+OKL2WkffvhhUlhYWKF3qExl/cvdd9+dRETy3HPPZadVp5/t2rVrud5r9erVSUlJSbll5s6dm+Tl5ZXbR7feemsSEclVV11VYUxl/V513it07dq1wuP48MMPk7y8vORnP/tZdlqa/vaJJ55IIiL55z//WW7+LrvsUmlf99XHGhFJmzZtyvXpF154YRIRSZ8+fZJ169Zlpw8dOjRp2rRpuee+sufptNNOSzbffPNyyx166KEVetQk+W+v27179wrbKpv35fdKJSUlyd577520a9cuWbp0aXLmmWcmTZo0qbQXh02VrzxDHRkxYkS5T7TKzt579913IyKiUaNG0b9//3juueci4otT55ctWxY///nPI0mSmDZtWkR8cdbizjvvnP00+P7774/CwsI46KCDYunSpdlb3759o0WLFlWebRgR8fjjj0enTp3iiCOOyE7Lz8+PU045pdLlW7RoET/84Q+z95s2bRp77LFH9jGsz/Tp02PWrFnxgx/8IJYtW5Yd58qVK+PAAw+M5557LkpLS6OkpCSeeOKJGDJkSGy99dbZ9XfccccYNGjQButERLlPmFeuXBlLly6N/v37R5Ik8dprr0VExKJFi2L69OkxfPjwKCwszC5/0EEHxU477VStGuvWrYtly5bFtttuG61atYpXX301O+/BBx+MPn36lLsQepmyT7Dvv//+2HHHHaNnz57lnsMDDjggIqLCczhw4MDsJ84RX3wyX1BQkH0eSktLY8KECXH44YfHt7/97SrrHnfccZGfnx933nlndt4TTzwRS5cuLfc8r8+wYcPKfardr1+/SJIkTjrppHLL9evXLxYsWBCff/55dtqX92FRUVEsXbo0BgwYEO+++24UFRWlqh8Rccopp6S6XuLmm28e48ePj7feeiv23XffeOyxx+Lqq68ud5wBQH2z4447xlZbbZW9NuLrr78eK1euzH6DpH///tnLz0ybNi1KSkqy10986KGHorS0NI477rhyPUr79u1ju+2222Cfudlmm5XrKxs1apT9FkJlvvqNgX322SdVn/nxxx/H008/Hccdd1x8+umn2XEuW7YsBg0aFLNmzYr3338/IiL+8Y9/xHe+853sN2MiItq0aZPqjLmI8v3L6tWrY+nSpfGd73wnIiLbA25sP5uXl5f9kZaSkpJYtmxZtGjRInbYYYcKfWbr1q3jJz/5SYVtfLnPrM57hZ122in7PiXii32zww47lHse0vS3AwcOjI4dO5brM2fMmBH/+c9/UveZxx57bLk+vV+/fhER8cMf/rDcjyX269cv1q5dm32OI8o/T2XHxD777BOrVq2Kt99+O1X9iIjhw4enOnu1UaNGMX78+FixYkUMHjw4/vjHP8aFF15YaS8OmyqBIuRA2T+kX/bV0GKLLbaIiCh37ZJ99tknXnnllfjss8/i+eefjw4dOsRuu+0Wffr0yX7tefLkyeX+kZ81a1YUFRVF27Zto02bNuVuK1asiA8//LDKcc6bNy969OhRYbzbbrttpct37ty5wrJbbLFFheuvVGbWrFkR8cU/yl8d55///OdYs2ZNFBUVxUcffRSfffZZbLfddhW2scMOO2ywTkTE/Pnz48QTT4wtt9wyew2eAQMGRERkg6p58+ZFRHztOp999llcfPHF0aVLl8jLy4vWrVtHmzZtYvny5eXCsDlz5sTOO++83m3NmjUrZs6cWWG/bL/99hERFZ7DygKwLz8PH330URQXF2+wbqtWreLwww+Pu+66KzvtzjvvjE6dOmXDzA356ljKmr4uXbpUmF5aWlpu30yZMiUGDhwYzZs3j1atWkWbNm3iF7/4RUREtQLFbt26pV52r732itNPPz1eeumlGDRoUIXgEwDqm0wmE/37989eK3HKlCnRtm3bbL/35UCx7L9lgeKsWbMiSZLYbrvtKvQpb7311gb7zA4dOmQvA1Omqj4zPz8/e43EMmn7zNmzZ0eSJHHRRRdVGOeoUaMi4r/91Lx58zaqz/z444/j7LPPjnbt2kWzZs2iTZs22V6krH/Z2H62tLQ0rr766thuu+3K9Zn/+c9/KvSZO+ywQ7lw7auq+15hQ31mWd0N9ZmNGjWKE044ISZMmBCrVq2KiC/6zPz8/Dj22GM3uA8qG8v6+syI8u+rZs6cGUcddVQUFhZGQUFBtGnTJhtk1laf2aNHjxg9enT8+9//jl69esVFF12Uel3YFLiGImyksl/0quwHPiIiVq1aVemvflV1BlWSJNn/33vvvWPdunUxbdq0eP7557PB4T777BPPP/98vP322/HRRx+VCxRLS0ujbdu25T79+7KvNmYbI81jqErZha4vv/zy2HXXXStdpkWLFhV+uKO6SkpK4qCDDoqPP/44LrjggujZs2c0b9483n///TjxxBNTX3B7Q37yk5/EbbfdFuecc07sueeeUVhYGJlMJo4//vhq1ygtLY3evXvHVVddVen8rzZNG/M8fNWwYcPi/vvvj6lTp0bv3r3j0UcfjTPOOCP7qfiGVDWWDY1xzpw5ceCBB0bPnj3jqquuii5dukTTpk3jH//4R1x99dXV2odpr3kU8cWP35RdQHvOnDmxatWqCm90AKC+2XvvveNvf/tbvPHGG9nrJ5bp379/nHfeefH+++/H5MmTo2PHjtG9e/eI+KJHyWQy8c9//rPSf9u/er25jZHm2wZVKesbzj333CrPAKwqyKyu4447LqZOnRrnnXde7LrrrtGiRYsoLS2NQw45pMb6zN/85jdx0UUXxUknnRSXXnppbLnlltGoUaM455xzvlafWZ33CjXdZ15++eUxYcKEGDp0aNx1111x2GGHlTvrcH2+bp+5fPnyGDBgQBQUFMQll1wSPXr0iPz8/Hj11VfjggsuqLU+M+KLa7RHfHE982XLlkX79u2rtT58kwkUYSN17do1IiLeeeedCkHPqlWrYsGCBXHwwQd/rW3vscce0bRp03j++efj+eefj/POOy8iIvbdd9/405/+FBMnTszeL9OjR4946qmnYq+99qr2P3hdu3aNN998M5IkKXfm4Zd/fbq6Kjs7s2ycEREFBQUxcODAKtdv06ZNNGvWLHtG45e98847G6z/xhtvxP/93//F7bffXu6X1p588slyy5U9j1+3zgMPPBDDhw+PK6+8Mjtt9erV5X6lO+KLxz1jxoz1bqtHjx7x+uuvx4EHHljl/quONm3aREFBwQbrRkQccsgh0aZNm7jzzjujX79+sWrVqvjRj3600WPYkL/97W+xZs2aePTRR8t9+lzZV6dqYp+UGTVqVLz11ltxxRVXxAUXXBA///nP49prr62x7QPAN1HZGYeTJ0+OKVOmxDnnnJOd17dv38jLy4tJkybFiy++GN/97nez83r06BFJkkS3bt2y35xIq2vXrvHMM89U+PCuNvrMsgB0s802W2+fWTaur9v/ffLJJzFx4sQYM2ZMuR+a++r2NraffeCBB2L//fePW265pdz05cuXR+vWrbP3e/ToES+++GKsW7euyh9h3Jj3ClVJ099GROy8887xrW99K+68887o3LlzzJ8/P6677roaGcP6TJo0KZYtWxYPPfRQufdNc+fOrbBsTfaZN954Yzz55JNx2WWXxdixY+O0006LRx55pMa2D3XNV55hIx144IHRtGnTuOGGGyp8unXzzTfH559/HoMHD/5a287Pz4/dd9897r777pg/f365MxQ/++yzuPbaa6NHjx7RoUOH7DrHHXdclJSUxKWXXlphe59//nmFgOvLBg0aFO+//348+uij2WmrV6+OP/3pT19r/BERzZs3j4ioULdv377Ro0ePuOKKK2LFihUV1vvoo48i4otPHAcNGhQTJkyI+fPnZ+e/9dZb8cQTT2ywftknll/+FDVJkvjDH/5QbrkOHTrErrvuGrfffnu5rz08+eST8eabb6aq89VPaq+77rooKSkpN+2YY46J119/PR5++OEK2yhb/7jjjov333+/0v3+2WefVfnLxVVp1KhRDBkyJP72t7/Fyy+/XGXdiIgmTZrE0KFD47777ovx48dH7969s7+WWJsqe56Kioritttuq7Bs8+bN13scp/Xiiy/GFVdcEeecc0787Gc/i/POOy+uv/76ePbZZzd62wDwTfbtb387e93k999/v9wZinl5ebHbbrvFuHHjYuXKldnwMSLi6KOPjsaNG8eYMWMq9D1JksSyZcuqrDlo0KBYt25duf6mtLQ0xo0b97UfR1kw+dW+oG3btrHffvvFTTfdFIsWLaqwXlmfGRHx3e9+N1544YV46aWXys2v6gy+L6usf4mIuOaaayost7H97Fdr3H///eWuERjxRZ+5dOnSuP766yts48t95td9r1CVNP1tmR/96Efxr3/9K6655prYaqutvvb7pOqo7Hlau3Zt/PGPf6ywbPPmzav1FeiqzJ07N84777w45phj4he/+EVcccUV8eijj8Ydd9yx0duGbwpnKMJGatu2bVx88cXxq1/9Kvbdd9844ogjYvPNN4+pU6fG3XffHQcffHAcfvjhX3v7++yzT/z2t7+NwsLC6N27d7bmDjvsEO+8806ceOKJ5ZYfMGBAnHbaaTF27NiYPn16HHzwwbHZZpvFrFmz4v77748//OEP8b3vfa/SWqeddlpcf/31MXTo0Dj77LOjQ4cO2WubRHy9T+x69OgRrVq1ihtvvDFatmwZzZs3j379+kW3bt3iz3/+cwwePDh69eoVI0aMiE6dOsX7778fzzzzTBQUFMTf/va3iIgYM2ZMPP7447HPPvvEGWecEZ9//nlcd9110atXr/jPf/6z3vo9e/aMHj16xLnnnhvvv/9+FBQUxIMPPljp9XfGjh0bhx56aOy9995x0kknxccff5ytU1no+WWHHXZY/OUvf4nCwsLYaaedYtq0afHUU0/FVlttVW658847Lx544IE49thj46STToq+ffvGxx9/HI8++mjceOON0adPn/jRj34U9913X/zP//xPPPPMM7HXXntFSUlJvP3223HffffFE088Ue0LOv/mN7+Jf/3rXzFgwIA49dRTY8cdd4xFixbF/fffH5MnT87+qE/EF19Hufbaa+OZZ56J3/3ud9Wq83UdfPDB0bRp0zj88MPjtNNOixUrVsSf/vSnaNu2bYU3An379o0bbrghfv3rX8e2224bbdu2TX2NxzKrV6+O4cOHx3bbbReXXXZZRHxxnP3tb3+LESNGxBtvvJENwwGgvmnatGnsvvvu8fzzz0deXl707du33Pz+/ftnv3Xx5UCxR48e8etf/zouvPDCeO+992LIkCHRsmXLmDt3bjz88MNx6qmnxrnnnltpzSFDhsQee+wRP/vZz2L27NnRs2fPePTRR+Pjjz+OiK/XZzZr1ix22mmnuPfee2P77bePLbfcMnbeeefYeeedY9y4cbH33ntH796945RTTonu3bvHkiVLYtq0abFw4cJ4/fXXIyLi/PPPj7/85S9xyCGHxNlnnx3NmzePm2++Obp27brBPrOgoCD23Xff+P3vfx/r1q2LTp06xb/+9a9Kz3zbmH72sMMOi0suuSRGjBgR/fv3jzfeeCPuvPPO7JmYZYYNGxZ33HFHjBw5Ml566aXYZ599YuXKlfHUU0/FGWecEUceeeRGvVeoSpr+tswPfvCDOP/88+Phhx+O008/vcozKWtS//79Y4sttojhw4fH//7v/0Ymk4m//OUvlX5tu2/fvnHvvffGyJEjY/fdd48WLVpU+71c2Q8SNmvWLG644YaI+OJ91oMPPhhnn3129gdqYJOXmx+Thvrvr3/9a/Kd73wnad68eZKXl5f07NkzGTNmTLJ69epyyz3zzDNJRCT3339/uelz585NIiK57bbbyk1/7LHHkohIBg8eXG76j3/84yQikltuuaXS8dx8881J3759k2bNmiUtW7ZMevfunZx//vnJBx98kF1mwIAByYABA8qt9+677yaHHnpo0qxZs6RNmzbJz372s+TBBx9MIiJ54YUXyq3bq1evCnWHDx+edO3atdy0Rx55JNlpp52SJk2aVHiMr732WnL00UcnW221VZKXl5d07do1Oe6445KJEyeW28azzz6b9O3bN2natGnSvXv35MYbb0xGjRqVpHkZe/PNN5OBAwcmLVq0SFq3bp2ccsopyeuvv17p/n7wwQeTHXfcMcnLy0t22mmn5KGHHqr0MUVEMmrUqOz9Tz75JBkxYkTSunXrpEWLFsmgQYOSt99+O+natWsyfPjwcusuW7YsOeuss5JOnTolTZs2TTp37pwMHz48Wbp0aXaZtWvXJr/73e+SXr16JXl5eckWW2yR9O3bNxkzZkxSVFRUbhxnnnlmhcdcWd158+Ylw4YNS9q0aZPk5eUl3bt3T84888xkzZo1Fdbv1atX0qhRo2ThwoXr37n/X1XH9W233ZZERPLvf/+73PSy5+6jjz7KTnv00UeTXXbZJcnPz0+22Wab5He/+11y6623JhGRzJ07N7vc4sWLk0MPPTRp2bJlEhHZY7iqWl+eV7adn/70p0njxo2TF198sdxyL7/8ctKkSZPk9NNPT/W4AWBTdeGFFyYRkfTv37/CvIceeiiJiKRly5bJ559/XmH+gw8+mOy9995J8+bNk+bNmyc9e/ZMzjzzzOSdd97JLlNZ//TRRx8lP/jBD5KWLVsmhYWFyYknnphMmTIliYjknnvuKbdu8+bNK9StrPebOnVqtkf8an82Z86cZNiwYUn79u2TzTbbLOnUqVNy2GGH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TjzxxAqP8ZBDDtngdjf14yViw/umstecTCYTl19+eZXbrA/HDPWXfrQ8/WjV9KOV04/+l360cvrRqulJK6cf3Tj1PlC89957Y+TIkTFq1Kh49dVXo0+fPjFo0KD48MMPK11+6tSpMXTo0Dj55JPjtddeiyFDhsSQIUNixowZOR557Xn22WfjzDPPjBdeeCGefPLJWLduXRx88MGxcuXK9a5XUFAQixYtyt7mzZuXoxHnVq9evco9zsmTJ1e5bEM4XiIi/v3vf5fbJ08++WRERBx77LFVrlNfj5eVK1dGnz59Yty4cZXO//3vfx/XXntt3HjjjfHiiy9G8+bNY9CgQbF69eoqt1nd16lvovXtl1WrVsWrr74aF110Ubz66qvx0EMPxTvvvBNHHHHEBrdbnb/Hb6INHS8REYcccki5x3j33Xevd5v14XiJ2PC++fI+WbRoUdx6662RyWTimGOOWe92N/VjhvpJP1qRfnT99KMV6Uf/Sz9aOf1o1fSkldOPbqSknttjjz2SM888M3u/pKQk6dixYzJ27NhKlz/uuOOSQw89tNy0fv36JaeddlqtjrMuffjhh0lEJM8++2yVy9x2221JYWFh7gZVR0aNGpX06dMn9fIN8XhJkiQ5++yzkx49eiSlpaWVzm8ox0tEJA8//HD2fmlpadK+ffvk8ssvz05bvnx5kpeXl9x9991Vbqe6r1PfdF/dL5V56aWXkohI5s2bV+Uy1f17/KarbL8MHz48OfLII6u1nfp2vCRJumPmyCOPTA444ID1LlPfjhnqD/3ohulH/0s/mo5+9Av60crpR6umJ62cfrT66vUZimvXro1XXnklBg4cmJ3WqFGjGDhwYEybNq3SdaZNm1Zu+YiIQYMGVbl8fVBUVBQREVtuueV6l1uxYkV07do1unTpEkceeWTMnDkzF8PLuVmzZkXHjh2je/fuccIJJ8T8+fOrXLYhHi9r166Nv/71r3HSSSdFJpOpcrmGcrx82dy5c2Px4sXljonCwsLo169flcfE13mdqg+Kiooik8lEq1at1rtcdf4eN1WTJk2Ktm3bxg477BCnn356LFu2rMplG+rxsmTJknjsscfi5JNP3uCyDeGYYdOiH01HP1qefnT99KNV04+mpx8tT0+6fvrRiup1oLh06dIoKSmJdu3alZverl27WLx4caXrLF68uFrLb+pKS0vjnHPOib322it23nnnKpfbYYcd4tZbb41HHnkk/vrXv0ZpaWn0798/Fi5cmMPR1r5+/frF+PHj4/HHH48bbrgh5s6dG/vss098+umnlS7f0I6XiIgJEybE8uXL48QTT6xymYZyvHxV2fNenWPi67xObepWr14dF1xwQQwdOjQKCgqqXK66f4+bokMOOSTuuOOOmDhxYvzud7+LZ599NgYPHhwlJSWVLt8Qj5eIiNtvvz1atmwZRx999HqXawjHDJse/eiG6UfL049umH60avrRdPSj5elJN0w/WlGTuh4AdevMM8+MGTNmbPA7/XvuuWfsueee2fv9+/ePHXfcMW666aa49NJLa3uYOTN48ODs/++yyy7Rr1+/6Nq1a9x3332pPoloCG655ZYYPHhwdOzYscplGsrxQvWtW7cujjvuuEiSJG644Yb1LtsQ/h6PP/747P/37t07dtlll+jRo0dMmjQpDjzwwDoc2TfLrbfeGieccMIGL6bfEI4ZqI/0o+V5Ldsw/SgbQz9akZ50w/SjFdXrMxRbt24djRs3jiVLlpSbvmTJkmjfvn2l67Rv375ay2/KzjrrrPj73/8ezzzzTHTu3Lla62622WbxrW99K2bPnl1Lo/tmaNWqVWy//fZVPs6GdLxERMybNy+eeuqp+PGPf1yt9RrK8VL2vFfnmPg6r1ObqrLmbd68efHkk0+u99Pgymzo77E+6N69e7Ru3brKx9iQjpcyzz//fLzzzjvVft2JaBjHDN98+tH1049umH60PP3o+ulH108/mo6etDz9aOXqdaDYtGnT6Nu3b0ycODE7rbS0NCZOnFju06ov23PPPcstHxHx5JNPVrn8pihJkjjrrLPi4Ycfjqeffjq6detW7W2UlJTEG2+8ER06dKiFEX5zrFixIubMmVPl42wIx8uX3XbbbdG2bds49NBDq7VeQzleunXrFu3bty93TBQXF8eLL75Y5THxdV6nNkVlzdusWbPiqaeeiq222qra29jQ32N9sHDhwli2bFmVj7GhHC9fdsstt0Tfvn2jT58+1V63IRwzfPPpRyunH01PP1qefnT99KNV04+mpyctTz9ahbr9TZjad8899yR5eXnJ+PHjkzfffDM59dRTk1atWiWLFy9OkiRJfvSjHyU///nPs8tPmTIladKkSXLFFVckb731VjJq1Khks802S9544426egg17vTTT08KCwuTSZMmJYsWLcreVq1alV3mq/tlzJgxyRNPPJHMmTMneeWVV5Ljjz8+yc/PT2bOnFkXD6HW/OxnP0smTZqUzJ07N5kyZUoycODApHXr1smHH36YJEnDPF7KlJSUJFtvvXVywQUXVJjXkI6XTz/9NHnttdeS1157LYmI5Kqrrkpee+217K/D/fa3v01atWqVPPLII8l//vOf5Mgjj0y6deuWfPbZZ9ltHHDAAcl1112Xvb+h16lNwfr2y9q1a5Mjjjgi6dy5czJ9+vRyrztr1qzJbuOr+2VDf4+bgvXtl08//TQ599xzk2nTpiVz585NnnrqqWS33XZLtttuu2T16tXZbdTH4yVJNvy3lCRJUlRUlGy++ebJDTfcUOk26uMxQ/2kH61IP1o1/WjV9KNf0I9WTj9aNT1p5fSjG6feB4pJkiTXXXddsvXWWydNmzZN9thjj+SFF17IzhswYEAyfPjwcsvfd999yfbbb580bdo06dWrV/LYY4/leMS1KyIqvd12223ZZb66X84555zsPmzXrl3y3e9+N3n11VdzP/ha9v3vfz/p0KFD0rRp06RTp07J97///WT27NnZ+Q3xeCnzxBNPJBGRvPPOOxXmNaTj5Zlnnqn076fs8ZeWliYXXXRR0q5duyQvLy858MADK+yzrl27JqNGjSo3bX2vU5uC9e2XuXPnVvm688wzz2S38dX9sqG/x03B+vbLqlWrkoMPPjhp06ZNstlmmyVdu3ZNTjnllApNWH08XpJkw39LSZIkN910U9KsWbNk+fLllW6jPh4z1F/60fL0o1XTj1ZNP/oF/Wjl9KNV05NWTj+6cTJJkiRf9+xGAAAAAKBhqdfXUAQAAAAAapZAEQAAAABITaAIAAAAAKQmUAQAAAAAUhMoAgAAAACpCRQBAAAAgNQEigAAAABAagJFAAAAACA1gSIAAAAAkJpAEQAAAABITaAIAAAAAKT2/wCt1BTGyE3CqAAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 1600x1000 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABRQAAAJ1CAYAAACo6XyZAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy81sbWrAAAACXBIWXMAAA9hAAAPYQGoP6dpAABfXElEQVR4nO3deXQV5f0/8M8FJEGWoLIrouKCC6JFRVDEBQ3UiqjVSq2CW63VVmu1SlsF1JZWqz/r8kWtClatu6Wb0gpuKKhVoW6VIkVQBFSUhEUQkvn94cmtlyQw0eQGktfrnHsOd+aZeZ557tzkwztz52aSJEkCAAAAACCFJvU9AAAAAABg0yFQBAAAAABSEygCAAAAAKkJFAEAAACA1ASKAAAAAEBqAkUAAAAAIDWBIgAAAACQmkARAAAAAEhNoAgAAAAApCZQhAbq4IMPjoMPPvhLb7vHHnvU7oBqaPTo0ZHJZOq8n3feeScymUxMmDChzvvKh6eeeioymUw89dRTddrPhAkTIpPJxDvvvJNd9lXOOQBg0zBixIjYbrvtvvS2rVq1qt0B1VBVNUxdyWQyMXr06DrvJx/yVTNXVct+lXMOqDsCRViPilDro48+qnL9Hnvs0agDlPfffz9Gjx4dM2fOrLcxzJo1K370ox9Fv379orCwMG8FIgDAxuKBBx6ITCYTf/zjHyut69WrV2QymXjyyScrrdt2222jX79++RhijaxcuTJGjx5d538gXZ+FCxfGJZdcEocccki0bt06L3+wBdiUCBShgfrHP/4R//jHP+q0j/fffz/GjBlTr4Hi9OnT4/rrr49ly5bFrrvuWm/jID/nHABQ2YEHHhgREc8++2zO8tLS0nj99dejWbNm8dxzz+Wse/fdd+Pdd9/NbpvW7373u5g1a9ZXG/AGrFy5MsaMGVOvAd6sWbPi17/+dSxYsCB69uxZb+MgP+ccUHMCRWigmjdvHs2bN6/vYdS5IUOGxNKlS+O1116Lk046qb6H06g1lnMOADY2Xbp0ie23375SoDh9+vRIkiSOP/74Susqntc0UNxss82ioKDgqw14E9C7d+9YsmRJ/Oc//4kLLrigvofTqDWWcw42NQJFqEUV9/x44IEH4he/+EVss802UVhYGIcddli8/fbb2XbXX399NG3aNJYuXZpdds0110Qmk8kpWMrKyqJ169Zx8cUXZ5eVl5fHddddF7vvvnsUFhZGx44d46yzzopPPvkkZyxV3c9u3rx5MWTIkGjZsmV06NAhfvSjH8Xf//73aj/C8eabb8YhhxwSm2++eWy99dZx1VVX5RzrvvvuGxERp556amQymUr3VXnhhRdi0KBBUVRUFJtvvnkMGDCg0l/HIz4vaPfdd98oLCyM7t27xy233LLeef6iLbfcMlq3bp26fRqvvvpqjBgxInbYYYcoLCyMTp06xWmnnRZLliyp1Papp56KffbZJ2fsVd3/8dNPP40f/vCH0a5du2jdunUMGTIkFixYUOW9dRYsWBCnnXZadOzYMQoKCmL33XePO+64o1Lf7733XgwdOjTn9Vy9enWqY5w3b158//vfj1122SVatGgRW221VRx//PFVflz8jTfeiEMPPTRatGgR22yzTVx55ZVRXl5eqd2659xnn30Wl112WfTu3TuKioqiZcuW0b9//yo/clVeXh6//e1vo2fPnlFYWBjt27ePQYMGxUsvvZTT7u67747evXtHixYtYsstt4wTTzwx3n333Urj2GOPPdZ7/lZYtWpVjB49OnbeeecoLCyMzp07x7HHHhtz5syJJEliu+22i6OPPrrK7YqKiuKss86qbooBIK8OPPDAmDFjRnz66afZZc8991zsvvvuMXjw4Hj++edzfn8/99xzkclk4oADDsguS/N7tqr72S1ZsiROPvnkaNOmTbRt2zaGDx8e//rXv6q9596CBQti6NCh0apVq2jfvn1ceOGFUVZWFhGf36uvffv2ERExZsyYbI35xXrprbfeim9+85ux5ZZbRmFhYeyzzz7x5z//uVI/aWuYqrRu3Tq23HLLVG3Tqkn99eqrr8aAAQNyxj5+/PhKt/cpLy+P0aNHR5cuXWLzzTePQw45JN58883YbrvtYsSIETn7XLp0aZx//vnRtWvXKCgoiB133DF+/etfV5qTpUuXxogRI6KoqCj7en7x/y3r8/HHH8eFF14YPXv2jFatWkWbNm1i8ODB8a9//atS27S1bFXn3G9+85vo169fbLXVVtGiRYvo3bt3PPTQQ1WO6e6774799tsvNt9889hiiy3ioIMOqvSpmsceeyz69+8fLVu2jNatW8eRRx4Zb7zxRqVxtGrVar3nb4UN1bYDBgyIXr16VTneXXbZJYqLi6tcBxuTZvU9AGiIfvWrX0WTJk3iwgsvjJKSkrjqqqvipJNOihdeeCEiIvr37x/l5eXx7LPPxje+8Y2IiJg6dWo0adIkpk6dmt3PjBkzYvny5XHQQQdll5111lkxYcKEOPXUU+OHP/xhzJ07N2688caYMWNGPPfcc7HZZptVOaYVK1bEoYceGgsXLozzzjsvOnXqFH/4wx+qDHciIj755JMYNGhQHHvssXHCCSfEQw89FBdffHH07NkzBg8eHLvuumtcfvnlcdlll8V3v/vd6N+/f0RE9j48TzzxRAwePDh69+4do0aNiiZNmsT48ePj0EMPjalTp8Z+++0XERGvvfZaHHHEEdG+ffsYPXp0rF27NkaNGhUdO3b8iq/Cl/f444/Hf//73zj11FOjU6dO8cYbb8Stt94ab7zxRjz//PPZsHDGjBkxaNCg6Ny5c4wZMybKysri8ssvzxbBXzRixIh44IEH4uSTT479998/nn766TjyyCMrtVu8eHHsv//+kclk4txzz4327dvHY489FqeffnqUlpbG+eefHxGfB5SHHXZYzJ8/P374wx9Gly5d4q677oonnngi1TH+85//jGnTpsWJJ54Y22yzTbzzzjsxbty4OPjgg+PNN9+MzTffPCIiFi1aFIccckisXbs2LrnkkmjZsmXceuut0aJFiw32UVpaGrfddlsMGzYszjzzzFi2bFncfvvtUVxcHC+++GLstdde2bann356TJgwIQYPHhxnnHFGrF27NqZOnRrPP/987LPPPhER8Ytf/CIuvfTSOOGEE+KMM86IDz/8MG644YY46KCDYsaMGdG2bdvs/jZ0/kZ8Hth/4xvfiClTpsSJJ54Y5513Xixbtiwef/zxeP3116N79+7xne98J6666qr4+OOPc/5T8Ze//CVKS0vjO9/5Tqr5BoC6duCBB8Zdd90VL7zwQvYPfM8991z069cv+vXrFyUlJfH666/HnnvumV3Xo0eP2GqrrSKiZr9nv6i8vDyOOuqoePHFF+Pss8+OHj16xJ/+9KcYPnx4le3LysqiuLg4+vTpE7/5zW9i8uTJcc0110T37t3j7LPPjvbt28e4cePi7LPPjmOOOSaOPfbYiIjsuN9444044IADYuutt87WJg888EAMHTo0Hn744TjmmGMi4qvVMHUlbf21YMGCOOSQQyKTycTIkSOjZcuWcdttt1V5ld7IkSPjqquuiqOOOiqKi4vjX//6VxQXF8eqVaty2q1cuTIGDBgQCxYsiLPOOiu23XbbmDZtWowcOTIWLlwY1113XUREJEkSRx99dDz77LPxve99L3bdddf44x//WO3rua7//ve/MXHixDj++ONj++23j8WLF8ctt9wSAwYMiDfffDO6dOkSEV+9lv3tb38bQ4YMiZNOOik+++yzuO++++L444+Pv/71rzk19pgxY2L06NHRr1+/uPzyy6N58+bxwgsvxBNPPBFHHHFERETcddddMXz48CguLo5f//rXsXLlyhg3blw2pP9imLmh87fChmrbk08+Oc4888x4/fXXc74M85///Gf85z//iZ///Oep5gHqVQJUa9SoUUlEJB9++GGV63ffffdkwIAB2edPPvlkEhHJrrvumqxevTq7/Le//W0SEclrr72WJEmSlJWVJW3atEl+8pOfJEmSJOXl5clWW22VHH/88UnTpk2TZcuWJUmSJNdee23SpEmT5JNPPkmSJEmmTp2aRERyzz335Ixj0qRJlZYPGDAgZ2zXXHNNEhHJxIkTs8s+/fTTpEePHklEJE8++WTOthGR/P73v88uW716ddKpU6fkuOOOyy775z//mUREMn78+JzxlJeXJzvttFNSXFyclJeXZ5evXLky2X777ZPDDz88u2zo0KFJYWFhMm/evOyyN998M2natGlS0x9RV199dRIRydy5c1NvM3fu3ErHsHLlykrt7r333iQikmeeeSa77Kijjko233zzZMGCBdlls2fPTpo1a5Yz9pdffjmJiOT888/P2eeIESOSiEhGjRqVXXb66acnnTt3Tj766KOctieeeGJSVFSUHdt1112XRETywAMPZNusWLEi2XHHHSu9nlWp6hinT59e6XU///zzk4hIXnjhheyyDz74ICkqKqo01+uec2vXrs15HyRJknzyySdJx44dk9NOOy277IknnkgiIvnhD39YaUwV588777yTNG3aNPnFL36Rs/61115LmjVrlrM87fl7xx13JBGRXHvttdX2O2vWrCQiknHjxuWsHzJkSLLddtvlnN8AUJ/eeOONJCKSK664IkmSJFmzZk3SsmXL5M4770ySJEk6duyY3HTTTUmSJElpaWnStGnT5Mwzz0ySpGa/Z4cPH55069Yt+/zhhx9OIiK57rrrssvKysqSQw89tFKNNXz48CQikssvvzynn7333jvp3bt39vmHH35YqUaqcNhhhyU9e/ZMVq1alV1WXl6e9OvXL9lpp52yy2pSw2zIgw8+mKq+Wte6x5C2/vrBD36QZDKZZMaMGdllS5YsSbbccsucsS9atChp1qxZMnTo0Jx9jh49OomIZPjw4dllV1xxRdKyZcvkP//5T07bSy65JGnatGkyf/78JEmSZOLEiUlEJFdddVW2zdq1a5P+/ftXWfeva9WqVUlZWVnOsrlz5yYFBQU5r3tNatl1z7kkqTyXn332WbLHHnskhx56aHbZ7NmzkyZNmiTHHHNMpTFV1HDLli1L2rZtm30vVFi0aFFSVFSUszzt+Zumtl26dGlSWFiYXHzxxTnrf/jDHyYtW7ZMli9fXmlb2Nj4yDPUgVNPPTXnXnIVV+/997//jYiIJk2aRL9+/eKZZ56JiIh///vfsWTJkrjkkksiSZKYPn16RHx+1eIee+yR/Yvwgw8+GEVFRXH44YfHRx99lH307t07WrVqVe3VhhERkyZNiq233jqGDBmSXVZYWBhnnnlmle1btWqVc/VV8+bNY7/99ssew/rMnDkzZs+eHd/+9rdjyZIl2XGuWLEiDjvssHjmmWeivLw8ysrK4u9//3sMHTo0tt122+z2u+66a71e5v/Fv1yvWrUqPvroo9h///0jIuKVV16JiM//Ojl58uQYOnRo9i+tERE77rhj9gq4CpMmTYqIiO9///s5y3/wgx/kPE+SJB5++OE46qijIkmSnNe4uLg4SkpKsv0/+uij0blz5/jmN7+Z3X7zzTeP7373uzU+xjVr1sSSJUtixx13jLZt22b7qOhn//33z15RGhHRvn37VPerbNq0afZ9UF5eHh9//HGsXbs29tlnn5w+Hn744chkMjFq1KhK+6i4GvSRRx6J8vLyOOGEE3LmpVOnTrHTTjtVOvfTnL8PP/xwtGvXrtLr8MV+d9555+jTp0/cc8892XUff/xxPPbYY3HSSSdV+mg7ANSXXXfdNbbaaqvsvRH/9a9/xYoVK7KfHunXr1/21jPTp0+PsrKy7P0Ta/p79osmTZoUm222WU5N2aRJkzjnnHOq3eZ73/tezvP+/funqjE//vjjeOKJJ+KEE06IZcuWZce5ZMmSKC4ujtmzZ8eCBQsi4qvVMHUlbf01adKk6Nu3b86nObbccstKY58yZUqsXbt2gzVmxOf/j+jfv39sscUWOa/xwIEDo6ysLPv/kkcffTSaNWuWc7Vd06ZNq9xnVQoKCqJJk89jhrKysliyZEm0atUqdtlll0o1Zm3Vsp988kmUlJRE//79c/qYOHFilJeXx2WXXZYdU4WKGu7xxx+PpUuXxrBhw3LmpWnTptGnT58qz/0Nnb9patuioqI4+uij4957740kSSLi8/m6//77sx8Dh42djzzDV1RVoPDFcCwiYosttoiIyLnPYf/+/WP06NHx6aefxtSpU6Nz587xta99LXr16hVTp06Nww8/PJ599tk44YQTstvMnj07SkpKokOHDlWO5YMPPqh2nPPmzYvu3btXGu+OO+5YZfttttmmUtstttgiXn311Wr7+OI4I2K9H40oKSmJ1atXx6effho77bRTpfW77LJLPProoxvsK60PP/ww594mrVq1ilatWlXZ9uOPP44xY8bEfffdV2lOS0pKIuLzuf7000+rnL91l82bNy+aNGkS22+//Xrbffjhh7F06dK49dZb49Zbb61ybBXjmTdvXuy4446VXqNddtmlyu3W9emnn8bYsWNj/PjxsWDBgmwh88VjrOinT58+lbZP28+dd94Z11xzTbz11luxZs2a7PIvzsWcOXOiS5cu671P0ezZsyNJkirPlYio9FH/NOfvnDlzYpdddolmzdb/q/CUU06Jc889N+bNmxfdunWLBx98MNasWRMnn3zyercDgHzKZDLZP1iXl5fHc889Fx06dMjWG/369Ysbb7wxIiIbLFYEijX9PftF8+bNi86dO2c/rluhuhqz4n5yX7TFFltUuh94Vd5+++1IkiQuvfTSuPTSS6ts88EHH8TWW2/9lWuYtD7++OP47LPPss9btGgRRUVFVbatSf3Vt2/fSttXVWNWtXzLLbfM/v+jwuzZs+PVV1+t8tY8Ebk1ZufOnSvVyWnnreLegf/3f/8Xc+fOzam/Kz5eX9HPV6ll//rXv8aVV14ZM2fOzLnv4hf3N2fOnGjSpEnstttu1e6n4v8thx56aJXr27Rpk/M8zfmbpraN+LzGvP/++2Pq1Klx0EEHxeTJk2Px4sVqTDYZAkVYj8LCwoiInJtbf9HKlSuzbb6oadOmVbb/YtFw4IEHxpo1a2L69OkxderU7FWM/fv3j6lTp8Zbb70VH374YXZ5xOe/oDt06JBztdQXVVcgfBlpjqE6FTd2vvrqq3P+svpFrVq1Sv0FIrVh3333zRZdERGjRo2q9GUoFU444YSYNm1aXHTRRbHXXntFq1atory8PAYNGpT6Rt5fRsW+v/Od71QbxlbcP+ir+sEPfhDjx4+P888/P/r27RtFRUWRyWTixBNPrLVjvPvuu2PEiBExdOjQuOiii6JDhw7RtGnTGDt2bMyZM6dG+yovL49MJhOPPfZYlefmukXvVzl/13XiiSfGj370o7jnnnvipz/9adx9992xzz771Pp/SADgqzrwwAPjL3/5S7z22mvZ+ydW6NevX1x00UWxYMGCePbZZ6NLly6xww47RETNf89+FdX9jk6joka58MILq/00S3VBZl059thj4+mnn84+Hz58eJVfRBORn/qrOuXl5XH44YfHT37ykyrX77zzzrXSzy9/+cu49NJL47TTTosrrrgittxyy2jSpEmcf/75tXaMU6dOjSFDhsRBBx0U//d//xedO3eOzTbbLMaPHx9/+MMfarSvijHddddd0alTp0rr1/3D81c5f9dVXFwcHTt2jLvvvjsOOuiguPvuu6NTp04xcODAWusD6pJAEdajW7duERExa9as6Nq1a866lStXxrvvvpu9mW9N7bffftG8efOYOnVqTJ06NS666KKIiDjooIPid7/7XUyZMiX7vEL37t1j8uTJccABB9T4htLdunWLN998M5IkyfnL3Re/fbqmqvu4Z/fu3SPi87/ore8XYvv27aNFixbZvwx+0axZs770uKpyzz335ATDFQX0uj755JOYMmVKjBkzJi677LLs8nXH2KFDhygsLKxy/tZd1q1btygvL4+5c+fm/OV/3Xbt27eP1q1bR1lZ2QYLiW7dusXrr79e6fVMO28PPfRQDB8+PK655prsslWrVlX6Br9u3bp96dfnoYceih122CEeeeSRnDGu+/GP7t27x9///vdKX3yybpskSWL77bevtYK3e/fu8cILL8SaNWvWe+XFlltuGUceeWTcc889cdJJJ8Vzzz2XvXE5AGxMKq44fPbZZ+O5557LfplbRETv3r2joKAgnnrqqXjhhRfi61//enbdV/k9261bt3jyySdj5cqVOVcp1kWNWVG/bbbZZqlqpXzUmNdcc03O1WlfvBXOumpSf6WtMSuWf/HTH0uWLKl0xWf37t1j+fLlqeZtypQpsXz58pwguSY15iGHHBK33357zvKlS5dGu3btcvr5srXsww8/HIWFhfH3v/8954tqxo8fn9Oue/fuUV5eHm+++Wa1FzlU/L+lQ4cOtRbkpaltIz4PJ7/97W/HhAkT4te//nVMnDgxzjzzzFoNLaEuuYcirMdhhx0WzZs3j3HjxlX6i9qtt94aa9eurXS/vLQKCwtj3333jXvvvTfmz5+fc4Xip59+Gtdff3107949OnfunN3mhBNOiLKysrjiiisq7W/t2rWVipEvKi4ujgULFsSf//zn7LJVq1bF7373uy81/ojI3ttj3X579+4d3bt3j9/85jexfPnyStt9+OGHEfH5L9Hi4uKYOHFizJ8/P7v+3//+d/z973//0uOqygEHHBADBw7MPqoLFCt+ga97Jdu6AVLTpk1j4MCBMXHixHj//fezy99+++147LHHctpW/AX9//7v/3KW33DDDZX2edxxx8XDDz8cr7/+eqWxVcxbRMTXv/71eP/99+Ohhx7KLlu5cmW1H5VeV9OmTSsd4w033JDzsZSKfp5//vl48cUXc8ZR3VWy6/YRkTuXL7zwQvYeoRWOO+64SJIkxowZU2kfFdsee+yx0bRp0xgzZkylcSdJEkuWLNngeNZ13HHHxUcffZT9+FdV/VY4+eST480334yLLroomjZtGieeeGKN+wOAurbPPvtEYWFh3HPPPbFgwYKcKxQLCgria1/7Wtx0002xYsWKbPgY8dV+zxYXF8eaNWtyasry8vK46aabvvRxVAST69aYHTp0iIMPPjhuueWWWLhwYaXt1q2VvmwNUxO9e/fOqTHX9/HatPVXcXFxTJ8+PWbOnJld9vHHH1ca+2GHHRbNmjWLcePG5SyvqrY54YQTYvr06VXW2EuXLo21a9dGxOfztnbt2px9lpWVVapba3KMDz74YPbelhW+Si3btGnTyGQyOfP2zjvvxMSJE3PaDR06NJo0aRKXX355pf/LVYyxuLg42rRpE7/85S9zbs9T4YvnVFppatsKJ598cnzyySdx1llnxfLly3PuAQ4bO1cownp06NAhLrvssvj5z38eBx10UAwZMiQ233zzmDZtWtx7771xxBFHxFFHHfWl99+/f//41a9+FUVFRdGzZ89sn7vsskvMmjUrRowYkdN+wIABcdZZZ8XYsWNj5syZccQRR8Rmm20Ws2fPjgcffDB++9vf5tzY+IvOOuusuPHGG2PYsGFx3nnnRefOneOee+7JfmT7y3y5RPfu3aNt27Zx8803R+vWraNly5bRp0+f2H777eO2226LwYMHx+677x6nnnpqbL311rFgwYJ48skno02bNvGXv/wlIiLGjBkTkyZNiv79+8f3v//9WLt2bdxwww2x++67p7pfY0lJSbbAqbgf0I033hht27aNtm3bxrnnnlujY2rTpk0cdNBBcdVVV8WaNWti6623jn/84x8xd+7cSm1Hjx4d//jHP+KAAw6Is88+O8rKyuLGG2+MPfbYI6cA7N27dxx33HFx3XXXxZIlS2L//fePp59+Ov7zn/9ERO7c/+pXv4onn3wy+vTpE2eeeWbstttu8fHHH8crr7wSkydPjo8//jgiIs4888y48cYb45RTTomXX345OnfuHHfddVel+xdV5xvf+EbcddddUVRUFLvttltMnz49Jk+enHNvm4iIn/zkJ3HXXXfFoEGD4rzzzouWLVvGrbfeGt26ddvg6/ONb3wjHnnkkTjmmGPiyCOPjLlz58bNN98cu+22W07QfMghh8TJJ58c119/fcyePTv70fKpU6fGIYccEueee2507949rrzyyhg5cmS88847MXTo0GjdunXMnTs3/vjHP8Z3v/vduPDCC1Mde4VTTjklfv/738cFF1wQL774YvTv3z9WrFgRkydPju9///tx9NFHZ9seeeSRsdVWW8WDDz4YgwcPrvY+pgBQn5o3bx777rtvTJ06NQoKCqJ379456/v165e9Ou6LgeJX+T07dOjQ2G+//eLHP/5xvP3229GjR4/485//nK1ZvkyN2aJFi9htt93i/vvvj5133jm23HLL2GOPPWKPPfaIm266KQ488MDo2bNnnHnmmbHDDjvE4sWLY/r06fHee+/Fv/71r4j4ajVMhSuvvDIiIt54442I+PxjsRVfevPzn/+8xsdVk/rr7rvvjsMPPzx+8IMfRMuWLeO2226LbbfdNj7++OPsnHbs2DHOO++8uOaaa2LIkCExaNCg+Ne//hWPPfZYtGvXLmfuL7roovjzn/8c3/jGN2LEiBHRu3fvWLFiRbz22mvx0EMPxTvvvBPt2rWLo446Kg444IC45JJL4p133onddtstHnnkkZx7PG7oGC+//PI49dRTo1+/fvHaa6/FPffcU+mP+V+llj3yyCPj2muvjUGDBsW3v/3t+OCDD+Kmm26KHXfcMee13XHHHeNnP/tZXHHFFdG/f/849thjo6CgIP75z39Gly5dYuzYsdGmTZsYN25cnHzyyfG1r30tTjzxxGjfvn3Mnz8//va3v8UBBxxQZUC7Pmlq2wp777137LHHHvHggw/GrrvuGl/72tdq1BfUq7r/ImnY9N19993J/vvvn7Rs2TIpKChIevTokYwZMyZZtWpVTrsnn3wyiYjkwQcfzFk+d+7cJCKS8ePH5yz/29/+lkREMnjw4JzlZ5xxRhIRye23317leG699dakd+/eSYsWLZLWrVsnPXv2TH7yk58k77//frbNgAEDkgEDBuRs99///jc58sgjkxYtWiTt27dPfvzjHycPP/xwEhHJ888/n7Pt7rvvXqnf4cOHJ926dctZ9qc//SnZbbfdkmbNmlU6xhkzZiTHHntsstVWWyUFBQVJt27dkhNOOCGZMmVKzj6efvrppHfv3knz5s2THXbYIbn55puTUaNGJWl+RFXMbVWPdce6vu2/OO733nsvOeaYY5K2bdsmRUVFyfHHH5+8//77SUQko0aNytl+ypQpyd577500b9486d69e3LbbbclP/7xj5PCwsKcditWrEjOOeecZMstt0xatWqVDB06NJk1a1YSEcmvfvWrnLaLFy9OzjnnnKRr167JZpttlnTq1Ck57LDDkltvvTWn3bx585IhQ4Ykm2++edKuXbvkvPPOSyZNmpRERPLkk0+u97g/+eST5NRTT03atWuXtGrVKikuLk7eeuutpFu3bsnw4cNz2r766qvJgAEDksLCwmTrrbdOrrjiiuT2229PIiKZO3dutt2651x5eXnyy1/+MunWrVtSUFCQ7L333slf//rXKs+jtWvXJldffXXSo0ePpHnz5kn79u2TwYMHJy+//HJOu4cffjg58MADk5YtWyYtW7ZMevTokZxzzjnJrFmzcsaR9vxduXJl8rOf/SzZfvvts3P9zW9+M5kzZ06l7b///e8nEZH84Q9/WO/cAkB9GjlyZBIRSb9+/Sqte+SRR5KISFq3bp2sXbu20vo0v2er+n364YcfJt/+9reT1q1bJ0VFRcmIESOS5557LomI5L777svZtmXLlpX6rarumzZtWrY+XLcGmzNnTnLKKacknTp1SjbbbLNk6623Tr7xjW8kDz30UM4+0tYw1amuxkz73+h1x12T+mvGjBlJ//79k4KCgmSbbbZJxo4dm1x//fVJRCSLFi3Ktlu7dm1y6aWXJp06dUpatGiRHHroocm///3vZKuttkq+973v5exz2bJlyciRI5Mdd9wxad68edKuXbukX79+yW9+85vks88+y7ZbsmRJcvLJJydt2rRJioqKkpNPPjmZMWNGlf+fWdeqVauSH//4x0nnzp2TFi1aJAcccEAyffr0Kv9vkraWreqcu/3225Oddtop+3+z8ePHV/v/hzvuuCPZe++9k4KCgmSLLbZIBgwYkDz++OM5bZ588smkuLg4KSoqSgoLC5Pu3bsnI0aMSF566aWccaQ9f9PWtkmSJFdddVUSEckvf/nL6qYVNkqZJPkSd6gHGozrrrsufvSjH8V7770XW2+9dX0Pp0EYOnRovPHGG1Xet+eLZs6cGXvvvXfcfffdcdJJJ+VpdHWnf//+UVBQEJMnT67vodSJH/3oR3H77bfHokWLUl8JCgCN1cSJE+OYY46JZ599Ng444ID6Hk6DcP7558ctt9wSy5cvX+999pYuXRpbbLFFXHnllfGzn/0sjyOsGyeffHJMnz79K92Xc2P229/+Nn70ox/FO++8E9tuu219DwdScw9FaETW/bbqVatWxS233BI77bSTMPFLWndOZ8+eHY8++mgcfPDB620X8XmY26RJk5wv3tmULVy4MOdm2w3JqlWr4u67747jjjtOmAgA61i3zqm4516bNm18hPNLWndOlyxZEnfddVcceOCBOWFidTVmRFSqRzdVDbnGTJIkbr/99hgwYIAwkU2OeyhCI3LsscfGtttuG3vttVeUlJTE3XffHW+99Vat35y6Mdlhhx1ixIgRscMOO8S8efNi3Lhx0bx58/jJT36S0+6qq66Kl19+OQ455JBo1qxZPPbYY/HYY4/Fd7/73UrfIL6pmTZtWjzyyCMxZ86cuPjii+t7OLXqgw8+iMmTJ8dDDz0US5YsifPOO6++hwQAG50f/OAH8emnn0bfvn1j9erV8cgjj8S0adPil7/8ZbRo0aK+h7dJ6tu3bxx88MGx6667xuLFi+P222+P0tLSuPTSS3Pa3X///TFhwoT4+te/Hq1atYpnn302e6/3Tf3K0FdffTUmTpwYzzzzTFx00UX1PZxatWLFivjzn/8cTz75ZLz22mvxpz/9qb6HBDUmUIRGpLi4OG67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5qV65qZq5qV65qZq5qV6DXluXJm4afuqNWlDPre/CvNSPXNTNfNSPXNTNfNSPXNTtYY8L2nrUX/+BgAAAABSEygCAAAAAKk1+kCxoKAgRo0aFQUF+f12tY2deamaeameuamaeameuamaeameuaGhcm5XzbxUz9xUzbxUz9xUzbxUz9xUzbz8T4P4UhYAAAAAID8a/RWKAAAAAEB6AkUAAAAAIDWBIgAAAACQmkARAAAAAEhNoAgAAAAApNYoAsWbbroptttuuygsLIw+ffrEiy++uN72Dz74YPTo0SMKCwujZ8+e8eijj+ZppPkxduzY2HfffaN169bRoUOHGDp0aMyaNWu920yYMCEymUzOo7CwME8jzp/Ro0dXOs4ePXqsd5uGfr5ERGy33XaV5iWTycQ555xTZfuGfL4888wzcdRRR0WXLl0ik8nExIkTc9YnSRKXXXZZdO7cOVq0aBEDBw6M2bNnb3C/Nf05tbFZ37ysWbMmLr744ujZs2e0bNkyunTpEqecckq8//77693nl3k/bmw2dL6MGDGi0jEOGjRog/vd1M+XiA3PTVU/czKZTFx99dXV7rMhnDM0XOrRXOrR6qlHq6Ye/R/1aNXUo9VTk1ZNPfrVNPhA8f77748LLrggRo0aFa+88kr06tUriouL44MPPqiy/bRp02LYsGFx+umnx4wZM2Lo0KExdOjQeP311/M88rrz9NNPxznnnBPPP/98PP7447FmzZo44ogjYsWKFevdrk2bNrFw4cLsY968eXkacX7tvvvuOcf57LPPVtu2MZwvERH//Oc/c+bk8ccfj4iI448/vtptGur5smLFiujVq1fcdNNNVa6/6qqr4vrrr4+bb745XnjhhWjZsmUUFxfHqlWrqt1nTX9ObYzWNy8rV66MV155JS699NJ45ZVX4pFHHolZs2bFkCFDNrjfmrwfN0YbOl8iIgYNGpRzjPfee+9699kQzpeIDc/NF+dk4cKFcccdd0Qmk4njjjtuvfvd1M8ZGib1aGXq0fVTj1amHv0f9WjV1KPVU5NWTT36FSUN3H777Zecc8452edlZWVJly5dkrFjx1bZ/oQTTkiOPPLInGV9+vRJzjrrrDodZ3364IMPkohInn766WrbjB8/PikqKsrfoOrJqFGjkl69eqVu3xjPlyRJkvPOOy/p3r17Ul5eXuX6xnK+RETyxz/+Mfu8vLw86dSpU3L11Vdnly1dujQpKChI7r333mr3U9OfUxu7deelKi+++GISEcm8efOqbVPT9+PGrqp5GT58eHL00UfXaD8N7XxJknTnzNFHH50ceuih623T0M4ZGg716IapR/9HPZqOevRz6tGqqUerpyatmnq05hr0FYqfffZZvPzyyzFw4MDssiZNmsTAgQNj+vTpVW4zffr0nPYREcXFxdW2bwhKSkoiImLLLbdcb7vly5dHt27domvXrnH00UfHG2+8kY/h5d3s2bOjS5cuscMOO8RJJ50U8+fPr7ZtYzxfPvvss7j77rvjtNNOi0wmU227xnK+fNHcuXNj0aJFOedEUVFR9OnTp9pz4sv8nGoISkpKIpPJRNu2bdfbribvx03VU089FR06dIhddtklzj777FiyZEm1bRvr+bJ48eL429/+FqeffvoG2zaGc4ZNi3o0HfVoLvXo+qlHq6ceTU89mktNun7q0coadKD40UcfRVlZWXTs2DFneceOHWPRokVVbrNo0aIatd/UlZeXx/nnnx8HHHBA7LHHHtW222WXXeKOO+6IP/3pT3H33XdHeXl59OvXL9577708jrbu9enTJyZMmBCTJk2KcePGxdy5c6N///6xbNmyKts3tvMlImLixImxdOnSGDFiRLVtGsv5sq6K170m58SX+Tm1qVu1alVcfPHFMWzYsGjTpk217Wr6ftwUDRo0KH7/+9/HlClT4te//nU8/fTTMXjw4CgrK6uyfWM8XyIi7rzzzmjdunUce+yx623XGM4ZNj3q0Q1Tj+ZSj26YerR66tF01KO51KQbph6trFl9D4D6dc4558Trr7++wc/09+3bN/r27Zt93q9fv9h1113jlltuiSuuuKKuh5k3gwcPzv57zz33jD59+kS3bt3igQceSPWXiMbg9ttvj8GDB0eXLl2qbdNYzhdqbs2aNXHCCSdEkiQxbty49bZtDO/HE088Mfvvnj17xp577hndu3ePp556Kg477LB6HNnG5Y477oiTTjppgzfTbwznDDRE6tFcfpZtmHqUr0I9WpmadMPUo5U16CsU27VrF02bNo3FixfnLF+8eHF06tSpym06depUo/absnPPPTf++te/xpNPPhnbbLNNjbbdbLPNYu+994633367jka3cWjbtm3svPPO1R5nYzpfIiLmzZsXkydPjjPOOKNG2zWW86Xida/JOfFlfk5tqiqKt3nz5sXjjz++3r8GV2VD78eGYIcddoh27dpVe4yN6XypMHXq1Jg1a1aNf+5ENI5zho2fenT91KMbph7NpR5dP/Xo+qlH01GT5lKPVq1BB4rNmzeP3r17x5QpU7LLysvLY8qUKTl/rfqivn375rSPiHj88cerbb8pSpIkzj333PjjH/8YTzzxRGy//fY13kdZWVm89tpr0blz5zoY4cZj+fLlMWfOnGqPszGcL180fvz46NChQxx55JE12q6xnC/bb799dOrUKeecKC0tjRdeeKHac+LL/JzaFFUUb7Nnz47JkyfHVlttVeN9bOj92BC89957sWTJkmqPsbGcL190++23R+/evaNXr1413rYxnDNs/NSjVVOPpqcezaUeXT/1aPXUo+mpSXOpR6tRv98JU/fuu+++pKCgIJkwYULy5ptvJt/97neTtm3bJosWLUqSJElOPvnk5JJLLsm2f+6555JmzZolv/nNb5J///vfyahRo5LNNtssee211+rrEGrd2WefnRQVFSVPPfVUsnDhwuxj5cqV2TbrzsuYMWOSv//978mcOXOSl19+OTnxxBOTwsLC5I033qiPQ6gzP/7xj5OnnnoqmTt3bvLcc88lAwcOTNq1a5d88MEHSZI0zvOlQllZWbLtttsmF198caV1jel8WbZsWTJjxoxkxowZSUQk1157bTJjxozst8P96le/Stq2bZv86U9/Sl599dXk6KOPTrbffvvk008/ze7j0EMPTW644Ybs8w39nNoUrG9ePvvss2TIkCHJNttsk8ycOTPn587q1auz+1h3Xjb0ftwUrG9eli1bllx44YXJ9OnTk7lz5yaTJ09Ovva1ryU77bRTsmrVquw+GuL5kiQbfi8lSZKUlJQkm2++eTJu3Lgq99EQzxkaJvVoZerR6qlHq6ce/Zx6tGrq0eqpSaumHv1qGnygmCRJcsMNNyTbbrtt0rx582S//fZLnn/++ey6AQMGJMOHD89p/8ADDyQ777xz0rx582T33XdP/va3v+V5xHUrIqp8jB8/Pttm3Xk5//zzs3PYsWPH5Otf/3ryyiuv5H/wdexb3/pW0rlz56R58+bJ1ltvnXzrW99K3n777ez6xni+VPj73/+eREQya9asSusa0/ny5JNPVvn+qTj+8vLy5NJLL006duyYFBQUJIcddlilOevWrVsyatSonGXr+zm1KVjfvMydO7fanztPPvlkdh/rzsuG3o+bgvXNy8qVK5Mjjjgiad++fbLZZpsl3bp1S84888xKRVhDPF+SZMPvpSRJkltuuSVp0aJFsnTp0ir30RDPGRou9Wgu9Wj11KPVU49+Tj1aNfVo9dSkVVOPfjWZJEmSL3t1IwAAAADQuDToeygCAAAAALVLoAgAAAAApCZQBAAAAABSEygCAAAAAKkJFAEAAACA1ASKAAAAAEBqAkUAAAAAIDWBIgAAAACQmkARAAAAAEhNoAgAAAAApCZQBAAAAABS+/+otApE3CFa0AAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 1600x1000 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABRQAAAJ1CAYAAACo6XyZAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy81sbWrAAAACXBIWXMAAA9hAAAPYQGoP6dpAABgzklEQVR4nO3deXRU5f0/8M8AkiBLUFkCiii44IqKiqKICxqoVVGrlVoF96/VVuta+60C2pbWVn8u+LXaKrTuO90UK4gKgloV6m6RIqgsKkrCIojJ/f3hydQhCdxIMpHk9TpnzmHufe59nnvnSfLhPXfuZJIkSQIAAAAAIIVmDT0AAAAAAGDDIVAEAAAAAFITKAIAAAAAqQkUAQAAAIDUBIoAAAAAQGoCRQAAAAAgNYEiAAAAAJCaQBEAAAAASE2gCAAAAACkJlCERurAAw+MAw888Gtvu/POO9ftgGpp5MiRkclk6r2fd999NzKZTIwbN67e+8qHp556KjKZTDz11FP12s+4ceMik8nEu+++m122PnMOANgwDB8+PLbaaquvvW2bNm3qdkC1VF0NU18ymUyMHDmy3vvJh3zVzNXVsusz54D6I1CEtagMtT7++ONq1++8885NOkCZP39+jBw5MmbOnNlgY3j44Yfju9/9bvTo0SM23njj2H777ePCCy+MJUuWNNiYAADy6f77749MJhOPPPJIlXW9e/eOTCYTkydPrrJuyy23jH79+uVjiLWyYsWKGDlyZL2/Qbo2kyZNilNPPTW222672HjjjaNHjx5x+umnx4IFCxpsTADfJC0aegBA/fjHP/5R733Mnz8/Ro0aFVtttVXstttu9d5fdc4888zo2rVrfP/7348tt9wyXn311RgzZkw8+uij8fLLL0erVq0aZFxNUT7mHABQ1f777x8REVOnTo2jjz46u7ysrCxee+21aNGiRTz77LNx0EEHZde999578d5778UJJ5xQq75+//vfR0VFRd0MvAYrVqyIUaNGRUQ02Jv3l156aXzyySdx3HHHxbbbbhv/+c9/YsyYMfG3v/0tZs6cGcXFxQ0yrqYoH3MOqD2BIjRSLVu2bOgh5MWDDz5YpdDs06dPDBs2LO666644/fTTG2ZgTVBTmXMA8E3TtWvX2HrrrWPq1Kk5y6dPnx5JksRxxx1XZV3l88owMq2NNtpo/Qa7gbj22mtj//33j2bN/vuhvkGDBsWAAQNizJgx8fOf/7wBR9e0NJU5BxsaH3mGOlR5z4/7778/fvGLX8QWW2wRhYWFccghh8Q777yTbXfDDTdE8+bNcz6We80110Qmk4kLLrggu6y8vDzatm0bl156aXZZRUVFXHfddbHTTjtFYWFhdO7cOc4666z49NNPc8ZS3f3s5s6dG0ceeWS0bt06OnXqFD/+8Y/j8ccfr/Gee2+88UYcdNBBsfHGG8fmm28eV199dc6x7rXXXhERccopp0Qmk6lyX5Xnn38+Bg0aFEVFRbHxxhvHgAED4tlnn63Sz9SpU2OvvfaKwsLC6NmzZ9xyyy1rPc9rHueaKt+Zf/PNN1Pv56teeeWVGD58ePTo0SMKCwujuLg4Tj311Fi8eHGVtk899VTsueeeOWOv7v6Pn332WfzoRz+KDh06RNu2bePII4+MDz74oNp763zwwQdx6qmnRufOnaOgoCB22mmnuP3226v0/f7778eQIUNyXs9Vq1alOsa5c+fGD37wg9h+++2jVatWsdlmm8Vxxx1X7f2EXn/99Tj44IOjVatWscUWW8TPf/7zat8lXnPOff7553HFFVdEnz59oqioKFq3bh39+/ev9iNXFRUVcf3118cuu+wShYWF0bFjxxg0aFC8+OKLOe3uvPPO6NOnT7Rq1So23XTTOOGEE+K9996rMo6dd955rfO30sqVK2PkyJGx3XbbRWFhYXTp0iWOOeaYmD17diRJEltttVUcddRR1W5XVFQUZ511Vk2nGADyav/9948ZM2bEZ599ll327LPPxk477RSDBw+O5557Lufv97PPPhuZTCb222+/7LI0f2eru5/d4sWL46STTop27dpF+/btY9iwYfGvf/2rxnvuffDBBzFkyJBo06ZNdOzYMS666KIoLy+PiC/v1dexY8eIiBg1alS2xvxqvfTWW2/Fd77zndh0002jsLAw9txzz/jLX/5SpZ+0NUx1DjjggJwwsXLZpptu+rVrzNrUX6+88koMGDAgZ+xjx46tcv/HioqKGDlyZHTt2jU23njjOOigg+KNN96IrbbaKoYPH56zzyVLlsT5558f3bp1i4KCgthmm23i17/+dZVzsmTJkhg+fHgUFRVlX8+0txP65JNP4qKLLopddtkl2rRpE+3atYvBgwfHv/71rypt09ay1c253/72t9GvX7/Y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ft9+++0kIpKbb745Z/2RRx6ZbLXVVjnzGwAa0uuvv55ERHLVVVclSZIkq1evTlq3bp388Y9/TJIkSTp37pzcdNNNSZIkSVlZWdK8efPkjDPOSJKkdn9nhw0blnTv3j37/KGHHkoiIrnuuuuyy8rLy5ODDz64So01bNiwJCKSK6+8Mqef3XffPenTp0/2+UcffVSlRqp0yCGHJLvsskuycuXK7LKKioqkX79+ybbbbptdVpsaJq2rrroqiYhk0qRJqdqveQxp668f/vCHSSaTSWbMmJFdtnjx4mTTTTfNGfvChQuTFi1aJEOGDMnZ58iRI5OISIYNG5Yz9tatW1epj3/yk58kzZs3T+bNm5ckSZKMHz8+iYjk6quvzrb54osvkv79+1db969p5cqVSXl5ec6yOXPmJAUFBTmve21q2TXnXJJUPZeff/55svPOOycHH3xwdtmsWbOSZs2aJUcffXSVMVXWcEuXLk3at2+f/VmotHDhwqSoqChnedr5m6a2XbJkSVJYWJhceumlOet/9KMfJa1bt06WLVtWZVv4pvGRZ6gHp5xySs795Cqv3vvPf/4TERHNmjWLfv36xTPPPBMRX340d/HixfGTn/wkkiSJ6dOnR8SXVy3uvPPO2XeEH3jggSgqKopDDz00Pv744+yjT58+0aZNmxqvNoyImDBhQmy++eZx5JFHZpcVFhbGGWecUW37Nm3a5Fx91bJly9h7772zx7A2M2fOjFmzZsX3vve9WLx4cXacy5cvj0MOOSSeeeaZqKioiPLy8nj88cdjyJAhseWWW2a332GHHb72Zf5333133HbbbXHhhRfGtttu+7X28dV3rleuXBkff/xx7LPPPhER8fLLL0fEl+9OTpw4MYYMGZJ9pzUiYptttsleAVdpwoQJERHxgx/8IGf5D3/4w5znSZLEQw89FEcccUQkSZLzGpeUlERpaWm2/0cffTS6dOkS3/nOd7Lbb7zxxnHmmWfW+hhXr14dixcvjm222Sbat2+f7aOyn3322Sd7RWlERMeOHePEE09cZx/NmzfP/hxUVFTEJ598El988UXsueeeOX089NBDkclkYsSIEVX2UXk16MMPPxwVFRVx/PHH55yX4uLi2HbbbavM/TTz96GHHooOHTpUeR2+2u92220Xffv2jbvuuiu77pNPPonHHnssTjzxxCofbQeAhrLDDjvEZpttlr034r/+9a9Yvnx59tMj/fr1y956Zvr06VFeXp69f2Jt/85+1YQJE2KjjTbKqSmbNWsW55xzTo3b/M///E/O8/79+6eqMT/55JN48skn4/jjj4+lS5dmx7l48eIoKSmJWbNmxQcffBAR61fDVOeZZ56JUaNGxfHHHx8HH3zw19pH2vprwoQJse++++Z8mmPTTTetMvZJkybFF198sc4aM+LL/0f0798/Ntlkk5zXeODAgVFeXp79f8mjjz4aLVq0yLnarnnz5tXuszoFBQXZj4qXl5fH4sWLo02bNrH99ttXqTHrqpb99NNPo7S0NPr375/Tx/jx46OioiKuuOKKKh9fr6zhnnjiiViyZEkMHTo057w0b948+vbtW+3cX9f8TVPbFhUVxVFHHRX33HNPJEkSEV+er/vuuy/7MXD4pvORZ1hP1QUKXw3HIiI22WSTiIic+xz2798/Ro4cGZ999llMmTIlunTpEnvssUf07t07pkyZEoceemhMnTo1jj/++Ow2s2bNitLS0ujUqVO1Y/nwww9rHOfcuXOjZ8+eVca7zTbbVNt+iy22qNJ2k002iVdeeaXGPr46zohY60cjSktLY9WqVfHZZ59VG/xtv/328eijj66zr6+aMmVKnHbaaVFSUhK/+MUvctZ99NFHOfc2adOmTbRp06ba/XzyyScxatSouPfee6uc09LS0oj48lx/9tln1Z6/NZfNnTs3mjVrFltvvfVa23300UexZMmSuPXWW+PWW2+tdmyV45k7d25ss802VV6j7bffvtrt1vTZZ5/F6NGjY+zYsfHBBx9kC5mvHmNlP3379q2yfdp+/vjHP8Y111wTb731VqxevTq7/KvnYvbs2dG1a9ecjxSvadasWZEkSY0h8Zof9U8zf2fPnh3bb799tGix9j+FJ598cpx77rkxd+7c6N69ezzwwAOxevXqOOmkk9a6HQDkUyaTyb5hXVFREc8++2x06tQpW2/069cvxowZExGRDRYrA8Xa/p39qrlz50aXLl2yH9etVFONWXk/ua/aZJNNqtwPvDrvvPNOJEkSl19+eVx++eXVtvnwww9j8803X+8a5qveeuutOProo2PnnXeOP/zhDznrPvnkk/j888+zz1u1ahVFRUXV7qc29de+++5bZfvqaszqlm+66abZ/39UmjVrVrzyyivV3ponIrfG7NKlS5U6Oe15q7x34P/93//FnDlzcurvyo/XV/azPrXs3/72t/j5z38eM2fOzLnv4lf3N3v27GjWrFnsuOOONe6n8v8tNYXE7dq1y3meZv6mqW0jvqwx77vvvpgyZUoccMABMXHixFi0aJEakw2GQBHWorCwMCIi5+bWX7VixYpsm69q3rx5te2/WjTsv//+sXr16pg+fXpMmTIlexVj//79Y8qUKfHWW2/FRx99lF0e8eUf6E6dOuVcLfVVNRUIX0eaY6hJ5Y2df/Ob3+S8s/pVbdq0Sf0FImn861//iiOPPDJ23nnnePDBB6uERHvttVe26IqIGDFiRJUvQ6l0/PHHx7Rp0+Liiy+O3XbbLdq0aRMVFRUxaNCg1Dfy/joq9/3973+/xjC28v5B6+uHP/xhjB07Ns4///zYd999o6ioKDKZTJxwwgl1dox33nlnDB8+PIYMGRIXX3xxdOrUKZo3bx6jR4+O2bNn12pfFRUVkclk4rHHHqt2bq5Z9K7P/F3TCSecED/+8Y/jrrvuip/+9Kdx5513xp577vm1/kMCAPVp//33j7/+9a/x6quvZu+fWKlfv35x8cUXxwcffBBTp06Nrl27Ro8ePSKi9n9n10dNf6PTqKxRLrrooho/zVJTkPl1vffee3HYYYdFUVFRPProo9G2bduc9cccc0w8/fTT2efDhg2r9otoIvJTf9WkoqIiDj300LjkkkuqXb/ddtvVST+//OUv4/LLL49TTz01rrrqqth0002jWbNmcf7559fZMU6ZMiWOPPLIOOCAA+L//u//okuXLrHRRhvF2LFj4+67767VvirHdMcdd0RxcXGV9Wv+n2J95u+aSkpKonPnznHnnXfGAQccEHfeeWcUFxfHwIED66wPqE8CRViL7t27R0TE22+/Hd26dctZt2LFimyB8XXsvffe0bJly5gyZUpMmTIlLr744oj48tvjfv/738ekSZOyzyv17NkzJk6cGPvtt1+tbyjdvXv3eOONNyJJkpx37r767dO1VdPHPXv27BkRX76jt7Y/iB07doxWrVpl3xn8qrfffjv1OGbPnh2DBg2KTp06xaOPPlpt0XvXXXflBMOVBfSaPv3005g0aVKMGjUqrrjiiuzyNcfYqVOnKCwsrPb8rbmse/fuUVFREXPmzMl553/Ndh07doy2bdtGeXn5OguJ7t27x2uvvVbl9Ux73h588MEYNmxYXHPNNdllK1eurPINft27d//ar8+DDz4YPXr0iIcffjhnjGt+/KNnz57x+OOPV/nikzXbJEkSW2+9dZ0VvD179oznn38+Vq9evdYrLzbddNM4/PDD46677ooTTzwxnn322eyNywHgm6TyisOpU6fGs88+m/0yt4iIPn36REFBQTz11FPx/PPPx7e+9a3suvX5O9u9e/eYPHlyrFixIucqxfqoMSvrt4022ihVrbS+NebixYvjsMMOi1WrVsWkSZOiS5cuVdpcc801OVenffVWOGuqTf2VtsasXP7VT38sXry4yhWfPXv2jGXLlqU6b5MmTYply5bl1NS1qTEPOuiguO2223KWL1myJOfLbNanln3ooYeisLAwHn/88Zwvqhk7dmxOu549e0ZFRUW88cYbNV7kUPn/lk6dOtVZkJemto34Mpz83ve+F+PGjYtf//rXMX78+DjjjDPqNLSE+uQeirAWhxxySLRs2TJuvvnmKu+o3XrrrfHFF19UuV9eWoWFhbHXXnvFPffcE/Pmzcu5QvGzzz6LG264IXr27JlTuBx//PFRXl4eV111VZX9ffHFF1WKka8qKSmJDz74IP7yl79kl61cuTJ+//vff63xR0T23h5r9tunT5/o2bNn/Pa3v41ly5ZV2e6jjz6KiC//iJaUlMT48eNj3rx52fVvvvlmPP7446nGsHDhwjjssMOiWbNm8fjjj9d4leZ+++0XAwcOzD5qChQr/4CveSXbmgFS8+bNY+DAgTF+/PiYP39+dvk777wTjz32WE7bynfQ/+///i9n+Y033lhln8cee2w89NBD8dprr1UZW+V5i4j41re+FfPnz48HH3wwu2zFihU1flR6Tc2bN69yjDfeeGPOx1Iq+3nuuefihRdeyBlHTVfJrtlHRO65fP7557P3CK107LHHRpIkMWrUqCr7qNz2mGOOiebNm8eoUaOqjDtJkli8ePE6x7OmY489Nj7++OPsx7+q67fSSSedFG+88UZcfPHF0bx58zjhhBNq3R8A1Lc999wzCgsL46677ooPPvgg5wrFgoKC2GOPPeKmm26K5cuXZ8PHiPX7O1tSUhKrV6/OqSkrKiripptu+trHURlMrlljdurUKQ488MC45ZZbYsGCBVW2W7NW+ro1TETE8uXL41vf+lZ88MEH8eijj9b4cfA+ffrk1Jhr+3ht2vqrpKQkpk+fHjNnzswu++STT6qM/ZBDDokWLVrEzTffnLO8utrm+OOPj+nTp1dbYy9ZsiS++OKLiPjyvH3xxRc5+ywvL69St9bmGB944IHsvS0rrU8t27x588hkMjnn7d13343x48fntBsyZEg0a9Ysrrzyyir/l6scY0lJSbRr1y5++ctf5tyep9JX51RaaWrbSieddFJ8+umncdZZZ8WyZcty7gEO33SuUIS16NSpU1xxxRXxs5/9LA444IA48sgjY+ONN45p06bFPffcE4cddlgcccQRX3v//fv3j1/96ldRVFQUu+yyS7bP7bffPt5+++0YPnx4TvsBAwbEWWedFaNHj46ZM2fGYYcdFhtttFHMmjUrHnjggbj++utzbmz8VWeddVaMGTMmhg4dGuedd1506dIl7rrrruxHtr/Ol0v07Nkz2rdvH7/73e+ibdu20bp16+jbt29svfXW8Yc//CEGDx4cO+20U5xyyimx+eabxwcffBCTJ0+Odu3axV//+teIiBg1alRMmDAh+vfvHz/4wQ/iiy++iBtvvDF22mmnVPdrHDRoUPznP/+JSy65JKZOnZq9EXlEROfOnePQQw+t1TG1a9cuDjjggLj66qtj9erVsfnmm8c//vGPmDNnTpW2I0eOjH/84x+x3377xdlnnx3l5eUxZsyY2HnnnXMKwD59+sSxxx4b1113XSxevDj22WefePrpp+Pf//53ROSe+1/96lcxefLk6Nu3b5xxxhmx4447xieffBIvv/xyTJw4MT755JOIiDjjjDNizJgxcfLJJ8dLL70UXbp0iTvuuKPK/Ytq8u1vfzvuuOOOKCoqih133DGmT58eEydOzLm3TUTEJZdcEnfccUcMGjQozjvvvGjdunXceuut0b1793W+Pt/+9rfj4YcfjqOPPjoOP/zwmDNnTvzud7+LHXfcMSdoPuigg+Kkk06KG264IWbNmpX9aPmUKVPioIMOinPPPTd69uwZP//5z+Oyyy6Ld999N4YMGRJt27aNOXPmxCOPPBJnnnlmXHTRRamOvdLJJ58cf/rTn+KCCy6IF154Ifr37x/Lly+PiRMnxg9+8IM46qijsm0PP/zw2GyzzeKBBx6IwYMH13gfUwBoSC1btoy99torpkyZEgUFBdGnT5+c9f369cteHffVQHF9/s4OGTIk9t5777jwwgvjnXfeiV69esVf/vKXbM3ydWrMVq1axY477hj33XdfbLfddrHpppvGzjvvHDvvvHPcdNNNsf/++8cuu+wSZ5xxRvTo0SMWLVoU06dPj/fffz/+9a9/RcT61TARESeeeGK88MILceqpp8abb74Zb775ZnZdmzZtYsiQIbU+rtrUX3feeWcceuih8cMf/jBat24df/jDH2LLLbeMTz75JHtOO3fuHOedd15cc801ceSRR8agQYPiX//6Vzz22GPRoUOHnHN/8cUXx1/+8pf49re/HcOHD48+ffrE8uXL49VXX40HH3ww3n333ejQoUMcccQRsd9++8VPfvKTePfdd2PHHXeMhx9+OOcej+s6xiuvvDJOOeWU6NevX7z66qtx1113VXkzf31q2cMPPzyuvfbaGDRoUHzve9+LDz/8MG666abYZpttcl7bbbbZJv73f/83rrrqqujfv38cc8wxUVBQEP/85z+ja9euMXr06GjXrl3cfPPNcdJJJ8Uee+wRJ5xwQnTs2DHmzZsXf//732O//farNqBdmzS1baXdd989dt5553jggQdihx12iD322KNWfUGDqv8vkoYN35133pnss88+SevWrZOCgoKkV69eyahRo5KVK1fmtJs8eXISEckDDzyQs3zOnDlJRCRjx47NWf73v/89iYhk8ODBOctPP/30JCKS2267rdrx3HrrrUmfPn2SVq1aJW3btk122WWX5JJLLknmz5+fbTNgwIBkwIABOdv95z//SQ4//PCkVatWSceOHZMLL7wweeihh5KISJ577rmcbXfaaacq/Q4bNizp3r17zrI///nPyY477pi0aNGiyjHOmDEjOeaYY5LNNtssKSgoSLp3754cf/zxyaRJk3L28fTTTyd9+vRJWrZsmfTo0SP53e9+l4wYMSJJ8ysqImp8rHn81anutXn//feTo48+Omnfvn1SVFSUHHfcccn8+fOTiEhGjBiRs/2kSZOS3XffPWnZsmXSs2fP5A9/+ENy4YUXJoWFhTntli9fnpxzzjnJpptumrRp0yYZMmRI8vbbbycRkfzqV7/Kabto0aLknHPOSbp165ZstNFGSXFxcXLIIYckt956a067uXPnJkceeWSy8cYbJx06dEjOO++8ZMKECUlEJJMnT17rcX/66afJKaecknTo0CFp06ZNUlJSkrz11ltJ9+7dk2HDhuW0feWVV5IBAwYkhYWFyeabb55cddVVyW233ZZERDJnzpxsuzXnXEVFRfLLX/4y6d69e1JQUJDsvvvuyd/+9rdq59EXX3yR/OY3v0l69eqVtGzZMunYsWMyePDg5KWXXspp99BDDyX7779/0rp166R169ZJr169knPOOSd5++23c8aRdv6uWLEi+d///d9k6623zp7r73znO8ns2bOrbP+DH/wgiYjk7rvvXuu5BYCGdNlllyURkfTr16/KuocffjiJiKRt27bJF198UWV9mr+z1f09/eijj5Lvfe97Sdu2bZOioqJk+PDhybPPPptERHLvvffmbNu6desq/VZX902bNi1bH65Zg82ePTs5+eSTk+Li4mSjjTZKNt988+Tb3/528uCDD+bsI20NU53u3bvXWGOuefw1WXPctam/ZsyYkfTv3z8pKChItthii2T06NHJDTfckEREsnDhwmy7L774Irn88suT4uLipFWrVsnBBx+cvPnmm8lmm22W/M///E/OPpcuXZpcdtllyTbbbJO0bNky6dChQ9KvX7/kt7/9bfL5559n2y1evDg56aSTknbt2iVFRUXJSSedlMyYMaPa/8+saeXKlcmFF16YdOnSJWnVqlWy3377JdOnT6/2/yZpa9nq5txtt92WbLvtttn/m40dO7bG/z/cfvvtye67754UFBQkm2yySTJgwIDkiSeeyGkzefLkpKSkJCkqKkoKCwuTnj17JsOHD09efPHFnHGknb9pa9skSZKrr746iYjkl7/8ZU2nFb6RMknyNe5QDzQa1113Xfz4xz+O999/PzbffPOGHk6jMGTIkHj99dervW/PV82cOTN23333uPPOO+PEE0/M0+jqT//+/aOgoCAmTpzY0EOpFz/+8Y/jtttui4ULF6a+EhQAmqrx48fH0UcfHVOnTo399tuvoYfTKJx//vlxyy23xLJly9Z6n70lS5bEJptsEj//+c/jf//3f/M4wvpx0kknxfTp09frvpzfZNdff338+Mc/jnfffTe23HLLhh4OpOYeitCErPlt1StXroxbbrkltt12W2Hi17TmOZ01a1Y8+uijceCBB661XcSXYW6zZs1yvnhnQ7ZgwYKcm203JitXrow777wzjj32WGEiAKxhzTqn8p577dq18xHOr2nNc7p48eK44447Yv/9988JE2uqMSOiSj26oWrMNWaSJHHbbbfFgAEDhIlscNxDEZqQY445JrbccsvYbbfdorS0NO6888546623Ut+cmqp69OgRw4cPjx49esTcuXPj5ptvjpYtW8Yll1yS0+7qq6+Ol156KQ466KBo0aJFPPbYY/HYY4/FmWeeWeUbxDc006ZNi4cffjhmz54dl156aUMPp059+OGHMXHixHjwwQdj8eLFcd555zX0kADgG+eHP/xhfPbZZ7HvvvvGqlWr4uGHH45p06bFL3/5y2jVqlVDD2+DtO+++8aBBx4YO+ywQyxatChuu+22KCsri8svvzyn3X333Rfjxo2Lb33rW9GmTZuYOnVq9l7vG/qVoa+88kqMHz8+nnnmmbj44osbejh1avny5fGXv/wlJk+eHK+++mr8+c9/bughQa0JFKEJKSkpiT/84Q9x1113RXl5eey4445x7733xne/+92GHtoGa9CgQXHPPffEwoULo6CgIPbdd9/45S9/WeWbAPv16xdPPPFEXHXVVbFs2bLYcsstY+TIkY3iYyi///3v47HHHovzzz8/TjnllIYeTp1644034sQTT4xOnTrFDTfcELvttltDDwkAvnEOPvjguOaaa+Jvf/tbrFy5MrbZZpu48cYbc758gtr51re+FQ8++GDceuutkclkYo899ojbbrutyidbdt1112jRokVcffXVUVZWlv2ilp///OcNNPK68/DDD8eNN94YJ5xwQlx22WUNPZw69dFHH8X3vve9aN++ffz0pz+NI488sqGHBLXmHooAAAAAQGruoQgAAAAApCZQBAAAAABSaxT3UKyoqIj58+dH27ZtI5PJNPRwAABqLUmSWLp0aXTt2jWaNfOe74ZITQoAbMhqU482ikBx/vz5G/y3pAIARES89957scUWWzT0MPga1KQAQGOQph5tFIFi27ZtI+LLA27Xrl1e+iwqKspLP5VKS0vz2l9E4z/Gxn581L18z5l8M0frnjlDbZSVlUW3bt2ydQ0bnsrX7u1Zb+TtdXzig2vy0k+lQze/MK/9RUSsnjQ/r/1tdEjXvPa3/N638tpf6xN65bU/6t4zO+T3G5x3PO3AvPbX4aL989pfU9Dqo4q89vf54s/y2l95r9Z57a8xW7p0aWy/7Y6p6phGEShWfqSkXbt2eQsU862xHtdXNfZjbOzHx4bPHKW2zJn64aOyG67K165t27Z5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7a8RTEUA+NrUMxu+ytdw/sL3vIZ16IXFY/Pa396bnZLX/gDgm6KsrCy6FndLVY+6QhEAAAAASE2gCAAAAACkJlAEAAAAAFITKAIAAAAAqQkUAQAAAIDUBIoAAAAAQGoCRQAAAAAgNYEiAAAAAJCaQBEAAAAASE2gCAAAAACkVutA8ZlnnokjjjgiunbtGplMJsaPH5+zPkmSuOKKK6JLly7RqlWrGDhwYMyaNWud+73ppptiq622isLCwujbt2+88MILtR0aAABNgHoUAKBh1TpQXL58efTu3TtuuummatdfffXVccMNN8Tvfve7eP7556N169ZRUlISK1eurHGf9913X1xwwQUxYsSIePnll6N3795RUlISH374YW2HBwBAI6ceBQBoWJkkSZKvvXEmE4888kgMGTIkIr58N7hr165x4YUXxkUXXRQREaWlpdG5c+cYN25cnHDCCdXup2/fvrHXXnvFmDFjIiKioqIiunXrFj/84Q/jJz/5yTrHUVZWFkVFRVFaWhrt2rX7uofDGjKZTF77W4+pCAAbPPXM1/NNqUcj/vsazl/4ntewDr2weGxe+9t7s1Py2h8AfFOUlZVF1+JuqerROr2H4pw5c2LhwoUxcODA7LKioqLo27dvTJ8+vdptPv/883jppZdytmnWrFkMHDiwxm1WrVoVZWVlOQ8AAMhXPRqhJgUAmq46DRQXLlwYERGdO3fOWd65c+fsujV9/PHHUV5eXqttRo8eHUVFRdlHt27d6mD0AABs6PJVj0aoSQGApmuD/Jbnyy67LEpLS7OP9957r6GHBABAE6MmBQCaqjoNFIuLiyMiYtGiRTnLFy1alF23pg4dOkTz5s1rtU1BQUG0a9cu5wEAAPmqRyPUpABA01WngeLWW28dxcXFMWnSpOyysrKyeP7552PfffetdpuWLVtGnz59crapqKiISZMm1bgNAABURz0KAFD/WtR2g2XLlsU777yTfT5nzpyYOXNmbLrpprHlllvG+eefHz//+c9j2223ja233jouv/zy6Nq1a/ab9yIiDjnkkDj66KPj3HPPjYiICy64IIYNGxZ77rln7L333nHdddfF8uXL45RTfMMaAAC51KMAAA2r1oHiiy++GAcddFD2+QUXXBAREcOGDYtx48bFJZdcEsuXL48zzzwzlixZEvvvv39MmDAhCgsLs9vMnj07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AKQmUAQAAAAAUhMoAgAAAACpCRQBAAAAgNQEigAAAABAagJFAAAAACA1gSIAAAAAkJpAEQAAAABITaAIAAAAAKQmUAQAAAAAUhMoAgAAAACptWjoAfDNlSRJQw8B1iqTyeS1Pz8TAJB/ye7tG3oIsFblTy3Ka3/ND+yc1/4AquMKRQAAAAAgNYEiAAAAAJCaQBEAAAAASE2gCAAAAACkJlAEAAAAAFITKAIAAAAAqQkUAQAAAIDUBIoAAAAAQGoCRQAAAAAgNYEiAAAAAJBarQPFZ555Jo444ojo2rVrZDKZGD9+fM764cOHRyaTyXkMGjRonfu96aabYquttorCwsLo27dvvPDCC7UdGgAATYB6FACgYdU6UFy+fHn07t07brrpphrbDBo0KBYsWJB93HPPPWvd53333RcXXHBBjBgxIl5++eXo3bt3lJSUxIcffljb4QEA0MipRwEAGlaL2m4wePDgGDx48FrbFBQURHFxcep9XnvttXHGGWfEKaecEhERv/vd7+Lvf/973H777fGTn/ykSvtVq1bFqlWrss/LyspS9wUAwIbtm1CPRqhJAYCmq17uofjUU09Fp06dYvvtt4+zzz47Fi9eXGPbzz//PF566aUYOHDgfwfVrFkMHDgwpk+fXu02o0ePjqKiouyjW7dudX4MAABsuOq7Ho1QkwIATVedB4qDBg2KP/3pTzFp0qT49a9/HU8//XQMHjw4ysvLq23/8ccfR3l5eXTu3DlneefOnWPhwoXVbnPZZZdFaWlp9vHee+/V9WEAALCBykc9GqEmBQCarlp/5HldTjjhhOy/d9lll9h1112jZ8+e8dRTT8UhhxxSJ30UFBREQUFBnewLAIDGJR/1aISaFABouurlI89f1aNHj+jQoUO888471a7v0KFDNG/ePBYtWpSzfNGiRbW67w0AAFRHPQoAULfqPVB8//33Y/HixdGlS5dq17ds2TL69OkTkyZNyi6rqKiISZMmxb777lvfwwMAoJFTjwIA1K1aB4rLli2LmTNnxsyZMyMiYs6cOTFz5syYN29eLFu2LC6++OJ47rnn4t13341JkybFUUcdFdtss02UlJRk93HIIYfEmDFjss8vuOCC+P3vfx9//OMf480334yzzz47li9fnv2WPQAAqKQeBQBoWLW+h+KLL74YBx10UPb5BRdcEBERw4YNi5tvvjleeeWV+OMf/xhLliyJrl27xmGHHRZXXXVVzv1lZs+eHR9//HH2+Xe/+9346KOP4oorroiFCxfGbrvtFhMmTKhyY2wAAFCPAgA0rEySJElDD2J9lZWVRVFRUZSWlka7du0aejhAnmQymbz21wh+XQLfYOqZDV/lazh/4XteQ2hCyp9atO5Gdaj5gd7oAOpHWVlZdC3ulqoerfd7KAIAAAAAjYdAEQAAAABITaAIAAAAAKQmUAQAAAAAUhMoAgAAAACpCRQBAAAAgNRaNPQASCeTyeS9zyRJ8t4n1Ea+52i+fw6bws+gcwqwYZnz2dN573PrVgPy3ifURvMDO+e1v3+X3J7X/rZ7/NS89tcQrpr8rbz2d/lBj+a1P6gPrlAEAAAAAFITKAIAAAAAqQkUAQAAAIDUBIoAAAAAQGoCRQAAAAAgNYEiAAAAAJCaQBEAAAAASE2gCAAAAACkJlAEAAAAAFITKAIAAAAAqQkUAQAAAIDUBIoAAAAAQGoCRQAAAAAgNYEiAAAAAJCaQBEAAAAASE2gCAAAAACkJlAEAAAAAFITKAIAAAAAqQkUAQAAAIDUBIoAAAAAQGoCRQAAAAAgNYEiAAAAAJCaQBEAAAAASE2gCAAAAACkJlAEAAAAAFITKAIAAAAAqQkUAQAAAIDUWjT0AEgnSZKGHgI0eX4O655zCrBh2brVgIYeAjR52z1+akMPodG5/KBHG3oIsMFxhSIAAAAAkJpAEQAAAABITaAIAAAAAKQmUAQAAAAAUhMoAgAAAACpCRQBAAAAgNQEigAAAABAagJFAAAAACA1gSIAAAAAkJpAEQAAAABITaAIAAAAAKQmUAQAAAAAUhMoAgAAAACpCRQBAAAAgNQEigAAAABAagJFAAAAACA1gSIAAAAAkJpAEQAAAABITaAIAAAAAKQmUAQAAAAAUhMoAgAAAACpCRQBAAAAgNQEigAAAABAagJFAAAAACC1WgeKzzzzTBxxxBHRtWvXyGQyMX78+Jz1mUym2sdvfvObGvc5cuTIKu179epV64MBAKDxU48CADSsWgeKy5cvj969e8dNN91U7foFCxbkPG6//fbIZDJx7LHHrnW/O+20U852U6dOre3QAABoAtSjAAANq0VtNxg8eHAMHjy4xvXFxcU5z//85z/HQQcdFD169Fj7QFq0qLItAACsST0KANCw6vUeiosWLYq///3vcdppp62z7axZs6Jr167Ro0ePOPHEE2PevHk1tl21alWUlZXlPAAAYE31VY9GqEkBgKar1lco1sYf//jHaNu2bRxzzDFrbde3b98YN25cbL/99rFgwYIYNWpU9O/fP1577bVo27ZtlfajR4+OUaNG1dewU8lkMnntL0mSvPbHhi/fczQi//O0IY6xMfN7BmiM6qsejfhm1KQzltyT1/52bz80r/2x4fvdy8Pz3uf/7DEur/2teODfee3vL7vcktf+9jhvp7z2t93jp+a1P+DrqdcrFG+//fY48cQTo7CwcK3tBg8eHMcdd1zsuuuuUVJSEo8++mgsWbIk7r///mrbX3bZZVFaWpp9vPfee/UxfAAANnD1VY9GqEkBgKar3q5QnDJlSrz99ttx33331Xrb9u3bx3bbbRfvvPNOtesLCgqioKBgfYcIAEAjVp/1aISaFABouurtCsXbbrst+vTpE7179671tsuWLYvZs2dHly5d6mFkAAA0BepRAID6UetAcdmyZTFz5syYOXNmRETMmTMnZs6cmXPT6rKysnjggQfi9NNPr3YfhxxySIwZMyb7/KKLLoqnn3463n333Zg2bVocffTR0bx58xg61D1aAADIpR4FAGhYtf7I84svvhgHHXRQ9vkFF1wQERHDhg2LcePGRUTEvffeG0mS1FiAzZ49Oz7++OPs8/fffz+GDh0aixcvjo4dO8b+++8fzz33XHTs2LG2wwMAoJFTjwIANKxaB4oHHnjgOr8J9Mwzz4wzzzyzxvXvvvtuzvN77723tsMAAKCJUo8CADSsev2WZwAAAACgcREoAgAAAACpCRQBAAAAgNQEigAAAABAagJFAAAAACA1gSIAAAAAkJpAEQAAAABITaAIAAAAAKQmUAQAAAAAUhMoAgAAAACpCRQBAAAAgNQEigAAAABAagJFAAAAACA1gSIAAAAAkJpAEQAAAABITaAIAAAAAKQmUAQAAAAAUhMoAgAAAACpCRQBAAAAgNQEigAAAABAagJFAAAAACC1TJIkSUMPYn2VlZVFUVFRlJaWRrt27Rp6OAAAtaae2fBVvobzF77nNQQANjhlZWXRtbhbqnrUFYoAAAAAQGoCRQAAAAAgNYEiAAAAAJCaQBEAAAAASE2gCAAAAACkJlAEAAAAAFITKAIAAAAAqQkUAQAAAIDUBIoAAAAAQGoCRQAAAAAgNYEiAAAAAJCaQBEAAAAASE2gCAAAAACkJlAEAAAAAFITKAIAAAAAqQkUAQAAAIDUBIoAAAAAQGoCRQAAAAAgNYEiAAAAAJCaQBEAAAAASE2gCAAAAACkJlAEAAAAAFITKAIAAAAAqQkUAQAAAIDUBIoAAAAAQGoCRQAAAAAgtRYNPYC6kCRJRESUlZU18EgAAL6eyjqmsq5hw1P52i1durSBRwIAUHuVNUyaerRRBIqVB9ytW7cGHgkAwPpZunRpFBUVNfQw+Boqa9Ltt92xgUcCAPD1palHM0kjeBu8oqIi5s+fH23bto1MJlOrbcvKyqJbt27x3nvvRbt27epphBse56V6zkvNnJvqOS81c26q57zUrLGfmyRJYunSpdG1a9do1sxdaTZEX7cmbexz++tyXmrm3FTPeamZc1M956Vmzk31Gvt5qU092iiuUGzWrFlsscUW67WPdu3aNcrJsL6cl+o5LzVzbqrnvNTMuame81KzxnxuXJm4YVvfmrQxz+314bzUzLmpnvNSM+emes5LzZyb6jXm85K2HvX2NwAAAACQmkARAAAAAEityQeKBQUFMWLEiCgoKGjooXyjOC/Vc15q5txUz3mpmXNTPeelZs4NjZW5XT3npWbOTfWcl5o5N9VzXmrm3FTPefmvRvGlLAAAAABAfjT5KxQBAAAAgPQEigAAAABAagJFAAAAACA1gSIAAAAAkJpAEQAAAABIrUkEijfddFNstdVWUVhYGH379o0XXnhhre0feOCB6NWrVxQWFsYuu+wSjz76aJ5Gmh+jR4+OvfbaK9q2bRudOnWKIUOGxNtvv73WbcaNGxeZTCbnUVhYmKcR58/IkSOrHGevXr3Wuk1jny8REVtttVWV85LJZOKcc86ptn1jni/PPPNMHHHEEdG1a9fIZDIxfvz4nPVJksQVV1wRXbp0iVatWsXAgQNj1qxZ69xvbX9PfdOs7bysXr06Lr300thll12idevW0bVr1zj55JNj/vz5a93n1/l5/KZZ13wZPnx4lWMcNGjQOve7oc+XiHWfm+p+52QymfjNb35T4z4bw5yh8VKP5lKP1kw9Wj316H+pR6unHq2ZmrR66tH10+gDxfvuuy8uuOCCGDFiRLz88svRu3fvKCkpiQ8//LDa9tOmTYuhQ4fGaaedFjNmzIghQ4bEkCFD4rXXXsvzyOvP008/Heecc04899xz8cQTT8Tq1avjsMMOi+XLl691u3bt2sWCBQuyj7lz5+ZpxPm100475Rzn1KlTa2zbFOZLRMQ///nPnHPyxBNPRETEcccdV+M2jXW+LF++PHr37h033XRTteuvvvrquOGGG+J3v/tdPP/889G6desoKSmJlStX1rjP2v6e+iZa23lZsWJFvPzyy3H55ZfHyy+/HA8//HC8/fbbceSRR65zv7X5efwmWtd8iYgYNGhQzjHec889a91nY5gvEes+N189JwsWLIjbb789MplMHHvssWvd74Y+Z2ic1KNVqUfXTj1alXr0v9Sj1VOP1kxNWj316HpKGrm99947Oeecc7LPy8vLk65duyajR4+utv3xxx+fHH744TnL+vbtm5x11ln1Os6G9OGHHyYRkTz99NM1thk7dmxSVFSUv0E1kBEjRiS9e/dO3b4pzpckSZLzzjsv6dmzZ1JRUVHt+qYyXyIieeSRR7LPKyoqkuLi4uQ3v/lNdtmSJUuSgoKC5J577qlxP7X9PfVNt+Z5qc4LL7yQREQyd+7cGtvU9ufxm6668zJs2LDkqKOOqtV+Gtt8SZJ0c+aoo45KDj744LW2aWxzhsZDPbpu6tH/Uo+mox79knq0eurRmqlJq6cerb1GfYXi559/Hi+99FIMHDgwu6xZs2YxcODAmD59erXbTJ8+Pad9RERJSUmN7RuD0tLSiIjYdNNN19pu2bJl0b179+jWrVscddRR8frrr+djeHk3a9as6Nq1a/To0SNOPPHEmDdvXo1tm+J8+fzzz+POO++MU089NTKZTI3tmsp8+ao5c+bEwoULc+ZEUVFR9O3bt8Y58XV+TzUGpaWlkclkon379mttV5ufxw3VU089FZ06dYrtt98+zj777Fi8eHGNbZvqfFm0aFH8/e9/j9NOO22dbZvCnGHDoh5NRz2aSz26durRmqlH01OP5lKTrp16tKpGHSh+/PHHUV5eHp07d85Z3rlz51i4cGG12yxcuLBW7Td0FRUVcf7558d+++0XO++8c43ttt9++7j99tvjz3/+c9x5551RUVER/fr1i/fffz+Po61/ffv2jXHjxsWECRPi5ptvjjlz5kT//v1j6dKl1bZvavMlImL8+PGxZMmSGD58eI1tmsp8WVPl616bOfF1fk9t6FauXBmXXnppDB06NNq1a1dju9r+PG6IBg0aFH/6059i0qRJ8etf/zqefvrpGDx4cJSXl1fbvinOl4iIP/7xj9G2bds45phj1tquKcwZNjzq0XVTj+ZSj66berRm6tF01KO51KTrph6tqkVDD4CGdc4558Rrr722zs/077vvvrHvvvtmn/fr1y922GGHuOWWW+Kqq66q72HmzeDBg7P/3nXXXaNv377RvXv3uP/++1O9E9EU3HbbbTF48ODo2rVrjW2aynyh9lavXh3HH398JEkSN99881rbNoWfxxNOOCH771122SV23XXX6NmzZzz11FNxyCGHNODIvlluv/32OPHEE9d5M/2mMGegMVKP5vK7bN3Uo6wP9WhVatJ1U49W1aivUOzQoUM0b948Fi1alLN80aJFUVxcXO02xcXFtWq/ITv33HPjb3/7W0yePDm22GKLWm270UYbxe677x7vvPNOPY3um6F9+/ax3Xbb1XicTWm+RETMnTs3Jk6cGKeffnqttmsq86Xyda/NnPg6v6c2VJXF29y5c+OJJ55Y67vB1VnXz2Nj0KNHj+jQoUONx9iU5kulKVOmxNtvv13r3zsRTWPO8M2nHl079ei6qUdzqUfXTj26durRdNSkudSj1WvUgWLLli2jT58+MWnSpOyyioqKmDRpUs67VV+177775rSPiHjiiSdqbL8hSpIkzj333HjkkUfiySefjK233rrW+ygvL49XX301unTpUg8j/OZYtmxZzJ49u8bjbArz5avGjh0bnTp1isMPP7xW2zWV+bL11ltHcXFxzpwoKyuL559/vsY58XV+T22IKou3WbNmxcSJE2OzzTar9T7W9fPYGLz//vuxePHiGo+xqcyXr7rtttuiT58+0bt371pv2xTmDN986tHqqUfTU4/mUo+unXq0ZurR9NSkudSjNWjY74Spf/fee29SUFCQjBs3LnnjjTeSM888M2nfvn2ycOHCJEmS5KSTTkp+8pOfZNs/++yzSYsWLZLf/va3yZtvvpmMGDEi2WijjZJXX321oQ6hzp199tlJUVFR8tRTTyULFizIPlasWJFts+Z5GTVqVPL4448ns2fPTl566aXkhBNOSAoLC5PXX3+9IQ6h3lx44YXJU089lcyZMyd59tlnk4EDByYdOnRIPvzwwyRJmuZ8qVReXp5sueWWyaWXXlplXVOaL0uXLk1mzJiRzJgxI4mI5Nprr01mzJiR/Xa4X/3qV0n79u2TP//5z8krr7ySHHXUUcnWW2+dfPbZZ9l9HHzwwcmNN96Yfb6u31MbgrWdl88//zw58sgjky222CKZOXNmzu+dVatWZfex5nlZ18/jhmBt52Xp0qXJRRddlEyfPj2ZM2dOMnHixGSPPfZItt1222TlypXZfTTG+ZIk6/5ZSpIkKS0tTTbeeOPk5ptvrnYfjXHO0DipR6tSj9ZMPVoz9eiX1KPVU4/WTE1aPfXo+mn0gWKSJMmNN96YbLnllknLli2TvffeO3nuueey6wYMGJAMGzYsp/3999+fbLfddknLli2TnXbaKfn73/+e5xHXr4io9jF27NhsmzXPy/nnn589h507d06+9a1vJS+//HL+B1/Pvvvd7yZdunRJWrZsmWy++ebJd7/73eSdd97Jrm+K86XS448/nkRE8vbbb1dZ15Tmy+TJk6v9+ak8/oqKiuTyyy9POnfunBQUFCSHHHJIlXPWvXv3ZMSIETnL1vZ7akOwtvMyZ86cGn/vTJ48ObuPNc/Lun4eNwRrOy8rVqxIDjvssKRjx47JRhttlHTv3j0544wzqhRhjXG+JMm6f5aSJEluueWWpFWrVsmSJUuq3UdjnDM0XurRXOrRmqlHa6Ye/ZJ6tHrq0ZqpSaunHl0/mSRJkq97dSMAAAAA0LQ06nsoAgAAAAB1S6AIAAAAAKQmUAQAAAAAUhMoAgAAAACpCRQBAAAAgNQEigAAAABAagJFAAAAACA1gSIAAAAAkJpAEQAAAABITaAIAAAAAKQmUAQAAAAAUvv/8CmHLScglwkAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 1600x1000 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Initiating the random DAG\n",
    "average_degrees_per_lagged_node = [2 for _ in range(number_of_lags)]\n",
    "B_true = data_generation.simulate_time_unrolled_dag(d, k * d, graph_type, number_of_lags, average_degrees_per_lagged_node) # random graph simulation with avg degree = k\n",
    "\n",
    "# Initializing weights on the adjacency matrix\n",
    "W_true = data_generation.simulate_parameter(np.array(B_true), w_ranges=((-b, -a), (a, b))) # sampling uniformly the weights\n",
    "W_true = list(W_true)\n",
    "\n",
    "for i, (B, W) in enumerate(zip(B_true, W_true)):\n",
    "    # Visualizing the adjacency matrix\n",
    "    fig, (ax1, ax2) = plt.subplots(1, 2)\n",
    "    fig.set_size_inches(16, 10)\n",
    "    title = 'adjacency matrix' if i==0 else  '{}-lagged adjacency'.format(i)\n",
    "\n",
    "    ax1.imshow(B, cmap='Greys') # blue = non-zero\n",
    "    ax1.set_title('Unweighted {}'.format(title))\n",
    "\n",
    "    ax2.imshow(W, cmap='PiYG') # green = positive, pink = negative\n",
    "    ax2.set_title(\"Weighted {}\".format(title))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "8c4bd531",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(10, 1000, 20)\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABP4AAAFbCAYAAABF6UA6AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy81sbWrAAAACXBIWXMAAA9hAAAPYQGoP6dpAAA2aklEQVR4nO3de5xVZdk38Gs4zXCYGVAYDoKAeEBRQDFJDVFAkfBUKZlmHns0MOWpx9TeV8GsCDEzzcgswTK18kklU5GDaB7whOcDohKiCAjJcB5gZr1/+LJznBmYQVgDi+/389mf3Gvuta5737P25uo3a++dlyRJEgAAAABApjSo7wkAAAAAAFuf4A8AAAAAMkjwBwAAAAAZJPgDAAAAgAwS/AEAAABABgn+AAAAACCDBH8AAAAAkEGCPwAAAADIIMEfAAAAAGSQ4A8AAAAyrEuXLnHWWWfV9zSAeiD4A3ImTpwYeXl5uVujRo1it912i7POOis++OCDbVr79ddfj9GjR8e//vWvOu334osvxje/+c3o1KlT5Ofnxy677BKDBg2KCRMmRHl5+baZLAAAn9tne8+CgoLo0KFDDB48OG644YZYsWLFFh/7ySefjNGjR8eyZcu23oQBdkCN6nsCwPbnRz/6UXTt2jXWrl0bM2fOjIkTJ8bjjz8er776ahQUFGyTmq+//npcddVVceSRR0aXLl1qtc/vfve7uOCCC6Jt27ZxxhlnxF577RUrVqyIadOmxbnnnhsffvhh/PCHP9wm8wUAYOvY2HuuX78+Fi5cGDNmzIiRI0fGddddF5MmTYqePXvW+ZhPPvlkXHXVVXHWWWdFy5Ytt/6kAXYQgj+giiFDhsTBBx8cERHnnXdetG7dOsaOHRuTJk2KYcOG1fPsPjFz5sy44IIL4tBDD40HHnggCgsLcz8bOXJkPPfcc/Hqq6/W4wwBAKiNT/eeERGXX355TJ8+PY477rg44YQT4o033oimTZvW4wwBdlze6gtsVr9+/SIi4p133qm0ffr06dGvX79o3rx5tGzZMk488cR44403quz/wgsvxJAhQ6KoqChatGgRAwcOjJkzZ+Z+PnHixDjllFMiIuKoo47Kvd1jxowZNc7pqquuiry8vPjTn/5UKfTb6OCDD670OSbXXnttHHbYYbHrrrtG06ZNo0+fPnH33XdX2udf//pX5OXlxcSJE6scLy8vL0aPHp27v2LFihg5cmR06dIl8vPzo6SkJI4++uiYNWtWpf2efvrpOPbYY6O4uDiaNWsW/fv3jyeeeKLSmNoeCwBgZzFgwIC44oorYt68eXH77bfntr/88stx1llnxR577BEFBQXRrl27OOecc2Lp0qW5MaNHj45LLrkkIiK6du2a6y03fqTMhAkTYsCAAVFSUhL5+fmx3377xfjx42s1r4ULF8bZZ58dHTt2jPz8/Gjfvn2ceOKJlT6u5r777ouhQ4dGhw4dIj8/P7p16xZXX311lY+hOfLII2P//fePl19+Ofr37x/NmjWLPffcM9ejPvroo9G3b99o2rRp7LPPPjF16tRK+48ePTry8vLizTffjGHDhkVRUVHsuuuucfHFF8fatWs3+1iWLVsWI0eOzH1kzp577hljx46NioqKSuPuuuuu6NOnTxQWFkZRUVEccMAB8ctf/rJW6wXUP1f8AZu1sZFp1apVbtvUqVNjyJAhsccee8To0aNjzZo1ceONN8bhhx8es2bNyr1d97XXXot+/fpFUVFR/OAHP4jGjRvHzTffHEceeWSumTniiCPioosuihtuuCF++MMfxr777hsRkfvfz1q9enVMmzYtjjjiiNh9991r9Rh++ctfxgknnBCnn356rFu3Lu6666445ZRT4v7774+hQ4fWeU0uuOCCuPvuu+PCCy+M/fbbL5YuXRqPP/54vPHGG3HQQQdFxCfB6JAhQ6JPnz4xatSoaNCgQa7R/Oc//xmHHHJIrY8FALCzOeOMM+KHP/xhPPzww/Htb387IiKmTJkS7777bpx99tnRrl27eO211+K3v/1tvPbaazFz5szIy8uLr371q/HWW2/FnXfeGb/4xS+idevWERHRpk2biIgYP3589OjRI0444YRo1KhR/P3vf4/hw4dHRUVFjBgxYpNz+trXvhavvfZafPe7340uXbrE4sWLY8qUKfHee+/l+t+JEydGixYt4nvf+160aNEipk+fHldeeWUsX748xo0bV+l4H3/8cRx33HFx6qmnximnnBLjx4+PU089Nf70pz/FyJEj44ILLojTTjstxo0bFyeffHLMnz+/yh+9hw0bFl26dIkxY8bEzJkz44YbboiPP/44/vCHP9T4OFavXh39+/ePDz74IM4///zYfffd48knn4zLL788Pvzww7j++utz6/2Nb3wjBg4cGGPHjo2IiDfeeCOeeOKJuPjii2v3iwTqVwLw/02YMCGJiGTq1KnJRx99lMyfPz+5++67kzZt2iT5+fnJ/Pnzc2N79+6dlJSUJEuXLs1te+mll5IGDRok3/rWt3LbTjrppKRJkybJO++8k9u2YMGCpLCwMDniiCNy2/76178mEZE88sgjm53nSy+9lEREcvHFF9f6sa1evbrS/XXr1iX7779/MmDAgNy2uXPnJhGRTJgwocr+EZGMGjUqd7+4uDgZMWJEjfUqKiqSvfbaKxk8eHBSUVFRaR5du3ZNjj766FofCwAgizb2ns8++2yNY4qLi5MDDzwwd/+zPV2SJMmdd96ZRETy2GOP5baNGzcuiYhk7ty5VcZXd4zBgwcne+yxxybn+/HHHycRkYwbN26T46o7/vnnn580a9YsWbt2bW5b//79k4hI7rjjjty2N998M4mIpEGDBsnMmTNz2ydPnlylTx01alQSEckJJ5xQqdbw4cOTiEheeuml3LbOnTsnZ555Zu7+1VdfnTRv3jx56623Ku172WWXJQ0bNkzee++9JEmS5OKLL06KioqSDRs2bPIxA9svb/UFqhg0aFC0adMmOnXqFCeffHI0b948Jk2aFB07doyIiA8//DBefPHFOOuss2KXXXbJ7dezZ884+uij44EHHoiIiPLy8nj44YfjpJNOij322CM3rn379nHaaafF448/HsuXL6/z/DbuU91bfGvy6c+F+fjjj6O0tDT69eu3xW+nbdmyZTz99NOxYMGCan/+4osvxpw5c+K0006LpUuXxpIlS2LJkiWxatWqGDhwYDz22GO5t1Fs7lgAADurFi1aVPp230/3dGvXro0lS5bEF7/4xYiIWvd1nz5GaWlpLFmyJPr37x/vvvtulJaWbnK/Jk2axIwZM+Ljjz+u1fFXrFgRS5YsiX79+sXq1avjzTffrPL4Tj311Nz9ffbZJ1q2bBn77rtv9O3bN7d943+/++67Vep99irF7373uxERuZ68On/961+jX79+0apVq1yfumTJkhg0aFCUl5fHY489FhGf9KmrVq2KKVOm1HgsYPsm+AOquOmmm2LKlClx9913x5e//OVYsmRJ5Ofn534+b968iPikMfmsfffdNxdwffTRR7F69eoax1VUVMT8+fPrPL+ioqKIiEpN4Obcf//98cUvfjEKCgpil112iTZt2sT48eM32dxtyjXXXBOvvvpqdOrUKQ455JAYPXp0pUZszpw5ERFx5plnRps2bSrdfve730VZWVmu9uaOBQCws1q5cmWlP/b++9//josvvjjatm0bTZs2jTZt2kTXrl0jImrd1z3xxBMxaNCg3OdUt2nTJn74wx9u9hj5+fkxduzYePDBB6Nt27ZxxBFHxDXXXBMLFy6sNO61116Lr3zlK1FcXBxFRUXRpk2b+OY3v1nt8Tt27Bh5eXmVthUXF0enTp2qbIuIagPHvfbaq9L9bt26RYMGDSp97uBnzZkzJx566KEqfeqgQYMiImLx4sURETF8+PDYe++9Y8iQIdGxY8c455xz4qGHHqrxuMD2x2f8AVUccsghuW9WO+mkk+JLX/pSnHbaaTF79uxo0aJFPc8uYs8994xGjRrFK6+8Uqvx//znP+OEE06II444In79619H+/bto3HjxjFhwoS44447cuM+23Rt9NkPYo745LNU+vXrF/fcc088/PDDMW7cuBg7dmz87W9/iyFDhuSu5hs3blz07t272uNuXMvNHQsAYGf0/vvvR2lpaey55565bcOGDYsnn3wyLrnkkujdu3e0aNEiKioq4thjj63ypRTVeeedd2LgwIHRvXv3uO6666JTp07RpEmTeOCBB+IXv/jFZo8xcuTIOP744+Pee++NyZMnxxVXXBFjxoyJ6dOnx4EHHhjLli2L/v37R1FRUfzoRz+Kbt26RUFBQcyaNSsuvfTSKsdv2LBhtXVq2p4kyWYfY0097adVVFTE0UcfHT/4wQ+q/fnee+8dERElJSXx4osvxuTJk+PBBx+MBx98MCZMmBDf+ta34rbbbttsHaD+Cf6ATWrYsGGMGTMmjjrqqPjVr34Vl112WXTu3DkiImbPnl1l/JtvvhmtW7eO5s2bR0FBQTRr1qzGcQ0aNMj9NbM2DcpGzZo1iwEDBsT06dNj/vz5Vf4i+ln/+7//GwUFBTF58uRKVy5OmDCh0riNX16ybNmySts3XuH4We3bt4/hw4fH8OHDY/HixXHQQQfFT37ykxgyZEh069YtIj65OnHjX043ZVPHAgDYGf3xj3+MiIjBgwdHxCdXu02bNi2uuuqquPLKK3PjNr7T4tNq6i3//ve/R1lZWUyaNKnSl8Q98sgjtZ5Xt27d4vvf/358//vfjzlz5kTv3r3j5z//edx+++0xY8aMWLp0afztb3+LI444IrfP3Llza338upozZ07uqseIiLfffjsqKipyXzZS02NYuXJlrfrUJk2axPHHHx/HH398VFRUxPDhw+Pmm2+OK664olIoC2yfvNUX2KwjjzwyDjnkkLj++utj7dq10b59++jdu3fcdtttlUKyV199NR5++OH48pe/HBGfhIbHHHNM3HfffZXearBo0aK444474ktf+lLubbvNmzePiKqhW01GjRoVSZLEGWecEStXrqzy8+effz73V8iGDRtGXl5epSv3/vWvf8W9995baZ+ioqJo3bp17jNNNvr1r39d6X55eXmVt2mUlJREhw4doqysLCIi+vTpE926dYtrr7222vl99NFHtT4WAMDOZvr06XH11VdH165d4/TTT4+I/1wF99mr3jZ+A+2n1dRbVneM0tLSKn8Qrs7q1atj7dq1lbZ169YtCgsLc31bdcdft25dlX5ya7rpppsq3b/xxhsjIjb5B+Rhw4bFU089FZMnT67ys2XLlsWGDRsiImLp0qWVftagQYPo2bNnRIReFXYQrvgDauWSSy6JU045JSZOnBgXXHBBjBs3LoYMGRKHHnponHvuubFmzZq48cYbo7i4OEaPHp3b78c//nFMmTIlvvSlL8Xw4cOjUaNGcfPNN0dZWVlcc801uXG9e/eOhg0bxtixY6O0tDTy8/NjwIABUVJSUu18DjvssLjpppti+PDh0b179zjjjDNir732ihUrVsSMGTNi0qRJ8eMf/zgiIoYOHRrXXXddHHvssXHaaafF4sWL46abboo999wzXn755UrHPe+88+JnP/tZnHfeeXHwwQfHY489Fm+99ValMStWrIiOHTvGySefHL169YoWLVrE1KlT49lnn42f//znEfFJU/S73/0uhgwZEj169Iizzz47dtttt/jggw/ikUceiaKiovj73/9eq2MBAGTZgw8+GG+++WZs2LAhFi1aFNOnT48pU6ZE586dY9KkSVFQUBARn/yRduPn6q1fvz522223ePjhh6u9mq5Pnz4REfF//s//iVNPPTUaN24cxx9/fBxzzDG5K9jOP//8WLlyZdxyyy1RUlISH3744Sbn+dZbb8XAgQNj2LBhsd9++0WjRo3innvuiUWLFuW+oOOwww6LVq1axZlnnhkXXXRR5OXlxR//+MdavUV3S82d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tWrVJvcrKiqKDz/8MHebN29eSjNOV48ePSo9zscff7zGsTvD+RIR8eyzz1ZakylTpkRExCmnnFLjPlk9X1atWhW9evWKm266qdqfX3PNNXHDDTfEb37zm3j66aejefPmMXjw4Fi7dm2Nx6zr69T2aFPrsnr16pg1a1ZcccUVMWvWrPjb3/4Ws2fPjhNOOGGzx63L83F7tblzJiLi2GOPrfQ477zzzk0eM+vnTERUWo8PP/wwbr311sjLy4uvfe1rmzxuFs4Zskc/Wj09ac30o9XTk35CP1ozPWn19KPV049+Tsl24pBDDklGjBiRu19eXp506NAhGTNmTLXjhw0blgwdOrTStr59+ybnn3/+Np1nfVq8eHESEcmjjz5a45gJEyYkxcXF6U2qnowaNSrp1atXrcfvjOdLkiTJxRdfnHTr1i2pqKio9uc7y/kSEck999yTu19RUZG0a9cuGTduXG7bsmXLkvz8/OTOO++s8Th1fZ3a3n12XarzzDPPJBGRzJs3r8YxdX0+7giqW5szzzwzOfHEE+t0nJ3xnDnxxBOTAQMGbHJMFs8ZskE/Wjt60k/oR2tPT6of3RQ9afX0o9XTj9bddnHF37p16+L555+PQYMG5bY1aNAgBg0aFE899VS1+zz11FOVxkdEDB48uMbxWVBaWhoREbvssssmx61cuTI6d+4cnTp1ihNPPDFee+21NKaXujlz5kSHDh1ijz32iNNPPz3ee++9GsfujOfLunXr4vbbb49zzjkn8vLyahy3s5wvnzZ37txYuHBhpXOiuLg4+vbtW+M5sSWvU1lQWloaeXl50bJly02Oq8vzcUc2Y8aMKCkpiX322Se+853vxNKlS2scuzOeM4sWLYp//OMfce6552527M5yzrDj0I/Wnp70P/Sjm6cnrZ5+tG70pP+hH900/WhV20Xwt2TJkigvL4+2bdtW2t62bdtYuHBhtfssXLiwTuN3dBUVFTFy5Mg4/PDDY//9969x3D777BO33npr3HfffXH77bdHRUVFHHbYYfH++++nONttr2/fvjFx4sR46KGHYvz48TF37tzo169frFixotrxO9v5EhFx7733xrJly+Kss86qcczOcr581sbfe13OiS15ndrRrV27Ni699NL4xje+EUVFRTWOq+vzcUd17LHHxh/+8IeYNm1ajB07Nh599NEYMmRIlJeXVzt+ZzxnbrvttigsLIyvfvWrmxy3s5wz7Fj0o7WjJ/0P/Wjt6Emrpx+tPT3pf+hHN08/WlWj+p4AtTNixIh49dVXN/ue80MPPTQOPfTQ3P3DDjss9t1337j55pvj6quv3tbTTM2QIUNy/92zZ8/o27dvdO7cOf7yl7/UKtnfGfz+97+PIUOGRIcOHWocs7OcL9Td+vXrY9iwYZEkSYwfP36TY3eW5+Opp56a++8DDjggevbsGd26dYsZM2bEwIED63Fm249bb701Tj/99M1+IPvOcs5AFulJ/8NrWe3oSfk89KSV6Uc3Tz9a1XZxxV/r1q2jYcOGsWjRokrbFy1aFO3atat2n3bt2tVp/I7swgsvjPvvvz8eeeSR6NixY532bdy4cRx44IHx9ttvb6PZbR9atmwZe++9d42Pc2c6XyIi5s2bF1OnTo3zzjuvTvvtLOfLxt97Xc6JLXmd2lFtbLDmzZsXU6ZM2eRfVquzuedjVuyxxx7RunXrGh/nznTORET885//jNmzZ9f5dSdi5zln2L7pRzdPT7pp+tGq9KQ1049unp508/SjlelHq7ddBH9NmjSJPn36xLRp03LbKioqYtq0aZX+8vNphx56aKXxERFTpkypcfyOKEmSuPDCC+Oee+6J6dOnR9euXet8jPLy8njllVeiffv222CG24+VK1fGO++8U+Pj3BnOl0+bMGFClJSUxNChQ+u0385yvnTt2jXatWtX6ZxYvnx5PP300zWeE1vyOrUj2thgzZkzJ6ZOnRq77rprnY+xuedjVrz//vuxdOnSGh/nznLObPT73/8++vTpE7169arzvjvLOcP2TT9aMz1p7ehHq9KT1kw/uml60trRj1amH61B/X63yH/cddddSX5+fjJx4sTk9ddfT/7rv/4radmyZbJw4cIkSZLkjDPOSC677LLc+CeeeCJp1KhRcu211yZvvPFGMmrUqKRx48bJK6+8Ul8PYav7zne+kxQXFyczZsxIPvzww9xt9erVuTGfXZerrroqmTx5cvLOO+8kzz//fHLqqacmBQUFyWuvvVYfD2Gb+f73v5/MmDEjmTt3bvLEE08kgwYNSlq3bp0sXrw4SZKd83zZqLy8PNl9992TSy+9tMrPdqbzZcWKFckLL7yQvPDCC0lEJNddd13ywgsv5L4J7Gc/+1nSsmXL5L777ktefvnl5MQTT0y6du2arFmzJneMAQMGJDfeeGPu/uZep3YEm1qXdevWJSeccELSsWPH5MUXX6z0ulNWVpY7xmfXZXPPxx3FptZmxYoVyf/8z/8kTz31VDJ37txk6tSpyUEHHZTstddeydq1a3PH2NnOmY1KS0uTZs2aJePHj6/2GFk9Z8ge/Wj19KTV049ump5UP7opetLq6Uerpx/9fLab4C9JkuTGG29Mdt9996RJkybJIYccksycOTP3s/79+ydnnnlmpfF/+ctfkr333jtp0qRJ0qNHj+Qf//hHyjPetiKi2tuECRNyYz67LiNHjsytYdu2bZMvf/nLyaxZs9Kf/Db29a9/PWnfvn3SpEmTZLfddku+/vWvJ2+//Xbu5zvj+bLR5MmTk4hIZs+eXeVnO9P58sgjj1T7/Nn4+CsqKpIrrrgiadu2bZKfn58MHDiwypp17tw5GTVqVKVtm3qd2hFsal3mzp1b4+vOI488kjvGZ9dlc8/HHcWm1mb16tXJMccck7Rp0yZp3Lhx0rlz5+Tb3/52lYZpZztnNrr55puTpk2bJsuWLav2GFk9Z8gm/WhVetLq6Uc3TU+qH90UPWn19KPV049+PnlJkiRberUgAAAAALB92i4+4w8AAAAA2LoEfwAAAACQQYI/AAAAAMggwR8AAAAAZJDgDwAAAAAySPAHAAAAABkk+AMAAACADBL8AQAAAEAGCf4AAAAAIIMEfwAAAACQQYI/AAAAAMig/wfhaaXlCi/9yAAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 1600x1000 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# X = ut.simulate_nonlinear_sem(B_true, n, sem_type, d, number_of_lags)\n",
    "# Wtrue = [W_true[i * d: (i + 1) * d, -d:] for i in range(number_of_lags + 1)]\n",
    "X, C_true = data_generation.sparse_input_sem(W_true, series_length, n=N, sparsity=sparsity, std=noise_std,\n",
    "                                      noise_type=noise_type, sparsity_type=sparsity_type)\n",
    "X_vis = X[0,]\n",
    "C_true_vis = C_true[0,]\n",
    "# X = X[0,]\n",
    "# C_true = C_true[0,]\n",
    "\n",
    "# Visualizing the root causes and the data \n",
    "fig, (ax1, ax2) = plt.subplots(1, 2)\n",
    "fig.set_size_inches(16, 10)\n",
    "\n",
    "# Picking the first 10 samples for visualization purposes\n",
    "ax1.imshow(C_true_vis[:10], cmap='Blues') # blue = non-zero\n",
    "ax1.set_title('Root Causes')\n",
    "\n",
    "ax2.imshow(X_vis[:10], cmap='Blues') # green = positive, pink = negative\n",
    "ax2.set_title(\"Data samples\")\n",
    "\n",
    "print(X.shape)\n",
    "\n",
    "W_true = np.concatenate(W_true, axis=1)\n",
    "B_true = np.concatenate(B_true, axis=1)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ae2c2a0f",
   "metadata": {},
   "source": [
    "## Causal Discovery"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "2165c989",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/pmisiakos/Desktop/causal-learning-time-series/experiments/utils.py:339: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  X = torch.tensor(X).reshape(n, d * T)\n",
      "/Users/pmisiakos/Desktop/causal-learning-time-series/sparserc/spinsvar.py:51: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  self.X_past = torch.tensor(utils.X_past(X, self.p, device), device=device, dtype=dtype)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([10, 1000, 60])\n",
      "Epoch: 0. Regression Loss=214.568, LogDet(I-B_0)=0.144 Sparsity=0.040, Acyclicity=0.059, Total = 107.311\n",
      "Epoch: 10. Regression Loss=212.473, LogDet(I-B_0)=0.317 Sparsity=0.038, Acyclicity=0.054, Total = 106.170\n",
      "Epoch: 20. Regression Loss=210.325, LogDet(I-B_0)=0.402 Sparsity=0.037, Acyclicity=0.050, Total = 105.049\n",
      "Epoch: 30. Regression Loss=208.151, LogDet(I-B_0)=0.402 Sparsity=0.036, Acyclicity=0.048, Total = 103.959\n",
      "Epoch: 40. Regression Loss=205.985, LogDet(I-B_0)=0.333 Sparsity=0.036, Acyclicity=0.047, Total = 102.909\n",
      "Epoch: 50. Regression Loss=203.865, LogDet(I-B_0)=0.203 Sparsity=0.035, Acyclicity=0.047, Total = 101.913\n",
      "Epoch: 60. Regression Loss=201.838, LogDet(I-B_0)=0.026 Sparsity=0.035, Acyclicity=0.049, Total = 100.990\n",
      "Epoch: 70. Regression Loss=199.952, LogDet(I-B_0)=-0.182 Sparsity=0.035, Acyclicity=0.052, Total = 100.153\n",
      "Epoch: 80. Regression Loss=198.218, LogDet(I-B_0)=-0.394 Sparsity=0.034, Acyclicity=0.056, Total = 99.396\n",
      "Epoch: 90. Regression Loss=196.611, LogDet(I-B_0)=-0.594 Sparsity=0.034, Acyclicity=0.060, Total = 98.697\n",
      "Epoch: 100. Regression Loss=195.119, LogDet(I-B_0)=-0.776 Sparsity=0.034, Acyclicity=0.065, Total = 98.046\n",
      "Epoch: 110. Regression Loss=193.729, LogDet(I-B_0)=-0.958 Sparsity=0.034, Acyclicity=0.069, Total = 97.446\n",
      "Epoch: 120. Regression Loss=192.423, LogDet(I-B_0)=-1.141 Sparsity=0.034, Acyclicity=0.073, Total = 96.889\n",
      "Epoch: 130. Regression Loss=191.186, LogDet(I-B_0)=-1.319 Sparsity=0.034, Acyclicity=0.078, Total = 96.364\n",
      "Epoch: 140. Regression Loss=190.009, LogDet(I-B_0)=-1.489 Sparsity=0.033, Acyclicity=0.083, Total = 95.865\n",
      "Epoch: 150. Regression Loss=188.877, LogDet(I-B_0)=-1.654 Sparsity=0.033, Acyclicity=0.089, Total = 95.387\n",
      "Epoch: 160. Regression Loss=187.785, LogDet(I-B_0)=-1.812 Sparsity=0.033, Acyclicity=0.095, Total = 94.926\n",
      "Epoch: 170. Regression Loss=186.729, LogDet(I-B_0)=-1.960 Sparsity=0.033, Acyclicity=0.102, Total = 94.479\n",
      "Epoch: 180. Regression Loss=185.703, LogDet(I-B_0)=-2.102 Sparsity=0.032, Acyclicity=0.109, Total = 94.043\n",
      "Epoch: 190. Regression Loss=184.706, LogDet(I-B_0)=-2.237 Sparsity=0.032, Acyclicity=0.117, Total = 93.620\n",
      "Epoch: 200. Regression Loss=183.726, LogDet(I-B_0)=-2.379 Sparsity=0.031, Acyclicity=0.126, Total = 93.210\n",
      "Epoch: 210. Regression Loss=182.767, LogDet(I-B_0)=-2.527 Sparsity=0.031, Acyclicity=0.137, Total = 92.815\n",
      "Epoch: 220. Regression Loss=181.836, LogDet(I-B_0)=-2.672 Sparsity=0.030, Acyclicity=0.150, Total = 92.434\n",
      "Epoch: 230. Regression Loss=180.932, LogDet(I-B_0)=-2.815 Sparsity=0.030, Acyclicity=0.164, Total = 92.067\n",
      "Epoch: 240. Regression Loss=180.061, LogDet(I-B_0)=-2.953 Sparsity=0.029, Acyclicity=0.178, Total = 91.714\n",
      "Epoch: 250. Regression Loss=179.230, LogDet(I-B_0)=-3.080 Sparsity=0.028, Acyclicity=0.192, Total = 91.376\n",
      "Epoch: 260. Regression Loss=178.442, LogDet(I-B_0)=-3.199 Sparsity=0.028, Acyclicity=0.207, Total = 91.055\n",
      "Epoch: 270. Regression Loss=177.705, LogDet(I-B_0)=-3.302 Sparsity=0.027, Acyclicity=0.221, Total = 90.752\n",
      "Epoch: 280. Regression Loss=177.034, LogDet(I-B_0)=-3.387 Sparsity=0.027, Acyclicity=0.234, Total = 90.471\n",
      "Epoch: 290. Regression Loss=176.448, LogDet(I-B_0)=-3.442 Sparsity=0.026, Acyclicity=0.245, Total = 90.217\n",
      "Epoch: 300. Regression Loss=175.961, LogDet(I-B_0)=-3.464 Sparsity=0.026, Acyclicity=0.253, Total = 89.992\n",
      "Epoch: 310. Regression Loss=175.567, LogDet(I-B_0)=-3.455 Sparsity=0.026, Acyclicity=0.257, Total = 89.794\n",
      "Epoch: 320. Regression Loss=175.256, LogDet(I-B_0)=-3.419 Sparsity=0.025, Acyclicity=0.258, Total = 89.621\n",
      "Epoch: 330. Regression Loss=175.018, LogDet(I-B_0)=-3.365 Sparsity=0.025, Acyclicity=0.256, Total = 89.473\n",
      "Epoch: 340. Regression Loss=174.836, LogDet(I-B_0)=-3.304 Sparsity=0.025, Acyclicity=0.253, Total = 89.348\n",
      "Epoch: 350. Regression Loss=174.686, LogDet(I-B_0)=-3.243 Sparsity=0.025, Acyclicity=0.248, Total = 89.237\n",
      "Epoch: 360. Regression Loss=174.575, LogDet(I-B_0)=-3.175 Sparsity=0.025, Acyclicity=0.241, Total = 89.141\n",
      "Epoch: 370. Regression Loss=174.504, LogDet(I-B_0)=-3.101 Sparsity=0.025, Acyclicity=0.233, Total = 89.061\n",
      "Epoch: 380. Regression Loss=174.490, LogDet(I-B_0)=-3.012 Sparsity=0.025, Acyclicity=0.222, Total = 88.998\n",
      "Epoch: 390. Regression Loss=174.521, LogDet(I-B_0)=-2.908 Sparsity=0.024, Acyclicity=0.208, Total = 88.947\n",
      "Epoch: 400. Regression Loss=174.573, LogDet(I-B_0)=-2.798 Sparsity=0.025, Acyclicity=0.194, Total = 88.904\n",
      "Epoch: 410. Regression Loss=174.640, LogDet(I-B_0)=-2.685 Sparsity=0.025, Acyclicity=0.180, Total = 88.867\n",
      "Epoch: 420. Regression Loss=174.712, LogDet(I-B_0)=-2.572 Sparsity=0.025, Acyclicity=0.166, Total = 88.833\n",
      "Epoch: 430. Regression Loss=174.787, LogDet(I-B_0)=-2.464 Sparsity=0.025, Acyclicity=0.154, Total = 88.804\n",
      "Epoch: 440. Regression Loss=174.865, LogDet(I-B_0)=-2.358 Sparsity=0.025, Acyclicity=0.142, Total = 88.778\n",
      "Epoch: 450. Regression Loss=174.950, LogDet(I-B_0)=-2.253 Sparsity=0.025, Acyclicity=0.130, Total = 88.756\n",
      "Epoch: 460. Regression Loss=175.039, LogDet(I-B_0)=-2.150 Sparsity=0.025, Acyclicity=0.120, Total = 88.739\n",
      "Epoch: 470. Regression Loss=175.130, LogDet(I-B_0)=-2.049 Sparsity=0.025, Acyclicity=0.109, Total = 88.724\n",
      "Epoch: 480. Regression Loss=175.222, LogDet(I-B_0)=-1.952 Sparsity=0.025, Acyclicity=0.100, Total = 88.711\n",
      "Epoch: 490. Regression Loss=175.312, LogDet(I-B_0)=-1.857 Sparsity=0.025, Acyclicity=0.091, Total = 88.700\n",
      "Epoch: 500. Regression Loss=175.399, LogDet(I-B_0)=-1.766 Sparsity=0.025, Acyclicity=0.082, Total = 88.690\n",
      "Epoch: 510. Regression Loss=175.484, LogDet(I-B_0)=-1.678 Sparsity=0.025, Acyclicity=0.075, Total = 88.681\n",
      "Epoch: 520. Regression Loss=175.565, LogDet(I-B_0)=-1.594 Sparsity=0.025, Acyclicity=0.068, Total = 88.673\n",
      "Epoch: 530. Regression Loss=175.642, LogDet(I-B_0)=-1.514 Sparsity=0.025, Acyclicity=0.061, Total = 88.665\n",
      "Epoch: 540. Regression Loss=175.718, LogDet(I-B_0)=-1.437 Sparsity=0.026, Acyclicity=0.056, Total = 88.659\n",
      "Epoch: 550. Regression Loss=175.789, LogDet(I-B_0)=-1.364 Sparsity=0.026, Acyclicity=0.051, Total = 88.653\n",
      "Epoch: 560. Regression Loss=175.856, LogDet(I-B_0)=-1.295 Sparsity=0.026, Acyclicity=0.046, Total = 88.647\n",
      "Epoch: 570. Regression Loss=175.922, LogDet(I-B_0)=-1.228 Sparsity=0.026, Acyclicity=0.042, Total = 88.642\n",
      "Epoch: 580. Regression Loss=175.984, LogDet(I-B_0)=-1.165 Sparsity=0.026, Acyclicity=0.038, Total = 88.638\n",
      "Epoch: 590. Regression Loss=176.043, LogDet(I-B_0)=-1.104 Sparsity=0.026, Acyclicity=0.034, Total = 88.634\n",
      "Epoch: 600. Regression Loss=176.100, LogDet(I-B_0)=-1.046 Sparsity=0.026, Acyclicity=0.031, Total = 88.630\n",
      "Epoch: 610. Regression Loss=176.154, LogDet(I-B_0)=-0.991 Sparsity=0.026, Acyclicity=0.028, Total = 88.627\n",
      "Epoch: 620. Regression Loss=176.205, LogDet(I-B_0)=-0.939 Sparsity=0.026, Acyclicity=0.026, Total = 88.624\n",
      "Epoch: 630. Regression Loss=176.254, LogDet(I-B_0)=-0.889 Sparsity=0.026, Acyclicity=0.023, Total = 88.621\n",
      "Epoch: 640. Regression Loss=176.301, LogDet(I-B_0)=-0.841 Sparsity=0.026, Acyclicity=0.021, Total = 88.618\n",
      "Epoch: 650. Regression Loss=176.345, LogDet(I-B_0)=-0.797 Sparsity=0.026, Acyclicity=0.019, Total = 88.616\n",
      "Epoch: 660. Regression Loss=176.387, LogDet(I-B_0)=-0.753 Sparsity=0.026, Acyclicity=0.018, Total = 88.614\n",
      "Epoch: 670. Regression Loss=176.427, LogDet(I-B_0)=-0.713 Sparsity=0.026, Acyclicity=0.016, Total = 88.612\n",
      "Epoch: 680. Regression Loss=176.466, LogDet(I-B_0)=-0.673 Sparsity=0.026, Acyclicity=0.015, Total = 88.611\n",
      "Epoch: 690. Regression Loss=176.502, LogDet(I-B_0)=-0.637 Sparsity=0.026, Acyclicity=0.013, Total = 88.609\n",
      "Epoch: 700. Regression Loss=176.537, LogDet(I-B_0)=-0.601 Sparsity=0.026, Acyclicity=0.012, Total = 88.608\n",
      "Epoch: 710. Regression Loss=176.570, LogDet(I-B_0)=-0.568 Sparsity=0.026, Acyclicity=0.011, Total = 88.607\n",
      "Epoch: 720. Regression Loss=176.600, LogDet(I-B_0)=-0.537 Sparsity=0.026, Acyclicity=0.010, Total = 88.606\n",
      "Epoch: 730. Regression Loss=176.630, LogDet(I-B_0)=-0.507 Sparsity=0.026, Acyclicity=0.010, Total = 88.605\n",
      "Epoch: 740. Regression Loss=176.658, LogDet(I-B_0)=-0.479 Sparsity=0.026, Acyclicity=0.009, Total = 88.604\n",
      "Epoch: 750. Regression Loss=176.685, LogDet(I-B_0)=-0.452 Sparsity=0.026, Acyclicity=0.008, Total = 88.603\n",
      "Epoch: 760. Regression Loss=176.710, LogDet(I-B_0)=-0.427 Sparsity=0.027, Acyclicity=0.008, Total = 88.602\n",
      "Epoch: 770. Regression Loss=176.733, LogDet(I-B_0)=-0.403 Sparsity=0.027, Acyclicity=0.007, Total = 88.602\n",
      "Epoch: 780. Regression Loss=176.755, LogDet(I-B_0)=-0.380 Sparsity=0.027, Acyclicity=0.007, Total = 88.601\n",
      "Epoch: 790. Regression Loss=176.776, LogDet(I-B_0)=-0.359 Sparsity=0.027, Acyclicity=0.006, Total = 88.601\n",
      "Epoch: 800. Regression Loss=176.796, LogDet(I-B_0)=-0.339 Sparsity=0.027, Acyclicity=0.006, Total = 88.600\n",
      "Epoch: 810. Regression Loss=176.815, LogDet(I-B_0)=-0.320 Sparsity=0.027, Acyclicity=0.006, Total = 88.600\n",
      "Epoch: 820. Regression Loss=176.833, LogDet(I-B_0)=-0.302 Sparsity=0.027, Acyclicity=0.006, Total = 88.600\n",
      "Epoch: 830. Regression Loss=176.849, LogDet(I-B_0)=-0.285 Sparsity=0.027, Acyclicity=0.005, Total = 88.599\n",
      "Epoch: 840. Regression Loss=176.865, LogDet(I-B_0)=-0.270 Sparsity=0.027, Acyclicity=0.005, Total = 88.599\n",
      "Epoch: 850. Regression Loss=176.880, LogDet(I-B_0)=-0.255 Sparsity=0.027, Acyclicity=0.005, Total = 88.599\n",
      "Epoch: 860. Regression Loss=176.894, LogDet(I-B_0)=-0.240 Sparsity=0.027, Acyclicity=0.005, Total = 88.599\n",
      "Epoch: 870. Regression Loss=176.907, LogDet(I-B_0)=-0.227 Sparsity=0.027, Acyclicity=0.005, Total = 88.598\n",
      "Epoch: 880. Regression Loss=176.919, LogDet(I-B_0)=-0.215 Sparsity=0.027, Acyclicity=0.004, Total = 88.598\n",
      "Epoch: 890. Regression Loss=176.931, LogDet(I-B_0)=-0.203 Sparsity=0.027, Acyclicity=0.004, Total = 88.598\n",
      "Epoch: 900. Regression Loss=176.942, LogDet(I-B_0)=-0.192 Sparsity=0.027, Acyclicity=0.004, Total = 88.598\n",
      "Epoch: 910. Regression Loss=176.952, LogDet(I-B_0)=-0.181 Sparsity=0.027, Acyclicity=0.004, Total = 88.598\n",
      "Epoch: 920. Regression Loss=176.962, LogDet(I-B_0)=-0.171 Sparsity=0.027, Acyclicity=0.004, Total = 88.598\n",
      "Epoch: 930. Regression Loss=176.971, LogDet(I-B_0)=-0.163 Sparsity=0.027, Acyclicity=0.004, Total = 88.598\n",
      "Epoch: 940. Regression Loss=176.980, LogDet(I-B_0)=-0.153 Sparsity=0.027, Acyclicity=0.004, Total = 88.598\n",
      "Epoch: 950. Regression Loss=176.987, LogDet(I-B_0)=-0.146 Sparsity=0.027, Acyclicity=0.004, Total = 88.598\n",
      "Epoch: 960. Regression Loss=176.994, LogDet(I-B_0)=-0.139 Sparsity=0.027, Acyclicity=0.004, Total = 88.598\n",
      "Epoch: 970. Regression Loss=177.002, LogDet(I-B_0)=-0.131 Sparsity=0.027, Acyclicity=0.004, Total = 88.597\n",
      "Epoch: 980. Regression Loss=177.009, LogDet(I-B_0)=-0.125 Sparsity=0.027, Acyclicity=0.004, Total = 88.597\n",
      "Epoch: 990. Regression Loss=177.015, LogDet(I-B_0)=-0.119 Sparsity=0.027, Acyclicity=0.004, Total = 88.597\n",
      "Epoch: 1000. Regression Loss=177.021, LogDet(I-B_0)=-0.112 Sparsity=0.027, Acyclicity=0.004, Total = 88.597\n",
      "Epoch: 1010. Regression Loss=177.026, LogDet(I-B_0)=-0.107 Sparsity=0.027, Acyclicity=0.004, Total = 88.597\n",
      "Epoch: 1020. Regression Loss=177.030, LogDet(I-B_0)=-0.103 Sparsity=0.027, Acyclicity=0.004, Total = 88.597\n",
      "Epoch: 1030. Regression Loss=177.036, LogDet(I-B_0)=-0.097 Sparsity=0.027, Acyclicity=0.004, Total = 88.597\n",
      "Epoch: 1040. Regression Loss=177.041, LogDet(I-B_0)=-0.093 Sparsity=0.027, Acyclicity=0.004, Total = 88.597\n",
      "Epoch: 1050. Regression Loss=177.044, LogDet(I-B_0)=-0.089 Sparsity=0.027, Acyclicity=0.004, Total = 88.597\n",
      "Epoch: 1060. Regression Loss=177.049, LogDet(I-B_0)=-0.084 Sparsity=0.027, Acyclicity=0.004, Total = 88.597\n",
      "Epoch: 1070. Regression Loss=177.052, LogDet(I-B_0)=-0.081 Sparsity=0.027, Acyclicity=0.004, Total = 88.597\n",
      "torch.Size([10, 1000, 60])\n",
      " Time for spinsvar was 2.332\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/pmisiakos/Desktop/causal-learning-time-series/experiments/utils.py:339: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  X = torch.tensor(X).reshape(n, d * T)\n",
      "/Users/pmisiakos/Desktop/causal-learning-time-series/sparserc/spinsvar.py:51: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  self.X_past = torch.tensor(utils.X_past(X, self.p, device), device=device, dtype=dtype)\n"
     ]
    }
   ],
   "source": [
    "best_params = {\n",
    "    \"spinsvar\" : {\"lambda1\" : 0.0005, \"lambda2\" :  0.5},\n",
    "    \"sparserc\" : {\"lambda1\" : 0.001, \"lambda2\" :  1, \"lambda3\" : 0.001, \"omega\": 0.09},\n",
    "    \"dynotears\" : {\"lambda_w\" : 0.01, \"lambda_a\" : 0.01}, #{\"lambda_w\" : 0.05, \"lambda_a\" : 0.05},\n",
    "    \"nts-notears\" : {\"lambda1\" : 0.002, \"lambda2\" :  0.01}, # {\"lambda1\" : 0.001, \"lambda2\" :  0.05},\n",
    "    \"tsfci\" : {\"sig_level\" : 0.1}, # {\"sig_level\" : 0.01},\n",
    "    \"pcmci\" : {\"pc_alpha\" : 0.1, \"alpha_level\" : 0.01}, # {\"pc_alpha\" : 0.05, \"alpha_level\" : 0.05},\n",
    "    \"TCDF\" : {\"significance\" :  1., \"nrepochs\" : 1000},\n",
    "}\n",
    "\n",
    "# X has shape n x t x d where \n",
    "# n: number of independent instantiations\n",
    "# t: length of the time-series\n",
    "# d: number of nodes  \n",
    "# search_params: used for hyperparameter search, otherwise we used the best-performing hyperparameters\n",
    "# ground truth: for algorithms that output edges with ambiguity we need the ground truth to allow the method get the correct result\n",
    "\n",
    "\n",
    "method = \"spinsvar\"\n",
    "# method = \"sparserc\"\n",
    "\n",
    "# method = \"varlingam\"\n",
    "# method = \"d_varlingam\"\n",
    "# method = \"culingam\"\n",
    "\n",
    "# method = \"timino\"\n",
    "\n",
    "# method = \"dynotears\"\n",
    "# method = \"nts-notears\"\n",
    "\n",
    "# method = \"tsfci\"\n",
    "# method = \"pcmci\"\n",
    "# method = \"pcmci+\"\n",
    "# method = \"lpcmci\"\n",
    "# method = \"pcmci_omega\"\n",
    "\n",
    "# method = \"GVAR\"\n",
    "# method = \"TCDF\"\n",
    "\n",
    "if method in best_params.keys():\n",
    "    params = best_params[method]\n",
    "\n",
    "if method == 'spinsvar':\n",
    "    start = time.time()\n",
    "    W_est = spinsvar_solver(X, lambda1=params[\"lambda1\"], lambda2=params[\"lambda2\"], time_lag=number_of_lags, epochs=spinsvar_epochs, omega=omega, T=series_length)\n",
    "    print(\" Time for spinsvar was {:.3f}\".format(time.time() - start))\n",
    "    T = time.time() - start\n",
    "    B_est = W_est != 0\n",
    "\n",
    "elif method == 'sparserc':\n",
    "    start = time.time()\n",
    "    X_used = experiments.utils.X_past(X, algo_lags)\n",
    "    X_used = X_used.reshape((N * series_length, d * (algo_lags + 1)))\n",
    "\n",
    "    # X_used = experiments.utils.overlapping_chunks(X, algo_lags + 1)\n",
    "    W = sparserc_solver(X_used, lambda1=params[\"lambda1\"], lambda2=params[\"lambda2\"], epochs=spinsvar_epochs, lambda3=params[\"lambda3\"], omega=params[\"omega\"], T =  algo_lags + 1)\n",
    "    # W_est = W[d:2 * d, d :(args.number_of_lags + 2) * d]\n",
    "    W_est = W[:d, :(number_of_lags + 1) * d]\n",
    "    L = min(number_of_lags, algo_lags)\n",
    "    W_est = W[:d, :(L + 1) * d]\n",
    "    if number_of_lags > algo_lags:\n",
    "        W_est = np.concatenate([W_est, np.zeros((d, d * (number_of_lags - algo_lags)))], axis=1)\n",
    "\n",
    "    print(\" Time for spinsvar was {:.3f}\".format(time.time() - start))\n",
    "    T = time.time() - start\n",
    "    B_est = W_est != 0\n",
    "    \n",
    "\n",
    "############### Functional causal model based\n",
    "elif method in ['varlingam', 'd_varlingam', 'culingam']:\n",
    "    if method == 'varlingam':\n",
    "        model = lingam.VARLiNGAM(lags=number_of_lags, criterion=None, lingam_model=ICALiNGAM())\n",
    "    elif method == 'd_varlingam':\n",
    "        model = lingam.VARLiNGAM(lags=number_of_lags, criterion=None, lingam_model=DirectLiNGAM())\n",
    "    elif method == 'culingam':\n",
    "        if utils.get_cuda_version():\n",
    "            try:\n",
    "                import experiments.methods.culingam as culingam\n",
    "                model = culingam.VARLiNGAM(lags=number_of_lags, criterion=None, lingam_model=None) # None implies directLiNGAM\n",
    "\n",
    "            except ImportError as e:\n",
    "                print(\"Failed to import CUDA-dependent package:\", e)\n",
    "        else:\n",
    "            print(\"CUDA is not available. Please ensure CUDA is installed and correctly configured.\")\n",
    "\n",
    "    data = pd.DataFrame(X.reshape((N * series_length, d))) \n",
    "    start = time.time()\n",
    "    model.fit(data)\n",
    "    T = time.time() - start\n",
    "    W_est = np.concatenate([W.T for W in model.adjacency_matrices_], axis=1)\n",
    "    W_est = np.where(np.abs(W_est) > omega, W_est, 0) #thresholding\n",
    "        \n",
    "    B_est = W_est !=0\n",
    "\n",
    "\n",
    "elif method == 'timino':\n",
    "    # timino outputs summary graph\n",
    "    # the code below requires modification to work properly\n",
    "    data = pd.DataFrame(X.reshape((N * series_length, d)))\n",
    "    W_est, B_est, T = execute_R(data, d, omega, number_of_lags, Rscript, path_to_timino, path_to_data_timino, method=method)\n",
    "\n",
    "############### Continuous Optimization\n",
    "elif method == \"dynotears\":\n",
    "    time_series = [pd.DataFrame(X[i,:,:]) for i in range(X.shape[0])]\n",
    "    assert len(time_series) == N # should have length equal to the n realizations of the time series\n",
    "    start = time.time()\n",
    "    # best params lambda_w=.05, lambda_a=.05\n",
    "    g_learnt = from_pandas_dynamic(time_series, p=number_of_lags, lambda_w=params[\"lambda_w\"], lambda_a=params[\"lambda_a\"], w_threshold=omega)\n",
    "    T = time.time() - start\n",
    "    B_est, W_est = experiments.utils.network_to_numpy(g_learnt, d, number_of_lags)\n",
    "\n",
    "elif method == \"nts-notears\":\n",
    "    data = np.array(X.reshape((N * series_length, d)), dtype=np.float32)\n",
    "    start = time.time()\n",
    "    model = NTS_NOTEARS(dims=[d, 10, 1], bias=True, number_of_lags=number_of_lags,\n",
    "                        prior_knowledge=None, variable_names_no_time=['X{}'.format(j) for j in range(1, d + 1)])\n",
    "\n",
    "\n",
    "    # best params  lambda1=0.001, lambda2=0.05,\n",
    "    W = train_NTS_NOTEARS(model, data, device=device, lambda1=params[\"lambda1\"], lambda2=params[\"lambda2\"],\n",
    "                                    w_threshold=omega, h_tol=1e-60, verbose=1)\n",
    "    T = time.time() - start\n",
    "    # W_est = [ 0 0 0 B_τ \n",
    "    #           0 0 0 Β_{τ-1}\n",
    "    #           ...\n",
    "    #           0 0 0 Β_1\n",
    "    #           0 0 0 Β_0\n",
    "    W_est = np.zeros((d, (number_of_lags + 1) * d))\n",
    "    for i in range(number_of_lags + 1):\n",
    "        W_est[:, i * d : (i + 1) * d] = W[(number_of_lags - i) * d:(number_of_lags + 1 - i) * d, -d:]\n",
    "    B_est = W_est !=0\n",
    "\n",
    "############### Constraint-based methods\n",
    "elif method == 'tsfci':\n",
    "    data = experiments.utils.get_lagged_data(X.reshape((N * series_length, d)), number_of_lags)\n",
    "    data = pd.DataFrame(data)\n",
    "    W, T = execute_R(data, d, omega, number_of_lags, Rscript, path_to_tsfci, path_to_data_tsfci, method=method, sig_level=params[\"sig_level\"])\n",
    "    # W_est contains 1 for arrow tail, 2 for arrow-head and 3 for circle. \n",
    "    W_est = np.zeros((d, d * (number_of_lags + 1)))\n",
    "    for t in range(number_of_lags + 1):\n",
    "        for i in range(d):\n",
    "            for j in range(i):\n",
    "                # We let the PAG get the correct choice in ambiguous cases.\n",
    "                if W[i, j + d * t] == 1 and W[j, i + d * t] == 2: #case <--\n",
    "                    W_est[j, i + d * t] = 1\n",
    "                if W[i, j + d * t] == 2 and W[j, i + d * t] == 1: #case -->\n",
    "                    W_est[i, j + d * t] = 1\n",
    "                if W[i, j + d * t] == 2 and W[j, i + d * t] == 2: #case <->\n",
    "                    W_est[i, j + d * t] = 0\n",
    "                    W_est[j, i + d * t] = 0\n",
    "                if W[i, j + d * t] == 2 and W[j, i + d * t] == 3: #case o->\n",
    "                    W_est[i, j + d * t] = W_true[i, j + d * t]\n",
    "                if W[i, j + d * t] == 3 and W[j, i + d * t] == 2: #case <-o\n",
    "                    W_est[j, i + d * t] = W_true[j, i + d * t]\n",
    "                if W[i, j + d * t] == 3 and W[j, i + d * t] == 3: #case o-o\n",
    "                    W_est[i, j + d * t] = W_true[i, j + d * t]\n",
    "                    W_est[j, i + d * t] = W_true[j, i + d * t]\n",
    "\n",
    "    B_est = W_est != 0\n",
    "\n",
    "elif method in ['pcmci', 'pcmci+', 'lpcmci']:\n",
    "    data = pp.DataFrame(X.reshape((N * series_length, d)))\n",
    "    start = time.time()\n",
    "\n",
    "    if method == 'pcmci':\n",
    "        model = PCMCI(dataframe=data, cond_ind_test=ParCorr(), verbosity=0)\n",
    "        # best params pc_alpha=0.05, alpha_level=0.05\n",
    "        results = model.run_pcmci(tau_min=0, tau_max=number_of_lags, pc_alpha=params[\"pc_alpha\"], alpha_level=params[\"alpha_level\"])\n",
    "    elif method == 'pcmci+':\n",
    "        model = PCMCI(dataframe=data, cond_ind_test=ParCorr(), verbosity=0)\n",
    "        results = model.run_pcmciplus(tau_min=0, tau_max=number_of_lags, pc_alpha=0.01)\n",
    "    elif method == 'lpcmci':\n",
    "        model = LPCMCI(dataframe=data, cond_ind_test=ParCorr(), verbosity=0)\n",
    "        results = model.run_lpcmci(tau_min=0, tau_max=number_of_lags, pc_alpha=0.05)\n",
    "\n",
    "    T = time.time() - start\n",
    "\n",
    "    # causal link from :math:`i` to :math:`j` at lag :math:`\\\\tau`\n",
    "    graph = np.where(np.isin(results['graph'], ['-->']), 1, 0)\n",
    "    # denotes an unoriented, contemporaneous adjacency between :math:`i` and :math:`j` indicating Markov equivalence => we count it as correct\n",
    "    graph_yes = np.where(np.isin(results['graph'], ['o-o']), 1, 0)\n",
    "    # directionality is undecided due to conflicting orientation rules => No edge\n",
    "    graph_no = np.where(np.isin(results['graph'], ['x-x']), 0, 1)\n",
    "\n",
    "    total_graph = (graph + 2 * graph_yes) * graph_no\n",
    "    W_est = np.concatenate([total_graph[:,:,i] for i in range(number_of_lags + 1)], axis=1)\n",
    "\n",
    "    # Whenever there is ambiguity we assume PCMCI made the correct choice.\n",
    "    W_est = np.where(W_est == 2, W_true, W_est)\n",
    "\n",
    "    # for LPCMCI\n",
    "    # A = np.concatenate([np.where(np.isin(results['graph'][:, :, i], ['-->', 'o->','x->', '<->', 'o-o', 'x-x']), 1, 0) for i in range(number_of_lags + 1)], axis=1)\n",
    "    # B = np.concatenate([np.where(np.isin(results['graph'][:, :, i].T, ['<--','<-o', '<-x', '<->', 'o-o', 'x-x']), 1, 0) for i in range(number_of_lags + 1)], axis=1)\n",
    "    # W_est = np.where(A | B, 1, 0)\n",
    "\n",
    "    B_est = (W_est != 0)\n",
    "\n",
    "elif method == 'pcmci_omega':\n",
    "    # cannot yet run because selected_links is deprecated in the new version\n",
    "    data = X.reshape((N * series_length, d))\n",
    "    start = time.time()\n",
    "    tem_array, omega_hat4, superset_bool, elapsed_time = algorithm_v2_mci_(data, tau_max_pcmci=number_of_lags, search_omega_bound=1)\n",
    "    T = time.time() - start  \n",
    "    print(tem_array.shape, omega_hat4, elapsed_time)\n",
    "    B_est = (tem_array != 0)\n",
    "\n",
    "############### Granger-Causality\n",
    "elif method == 'GVAR':\n",
    "    data = X.reshape((N * series_length, d))\n",
    "    start = time.time()\n",
    "    B, W, coefs_full = training_procedure_trgc(data, order=5, hidden_layer_size=50, end_epoch=1000, batch_size=256, lmbd=1.5, gamma=0.015, seed=42)\n",
    "    T = time.time() - start  \n",
    "    # GVAR outputs summary graph\n",
    "    W_est, B_est = np.zeros((d, (number_of_lags + 1) * d)), np.zeros((d, (number_of_lags + 1) * d))\n",
    "    W_est[:, :d] = W\n",
    "    B_est[:, :d] = B\n",
    "\n",
    "############## Neural Networks \n",
    "elif method == 'TCDF':\n",
    "    data = pd.DataFrame(X.reshape((N * series_length, d)))\n",
    "    start = time.time()\n",
    "    print(\"Kernel size is {} ############\".format(number_of_lags + 1))\n",
    "    allcauses, alldelays, allreallosses, allscores, columns = \\\n",
    "        runTCDF(data, kernel_size=number_of_lags + 1, dilation_c=number_of_lags + 1, nrepochs=params[\"nrepochs\"], significance=params[\"significance\"])\n",
    "\n",
    "    T = time.time() - start\n",
    "    W_est = np.zeros((d, (number_of_lags + 1) * d))\n",
    "\n",
    "    for effect in allcauses.keys():\n",
    "        for cause in allcauses[effect]:\n",
    "            delay = alldelays[(effect, cause)]\n",
    "            if delay <= number_of_lags: # just to prevent throwing error\n",
    "                W_est[cause, effect + d * delay] = 1 # Updating B_delay\n",
    "    B_est = (W_est != 0)\n",
    "\n",
    "else: \n",
    "    print(\"method not implemented\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "b475d950",
   "metadata": {},
   "source": [
    "## Evaluation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "1cbc1a8a",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "No GPU automatically detected. Setting SETTINGS.GPU to 0, and SETTINGS.NJOBS to cpu_count.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "SparseRC performance evaluation\n",
      "Data on graph with 20 nodes and consisting of 10 samples\n",
      "Graph has 180.0 edges\n",
      "\n",
      "\n",
      "----- Graph Metrics -------\n",
      "Structural Hamming Distance 0.000\n",
      "Total edges proposed 180.000\n",
      "True positive rate 1.000\n",
      "Precision 1.000\n",
      "Recall 1.000\n",
      "F1-score 1.000\n",
      "Area under ROC 0.000\n",
      "Normalized mean-square error on approximation of weighted adjacency 0.021\n",
      "----- Root causes metrics -------\n",
      "Normalized mean-square error on approximation of root causes 0.090\n",
      "Number of non-zero root causes support 4982.000\n",
      "SHD on the root causes support 27.000\n"
     ]
    }
   ],
   "source": [
    "import cdt \n",
    "import sklearn.metrics\n",
    "import numpy as np\n",
    "\n",
    "# Computing the performance metrics \n",
    "nmse = np.linalg.norm(W_est - W_true) / np.linalg.norm(W_true)\n",
    "shd=0\n",
    "for i in range(number_of_lags + 1):\n",
    "    shd += cdt.metrics.SHD(B_true[:, i * d : (i + 1) * d], B_est[:, i * d : (i + 1) * d], double_for_anticausal=False)\n",
    "tpr = (B_true * B_est).sum() / B_true.sum() # tp / (tp + fn)\n",
    "nnz = np.sum(B_est)\n",
    "prec = sklearn.metrics.precision_score(B_true.flatten(), B_est.flatten()) # tp / (tp + fp) (1-FDR)\n",
    "rec = sklearn.metrics.recall_score(B_true.flatten(), B_est.flatten()) # tp / (tp + fn)\n",
    "f1 = sklearn.metrics.f1_score(B_true.flatten(), B_est.flatten()) # harmonic mean\n",
    "auroc = 0# sklearn.metrics.roc_auc_score(B_true.flatten(), B_est.flatten()) # area under ROC curve\n",
    "\n",
    "print(\"SparseRC performance evaluation\")\n",
    "print(\"Data on graph with {} nodes and consisting of {} samples\".format(d, N))\n",
    "print(\"Graph has {} edges\".format(np.sum(B_true)))\n",
    "print(\"\\n\")\n",
    "print(\"----- Graph Metrics -------\")\n",
    "print(\"Structural Hamming Distance {:.3f}\".format(shd))\n",
    "print(\"Total edges proposed {:.3f}\".format(nnz))\n",
    "print(\"True positive rate {:.3f}\".format(tpr))\n",
    "print(\"Precision {:.3f}\".format(prec))\n",
    "print(\"Recall {:.3f}\".format(rec))\n",
    "print(\"F1-score {:.3f}\".format(f1))\n",
    "print(\"Area under ROC {:.3f}\".format(auroc))\n",
    "print(\"Normalized mean-square error on approximation of weighted adjacency {:.3f}\".format(nmse))\n",
    "\n",
    "# Evaluating the approximation of the root causes \n",
    "C_est, c_nmse, c_num, c_shd = input_approximation(method, X, series_length, W_est, C_true)\n",
    "print(\"----- Root causes metrics -------\")\n",
    "print(\"Normalized mean-square error on approximation of root causes {:.3f}\".format(c_nmse))\n",
    "print(\"Number of non-zero root causes support {:.3f}\".format(c_num))\n",
    "print(\"SHD on the root causes support {:.3f}\".format(c_shd))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "f0b240fe",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA9YAAAF2CAYAAACLagB1AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy81sbWrAAAACXBIWXMAAA9hAAAPYQGoP6dpAABGKElEQVR4nO3deXRTdf7/8Vfa0hawLVuhrZZ9ExFQkApjWQawVAYEVBbRsqMIgw7jhguLGy6IjIIo3xFQAcUFcdxARBYZQAWsCv50AAsFoWWRNrRIWfr5/eFpNDRtSW7SJOX5OCfnkJv7vp93bm4v73dyF5sxxggAAAAAAHgkxN8JAAAAAAAQzGisAQAAAACwgMYaAAAAAAALaKwBAAAAALCAxhoAAAAAAAtorAEAAAAAsIDGGgAAAAAAC2isAQAAAACwgMYaAAAAAAALaKzdZLPZNHXqVH+nUaphw4bpoosu8tv4Xbp0UZcuXRzP9+zZI5vNpoULF/otJ7hn6tSpstlsXl1mYWGhWrZsqccff9yryy1vVtZNUeyRI0e8nNX5W7t2rWw2m9auXeuYNmjQIA0YMMBvOQFAEeqsslFnBb+KUmdREznzSWOdkZGh8ePHq2nTpqpSpYqqVKmiFi1aaNy4cfruu+98MWTA6NKli2w2W5kPq/9pnDhxQlOnTnXaEABXnnjiCS1fvtzfaeiNN97Qvn37NH78eH+nEhTK83O777779O677+rbb78tl/EAWEOdRZ2FwEGd5XvBUhOFeTuZDz/8UAMHDlRYWJiGDBmi1q1bKyQkRD/++KOWLVumuXPnKiMjQ/Xq1fP20AHhwQcf1KhRoxzPv/76az3//PN64IEHdOmllzqmt2rVytI4J06c0LRp0yTJ6VvLQFSvXj399ttvqlSpkr9TuSA98cQTuvHGG9W3b9/zjnnooYd0//33ezWPZ555RoMGDVJMTIxXl1vefLFuXPHkc/PUFVdcoXbt2unZZ5/Va6+95vPxAHiOOos661zUWf51IddZ1ETOvNpY7969W4MGDVK9evW0evVqxcfHO73+1FNP6cUXX1RISOk/lOfn56tq1areTK3c9OjRw+l5ZGSknn/+efXo0aPUHXMwv+ey2Gw2RUZG+jsNnIei7TAsLExhYd7bPXzzzTf69ttv9eyzz3ptmf7i7XUTKAYMGKApU6boxRdf9OshjgBKRp1FneUKdVbwqGh1FjWRM68eCv70008rPz9fCxYsKLazl35f+RMmTFBiYqJjWtF5Krt379Z1112nqKgoDRkyRNLvG98///lPJSYmKiIiQs2aNdOMGTNkjHHEl3ZeybmHAhUdy79r1y4NGzZM1apVU0xMjIYPH64TJ044xRYUFOgf//iHYmNjFRUVpT59+mj//v0W15BzHj/88INuvvlmVa9eXddcc42k4ufNFBk2bJjq16/veM+xsbGSpGnTppV42NMvv/yivn376qKLLlJsbKzuvvtunT17tsz83n//ffXq1UsJCQmKiIhQo0aN9Oijj7qMnTdvnho1aqTKlSurffv2+uKLL4rN4+oz+u677zRs2DA1bNhQkZGRiouL04gRI3T06NFi8b/88otGjhzpyKdBgwYaO3asTp065ZgnJydHd911l2Nbady4sZ566ikVFhYWy2PGjBmOvCMiInTVVVfp66+/Ljbujz/+qAEDBig2NlaVK1dWs2bN9OCDD0qS1qxZI5vNpvfee69Y3JIlS2Sz2bRp06YS1/HChQtls9m0YcMGTZgwQbGxsapWrZpuu+02nTp1Sjk5OUpLS1P16tVVvXp13XvvvU7bvSTNmDFDHTt2VM2aNVW5cmW1bdtW77zzjtM8NptN+fn5evXVVx3bybBhwySVvh2ee87MggULZLPZNH/+fKflP/HEE7LZbPr4449LfK+StHz5coWHh6tTp05O0/+8Xf+Zq3N2bDabxo8fr+XLl6tly5aKiIjQZZddphUrVjjm+e6772Sz2fSf//zHMW3r1q2y2Wy68sornZaXmpqqpKQkp2mffPKJkpOTVbVqVUVFRalXr17asWNHmbn99ttvmjBhgmrVquXYX/zyyy8lHo6Yk5NT6j6otM9N+v1vYsSIEapTp45jPZz72UjS/v371bdvX1WtWlW1a9fWP/7xDxUUFBSbT/q9WM3Pz9eqVatcvg7A/6izzg91FnUWdRY10bnKoyby6lcMH374oRo3blzsgynLmTNnlJKSomuuuUYzZsxQlSpVZIxRnz59tGbNGo0cOVJt2rTRypUrdc899+iXX37Rc88953GeAwYMUIMGDTR9+nRt27ZN//73v1W7dm099dRTjnlGjRqlRYsW6eabb1bHjh31+eefq1evXh6P6cpNN92kJk2a6Iknnij2x1ya2NhYzZ07V2PH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kqLc3FzH5//xxx8rPj5eN954oyO+SpUqTt9In6vobwhA4KHOsp6Ht1FnUWedD3/WWdRE5VsTee1Q8KioKElSXl5esddefvllHT9+XNnZ2S7/EMLCwnTJJZc4Tdu7d68SEhIcyy1SdMXHvXv3epzruX/ERRvisWPHFB0drb179yokJKTYoRzNmjXzeExXGjRo4NXl/VlkZKTj/KAi1atX17Fjx8qM3bFjhx566CF9/vnnxTbq3NxcSX+s/yZNmji9XqlSJTVs2LDMMX799VdNmzZNb775pg4dOuRyjMOHD8tut6tly5alLmvnzp367rvvir3fIucuv7TPX/pjx1/WuM2bN9dVV12lxYsXO3bQixcv1tVXX63GjRuXGltSLkX/WZ57iFdMTEyxz+7DDz/UY489pvT0dKdzRNy9n6A72+GgQYO0aNEiffTRRxozZoy6det23rHGjcPwSnLu+pKKb9fJyck6c+aMNm3apMTERB06dEjJycnasWOH038iLVq0UI0aNST9vg1J0l//+leX45b2n1rR/uLc9VjaNlDWPqgkhw8fVk5OjubNm6d58+a5nKdoe9+7d68aN25cbHsobT9mjPH6fTUBeAd1lvuos6izLvQ6i5qofGsirzXWMTExio+P1/bt24u9VnQu0J49e1zGRkRElHkFy5KU9IZLu3hEaGioy+neKPzd8edvworYbDaXeZzPxTD+rKT3WJacnBx17txZ0dHReuSRR9SoUSNFRkZq27Ztuu+++5wuUmHFgAEDtHHjRt1zzz1q06aNLrroIhUWFqpnz55uj1FYWKgePXro3nvvdfl606ZNnZ578/NPS0vTnXfeqf3796ugoECbN2/W7Nmzzzu+pFxcTf9zfl988YX69OmjTp066cUXX1R8fLwqVaqkBQsWaMmSJW69B1fbYUmOHj2qLVu2SJJ++OEHFRYWntffbs2aNV0WG+7+/Z7PZ9euXTtFRkZq/fr1qlu3rmrXrq2mTZsqOTlZL774ogoKCvTFF184nTNTtM29/vrriouLK7Z8b1/x0tNtsCjPW265RUOHDnU5j5VbzBw7dqxYEQcgMFBnuY86izrrQq+zqInKtyby6prp1auX/v3vf+urr75S+/btLS2rXr16+uyzz3T8+HGnb1OLDpEpuj9j0bcaOTk5TvFWvmmtV6+eCgsLtXv3bqdvMn766SePl3m+qlev7vIwonPfj69+VVq7dq2OHj2qZcuWOV1ZMCMjw2m+ovW/c+dOp2+0Tp8+rYyMDLVu3brEMY4dO6bVq1dr2rRpmjx5smN60TdkRWJjYxUdHe2yiPizRo0aKS8vT927dy/7DZ6Hom+CyxpX+v2bxYkTJ+qNN95w3ENy4MCBXsmjNO+++64iIyO1cuVKRUREOKYvWLCg2Lze3FbGjRun48ePa/r06Zo0aZJmzZqliRMnlhnXvHnzYtuQ9Pv2fu7frmTt7zc8PNxx5dS6des6DkFLTk5WQUGBFi9erOzsbKftu+hXk9q1a7u9HRXtLzIyMpx2wLt27fL4PUiuP7eiq+eePXu2zDzr1aun7du3F/vGtaT92JkzZ7Rv3z7HBU4ABB7qLOuos/5AnVWyilJnURP9kVd51ERevd3WvffeqypVqmjEiBHKzs4u9ro731Rdd911Onv2bLFvpZ577jnZbDalpqZK+v1whFq1ahU7v+PFF1/04B38rmjZzz//vNP0c6966AuNGjXSjz/+qMOHDzumffvtt/rvf//rNF+VKlUkFf+Pzqqib43+/FmdOnWq2Pps166dYmNj9dJLLzndjmHhwoVl5uRqDKn4+g0JCVHfvn31wQcfOL69+7Oi+AEDBmjTpk1auXJlsXlycnJ05syZUvM5V2xsrDp16qT58+crMzPT5ZhFatWqpdTUVC1atEiLFy9Wz549VatWLbfG80RoaKhsNpvTN+x79uzR8uXLi81btWpVr2wn77zzjpYuXaonn3xS999/vwYNGqSHHnpI//vf/8qM7dChg7Zv317stgaNGjVSbm6uvvvuO8e0gwcPury9hjuSk5P15Zdfas2aNY7/RGrVqqVLL73UcZXJoumSlJKSoujoaD3xxBM6ffp0seX9+e/xXCkpKZKK73NeeOEFS+/B1ecWGhqqG264Qe+++67LguTPeV533XU6cOCA07lpJ06cKPFwqR9++EEnT55Ux44dLeUNwHeos6yjzvoDdVbJKkqdJVETSeVXE3n1F+smTZpoyZIlGjx4sJo1a6YhQ4aodevWMsYoIyNDS5YsUUhISLHzfFzp3bu3unbtqgcffFB79uxR69at9emnn+r999/XXXfd5XRezqhRo/Tkk09q1KhRateundavX39eG2FJ2rRpo8GDB+vFF19Ubm6uOnbsqNWrV1v+tuV8jBgxQjNnzlRKSopGjhypQ4cO6aWXXtJll13mdB5O5cqV1aJFCy1dulRNmzZVjRo11LJlyzLPVylLx44dVb16dQ0dOlQTJkyQzWbT66+/XmxHV6lSJT322GO67bbb9Ne//lUDBw5URkaGFixYUOa5P9HR0erUqZOefvppnT59WhdffLE+/fRTl9+0PfHEE/r000/VuXNnjRkzRpdeeqkOHjyot99+Wxs2bFC1atV0zz336D//+Y/+9re/adiwYWrbtq3y8/P1/fff65133tGePXvc3gk///zzuuaaa3TllVdqzJgxatCggfbs2aOPPvpI6enpTvOmpaU5Lobw6KOPujWOp3r16qWZM2eqZ8+euvnmm3Xo0CHNmTNHjRs3dmpSJalt27b67LPPNHPmTCUkJKhBgwZu36rl0KFDGjt2rLp27arx48dLkmbPnq01a9Zo2LBh2rBhQ6mHKl1//fV69NFHtW7dOl177bWO6YMGDdJ9992nfv36acKECY7bOTRt2tTti4P8WXJysh5//HHt27fP6T+LTp066eWXX1b9+vWd9kPR0dGaO3eubr31Vl155ZUaNGiQYmNjlZmZqY8++kh/+ctfSjz0rG3btrrhhhs0a9YsHT161HFriaJ9kKffZJf0uT355JNas2aNkpKSNHr0aLVo0UK//vqrtm3bps8++0y//vqrJGn06NGaPXu20tLStHXrVsXHx+v11193FIvnWrVqlapUqaIePXp4lC8A36POso46yxl1lmsVpc6SqImkcqyJ3LqG+HnatWuXGTt2rGncuLGJjIw0lStXNs2bNze33367SU9Pd5p36NChpmrVqi6Xc/z4cfOPf/zDJCQkmEqVKpkmTZqYZ555xumy+cb8fjn8kSNHmpiYGBMVFWUGDBhgDh06VOJl3Q8fPuwUX3RJ/oyMDMe03377zUyYMMHUrFnTVK1a1fTu3dvs27fPq7eBODePIosWLTINGzY04eHhpk2bNmblypUub0u0ceNG07ZtWxMeHu6UV0nr1NWl/V3573//a66++mpTuXJlk5CQYO69916zcuVKl5ejf/HFF02DBg1MRESEadeunVm/fn2xW1m4ug3E/v37Tb9+/Uy1atVMTEyMuemmm8yBAwdcrt+9e/eatLQ0ExsbayIiIkzDhg3NuHHjnG4/cfz4cTNp0iTTuHFjEx4ebmrVqmU6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EmNsNpvi4uK8nQoAAEBQoH4CgODm03OsT506pUWLFmnEiBGlfoual5enevXqKTExUddff7127NhR6nILCgpkt9udHgAAABUB9RMABB+bMcb4auFvvfWWbr75ZmVmZiohIcHlPJs2bdLOnTvVqlUr5ebmasaMGVq/fr127NihSy65xGXM1KlTNW3aNK/laXUVWDn0KpjHDlZ8Xu6zenihldz9ObY/2O12xcTEKDc3V9HR0f5OB4AflHf99O1dixQVUcXtPOMf7ul2zJ8VrN3ncWxEl0RLY89JH+Jx7Lg2iy2NHax+W7nb49jKKY08jt158lOPYyWpSeS1luKtSJnR3OPYlXf/6HHsvStLPtLlfDydss5SvD/Y7XbVSYjza/3k01+sX3nlFaWmppb4n4IkdejQQWlpaWrTpo06d+6sZcuWKTY2Vi+//HKJMZMmTVJubq7jsW+f5ztmAACAQEL9BADBx+vnWBfZu3evPvvsMy1btsytuEqVKumKK67Qrl27SpwnIiJCERERVlMEAAAIKNRPABCcfPaL9YIFC1S7dm316tXLrbizZ8/q+++/V3x8vI8yAwAACEzUTwAQnHzSWBcWFmrBggUaOnSowsKcfxRPS0vTpEmTHM8feeQRffrpp/r555+1bds23XLLLdq7d69GjRrli9QAAAACEvUTAAQvnxwK/tlnnykzM1MjRowo9lpmZqZCQv7o548dO6bRo0crKytL1atXV9u2bbVx40a1aNHCF6kBAAAEJOonAAhePmmsr7322hKvxLt27Vqn588995yee+45X6QBAAAQNKifACB4+fSq4AAAAAAAVHQ01gAAAAAAWEBjDQAAAACABTTWAAAAAABYQGMNAAAAAIAFNNYAAAAAAFhAYw0AAAAAgAU01gAAAAAAWEBjDQAAAACABWH+TsCbcnNzFR0dXe7jGmM8jrXZbF7MBOfDyuflT/7cVoJ1nfkbf98AgkHcvd39Uj9FdEn0OHbymu6Wxp580SJL8ReiyimN/DLuT0c3WYqfsHSCx7HDru9laeyVd/9oKd5Tvdr198u43rDjxPsexeX9dsLLmbiPX6wBAAAAALCAxhoAAAAAAAtorAEAAAAAsIDGGgAAAAAAC2isAQAAAACwgMYaAAAAAAALaKwBAAAAALCAxhoAAAAAAAtorAEAAAAAsIDGGgAAAAAAC2isAQAA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",
      "text/plain": [
       "<Figure size 1400x400 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA8MAAAF2CAYAAABK7UrZAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy81sbWrAAAACXBIWXMAAA9hAAAPYQGoP6dpAABFKUlEQVR4nO3deXxTdfb/8Xfa2hShDVsXKqWssi9apKJUQJZSkbGMClSFgoAKwujwRUcc2dSx4gIqMCAqVFFH0EHGFVmUTUAFrA6oTEFWoUUKbWiBgu39/eGvkdAWyNIm5b6ej0cemnvvuZ+Te28v5yS5NxbDMAwBAAAAAGAiAb5OAAAAAACAykYzDAAAAAAwHZphAAAAAIDp0AwDAAAAAEyHZhgAAAAAYDo0wwAAAAAA06EZBgAAAACYDs0wAAAAAMB0aIYBAAAAAKZjimZ4z549slgsSk9P93Uqfqms7TNlyhRZLBbfJQWXNWzYUEOHDvXqOr/++msFBwdr7969Xl1vZfNk2zRs2FA333yzdxNy0dChQ9WwYUPH85ycHFWvXl2ffPKJ75ICgP+POuv8qLMuDZdKnUVN5MwUzTBQlfzwww+aMmWK9uzZ4+tU9Pe//10pKSmKjY31dSp+rzL3W506dTRixAhNnDixwscCAOBSQp1V8apSTWSKZjg2NlYnT57U4MGDfZ1KlfHYY4/p5MmTvk7DlH744QdNnTrV5RPIjh079Morr3gtj4yMDK1cuVL33Xef19bpK97eNmVxd7+567777tPWrVv1+eefV8p4AFAe6izXUWf5jtnrLGoiZ6Zohi0Wi0JCQhQYGOjrVNxWUFBQqeMFBQUpJCSkUseE6wzDcPxjarVaddlll3lt3QsWLFCDBg107bXXem2dvuLtbeMPWrZsqTZt2vC1RAA+R53lOuqsquFSrLOoiZz5bTN8/PhxPfjgg2rYsKGsVqsiIiLUq1cvbd261bFMt27d1KZNG23ZskXXXXedqlWrpkaNGmnu3LlO6yrrWo2hQ4eqRo0a+uWXX5ScnKwaNWooPDxc48ePV1FRkVP8O++8o7i4OIWGhiosLExt27bViy++KEnavHmzLBaLXn/99VKv4bPPPpPFYtFHH30kSdq7d69Gjx6t5s2bq1q1aqpTp45uv/32Uu+apKeny2KxaM2aNRo9erQiIiJUv379crfV6dOnNWnSJMXFxclms6l69epKSEjQF198UWrZ3NxcDR06VDabTTVr1lRqaqpyc3NLLVfWtSwLFizQjTfeqIiICFmtVrVq1Upz5swpM6dPP/1UXbt2dWyza665Rm+//bbTMl999ZX69Okjm82myy+/XF27dtWXX35ZZh47d+7U0KFDVbNmTdlsNg0bNkwnTpwoNe6bb76pTp066fLLL1etWrV0ww03aPny5ZKk1NRU1a1bV2fOnCkV17t3bzVv3rzM11Ki5Hj7/vvv1bVrV11++eVq2rSp3nvvPUnSmjVrFB8fr2rVqql58+ZauXKlU/zF7P/09HTdfvvtkqTu3bvLYrHIYrFo9erVkv64VuOzzz5Tx44dVa1aNb388suOeSXXgBiGoe7duys8PFyHDx92rP/06dNq27atmjRpcsF/+JcuXaobb7yx1HFgsVg0ZcqUUsufew1KyXH85Zdfaty4cQoPD1f16tXVv39//frrr47lxo0bpzp16sgwDMe0sWPHymKx6KWXXnJMy87OlsVicTrmCgsLNXnyZDVt2lRWq1UxMTF6+OGHVVhYeN7cJDn2Y7Vq1VS/fn09+eSTWrBggSwWS5nvZK5fv16dOnVSSEiIGjdurDfeeMPptZ5vv0m//00kJCSoevXqCg0NVd++fbV9+/ZS4yxdulRt2rRRSEiI2rRpo/fff7/UMiV69eqlDz/80GnbAcDFoM6izjo7D+qs1ZJ8X2dRE5XeRhVdE/ltM3zfffdpzpw5uvXWW/XPf/5T48ePV7Vq1fTjjz86LXfs2DHddNNNiouL0zPPPKP69etr1KhRmj9//gXHKCoqUmJiourUqaPnnntOXbt21fPPP6958+Y5llmxYoVSUlJUq1YtTZs2TU8//bS6devmOJl07NhRjRs31uLFi0utf9GiRapVq5YSExMlSd988402bNigQYMG6aWXXtJ9992nVatWqVu3bmWecEaPHq0ffvhBkyZN0iOPPFLu67Db7Xr11VfVrVs3TZs2TVOmTNGvv/6qxMREZWRkOJYzDEO33HKLFi5cqLvuuktPPvmkDhw4oNTU1AtuK0maM2eOYmNj9eijj+r5559XTEyMRo8erdmzZzstl56err59++ro0aOaMGGCnn76aXXo0EHLli1zLPP555/rhhtukN1u1+TJk/XUU08pNzdXN954o77++utSYw8YMEDHjx9XWlqaBgwYoPT0dE2dOtVpmalTp2rw4MG67LLL9Pjjj2vq1KmKiYlxfGVi8ODBysnJ0WeffeYUl5WVpc8//1x33XXXBbfBsWPHdPPNNys+Pl7PPPOMrFarBg0apEWLFmnQoEG66aab9PTTT6ugoEC33Xabjh8/7oi9mP1/ww036C9/+Ysk6dFHH9XChQu1cOFCtWzZ0rGeHTt2KCUlRb169dKLL76oDh06lMrTYrFo/vz5OnXqlNPXbyZPnqzt27drwYIFql69ermv85dfftG+fft09dVXX3CbXMjYsWP13XffafLkyRo1apQ+/PBDjRkzxjE/ISFBR48edToJrlu3TgEBAVq3bp3TNOn3bSRJxcXF+tOf/qTnnntO/fr108yZM5WcnKwZM2Zo4MCB583pl19+Uffu3bV9+3ZNmDBBf/3rX/XWW285iq9z7dy5U7fddpt69eql559/XrVq1dLQoUMdOV9ovy1cuFB9+/ZVjRo1NG3aNE2cOFE//PCDunTp4vSPzPLly3XrrbfKYrEoLS1NycnJGjZsmDZv3lxmXnFxccrNzS3zHxAAOB/qLOqss1Fn+UedRU20xzFOpdVEhp+y2WzG/ffff95lunbtakgynn/+ece0wsJCo0OHDkZERIRx+vRpwzAMY/fu3YYkY8GCBY7lUlNTDUnG448/7rTOq666yoiLi3M8f+CBB4ywsDDjt99+KzePCRMmGJdddplx9OhRpzxq1qxp3H333Y5pJ06cKBW7ceNGQ5LxxhtvOKYtWLDAkGR06dLlvOOW+O2334zCwkKnaceOHTMiIyOdxl+6dKkhyXjmmWecYhMSEkptn8mTJxvnHh5l5Z+YmGg0btzY8Tw3N9cIDQ014uPjjZMnTzotW1xc7Phvs2bNjMTERMe0kvU3atTI6NWrV6k8zn4dhmEY/fv3N+rUqeN4npmZaQQEBBj9+/c3ioqKyhy3qKjIqF+/vjFw4ECn+dOnTzcsFovx888/l3p9Zys53t5++23HtJ9++smQZAQEBBibNm1yTP/ss89KbdOL3f/vvvuuIcn44osvSi0fGxtrSDKWLVtW5rzU1FSnaS+//LIhyXjzzTeNTZs2GYGBgcaDDz543tdpGIaxcuVKQ5Lx4YcflponyZg8efIFxy85jnv27Om0n//6178agYGBRm5urmEYhnH48GFDkvHPf/7TMIzfj6GAgADj9ttvNyIjIx1xf/nLX4zatWs71rVw4UIjICDAWLdunVMec+fONSQZX375Zbm5jR071rBYLMa3337rmJaTk2PUrl3bkGTs3r3bKVaSsXbtWse0w4cPG1ar1fi///s/x7Ty9tvx48eNmjVrGiNHjnSanpWVZdhsNqfpHTp0MOrVq+fYNoZhGMuXLzckGbGxsca5NmzYYEgyFi1aVGoeAJwPdRZ11tl5UGf9ztd1FjVR5ddEfvvJcM2aNfXVV1/p4MGD510uKChI9957r+N5cHCw7r33Xh0+fFhbtmy54DjnXrSekJCgn3/+2SmPgoICrVixotx1DBw4UGfOnNGSJUsc05YvX67c3Fynd2OqVavm+P8zZ84oJydHTZs2Vc2aNZ2+llRi5MiRF3X9TWBgoIKDgyX9/s7Q0aNH9dtvv6ljx45O6/3kk08UFBSkUaNGOcWOHTv2gmOcm39eXp6OHDmirl276ueff1ZeXp6k39/hPX78uB555JFS18KUfA0kIyNDmZmZuuOOO5STk6MjR47oyJEjKigoUI8ePbR27VoVFxc7xZa1n3JycmS32yX9/jWK4uJiTZo0SQEBzod1ybgBAQG688479cEHHzi9k/jWW2/puuuuU6NGjS64DWrUqKFBgwY5njdv3lw1a9ZUy5YtFR8f75he8v9nH0uu7v/yNGrUyPEu+IXcc889SkxM1NixYzV48GA1adJETz311AXjcnJyJEm1atW66LzOl8PZXwFKSEhQUVGR42cEwsPD1aJFC61du1aS9OWXXyowMFAPPfSQsrOzlZmZKen3d0G7dOniWNe7776rli1bqkWLFo5j6MiRI7rxxhslqcyvr5VYtmyZOnfu7PRub+3atXXnnXeWuXyrVq2UkJDgeB4eHq7mzZs77d/yrFixQrm5uUpJSXHKMzAwUPHx8Y48Dx06pIyMDKWmpspmsznie/XqpVatWpW57pL9c+TIkQvmAQBno86izjobddYffFlnURNVfk3kt83wM888o23btikmJkadOnXSlClTytzI0dHRpb6GcOWVV0rSBe9gFhISovDwcKdptWrV0rFjxxzPR48erSuvvFJJSUmqX7++7r77bqevoUhS+/bt1aJFCy1atMgxbdGiRapbt67jIJSkkydPatKkSYqJiZHValXdunUVHh6u3Nxcx0nubBdz0ijx+uuv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O504cUKvv/66AgIC9OqrryopKUmtW7fWsGHDdMUVV+iXX37RF198obCwMH344YcubYOmTZvq73//u5544gklJCToz3/+s6xWq7755htFR0crLS3NsWx4eLj69Omjd999VzVr1lTfvn1dGstdF7v/O3TooMDAQE2bNk15eXmyWq2O3x10xYIFC/Txxx8rPT3d8fuJM2fO1F133aU5c+Zo9OjR542/5ZZb9P7778swDKd3+EaMGKH77rtPt956q3r16qXvvvtOn332mcdf1U1ISNA777yjtm3bOt5Bvvrqq1W9enX973//0x133OG0/ODBg7V48WLdd999+uKLL3T99derqKhIP/30kxYvXuz4jcCyPPzww3rzzTfVq1cvjR07VtWrV9err76qBg0a6OjRo269a3y+/TZnzhwNHjxYV199tQYNGqTw8HDt27dPH3/8sa6//nrNmjVLkpSWlqa+ffuqS5cuuvvuu3X06FHNnDlTrVu3LrOgWbFihfr168c1wwBcQp3lGuos6qyyVFSdJVETSZVYE7l07+lKUlhYaDz00ENG+/btjdDQUKN69epG+/btHbcZL9G1a1ejdevWxubNm43OnTsbISEhRmxsrDFr1iyn5cq75X/16tVLjX3ure7fe+89o3fv3kZERIQRHBxsNGjQwLj33nuNQ4cOlYrNzMw0JBmSjPXr15eaf+zYMWPYsGFG3bp1jRo1ahiJiYnGTz/9VO5P0nzzzTcXtb2Ki4uNp556yoiNjTWsVqtx1VVXGR999JGRmppa6tbjOTk5xuDBg42wsDDDZrMZgwcPNr799tuLuuX/Bx98YLRr184ICQkxGjZsaEybNs2YP39+qduulyx73XXXGdWqVTPCwsKMTp06Gf/617+clvn222+NP//5z0adOnUMq9VqxMbGGgMGDDBWrVpVKo9ff/3VKbZkG5077vz5842rrrrKsFqtRq1atYyuXbsaK1asKLXNFi9ebEgy7rnnngts3T+UHG/nio2NNfr27VtquiSnn6242P1vGIbxyiuvGI0bNzYCAwOdbk1f3lgl80rWs3//fsNmsxn9+vUrtVz//v2N6tWrX/AnDrZu3WpIKnWb/qKiIuNvf/ubUbduXePyyy83EhMTjZ07d170cfzFF1+Uebv92bNnG5KMUaNGOU3v2bOnIcnpuChx+vRpY9q0aUbr1q0d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",
      "text/plain": [
       "<Figure size 1400x400 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA+EAAAF2CAYAAAABRZk0AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy81sbWrAAAACXBIWXMAAA9hAAAPYQGoP6dpAABE7UlEQVR4nO3deVgVdf//8ddBFFwALZFFEZVUci9KcktNCqlMrbTIO3H9ltWdZWZ1Vy5ttpqVlnWbWXe7LdRd3pZRbrllZqllCaG4gUIKgkoGn98f/jh5ZNFz4Mw5wPNxXXNdnDnzmc975swZ3u+ZMzM2Y4wRAAAAAABwOx9PBwAAAAAAQG1BEQ4AAAAAgEUowgEAAAAAsAhFOAAAAAAAFqEIBwAAAADAIhThAAAAAABYhCIcAAAAAACLUIQDAAAAAGARinAAAAAAACxCEX4Km82m6dOnezqMCo0aNUqNGjXyWP/Lli2TzWbTsmXLPBZDVVq4cKFsNpt27Njh1n6mT58um83mMK5Vq1YaNWqUW/utjnbt2iV/f399++23ng6lUvr166d+/fq53LZTp05VG5CTTt1mjx8/roiICL344osejApAdUaedXrkWa4hzzpznsizyIkcuVSEp6en67bbblO7du3UoEEDNWjQQB06dNCtt96qn376yaVAqot+/frJZrOddqjsP5gjR45o+vTpbtkBr1+/XrfccotiYmJUt27dUjsswNMeeughxcbGqlevXp4Oxevt3btX06dP16ZNm9zeV926dTVp0iQ9+uijOnbsmNv7A2or8izyLMCdamqeVZ1yIl9nG3z22We67rrr5OvrqxEjRqhr167y8fHRtm3b9NFHH+mll15Senq6IiMjnQ6mOrj//vs1btw4++vvvvtOzz//vP71r3/p3HPPtY/v0qVLpfo5cuSIZsyYIUkuHzUqz+LFizV//nx16dJFbdq00W+//Val88eZ+/XXX+Xjww9STnbgwAG9/vrrev311z0dSqV9+eWXbu9j7969mjFjhlq1aqVu3bq5vb/Ro0fr3nvv1dtvv60xY8a4vT+gtiHPIs9C1SHPKs1TeRY5kSOnivC0tDRdf/31ioyMVEpKisLCwhzef+KJJ/Tiiy+edmMvKChQw4YNnQrUW1x66aUOr/39/fX888/r0ksvrXAn7k3LPGHCBN1zzz2qX7++brvtNv45eJCfn5+nQ/A6b775pnx9fTVo0CBPh1Jp9erV83QIVa5x48a67LLLtHDhQopwoIqRZ5FnoWqRZ5XmqTyLnMiRU4eGnnzySRUUFOi1114r9Y9Bknx9fXX77bcrIiLCPq7kupq0tDRdfvnlCggI0IgRIySd2GHeddddioiIkJ+fn9q3b6+nn35axhh7+x07dshms2nhwoWl+jv150glv9VPTU3VqFGj1LhxYwUFBWn06NE6cuSIQ9vCwkLdeeedCg4OVkBAgK666irt3r3bmdVRrpI4fv75Z91www1q0qSJevfuLan86yFGjRqlVq1a2Zc5ODhYkjRjxoxyf3q1Z88eDRkyRI0aNVJwcLAmT56soqKi08YXEhKi+vXrV2oZT7Vy5UoNGzZMLVu2lJ+fnyIiInTnnXfq6NGjpaZdtGiROnToIH9/f3Xq1Ekff/yxw/KXyMnJ0Y033qjAwEA1btxYSUlJ+vHHH8vcHrZt26Zrr71WZ511lvz9/XXBBRfo008/LdX31q1bdckll6h+/fpq0aKFHnnkERUXF5/RMv70008aNWqU2rRpI39/f4WGhmrMmDHKyckpNe2qVat04YUXyt/fX1FRUXr55ZfLnOep1yr98ccfmjx5sjp37qxGjRopMDBQCQkJ+vHHH0u1PXbsmKZPn6527drJ399fYWFhuvrqq5WWlmafpri4WLNnz1bHjh3l7++vkJAQ3XTTTTp48GCpOK688kqtWrVK3bt3l7+/v9q0aaM33nijVL+HDh3SnXfeqVatWsnPz08tWrTQyJEjlZ2drfz8fDVs2FATJ04s1W737t2qU6eOZs6cWe46lqTk5GTFxsaWuh6vvOu6Tv1OlVxL9/777+vRRx9VixYt5O/vrwEDBig1NdU+3fPPP686dero0KFD9nHPPPOMbDabJk2aZB9XVFSkgIAA3XPPPfZxZ7pey/q+79y5U1dddZUaNmyoZs2a6c4779QXX3xR7vV/P//8s/r3768GDRqoefPmevLJJx2W9cILL5R04mhsyb7i5O/HunXrNHDgQAUFBalBgwbq27dvmdeAnek2K51IkletWqU//vij3GkAOI8868yQZ5FnkWdVbZ5FTuTIipzIqTPhn332mc455xzFxsY61clff/2l+Ph49e7dW08//bQaNGggY4yuuuoqffPNNxo7dqy6deumL774Qnfffbf27NmjZ5991qk+TjZ8+HC1bt1aM2fO1MaNGzV//nw1a9ZMTzzxhH2acePG6c0339QNN9ygnj176uuvv9YVV1zhcp9lGTZsmNq2bavHHnvM4R/e6QQHB+ull17ShAkTNHToUF199dWSHH96VVRUpPj4eMXGxurpp5/WV199pWeeeUZRUVGaMGFClS7HmVi0aJGOHDmiCRMm6Oyzz9b69ev1wgsvaPfu3Vq0aJF9us8//1zXXXedOnfurJkzZ+rgwYMaO3asmjdv7jC/4uJiDRo0SOvXr9eECRMUHR2tTz75RElJSaX63rp1q3r16qXmzZvr3nvvVcOGDfX+++9ryJAh+vDDDzV06FBJUmZmpvr376+//vrLPt0rr7xyxv8oly5dqt9//12jR49WaGiotm7dqldeeUVbt27V2rVr7dd8bd68WZdddpmCg4M1ffp0/fXXX5o2bZpCQkJO28fvv/+u5ORkDRs2TK1bt1ZWVpZefvll9e3bVz///LPCw8Mlnfj8r7zySqWkpOj666/XxIkTdfjwYS1dulRbtmxRVFSUJOmmm27SwoULNXr0aN1+++1KT0/XnDlz9MMPP+jbb79V3bp17X2npqbq2muv1dixY5WUlKQFCxZo1KhRiomJUceOHSVJ+fn56tOnj3755ReNGTNG559/vrKzs/Xpp59q9+7d6tatm4YOHar33ntPs2bNUp06dezzf+edd2SMsSeHZTl+/Li+++67KtmGH3/8cfn4+Gjy5MnKzc3Vk08+qREjRmjdunWSpD59+qi4uFirVq3SlVdeKelEkuPj46OVK1fa5/PDDz8oPz9fF198sX2cM+v1ZAUFBbrkkku0b98+TZw4UaGhoXr77bf1zTfflDn9wYMHNXDgQF199dUaPny4PvjgA91zzz3q3LmzEhISdO655+qhhx7S1KlT9X//93/q06ePJKlnz56SpK+//loJCQmKiYnRtGnT5OPjo9dee02XXHKJVq5cqe7du0tyfpuNiYmRMUarV6+2rzsAlUee5RzyLPIs8qyqybPIiTyQE5kzlJubaySZIUOGlHrv4MGD5sCBA/bhyJEj9veSkpKMJHPvvfc6tElOTjaSzCOPPOIw/tprrzU2m82kpqYaY4xJT083ksxrr71Wql9JZtq0afbX06ZNM5LMmDFjHKYbOnSoOfvss+2vN23aZCSZW265xWG6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",
      "text/plain": [
       "<Figure size 1400x400 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA8wAAAF2CAYAAAC75hFUAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy81sbWrAAAACXBIWXMAAA9hAAAPYQGoP6dpAABDZklEQVR4nO3deXQUZdr38V8nIQlCCCBZJbJDZEnQKAiySjREh0WRJYPDIiICOvLwMDr4KoviRNweHEBQZwCdUVlccAMUGNkEUbZREJmAYRMCBCFNIgZI7vcPT3poUgG6053uDt/POXVOuvq+q66urq5cV602Y4wRAAAAAABwEuTrAAAAAAAA8EcUzAAAAAAAWKBgBgAAAADAAgUzAAAAAAAWKJgBAAAAALBAwQwAAAAAgAUKZgAAAAAALFAwAwAAAABggYIZAAAAAAALAV8w7927VzabTfPmzfN1KH5ryJAhql+/vq/D8JguXbqoS5cuXp9P/fr1NWTIEMfrVatWyWazadWqVV6fd6B57rnnlJiYqOLiYl+H4rbybEtK+r7wwgueD8wFF66zy5YtU/Xq1XXs2DHfBQUgoJFnXRp5lnvIsy5fRedZ5ETOAr5gvhLMmjVLffv21bXXXiubzeb05QO+ZrfbNXXqVD322GMKCmKTcilLlizRpEmTKmRe3bt3V+PGjZWZmVkh8wOAQESeBX9WmfOsQMmJQrwQT4WqV6+eTp8+rSpVqvg6FK+ZOnWqTp06pTZt2ujw4cO+DueK1alTJ50+fVqhoaG+DsWvzJkzR+fOnVNGRoavQymXitqWLFmyRDNnzqywfxAjRozQuHHjNHnyZEVERFTIPAFUHuRZqCjkWdZ8kWeREzkL+N0UNptN4eHhCg4O9nUobisoKLjo+6tXr1Zubq6WLl2qsLCwCooKFwoKClJ4eHil27tXXnPnzlXPnj0VHh7u61DKpTJsS6z06dNHhYWFWrRoka9DARCAKsO2kTwrMJBnWfNFnlUZfvdW3M2JfLJGnjp1SmPGjFH9+vUVFham6Oho3XbbbdqyZYujTZcuXdSyZUtt3rxZ7du3V9WqVdWgQQPNnj3baVpW59gPGTJE1atX108//aTevXurevXqioqK0rhx41RUVOTUf/78+UpJSVFERIRq1KihVq1a6eWXX5Ykbdq0STabTW+88Uapz/DZZ5/JZrPpk08+kSTt27dPo0aNUrNmzVS1alVdffXV6tu3r/bu3evUb968ebLZbFq9erVGjRql6Oho1a1b96LLq169erLZbJdcrq544YUX1L59e1199dWqWrWqUlJS9O6775Zqd/r0af3xj39UnTp1FBERoZ49e+qnn36SzWYrtTdo1apVuvHGGxUeHq5GjRrp1Vdf1aRJkyxj/+c//6mUlBRVrVpVtWvX1oABA3TgwIFS7V577TU1atRIVatWVZs2bbR27drL/oxz587VrbfequjoaIWFhal58+aaNWtWqXbGGE2ZMkV169bVVVddpa5du2rHjh2l2lldW7N27VrHaVxhYWFKSEjQ//zP/+j06dOl+v/www/q16+foqKiVLVqVTVr1kz/7//9P6c2P/30k+677z7FxMQoLCxMLVq00Jw5cyzjWLhwoZ555hnVrVtX4eHh6tatm3bv3l1qvhs3btQdd9yhWrVqqVq1akpKSnKs43PnzpXNZtPWrVtL9fvLX/6i4OBg/fTTT9YLWFJ2dra+/fZbpaamXnJZSeX7vd5www26++67nabXqlUr2Ww2ffvtt45xCxYskM1m086dOx3jLme5lnW9zqJFi9S8eXOFh4erZcuW+uCDDy56vVrJOhsWFqabbrpJ33zzjdNnnTlzpqTf/hmVDCWKi4s1bdo0tWjRQuHh4YqJidGIESN04sQJp3lc7jorSdHR0UpKStKHH35o+T6Ayoc8izyLPKty51nkRP9VETmRT07JfvDBB/Xuu+/qoYceUvPmzXX8+HGtW7dOO3fu1A033OBod+LECd1xxx3q16+fMjIytHDhQo0cOVKhoaG67777LjqPoqIipaWlqW3btnrhhRe0YsUKvfjii2rUqJFGjhwpSVq+fLkyMjLUrVs3TZ06VZK0c+dOffnll3rkkUd04403qmHDhlq4cKEGDx7sNP0FCxaoVq1aSktLkyR98803Wr9+vQYMGKC6detq7969mjVrlrp06aLvv/9eV111lVP/UaNGKSoqShMmTLjknk9vePnll9WzZ08NHDhQZ86c0fz589W3b1998sknuvPOOx3thgwZooULF+oPf/iDbr75Zq1evdrp/RJbt25V9+7dFRcXp8mTJ6uoqEhPPfWUoqKiSrV95pln9OSTT6pfv366//77dezYMU2fPl2dOnXS1q1bVbNmTUnS3//+d40YMULt27fXmDFj9OOPP6pnz56qXbu2EhISLvkZZ82apRYtWqhnz54KCQnRxx9/rFGjRqm4uFijR492tJswYYKmTJmiO+64Q3fccYe2bNmi22+/XWfOnLnkPBYtWqRffvlFI0eO1NVXX62vv/5a06dP18GDB532Xn377bfq2LGjqlSpogceeED169fXnj179PHHH+uZZ56RJB05ckQ333yzbDabHnroIUVFRWnp0qUaNmyY7Ha7xowZ4zTvZ599VkFBQRo3bpzy8vL03HPPaeDAgdq4caOjzfLly/W73/1OcXFxeuSRRxQbG6udO3fqk08+0SOPPKJ77rlHo0eP1ltvvaXrr7/eafpvvfWWunTpomuuuabMz79+/XpJcvrduuNyfq8dO3bUO++84+jz888/a8eOHQoKCtLatWuVlJQk6bd/rlFRUbruuuskub5cz/fpp5+qf//+atWqlTIzM3XixAkNGzaszGXy9ttv69SpUxoxYoRsNpuee+453X333frxxx9VpUoVjRgxQocOHdLy5cv1j3/8o1T/ESNGaN68eRo6dKj++Mc/Kjs7WzNmzNDWrVv15ZdfOk6NcnWdTUlJ0eLFiy/5PQCoHMizyLPIsyp3nkVOVME5kfGByMhIM3r06Iu26dy5s5FkXnzxRce4wsJC07p1axMdHW3OnDljjDEmOzvbSDJz5851tBs8eLCRZJ566imnaV5//fUmJSXF8fqRRx4xNWrUMOfOnSszjvHjx5sqVaqYn3/+2SmOmjVrmvvuu88x7pdffinVd8OGDUaSefPNNx3j5s6daySZDh06XHS+ZalWrZoZPHiwS30GDx5s6tWr5zTuwnjPnDljWrZsaW699VbHuM2bNxtJZsyYMU5thwwZYiSZiRMnOsb16NHDXHXVVeann35yjMvKyjIhISHm/NVs7969Jjg42DzzzDNO0/zuu+9MSEiIY/yZM2dMdHS0ad26tSksLHS0e+2114wk07lz50t+bqvvJC0tzTRs2NDx+ujRoyY0NNTceeedpri42DH+8ccfN5KclvUXX3xhJJkvvvjiovPIzMw0NpvN7Nu3zzGuU6dOJiIiwmmcMcZpnsOGDTNxcXEmNzfXqc2AAQNMZGSkY14lcVx33XVOy+bll182ksx3331njDHm3LlzpkGDBqZevXrmxIkTZc43IyPDxMfHm6KiIse4LVu2lPpd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",
      "text/plain": [
       "<Figure size 1400x400 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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cKmT33//XUlJSerVq5eef/551atXT8YYXX/99Vq2bJlGjx6tbt26afHixZo0aZL27dunF1980aU+zjR06FC1atVK06dP16ZNm/T666+radOmeuaZZxzzjBkzRm+99ZZuu+029ezZU1999ZWuvfZat/ssy5AhQ9SmTRs99dRTTv/wziU8PFyvvvqqxo0bp8GDB+vGG2+U5PzTq6KiIiUlJSkhIUHPP/+8li5dqhdeeEFxcXEaN26cy7FmZ2dLkpo0aeJyW+n0Dv/EiRMaN26cGjdurA0bNuiVV17R3r17tXDhQsd8n3/+uW655RZ17txZ06dP19GjRzV69Gg1a9bMaXnFxcUaOHCgNmzYoHHjxqldu3b65JNPlJqaWqrvrVu36oorrlCzZs300EMPqX79+nr//fc1aNAgffjhh45/fNnZ2erXr59+//13x3z/+Mc/VLdu3fN6j0uWLNEvv/yikSNHKjIyUlu3btU//vEPbd26VevWrXP8vGzLli26+uqrFR4erilTpuj333/X5MmTFRERcc4+fvnlF6WlpWnIkCFq1aqVDh48qNdee019+vTRTz/9pOjoaEmnP//rrrtO6enpuvXWWzV+/HgdP35cS5Ys0Y8//qi4uDhJ0h133KH58+dr5MiRuueee5SVlaVZs2bpu+++09dff606deo4+s7IyNDNN9+s0aNHKzU1VXPnztWIESMUHx+vjh07SpLy8vLUu3dv/fzzzxo1apQuueQS5eTk6NNPP9XevXvVrVs3DR48WO+9955mzJihWrVqOZb/zjvvyBjjSA7LUlhYqG+++catbfhsTz/9tAICAjRx4kTl5ubq2Wef1bBhw7R+/XpJUu/evVVcXKzVq1fruuuuk3Q6yQkICNCqVascy/nuu++Ul5enP/zhD45xrqzXM+Xn5+vKK6/UgQMHNH78eEVGRmrBggVatmxZmfMfPXpUAwYM0I033qihQ4fqgw8+0IMPPqjOnTsrOTlZ7du31xNPPKHHH39ct99+u3r37i1JjgTwq6++UnJysuLj4zV58mQFBARo3rx5uvLKK7Vq1Sp1795dkuvbbHx8vIwxWrNmjWPdAfAceZZryLPIs8izKifPIifyQU5kzlNubq6RZAYNGlRq2tGjR83hw4cdw4kTJxzTUlNTjSTz0EMPObVJS0szksyTTz7pNP7mm282NpvNZGRk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NXToUK1Zs0aTJk1St27d1KBBAxUXF2vAgAGV9h6feuopPfbYYxo1apSmTZumCy64QAEBAbr33ntd7qO4uFhNmzZ1OlJ6prOTi8r83gwfPlzPPfec0tLSlJKSogULFui6665TWFhYhe0aN24sSWXuUCvaF5QV+/m8n169eqmwsFBr167VqlWrHP9YevfurVWrVmnbtm06fPiw0z8cV9erJzz5TEq2l+eee67cx3Q0aNBABQUFLsdV8vm4e20jgNLIs1xHnkWe5SryrPLzLHIia3Mil27Mdu211+r111/Xhg0bnH5q4o7Y2FgtXbpUx48fdzpKu23bNsd06X9HV8+8W5/k2RHc2NhYFRcXO45yldi+fbvbyzxfjRo1KvNnE2e/H2+fYVq/fr0GDx6sSy+9VO+//36ZR/qWLFni9LrkphFn27Jli/773//qjTfe0PDhw8ttX/KZnnmH6hJnj4uNjdWyZct04sQJp6O0Z8/XunVrSVKdOnXO+ciP2NhYx5GwM53P53706FGlp6dr6tSpevzxxx3jz15eeHi46tat63Y/H3zwgfr166d//etfTuOPHTvm9OWOi4vT+vXrVVhYWO4NL+Li4rR06VJdccUV531TlHOJi4srM0E8W6dOnXTxxRfr7bffVvPmzbV792698sor52zXokUL1a1bV1lZWaWmNWrUqNR+QDr93SnZDlzVvXt3BQYGatWqVVq1apUmTZokSfrDH/6gf/7zn0pPT3e8LuHJeo2NjdVPP/0kY4zTd7ys78T5Km9fUXIGKjQ0tMLvhjvbbMnnc+YzewF4jjzLc+RZ5FkVIc8qP88iJ7I2J3LpsOkDDzygevXqadSoUTp48GCp6a4cybnmmmtUVFSkWbNmOY1/8cUXZbPZlJycLOn0ymrSpInjGoUSf//7310J3UnJsl9++WWn8TNnznR7mecrLi7OcSSpxPfff1/q9vglO8Syig5P/fzzz7r22mvVsmVLffbZZ+V+aRITE52Gsh6XIv3vyNSZn78xRi+99JLTfNHR0erUqZPefPNNp5/brVixQlu2bHGaNykpSYWFhfrnP//pGFdcXFzqOrimTZuqb9++eu2113TgwIFSsZ25nq+55hqtW7dOGzZscJpe3tG7c71HqfQ2U6tWLSUlJSktLU27d+92jP/555+1ePHi8+rn7D4WLlzouN6qxE033aScnJxS358zYxw6dKiKioo0bdq0UvP8/vvvbm1bN910k77//nt9/PHH5fZb4k9/+pO+/PJLzZw5U40bN3Z87ypSp04dXXrppdq4cWOpaXFxcVq3bp1+++03x7jPPvtMe/bscfl9lAgODtZll12md955R7t373Y66nvy5Em9/PLLiouLc9r2PVmvSUlJ2rdvn9NjXU6dOuW0nbuq5Lm4Z/cbHx+vuLg4Pf/882X+vLXku+HONvvtt9/KZrOpR48ebscNoDTyLM+RZ5Fnnasf8qyy8yxyImtzIpfOhLdp00YLFixQSkqK2rZtq2HDhqlr164yxigrK0sLFixQQEBAqeuSyjJw4ED169dPjzzyiHbu3KmuXbvqyy+/1CeffKJ7773X6TqiMWPG6Omnn9aYMWN06aWXauXKlfrvf//r0hs9U7du3ZSSkqK///3vys3NVc+ePZWenu7RkZfzNWrUKM2YMUNJSUkaPXq0Dh06pDlz5qhjx46OG5pIp39i1aFDB7333nu66KKLdMEFF6hTp07nvE7kXI4fP66kpCQdPXpUkyZN0ueff+40PS4uzuWNqF27doqLi9PEiRO1b98+hYaG6sMPPyzzpy5PPfWUbrjhBl1xxRUaOXKkjh49qlmzZqlTp05OX4pBgwape/fuuv/++5WRkaF27drp008/dTyD78wjXbNnz1avXr3UuXNnjR07Vq1bt9bBgwe1du1a7d271/HsxwceeED//ve/NWDAAI0fP97x6IzY2Fj98MMPFb7H0NBQ/eEPf9Czzz6rwsJCNWvWTF9++WWZRxKnTp2qRYsWqXfv3vrzn/+s33//Xa+88oo6dux4zn6uu+46PfHEExo5cqR69uypLVu26O233y51pnf48OF68803NWHCBG3YsEG9e/dWfn6+li5dqj//+c+64YYb1KdPH91xxx2aPn26Nm/erKuvvlp16tTRjh07tHDhQr300ku6+eabK4znbJMmTdIHH3ygIUOGaNSoUYqPj9evv/6qTz/9VHPmzFHXrl0d895222164IEH9PHHH2vcuHHlHkk+2w033KBHHnlEdrtdoaGhjvFjxozRBx98oAEDBmjo0KHKzMzUW2+9VeqaQ1f17t1bTz/9tMLCwhw3rmnatKnatm2r7du3l/ppoCfr9Y477tCsWbOUkpKi8ePHKyoqynEdl+TemZm4uDg1bNhQc+bMUUhIiOrXr6+EhAS1atVKr7/+upKTk9WxY0eNHDlSzZo10759+7Rs2TKFhobq//7v/yS5vs0uWbJEV1xxheNnbQAqB3mW58izyLMqQp5Vfp4lkRNJFuZELt1L/f/LyMgw48aNMxdeeKEJDg42devWNe3atTN33nmn2bx5s9O8qamppn79+mUu5/jx4+a+++4z0dHRpk6dOqZNmzbmueeec7p1vDGnbx8/evRoExYWZkJCQszQoUPNoUOHyn10xuHDh53az5s3r9SjEU6ePGnuuece07hxY1O/fn0zcOBAs2fPnkp9dMbZcZR46623TOvWrU1gYKDp1q2bWbx4calHZxhjzJo1a0x8fLwJDAx0iqu8dVrSb0VKHkVS3lDWI6DOVtajM3766SeTmJhoGjRoYJo0aWLGjh1rvv/++zIfE/Duu++adu3amaCgINOpUyfz6aefmptuusm0a9fOab7Dhw+b2267zYSEhJiwsDAzYsQI8/XXXxtJ5t1333WaNzMz0wwfPtxERkaaOnXqmGbNmpnrrrvOfPDBB07z/fDDD6ZPnz4mODjYNGvWzEybNs3861//Oq9HZ+zdu9cMHjzYNGzY0ISFhZkhQ4Y4Hktw9jazYsUKx2fXunVrM2fOnDI/n7IenXH//febqKgoU7duXXPFFVeYtWvXlvnIlRMnTphHHnnEtGrVytSpU8dERkaam2++2WRmZjrN949//MPEx8ebunXrmpCQENO5c2fzwAMPmP379zvFce2115Z6z2X1e+TIEXP33XebZs2amcDAQNO8eXOTmppqcnJySrW/5pprjCSzZs2aCtass4MHD5ratWubf//736WmvfDCC6ZZs2YmKCjIXHHFFWbjxo3lPqJs4cKFTm3LewzP559/biSZ5ORkp/Fjxowxksy//vWvMuM8n/Va1vr75ZdfzLXXXmvq1q1rwsPDzf333+94VMy6deuc2nbs2LFUv2XtKz755BPToUMHU7t27VLv8bvvvjM33nijady4sQkKCjKxsbFm6NChJj093WkZ57vNHjt2zAQGBprXX3+9zPUCwHPkWf9DnnUaedZkp3nJs06r7DyLnOg0K3IimzEW30UDKEO3bt0UHh5e6vqms6WlpWnw4MFavXq1rrjiCoui856YmBglJSXp9ddf93UoXjF48GBt2bLF5bMfo0eP1n//+1/H3Tir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",
      "text/plain": [
       "<Figure size 1400x400 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA8wAAAF2CAYAAAC75hFUAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy81sbWrAAAACXBIWXMAAA9hAAAPYQGoP6dpAABEPklEQVR4nO3dd3xUVf7/8fckIRNKEkBSJYZOqEGjIEiVYEAFUaRkVYqILKCrPxZ18SvNsohtUUDU3SXo2hALNkCBlSZYaKtYWMDQDKEJGYgYIDm/P3xkliE3wLTMTHg9H4/7eDB3zpnzmTM3l89n7tx7bcYYIwAAAAAA4CIs0AEAAAAAABCMKJgBAAAAALBAwQwAAAAAgAUKZgAAAAAALFAwAwAAAABggYIZAAAAAAALFMwAAAAAAFigYAYAAAAAwAIFMwAAAAAAFkK+YN6xY4dsNpvmzp0b6FCC1tChQ1WvXr1Ah+EzXbt2VdeuXf0+Tr169TR06FDn4+XLl8tms2n58uV+HzvUPPHEE0pLS1NJSUmgQ/GYN/uS0r5PPfWU7wNzw5nb7OLFi1WjRg0dOHAgcEEBCGnkWedGnuUZ8qzzV9F5FjmRq5AvmCu73bt3a8qUKWrbtq1q1aqlOnXqqGvXrlq6dGmgQwMkSQ6HQ9OmTdMDDzygsDB2KeeycOFCTZ48uULG6tmzpxo1aqSpU6dWyHgAEGrIsxDsKnOeFSo5UcjPempqqo4fP67bbrst0KH4xfvvv69p06apUaNGevTRRzVhwgQdPXpUPXr0UE5OTqDDu6B07txZx48fV+fOnQMdSlCZM2eOTp06pezs7ECH4pWK2pcsXLhQU6ZM8esYpxs5cqRefPFFHT16tMLGBFB5kGehopBnWQtEnkVO5CrkC2abzaaoqCiFh4cHOhSPFRYWlvtct27dtGvXLr3++usaM2aM7rnnHq1Zs0ZpaWmaOHFiBUaJsLAwRUVFVbpv97yVk5OjPn36KCoqKtCheKUy7Eus9OvXT0VFRZo/f36gQwEQgirDvpE8KzSQZ1kLRJ5VGf7urXiaEwVkizx69Kjuvfde1atXT3a7XfHx8erRo4c2bNjgbNO1a1e1bNlS69evV4cOHVS1alXVr19fL7zwgstrWf3GfujQoapRo4Z+/vln9e3bVzVq1FBcXJzGjRun4uJil/5vvvmmMjIyFB0drZiYGLVq1UrPPvusJGndunWy2Wx6+eWXy7yHTz75RDabTR999JEkaefOnRo9erSaNm2qqlWr6qKLLlL//v21Y8cOl35z586VzWbTihUrNHr0aMXHx6tu3brlzlWLFi1Up04dl3V2u13XXnut9uzZ4/FRo6eeekodOnTQRRddpKpVqyojI0Nvv/12mXbHjx/Xn/70J9WpU0fR0dHq06ePfv75Z9lstjI/oVi+fLkuv/xyRUVFqWHDhnrxxRc1efJk2Wy2Mq/76quvKiMjQ1WrVlXt2rU1aNAg7d69u0y7l156SQ0bNlTVqlXVtm1brVq16rzfY05Ojq6++mrFx8fLbrerefPmmj17dpl2xhg9+uijqlu3rqpVq6Zu3brpu+++K9PO6tyaVatWqX///rrkkktkt9uVkpKi//f//p+OHz9epv+PP/6oAQMGKC4uTlWrVlXTpk31f//3fy5tfv75Z91+++1KSEiQ3W5XixYtNGfOHMs43nrrLT322GOqW7euoqKi1L17d23btq3MuF9++aWuvfZa1apVS9WrV1fr1q2d23hOTo5sNps2btxYpt9f//pXhYeH6+eff7aeYEm5ubn65ptvlJmZec65krz7e73ssst00003ubxeq1atZLPZ9M033zjXzZs3TzabTT/88INz3fnMa3nn68yfP1/NmzdXVFSUWrZsqffee++s56uVbrN2u11XXHGFvv76a5f3OmvWLEm//2dUupQqKSnR9OnT1aJFC0VFRSkhIUEjR47U4cOHXcY4321WkuLj49W6dWu9//77ls8DqHzIs8izyLMqd55FTvQ/FZETRbjV2kf++Mc/6u2339Zdd92l5s2b69ChQ1q9erV++OEHXXbZZc52hw8f1rXXXqsBAwYoOztbb731lkaNGqXIyEjdfvvtZx2juLhYWVlZateunZ566iktXbpUTz/9tBo2bKhRo0ZJkpYsWaLs7Gx1795d06ZNkyT98MMP+vzzz3XPPffo8ssvV4MGDfTWW29pyJAhLq8/b9481apVS1lZWZKkr7/+WmvWrNGgQYNUt25d7dixQ7Nnz1bXrl31/fffq1q1ai79R48erbi4OE2cOPGs33yWJz8/X9WqVSvzuufr2WefVZ8+fXTLLbfoxIkTevPNN9W/f3999NFHuu6665zthg4dqrfeeku33XabrrzySq1YscLl+VIbN25Uz549lZSUpClTpqi4uFgPP/yw4uLiyrR97LHHNGHCBA0YMEB33HGHDhw4oBkzZqhz587auHGjatasKUn65z//qZEjR6pDhw6699579dNPP6lPnz6qXbu2UlJSzvkeZ8+erRYtWqhPnz6KiIjQhx9+qNGjR6ukpERjxoxxtps4caIeffRRXXvttbr22mu1YcMGXXPNNTpx4sQ5x5g/f75+/fVXjRo1ShdddJG++uorzZgxQ3v27HH59uqbb75Rp06dVKVKFd15552qV6+etm/frg8//FCPPfaYJGnfvn268sorZbPZdNdddykuLk6LFi3S8OHD5XA4dO+997qM/fjjjyssLEzjxo1TQUGBnnjiCd1yyy368ssvnW2WLFmi66+/XklJSbrnnnuUmJioH374QR999JHuuece3XzzzRozZoxee+01XXrppS6v/9prr6lr1666+OKLy33/a9askSSXv1tPnM/fa6dOnfTGG284+/zyyy/67rvvFBYWplWrVql169aSfv/PNS4uTs2aNZPk/rye7uOPP9bAgQPVqlUrTZ06VYcPH9bw4cPLnZPXX39dR48e1ciRI2Wz2fTEE0/opptu0k8//aQqVapo5MiRysvL05IlS/Svf/2rTP+RI0dq7ty5GjZsmP70pz8pNzdXM2fO1MaNG/X555+rSpUqktzfZjMyMrRgwYJzfg4AKgfyLPIs8qzKnWeRE1VwTmQCIDY21owZM+asbbp06WIkmaefftq5rqioyLRp08bEx8ebEydOGGOMyc3NNZJMTk6Os92QIUOMJPPwww+7vOall15qMjIynI/vueceExMTY06dOlVuHOPHjzdVqlQxv/zyi0scNWvWNLfffrtz3a+//lqm79q1a40k88orrzjX5eTkGEmmY8eOZx33bLZu3WqioqLMbbfddl7thwwZYlJTU13WnRnviRMnTMuWLc3VV1/tXLd+/Xojydx7770ubYcOHWokmUmTJjnX9e7d21SrVs38/PPPLnFGRESY0zezHTt2mPDwcPPYY4+5vOa3335rIiIinOtPnDhh4uPjTZs2bUxRUZGz3UsvvWQkmS5dupzzfVt9JllZWaZBgwbOx/v37zeRkZHmuuuuMyUlJc71Dz74oJFkhgwZ4lz32WefGUnms88+O+sYU6dONTabzezcudO5rnPnziY6OtplnTHGZczhw4ebpKQkc/DgQZc2gwYNMrGxsc6xSuNo1qyZy9w8++yzRpL59ttvjTHGnDp1ytSvX9+kpqaaw4cPlztudna2SU5ONsXFxc51GzZsKPN3ZeWhhx4ykszRo0dd1lvNlTHe/b3Onz/fSDLff/+9McaYDz74wNjtdtOnTx8zcOBAZ7vWrVubG2+80fn4fOfVKrZWrVqZunXrury/5cuXG0kuf1OlfS+66CKXfcX7779vJJkPP/zQuW7MmDHGate7atUqI8m89tprLusXL17sst6dbbbUX//6VyPJ7Nu3r8xzACof8izyLPKs31XWPIucqGJzooD8JLtmzZr68ssvlZeXd9Z2ERERGjlypPNxZGSkRo4cqf3792v9+vXnHOePf/yjy+NOnTrpp59+comjsLBQS5YsKfc1Bg4cqJMnT+rdd991rvv000915MgRDRw40LmuatWqzn+fPHlShw4dUqNGjVSzZk2Xn0CVGjFihEfnBfz666/q37+/qlatqscff9zt/lbxHj58WAUFBerUqZNLrIsXL5b0+7e0p7v77rtdHhcXF2vp0qXq27evkpOTnesbNWqkXr16ubR99913VVJSogEDBujgwYPOJTExUY0bN9Znn30m6fefae3fv19//OMfFRkZ6ew/dOhQxcbGuv0eCwoKdPDgQXXp0kU//fSTCgoKJElLly7ViRMndPfdd7v8DORs37CVN0ZhYaEOHjyoDh06yBjj/PnNgQMHtHLlSt1+++265JJLXPqXjmmM0TvvvKPevXvLGOMyN1lZWSooKCizHQ0bNsxlbjp16iRJzm1848aNys3N1b333uv8NvnMcSVp8ODBysvLc8699Pu3nlWrVlW/fv3O+v4PHTqkiIgI1ahR46ztzse5/l5L39/KlSsl/f6t6RVXXKEePXo4f0J25MgRbd682dnWk3ktlZeXp2+//VaDBw92eX9dunRRq1atLPsMHDhQtWrVKhPz6e+jPPPnz1dsbKx69OjhEmdGRoZq1Kjh/Hw82WZLYzp48OA54wAQ+sizyLPIs35XWfMscqKKzYkCUjA/8cQT2rx5s1JSUtS2bVtNnjzZcvKSk5NVvXp1l3VNmjSRpDLnrJwpKiqqzM9UatWq5fK799GjR6tJkybq1auX6tatq9tvv9258yqVnp6utLQ0zZs3z7lu3rx5qlOnjq6++mrnuuPHj2vixIlKSUmR3W5XnTp1FBcXpyNHjjh3GqerX7/+WeO3UlxcrEGDBun777/X22+/7bLTPH78uPLz812Ws/noo4905ZVXKioqSrVr11ZcXJxmz57tEuvOnTsVFhZWJtZGjRq5PN6/f7+OHz9eZr1V261bt8oYo8aNGysuLs5l+eGHH7R//37n2JLUuHFjl/5VqlRRgwYNzvreSn3++efKzMxU9erVVbNmTcXFxenBBx+UJOf7LG+cuLg4lz/y8uzatUtDhw5V7dq1nedwdenSxWWM0m27ZcuW5b7OgQMHdOTIEb300ktl5mXYsGGS5JybUmf+p1Aab+k2vn379nOOK0k9evRQUlKSXnvtNUm/nzPyxhtv6IYbblB0dPQ558AXzufvNSEhQY0bN3b+R7Bq1Sp16tRJnTt3Vl5enn766Sd9/vnnKikpce6UPZnXUqXbxvls16XO9ZmczdatW1VQUKD4+PgysR47duycfxtn22aNMZJkeZ4bgMqHPIs8izzLVWXLs8iJKjYnCsg5zAMGDFCnTp303nvv6dNPP9WTTz6padOm6d133y3zTZmnzudbxfj4eG3atEmffPKJFi1apEWLFiknJ0eDBw92uQDFwIED9dhjj+ngwYOKjo7WBx98oOzsbEVE/G/67r77buXk5Ojee+9V+/btFRsbK5vNpkGDBlneZPz0b8zO14gRI/TRRx/ptddec/lPRPr9P5fSjb1U6QZxplWrVqlPnz7q3Lmznn/+eSUlJalKlSrKycnR66+/7nZc7igpKZHNZtOiRYssPyNfHKmUft+Jde/eXWlpaXrmmWeUkpKiyMhILVy4UH/72998cuP34uJi9ejRQ7/88oseeOABpaWlqXr16vr55581dOhQt8YobXvrrbeWOY+rVOn5KKXK28bL+9zLEx4erj/84Q/6+9//rueff16ff/658vLydOutt56z70UXXaRTp07p6NGjLjv98nZCZ14M5vQYzkfHjh21bNkyHT9+XOvXr9fEiRPVsmVL1axZU6tWrdIPP/ygGjVqOM8T8mReveHNZ1JSUqL4+Hjnf6hnsjpP7XyV/ud05oVtAFRO5FnkWeRZripbniWRE3nKk5woIAWzJCUlJWn06NEaPXq09u/fr8suu0yPPfaYy448Ly9PhYWFLt9+/ve//5Wkcq/G5q7IyEj17t1bvXv3VklJiUaPHq0XX3xREyZMcH5jMnDgQE2ZMkXvvPOOEhIS5HA4NGjQIJfXefvttzVkyBA9/fTTznW//fabjhw54pM477vvPuXk5Gj69OmW92HLyso660+eTvfOO+8oKipKn3zyiex2u3P9mfcbTE1NVUlJiXJzc12+uTnzCoHx8fGKioqyvHLgmesaNmwoY4zq16/v/BbbSmpqqqTfv2E6/T+tkydPKjc3V+np6Wd9jx9++KGKior0wQcfuHzDdfrPYc4c5/RvVA8cOHDOb8C+/fZb/fe//9XLL7+swYMHO9ef+TmUvu7mzZvLfa24uDhFR0eruLi4zJUQPdWwYUPnuOd6zcGDB+vpp5/Whx9+qEWLFikuLs55oZWzSUtLk/T7VRxP38mWfqt35vZf+k2gpzp16qScnBy9+eabKi4uVocOHRQWFqaOHTs6/3Po0KGDcyftzbyWbhvns127o7wvExo2bKilS5fqqquuOmui58k2m5ub6zwaA+DCQJ7lHvKs35Fnnb9A5lkSOdHpcfk7J6rwn2QXFxeX+elMfHy8kpOTVVRU5LL+1KlTevHFF52PT5w4oRdffFFxcXHKyMjwOpZDhw65PA4LC3NujKfH0qxZM7Vq1Urz5s3TvHnzlJSUVOam6uHh4WW+MZkxY0a5R9Tc8eSTT+qpp57Sgw8+qHvuuceyTVJSkjIzM12W8oSHh8tms7nEtmPHjjJXjCv9Q37++edd1s+YMaPM62VmZmrBggUu50tt27ZNixYtcml70003KTw8XFOmTCkzX8YY52dy+eWXKy4uTi+88ILLVe7mzp17Xv85lu4cTh+joKCgzH9WmZmZqlKlimbMmOHSdvr06R6NYYxx3kqgVFxcnDp37qw5c+Zo165dLs+V9g0PD1e/fv30zjvvWO7wDxw4cM54znTZZZepfv36mj59epk5O3PuW7durdatW+sf//iH3nnnHQ0aNMjlm/3ytG/fXtLv50KdLjU1VeHh4c5za0qduS25q/RnRdOmTVPr1q2d51l16tRJy5Yt07p165xtJO/mNTk5WS1bttQrr7yiY8eOOdevWLFC3377rcfvoTQxPfMzGTBggIqLi/XII4+U6XPq1Clne0+22fXr1zs/KwCVG3mW+8izyLNCLc+SyImkisuJKvwI89GjR1W3bl3dfPPNSk9PV40aNbR06VJ9/fXXLt8aSr9/ONOmTdOOHTvUpEkTzZs3T5s2bdJLL73kvJS4N+644w798ssvuvrqq1W3bl3t3LlTM2bMUJs2bZyXXy81cOBATZw4UVFRURo+fHiZm6pff/31+te//qXY2Fg1b95ca9eu1dKlS3XRRRd5FeN7772n+++/X40bN1azZs306quvujzfo0cPJSQkuPWa1113nZ555hn17NlTf/jDH7R//37NmjVLjRo1crl3W0ZGhvr166fp06fr0KFDztsdlH77fPq3QpMnT9ann36qq666SqNGjVJxcbFmzpypli1batOmTc52DRs21KOPPqrx48drx44d6tu3r6Kjo5Wbm6v33ntPd955p8aNG6cqVaro0Ucf1ciRI3X11Vdr4MCBys3NVU5OznmdW3PNNdc4v9UeOXKkjh07pr///e+Kj4/X3r17ne1K7xs5depUXX/99br22mu1ceNGLVq06Jw/1UhLS1PDhg01btw4/fzzz4qJidE777xj+Y3Wc889p44dO+qyyy7TnXfeqfr162vHjh36+OOPnfPz+OOP67PPPlO7du00YsQINW/eXL/88os2bNigpUuX6pdffjnn+z5dWFiYZs+erd69e6tNmzYaNmyYkpKS9OOPP+q7777TJ5984tJ+8ODBGjdunCSd18+EpN+/1W3ZsqWWLl3qcguS2NhY9e/fXzNmzJDNZlPDhg310UcflXtuzPlq1KiREhMTtWXLFpeLonTu3FkPPPCAJLn85yB5N69//etfdcMNN+iqq67SsGHDdPjwYed2ffp/GO4oTUL/9Kc/KSsrS+Hh4Ro0aJC6dOmikSNHaurUqdq0aZOuueYaValSRVu3btX8+fP17LPP6uabb3Z7m92/f7+++eYbl1t8AKi8yLPcQ55FnhWKeZZETlShOdF5X0/bR4qKisx9991n0tPTTXR0tKlevbpJT083zz//vEu7Ll26mBYtWph169aZ9u3bm6ioKJOammpmzpzp0q682x1Ur169zNiTJk1yuXT522+/ba655hoTHx9vIiMjzSWXXGJGjhxp9u7dW6bv1q1bjSQjyaxevbrM84cPHzbDhg0zderUMTVq1DBZWVnmxx9/NKmpqS6XNC+93cHXX399XvNVGnN5y5m37bFidbuDf/7zn6Zx48bGbrebtLQ0k5OTU2Z+jDGmsLDQjBkzxtSuXdvUqFHD9O3b12zZssVIMo8//rhL22XLlplLL73UREZGmoYNG5p//OMf5s9//rOJiooqE9M777xjOnbsaKpXr26qV69u0tLSzJgxY8yWLVtc2j3//POmfv36xm63m8svv9ysXLnSdOnS5bxud/DBBx+Y1q1bm6ioKFOvXj0zbdo0M2fOHCPJ5ObmOtsVFxebKVOmmKSkJFO1alXTtWtXs3nz5jKfndXtDr7//nuTmZlpatSoYerUqWNGjBhh/vOf/1jeKmDz5s3mxhtvNDVr1jRRUVGmadOmZsKECS5t9u3bZ8aMGWNSUlJMlSpVTGJiounevbt56aWXysQxf/58l75WfwvGGLN69WrTo0cP599b69atzYwZM8rM1969e014eLhp0qTJOef2dM8884ypUaNGmVs/HDhwwPTr189Uq1bN1KpVy4wcOdJs3rzZ47/XUv379zeSzLx585zrTpw4YapVq2YiIyPN8ePHy/Q5n3ktb/7efPNNk5aWZux2u2nZsqX54IMPTL9+/UxaWlqZvk8++WSZsXXGrUFOnTpl7r77bhMXF2dsNluZ9/jSSy+ZjIwMU7VqVRMdHW1atWpl7r//fpOXl+dsc77brDHGzJ4921SrVs04HI4ysQGofMizyLOMIc+6EPIsY8iJjKmYnCgg92E+H6U7cgSfjRs3Gknm1VdfPWfbG264wTRq1KgCovK/pUuXGklm1apVgQ7FLw4cOGAiIiLK3FfzXI4cOWJq165t/vGPf/gpsuCTnp5uMjMzAx3GeWnTpk2Ze3wCAHlW8CLPIs86XbDnWRdCThSQ20ohdBw/frzMuunTpyssLKzM+UVntt26dasWLlyorl27+jPEClP6E6PKeqXhuXPnqri4WLfddptb/WJjY3X//ffrySef9MlVMYPJyZMnderUKZd1y5cv13/+85+Q2K4XL16srVu3avz48YEOBQBggTzrf8izrAVLnnUh50Q2Y9y8NnoF6dq1qw4ePHjWK97B/6ZMmaL169erW7duioiIcN4W4s4773S5UIj0+wUxhg4dqgYNGmjnzp2aPXu2ioqKtHHjxjL3RwslhYWFeu211/Tss8/K4XA475tYWfz73//W999/rwkTJqhbt2569913Ax1S0NixY4cyMzN16623Kjk5WT/++KNeeOEFxcbGavPmzV6fOwcAgUKeFRzIs8izQsUFnRP5/Fi3j/BToeDw6aefmquuusrUqlXL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",
      "text/plain": [
       "<Figure size 1400x400 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "for i in range(p + 1):\n",
    "    title = 'adjacency matrix' if i==0 else  '{}-lagged adjacency'.format(i)\n",
    "\n",
    "    # Visualizing the original adjacency matrix\n",
    "    fig, (ax1, ax2) = plt.subplots(1, 2)\n",
    "    fig.set_size_inches(14, 4)\n",
    "\n",
    "    ax1.imshow(B_true[:, i * d : (i + 1) * d], cmap='Greys') # blue = non-zero\n",
    "    ax1.set_title('Ground Truth {} (unweighted)'.format(title))\n",
    "\n",
    "    ax2.imshow(W_true[:, i * d : (i + 1) * d], cmap='PiYG') # green = positive, pink = negative\n",
    "    ax2.set_title(\"Ground Truth {} (weighted)\".format(title))\n",
    "\n",
    "    # Note:\n",
    "    # for larger graphs the dpi imshow analysis must be set accordingly (higher).\n",
    "\n",
    "    fig, (ax1, ax2) = plt.subplots(1, 2)\n",
    "    fig.set_size_inches(14, 4)\n",
    "\n",
    "    ax1.imshow(B_est[:, i * d : (i + 1) * d], cmap='Greys') # blue = non-zero\n",
    "    ax1.set_title('{} {} (unweighted)'.format(method, title))\n",
    "\n",
    "    ax2.imshow(W_est[:, i * d : (i + 1) * d], cmap='PiYG') # green = positive, pink = negative\n",
    "    ax2.set_title('{} {} (weighted)'.format(method, title))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "fb841495",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAgMAAAFtCAYAAACazWngAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy81sbWrAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAg3klEQVR4nO3df3zN9f//8ftrs8V+YJLRFuvtR2+/3tiiFZ+YRTIuhTKkVkqlVcsbpSKSLniTEpVC+iFEl1Jh7975lS7JezYUmR95W6mILSw/9+v5/aPvTs3GduRsZ3verpfLuWTnPM/z9Xi9zus8d+95XnsexxhjBAAArOVT0QUAAICKRRgAAMByhAEAACxHGAAAwHKEAQAALEcYAADAcoQBAAAsRxgAAMByhAEAACxHGIB13n//fTmOow0bNpT5ORERERo8eLAkaeHChQoNDdXevXs9VaKVWrVqpYcffriiywCsVK2iCwDK2+zZsyVJs2bN0nXXXef283v06KHg4GBFRERc5Mrs9uqrr6p+/foVXQZgJYfvJoBN9uzZo6uuukoBAQHKycnRDz/8UKZfQBEREerUqZMWLFhQDlVWHVu3blXbtm0rugwApeBjAljltddek4+Pj9544w3l5ubqtddeq+iSqqxp06bp+eefr+gyAJQBYQDWOHPmjN58803ddNNN6t+/v9q1a6fXX39dubm5xdq+/fbbatGihfz9/dWkSRMdOnTI9djcuXPlOI4yMjKUm5urESNGKDQ0VIGBgYqJidGOHTuK9LV8+XK1a9dOl1xyiS6//HI9+uijrsdSU1N1/fXXq3r16goLC9OUKVNcj7355ptyHEfLly/Xddddp5o1a2rAgAHKzs52tTl27JiGDh2qunXrqkaNGrrmmmu0adMm3X777QoMDFRWVpar7ZQpU+Q4jr7++usSj4/jOBo5cqTuu+8+BQYGqn379tq1a5dSU1PVpk0b1a5dW8OGDVNeXp4k6auvvlJ0dLSqV6+u8PBwTZw40dXXzJkzNWrUKC1YsECO48hxHEnS+PHj5TiOfvnlF8XExCg4OFijR4+WJIWHh+uuu+5y9ZGenq6bbrpJgYGBql27tuLi4nTs2DFJ0qFDhzRw4EDVqlVLNWvW1N13360TJ064njt27FjVq1dPISEh6tu3r/bv31/iPgP4HWEA1li6dKmysrI0dOhQSVJiYqJ+/vlnffDBB0XazZ07VwkJCQoMDNSkSZM0ePBg+fiU/FZJS0vTwoULdffdd2vChAn69ttvlZCQ4Hp848aNuvnmm5Wfn6/nnntOQ4cOVWpqqqTff6HdcMMNys/P15QpUxQfH68xY8Zo3rx5RbbxwAMPqEePHkpISNB7772nZ5991vXYoEGDNH/+fPXv319Tp05VWFiY0tPT9dhjj+nkyZOu6yPy8vL08ssvKyYmRm3atDnnMXr55Zfl6+ur8ePHa+/everdu7fuuOMODRo0SDExMZo9e7bmz58vSZowYYLq1KmjqVOnqmPHjho7dqxWrFihM2fOKCAgQJdeeqmio6M1Z84czZkzp8h2EhMTFRsbq169ehX5JV4oOztbXbt2VUpKikaOHKmxY8fq0KFDOnLkiIwx6tOnjzZs2KDRo0dr9OjRWrlypR544AFJ0rp16zRx4kR169ZNo0eP1oEDB/Ttt9+ec58BSDKAJTp27GgaNGhg8vLyjDHGnDx50tSpU8d07NixSLuwsDDTsmVLk5OT47qvUaNG5vbbbzfGGDNnzhwjyezbt8/s37/fHD582NVuxIgRplq1aq6fe/ToYcLDw83x48dd9+Xm5hpjjBkzZoy59NJLTUZGhjlw4IA5cOCAGTRokLn66quNMcbMnz/fSDKrVq1yPbdTp04mMjLSGGPMxo0bjSTz4osvFqm/sP8ePXqY+vXrmzNnzpglS5YYSeajjz465/GRZB566CHXz+PGjTOSzObNm1391q9f38THxxtjjNmyZYur7W+//WYkmYkTJ5Z4zM7uc9GiRa77Co9zWFiYSUhIMMYYM3nyZOPj4+PatjHGFBQUmLy8PLNq1SojyXz66aeu4zZr1ixTrVo1c/ToUfPvf//bSDIzZsxwPffMmTPn3G8AxvDXBLDC9u3b9eWXX0qSqlUretp/+eWXrgvdfvnlF/30008aNmyY/Pz8Su03PDxckvS///1Pr7zyit59913XNLokbdmyRX369FFgYKDrvsLtb9u2TVlZWcX+KqFGjRpFfm7UqJHr340bN9bq1atdfUvSgAEDirQv7P+xxx5T165dtXDhQs2dO1dNmjRRr169zrs/tWrVKrZvISEhrn4bNWrk+uihbdu2ys/P15IlS1yzBSV95FKSHj16uP5d0nHesmWLmjVrpnbt2rnucxxHvr6+2rZtmyTpxhtvLPa8Xbt2qXv37ho6dKiSkpL05Zdf6uWXX1bdunXLVBdgK8IArDB79mz5+PgoKSmpyJS/MUYvvfSSZs2apblz5yooKEiSXP8ti1GjRmnt2rUaP368/P39NWnSJNdjR48ePefzLrnkEjVs2LDYRYyFn6+fi/n/fwB0vr4lKSYmRu3bt9cTTzyhgwcPaubMmef8uMMdhdvfsmWLEhIS1LNnT82dO7dIaClNace3tOMmSYsXLy4SXiSpSZMmchxHr7/+umJjY/XPf/5TkZGRWr9+PX8KCpwHYQBV3okTJ7RgwQLFxcVp+vTpxR7fv3+/Fi5cqH/961+qU6eOGjdurC+++EJJSUml9r1mzRpNmzZNKSkpat++vTZu3Fjk8Xbt2mnFihU6fvx4sV+A0dHRWrp0qUJDQ4v8H/Dhw4fLtF+Fz1m8ePE5a3388cd16623qnbt2kUuzrsYkpKSdMUVV2jy5MlFZkMK+fn5KScn54L6bteunT777DNt2bKlyLGRfj9uknTw4EHFx8e77j9x4oR8fHz0448/6vLLL1d8fLy6dOmiiIgIzZgxQy+88MIF1QLYgDCAKm/RokU6duyYEhMTS3w8KSlJS5cu1bx58zRq1Cg9/fTTSkhI0LBhwxQbG6vq1avr1KlTJT739OnTkqSJEycqOjradfHfmDFjNHr0aI0fP149e/bU1VdfrTvvvFMBAQH67LPPtGLFCt13332aNm2aunXrpvvvv1/16tXTpk2blJaWpvT09FL3q3v37urUqZNGjBihb775RpGRkcrIyFCTJk10//33S5KioqIkSffee69bsx1lcfr0aX399deaOnWqUlJSJEkbNmzQkiVL1L9/f/3jH//QypUrNWnSJP3888/q1KlTmft++OGHNW/ePHXt2lX333+/GjZsqNTUVD3wwAPq0KGDbr75Zo0cOVLffvutWrdure+++06LFi1SSkqKli1bptdff12DBw9WZmamzpw54/rIA8A5VPA1C4DHRUVFmSZNmpiCgoLztrnyyitNfn6+McaYWbNmmcaNGxsfHx8jyUgq8QLCvLw8c+utt5rg4GATFxdnXn31VVOzZk0THx/vupAvOTnZdOjQwfj7+5uAgAATGxvr2u6OHTtMt27dTI0aNUzNmjXN//3f/5mlS5caY/64gHDPnj2u9gkJCSYsLMz1c3Z2tnnwwQdNvXr1jOM4JiIiwrz//vuux0eOHGl8fX3N999/X+pxkmSeeuop189/3s9C11xzjav+VatWmQYNGphGjRqZ2bNnm86dO5v69eub1atXG2OM2bt3r+nUqZOpUaOGadGihdmwYYPrAsLCY/Nnf76A0Bhjdu3aZXr37m2CgoJMtWrVTNu2bc3OnTuNMcYcPXrUDBkyxISEhJgaNWqYli1bmilTppicnByzfft2ExcXZwIDA01wcLC58847zenTp0vdf8BmrEAIuGnu3LkaOnSoMjIy3PqcvLwdP35c4eHh6t69u5YsWVLR5QDwYqwzALipcAGi4ODgCq7k/ObPn69jx45p+PDhFV0KAC/HzADghq1btyo2NlahoaHFVhr0JgUFBWrWrJnq1q1b7KJGADgbMwOAG5o3b66ePXvqnXfeqehSzuuTTz7R3r17iyx9DADnwswAAACWY2YAAADLEQYAALAcYQAAAMsRBgAAsBxhAAAAyxEGAACwHGEAAADLEQYAALAcYQAAAMsRBgAAsBxhAAAAyxEGAACwHGEAAADLEQYAALAcYQAAAMsRBgAAsBxhAAAAyxEGAACwHGEAAADLEQYAALAcYQAAAMsRBgAAsBxhAAAAyxEGAACwHGEAAADLEQYAALAcYQAAAMsRBgAAsBxhAAAAyxEGAACwHGEAAADLEQYAALAcYQAAAMsRBgAAsBxhAAAAyxEGAACwHGEAAADLEQYAALAcYQAAAMsRBgAAsBxhAAAAyxEGAACwHGEAAADLEQYAALAcYQAAAMsRBgAAsBxhAAAAyxEGAACwHGEAAADLEQYAALAcYQAAAMsRBgAAsBxhAAAAyxEGAACwHGEAAADLEQYAALAcYQAAAMsRBgAAsBxhAAAAyxEGAACwHGEAAADLEQYAALAcYQAAAMsRBgAAsBxhAAAAyxEGAACwHGEAAADLEQYAALAcYQAAAMsRBgAAsBxhAAAAyxEGAACwHGEAAADLEQYAALAcYQAAAMsRBgAAsBxhAAAAyxEGAACwHGEAAADLEQYAALAcYQAAAMsRBgAAsBxh4DwOHjyop59+Wtdcc43q1KkjHx8fBQYGqkOHDnr00Ue1du1aFRQUVHSZF2zr1q1yHEd33XVXscciIiLkOE6ZbuPHj/donePHj5fjOHr//fc9uh2gKsvIyNAVV1yhgQMHVnQp8ELVKroAbzVnzhwlJSXp1KlTatasmXr16qWQkBBlZ2crJSVFL730kmbMmKGvvvpK0dHRFV3uRTdkyBD9+uuvrp+zs7M1f/58BQcHa8iQIUXaVsX9B6qa+vXr65FHHlHLli0ruhR4IcJACZ5//nmNHDlSoaGhWrJkiXr16lWszYEDB/TGG2+odu3a5V9gOXj66aeL/JyRkaH58+erTp06evHFFz223QULFmjw4MEe6x+wVfXq1TVq1KiKLgNeijBwlq+//lqPP/64QkJCtH79ejVr1qzEdg0aNNBTTz1VztVVbU888YQWLVpEGACAcsY1A2eZPn268vPzNWbMmHMGgXPp0qWLHMdRZmamnnnmGdWqVUtNmzZ1fdZtjNHs2bMVGRmpGjVqKDg4WNdff70WL15cpJ9169bJcRw99NBDRe4/+7PzjIwMOY6jXr16KTk5WW3btlVQUJC6dOmib775plh9H3zwga699loFBAQoODhYd999t1v7V5I/17pz50516NBBgYGBGjx4sH799Ve9+eabchxH06ZNK/K8u+66S47jKDU1VcYYJSYmavLkyfr+++9d1yKcfS1Dbm6unnzySdWrV0+hoaF65JFHdOrUqb+8D0BlkJqaqs6dOys4OFiXX365Bg0apPT0dNd7sPAWFBSktm3basKECTpx4oTr+X8eLwoVjlnbt29XfHy8goKC1LhxY73yyitl2vZPP/0kf39/NW/eXMaYIs9p166d/Pz89OOPP2rdunXq3LmzgoKCVLt2bXXv3l2pqalF2pc2fsKzCANnWbNmjSSpX79+F9zH5MmTtXLlSvXq1Us//fSTvvvuOxUUFKh///4aNmyYsrKy1L9/f/Xo0UPbtm3TwIEDlZiYeMHb27x5swYNGqR27dqpY8eO+vzzzxUXF6fjx4+72kydOlX9+vXT1q1b1b17d91xxx3y9fW94G2eLSsrS3379tVVV12lpk2batWqVWXuf9OmTfLz85O/v7+Cg4OVlJSkpKQkde/evUi7xx9/XB999JH69OmjwMBAzZw5U2PHjr1o+wB4q4KCAvXu3VsbNmxQz549FR0drU8//VQrVqxwtWnTpo2SkpIUHx+v3NxcjRs3Th07diwyDpxLz549XePS4cOHlZiYqGXLlpW67bCwMMXHx2vnzp1auXKlq7/PP/9cW7du1W233abw8HD17dtXGRkZGjhwoLp1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",
      "text/plain": [
       "<Figure size 640x480 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAgMAAAFtCAYAAACazWngAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy81sbWrAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAftklEQVR4nO3de1RVZcLH8d8GIeWiYiYapDSijbfxlkbppEgaia5SS9QsyrIyKnLUsvKW2VJHs0wrS80upqatslKZJm/ZyhyEtDTxkiNlpSmkklduz/tHL6eOoHAYkQPP97MWKzlnn72fsw88fNtns3GMMUYAAMBaPhU9AAAAULGIAQAALEcMAABgOWIAAADLEQMAAFiOGAAAwHLEAAAAliMGAACwHDEAAIDliAFY57333pPjONq4cWOpHxMREaHBgwdLkhYtWqTQ0FDt3bu3vIZopZYtW+rhhx+u6GEAVqpW0QMALrY5c+ZIkmbPnq3rrrvO48fHxsYqODhYERERF3hkdnvllVdUv379ih4GYCWHv00Am+zZs0dXXXWVAgIClJOTox9++KFUP4AiIiLUuXNnLVy48CKMsurYunWr2rRpU9HDAFAC3iaAVV599VX5+Pjo9ddfV25url599dWKHlKVNX36dD333HMVPQwApUAMwBpnzpzRG2+8oZtuukn9+/dX27Zt9dprryk3N7fIsm+99ZaaN28uf39/RUZG6tChQ6775s2bJ8dxlJGRodzcXI0YMUKhoaEKDAxUdHS0duzY4bauFStWqG3btrrkkkt0+eWX69FHH3Xdl5qaquuvv17Vq1dXWFiYpk6d6rrvjTfekOM4WrFiha677jrVrFlTAwYMUHZ2tmuZY8eOaejQoapbt65q1Kiha665Rps3b9btt9+uwMBAZWVluZadOnWqHMfR119/Xez+cRxHI0eO1H333afAwEB16NBBu3btUmpqqlq3bq3atWtr2LBhysvLkyR9+eWXioqKUvXq1RUeHq5Jkya51jVr1iyNGjVKCxculOM4chxHkjRhwgQ5jqNffvlF0dHRCg4O1ujRoyVJ4eHhuuuuu1zrSE9P10033aTAwEDVrl1bcXFxOnbsmCTp0KFDGjhwoGrVqqWaNWvq7rvv1okTJ1yPHTt2rOrVq6eQkBD17dtX+/fvL/Y5A/gdMQBrLFu2TFlZWRo6dKgkKTExUT///LPef/99t+XmzZunhIQEBQYGavLkyRo8eLB8fIr/VklLS9OiRYt09913a+LEifr222+VkJDgun/Tpk26+eablZ+fr2effVZDhw5VamqqpN9/oN1www3Kz8/X1KlTFR8frzFjxmj+/Plu23jggQcUGxurhIQEvfvuu3rmmWdc9w0aNEgLFixQ//79NW3aNIWFhSk9PV2PPfaYTp486To/Ii8vTy+99JKio6PVunXrc+6jl156Sb6+vpowYYL27t2r3r1764477tCgQYMUHR2tOXPmaMGCBZKkiRMnqk6dOpo2bZo6deqksWPHauXKlTpz5owCAgJ06aWXKioqSnPnztXcuXPdtpOYmKiYmBj16tXL7Yd4oezsbHXr1k0pKSkaOXKkxo4dq0OHDunIkSMyxqhPnz7auHGjRo8erdGjR2vVqlV64IEHJEnr16/XpEmT1L17d40ePVoHDhzQt99+e87nDECSASzRqVMn06BBA5OXl2eMMebkyZOmTp06plOnTm7LhYWFmRYtWpicnBzXbY0aNTK33367McaYuXPnGklm3759Zv/+/ebw4cOu5UaMGGGqVavm+jw2NtaEh4eb48ePu27Lzc01xhgzZswYc+mll5qMjAxz4MABc+DAATNo0CBz9dVXG2OMWbBggZFkVq9e7Xps586dTbt27YwxxmzatMlIMi+88ILb+AvXHxsba+rXr2/OnDljli5daiSZDz/88Jz7R5J56KGHXJ+PHz/eSDJfffWVa73169c38fHxxhhjtmzZ4lr2t99+M5LMpEmTit1nZ69z8eLFrtsK93NYWJhJSEgwxhgzZcoU4+Pj49q2McYUFBSYvLw8s3r1aiPJfPLJJ679Nnv2bFOtWjVz9OhR869//ctIMjNnznQ99syZM+d83gCM4bcJYIXt27friy++kCRVq+b+Zf/FF1+4TnT75Zdf9NNPP2nYsGHy8/Mrcb3h4eGSpP/+9796+eWX9c4777gOo0vSli1b1KdPHwUGBrpuK9z+tm3blJWVVeS3EmrUqOH2eaNGjVz/bty4sdasWeNatyQNGDDAbfnC9T/22GPq1q2bFi1apHnz5ikyMlK9evU67/OpVatWkecWEhLiWm+jRo1cbz20adNG+fn5Wrp0qetoQXFvuRQnNjbW9e/i9vOWLVvUtGlTtW3b1nWb4zjy9fXVtm3bJEk33nhjkcft2rVLPXr00NChQ5WUlKQvvvhCL730kurWrVuqcQG2IgZghTlz5sjHx0dJSUluh/yNMXrxxRc1e/ZszZs3T0FBQZLk+m9pjBo1SuvWrdOECRPk7++vyZMnu+47evToOR93ySWXqGHDhkVOYix8f/1czP//AtD51i1J0dHR6tChg5544gkdPHhQs2bNOufbHZ4o3P6WLVuUkJCgnj17at68eW7RUpKS9m9J+02SlixZ4hYvkhQZGSnHcfTaa68pJiZG//jHP9SuXTtt2LCBXwUFzoMYQJV34sQJLVy4UHFxcZoxY0aR+/fv369Fixbpn//8p+rUqaPGjRvr888/V1JSUonrXrt2raZPn66UlBR16NBBmzZtcru/bdu2WrlypY4fP17kB2BUVJSWLVum0NBQt/8DPnz4cKmeV+FjlixZcs6xPv7447r11ltVu3Ztt5PzLoSkpCRdccUVmjJlitvRkEJ+fn7Kyckp07rbtm2rTz/9VFu2bHHbN9Lv+02SDh48qPj4eNftJ06ckI+Pj3788Uddfvnlio+PV9euXRUREaGZM2fq+eefL9NYABsQA6jyFi9erGPHjikxMbHY+5OSkrRs2TLNnz9fo0aN0rhx45SQkKBhw4YpJiZG1atX16lTp4p97OnTpyVJkyZNUlRUlOvkvzFjxmj06NGaMGGCevbsqauvvlp33nmnAgIC9Omnn2rlypW67777NH36dHXv3l3333+/6tWrp82bNystLU3p6eklPq8ePXqoc+fOGjFihL755hu1a9dOGRkZioyM1P333y9Jat++vSTp3nvv9ehoR2mcPn1aX3/9taZNm6aUlBRJ0saNG7V06VL1799ff/vb37Rq1SpNnjxZP//8szp37lzqdT/88MOaP3++unXrpvvvv18NGzZUamqqHnjgAXXs2FE333yzRo4cqW+//VatWrXSd999p8WLFyslJUXLly/Xa6+9psGDByszM1NnzpxxveUB4Bwq+JwFoNy1b9/eREZGmoKCgvMuc+WVV5r8/HxjjDGzZ882jRs3Nj4+PkaSkVTsCYR5eXnm1ltvNcHBwSYuLs688sorpmbNmiY+Pt51Il9ycrLp2LGj8ff3NwEBASYmJsa13R07dpju3bubGjVqmJo1a5q///3vZtmyZcaYP04g3LNnj2v5hIQEExYW5vo8OzvbPPjgg6ZevXrG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kSNHioyluPkTF4GBG39/fyPJ5OTkFLkvKyvLJCUluX0kJye77u/SpYuRZG677TZTUFBgjDFm9+7dJicnx8yZM8dIMnFxcebkyZOuxxw8eNC0atXKSDIrV640xhizbt06I8kkJia6bX/8+PFGklm2bJkxxph9+/YZSaZBgwZm9+7druXi4+ONJPPRRx8ZY4z5/vvvjZ+fnwkODjbbtm1zLbdlyxYjySQkJJS4Xwq31ahRI7fbC8fq5+dn0tLSjDHG5Ofnmx07dhhjjFmwYIGRZKZNm+b2uISEBCPJbN682XVbrVq1iqz/z897wIABrtfl0KFDJigoyFx66aUljh2o7LKysowk06pVK5OXl2eMMebUqVNmz549xc4X+fn55t577zWSzDPPPGOM+eN7OC4uzrVc4Zw1a9Ys123JyclGkunbt2+J2zbGmK1btxpJplu3bq513HLLLUaSSUlJMcYYM2nSJLc59Z577jGSzL///e8iYylu/kT548jAWQpPCPzll1+K3Jedna2ZM2e6fWzatKnIciNHjpTjOJKkJk2ayM/PT4sWLZIkzZw5UzVq1HAtGxoaqhkzZkhSkbcLSqtdu3Zq0qSJ6/Po6GhJ0r59+yRJycnJys3N1bBhw9SyZcsybaMkN9xwg9q1aydJ8vHxUbNmzS74Nvr16yc/Pz9J0mWXXaaWLVsqKytLv/322wXfFuBN6tSpo379+mnbtm2KiYnRrl27VL16dUVGRha7vI+Pj5555hlJv3//l2TAgAGuf589f5S07datWysmJkZr167V1q1btW/fPn300Ufq1KmTOnToIEl66qmnXN+733zzjX744QdJ0rFjx4qMpbj5E+WPGDhL4a/JffDBB0Xui4iIkDFGxhiNHz/+nOu48sori9x24MAB+fr6Fntf4Q/O4gKkLC655BJJUk5OjiQpMzNTksotBKTin3N5K3yeZ86cuejbBi62d999V08//bQ2btyoVq1aafLkyUXep/+z+vXry9/fX4cPH/ZoO2fPH6XZ9siRIyX9fs7VrFmzVFBQoOHDh7ut96OPPlLHjh01atQo1w/74lTEXAJioIjCk/YmTpzoKmNPFfeFHh4ervz8fO3atavIfTt37pQkhYWFSZKrhPPy8sq0/bOFhoZK+iMKysO5vrkv9HMBbOXr66tx48Zpx44dio6O1pNPPnnec2Z2796t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",
      "text/plain": [
       "<Figure size 640x480 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAgMAAAFtCAYAAACazWngAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy81sbWrAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAf80lEQVR4nO3de1RVZeL/8c8GIeWiYiYapDReGm/jLY3Sb4qkmegqtUTNoiwroyJHLStvmS11NMu0stTsYmraKiuVafKWrcxBTEsTLzlSVppCKnnl9vz+6MeejqBwmA4gz/u1Fis5Z5+9n72BzbvN5sExxhgBAABr+ZX3AAAAQPkiBgAAsBwxAACA5YgBAAAsRwwAAGA5YgAAAMsRAwAAWI4YAADAcsQAAACWIwZgnffee0+O42jjxo0lfk1UVJQGDx4sSVq0aJHCw8O1b98+Xw3RSi1atNDDDz9c3sMArFSlvAcAlLU5c+ZIkmbPnq3rrrvO69f36NFDoaGhioqK+pNHZrdXXnlFdevWLe9hAFZy+NsEsMnevXt11VVXKSgoSNnZ2frhhx9K9A0oKipKnTp10sKFC8tglJXHtm3b1Lp16/IeBoBi8GMCWOXVV1+Vn5+fXn/9deXk5OjVV18t7yFVWtOnT9dzzz1X3sMAUALEAKxx9uxZvfHGG7rpppvUv39/tWnTRq+99ppycnIKLfvWW2+pWbNmCgwMVKNGjXT48GH3uXnz5slxHKWnpysnJ0cjRoxQeHi4goODFRMTo507d3qsa8WKFWrTpo0uueQSXX755Xr00Ufd51JTU3X99deratWqioiI0NSpU93n3njjDTmOoxUrVui6665T9erVNWDAAGVlZbnLHD9+XEOHDlXt2rVVrVo1XXPNNdq8ebNuv/12BQcHKzMz01126tSpchxHX3/9dZHHx3EcjRw5Uvfdd5+Cg4PVvn177d69W6mpqWrVqpVq1qypYcOGKTc3V5L05ZdfKjo6WlWrVlVkZKQmTZrkrmvWrFkaNWqUFi5cKMdx5DiOJGnChAlyHEe//PKLYmJiFBoaqtGjR0uSIiMjddddd7nrSEtL00033aTg4GDVrFlTcXFxOn78uCTp8OHDGjhwoGrUqKHq1avr7rvv1smTJ93Xjh07VnXq1FFYWJj69u2rAwcOFLnPAH5HDMAay5YtU2ZmpoYOHSpJSkxM1M8//6z333/fY7l58+YpISFBwcHBmjx5sgYPHiw/v6K/VLZs2aJFixbp7rvv1sSJE/Xtt98qISHBfX7Tpk26+eablZeXp2effVZDhw5VamqqpN+/od1www3Ky8vT1KlTFR8frzFjxmj+/Pke23jggQfUo0cPJSQk6N1339UzzzzjPjdo0CAtWLBA/fv317Rp0xQREaG0tDQ99thjOnXqlHt/RG5url566SXFxMSoVatW5z1GL730kvz9/TVhwgTt27dPvXv31h133KFBgwYpJiZGc+bM0YIFCyRJEydOVK1atTRt2jR17NhRY8eO1cqVK3X27FkFBQXp0ksvVXR0tObOnau5c+d6bCcxMVGxsbHq1auXxzfxAllZWeratatSUlI0cuRIjR07VocPH9bRo0dljFGfPn20ceNGjR49WqNHj9aqVav0wAMPSJLWr1+vSZMmqVu3bho9erQOHjyob7/99rz7DECSASzRsWNHU69ePZObm2uMMebUqVOmVq1apmPHjh7LRUREmObNm5vs7Gz3sQYNGpjbb7/dGGPM3LlzjSSzf/9+c+DAAXPkyBF3uREjRpgqVaq47/fo0cNERkaaEydOuI/l5OQYY4wZM2aMufTSS016ero5ePCgOXjwoBk0aJC5+uqrjTHGLFiwwEgyq1evdl/bqVMn07ZtW2OMMZs2bTKSzAsvvOAx/oL19+jRw9StW9ecPXvWLF261EgyH3744XmPjyTz0EMPue+PHz/eSDJfffWVu966deua+Ph4Y4wxW7dudZf97bffjCQzadKkIo/ZuetcvHix+1jBcY6IiDAJCQnGGGOmTJli/Pz83G0bY0x+fr7Jzc01q1evNpLMJ5984h632bNnmypVqphjx46Zf/7zn0aSmTlzpvvas2fPnne/ARjDbxPACjt27NAXX3whSapSxfPT/osvvnBvdPvll1/0008/adiwYQoICCh2vZGRkZKk//znP3r55Zf1zjvvuJfRJWnr1q3q06ePgoOD3ccKtr99+3ZlZmYW+q2EatWqebzfoEED998NGzbUmjVr3HVL0oABAzyWL1j/Y489pq5du2rRokWaN2+eGjVqpF69el1wf2rUqFFo38LCwtz1NmjQwP3RQ+vWrZWXl6elS5e6VwuK+pFLUXr06OH+u6jjvHXrVjVp0kRt2rRxH3McR/7+/tq+fbsk6cYbbyz0ut27d6t79+4aOnSokpKS9MUXX+ill15S7dq1SzQuwFbEAKwwZ84c+fn5KSkpyeOSvzFGL774ombPnq158+YpJCREktz/lsSoUaO0bt06TZgwQYGBgZo8ebL73LFjx877uksuuUT169cvdBNjwc/Xz8f8/18AutC6JSkmJkbt27fXE088oUOHDmnWrFnn/XGHNwq2v3XrViUkJKhnz56aN2+eR7QUp7jjW9xxk6QlS5Z4xIskNWrUSI7j6LXXXlNsbKz+/ve/q23bttqwYQO/CgpcADGASu/kyZNauHCh4uLiNGPGjELPHzhwQIsWLdI//vEP1apVSw0bNtTnn3+upKSkYte9du1aTZ8+XSkpKWrfvr02bdrk8XybNm20cuVKnThxotA3wOjoaC1btkzh4eEe/wd85MiREu1XwWuWLFly3rE+/vjjuvXWW1WzZk2Pm/P+DElJSbriiis0ZcoUj6shBQICApSdnV2qdbdp00affvqptm7d6nFspN+PmyQdOnRI8fHx7uMnT56Un5+ffvzxR11++eWKj49Xly5dFBUVpZkzZ+r5558v1VgAGxADqPQWL16s48ePKzExscjnk5KStGzZMs2fP1+jRo3SuHHjlJCQoGHDhik2NlZVq1bV6dOni3ztmTNnJEmTJk1SdHS0e/PfmDFjNHr0aE2YMEE9e/bU1VdfrTvvvFNBQUH69NNPtXLlSt13332aPn26unXrpvvvv1916tTR5s2btWXLFqWlpRW7X927d1enTp00YsQIffPNN2rbtq3S09PVqFEj3X///ZKkdu3aSZLuvfder652lMSZM2f09ddfa9q0aUpJSZEkbdy4UUuXLlX//v31t7/9TatWrdLkyZP1888/q1OnTiVe98MPP6z58+era9euuv/++1W/fn2lpqbqgQceUIcOHXTzzTdr5MiR+vbbb9WyZUt99913Wrx4sVJSUrR8+XK99tprGjx4sDIyMnT27Fn3Rx4AzqOc71kAfK5du3amUaNGJj8//4LLXHnllSYvL88YY8zs2bNNw4YNjZ+fn5FkJBV5A2Fubq659dZbTWhoqImLizOvvPKKqV69uomPj3dv5EtOTjYdOnQwgYGBJigoyMTGxrrb3blzp+nWrZupVq2aqV69uvm///s/s2zZMmPMf28g3Lt3r7t8QkKCiYiIcN/PysoyDz74oKlTp45x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turWrevzbffo0UPNmzfXkiVLNH/+fEVFRemWW25xn09ISNAdd9yh2bNn65NPPtG111573m1dKBTgO8TAObp166YHH3xQGRkZ6tSpk1asWFHkcjk5OV6td9CgQZKk4cOH69SpU+7jR48e1ejRoyX991JdVFSUJCklJcWt7zNnzuizzz7zapsFunfvLn9/f7311ltl/n/RBfvy73//233s6NGjSklJKbRsSEiIjh075h7bnJwcr48zUBn98MMP7g16jRo10gcffCB/f399+OGHRS5/+vRpJSUlSZL69OlTJtseMWKEcnJylJWVpUceecS9gTgrK0tvv/22mjVrpg4dOkj6/XyGioV5Boowa9YshYWFafLkyerdu7euvPJKRUdHKywsTBkZGdq+fbvS0tK8WueQIUOUnJys999/X02bNlWXLl105swZrV27VhkZGUpMTHTvno+IiFBsbKzWrFmj6OhotW7dWmvWrCny52slUb9+fY0ePVrPPvusrr76avXs2VOXXXaZfv7551KtzxsdOnTQX//6Vy1fvlyxsbH6y1/+opUrVxb5TT4mJkYLFy5Up06d1KxZM61evVqff/65z8cIVHS//vqr4uLi1KJFC1177bVKTU1VXl6eOnbs6C7z5ptvKiMjQ0FBQVq3bp3S09N13XXX6cEHH/T5tiXp9ttv15NPPqmTJ0/qnnvucR+vWrWqgoODtWnTJvXr10+5ubluXMyaNUs7duzw+ZTmKB5XBorg5+enSZMmKS0tTcOHD1doaKhWrFihV199VcnJyXIcRwMHDtSbb76pESNGlHidy5Yt04svvqiwsDC9++67WrVqla666iq98847mj17tsfy77zzjvr37689e/YoOTlZw4YN+5++qCdNmqR58+apSpUqmjlzpkaNGqXnn3++1OsrqYCAAH388ce68cYblZKSog0bNmjKlCmKi4srtOyMGTN02223ae/evfrggw/Uvn171apVy+djBCq6xo0ba/z48crJydHrr7+uAwcOaOjQoR7zd9SuXVsbNmzQ22+/LX9/f40ZM0arV6927wHw5bYlKTAwUA8//LCGDBmi6tWrezz+1ltvKTIyUqtXr1adOnW0fPly1axZU4cOHSr0K8QoH4650B0oAIAKbf369YqJiVFiYmKh/6kASoorAwAAWI4YAADAcsQAAACWIwYAALAcNxAC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",
      "text/plain": [
       "<Figure size 640x480 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "for i in range(p + 1):\n",
    "    visualize(B_true[:, i * d : (i + 1) * d], B_est[:, i * d : (i + 1) * d], method=method, filename=\"visualization.png\")\n",
    "\n",
    "# Black = correct edge\n",
    "# White = correctly absent edge\n",
    "\n",
    "# Errors (if any):\n",
    "# Red = wrong edge\n",
    "# Grey = missing edge\n"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "sparserc",
   "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.7"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
