{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import pandas as pd\n",
    "import networkx as nx\n",
    "import matplotlib\n",
    "import matplotlib.pyplot as plt\n",
    "import torch\n",
    "import fantom\n",
    "import pyro.distributions as distrib\n",
    "import torch.distributions as td\n",
    "import torch.nn as nn\n",
    "from metrics import shd, classification_metrics, threshold_metrics\n",
    "from sklearn.metrics import accuracy_score,roc_auc_score\n",
    "from torch.utils.data import DataLoader\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "import numpy as np\n",
    "import matplotlib.colors as mcolors\n",
    "device = \"cuda:0\" if torch.cuda.is_available() else \"cpu\""
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Synthetic Data generation:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 82,
   "metadata": {},
   "outputs": [],
   "source": [
    "from generate_nonlin_diff_var import gen_stationary_dyn_net_and_df_regime"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 83,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([2500, 3000])"
      ]
     },
     "execution_count": 83,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "n_nodes = 10\n",
    "reg = np.random.choice(np.array([1500,2000,2500,3000]),2)\n",
    "reg"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "g_list,df_total, intra_nodes, inter_nodes = gen_stationary_dyn_net_and_df_regime(2,[np.exp, np.tanh, np.exp],n_nodes,reg,1,4,2,w_max_inter=1,w_min_inter=0,\n",
    "                                                                                 w_max_intra=1,w_min_intra=0,\n",
    "                                                                                 graph_type_intra = \"barabasi-albert\",\n",
    "                                                                                 graph_type_inter = \"erdos-renyi\",\n",
    "                                                                                 noise_scale = [1,1,1],\n",
    "                                                                                 max_data_gen_trials = 1000,\n",
    "                                                                                 sem_type = \"heteroscedastic\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 85,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "lag = False\n",
    "if lag == True:\n",
    "            rearange_intra = [str(i)+\"_lag0\" for i in range(n_nodes)]\n",
    "            rearange_inter1 = [str(i)+\"_lag1\" for i in range(n_nodes)]\n",
    "            rearange_inter2 = [str(i)+\"_lag2\" for i in range(n_nodes)]\n",
    "            rearange_inter = rearange_inter1 + rearange_inter2\n",
    "else:\n",
    "            rearange_intra = [str(i)+\"_lag0\" for i in range(n_nodes)]\n",
    "            rearange_inter = [str(i)+\"_lag1\" for i in range(n_nodes)]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 86,
   "metadata": {},
   "outputs": [],
   "source": [
    "data = df_total[rearange_inter+rearange_intra].to_numpy()\n",
    "data = data.reshape((reg.sum(),2,n_nodes))\n",
    "#data[:,0,:] = (data[:,0,:] -data[:,0,:].mean())/data[:,0,:].std()\n",
    "#data[:,1,:] = (data[:,1,:] -data[:,1,:].mean())/data[:,1,:].std()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Fantom: "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 87,
   "metadata": {},
   "outputs": [],
   "source": [
    "dataset_config = {'dataset_format': 'temporal_causal_csv', 'use_predefined_dataset': True, 'test_fraction': 0.0, \n",
    "                  'val_fraction': 0.0, 'random_seed': 0, 'negative_sample': False}\n",
    "model_config = {'tau_gumbel': 0.25, 'lambda_dag': 1.0, 'lambda_sparse': 50.0, 'spline_bins': 128, \n",
    "                'encoder_layer_sizes':[32,32],'decoder_layer_sizes':[32,32],\n",
    "                'var_dist_A_mode': 'temporal_three', \"heteroscedastic\":False,#'mode_adjacency': 'learn', \n",
    "                'norm_layers': True, 'res_connection': True, 'base_distribution_type': \"conditional_spline\"}\n",
    "# To speed up training you can try:\n",
    "#  increasing learning_rate\n",
    "#  increasing batch_size (reduces noise when using higher learning rate)\n",
    "#  decreasing max_steps_auglag (go as low as you can and still get a DAG)\n",
    "#  decreasing max_auglag_inner_epochs\n",
    "training_params = {'learning_rate': 0.005, 'batch_size': 256, 'stardardize_data_mean': False, \n",
    "                   'stardardize_data_std': False, 'rho': 1.0, 'safety_rho': 10000000000000.0, \n",
    "                   'alpha': 0.0, 'safety_alpha': 10000000000000.0, 'tol_dag': 1e-04, 'progress_rate': 0.65, \n",
    "                   'max_steps_auglag': 1, 'max_auglag_inner_epochs': 2000, 'max_p_train_dropout': 0.0, \n",
    "                   'reconstruction_loss_factor': 1.0, 'anneal_entropy': 'noanneal'}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 88,
   "metadata": {},
   "outputs": [],
   "source": [
    "class pi_tn(nn.Module):\n",
    "            def __init__(self, regime):\n",
    "                        super(pi_tn, self).__init__()\n",
    "                        self.regime = regime\n",
    "                        self.linear = nn.Linear(1,self.regime)\n",
    "                \n",
    "                        \n",
    "            def forward(self,t):\n",
    "                        outp = self.linear(t)\n",
    "                        return outp"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 89,
   "metadata": {},
   "outputs": [],
   "source": [
    "def train(num_epochs, model, data, gamma):\n",
    "            model.train()\n",
    "            criterion = nn.CrossEntropyLoss()\n",
    "            optimizer = torch.optim.Adam(model.parameters(), lr=0.001)\n",
    "            soft = nn.Softmax()\n",
    "            for _ in range(num_epochs):\n",
    "                        y_pre = model(data)  \n",
    "                        loss = criterion(y_pre, gamma)\n",
    "                        \n",
    "                        optimizer.zero_grad()\n",
    "                        loss.backward()\n",
    "                        optimizer.step()\n",
    "            #print(\"loss: \"+str(loss.item()))\n",
    "            \n",
    "            \n",
    "            return soft(y_pre),loss.item(),model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "def FANTOM(X, max_it, n_nodes, lag, window, zeta, thresh, device):\n",
    "            n = int(X.shape[1]//2)\n",
    "            m = X.shape[0]\n",
    "            N_regime = m//window\n",
    "            X_std = np.zeros(X.shape)\n",
    "            X_std[:,0,:] = (X[:,0,:] -X[:,0,:].mean(axis=0))/X[:,0,:].std(axis=0)\n",
    "            X_std[:,1,:] = (X[:,1,:] -X[:,1,:].mean(axis=0))/X[:,1,:].std(axis=0)\n",
    "            for it in range(max_it):\n",
    "                        if it >= 3:\n",
    "                        #            model_config['lambda_sparse'] = 100 \n",
    "                                    training_params[\"encoder_layer_sizes\"] = [32,32]\n",
    "                                    training_params[\"decoder_layer_sizes\"] = [32,32]    \n",
    "                                    training_params[\"max_auglag_inner_epochs\"] = 3000  \n",
    "                                    training_params[\"max_steps_auglag\"] = 2\n",
    "                       \n",
    "                        \n",
    "                        model_n = [fantom.FANTOM_stationary(n_nodes, device, lag = lag, allow_instantaneous=True, **model_config) for _ in range(N_regime)]\n",
    "                        device = torch.device('cuda:1')\n",
    "                        yl = np.zeros((m, n , N_regime))\n",
    "                        log_pdf_emission = np.zeros((m, N_regime))\n",
    "                        if it == 0:\n",
    "                                    p = np.zeros((m,N_regime))\n",
    "                                    for c in range(N_regime):\n",
    "                                                if c  == N_regime -1:\n",
    "                                                            p[c*window:,c] = np.ones(m-c*window)\n",
    "                                                            initial_regime_data = (X[c*window:,:,:] - X[c*window:,:,:].mean(axis=0))/X[c*window:,:,:].std(axis=0)\n",
    "                                                            dataloader = DataLoader(initial_regime_data,training_params[\"batch_size\"])\n",
    "                                                            model_n[c].run_train(dataloader, window, training_params)\n",
    "                                                            log_pdf_emission[:,c] = np.exp(model_n[c].log_prob(torch.tensor(X_std),1))\n",
    "                                                            \n",
    "                                                else:\n",
    "                                                            p[c*window:(c+1)*window,c] = np.ones(window)\n",
    "                                                            initial_regime_data = (X[c*window:(c+1)*window,:] - X[c*window:(c+1)*window,:].mean(axis=0))/X[c*window:(c+1)*window,:].std(axis=0)\n",
    "                                                            dataloader = DataLoader(initial_regime_data,training_params[\"batch_size\"])\n",
    "                                                            model_n[c].run_train(dataloader,window, training_params)\n",
    "                                                            log_pdf_emission[:,c] = np.exp(model_n[c].log_prob(torch.tensor(X_std),1))\n",
    "                                                            \n",
    "                                                \n",
    "                        else:\n",
    "                                    for c in range(N_regime):\n",
    "                                                gamma = gamma_hat[:,c]\n",
    "                                                data = gamma.reshape((m,1,1))*X\n",
    "                                                b = data[~np.all(data == 0, axis=2)]\n",
    "                                                regime_data = b.reshape(b.shape[0]//(lag + 1), (lag + 1), n_nodes)\n",
    "                                                for cte in range(lag+1):\n",
    "                                                               regime_data[:,cte,:] = (regime_data[:,cte,:] - regime_data[:,cte,:].mean(axis=0))/regime_data[:,cte,:].std(axis=0)\n",
    "                                                dataloader = DataLoader(regime_data,training_params[\"batch_size\"])\n",
    "                                                model_n[c].run_train(dataloader,regime_data.shape[0], training_params)\n",
    "                                                log_pdf_emission[:,c] = np.exp(model_n[c].log_prob(torch.tensor(X_std),1))\n",
    "                        pall = 0                        \n",
    "                        gamma_hat = np.zeros((m, N_regime))\n",
    "                        for class_idx in range(N_regime):\n",
    "                                    pall = pall + p[:,class_idx] * log_pdf_emission[:,class_idx]\n",
    "                                    gamma_hat[:, class_idx] = p[:,class_idx] * log_pdf_emission[:,class_idx]\n",
    "                        idx = np.argmax(gamma_hat/pall.reshape((m,1)), axis=-1)\n",
    "                        gamma_hat = np.zeros( gamma_hat.shape )\n",
    "                        gamma_hat[ np.arange(gamma_hat.shape[0]), idx] = 1\n",
    "                       \n",
    "                        t = torch.tensor(np.linspace(0,20*N_regime,X.shape[0]).reshape((X.shape[0],1)))\n",
    "                        model = pi_tn(N_regime)\n",
    "                        p,loss,model_ = train(500,model, t.float(), torch.tensor(gamma_hat).float())\n",
    "                        p = p.detach().numpy()\n",
    "                        while loss>=thresh:\n",
    "                              p,loss,model_ = train(100,model_, t.float(), torch.tensor(gamma_hat).float())\n",
    "                              p = p.detach().numpy()\n",
    "                              \n",
    "                        if it ==0:\n",
    "                              pall = 0                        \n",
    "                              gamma_hat = np.zeros((m, N_regime))\n",
    "                              for class_idx in range(N_regime):\n",
    "                             \n",
    "                                             pall = pall + p[:,class_idx] * log_pdf_emission[:,class_idx]\n",
    "                                             gamma_hat[:, class_idx] = p[:,class_idx] * log_pdf_emission[:,class_idx]\n",
    "                              idx = np.argmax(gamma_hat/pall.reshape((m,1)), axis=-1)\n",
    "                              gamma_hat = np.zeros( gamma_hat.shape )\n",
    "                              gamma_hat[ np.arange(gamma_hat.shape[0]), idx] = 1\n",
    "                                          \n",
    "                        gamma_sum = np.sum(gamma_hat, axis=0) \n",
    "                        gamma_sum[gamma_sum<zeta] = 0  \n",
    "                        indexes, = np.where(gamma_sum!= 0)\n",
    "                        gamma_hat = gamma_hat[:,indexes]\n",
    "                        p = p[:,indexes]\n",
    "                        N_regime = len(indexes)          \n",
    "                        print(str(np.sum(gamma_hat, axis=0))+\" iter: \"+str(it)+\" , p: \"+str(np.sum(p, axis=0)))\n",
    "            return gamma_hat, model_n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 91,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Auglag Step: 0\n",
      "Beta Value: 1.0\n",
      "LR: 0.005\n",
      "Inner Step: 1000, loss: 5.36, log p(x|A): -4.81, dag: 3.21067319, log p(A)_sp: -0.56, log q(A): -0.015, H filled: 0.000, rec: 0.000, penalty_dag_weighed: 0.00148, cts_mse_icgnn: 10.5, cts_medse_icgnn: 7.94\n",
      "Inner Step: 2000, loss: 2.32, log p(x|A): -1.83, dag: 0.46183150, log p(A)_sp: -0.49, log q(A): -0.007, H filled: 0.000, rec: 0.000, penalty_dag_weighed: 6.12e-05, cts_mse_icgnn: 10.4, cts_medse_icgnn: 7.88\n",
      "Inner Step: 2000, loss: 2.32, log p(x|A): -1.83, dag: 0.46183150, log p(A)_sp: -0.49, log q(A): -0.007, H filled: 0.000, rec: 0.000, penalty_dag_weighed: 6.12e-05, cts_mse_icgnn: 10.4, cts_medse_icgnn: 7.88\n",
      "Best model found at innner step 1944, with Loss 1.92\n",
      "Dag penalty: 3.388712030410767\n",
      "Rho: 1.00, alpha: 0.00\n",
      "Auglag Step: 0\n",
      "Beta Value: 1.0\n",
      "LR: 0.005\n",
      "Inner Step: 1000, loss: 7.50, log p(x|A): -6.97, dag: 2.64579368, log p(A)_sp: -0.55, log q(A): -0.017, H filled: 0.000, rec: 0.000, penalty_dag_weighed: 0.00101, cts_mse_icgnn: 10.2, cts_medse_icgnn: 7.07\n",
      "Inner Step: 2000, loss: 5.23, log p(x|A): -4.70, dag: 1.28420125, log p(A)_sp: -0.54, log q(A): -0.010, H filled: 0.000, rec: 0.000, penalty_dag_weighed: 0.0003, cts_mse_icgnn: 10.2, cts_medse_icgnn: 7.05\n",
      "Inner Step: 2000, loss: 5.23, log p(x|A): -4.70, dag: 1.28420125, log p(A)_sp: -0.54, log q(A): -0.010, H filled: 0.000, rec: 0.000, penalty_dag_weighed: 0.0003, cts_mse_icgnn: 10.2, cts_medse_icgnn: 7.05\n",
      "Best model found at innner step 2000, with Loss 4.99\n",
      "Dag penalty: 3.293124175071716\n",
      "Rho: 1.00, alpha: 0.00\n",
      "Auglag Step: 0\n",
      "Beta Value: 1.0\n",
      "LR: 0.005\n",
      "Inner Step: 1000, loss: 2.37, log p(x|A): -1.91, dag: 2.36325523, log p(A)_sp: -0.48, log q(A): -0.014, H filled: 0.000, rec: 0.000, penalty_dag_weighed: 0.00085, cts_mse_icgnn: 10.1, cts_medse_icgnn: 6.14\n",
      "Inner Step: 2000, loss: 0.69, log p(x|A): -0.30, dag: 0.81471130, log p(A)_sp: -0.40, log q(A): -0.008, H filled: 0.000, rec: 0.000, penalty_dag_weighed: 0.000121, cts_mse_icgnn: 10.1, cts_medse_icgnn: 6.13\n",
      "Inner Step: 2000, loss: 0.69, log p(x|A): -0.30, dag: 0.81471130, log p(A)_sp: -0.40, log q(A): -0.008, H filled: 0.000, rec: 0.000, penalty_dag_weighed: 0.000121, cts_mse_icgnn: 10.1, cts_medse_icgnn: 6.13\n",
      "Best model found at innner step 1960, with Loss 0.49\n",
      "Dag penalty: 3.169812948703766\n",
      "Rho: 1.00, alpha: 0.00\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_1497454/3910170848.py:16: UserWarning: Implicit dimension choice for softmax has been deprecated. Change the call to include dim=X as an argument.\n",
      "  return soft(y_pre),loss.item(),model\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[1708. 2943.] iter: 0 , p: [ 422.08295 3481.054  ]\n",
      "Auglag Step: 0\n",
      "Beta Value: 1.0\n",
      "LR: 0.005\n",
      "Inner Step: 1000, loss: 5.48, log p(x|A): -4.94, dag: 3.25422905, log p(A)_sp: -0.56, log q(A): -0.016, H filled: 0.000, rec: 0.000, penalty_dag_weighed: 0.00142, cts_mse_icgnn: 11.8, cts_medse_icgnn: 8.74\n",
      "Inner Step: 2000, loss: 2.10, log p(x|A): -1.63, dag: 0.89267265, log p(A)_sp: -0.47, log q(A): -0.007, H filled: 0.000, rec: 0.000, penalty_dag_weighed: 0.000155, cts_mse_icgnn: 11.5, cts_medse_icgnn: 8.56\n",
      "Inner Step: 2000, loss: 2.10, log p(x|A): -1.63, dag: 0.89267265, log p(A)_sp: -0.47, log q(A): -0.007, H filled: 0.000, rec: 0.000, penalty_dag_weighed: 0.000155, cts_mse_icgnn: 11.5, cts_medse_icgnn: 8.56\n",
      "Best model found at innner step 1997, with Loss 1.69\n",
      "Dag penalty: 3.588409258365631\n",
      "Rho: 1.00, alpha: 0.00\n",
      "Auglag Step: 0\n",
      "Beta Value: 1.0\n",
      "LR: 0.005\n",
      "Inner Step: 1000, loss: 2.87, log p(x|A): -2.37, dag: 3.24960387, log p(A)_sp: -0.52, log q(A): -0.016, H filled: 0.000, rec: 0.000, penalty_dag_weighed: 0.00151, cts_mse_icgnn: 10, cts_medse_icgnn: 6\n",
      "Inner Step: 2000, loss: 0.85, log p(x|A): -0.46, dag: 0.91481412, log p(A)_sp: -0.40, log q(A): -0.009, H filled: 0.000, rec: 0.000, penalty_dag_weighed: 0.000179, cts_mse_icgnn: 10.1, cts_medse_icgnn: 6.04\n",
      "Inner Step: 2000, loss: 0.85, log p(x|A): -0.46, dag: 0.91481412, log p(A)_sp: -0.40, log q(A): -0.009, H filled: 0.000, rec: 0.000, penalty_dag_weighed: 0.000179, cts_mse_icgnn: 10.1, cts_medse_icgnn: 6.04\n",
      "Best model found at innner step 1980, with Loss 0.61\n",
      "Dag penalty: 3.642141294956207\n",
      "Rho: 1.00, alpha: 0.00\n",
      "[2420. 3080.] iter: 1 , p: [1740.6788 3759.3213]\n",
      "Auglag Step: 0\n",
      "Beta Value: 1.0\n",
      "LR: 0.005\n",
      "Inner Step: 1000, loss: 4.32, log p(x|A): -3.83, dag: 1.74486375, log p(A)_sp: -0.50, log q(A): -0.011, H filled: 0.000, rec: 0.000, penalty_dag_weighed: 0.000445, cts_mse_icgnn: 10.6, cts_medse_icgnn: 7.9\n",
      "Inner Step: 2000, loss: 2.05, log p(x|A): -1.60, dag: 0.31216162, log p(A)_sp: -0.45, log q(A): -0.005, H filled: 0.000, rec: 0.000, penalty_dag_weighed: 3.52e-05, cts_mse_icgnn: 10.5, cts_medse_icgnn: 7.79\n",
      "Inner Step: 2000, loss: 2.05, log p(x|A): -1.60, dag: 0.31216162, log p(A)_sp: -0.45, log q(A): -0.005, H filled: 0.000, rec: 0.000, penalty_dag_weighed: 3.52e-05, cts_mse_icgnn: 10.5, cts_medse_icgnn: 7.79\n",
      "Best model found at innner step 1990, with Loss 1.87\n",
      "Dag penalty: 2.541245451450348\n",
      "Rho: 1.00, alpha: 0.00\n",
      "Auglag Step: 0\n",
      "Beta Value: 1.0\n",
      "LR: 0.005\n",
      "Inner Step: 1000, loss: 2.76, log p(x|A): -2.30, dag: 1.90935317, log p(A)_sp: -0.47, log q(A): -0.013, H filled: 0.000, rec: 0.000, penalty_dag_weighed: 0.000503, cts_mse_icgnn: 10.4, cts_medse_icgnn: 6.1\n",
      "Inner Step: 2000, loss: 1.10, log p(x|A): -0.72, dag: 0.76733126, log p(A)_sp: -0.38, log q(A): -0.008, H filled: 0.000, rec: 0.000, penalty_dag_weighed: 0.000128, cts_mse_icgnn: 10.4, cts_medse_icgnn: 6.11\n",
      "Inner Step: 2000, loss: 1.10, log p(x|A): -0.72, dag: 0.76733126, log p(A)_sp: -0.38, log q(A): -0.008, H filled: 0.000, rec: 0.000, penalty_dag_weighed: 0.000128, cts_mse_icgnn: 10.4, cts_medse_icgnn: 6.11\n",
      "Best model found at innner step 1981, with Loss 0.21\n",
      "Dag penalty: 2.737266745090484\n",
      "Rho: 1.00, alpha: 0.00\n",
      "[2479. 3021.] iter: 2 , p: [2017.0679 3482.932 ]\n",
      "Auglag Step: 0\n",
      "Beta Value: 1.0\n",
      "LR: 0.005\n",
      "Inner Step: 1000, loss: 5.40, log p(x|A): -4.95, dag: 1.06292177, log p(A)_sp: -0.46, log q(A): -0.012, H filled: 0.000, rec: 0.000, penalty_dag_weighed: 0.000187, cts_mse_icgnn: 11.4, cts_medse_icgnn: 8.42\n",
      "Inner Step: 2000, loss: 2.64, log p(x|A): -2.19, dag: 0.35193479, log p(A)_sp: -0.45, log q(A): -0.005, H filled: 0.000, rec: 0.000, penalty_dag_weighed: 3.75e-05, cts_mse_icgnn: 11.1, cts_medse_icgnn: 8.23\n",
      "Inner Step: 3000, loss: 1.72, log p(x|A): -1.28, dag: 0.09634167, log p(A)_sp: -0.44, log q(A): -0.003, H filled: 0.000, rec: 0.000, penalty_dag_weighed: 8.07e-06, cts_mse_icgnn: 11, cts_medse_icgnn: 8.18\n",
      "Inner Step: 3000, loss: 1.72, log p(x|A): -1.28, dag: 0.09634167, log p(A)_sp: -0.44, log q(A): -0.003, H filled: 0.000, rec: 0.000, penalty_dag_weighed: 8.07e-06, cts_mse_icgnn: 11, cts_medse_icgnn: 8.18\n",
      "Best model found at innner step 2890, with Loss 1.31\n",
      "Dag penalty: 1.270874585469564\n",
      "Rho: 1.00, alpha: 0.00\n",
      "Auglag Step: 1\n",
      "Beta Value: 1.0\n",
      "LR: 0.005\n",
      "Inner Step: 1000, loss: 0.92, log p(x|A): -0.49, dag: 0.05218290, log p(A)_sp: -0.43, log q(A): -0.002, H filled: 0.000, rec: 0.000, penalty_dag_weighed: 2.97e-06, cts_mse_icgnn: 10.9, cts_medse_icgnn: 8.14\n",
      "Inner Step: 2000, loss: 0.27, log p(x|A): 0.15, dag: 0.04431368, log p(A)_sp: -0.42, log q(A): -0.002, H filled: 0.000, rec: 0.000, penalty_dag_weighed: 3.58e-06, cts_mse_icgnn: 10.8, cts_medse_icgnn: 8.04\n",
      "Inner Step: 3000, loss: -0.13, log p(x|A): 0.55, dag: 0.02537642, log p(A)_sp: -0.42, log q(A): -0.001, H filled: 0.000, rec: 0.000, penalty_dag_weighed: 2.11e-06, cts_mse_icgnn: 10.7, cts_medse_icgnn: 7.97\n",
      "Inner Step: 3000, loss: -0.13, log p(x|A): 0.55, dag: 0.02537642, log p(A)_sp: -0.42, log q(A): -0.001, H filled: 0.000, rec: 0.000, penalty_dag_weighed: 2.11e-06, cts_mse_icgnn: 10.7, cts_medse_icgnn: 7.97\n",
      "Best model found at innner step 2650, with Loss -0.56\n",
      "Updating alpha.\n",
      "Dag penalty: 0.037874985694885\n",
      "Rho: 1.00, alpha: 0.04\n",
      "Auglag Step: 0\n",
      "Beta Value: 1.0\n",
      "LR: 0.005\n",
      "Inner Step: 1000, loss: 2.65, log p(x|A): -2.19, dag: 2.12010318, log p(A)_sp: -0.48, log q(A): -0.014, H filled: 0.000, rec: 0.000, penalty_dag_weighed: 0.00062, cts_mse_icgnn: 10.6, cts_medse_icgnn: 6.72\n",
      "Inner Step: 2000, loss: 0.88, log p(x|A): -0.50, dag: 0.48870618, log p(A)_sp: -0.39, log q(A): -0.008, H filled: 0.000, rec: 0.000, penalty_dag_weighed: 8.84e-05, cts_mse_icgnn: 11.1, cts_medse_icgnn: 7.08\n",
      "Inner Step: 3000, loss: 0.18, log p(x|A): 0.17, dag: 0.27947280, log p(A)_sp: -0.35, log q(A): -0.005, H filled: 0.000, rec: 0.000, penalty_dag_weighed: 3.19e-05, cts_mse_icgnn: 11.1, cts_medse_icgnn: 7.1\n",
      "Inner Step: 3000, loss: 0.18, log p(x|A): 0.17, dag: 0.27947280, log p(A)_sp: -0.35, log q(A): -0.005, H filled: 0.000, rec: 0.000, penalty_dag_weighed: 3.19e-05, cts_mse_icgnn: 11.1, cts_medse_icgnn: 7.1\n",
      "Best model found at innner step 2980, with Loss -0.13\n",
      "Dag penalty: 2.062655989329020\n",
      "Rho: 1.00, alpha: 0.00\n",
      "Auglag Step: 1\n",
      "Beta Value: 1.0\n",
      "LR: 0.005\n",
      "Inner Step: 1000, loss: -0.25, log p(x|A): 0.58, dag: 0.07188387, log p(A)_sp: -0.33, log q(A): -0.004, H filled: 0.000, rec: 0.000, penalty_dag_weighed: 5.09e-06, cts_mse_icgnn: 11, cts_medse_icgnn: 7.04\n",
      "Inner Step: 2000, loss: -0.54, log p(x|A): 0.85, dag: 0.04561832, log p(A)_sp: -0.31, log q(A): -0.003, H filled: 0.000, rec: 0.000, penalty_dag_weighed: 4.03e-06, cts_mse_icgnn: 11, cts_medse_icgnn: 6.99\n",
      "Inner Step: 3000, loss: -0.64, log p(x|A): 0.94, dag: 0.02200232, log p(A)_sp: -0.31, log q(A): -0.002, H filled: 0.000, rec: 0.000, penalty_dag_weighed: 1.9e-06, cts_mse_icgnn: 11, cts_medse_icgnn: 6.98\n",
      "Inner Step: 3000, loss: -0.64, log p(x|A): 0.94, dag: 0.02200232, log p(A)_sp: -0.31, log q(A): -0.002, H filled: 0.000, rec: 0.000, penalty_dag_weighed: 1.9e-06, cts_mse_icgnn: 11, cts_medse_icgnn: 6.98\n",
      "Best model found at innner step 2668, with Loss -1.08\n",
      "Updating alpha.\n",
      "Dag penalty: 0.073052215258280\n",
      "Rho: 1.00, alpha: 0.07\n",
      "[2443. 3057.] iter: 3 , p: [1130.5505 4369.449 ]\n"
     ]
    }
   ],
   "source": [
    "gamma_hat, model_n = FANTOM(data, 4, n_nodes, 1, 1500, 1200, 0.85, device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 74,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([1978.,   22.])"
      ]
     },
     "execution_count": 74,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "gamma_hat[:2000].sum(axis=0)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Evaluation:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 92,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "def plt_fig(reg, g_list, L, node):\n",
    "    plt.figure(figsize=(30, 30))  # Increased width for 3 columns\n",
    "    custom_cmap = mcolors.ListedColormap([\"lightgray\", \"darkred\"])  # For matrices\n",
    "    diff_cmap = mcolors.ListedColormap([\"lightgray\", \"red\"])  # For absolute difference\n",
    "\n",
    "    for i in range(reg):\n",
    "        # First column: Estimated G_0\n",
    "        plt.subplot(2 * reg, 3, 6 * i + 1)\n",
    "        L1 = model_n[i].get_adj_matrix(samples=1, most_likely_graph=True, squeeze=True)[0]\n",
    "        sns.heatmap(L1, cmap=custom_cmap, square=True, xticklabels=False, yticklabels=False, linewidths=0.003, \n",
    "                    linecolor=\"white\", cbar=False, vmin=0, vmax=1)\n",
    "        plt.title(\"Estimated $\\hat{G}_0$. Regime \" + str(i+1), fontsize=20)\n",
    "\n",
    "        # Second column: True G_0\n",
    "        plt.subplot(2 * reg, 3, 6 * i + 2)\n",
    "        g_ground = nx.to_numpy_array(g_list[i])[node:2*node, node:2*node]\n",
    "        sns.heatmap(g_ground, cmap=custom_cmap, square=True, xticklabels=False, yticklabels=False, linewidths=0.003, \n",
    "                    linecolor=\"white\", cbar=False, vmin=0, vmax=1)\n",
    "        plt.title(\"True $G_0$. Regime \" + str(i+1), fontsize=20)\n",
    "\n",
    "        # Third column: Absolute Difference (|Estimated - True|)\n",
    "        plt.subplot(2 * reg, 3, 6 * i + 3)\n",
    "        diff_matrix = np.abs(L1 - g_ground)\n",
    "        sns.heatmap(diff_matrix, cmap=diff_cmap, square=True, xticklabels=False, yticklabels=False, linewidths=0.003, \n",
    "                    linecolor=\"white\", cbar=False, vmin=0, vmax=1)\n",
    "        plt.title(\"Difference $|\\\\hat{G}_0 - G_0|$. Regime \" + str(i+1),fontsize=20)\n",
    "\n",
    "        # First column (Row 2): Estimated G_1\n",
    "        plt.subplot(2 * reg, 3, 6 * i + 4)\n",
    "        L1 = model_n[i].get_adj_matrix(samples=1, most_likely_graph=True, squeeze=True)[1]\n",
    "        sns.heatmap(L1, cmap=custom_cmap, square=True, xticklabels=False, yticklabels=False, linewidths=0.003, \n",
    "                    linecolor=\"white\", cbar=False, vmin=0, vmax=1)\n",
    "        plt.title(\"Estimated $\\hat{G}_1$. Regime \" + str(i+1), fontsize=20)\n",
    "\n",
    "        # Second column (Row 2): True G_1\n",
    "        plt.subplot(2 * reg, 3, 6 * i + 5)\n",
    "        g_gt_lag = nx.to_numpy_array(g_list[i])[:node, node:2*node]\n",
    "        sns.heatmap(g_gt_lag, cmap=custom_cmap, square=True, xticklabels=False, yticklabels=False, linewidths=0.003, \n",
    "                    linecolor=\"white\", cbar=False, vmin=0, vmax=1)\n",
    "        plt.title(\"True $G_1$. Regime \" + str(i+1), fontsize=20)\n",
    "\n",
    "        # Third column (Row 2): Absolute Difference |Estimated - True|\n",
    "        plt.subplot(2 * reg, 3, 6 * i + 6)\n",
    "        diff_matrix_lag = np.abs(L1 - g_gt_lag)\n",
    "        sns.heatmap(diff_matrix_lag, cmap=diff_cmap, square=True, xticklabels=False, yticklabels=False, linewidths=0.003, \n",
    "                    linecolor=\"white\", cbar=False, vmin=0, vmax=1)\n",
    "        plt.title(\"Difference $|\\\\hat{G}_1 - G_1|$. Regime \" + str(i+1), fontsize=20)\n",
    "\n",
    "    plt.tight_layout()\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 93,
   "metadata": {},
   "outputs": [],
   "source": [
    "n_reg = 2\n",
    "adj_mat = []\n",
    "node = 10\n",
    "for i in range(n_reg):\n",
    "            adj_mat.append(model_n[i].get_adj_matrix(\n",
    "                                    samples=1, most_likely_graph=True, squeeze=True\n",
    "                                     ))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 94,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAChEAAAuuCAYAAAAwWeokAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/YYfK9AAAACXBIWXMAAA9hAAAPYQGoP6dpAAEAAElEQVR4nOzdeZhU5Zk34KeRHQFRQY0ooHEHRQXUoKJGXHFLSESNAlHjh0nUROJCMqLjmnGJzsQxahIwZNS4jKNoFFdcMAoqBlpU3IiCImhQXBBUzveH6aLb0yt0d3X3e9/X1ddVcJZ66zlV1eft51enSrIsywIAAAAAAAAAAABITqtiDwAAAAAAAAAAAAAoDiFCAAAAAAAAAAAASJQQIQAAAAAAAAAAACRKiBAAAAAAAAAAAAASJUQIAAAAAAAAAAAAiRIiBAAAAAAAAAAAgEQJEQIAAAAAAAAAAECihAgBAAAAAAAAAAAgUUKEAAAAAAAAAAAAkCghQgAAAAAAAAAAAEhU62IPACAlH3/8cVx++eWRZVmceOKJsfHGGxd7SAAAAAAAAEAi9CsBqIwQIUAjOu+88+Kyyy6LiIg5c+bELbfcUuQRAQAAAAAAAKnQrwSgMiVZlmXFHgRACl544YXo379/rLPOOtGtW7d45ZVX4v7774+hQ4cWe2gAAAAAAABAC6dfCUBVhAgBGslee+0Vjz76aNx2222x8cYbx+677x6bb755zJ49O9q2bVvs4QEAAAAAAAAtmH4lAFVpVewBAKTgz3/+czz66KNx9NFHx3e/+93Ydddd44wzzoi5c+fGpZdeWuzhAQAAAAAAAC2YfiUA1XElQoAG9uGHH8bWW28drVq1itLS0ujWrVtERKxYsSIGDhwYr7zySsyZMyd69+5d3IECAAAAAAAALY5+JQA1ESIEAAAAAAAAAACARPk6YwAAAAAAAAAAAEiUECEAAAAAAAAAAAAkSogQAAAAAAAAAAAAEiVECE3cxIkTo6SkJEpKSmLevHnFHk6Lpc7pcKwBAAAAAIDmoLY9jTfffDNOOumk2HzzzaN9+/aFbf7v//6vTuvQtJ177rlRUlISe+21V7GHwmpyDNeMPi80LCFCkjV16tTCL5ja/px22mnFHjbN0KJFi+Lyyy+PQw89NHr37h2dO3eOdu3aRY8ePWKXXXaJk08+Oe6999744osvij3UCqp7jXTs2DE22WSTGDZsWPzxj3+M5cuXF3u41GDRokVx9913xznnnBMHHnhgrL/++oXjOWrUqGIPDwAAoN5pLgAA0Jiq6qu0bt061l133ejTp0/sueee8bOf/Sxuv/32WLFiRb3c75tvvhk777xzXHfddfH6669X2rOpzTq0bM21X9mQWnJN9HlbFn1eGkvrYg8AUjRx4sQYPXp0RES88cYb0bt37+IOqBGl9Ng//fTTOPvss+Paa6+t9ORr8eLFsXjx4pg+fXpcc801seGGG8aZZ54ZP/nJT6J166b99rxs2bKYP39+zJ8/P+6555644oor4u67727Rx7O522CDDYo9BAAAmrh58+ZFnz591ng/WZbVw2ian0WLFsWkSZPi0UcfjVmzZsX7778fK1asiK5du0afPn1i5513jkMOOSSGDh3a5OZ8U6dOjb333rvSZR06dIj11lsvdthhh/jOd74TxxxzTLRr166RR0htLVq0KKZPnx7Tp0+PGTNmxIwZM+L999+PiIiRI0fGxIkTiztAAIAEffnll7FkyZJYsmRJzJs3Lx5//PG48soro3v37nHKKafEWWedtUZzhAsuuCDee++9aN26dVx44YWx5557xtprrx0REb169ar1OrRMLblfubpSr4k+b/Ojz0tjaf7vcFAPxowZEyeffHKN662//vqNMJqKRo0aJT3eDL355psxdOjQmDt3bkREdOnSJY444ojYb7/9YuONN45OnTrFokWL4vnnn4/JkyfHU089FQsXLowzzzyzVs/Fxvb118iiRYuitLQ0Lr300pg/f3688MILceihh8bMmTNjrbXWKuJIa+Y1FbHpppvG1ltvHffff3+xhwIAAM1eS28+aC40LxoLAABNw9f7Kh9//HEsWbIkZs2aFQ899FA8+OCDsXjx4vi3f/u3mDx5ctx9993RvXv33H5q09N48MEHIyLi8MMPjzPOOGO116HlaWn9yvqQYk30eVsWfV4aUtP/SyU0gh49ekTfvn2LPQxaiAULFsQ+++wTr732WkR8dTJz5ZVXRteuXXPrHnTQQTFu3Lh49NFH45RTTonWrVtH27ZtG3vINarsNbLPPvvE6NGjY/vtt4958+bF7Nmz44477ojhw4cXaZRU55xzzomBAwfGwIEDY4MNNqi3q8wAANBybLzxxjF79uwql/fr1y8iIgYMGBATJkxorGE1aS2x+aC50HJoLAAAFE9VvccDDzwwzjzzzJgzZ0784Ac/iJkzZ8b06dPjiCOOiIcffni1ekQLFiyIiIgtt9xyjdahZWmJ/co1lWpN9HmbP31eGosQIUA9+uSTT+Lb3/524eTzsssui9NPP73G7YYMGRJPPvlk/PWvf23oIdarzp07x69+9as44YQTIuKrT7I5uWyazjvvvGIPAQCAJq5Nmza1+oBdp06dfBAvWm7zQXOhedNYAABoHrbddtuYNm1aDB48OGbOnBnTpk2Lq6++On72s5/VeV8rVqyIiK/mdGuyDi1Hav3K2lCTPH3e5kOfl8bSqtgDgObu7bffjrPOOit22mmn6Nq1a7Rp0yY22GCD6NevXxx11FExceLEWLp0aURETJ06NUpKSmL06NGF7fv06RMlJSUVfqZOnVpYPnHixML/z5s3L3f/5557bmF5RMTSpUvj3HPPjX79+sXaa68dPXr0iIMOOiiefPLJCtstWrQofvWrX8V2220XnTp1ivXWWy8OO+ywmDlzZrWPt7S0NC644ILYf//9o2fPntGuXbtYe+21Y4sttoiRI0fGU089Vel2q/PYy3vkkUdi5MiRsdlmm0XHjh2jS5cu0a9fv/jFL34Rb7/9drVjjohYsmRJnHXWWbH11ltHhw4dokePHrHvvvvGrbfeWuO2dXH++efHyy+/HBERp512Wq1OPst06tQpvve979XreBpD2dVIIiLeeuutGtdf02P5/vvvxxlnnBFbbbVVdOjQITbYYIMYOnRo3HHHHRFR82umqb2m6qsuAABA46ms+TBhwoRKA4TllTUfzjrrrMYYZr0qay6UKfs6NJqW8847L4YNG+ZrjQEAmoEOHTrEpEmTCv2Iyy67LD7//PMK61TV0yj//2XOO++8Cj233r1717hOVVfuXt2exdd7LB9++GGcf/75seOOO8Y666wTJSUlMXHixAa9z88++ywuvfTS2GmnnaJz587RuXPnGDRoUPz2t7+NL774osr9lJk2bVqccMIJsdVWW0WXLl2ibdu20bNnzxg2bFhcffXV8cEHH1S7fVPo96TYr6yJmlSurn3eiOL2evV5oYFlkKhHHnkki4gsIrLx48ev1j4ee+yxrEuXLoX9VPUzefLk3H1W9/PII48U7mPChAmF/3/jjTdyYxg/fnxh+ZtvvpltueWWle5zrbXWym655ZYsy7Ls73//e7bxxhtXul67du2yhx9+uMaaVfdz1llnrfa25R97lmXZsmXLshEjRlS7TadOnbK77rqryuM0Z86c7Bvf+EaV248ePbrGOtfGiy++mLVt2zaLiKxPnz7Zp59+ulr7aSpq+xqZOXNmYb3DDjusyvXq41jOmjUr22CDDarc/kc/+lGNx7Ipvabqqy6r44033ijsf+TIkfW6bwAAWqay88chQ4bUav3y59ZZlmUffPBB9u///u9Z//79s65du2YRkU2YMCHLsiwbOXJkFhFZr169qt1nXeZuDz/8cHbcccdlffr0yTp06JB17tw569u3bzZ27NhswYIFtXoMVTnzzDML4zjttNPWaF9NQW3nf08//XRhvYMOOqjG/a7pMXjvvfeyX/ziF9mWW26ZtW/fPuvRo0e27777Zv/7v/+bZVnNz4fqln/9+fnhhx9m48ePz/r27Zt16tQp6969e3bggQdm06ZNq7Ddu+++m/3yl7/Mtt1226xjx47Zuuuumx166KHZc889V+PjqY+a1JW5HwBA41nd3uN+++1X2O7r559VndOW//+qfnr16lXjOl8/R1zTnkX58+y5c+dmvXv3zm1fNg9siPtcuHBh1r9//yr3c8ghh2Rffvllpfv59NNPs6OOOqrGmlV1bBuj31P2WKubl7e0fmV9aEo1qc0xrA/13efNsqbR69Xn/Yq5Pg3F1xnDalq+fHmMGDEili5dGp07d44xY8bE3nvvHT169IgVK1bEG2+8EU8++WQhMR8RMXDgwJg9e3bceeedhU/vT5kyJb7xjW9U2Pfqfs3M9773vZg/f36cffbZccABB0THjh3jiSeeiPHjx8fSpUvj+OOPjwEDBsSwYcNi2bJlceGFF8aQIUOiTZs2cd9998WFF14Yy5cvj1GjRsUrr7yS+2qlL774Ijp16hQHH3xw7LPPPrH11ltHly5dYtGiRfHCCy/Ef/7nf8Y//vGPuOSSS2LLLbescNXB1XnsWZbF8OHD45577omIiEMOOSS+//3vx2abbRatWrWK6dOnx+WXXx5vvvlmDB8+PKZNmxYDBgyosL+lS5fG/vvvX0j4H3nkkTFy5Mjo0aNHzJ07N6644oqYMGFClJaWrlbNy7vwwgsLl4MfP358dOjQYY332Ry8+OKLhdu9e/eudJ36OJYffPBBHHDAAfHuu+9GRMSxxx4bRx99dHTv3j1effXVuOqqq+K6666Lv//97/X22Br6NVUfdQEAgObglVdeif3226/ST4nXt88++yxGjx4dN998c25ZaWlplJaWxjXXXBM33XRTHHLIIXXe/0svvRS/+c1vIuKrOexFF120xmNuLsrPaar7GrT6OAazZ8+OoUOHFuaAZft98MEH48EHH4wf/ehHsdtuu63Bo1nlrbfein333Tfmzp1b+L9PPvkk7r333rj//vvjpptuiu9973sxa9asOOigg2LBggWF9T799NO46667YsqUKXHvvffG3nvvXel9NPTzEgCA5mvfffeN+++/PyIiHn/88fjWt75V4zaHH354oV9QdiWxMWPGxMknn1xYp1u3brFkyZIa1ylT3z2L4cOHx4IFC+KnP/1pHHroodGtW7d45ZVXolevXg12n9/5zndizpw5ccopp8QhhxwS6667brz88stx/vnnx4svvhiTJ0+O66+/Pk466aQK261cuTIOO+yweOCBByIiYosttoiTTz45BgwYEB07dox33nknnnzyybjlllsqvd+m1O9JtV9ZHTWpWm36vBHNs9erzwuroXj5RSiu8un7MWPGZLNnz67xZ8WKFYXtH3roocL2ZVcarMznn3+effjhhxX+ry5XTqhLmr5du3bZU089lVvn7rvvLqzTvXv3bP31189effXV3HpXX311Yb2yT/WXt3jx4mzJkiVVjnX58uXZ0KFDC59u+uKLL+r8eMq77rrrsojI2rRpk917772VrvPPf/4z22677bKIyAYPHpxbPnbs2ML9XXTRRbnlK1asqPAJr9qMqzJLly7N2rdvn0VEts4667SIT/XU5hMqX3zxRbbjjjsW1nv88ccrXa8+juVpp51WuJ8rr7yy0rEcdthhNR7LpvSaqo+6rC6fUAEAoK7Kzh9X50qE22+/fdamTZvspz/9afbAAw9kzzzzTHbTTTdlTz75ZJZl9XclwpUrV2YHH3xwhatMTJo0KZs2bVr2t7/9LbvqqquyTTfdNIuIrG3bttmMGTPqWIUs+8EPflDY/8SJE+u8fVNU2ysU3HjjjYX1Tj311ErXqY9jsGTJkgrfKHDsscdm9957b/bMM89kN998c7bbbrtlEZHtsssuqz3/K//83GWXXbKOHTtmZ599dvboo49mM2bMyH7zm98Uvn2ic+fO2euvv55tsskm2brrrptdeOGF2RNPPJE9/fTT2XnnnVe4osWmm26aLV++vEFqsrrM/QAAGs/qXonwwQcfLGz3wx/+sMKy2vTVanOftVmnPnoW5c+zW7VqlU2ZMqXK+2uI+2zTpk3uW8+yLMvef//9wtXPtt9++9zyq666qrCPI444Ivvss88qHcuXX36ZzZ8/v0EeR23UdBW7ltivXFNNrSZN6UqEte3zZlnT6fXq837FXJ+GIkRIsmr79bpV/ZL6n//5n8L/fz0kWJOGChGeeeaZVe6n/CXLr7nmmkrX+fTTTwsnUT/72c/q8pAKnn/++cL9PPPMM3V+PGVWrlyZbb755llEZKeffnq19/nXv/61sM+5c+cW/n/58uVZt27dChOClStXVrr9W2+9lbVp06bWx6Qyd955Z2H7ESNGVLvuSy+9VGVQ9aOPPqrzfTeU6k4uFy1alD300EPZ4MGDC+sMHz680v3Ux7H87LPPsnXWWSeLiGzgwIFVbr9w4cLCc3h1mkhZ1nivqfqoy5pwcgkAQF2VnT+uToiwpuZRfYUIG/oPuE2t+VBfUvwQmcYCAAD1bXVDhOW/TvSII46osKyxQoT11bMof5799UBkY9znz3/+8yr3cdZZZ2URkZWUlGQffPBB4f+//PLLrGfPnllEZD179qxzr64x+z01BdBaYr9yTTW1mjSFEGFd+rxZ1rR6vfq8XzHXp6G0CmC1bLTRRoXbEyZMKOJIVhkxYkSVy7bffvuIiCgpKYkjjzyy0nU6dOgQW2yxRUREvP766zXe3/Lly+PNN9+MOXPmFL56J8uywvI1udTwnDlz4rXXXouIry53Xp0999yzcPtvf/tb4fazzz5buEz7yJEjo6SkpNLte/bsGfvtt99qjzUi4umnny7cHjx4cJXrLV++PPr161flT23qXgznnXdelJSUFH569OgR3/72t2PatGnRsWPH+PnPfx433nhjpdvWx7F85pln4oMPPoiIiB/84AdVbr/BBhvE/vvvX9uHVaOGfE3VR10AAKC5GDVq1BrPu2qSZVn8+te/joiIU045JQ444IBK1+vWrVtceumlERExbdq0eOWVV2p9H4888kh89tlnERFxwAEHVPsVSC+//HJhrvz1n48//rjW91lsixcvjocffjiGDBkSM2fOjIiv5jC77757bt36OAbLly+PiRMnRkTEwIED49RTT81tv9Zaa8W1114b7du3X6PHVua0006LXXbZJff/Bx98cOGr1hYvXhznn39+bL755rn1Ro8eXRjL448/XmFZYzwvAQBo3tZee+3C7Y8++qgoY2iInsUxxxzTpO5z5513joivztHfeOONwv8///zzMX/+/IiIOPHEEyscj9poSv2elt6vXB1qsmZ93ojm2+vV54W6EyKEiBg/fnxkX12Zs9qf3r17F7bZfffdY7PNNouIr/7YPGjQoLj44otj2rRpsWLFiqI8ji233LLKZeuss05ERKy//vrRrVu3GterapLyySefxMUXXxw77LBDdOrUKXr16hXbbbdd4QRqxx13LKz73nvv1f1B/MszzzxTuL3bbrtVOLH5+k/5k/mFCxcWbs+ePbtwe+DAgdXe36BBg1Z7rBFR4Y/72267bZXrlZaWxueff17psnbt2lW7bVPVv3//OOWUU6JNmzaVLq+PY1laWlq4XTbJq8qAAQNW96HkNORrqj7qAgAAzUVNzaP60Bh/wE2h+ZDih8g0FgAAKKby/YMuXboUZQwN0bMoO5duzPvceuutq1y27rrrFm6Xr3nZh6UiIvbYY49qx9xYj2N1NZd+ZXU1qu1P2YfPatJcalIsNfV5I5pvr1efF+pOiBBWU5s2bWLy5MmxzTbbRETEjBkzYty4cbH77rvHOuusEwcccEDceOON8eWXXzbamDp27FjlslatWtW4Tvn1Khv3vHnzol+/fjFu3LiYNWtWjY9t2bJlNQ25SosWLVqt7T799NPC7X/+85+F2z169Kh2uw022GC17q9MWYMjImK99darcr2dd945F07deOONIyKiX79+0bp169w2M2bMiIMOOijWWWed6NSpU+y6665xyy23rNF462rMmDExe/bsmD17dsycOTMmT54cI0eOjFatWsWTTz4Ze+21VyxevLjSbevjWJZdUTIionv37tVuV9PyumjI11R91AUAAJqLmppH9aEx/oDb0M2HpjD/q05L/RCZxgIAAMVU/qIc5YNujakhehbVnT831H3Wpq8TUbFnU77+5b+JrraaUr+nIfuVEU1/zlqZlt7DrY016fNGNN9erz4v1F3l7/5ArWy77bYxe/bsmDx5ckyePDkee+yxePXVV2PZsmUxZcqUmDJlSlxxxRXx17/+tcYQW3Nw7LHHxhtvvBElJSUxevToGDFiRGyzzTbRvXv3aNu2bZSUlMTKlStjrbXWioio8NXGdVX+F/HkyZMrXAWyOlXVuaqvMq4v5U8cq/ukxtctXrw4FixYEBFR4SqOZR555JHYf//9o3379jFixIjo3Llz3H777XHkkUfGW2+9FaeffvqaD74WevToEX379i38u3///jFs2LDYe++9Y9SoUTFv3rw44YQT4s4778xtW9/HsqVQFwAAUlJT86g+NMYfcOvafCivZ8+esWDBgiqbD01l/jdmzJg4+eSTIyLiiy++iPnz58dtt90WkyZNKjQXpk+fXukf9TUWNBYAAKi78lfC22qrrYoyhoboWZT1CxvzPouhKT2OhupXRtTvnPXFF1+s9bpVqW3gs6X3cGtjTfq8EU3rOd5UqAktlRAhrKG11lorDj/88Dj88MMjIuKdd96J++67L66++up49tln49lnn42TTjop7rjjjuIOdA299NJL8cQTT0RExLhx4+KCCy6odL3yV/9bE+WbMeuss06FE5vaKt+kevfdd6u9ssC7775b5/2Xt/766xduL1y4sNaXtH7++ecLt3faaacKy7744os48cQTo1WrVvHYY49F//79IyLinHPOiUGDBsW4ceNi+PDh0atXrzUa+5oYOXJkTJ48OW6//fa466674uGHH4599tmnwjr1fSwXL15c7bGs7pMyTUl91AUAAJqLmppH9aEx/oDbUM2HpjT/8yGy+qUmAADU5IEHHijc3n333YsyhmL0LJpKn6R8j++dd96p9iuRK9NUHkdEw/QrI+p/zlrXGq+JVHu4tVGbPm+EXm9lmtLrHuqTrzOGerbRRhvF6NGj429/+1vhhOLuu++u8NW+DX1VvIbwwgsvFG4feeSRVa5X/mt6KlPbx16+qTJt2rRabfN1/fr1K9yeMWNGtevWtLwm5b9i6fHHH6/1duVPQL/eSHr44Yfjtddei6OPPrpw8hkR0bVr1xg3blysWLEibrjhhtUec3256KKLCg3BcePG5ZbXx7HcbrvtCrefffbZatet6TnYVNRHXQAAoKUou4rbypUrq13vk08+qXJZZX/Arc1PXcJaX28+1FZNDZnmMP8bOXJkfPe7342IKDQXvq4+jsHXGwvVaa6Nhfp+XgIA0HyVlpbGQw89FBERm2yySQwYMKAo4yhGz6Kp9EnKz9Eee+yxOm/fVB5HRMP0KyOax5y1Kin3cGujpj5vhF5vZZrS6x7qkxAhNJA2bdrEkCFDIuKrTyOU/8qj9u3bF24vX768sYe2Wr744ovC7eqaNr/73e+q3U9tH/tOO+0UPXv2jIiI6667Lj777LPaDrVg5513LjQfJk2aVOXXKy9YsCDuv//+Ou+/vGHDhhWaXtdff318/PHHtdqu7AR0rbXWiu23377CsqlTp0ZExH777Zfbbv/994+IiEcffXQ1R1x/ttxyy/j+978fERFPP/10hU/MRdTPsRwwYEB07do1IiL+/Oc/V7neu+++G1OmTKnz/ouhPuoCAAAtRefOnSOi4tcFV2bu3LlVLmuMP+A2VEOmucz/fIis7jQWAACoyrJly+K4444r9K/Gjh1b4ernjakYPYum0ifZYYcdYpNNNomIiN///ve17vGVaSqPI6Jh+pURzWfOWpmUe7i1UVOfN0KvtzJN6XUP9UmIEFbT448/Hq+++mqVy1esWFE4OVh77bWje/fuhWUbbbRR4fZrr73WcIOsR1tssUXh9sSJEytd55prrqn064zKq+1jb9WqVaEh8frrr8dxxx1Xbehw6dKl8dvf/rbC/7Vr1y5Gjx4dEV+d6F166aW57couN71ixYpqx12TzTffPEaMGBERX4USR4wYER999FG127zyyiuFBsLWW28dHTp0yC2PqFj7MhtuuGGsvfbahXW+rqSkJEpKSmr9NUlraty4cYWrTH79q67r41i2b98+jjvuuIj46qqRV111VW67lStXxkknndRsTtLqoy4AANBS9OnTJyIiPvroo3j55ZcrXWfFihVx++23V7mPxvgDbkM1ZNZk/teYfIis7jQWAACozJw5c2L33XePmTNnRkTEkCFDYsyYMUUbTzF6Fk2lT9KqVav4xS9+ERER8+fPj+OOO67KvuHKlSvj7bffzm3fFB5HRMP0K8vWiWj6c9bKNLUebm01Zq+3uj5vhF5vZZrS6x7qU3E+ygBNzKJFi6K0tLTG9Tp06BCbb755REQ89NBDcf7558cee+wRBx98cGy//fbRvXv3WLZsWcydOzd+97vfxXPPPRcREccff3yFTw7tuOOO0b59+/jss8/i3/7t36JNmzbRq1evQiNi4403rvQErZh23HHH6Nu3b5SWlsa1114bS5YsiWOPPTY22mijmD9/fvz5z3+O2267LQYPHlztJ+vr8tj/3//7f/HAAw/EHXfcEbfeems899xzcdJJJ8WgQYOia9eusXTp0njppZdi6tSpcdddd0X79u3jJz/5SYX7O+ecc+KWW26J+fPnx5lnnhnPP/98HHfccdGjR4+YO3duXHHFFTFjxowYMGDAGl/B4Le//W1Mnz49Xn311bjnnntiyy23jB/+8IcxePDg2HDDDWPlypWxaNGimDVrVkyZMiUee+yxwld1VXZ5+g8//DAiotA8+bouXboU1im2vn37xqGHHhp33nlnPPbYY/HEE0/E7rvvXlheH8fy3HPPjVtvvTUWLlwYp512Wjz77LNxzDHHRPfu3ePVV1+Nq666Kp588skYNGhQTJ8+PSKa/leH10ddauuJJ56oEHx+7733CrdfffXVXDh41KhRq3U/AACwOsqu5B8Rcfnll8d1112XW+fnP/95LFiwoMp9lP0B9+STTy78AXfSpEnRrl27StdfunRp/OlPf6rTOXZZ8+HGG28sNB9uuummwpUUK1ObhsyazP/K5j29evWKefPm1fqxrK5x48bFzTffHFmWxQUXXBBDhw4tLKuPY1DWWPiv//qvQmPh1FNPrbBdc2wsNOTzEgCApufrvcdPPvkklixZErNmzYqHHnooHnjggcIVCHfddde47bbbok2bNsUabkQ0bs+imPdZmR//+McxefLkwlj69esXJ598cgwYMCA6duwYCxcujKeeeipuuummOProo+Pcc89tko8jov77lRHNq2dZmZR7uLVRU583Qq+3Mvq8tEgZJOqRRx7JIqJOPzvssENh+/Hjx9dqm8MOOyz79NNPc/d/xhlnVLnNI488UlhvwoQJhf9/4403cvspP47qjBw5MouIrFevXtWuN2TIkCwisiFDhuSWzZw5M+vWrVuV4+7Xr1/29ttvF/49fvz4Su+jto89y7JsxYoV2ZgxY7KSkpIaa92nT59K76+0tDTbcMMNq9xu1KhRNda5tt59991s3333rfVzaptttsmuvfbabPny5bl9DR06NIuI7JVXXqn0vr7xjW9kXbp0qXRZ2f5rOt7VKf8aqepYljd9+vTC+vvtt19ueX0cy+effz7r3r17tcfyD3/4Q+HfCxcuzO2jKb2m6qsutVE23tr+AADA15WdK1Z1bvt1tT23LrPbbrsV1h85cmT28MMPZ88++2x28803Z/vss08WEdm3vvWtas/nV65cmR1xxBGFdTbffPPsP/7jP7KpU6dmM2fOzB599NHs2muvzY466qisU6dO2XrrrVeHCnzln//8Z/bNb36zcB8bbrhhNm7cuOyee+7Jnn322WzGjBnZPffck1188cXZXnvtlbVq1arC46pMc5v/HXbYYYX1H3/88QrL6uMYvP/++xXm8ccee2x23333Zc8++2z2l7/8pfA8GDRoUGGdefPm5fZT3fyvMed+jfG8LPP4449nEyZMKPxceumlhfsdPHhwhWUTJkxY7fsBACCvrr3H7t27ZxdeeGH2+eefV7nP2vSvanMuX9vz/TXtWdR1HtiY91n++Hy9H5llWfbJJ59kw4cPr3EMVdWwMfo9ZY+1pnl5ffYrs2zN5qxNRVPp4db2GK7pXL+++7xZ1jR6vfq8+rw0LFcihNU0duzY2H777ePBBx+MmTNnxttvvx2LFi2KiK8uUzxo0KA47rjj4uCDD650+0suuSS22GKL+NOf/hQvvPBCfPjhh/Hll1825kOos/79+8fzzz8fF198cdx7773x9ttvR+fOneOb3/xmfP/7348f//jH0b59+xr3U5fH3qZNm/jv//7vGDNmTFx//fUxderUePPNN+Pjjz+OtddeO/r06RM777xzHHjggTFs2LBK97HddtvFCy+8EL/+9a/jjjvuiDfffDM6d+4c/fr1ixNPPDGOOuqoKr+iua569OgRDzzwQDz88MNx4403xrRp0+Ltt9+OTz/9NDp37hw9evSIfv36xYABA2LYsGGx3XbbVbmvsk+vVPVJlaVLl0a3bt3qZdz1YeDAgTF06NB44IEH4v77748ZM2bEwIEDC8vr41jusMMOMWfOnLjkkkvirrvuqvRYXnnllYX1q/oEUFNSH3UBAICW4I9//GMMGTIkFi1aFDfccEPccMMNFZaPHTs2tttuu3jyySer3EdJSUn85S9/iVNPPTV+97vfxWuvvRZnnHFGlev36NGjzuPs1q1bTJs2LY455ph48MEHY+HChXHRRRdVu80222wTp512WpWfBG9u879f/vKXceedd0ZExPnnn1/ha4Xr4xisu+66cd9998XQoUNj8eLFMWnSpJg0aVKFdUaNGhV77LFH4eoEtfl7RLE0xvOyzO9///vca6fMtGnTct8e4eoEAAANr1WrVtG5c+fo2rVr9OrVK3beeefYY489YtiwYdG2bdtiD6+CYvQsmkqfpGPHjnHrrbfGI488EhMmTIgnnngiFi5cGF9++WVssMEG0b9//xg2bFgcddRRTfpxRNRvvzKi+c1ZK5NyD7c2aurzRuj1VqYpve6hXhQ7xQhA5c4+++wsIrKbbropt+ydd97JIiLbZ599ijCypu3444/PIiLr2bNnsYcCAAAtSkTDXokwy7Js/vz52ZgxY7JevXplbdu2zbp3754dcMAB2T333JNlWe2uwlFm1qxZ2U9/+tOsX79+WdeuXbO11lor69q1a9a/f//s+OOPz2677bbss88+q/XYKvPQQw9lxx9/fLb11ltnXbp0yVq3bp1169Yt22qrrbLhw4dnl1xySVZaWlrjftZk/ldWj8a8EmGWrbryQkRk06dPr3SdNT0Gixcvzk4//fRsiy22yNq1a5etv/762d57753deOONWZZl2W9+85vCGJYtW5bbvqlcibC8hn5eujoBAAC0XLW9il1907OsaE3qUaxj2Jzo9ULxlGRZljVQPhGANTBlypQ44IADYvTo0fHHP/6xwrIbbrghRo0aFeedd16cc845RRph07Ns2bLYdNNN47333ovhw4fHrbfeWuwhAQAA1Mj8b/WccMIJ8Yc//CF69uwZb731VrGHAwAA0KDOPffcOO+882LIkCExderURrtfc9aK1qQexTqGzYVeLxRXq2IPAIDKffvb347NNtssbrzxxnj++ecL///hhx/GRRddFG3bto3jjjuueAMsgtdeey2qyr5/+eWXMWbMmHjvvfciImLkyJGNOTQAAIDVZv5Xd8uWLSt8pfKuu+5a5NEAAAC0XOasFanH6tPrhaatdbEHAEDlWrduHb///e9j//33jz333DNGjBgRnTt3jttvvz3+8Y9/xGWXXRa9e/cu9jAb1fnnnx/Tp0+PESNGxC677BI9evSIZcuWxaxZs+L666+P5557LiIi9t133zj44IOLPFoAAIDaMf/Le+2112KzzTaLkpKS3DKNBQAAgMZjzlqReqw+vV5o2oQIAZqwvffeO5544okYP358/OUvf4nPP/88+vXrF7/+9a/jyCOPLPbwiuLFF1+M8ePHV7l88ODBcfPNN1faaAIAAGiqzP8q0lgAAABoOsxZK1KP1afXC02XECFAEzdo0KC49957iz2MJuHss8+OLbfcMh588MGYN29eLF68OD7//PNYb731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UJuECAEAAAAAAAAAGiiTngBQHiFCAAAAAAAAAAAASFSj2m4AAAAAAAAAAAAAUDuECAEAAAAAAAAAACBRQoRQx40ePToKCgqioKAgFi1aVNvNabDUOR3ONQAAAAAAAADAJkKEJGvSpEn5IFFFf4YMGVLbzaYeWr58edx6661xyimnxF577RXNmzePpk2bRps2beKwww6LSy65JJ599tlYv359bTe1hM1dI82aNYs999wz+vbtG3/84x9j7dq1td1cyrF8+fJ46qmn4te//nV897vfjVatWuXP58CBA2u7eQAAAFXOIDIAAOq7ij7TLl68OC6++OLYd999Y7vttstv8/jjj1dqHeq2YcOGRUFBQRx99NG13RS2kHO4dfTzoXptU9sNgBSNHj06Bg0aFBER77zzTuy1116126AalNKxr1q1Kq655pr4wx/+UGrIbsWKFbFixYqYPn163HXXXbHbbrvFVVddFZdddllss03dvj2vXr06lixZEkuWLImnn346fvOb38RTTz3VoM9nfde2bdvabgIAAHXcokWLYu+9997q/eRyuSpoTf2zfPnyGDNmTEyePDnmzJkTH3/8caxbty5atGgRe++9d3Tt2jVOPvnk6NOnT53r802aNCmOOeaYUpdtv/32seuuu8ZBBx0UZ5xxRpx33nnRtGnTGm4hFbV8+fKYPn16TJ8+PWbMmBEzZsyIjz/+OCIiBgwYEKNHj67dBgIANGBlPVc3btw4dtppp2jRokXsueee0bVr1+jZs2ecfPLJse222271+y5evDi6du0aH3300VatQ8NWn/us1aUh10Q/v2HR16em1K87HVSTwYMHxyWXXFLueq1ataqB1pQ0cOBAs4TVQ4sXL44+ffrE/PnzIyJip512itNPPz2OO+642GOPPWKHHXaI5cuXx+zZs2Ps2LHxyiuvxLJly+Kqq66q0Gexpn31Glm+fHkUFhbGiBEjYsmSJfH666/HKaecErNmzYrGjRvXYkvL55qK+PrXvx4dO3aM8ePH13ZTAACg3mvIA8giDCKrbwwgAwCoezZs2BCffPJJfPLJJ7Fo0aKYMmVK3HbbbdG6deu4/PLL4+qrr96qvsH1118fH330UWyzzTZxww03xLe//e3YcccdIyKiffv2FV6Hhqmh91m3ROo10c+vf/T1qSn1/w4HVaBNmzbRuXPn2m4GDcTSpUujd+/e8fbbb0fEl6G12267LVq0aJFZ98QTT4yhQ4fG5MmT4/LLL49tttmmSkadVbXSrpHevXvHoEGD4sADD4xFixbF3Llz47HHHot+/frVUivZnF//+tfRvXv36N69e7Rt27bKZpkBAKDh2GOPPWLu3LllLu/SpUtERHTr1i1GjRpVU82q0xraALIIg8gaEgPIAABqz1efqz///PP45JNPYs6cOfH888/HxIkTY8WKFfGrX/0qxo4dG0899VS0bt06s5+KPNNOnDgxIiJOO+20uPLKK7d4HRqehthn3Vop1kQ/v2HR16c6CRECVKEvvvgivvOd7+QDhCNHjoyf/exn5W7Xq1evePnll+OZZ56p7iZWqebNm8cvf/nLuPDCCyPiy06oEGHdNHz48NpuAgAAdVyTJk0qNMBuhx12MBAvGuYAsgiDyOo7A8gAAOqGsiYw+e53vxtXXXVVzJs3L77//e/HrFmzYvr06XH66afHCy+8sEX9hKVLl0ZERIcOHbZqHRqWhtpn3Rqp1kQ/v/7T16emNKrtBkB99/7778fVV18dhx56aLRo0SKaNGkSbdu2jS5dusQ555wTo0ePjpUrV0ZExKRJk6KgoCAGDRqU337vvfeOgoKCEj+TJk3KLx89enT+94sWLcq8/7Bhw/LLIyJWrlwZw4YNiy5dusSOO+4Ybdq0iRNPPDFefvnlEtstX748fvnLX0anTp1ihx12iF133TVOPfXUmDVr1maPt7CwMK6//vo4/vjjo127dtG0adPYcccdY7/99osBAwbEK6+8Uup2W3Lsxb344osxYMCA2GeffaJZs2ax0047RZcuXeLnP/95vP/++5ttc0TEJ598EldffXV07Ngxtt9++2jTpk0ce+yx8cgjj5S7bWVcd9118dZbb0VExJAhQyoUICyyww47xJlnnlml7akJRbORRES899575a6/tefy448/jiuvvDL233//2H777aNt27bRp0+feOyxxyKi/Gumrl1TVVUXAACg5pQ2gGzUqFGl/uGhuKIBZFdffXVNNLNKFQ0iK1I0kwl1y/Dhw6Nv376+6ggAoI775je/GdOmTYtDDjkkIiKmTZsWd9555xbta926dRHx5cCwrVmHhiPFPmt51CRLP7/+0NenpggRwlaYMmVKHHDAAXHLLbfErFmzYuXKlbF+/fr8FMAPPfRQDBo0KF566aUaac97770X3bt3j+HDh0dhYWF88cUXsWLFinj22Wfj29/+dj4wN2fOnDj00EPjhhtuiHnz5sWqVaviH//4Rzz55JNxxBFHxIsvvljq/idNmhRdunSJX/3qVzF+/PhYunRprFu3Lr744otYuHBh3HfffXHEEUfENddcU2XHtGbNmjjnnHOid+/ecd9998U777wTq1evjs8++ywKCwtj5MiR0aFDhxg7dmyZ+3jjjTeic+fOccstt8Rbb70Va9asiRUrVsTzzz8fZ511VvzgBz+okra++eab8dvf/jYivgxI3njjjVWy37qu+KibzXU+q+Jczp07Nzp16hQjRoyI+fPnx5o1a2L58uUxceLEOOOMM+Liiy+u0mOr7muqquoCAAB10VcH6Hz66adx3XXXxSGHHBItW7aMgoKCGD16dER8Ofq/oKAg9tprr83us7xBQcVV50CdFAeQRTSsQWQGkAEAUNu23377GDNmTP6ZdOTIkfGvf/2rxDplPdMW/32R4cOHl5i4Y6+99ip3nbK+FnRLn1sr0w+srvdcs2ZNjBgxIg499NBo3rx5NG/ePHr06BF33HFHrF+/vsz9FJk2bVpceOGFsf/++8dOO+0U2267bbRr1y769u0bd955Z/zzn//c7PZ14Zk/1T7r5qhJ6Srbz4+o3b6+yWKgevk6Y9hCa9eujf79+8fKlSujefPmMXjw4DjmmGOiTZs2sW7dunjnnXfi5Zdfzv9jFxHRvXv3mDt3bjzxxBP5VP+4cePia1/7Wol9b+nUs2eeeWYsWbIkrrnmmjjhhBOiWbNmMXXq1Lj22mtj5cqV8cMf/jC6desWffv2jdWrV8cNN9wQvXr1iiZNmsRzzz0XN9xwQ6xduzYGDhwYCxYsyEzJvH79+thhhx3ipJNOit69e0fHjh1jp512iuXLl8frr78ev/vd7+Ldd9+Nm2++OTp06FBi1sEtOfZcLhf9+vWLp59+OiIiTj755DjrrLNin332iUaNGsX06dPj1ltvjcWLF0e/fv1i2rRp0a1btxL7W7lyZRx//PH5f5zPPvvsGDBgQLRp0ybmz58fv/nNb2LUqFFRWFi4RTUv7oYbbsiP5Lr22mtj++233+p91gdvvPFG/nVZf/CrinP5z3/+M0444YT48MMPIyLi/PPPj3PPPTdat24dCxcujNtvvz3uvvvu+L//+78qO7bqvqaqoi4AAFAfLFiwII477rhyg39VYc2aNTFo0KB46KGHMssKCwujsLAw7rrrrnjwwQfj5JNPrvT+Ux1AFlG5QWRbew7mzp0bffr0yfcBi/Y7ceLEmDhxYvzHf/xHHHHEEVtxNJu89957ceyxx8b8+fPzv/viiy/i2WefjfHjx8eDDz4YZ555ZsyZMydOPPHE/FfBRUSsWrUqnnzyyRg3blw8++yzccwxx5T6HtX9uQQAoH7q1KlT9OnTJ8aPHx/vv/9+zJgxI771rW/VWnuq8rm1ov3AqnzPDz/8ME444YSYPXt2id/PmDEjZsyYEePHj4/HH388GjXKzrW0evXq+OEPfxgPPvhgZtnSpUtj6dKl8fTTT8eKFSti2LBh1XocWyPlPmtZ1KRsFe3nR+jrl6auXPdQVYQIISI/c2B59t9///w/ntOmTcsH0x544IHo27dviXUPP/zwOOecc+K3v/1trFq1KiK+HKXQuXPnePXVV/PrdejQodyZFipq9uzZMXny5DjssMPyv+vWrVvst99+0bdv3/jss8/isMMOi1wuF9OnT4999903v16PHj2iVatWcemll8bixYvj6aefjtNPP73E/g8++OBYsmRJtGzZMvPexx9/fFx22WXRt2/fmDBhQgwfPjwuuOCCaNy48RYf+7333htPP/10NGnSJJ588sk44YQTSiw//PDD4/zzz4+jjjoqXn/99RgyZEhMnTq1xDrXXXddftTEjTfeWGKWxK5du0a/fv2ib9++MX78+DLbURGfffZZPProoxER0bJlyzjrrLO2an/1xYYNG2LEiBH5/+7Xr1+p61XFuRw+fHj+mrvtttviJz/5SX5Z0bn83ve+F0888URVHV61X1NVURcAAKgP+vXrF0uXLo0f//jHccopp8TOO+8cCxYsiPbt21fp+9TEQJ1UB5BFNNxBZAaQAQBQm4499tj836mmTJlSoRDhaaedln9mLJpJbPDgwXHJJZfk19l5553jk08+KXedIlX93FqRfmBVv+cZZ5wR8+bNi8svvzxOPvnk2GWXXeKtt96K6667Lt54440YO3Zs3HPPPZlvttq4cWOceuqpMWHChIiI2G+//eKSSy6Jbt26RbNmzeKDDz6Il19+OR5++OFS37cuPfOn3Gcti5qUrSL9/Ah9fX19kpGDRL344ou5iKjUzzvvvJPf/s9//nP+959++mml3nvUqFGl7nNL1r322mvzy6+66qoy99O+ffv8enfddVep66xatSq33Xbb5SIi9//+3/+rzCHlzZ49O/8+r776aqWPp8jGjRtz++67by4icj/72c82+57PPPNMfp/z58/P/37t2rW5nXfeORcRuQMPPDC3cePGUrd/7733ck2aNKnwOSnNE088kd++f//+m133zTffzM2dO7fUn88++6zS711dil8j1157bYlly5cvzz3//PO5I488Mr9Ov379St1PVZzLNWvW5Fq2bJmLiFz37t3L3H7ZsmX5z3BZ57KuXFNVUZet8c477+T3OWDAgCrZJwAADVvR82OvXr0qtH7xZ+tGjRrlxo0bV+a6AwYMyEVErn379pvdZ3nP83fffXcuInJNmjTJPfvss6Xu4x//+EeuU6dOuYjIHXnkkRU6liIrV67MP+O3bNkyt2rVqkptX1dtrv9XZP369blDDjkkv96UKVNKXa8qzsGQIUPy73PbbbeV2pZTTz21zP9nU2Rzn5fin8+mTZvmXnnllcz2Tz31VH6d1q1b51q1apVbuHBhZr0777wzv97//u//VktNtpS+HwBAzanIc3VpJk6cmN/uBz/4QYllFfm7WkXesyLrVMVza2X6gdXxnk2aNMm9+OKLmXU+/vjjXNu2bfN/M/yq22+/Pb+P008/PbdmzZpS27Jhw4bckiVLquU4KqLoWMvqlzfUPuvWqGs1Ke8cVpWq7OfncnWnr1+Zv/Pq60PlZefpBSpk9913z78eNWpULbZkk/79+5e57MADD4yIiIKCgjj77LNLXWf77beP/fbbLyIi/v73v5f7fmvXro3FixfHvHnz8tPx5nK5/PKtGSUwb968ePvttyOi7Nntinz729/Ov/7rX/+af/3aa6/lR1gNGDAgCgoKSt2+Xbt2cdxxx21xWyMi/va3v+VfH3nkkWWut3bt2ujSpUuZPxWpe20YPnx4FBQU5H/atGkT3/nOd2LatGnRrFmz+OlPfxoPPPBAqdtWxbl89dVX45///GdERHz/+98vc/u2bdvG8ccfX9HDKld1XlNVURcAAKgvBg4cuNX9rvLkcrm45ZZbIiLi8ssvz8z0XWTnnXfOz6g+bdq0WLBgQYXf48UXX4w1a9ZERMQJJ5yw2dkL3nrrrXxf+as/n3/+eYXfs7atWLEiXnjhhejVq1fMmjUrIr7sw/Ts2TOzblWcg7Vr18bo0aMjIqJ79+4lZqEv0rhx4/jDH/4Q22233VYdW5EhQ4aUmIG+yEknnZSfJWXFihVx3XXXlZiBvsigQYPybZkyZUqJZTXxuQQAoH7bdddd86+L/q5V06rjubW8fmB1vOePf/zjOProozO/32WXXWLQoEER8eXXqX766af5ZRs3bszvv127dnHfffdF06ZNS91/o0aNYo899qj249hSKfZZy6MmWZXp50fo60fo65MOIUKIL6ctzuVy5f4Un8K3Z8+esc8++0TEl/8A9ejRI2666aaYNm1afjrkmtahQ4cylxV9BXGrVq1KTE1e1nqfffZZqcu/+OKLuOmmm+Kggw6KHXbYIdq3bx+dOnXKh+AOOeSQ/LofffRR5Q/i34p/7fERRxxRIsD21Z8dd9wxv+6yZcvyr+fOnZt/3b17982+X48ePba4rRFR4h/8b37zm2WuV1hYGP/6179KXda0adPNbltXHXzwwXH55Zfnv+r7q6riXBb/uvGuXbtutj1VOQ10dV5TVVEXAACoL84777xqf4+aGKjT0AeQRaQ5iMwAMgAAalPxvwGU9fe56lYdz63l9QNr+j2L/r6Uy+XinXfeyf9+9uzZsWTJkoiIuOiii0qcj4qoS8/8KfRZK0tNtq6fH6GvH6GvTzqECGELNWnSJMaOHRsHHHBARETMmDEjhg4dGj179oyWLVvGCSecEA888EBs2LChxtrUrFmzMpc1atSo3HWKr1dauxctWhRdunSJoUOHxpw5c8o9ttWrV5fX5DItX758i7ZbtWpV/vU//vGP/Os2bdpsdru2bdtu0fsVKXroiSg5YuyrunbtmgmnFo1Y6tKlS2yzzTYl1r///vvj4osvjm7dukXTpk2joKAgP0qjJg0ePDjmzp0bc+fOjVmzZsXYsWNjwIAB0ahRo3j55Zfj6KOPjhUrVpS6bVWcy+Ij71q3br3Z7cpbXhnVeU1VRV0AAKC+KPqfs9WpJgbqVOcAsrrS/9uchjqIzAAyAABqU/FnyJ122qlW2lAdz63l9QOr4z07duxY5rJddtkl/7p4zYtmYouIOOqoozbb5po6ji1VXyY92VyNKvpT0f5yfalJbSmvnx+hrx+hr086til/FaAs3/zmN2Pu3LkxduzYGDt2bLz00kuxcOHCWL16dYwbNy7GjRsXv/nNb+KZZ54pN8RWH5x//vnxzjvvREFBQQwaNCj69+8fBxxwQLRu3Tq23XbbKCgoiI0bN0bjxo0jIkp8tXFlFQ9cjR07tsQskJtTVp3L+irjqlI8/Le5h6yvWrFiRSxdujQiosQsjkV++ctfxrvvvhutWrWK3XffPd59992tb+wWaNOmTXTu3Dn/3wcffHD07ds3jjnmmBg4cGAsWrQoLrzwwnjiiScy21b1uWwo1AUAgJRs7n/IVpWaGKhT2QFkxbVr1y6WLl1a6gCyiLrT/xs8eHBccsklERGxfv36WLJkSTz66KMxZsyY/CCy6dOnlzqAq74OIjOADACA2lT8m72KB91qUnU8t5bXD6yO96zIs31Eyef24vXffffdK92euvTMX5191vvvvz+mTJkSr732WsydOzfWrVsXo0aNioEDB1ZV86tFddWkPtVja/r5Efr6Efr6pEOIELZS48aN47TTTovTTjstIiI++OCDeO655+LOO++M1157LV577bW4+OKL47HHHqvdhm6lN998M6ZOnRoREUOHDo3rr7++1PWKz/63NYo/xLVs2bJEgK2iindOPvzww82ONvjwww8rvf/iWrVqlX+9bNmyCo9GmT17dv71oYcemll+7733xn777Rft27ePm2++Oa655pqtamdVGzBgQIwdOzb+8pe/xJNPPhkvvPBC9O7du8Q6VX0uV6xYsdlzWdaMiHVNVdQFAADqi6LBZtWpJgbqVNcAsoi60/8ziKxqqQkAAOUpPhPe/vvvXyttqI7n1vL6gQ3lWbkuHUd19lmrcuDbG2+8scXbFqlo4LOhTwRTEVvTz4+oW5/xukJNaKiECKGK7b777jFo0KD4/ve/H4cffnjMnDkznnrqqVi9enVsv/32EVH9s+JVh9dffz3/+uyzzy5zveJT95amosde/GFs2rRp0bNnzwptV1yXLl3yr2fMmLHZKchnzJhR6f0X17Vr1xgzZkxEREyZMiUTpCtL8RBhaQ+gxx577Fa1qybceOON8fjjj8eGDRti6NCh8corr5RYXhXnslOnTvnXr732Whx55JFlrlveZ7CuqIq6AABAQ1E0snvjxo2bXe+LL74oc1lNDNSprgFkEXW//2cQ2ZYxgAwAgPJMmDAh/7q2/lZQG8+tdeVZuXg/74MPPtjsVyKXpq4cR0T19lmrcuBbZWu8NVKdCKYiKtLPj9DXL01duu6hKjUqfxVgSzRp0iR69eoVEV9OC1x8quTtttsu/3rt2rU13bQtsn79+vzrzf3R5ve///1m91PRYz/00EOjXbt2ERFx9913x5o1ayra1LyuXbvmH0jGjBlT5tcrL126NMaPH1/p/RfXt2/f/B+97rnnnvj8888rtF3RA2jjxo3jwAMP3Ko21JYOHTrEWWedFRERf/vb30p0diOq5lx269YtWrRoERFfTg9elg8//DDGjRtX6f3XhqqoCwAANBTNmzePiJJfM1Sa+fPnl7nsqwN1qkPXrl3zr6dMmVLh7cobQFZf3HjjjfnZRIYOHZpZXhXn4KuDyDanPgwiq4nPJQAA9VdhYWE8//zzERGx5557Rrdu3WqlHbXx3FpXnpWLB8ReeumlSm9fV44jonr7rMcee2y0b99+i9tWW6qrJvW1Hl9VXj8/Ql+/NHXpuoeqJEQIW2jKlCmxcOHCMpevW7cuJk+eHBERO+64Y7Ru3Tq/rPj0ym+//Xb1NbIK7bfffvnXo0ePLnWdu+66q8xpjotU9NgbNWqUf1D5+9//HhdccMFmQ4crV66MO+64o8TvmjZtGoMGDYqILx/0RowYkdlu/fr1cdFFF8W6des22+7y7LvvvtG/f/+I+DKU2L9///jss882u82CBQvyDxUdO3bMz1RZFQoKCqKgoKDCUydvraFDh+ZnmfzqV11Xxbncbrvt4oILLoiIL2eNvP322zPbbdy4MS6++OJ6E8ariroAAEBDsffee0dExGeffRZvvfVWqeusW7cu/vKXv5S5j5oYqJPyALIIg8i2hAFkAACUZfXq1XHBBRfkJ8G44oorSnz1ak2qjefWuvKsfNBBB8Wee+4ZEV/OLlfRfl6RunIcEfqspVGTzSuvnx+hr1+aunTdQ1USIoSIWL58eRQWFpb7Uzz09vzzz8f+++8fRx99dIwYMSLGjRsXM2fOjGnTpsWoUaPiqKOOipkzZ0ZExA9/+MMSD/2HHHJIfka+X/3qVzFhwoSYP39+LFy4MBYuXBirV6+u2QJUwCGHHJKfhvcPf/hDnH322fHUU0/Fa6+9Fk888USceeaZcckll2z2a2aL9lPRY//Rj34Up59+ekREPPLII9GpU6cYMWJETJ48OWbPnh0vvfRS3H333XHuuefG1772tRg2bFjm/X7961/n/wG/6qqr4txzz43nnnsuZs6cGQ899FB861vfimeffbZKRnbdcccd8Y1vfCMiIp5++uno0KFD/OIXv4hnnnkmZs6cGa+++mo888wzcfPNN8cxxxwTHTt2jHfffTciotZGllWVzp07xymnnBIRX47Smjp1aonlVXEuhw0bFrvttltERAwZMiQuuOCC/HX38MMPx1FHHRVPPPFE9OjRI79NXf/q8KqoS0VNnTo1Ro8enf959NFH88sWLlxYYllZQWEAAKguRTP5R0Tceuutpa7z05/+NJYuXVrmPmpioE5dG0AWYRBZXWcAGQAApZk3b1707NkzZs2aFRFf9okGDx5ca+2pjefWuvKs3KhRo/j5z38eERFLliyJCy64oMzJRzZu3Bjvv/9+Zvu6cBwRdbPPWtvqa01qsq+/uX5+hL5+aerSdQ9VqXaGMkAdc9ddd8Vdd91V7noHHXRQiamLN27cGJMnT87POFiaU089NW666aYSv2vevHlcfvnl8Z//+Z8xc+bMOO6440osf/HFF+Poo4+u1DFUt4KCghgzZkz07t07Pvnkk3j44Yfj4YcfLrFOly5d4pFHHomvfe1rZe6nMsdeUFAQ//M//xM/+clP4ve//328/fbbceWVV5a57zZt2mR+16JFi3juuefi2GOPjWXLlsWDDz4YDz74YIl1Bg4cGL169crPWrildt5555g2bVqcd955MXHixFi2bFnceOONm93mgAMOiCFDhsTAgQO36r3rgl/84hf5mSivu+66EqNEquJc7rLLLvHcc89Fnz59YsWKFTFmzJgYM2ZMiXUGDhwYRx11VEyfPj0iSn59dl1UFXWpqHvvvTf+9Kc/lbps2rRpmam2G8JnEgCA+uOQQw6JI444Iv7617/GPffcE+vWrYsBAwZEixYtYsGCBXH33XfHCy+8EN/61rfi5ZdfLnM/P/rRj2LChAnx2GOPxSOPPBIzZ86Miy++OHr06BEtWrSIlStXxptvvhmTJk2KJ598Mrbbbru47LLLKtXWO+64I6ZPnx4LFy7MDyD7wQ9+EEceeWTstttusXHjxli+fHnMmTMnxo0bFy+99FJs3LgxIur/ALKITYPInnjiifwgsp49e+aXV8U5GDZsWDzyyCOxbNmyGDJkSLz22mtx3nnnRevWrWPhwoVx++23x8svvxw9evTI9//q8iCymvhcFpk6dWqJb8746KOP8q+LBpAVp+8HAFA9iiYwKfLFF1/EJ598EnPmzInnn38+JkyYkJ+B8PDDD49HH300mjRpUlvNjYiafW6tzfcszaWXXhpjx47Nt6VLly5xySWXRLdu3aJZs2axbNmyeOWVV+LBBx+Mc889NzPpQ105jgh91tKoyeaV18+P0Ncvjb4+DZEQIWyhK664Ig488MCYOHFizJo1K95///1Yvnx5RETstttu0aNHj7jgggvipJNOKnX7m2++Ofbbb7+477774vXXX49PP/00NmzYUJOHUGkHH3xwzJ49O2666aZ49tln4/3334/mzZvHN77xjTjrrLPi0ksvrVBoqzLH3qRJk/iv//qvGDx4cNxzzz0xadKkWLx4cXz++eex4447xt577x1du3aN7373u9G3b99S99GpU6d4/fXX45ZbbonHHnssFi9eHM2bN48uXbrERRddFOecc06VzbzWpk2bmDBhQrzwwgvxwAMPxLRp0+L999+PVatWRfPmzaNNmzbRpUuX6NatW/Tt2zc6depUJe9bF3Tv3j369OkTEyZMiPHjx8eMGTOie/fu+eVVcS4POuigmDdvXtx8883x5JNPlnoub7vttvz6RdNi12VVURcAAGgI/vjHP0avXr1i+fLl8ac//SkzCOaKK66ITp06bTZEWBMDdVIfQBZhEFllGUAGAJCeikxg0rp16xgyZEhceeWVtfY1xsXV5HNrbb5naRo1ahSPP/54DBgwIB599NGYP39+DBkypMLb15XjiNBnLY2alG9z/fwIff3S6OvTENX+0wjUkqOPPjo/wmdL7LjjjnHGGWfEGWecsUXbFxQUxIUXXhgXXnjhZtcbOHDgZm/yw4YNq9BXnFb0K0onTZq02eVf//rXy+30lFfXih57cV26dInf/e53FV7/q3bZZZe45ZZb4pZbbil1eXl1rqzevXtH7969q2x/lbU1n+0iW3KNjB8/vtx1tvZctmrVKkaOHBkjR44sdXnRyL527dqV+mBZ166pIltbl/L4mmIAAOq6jh07xsyZM+OGG26IZ555Jj744INo0aJFdO3aNX784x/HiSeeWKFn2poYqJPyALIIg8i2hAFkAADpatSoUTRv3jxatGgR7du3j65du8ZRRx0Vffv2jW233ba2m1dCbTy31pVn5WbNmsUjjzwSL774YowaNSqmTp0ay5Ytiw0bNkTbtm3j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m2a5n2S5n2SpSUn6pdBwuc9t4t6fpSZZalKSemSpSZaaZKlJlppkqUlWRfumZiIEAAAAAAAAAACARAkRAgAAAAAAAAAAQKKECAEAAAAAAAAAACBRQoQAAAAAAAAAAACQKCFCAAAAAAAAAAAASJQQIQAAAAAAAAAAACRKiBAAAAAAAAAAAAASJUQIAAAAAAAAAAAAiRIiBAAAAAAAAAAAgEQJEQIAAAAAAAAAAECihAgBAAAAAAAAAAAgUUKEAAAAAAAAAAAAkCghQgAAAAAAAAAAAEiUECEAAAAAAAAAAAAkSogQAAAAAAAAAAAAEiVECAAAAAAAAAAAAIkSIgQAAAAAAAAAAIBECRECAAAAAAAAAABAooQIAQAAAAAAAAAAIFFChAAAAAAAAAAAAJAoIUIAAAAAAAAAAABIlBAhAAAAAAAAAAAAJEqIEAAAAAAAAAAAABIlRAgAAAAAAAAAAACJEiIEAAAAAAAAAACARAkRAgAAAAAAAAAAQKKECAEAAAAAAAAAACBRQoQAAAAAAAAAAACQKCFCAAAAAAAAAAAASJQQIQAAAAAAAAAAACRKiBAAAAAAAAAAAAASJUQIAAAAAAAAAAAAiRIiBAAAAAAAAAAAgEQJEQIAAAAAAAAAAECihAgBAAAAAAAAAAAgUUKEAAAAAAAAAAAAkCghQgAAAAAAAAAAAEiUECEAAAAAAAAAAAAkSogQAAAAAAAAAAAAEiVECAAAAAAAAAAAAIkSIgQAAAAAAAAAAIBECRECAAAAAAAAAABAooQIAQAAAAAAAAAAIFFChAAAAAAAAAAAAJAoIUIAAAAAAAAAAABIlBAhAAAAAAAAAAAAJEqIEAAAAAAAAAAAABIlRAgAAAAAAAAAAACJEiIEAAAAAAAAAACARAkRAgAAAAAAAAAAQKKECAEAAAAAAAAAACBRQoQAAAAAAAAAAACQKCFCAAAAAAAAAAAASJQQIQAAAAAAAAAAACRKiBAAAAAAAAAAAAASJUQIAAAAAAAAAAAAiRIiBAAAAAAAAAAAgEQJEQIAAAAAAAAAAECihAgBAAAAAAAAAAAgUUKEAAAAAAAAAAAAkCghQgAAAAAAAAAAAEiUECEAAAAAAAAAAAAkSogQAAAAAAAAAAAAEiVECAAAAAAAAAAAAIkSIgQAAAAAAAAAAIBECRECAAAAAAAAAABAogpyuVyu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AAAAAAAAAAAgUUKEAAAAAAAAAAAAkCghQgAAAAAAAAAAAEiUECEAAAAAAAAAAAAkSogQAAAAAAAAAAAAEiVECAAAAAAAAAAAAIkSIgQAAAAAAAAAAIBECRECAAAAAAAAAABAooQIAQAAAAAAAAAAIFFChAAAAAAAAAAAAJAoIUIAAAAAAAAAAABIlBAhAAAAAAAAAAAAJEqIEAAAAAAAAAAAABIlRAgAAAAAAAAAAACJEiIEAAAAAAAAAACARAkRAgAAAAAAAAAAQKKECAEAAAAAAAAAACBRQoQAAAAAAAAAAACQKCFCAAAAAAAAAAAASJQQIQAAAAAAAAAAACRKiBAAAAAAAAAAAAASJUQIAAAAAAAAAAAAiRIiBAAAAAAAAAAAgEQJEQIAAAAAAAAAAECihAgBAAAAAAAAAAAgUUKEAAAAAAAAAAAAkCghQgAAAAAAAAAAAEiUECEAAAAAAAAAAAAkSogQAAAAAAAAAAAAEiVECAAAAAAAAAAAAIkSIgQAAAAAAAAAAIBECRECAAAAAAAAAABAooQIAQAAAAAAAAAAIFFChAAAAAAAAAAAAJAoIUIAAAAAAAAAAABIlBAhAAAAAAAAAAAAJEqIEAAAAAAAAAAAABIlRAgAAAAAAAAAAACJEiIEAAAAAAAAAACARAkRAgAAAAAAAAAAQKKECAEAAAAAAAAAACBRQoQAAAAAAAAAAACQKCFCAAAAAAAAAAAASJQQIQAAAAAAAAAAACRKiBAAAAAAAAAAAAASJUQIAAAAAAAAAAAAiRIiBAAAAAAAAAAAgEQJEQIAAAAAAAAAAECihAgBAAAAAAAAAAAgUUKEAAAAAAAAAAAAkCghQgAAAAAAAAAAAEiUECEAAAAAAAAAAAAkSogQAAAAAAAAAAAAEiVECAAAAAAAAAAAAIkSIgQAAAAAAAAAAIBECRECAAAAAAAAAABAooQIAQAAAAAAAAAAIFFChAAAAAAAAAAAAJAoIUIAAAAAAAAAAABIlBAhAAAAAAAAAAAAJEqIEAAAAAAAAAAAABIlRAgAAAAAAAAAAACJEiIEAAAAAAAAAACARAkRAgAAAAAAAAAAQKKECAEAAAAAAAAAACBRQoQAAAAAAAAAAACQqJIsy7JiNwIAAAAAAAAAAABoemYiBAAAAAAAAAAAgEQJEQIAAAAAAAAAAECihAgBAAAAAAAAAAAgUUKEAAAAAAAAAAAAkCghQgAAAAAAAAAAAEiUECEAAAAAAAAAAAAkSogQAAAAAAAAAAAAEiVECAAAAAAAAAAAAIkSIgQAAAAAAAAAAIBECRECAAAAAAAAAABAooQIAQAAAAAAAAAAIFFChAAAAAAAAAAAAJAoIUIAAAAAAAAAAABIlBAhAAAAAAAAAAAAJEqIEAAAAAAAAAAAABLVptgNAEjJBx98EFdddVVkWRbf+c53Yvvtty92kwAAAAAAAAAASJgQIUATGjt2bIwbNy4iIubPnx933nlnkVsEAAAAAAAApMKkJwBUpiTLsqzYjQBIwYsvvhh77713dOnSJbbaaqtYsGBBPPLII3HEEUcUu2kAAAAAAABAAn784x8XJj054YQTTHoCQEQIEQI0mUMOOSSmTZsWd999d2y//fYxcODA2HnnnWPevHnRrl27YjcPAAAAAAAAaMFMegJAVVoVuwEAKfjd734X06ZNi1NOOSW+/vWvx4ABA+K8886LV155Ja688spiNw8AAAAAAABo4b7//e/H2rVr48Ybb4zbbrstWrduHWeddVasWbOm2E0DoMjMRAjQyN59993YbbfdolWrVlFaWhpbbbVVRESsWbMm9ttvv1iwYEHMnz8/evbsWdyGAgAAAAAAAC3S7373uzj11FPjlFNOid///vcRETF69Oi4/PLL45JLLomf/OQnRW4hAMUkRAgAAAAAAAAA0EKZ9ASAmggRAgAAAAAAAAAAQKJaFbsBAAAAAAAAAAAAQHEIEQIAAAAAAAAAAECihAihmRs/fnyUlJRESUlJLFq0qNjNabHUOR2uNQAAAAAAAADABkKEJGvq1KmFIFFtf0aNGlXsZrMJWrZsWVx11VXxla98JXr27BkdO3aM9u3bR7du3WL//fePM888Mx566KFYu3ZtsZtaQXWvkc033zx22GGHGDx4cPzmN7+J1atXF7u51GDWrFnx85//PI488sjo3r17tG/fPrbccsvo1atXjBgxIp566qliNxEAAKBBGUQGAMCmrrb3tK+//nqcccYZsfPOO0eHDh0K2/z5z3+u0zo0bxdddFGUlJTEIYccUuymsJFcw/rRz4fG1abYDYAUjR8/PkaMGBEREa+99lr07NmzuA1qQimd+0cffRQXXnhh3HTTTZWG7JYvXx7Lly+PmTNnxg033BCf/exn4/zzz4+zzjor2rRp3m/PK1eujMWLF8fixYvjgQceiF/+8pdx//33t+jruSk7+OCDY/r06bnfr1mzJhYsWBALFiyI8ePHx2mnnRa33HJLtGvXrgitBACg2BYtWhQ77bRTvfeTZVkDtGbTs2zZspgwYUJMmzYt5s6dG++8806sWbMmOnfuHDvttFP07ds3jj322DjiiCOaXZ9v6tSpceihh1a6bLPNNovPfOYzsddee8XXvva1+MY3vhHt27dv4hZSW7NmzYoHH3wwnnrqqZg/f34sX7482rZtG9ttt10ceOCBcfrpp8fAgQOL3UwAgBapqvvq1q1bR6dOnaJz586xww47RN++fWPgwIFx7LHHNsj/x7/++uvRt2/fePvtt+u1Di3bptxnbSwtuSb6+S2Lvj5NZdN6p4NGMnLkyDjzzDNrXG+bbbZpgtZUNHz48Bg+fHiTH5f6ef311+OII46IV155JSIiOnXqFMcff3wceeSRsf3228cWW2wRy5YtixdeeCEmTZoUzz77bCxdujTOP//8Wj0Xm9qnXyPLli2L0tLSuPLKK2Px4sXx4osvxle+8pWYM2dOtG7duogtrVmKr6k333wzIiK22267OOGEE+Kggw6KHXfcMdatWxfPPPNMXHXVVbFkyZK47bbb4uOPP46JEycWucUAALDpaMkDyCIMItuUGEAGANA8rVu3LlasWBErVqyIRYsWxfTp0+Oaa66Jrl27xtlnnx0XXHBBvfoGl1xySbz99tvRpk2buPTSS+Pggw+OLbfcMiIievToUet1aJlaep91Y6ReE/38TYu+Pk1p03+HgwbQrVu36N27d7GbQQuxZMmSOOyww+LVV1+NiE9Ca9dcc0107tw5t+6Xv/zlGD16dEybNi3OPvvsaNOmTbP8w17Za+Swww6LESNGxJ577hmLFi2KefPmxZ/+9KcYMmRIkVpJVXbbbbe47LLL4utf/3ou5DlgwIA49dRT48ADD4xXXnklbr/99vje974XBx98cJFaCwBAsWy//fYxb968Kpf36dMnIiL69esXt956a1M1q1lraQPIIgwi25QZQAYA0Hx8+r76gw8+iBUrVsTcuXPj8ccfj8ceeyyWL18eP/3pT2PSpElx//33R9euXXP7qc097WOPPRYREV/96lfjvPPO2+h1aHlaYp+1vlKsiX7+pk1fn6YkRAjQgD788MP40pe+VAgQjhs3Ls4555watxs0aFA8/fTT8eCDDzZ2ExtUx44d43/+53/i29/+dkR80gkVImx+7r///mqXb7PNNnHVVVfFscceGxERd999txAhAECC2rZtW6sBdltssYWBeNEyB5BFGES2KTOADACg+ahqApP//u//jvPPPz/mz58f3/zmN2POnDkxc+bMOP744+OJJ57YqH7CkiVLIiKiV69e9VqHlqWl9lnrI9Wa6Odv2vT1aUqtit0A2NS9+eabccEFF8S+++4bnTt3jrZt28a2224bffr0iZNPPjnGjx8f7733XkRETJ06NUpKSmLEiBGF7XfaaacoKSmp8DN16tTC8vHjxxd+v2jRotzxL7roosLyiIj33nsvLrrooujTp09sueWW0a1bt/jyl78cTz/9dIXtli1bFv/zP/8Te+yxR2yxxRbxmc98Jo477riYM2dOtedbWloal1xySRx11FHRvXv3aN++fWy55Zaxyy67xLBhw+LZZ5+tdLuNOffypkyZEsOGDYvPf/7zsfnmm0enTp2iT58+8eMf/7iQvq/OihUr4oILLojddtstNttss+jWrVscfvjhcdddd9W4bV1cfPHF8fLLL0dExKhRo2oVICyzxRZbxAknnNCg7WkKZbORRES88cYbNa5f32v5zjvvxHnnnRe77rprbLbZZrHtttvGEUccEX/6058ioubXTHN7TTVUXerr0EMPLTwu6zwBAACVq2wA2a233lrpBw/llQ0gu+CCC5qimQ2qbBBZmbKZTGg+7r///jjxxBOrnDmibABZmbvvvrupmgYAwKd84QtfiBkzZsQ+++wTEREzZsyI66+/fqP2tWbNmoj4ZGBYfdah5Uixz1oTNcnTz9806OvTlIQIoR6mT58eu+++e/ziF7+IOXPmxHvvvRdr164tTAF8xx13xIgRI+LJJ59skva88cYbsd9++8XYsWOjtLQ0Pvzww1i+fHk89NBDcfDBBxcCc3Pnzo199903Lr300pg/f3589NFH8a9//Svuu+++OOCAA2LKlCmV7n/q1KnRp0+f+OlPfxqPPPJILFmyJNasWRMffvhhLFy4MG677bY44IAD4sILL2ywc1q1alWcfPLJcdhhh8Vtt90Wr732WqxcuTLef//9KC0tjXHjxkWvXr1i0qRJVe7jpZdeit69e8cvfvGLePnll2PVqlWxfPnyePzxx+PEE0+Mb33rWw3S1r/97W9x9dVXR8QnAcnLLrusQfbb3JUfdVNd57MhruW8efNijz32iCuvvDJeeeWVWLVqVSxbtiwee+yx+NrXvhZnnHFGg55bY7+mGqouDWH16tWFx819qnIAADYNnx6g8+6778bFF18c++yzT3Tp0iVKSkpi/PjxEfHJ6P+SkpLo2bNntfusaVBQeY05UCfFAWQRLWsQmQFkBpABABTbZpttFhMmTCjck44bNy4+/vjjCutUdU9b/vdlxo4dW2Hijp49e9a4TlVfC7qx96116Qc21jFXrVoVV155Zey7777RsWPH6NixY/Tv3z+uu+66WLt2bZX7KTNjxoz49re/Hbvuumt06tQp2rVrF927d4/BgwfH9ddfH//+97+r3b7Y9/wR6fZZq6MmlatrPz+iuH19k8VUTl+fBpNBoqZMmZJFRBYR2ZgxY+q8/apVq7Ltttsui4isY8eO2XnnnZc99NBD2fPPP58988wz2cSJE7Ozzjor23777bNJkyZlWZZlH3zwQTZv3rzskksuKRx78uTJ2bx58yr8fPDBB4Xj3HrrrYV1X3vttVw7xowZU1i+//77Z5tvvnl24YUXZtOmTcuee+657Oqrr846depUaOff//73bIcddsi23nrr7NJLL82eeuqp7C9/+Us2duzYrF27dllEZDvuuGO2evXq3LEeffTRbIsttshOPPHE7MYbb8ymTp2azZ49O3v44Yezq666KuvRo0ehLb/5zW8qbLsx575+/frsmGOOKax/7LHHZhMmTMhmzJiRPfPMM9m1116b7bjjjllEZO3atcuee+65XJvffffdbIcddijs46STTsoefPDBbNasWdnEiROzfv36ZRGR7bffftXWuTa++c1vFvYxfvz4jdpHc1Lb18jEiRML6/3whz+sdJ2GuJYrVqwovOYiIjv11FOzhx56KJs1a1Z2xx13ZAcccEDhdVDdtWxOr6mGqEtD+eMf/1hox3nnnddoxwEAYNNVdr84aNCgWq1f/t76lVdeyXr27Fn4d9nPrbfemmVZlg0bNiyLiKxHjx7V7rOm+/ksy7KVK1dmQ4cOzR2r/M8WW2yR3XfffbU/+XJeeumlwr3+TjvtlH300UcbtZ/mpLb9vzlz5hTWO+6446pcryGuwdy5c7Ntt922yu2/+93v1vh8qG55+efn66+/nvXq1avS47Ru3Tq78847syzLsr/+9a/Z9ttvX+l67du3z5544olGrUlDeOeddyr0QQEAaDgb+9njkUceWdhuxowZFZZVdU9b/vdV/ZT/3K6qn2HDhlU4Xn3vW+vSD2yMYy5dujTbe++9q9zPsccem61bt67S/Xz00UfZySefXGPNqrq2TXHPX3au1fXLW2Kftb6aU01qcw0bQkP387OsefT16/I5r74+1F2bAAozB9Zk1113Lcy0NmPGjEJqfOLEiTF48OAK6w4YMCBOPvnkuPrqq+Ojjz6KiE9GKfTu3TtmzZpVWK9Xr141zrRQWy+88EJMmzYt9t9//8Lv+vXrF7vssksMHjw43n///dh///0jy7KYOXNm7LzzzoX1+vfvH9tss018//vfj9dffz0eeOCBOP744yvsf++9947FixdHly5dcsc+6qij4qyzzorBgwfHo48+GmPHjo3TTjutMKPZxpz7r371q3jggQeibdu2cd9998XRRx9dYfmAAQPi1FNPjYMOOihefPHFGDVqVDz11FMV1rn44osLoyYuu+yyCrMk9u3bN4YMGRKDBw+ORx55pMp21Mb7779fmBq4S5cuceKJJ9Zrf5uKdevWxZVXXln495AhQypdryGu5dixYwuvuWuuuSZ++MMfFpaVXcuvf/3rce+99zbU6TX6a6oh6tIQ1q9fH1dccUXh36k8fwEAaDpDhgyJJUuWxA9+8IP4yle+EltttVUsWLAgevTo0aDHybIshgwZEg888EBERBx77LFx4oknxuc///lo1apVzJw5M6666qp4/fXXY8iQITFjxozo169fnY5x6aWXFr4KbMyYMbHZZps16Dk0Zy+99FLhcVX9+Ya4Bv/+97/j6KOPjrfeeisiIk499dQ45ZRTomvXrrFw4cK49tpr4+abb46//vWvDXJeJ5xwQixevDguvPDCOProo2PzzTePp556KsaMGRPvvfdenH766dGvX78YPHhwrFy5Mi699NIYNGhQtG3bNh5++OG49NJLY/Xq1TF8+PBYsGBBhRn7G6omDWXatGmFx7vvvnujHAMAgLo5/PDDC59TTZ8+Pb74xS/WuM1Xv/rVwj1j2UxiI0eOjDPPPLOwzlZbbRUrVqyocZ0yDX3fWpt+YEMf82tf+1rMnz8/zj777Dj22GNj6623jpdffjkuvvjieOmll2LSpElxyy235L7Zav369XHcccfFo48+GhERu+yyS5x55pnRr1+/2HzzzeOf//xnPP3003HnnXdWetzmdM+fcp+1KmpStdr08yP09fX1SUax0otQbOXT97X9KZ9m//3vf1/4/bvvvlunY9dm5oTarls+TX/++edXuZ/yo41uuOGGStf56KOPsg4dOmQRkf2///f/6nJKBS+88ELhOLNmzarz+ZRZv359tvPOO2cRkZ1zzjnVHvPBBx+sMKqpzOrVq7Otttoqi4hszz33zNavX1/p9m+88UbWtm3bWl+Tytx7772F7YcOHVrtun/7299yMzCW/bz//vt1PnZjqW6EyrJly7LHH388O/DAAwvrDBkypNL9NMS1XLVqVdalS5cs4pNZI6uydOnSwnO4qmvZXF5TDVGXhjJu3LjC/r/2ta81+P4BAGgZyu4ZN2YmwlatWmWTJ0+uct2Gmonw5ptvziIia9u2bfbQQw9Vuo9//etf2R577JFFRHbggQfW6lzKvPfee4V7/C5durSYGR1qM0PB2rVrs3322aew3vTp0ytdryGuwahRowrHueaaaypty3HHHVfl/9mUqe1MhO3bt8+effbZ3Pb3339/YZ2uXbtm22yzTbZw4cLcetdff31hvT/+8Y+NUpOGsG7duqx///7V/r8NAAAbb2NnInzssccK233rW9+qsKw2n6vV5pi1Wach7lvr0g9sjGO2bds2mzJlSm6dd955pzD72Z577plbfu211xb2cfzxx2erVq2qtC3r1q3LFi9e3CjnURs1zWLXUvus9dHcatKcZiKsbT8/y5pPX78un/Pq60PdtQpgo3zuc58rPL711luL2JINhg4dWuWyPffcMyIiSkpK4qSTTqp0nc022yx22WWXiIj4+9//XuPxVq9eHa+//nrMnz8/SktLo7S0NLIsKyyvzyiB+fPnx6uvvhoRVc9uV+bggw8uPH7mmWcKj59//vnCCKthw4ZFSUlJpdt37949jjzyyI1ua0TEX/7yl8LjAw88sMr1Vq9eHX369KnypzZ1L4axY8dGSUlJ4adbt27xpS99KWbMmBGbb755/OhHP4qJEydWum1DXMtZs2bFv//974iI+OY3v1nl9ttuu20cddRRtT2tGjXma6oh6tIQpk2bFhdccEFERHTr1i1uuOGGBt0/AABERAwfPrze/a6aZFkWv/jFLyIi4uyzz87N9F1mq622KsyoPmPGjFiwYEGtjzFlypRYtWpVREQcffTR1c5e8PLLLxf6yp/++eCDD2p9zGJbvnx5PPHEEzFo0KCYM2dORHzShxk4cGBu3Ya4BqtXr47x48dHRMR+++1XYRb6Mq1bt46bbropOnToUK9zKzNq1KgKM9CXOeaYYwqzpCxfvjwuvvjiCjPQlxkxYkShLdOnT6+wrCmel7V19dVXx8yZMyPikxla+vbt2+DHAACg7j7zmc8UHpd9rtXUGuO+taZ+YGMc8wc/+EEccsghud9vvfXWMWLEiIiImDdvXrz77ruFZevXry/sv3v37nHbbbdF+/btK91/q1atYvvtt2/089hYKfZZa6ImeXXp50fo60fo65MOIUKIT6YtzrKsxp/yU/gOHDgwPv/5z0fEJ3+A+vfvH5dffnnMmDGjMB1yU+vVq1eVy8q+gnibbbapMDV5Veu9//77lS7/8MMP4/LLL4+99tortthii+jRo0fssccehRDcPvvsU1j37bffrvtJ/Ef5rz0+4IADKgTYPv2z5ZZbFtZdunRp4fG8efMKj/fbb79qj9e/f/+NbmtEVPiD/4UvfKHK9UpLS+Pjjz+udFn79u2r3ba52nvvvePss88ufNX3pzXEtSz/deM13fg05DTQjfmaaoi61NeLL74Yxx9/fKxduzY6dOgQd911V3Tr1q3B9g8AAGW+8Y1vNPoxmmKgTksfQBaR5iAyA8gAACim8p8BVPX5XGNrjPvWmvqBTX3Mss+XsiyL1157rfD7F154IRYvXhwREd/5zncqXI/aaC73/BFp9FnrSk3q18+P0NeP0NcnHUKEsJHatm0bkyZNKnyn/HPPPRejR4+OgQMHRpcuXeLoo4+OiRMnxrp165qsTZtvvnmVy1q1alXjOuXXq6zdixYtij59+sTo0aNj7ty5NZ7bypUra2pylZYtW7ZR23300UeFx//6178Kj2sKRm277bYbdbwyZTc9ERVHjH1a3759c+HUshFLffr0iTZt2uS2ee655+LLX/5ydOnSJbbYYosYMGBA3HnnnfVqb12NHDky5s2bF/PmzYs5c+bEpEmTYtiwYdGqVat4+umn45BDDonly5dXum1DXMvyI++6du1a7XY1La+LxnxNNURd6uO1116LI488MlasWBGtW7eOO+64o8JNLAAANKSy/5xtTE0xUKexB5A1h/5fdVrqIDIDyAAAKKby95CdOnUqShsa4761pn5gYxxzt912q3LZ1ltvXXhcvuZlM7FFRBx00EHVtrmpzmNjbSqTnlRXo9r+lM1qV5NNpSbFUlM/P0JfP0Jfn3Tk0ypArX3hC1+IefPmxaRJk2LSpEnx5JNPxsKFC2PlypUxefLkmDx5cvzyl7+MBx98sEW8YZ966qnx2muvRUlJSYwYMSKGDh0au+++e3Tt2jXatWsXJSUlsX79+mjdunVERIWvNq6r8oGrSZMmVZgFsjpV1bmqrzJuKOXDf9XdZH3a8uXLY8mSJRERFWZxLDNlypQ46qijokOHDjF06NDo2LFj3HPPPXHSSSfFG2+8Eeecc079G18L3bp1i969exf+vffee8fgwYPj0EMPjeHDh8eiRYvi29/+dtx77725bRv6WrYUxazLm2++GYcffni8+eabUVJSEr/5zW/iuOOOq/d+AQCgKtX9h2xDaYqBOnUdQFZe9+7dY8mSJVUOIGsu/b+RI0fGmWeeGRERa9eujcWLF8fdd98dEyZMKAwimzlzZqUDuDbVQWQGkAEAUEzlv9mrfNCtKTXGfWtN/cDGOGZt7u0jKt63l6//5z73uTq3p9j3/OU1Zp814pOBb2PGjImnn346Pv744+jTp0/86Ec/ihNPPLFB2t8YGrMmm0o96tPPj9DXj9DXJx1ChFBPrVu3jq9+9avx1a9+NSIi/vnPf8bDDz8c119/fTz//PPx/PPPxxlnnBF/+tOfitvQevrb3/4WTz31VEREjB49Oi655JJK1ys/+199lL+J69KlS4UAW22V75y89dZb1Y42eOutt+q8//K22WabwuOlS5fWejTKCy+8UHi87777Vli2du3a+M53vhOtWrWKJ598Mvbee++IiPjZz34W/fv3j9GjR8eQIUOiR48e9Wp7fQwbNiwmTZoU99xzT9x3333xxBNPxGGHHVZhnYa+lsuXL6/2WlY1I2Jz0xB12Rhvv/12HHHEEYVpt//v//4vTjvttCY5NgAA6SobbNaYmmKgTmMNIGtO/T+DyBqWAWQAANSk/Ex4u+66a1Ha0Bj3rTX1A1tK/6E5nUdj9VkjGnbg20svvVTrdatS28BnS58Ipjbq08+PaF7P8eZCX5+WSogQGtjnPve5GDFiRHzzm9+MAQMGxOzZs+P++++PlStXxmabbRYRjT8rXmN48cUXC49POumkKtcrP3VvZWp77uVvxmbMmBEDBw6s1Xbl9enTp/D4ueeeq3YK8ueee67O+y+vb9++MWHChIiImD59ei5IV5XyIcJP34A+8cQT8eqrr8aIESMKHyBFRHTu3DlGjx4dw4cPj9/+9rfxs5/9rF5tr6/LLrss/vznP8e6deti9OjR8eyzz1ZY3hDXco899ig8fv755+PAAw+sct2anoPNRUPUpa7efffdOOqoo2L+/PkREXHFFVfE97///UY/LgAA1KRsZPf69eurXe/DDz+scllTDNRpjAFkEZtG/88gso1jABkAADV59NFHC4+b4rOCyhTjvrVY98qfVr6f989//rPar0SuTHM5j4jG67M29MC3uta4PlKdCKY2atPPj9DXr4y+Pi1Vq5pXATZG27ZtY9CgQRHxyY1E+amSO3ToUHi8evXqpm7aRlm7dm3hcXUf2tx4443V7qe2577vvvtG9+7dIyLi5ptvjlWrVtW2qQV9+/Yt3JBMmDChyq9XXrJkSTzyyCN13n95gwcPLnzodcstt8QHH3xQq+3KbkBbt24de+65Z4VlU6dOjYiII488MrfdUUcdFRER06ZN28gWN5xevXoVpuX+y1/+UqGzG9Ew17Jfv37RuXPniIj43e9+V+V6b731VkyePLnO+y+GhqhLXXz00UdxzDHHxOzZsyMi4ic/+Umcf/75jXpMAACorY4dO0ZExa8Zqswrr7xS5bJPD9RpDH379i08nj59eq23q24AWcSm0/+77LLLCrOJjB49Ore8Ia7BpweRVWdTGETWFM/LTzOADABg01FaWhqPP/54RETssMMO0a9fv6K0oxj3rcU4ZmXKB8SefPLJOm/fXM4jovH6rGUD30455ZRKB76tWbMmfvvb325UmxtbY9RkU67Hp9XUz4/Q16+Mvj4tlRAhbKTp06fHwoULq1y+Zs2awn/wb7nlltG1a9fCsvLTK7/66quN18gGtMsuuxQejx8/vtJ1brjhhiqnOS5T23Nv1apV4Ubl73//e5x22mnVhg7fe++9uO666yr8rn379jFixIiI+ORG78orr8xtVzZSZM2aNdW2uyY777xzDB06NCI+CSUOHTo03n///Wq3WbBgQeGmYrfddivMVFl+eUTF2pf57Gc/G1tuuWVhnU8rKSmJkpKSWk+dXF+jR48uzDL56a+6bohr2aFDh8Ioiueeey6uvfba3Hbr16+PM844o9HDeA2lIepSW2vWrInjjz++8Hz74Q9/WOVXkgMAQDHstNNOERHx/vvvx8svv1zpOmvWrIl77rmnyn00xUCdxhhAFlG//l9TMois7gwgAwCgKitXrozTTjutMAnGueeeW+GrV5tSU9+3FuuYldlrr71ihx12iIiIX/3qV7Xu55VpLucR0Xh91k1l4FtlUp4IpjZq6udH6OtXRl+flkqIECJi2bJlUVpaWuNP+dDb448/HrvuumsccsghceWVV8bkyZNj9uzZMWPGjLj11lvjoIMOKryJn3766RVu+vfZZ5/CjHw//elP49FHH41XXnklFi5cGAsXLoyVK1c2bQFqYZ999ilMw3vTTTfFSSedFPfff388//zzce+998YJJ5wQZ555ZrVfM1u2n9qe+/e+9704/vjjIyLirrvuij322COuvPLKmDZtWrzwwgvx5JNPxs033xynnHJKbLfddnHRRRfljvezn/2s8Af8/PPPj1NOOSUefvjhmD17dtxxxx3xxS9+MR566KEGGdl13XXXxX/9139FRMQDDzwQvXr1ip/85Cfx4IMPxuzZs2PWrFnx4IMPxhVXXBGHHnpo7LbbbvGPf/wjIqLS47/77rsREYUbqk/r1KlTYZ1i6927d3zlK1+JiE9GaT311FMVljfEtbzooovis5/9bEREjBo1Kk477bTC6+7OO++Mgw46KO69997o379/YZvm/tXhDVGX2jj55JMLs20edthhcfrpp1f7Xlfd7C4AANAYymbyj4i46qqrKl3nRz/6USxZsqTKfTTFQJ3GGEAWUb/+n0FkzZsBZAAAVGb+/PkxcODAmDNnTkR80icaOXJk0drTlPetxTxmVe348Y9/HBERixcvjtNOO63KyUfWr18fb775Zm775nAeEY3XZ91UBr5VprlNBFNbTdnXr66fH6GvXxl9fVqq4gxlgGbmhhtuiBtuuKHG9fbaa68KUxevX78+pk2bVu1IguOOOy4uv/zyCr/r2LFjnH322fG///u/MXv27NwohSlTpsQhhxxSp3NobCUlJTFhwoQ47LDDYsWKFXHnnXfGnXfeWWGdPn36xF133RXbbbddlfupy7mXlJTEH/7wh/jhD38YN954Y7z66qtx3nnnVbnvbt265X7XuXPnePjhh+Pwww+PpUuXxu233x633357hXWGDx8egwYNKsxauLG22mqrmDFjRnzjG9+Ixx57LJYuXRqXXXZZtdvsvvvuMWrUqBg+fHi9jt0c/OQnPynMRHnxxRdXGCXSENdy6623jocffjiOOOKIWL58eUyYMCEmTJhQYZ3hw4fHQQcdFDNnzoyIil+f3Rw1RF1q449//GPh8RNPPFHpKLLyevToEYsWLdqoYwEAwMbYZ5994oADDohnnnkmbrnlllizZk0MGzYsOnfuHAsWLIibb745nnjiifjiF78YTz/9dJX7+d73vhePPvpo/OlPf4q77rorZs+eHWeccUb0798/OnfuHO+991787W9/i6lTp8Z9990XHTp0iLPOOqtObb3uuuti5syZsXDhwsIAsm9961tx4IEHxmc/+9lYv359LFu2LObOnRuTJ0+OJ598MtavXx8RlQ8g29SUDSK79957C4PIBg4cWFjeENfgoosuirvuuiuWLl0ao0aNiueffz6+8Y1vRNeuXWPhwoVx7bXXxtNPPx39+/cv9P+a8yCypnheRlQ9gKwq7dq1i169em30eQEAULWyCUzKfPjhh7FixYqYO3duPP744/Hoo48WZiAcMGBA3H333dG2bdtiNTcimu6+tdjHrMz3v//9mDRpUqEtffr0iTPPPDP69esXm2++eSxdujSeffbZuP322+OUU07JTfrQXM4jonH6rJvSxCeVaeiabOr1+LSa+vkR+vqV0denRcogUVOmTMkiok4/e+21V2H7999/P7vnnnuykSNHZgMGDMh23HHHrEOHDlmHDh2ynj17ZieeeGJ2//33V3n89evXZ7fcckt20EEHZVtvvXXWunXrwnGmTJlSWO/WW28t/P61117L7WfMmDGF5dUZNmxYFhFZjx49ql1v0KBBWURkgwYNqnT5P/7xj+x73/te1qNHj6xt27bZ1ltvnfXv3z8bN25ctnLlyizLskJ7xowZU69zL2/u3LnZD37wg6xPnz5Z586ds9atW2edO3fO9t577+z000/P7r777mzVqlVVntc777yTnXfeedkuu+yStW/fPttmm22yQw89NJs4cWKWZTXXua4ef/zx7PTTT8922223rFOnTlmbNm2yrbbaKtt1112zIUOGZFdccUVWWlpa7T6GDBmSRUQ2a9asSpdvueWW2Q477FDpsrJzqel6V6f8a6Sqa/lpRxxx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PRQTJ06M6dOnx4IFC6JFixaxxRZbRK9eveKUU06J3r17N/QwAQCSsmLFili4cGEsXLgwZs2aFRMmTIhrr702OnToEGeeeWZccMEFa3SOcOmll8YHH3wQzZs3j8suuyz23XffWG+99SIionPnztWehqapKfcrV1fqNdHnXbvo81Kf1v5POKgFQ4YMiTPOOKPK6TbZZJN6GE1ZgwYNikGDBtX7elkz77zzTvTr1y9mzJgRERHrr79+HHXUUXHggQfGlltuGW3bto358+fHyy+/HKNHj45nn3025s2bF+eff3619sX69tX3yPz586O4uDiuuuqqmD17drzyyitx+OGHx5QpU2KdddZpwJFWLcX31Ny5cyMiYosttohjjz029tlnn/j6178eK1asiGeeeSauvvrqmDNnTvz973+PL774Im677bYGHjEAAKw9mnrzQXNh7aGxAADQeHy1r/Lpp5/GwoULY+rUqfHEE0/E448/HgsWLIhf//rXMXr06HjggQeiQ4cOueVUp6fx+OOPR0TEkUceGeedd95qT0PT09T6lbUhxZro867d9HmpT43/L5VQDzp27Bjdu3dv6GHQRMyZMyf69u0bb775ZkR8eTBz7bXXxgYbbJCb9pBDDomhQ4fG+PHj48wzz4zmzZs3yj/il/ce6du3bwwePDh23HHHmDVrVkybNi3uvffeOOaYYxpolFRk2223jcsvvzy++93v5g7+99prrzjppJOiV69eMWPGjLj99tvjRz/6Uey7774NNFoAABrKlltuGdOmTavw+R49ekRERM+ePWPEiBH1NaxGrSk2HzQX1l4aCwAAjUdFvcfvfOc7cf7558f06dPj+9//fkyZMiUmT54cRx11VIwdO3a1ekRz5syJiIhu3bqt0TQ0LU2xX7mmUq2JPu/aTZ+X+iRECFCLPvvss/j2t79dOPgcPnx4/PznP69yvj59+sTTTz8dDz30UF0PsVa1a9cufvWrX8Wpp54aEV9+k83BZePzwAMPVPr8JptsEldffXUcdthhERFx9913O7gEAEhQixYtqvUFu7Zt2/oiXjTd5oPmwtpLYwEAYO2x/fbbx6RJk6JXr14xZcqUmDRpUlx//fVxzjnn1HhZy5Yti4gvz+nWZBqajtT6ldWhJnn6vGsHfV7qU7OGHgCs7ebOnRsXXHBB7LrrrrHBBhtEixYtYtNNN40ePXrECSecECNHjoxFixZFRMS4ceOiqKgoBg8eXJi/a9euUVRUVOZn3LhxhedHjhxZ+P2sWbNy67/ooosKz0dELFq0KC666KLo0aNHrLfeetGxY8c45JBD4umnny4z3/z58+NXv/pV7LDDDtG2bdvYeOON44gjjogpU6ZU+nqLi4vj0ksvjYMOOig6deoULVu2jPXWWy+22WabGDhwYDz77LPlzrc6r720J598MgYOHBhbbbVVtGnTJtZff/3o0aNH/OIXvyh8074yCxcujAsuuCC23XbbaN26dXTs2DEOOOCAuOuuu6qctyYuueSSeP311yMi4uyzz67WwWeJtm3bxrHHHlur46kPJVcjiYh49913q5x+Tbflhx9+GOedd15885vfjNatW8emm24a/fr1i3vvvTciqn7PNLb3VG3VZU3tv//+hcclJ1AAAED5yms+jBgxotwAYWklzYcLLrigPoZZq0qaCyVKbodG4/HAAw/EcccdV+EVIksaCyXuvvvu+hoaAADlaN26dYwaNarQjxg+fHh88cUXZaapqKdR+vclLr744jI9ty5dulQ5TUVX7l7dnsVXeywff/xxXHLJJbHLLrvEhhtuGEVFRTFy5Mg6Xefnn38eV111Vey6667Rrl27aNeuXeyxxx7xxz/+MZYvX17hckpMmjQpTj311PjmN78Z66+/fqy77rrRqVOn6N+/f1x//fXx0UcfVTp/Q/d7ItLsV1ZFTcpX0z5vRMP2evV5y6fPS63JIFFPPvlkFhFZRGTDhg1brWU89dRT2frrr19YTkU/o0ePzq2zsp8nn3yysI4RI0YUfv/222/nxjBs2LDC8++8807WrVu3cpe5zjrrZHfeeWeWZVn2r3/9K9tyyy3Lna5ly5bZ2LFjq6xZZT8XXHDBas9b+rVnWZYtWbIkGzBgQKXztG3bNrv//vsr3E7Tp0/PtthiiwrnHzx4cJV1ro5XX301W3fddbOIyLp27ZotXrx4tZbTWFT3PTJlypTCdEcccUSF09XGtpw6dWq26aabVjj/D3/4wyq3ZWN6T9VWXWrDhx9+WFjfYYcdVqfrAgBg7VRyvNinT59qTV/62DrLsuyjjz7KfvOb32Q777xztsEGG2QRkY0YMSLLsiwbOHBgFhFZ586d206IUgAARbVJREFUK11mTc7dxo4dm5188slZ165ds9atW2ft2rXLunfvnp177rnZnDlzqvUaKnL++ecXxnH22Wev0bIag+qe/z333HOF6Q455JAql7um2+CDDz7IfvGLX2TdunXLWrVqlXXs2DE74IADsn/+859ZllW9P1T2/Ff3z48//jgbNmxY1r1796xt27ZZhw4dsu985zvZpEmTysz3/vvvZ7/85S+z7bffPmvTpk220UYbZYcffnj20ksvVfl6aqMma+rTTz+t0TYEAKD6Vrf3eOCBBxbm++rxZ0XHtKV/X9FP586dq5xm4MCBZda3pj2L0sfZM2bMyLp06ZKbv+Q8sC7WOW/evGznnXeucDmHHXZYtmLFinKXs3jx4uyEE06osmYVbdv66PeUvNbKzsubWr+yNjSmmlRnG9aG2u7zZlnj6PXq85ZPn5fa4nbGsJqWLl0aAwYMiEWLFkW7du1iyJAhsf/++0fHjh1j2bJl8fbbb8fTTz9dSMxHROy+++4xbdq0uO+++wrf3n/00Udjiy22KLPsrl27rtaYjj322Jg9e3ZceOGFcfDBB0ebNm1i4sSJMWzYsFi0aFGccsop0bNnz+jfv38sWbIkLrvssujTp0+0aNEiHnnkkbjsssti6dKlMWjQoJg5c2bu1krLly+Ptm3bxqGHHhp9+/aNbbfdNtZff/2YP39+vPLKK/H73/8+/v3vf8eVV14Z3bp1K3PVwdV57VmWxTHHHBMPPvhgREQcdthhcdxxx8VWW20VzZo1i8mTJ8fVV18d77zzThxzzDExadKk6NmzZ5nlLVq0KA466KBCwv/444+PgQMHRseOHWPGjBlxzTXXxIgRI6K4uHi1al7aZZddVrgc/LBhw6J169ZrvMy1wauvvlp43KVLl3KnqY1t+dFHH8XBBx8c77//fkREnHTSSfG9730vOnToEG+88UZcd911cdNNN8W//vWvWnttdf2eqo261Jbx48cXHm+33XZ1sg4AANI1c+bMOPDAA8v9lnht+/zzz2Pw4MFxxx135J4rLi6O4uLiuOGGG+L2228v3OqlJl577bX43e9+FxFfnsNefvnlazzmtUXpc5rKboNWG9tg2rRp0a9fv8I5YMlyH3/88Xj88cfjhz/8Yey9995r8GpWeffdd+OAAw6IGTNmFH732WefxcMPPxyPPfZY3H777XHsscfG1KlT45BDDok5c+YUplu8eHHcf//98eijj8bDDz9c5tv/pdX1flldS5cuLTyu6IqFAADUrwMOOCAee+yxiIiYMGFCfOtb36pyniOPPLLQLyi5ktiQIUPijDPOKEzTvn37WLhwYZXTlKjtnsUxxxwTc+bMiZ/+9Kdx+OGHR/v27WPmzJnRuXPnOlvn0UcfHdOnT48zzzwzDjvssNhoo43i9ddfj0suuSReffXVGD16dNx8881x+umnl5lv5cqVccQRR8SYMWMiImKbbbaJM844I3r27Blt2rSJ9957L55++um48847y11vY+r3pNqvrIyaVKw6fd6ItbPXq88Lq6Hh8ovQsEqn74cMGZJNmzatyp9ly5YV5n/iiScK85dcabA8X3zxRfbxxx+X+V1NrpxQkzR9y5Yts2effTY3zQMPPFCYpkOHDtkmm2ySvfHGG7nprr/++sJ0Jd/qL23BggXZwoULKxzr0qVLs379+hW+3bR8+fIav57SbrrppiwishYtWmQPP/xwudP85z//yXbYYYcsIrJevXrlnj/33HML67v88stzzy9btqzMN7yqM67yLFq0KGvVqlUWEdmGG27YJL7VU51vqCxfvjzbZZddCtNNmDCh3OlqY1ueffbZhfVce+215Y7liCOOqHJbNqb3VG3UpTasWLEi22OPPQpjfeGFF+pkPQAArN1KjhdX50qEO+64Y9aiRYvspz/9aTZmzJjshRdeyG6//fbs6aefzrKs9q5EuHLlyuzQQw8t8+3rUaNGZZMmTcqeeeaZ7Lrrrsu+/vWvZxGRrbvuutnzzz9fwypk2fe///3C8keOHFnj+Ruj6l6h4LbbbitMd9ZZZ5U7TW1sg4ULF5a5o8BJJ52UPfzww9kLL7yQ3XHHHdnee++dRUS25557rvb5X+n9c88998zatGmTXXjhhdn48eOz559/Pvvd735XuPtEu3btsrfeeiv72te+lm200UbZZZddlk2cODF77rnnsosvvrhwRYuvf/3r2dKlS+ukJrXln//8Z2Ec5513Xp2tBwAgRat7JcLHH3+8MN8PfvCDMs9Vp69WnXVWZ5ra6FmUPs5u1qxZ9uijj1a4vrpYZ4sWLXJ3PcuyL6/SVXL1sx133DH3/HXXXVdYxlFHHZV9/vnn5Y5lxYoV2ezZs+vkdVRHVVexa4r9yjXV2GrSmK5EWN0+b5Y1nl6vPm+ePi+1SYiQZFX39roV/Sf1v//7v4XffzUkWJW6ChGef/75FS6n9CXLb7jhhnKnWbx4ceEg6pxzzqnJSyp4+eWXK/0PqrqvfeXKldnWW2+dRUT285//vNJ1PvTQQ4Vlzpgxo/D7pUuXZu3bty+cEKxcubLc+d99992sRYsW1d4m5bnvvvsK8w8YMKDSaV977bUKg6qffPJJjdddVyo7uJw/f372xBNPZL169SpMc8wxx5S7nNrYlp9//nm24YYbZhGR7b777hXOP2/evMI+vDpNpCyrv/dUbdSltgwfPryw/KOPPrrWlw8AQNNQcsy4OiHCqppHtRUirOs/4Da25kNtSfFLZBoLGgsAALVtdUOEpW8netRRR5V5rr5ChLXVsyh9nP3VQGR9rPNnP/tZhcu44IILsojIioqKso8++qjw+xUrVmSdOnXKIiLr1KlTjXt19dnvqSqA1hT7lWuqsdWkMYQIa9LnzbLG1evV583T56U2NQtgtWy++eaFxyNGjGjAkawyYMCACp/bcccdIyKiqKgojj/++HKnad26dWyzzTYREfHWW29Vub6lS5fGO++8E9OnTy/ceifLssLza3Kp4enTp8ebb74ZEV9e7rwy++67b+HxM888U3j84osvFi7TPnDgwCgqKip3/k6dOsWBBx642mONiHjuuecKj3v16lXhdEuXLo0ePXpU+FOdujeEiy++OIqKigo/HTt2jG9/+9sxadKkaNOmTfzsZz+L2267rdx5a2NbvvDCC/HRRx9FRMT3v//9CuffdNNN46CDDqruy6pSXb6naqMutWH8+PFxwQUXREREx44d44YbbqjV5QMAQETEoEGD1vi8qypZlsVvf/vbiIg488wz4+CDDy53uvbt28dVV10VERGTJk2KmTNnVnsdTz75ZHz++ecREXHwwQdXeguk119/vXCu/NWfTz/9tNrrbGgLFiyIsWPHRp8+fWLKlCkR8eU5TO/evXPT1sY2WLp0aYwcOTIiInbfffc466yzcvOvs846ceONN0arVq3W6LWVOPvss2PPPffM/f7QQw8t3GptwYIFcckll8TWW2+dm27w4MGFsUyYMKHMc/WxX1bX7373u5g8eXJEfHmbt912263W1wEAQM2tt956hceffPJJg4yhLnoWJ554YqNaZ8nxb5Zl8fbbbxd+//LLL8fs2bMjIuK0004rsz2qo7H0eyKafr9ydajJmvV5I9beXq8+L9ScECFExLBhwyL78sqclf506dKlME/v3r1jq622iogv/9i8xx57xBVXXBGTJk2KZcuWNcjr6NatW4XPbbjhhhERsckmm0T79u2rnK6ik5TPPvssrrjiithpp52ibdu20blz59hhhx0KB1C77LJLYdoPPvig5i/iv1544YXC47333rvMgc1Xf0ofzM+bN6/weNq0aYXHu+++e6Xr22OPPVZ7rBFR5o/722+/fYXTFRcXxxdffFHucy1btqx03sZq5513jjPPPDNatGhR7vO1sS2Li4sLj6tqcvTs2XN1X0pOXb6naqMua+qVV16Jo446KpYvXx6tWrWKu+66Kzp27FhrywcAgBJVNY9qQ338ATeF5kOKXyLTWAAAoCGV7h+sv/76DTKGuuhZlBxL1+c6t9122wqf22ijjQqPS9e85MtSERH77LNPpWOur9exutaWfmVlNaruT8mXz6qyttSkoVTV541Ye3u9+rxQc0KEsJpatGgRo0ePju222y4iIp5//vkYOnRo9O7dOzbccMM4+OCD47bbbosVK1bU25jatGlT4XPNmjWrcprS05U37lmzZkWPHj1i6NChMXXq1Cpf25IlS6oacoXmz5+/WvMtXry48Pg///lP4XFV/2Fuuummq7W+EiUNjoiIjTfeuMLpdtttt1w4dcstt4yIiB49ekTz5s3LTH/rrbfG6aefHj179oyWLVvW6KC4Ng0ZMiSmTZsW06ZNiylTpsTo0aNj4MCB0axZs3j66adjv/32iwULFpQ7b21sy5IrSkZEdOjQodL5qnq+JuryPVUbdVkTb7/9dhx44IGxcOHCWGeddeKOO+4o07ACAIDaVFXzqDbUxx9w67L50FjO/yrTVL9EprEAAEBDKn1RjtJBt/pUFz2Lyo6f62qd1enrRJTt2ZSuf+k70VVXQ/d7SqurfmXE2nHOWp6m3sOtjjXp80asvb1efV6oufynP1Bt22+/fUybNi1Gjx4do0ePjqeeeireeOONWLJkSTz66KPx6KOPxjXXXBMPPfRQk/jj7EknnRRvv/12FBUVxeDBg2PAgAGx3XbbRYcOHWLdddeNoqKiWLlyZayzzjoREWVubVxTpf8jHj16dJmrQFamojpXdCvj2lL6wLGyb2p81YIFC2LOnDkREWWu4ljiV7/6Vfz73/+OTTbZJDbffPP497//veaDXQ0dO3aM7t27F/698847R//+/WP//fePQYMGxaxZs+LUU0+N++67LzdvbW/LpqIh6zJ37tw44IADYu7cuVFUVBR/+9vf4ogjjljj5QIAQEWqah7Vhvr4A25Nmw+lderUKebMmVNhQ6axnP8NGTIkzjjjjIiIWL58ecyePTvuvvvuGDVqVKG5MHny5HL/qK+xoLEAAEDNlb4S3je/+c0GGUNd9CxK+oX1uc6G0JheR131KyNq95z11VdfXe15S1Q38NnUe7jVsSZ93ojGtY83Fvq8NFVChLCG1llnnTjyyCPjyCOPjIiI9957Lx555JG4/vrr48UXX4wXX3wxTj/99Lj33nsbdqBr6LXXXouJEydGRMTQoUPj0ksvLXe60lf/WxOlmzEbbrhhmQOb6irdpHr//fcrvbLA+++/X+Pll7bJJpsUHs+bN6/al7R++eWXC4933XXX3PN/+ctfYptttonOnTvHlVdeGRdeeOEajbO2DRw4MEaPHh333HNP3H///TF27Njo27dvmWlqe1suWLCg0m1Z2TdlGpPaqMvq+OCDD6Jfv36FW2z94Q9/iJNPPrle1g0AQLqqah7Vhvr4A25dNmQay/mfL5HVLo0FAACqMmbMmMLj3r17N8gYGqJn0VB9kq8q3eN77733Kr0lcnkay+uIqLt+ZUTtnrPWtMZrItUebnVUp88boddbHn1emiq3M4Zatvnmm8fgwYPjmWeeKRxQPPDAA2Vu7VvXV8WrC6+88krh8fHHH1/hdKVv01Oe6r720k2VSZMmVWuer+rRo0fh8fPPP1/ptFU9X5XSt1iaMGFCtecrfQBaXiPpgAMOiM6dO6/R2Ora5ZdfXmgIDh06NPd8bWzLHXbYofD4xRdfrHTaqvbBxqI26lJTH3/8cRx00EExffr0iIi48sor48c//nG9rBsAACpTchW3lStXVjrdZ599VuFz5f0Btzo/NQlrfbX5UF3Vacg09vO/gQMHxne/+92IiEJz4atqYxt8tbFQmbW1sVDb+2V5NBYAANYOxcXF8cQTT0RExNe+9rXo2bNng4yjIXoWDbHO8pQ+R3vqqadqPH9jeR0RddevjGj856wVSbmHWx1V9Xkj9HrLo89LUyVECHWkRYsW0adPn4j48vY/pW951KpVq8LjpUuX1vfQVsvy5csLjytr2vz5z3+udDnVfe277rprdOrUKSIibrrppvj888+rO9SC3XbbrdB8GDVqVIW3V54zZ0489thjNV5+af379y80vW6++eb49NNPqzVfyQHoOuusEzvuuOMajaGhdOvWLY477riIiHjuuefKfGMuona2Zc+ePWODDTaIiIhbb721wunef//9ePTRR2u8/IZQG3WpicWLF8ehhx4aL730UkRE/PKXv4zzzz+/TtcJAADV1a5du4goe7vg8syYMaPC5+rjD7h12ZBZG/gSWc1pLAAAUJElS5bEySefXOhfnXvuuWWufl6f6rtn0VDrLM9OO+0UX/va1yLiy6vLVbfHV6KxvI6ItPuVFVGTylXV543Q6y2PPi9NlRAhrKYJEybEG2+8UeHzy5Yti/Hjx0dExHrrrRcdOnQoPLf55psXHr/55pt1N8hatM022xQejxw5stxpbrjhhnJvZ1RadV97s2bNCg2Jt956K04++eRKQ4eLFi2KP/7xj2V+17Jlyxg8eHBEfHmgd9VVV+XmW758eZx22mmxbNmySsddla233joGDBgQEV+GEgcMGBCffPJJpfPMnDmz0EDYdttto3Xr1ms0htKKioqiqKio2rdJWlNDhw4tXGXyq7e6ro1t2apVq8IVE55//vm47rrrcvOtXLkyTj/99AY9OauJ2qhLdS1btiyOOuqowv521llnVXhLcgAAaAhdu3aNiIhPPvkkXn/99XKnWbZsWdxzzz0VLqM+/oCbevPBl8hqTmMBAIDyTJ8+PXr37h1TpkyJiIg+ffrEkCFDGmw89dmzaMh1VjSOX/ziFxERMXv27Dj55JMr7BuuXLky5s6dm5u/MbyOiMbXr2wM1taa1Gevt7I+b4Reb3n0eWmqGuarDNDIzJ8/P4qLi6ucrnXr1rH11ltHRMQTTzwRl1xySeyzzz5x6KGHxo477hgdOnSIJUuWxIwZM+LPf/5z4Q+2p5xySplvDu2yyy7RqlWr+Pzzz+PXv/51tGjRIjp37lxoRGy55ZaN7gBtl112ie7du0dxcXHceOONsXDhwjjppJNi8803j9mzZ8ett94ad999d/Tq1avSb9bX5LX/6Ec/ijFjxsS9994bd911V7z00ktx+umnxx577BEbbLBBLFq0KF577bUYN25c3H///dGqVav4yU9+UmZ9/+///b+48847Y/bs2XH++efHyy+/HCeffHJ07NgxZsyYEddcc008//zz0bNnzzW+gsEf//jHmDx5crzxxhvx4IMPRrdu3eIHP/hB9OrVKzbbbLNYuXJlzJ8/P6ZOnRqPPvpoPPXUU4VbdTXU5elrS/fu3ePwww+P++67L5566qmYOHFi9O7du/B8bWzLiy66KO66666YN29enH322fHiiy/GiSeeGB06dIg33ngjrrvuunj66adjjz32iMmTJ0dE4791eG3UpTpOOOGEwtU2+/btG6ecckqln3nrrrtudOvWbbVfFwAA1FTJlfwjIq6++uq46aabctP87Gc/izlz5lS4jJI/4J5xxhmFP+COGjUqWrZsWe70ixYtir///e81OsYuaT7cdttthebD7bffXriSYnnquvlQct7TuXPnmDVrVq0uuzxDhw6NO+64I7Isi0svvTT69etXeK42tkFJY+EPf/hDobFw1llnlZlvbWws1OV+WUJjAQCg8fhq7/Gzzz6LhQsXxtSpU+OJJ56IMWPGFK5AuNdee8Xdd98dLVq0aKjhRkT99Swaep3l+fGPfxyjR48ujKVHjx5xxhlnRM+ePaNNmzYxb968ePbZZ+P222+P733ve3HRRRc1ytcRkXa/siJqUrmq+rwRer3l0eelScogUU8++WQWETX62WmnnQrzDxs2rFrzHHHEEdnixYtz6z/vvPMqnOfJJ58sTDdixIjC799+++3cckqPozIDBw7MIiLr3LlzpdP16dMni4isT58+ueemTJmStW/fvsJx9+jRI5s7d27h38OGDSt3HdV97VmWZcuWLcuGDBmSFRUVVVnrrl27lru+4uLibLPNNqtwvkGDBlVZ5+p6//33swMOOKDa+9R2222X3XjjjdnSpUurXPYVV1yRRUQ2YsSIKqctWX5V27sypd8jFW3L0iZPnlyY/sADD8w9Xxvb8uWXX846dOhQ6bb861//Wvj3vHnzcstoTO+p2qpLVWr6Wbcm+w0AAE1XyfFiRce2X1XdY+sSe++9d2H6gQMHZmPHjs1efPHF7I477sj69u2bRUT2rW99q9Lj+ZUrV2ZHHXVUYZqtt946+5//+Z9s3Lhx2ZQpU7Lx48dnN954Y3bCCSdkbdu2zTbeeOMaVOBL//nPf7JvfOMbhXVsttlm2dChQ7MHH3wwe/HFF7Pnn38+e/DBB7Mrrrgi22+//bJmzZqVeV3V0djP/4444ojC9BMmTCjzXG1sgw8//LDMefxJJ52UPfLII9mLL76Y/eMf/yjsB3vssUdhmlmzZuWWU9n5X32e+9XHfpllWXb00UcX1tG3b99s6tSp2bRp0yr8ef3111drPQAAlK+mvccOHTpkl112WfbFF19UuMzq9K+qcyxf3eP9Ne1Z1PQ8sD7XWXr7fLUfmWVZ9tlnn2XHHHNMlWOoqIb10e8pea1VnZfXZb8yy2p2ztpYNJYebnW34Zqe69d2nzfLGkevV59Xn5e65UqEsJrOPffc2HHHHePxxx+PKVOmxNy5c2P+/PkREbHZZpvFHnvsESeffHIceuih5c5/5ZVXxjbbbBN///vf45VXXomPP/44VqxYUZ8vocZ23nnnePnll+OKK66Ihx9+OObOnRvt2rWLb3zjG3HcccfFj3/842jVqlWVy6nJa2/RokX86U9/iiFDhsTNN98c48aNi3feeSc+/fTTWG+99aJr166x2267xXe+853o379/ucvYYYcd4pVXXonf/va3ce+998Y777wT7dq1ix49esRpp50WJ5xwQoW3aK6pjh07xpgxY2Ls2LFx2223xaRJk2Lu3LmxePHiaNeuXXTs2DF69OgRPXv2jP79+8cOO+xQK+ttDHbffffo169fjBkzJh577LF4/vnnY/fddy88Xxvbcqeddorp06fHlVdeGffff3+52/Laa68tTF9yC6zGrDbqAgAATcHf/va36NOnT8yfPz9uueWWuOWWW8o8f+6558YOO+wQTz/9dIXLKCoqin/84x9x1llnxZ///Od4880347zzzqtw+o4dO9Z4nO3bt49JkybFiSeeGI8//njMmzcvLr/88krn2W677eLss8+OQYMG1Xh9jdEvf/nLuO+++yIi4pJLLilzW+Ha2AYbbbRRPPLII9GvX79YsGBBjBo1KkaNGlVmmkGDBsU+++xTuDpBdf4e0VDqY7+MiPjnP/9ZeDx27Ngqb51dX1evBABIXbNmzaJdu3axwQYbROfOnWO33XaLffbZJ/r37x/rrrtuQw+vjIboWTSWPkmbNm3irrvuiieffDJGjBgREydOjHnz5sWKFSti0003jZ133jn69+8fJ5xwQqN+HRFp9ysroiaVq6rPG6HXW57G9L6H2lCUZf+9TjIAjdqVV14ZF154YYwYMaLJNJ7qwqmnnhp//etfo1OnTvHuu+829HAAAKDJKLmFTJ8+fWLcuHFVTn/R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",
      "text/plain": [
       "<Figure size 3000x3000 with 12 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt_fig(2,g_list,adj_mat, node)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 95,
   "metadata": {},
   "outputs": [],
   "source": [
    "import networkx as nx\n",
    "def define_big_mat(N,regime, L,g_list,tr_lab):\n",
    "            if tr_lab ==False:\n",
    "                        all_estimated_g = np.zeros((N*regime,N*regime))\n",
    "                        all_estimated_g_lag = np.zeros((N*regime,N*regime))\n",
    "                        for i in range(regime):\n",
    "                                    all_estimated_g[i*N:(i+1)*N,i*N:(i+1)*N] = L[i][0]\n",
    "\n",
    "                             \n",
    "                             \n",
    "                                    all_estimated_g_lag[i*N:(i+1)*N,i*N:(i+1)*N] = L[i][1]\n",
    "                        all_estimated_g[all_estimated_g<0.4] = 0\n",
    "                        all_estimated_g[all_estimated_g>0.4] = 1\n",
    "\n",
    "                        all_estimated_g_lag[all_estimated_g_lag<0.4] = 0\n",
    "                        all_estimated_g_lag[all_estimated_g_lag>0.4] = 1\n",
    "                        return all_estimated_g,all_estimated_g_lag\n",
    "            else:\n",
    "                        g_3_regime = np.zeros((N*regime,N*regime))\n",
    "                        g_3_regime_lag = np.zeros((N*regime,N*regime))\n",
    "                        for i in range(regime):\n",
    "                                    g_3_regime[(i)*N:(i+1)*N,(i)*N:(i+1)*N] = nx.to_numpy_array(g_list[i])[N:2*N,N:2*N]\n",
    "                                    g_3_regime_lag[(i)*N:(i+1)*N,(i)*N:(i+1)*N] = nx.to_numpy_array(g_list[i])[:N,N:2*N]\n",
    "                                    #g_3_regime[(i)*N:(i+1)*N,(i)*N:(i+1)*N] = g_list[i][N:2*N,N:2*N]\n",
    "                                    #g_3_regime_lag[(i)*N:(i+1)*N,(i)*N:(i+1)*N] = g_list[i][:N,N:2*N]\n",
    "                        return g_3_regime,g_3_regime_lag"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 96,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "all_estimated_g,all_estimated_g_lag = define_big_mat(node,n_reg, adj_mat,g_list,False)\n",
    "g_3_regime,g_3_regime_lag = define_big_mat(node,n_reg, adj_mat, g_list,True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 97,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(0.0, 1.0)"
      ]
     },
     "execution_count": 97,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "shd(g_3_regime,all_estimated_g), classification_metrics(g_3_regime,all_estimated_g.astype(int))['f1']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 98,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(2.0, 0.9787234042553191)"
      ]
     },
     "execution_count": 98,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "shd(g_3_regime_lag,all_estimated_g_lag), classification_metrics(g_3_regime_lag,all_estimated_g_lag.astype(int))['f1']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 99,
   "metadata": {},
   "outputs": [],
   "source": [
    "def normalized_hamming_distance(prediction, target):\n",
    "  '''\n",
    "  prediction and target are edge lists\n",
    "  calculate the normalized hamming distance\n",
    "\n",
    "  For a graph with m nodes, the distance is given by ∑m i,j=1 1 m2 1Gij 6=G′ ij , \n",
    "  the number of edges that are present in one graph but not the other, \n",
    "  divided by the total number of all possible edges.\n",
    "  '''\n",
    "  prediction = set(prediction)\n",
    "  target = set(target)\n",
    "  total_nodes = set()\n",
    "  for i,j in target:\n",
    "    total_nodes.add(i)\n",
    "    total_nodes.add(j)\n",
    "  no_overlap = len(prediction.union(target)) - len(prediction.intersection(target))\n",
    "  nhd = no_overlap / (len(total_nodes) ** 2)\n",
    "  reference_nhd = (len(prediction) + len(target))/ (len(total_nodes) ** 2)\n",
    "  return nhd, reference_nhd, nhd / reference_nhd"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 100,
   "metadata": {},
   "outputs": [],
   "source": [
    "def adj_mat_to_edge_list(adj_mat):\n",
    "    n = adj_mat.shape[0]\n",
    "    edge_list = []\n",
    "    for i in range(n):\n",
    "        for j in range(n):\n",
    "            if adj_mat[i][j] == 1:\n",
    "                edge_list.append((i, j))\n",
    "    return edge_list"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 101,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(0.0, 0.14, 0.0)"
      ]
     },
     "execution_count": 101,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "normalized_hamming_distance(adj_mat_to_edge_list(all_estimated_g), adj_mat_to_edge_list(g_3_regime))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 102,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(0.005, 0.235, 0.021276595744680854)"
      ]
     },
     "execution_count": 102,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "normalized_hamming_distance(adj_mat_to_edge_list(all_estimated_g_lag), adj_mat_to_edge_list(g_3_regime_lag))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Fantom Regime Accuracy:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 103,
   "metadata": {},
   "outputs": [],
   "source": [
    "list_dur  = np.array([0,2500,5500,6500]).astype(int)\n",
    "true_label = np.zeros((list_dur[n_reg],n_reg))\n",
    "for i in range(n_reg):\n",
    "            true_label[list_dur[i]:list_dur[i+1],i] = np.ones(list_dur[i+1] - list_dur[i])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 104,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(0.9852727272727273, 0.9842)"
      ]
     },
     "execution_count": 104,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "accuracy_score(true_label,gamma_hat ),roc_auc_score(true_label,gamma_hat )"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# CASTOR evaluation (Baseline):"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 159,
   "metadata": {},
   "outputs": [],
   "source": [
    "from CASTOR import CASTOR_1, define_big_mat_CASTOR"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 160,
   "metadata": {},
   "outputs": [],
   "source": [
    "n_nodes = 10\n",
    "lag = False\n",
    "if lag == True:\n",
    "            rearange_intra = [str(i)+\"_lag0\" for i in range(n_nodes)]\n",
    "            rearange_inter1 = [str(i)+\"_lag1\" for i in range(n_nodes)]\n",
    "            rearange_inter2 = [str(i)+\"_lag2\" for i in range(n_nodes)]\n",
    "            rearange_inter = rearange_inter1 + rearange_inter2\n",
    "else:\n",
    "            rearange_intra = [str(i)+\"_lag0\" for i in range(n_nodes)]\n",
    "            rearange_inter = [str(i)+\"_lag1\" for i in range(n_nodes)]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 161,
   "metadata": {},
   "outputs": [
    {
     "ename": "KeyboardInterrupt",
     "evalue": "",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m                         Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[161], line 4\u001b[0m\n\u001b[1;32m      1\u001b[0m X \u001b[38;5;241m=\u001b[39m df_total[rearange_intra\u001b[38;5;241m+\u001b[39mrearange_inter]\u001b[38;5;241m.\u001b[39mto_numpy()\n\u001b[1;32m      3\u001b[0m \u001b[38;5;66;03m#X = (X - X.mean())/X.std()\u001b[39;00m\n\u001b[0;32m----> 4\u001b[0m gamma_hat, model_n \u001b[38;5;241m=\u001b[39m \u001b[43mCASTOR_1\u001b[49m\u001b[43m(\u001b[49m\u001b[43mX\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m4\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m2\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m4000\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43mtorch\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mdevice\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[38;5;124;43mcuda:1\u001b[39;49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[43m)\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m1.5\u001b[39;49m\u001b[43m,\u001b[49m\u001b[38;5;241;43m2500\u001b[39;49m\u001b[43m)\u001b[49m\n",
      "File \u001b[0;32m~/causal_discovery/cagam/rhino_cnf/CASTOR.py:80\u001b[0m, in \u001b[0;36mCASTOR_1\u001b[0;34m(X, max_it, lags, window, device, thresh, window_thresh)\u001b[0m\n\u001b[1;32m     78\u001b[0m                         \u001b[38;5;28;01melse\u001b[39;00m:\n\u001b[1;32m     79\u001b[0m                                     p[c\u001b[38;5;241m*\u001b[39mwindow:(c\u001b[38;5;241m+\u001b[39m\u001b[38;5;241m1\u001b[39m)\u001b[38;5;241m*\u001b[39mwindow,c] \u001b[38;5;241m=\u001b[39m np\u001b[38;5;241m.\u001b[39mones(window)\n\u001b[0;32m---> 80\u001b[0m                                     \u001b[43mmodel_n\u001b[49m\u001b[43m[\u001b[49m\u001b[43mc\u001b[49m\u001b[43m]\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mlearn\u001b[49m\u001b[43m(\u001b[49m\u001b[43mTensor\u001b[49m\u001b[43m(\u001b[49m\u001b[43mX\u001b[49m\u001b[43m[\u001b[49m\u001b[43mc\u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43mwindow\u001b[49m\u001b[43m:\u001b[49m\u001b[43m(\u001b[49m\u001b[43mc\u001b[49m\u001b[38;5;241;43m+\u001b[39;49m\u001b[38;5;241;43m1\u001b[39;49m\u001b[43m)\u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43mwindow\u001b[49m\u001b[43m,\u001b[49m\u001b[43m:\u001b[49m\u001b[43m]\u001b[49m\u001b[43m)\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m     82\u001b[0m \u001b[38;5;28;01melse\u001b[39;00m:\n\u001b[1;32m     83\u001b[0m             \u001b[38;5;28;01mfor\u001b[39;00m c \u001b[38;5;129;01min\u001b[39;00m \u001b[38;5;28mrange\u001b[39m(N_regime):\n",
      "File \u001b[0;32m~/causal_discovery/cagam/rhino_cnf/nnlinear_utils.py:489\u001b[0m, in \u001b[0;36mNotearsNonlinear_lag.learn\u001b[0;34m(self, data, columns, **kwargs)\u001b[0m\n\u001b[1;32m    487\u001b[0m model \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mget_model(input_dim)\n\u001b[1;32m    488\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m model:\n\u001b[0;32m--> 489\u001b[0m     W_est,A, modell \u001b[38;5;241m=\u001b[39m \u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mnotears_nonlinear\u001b[49m\u001b[43m(\u001b[49m\u001b[43mmodel\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mX\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    490\u001b[0m     \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mW_no_thres \u001b[38;5;241m=\u001b[39m W_est\n\u001b[1;32m    491\u001b[0m     \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mA_no_thres \u001b[38;5;241m=\u001b[39m A\n",
      "File \u001b[0;32m~/causal_discovery/cagam/rhino_cnf/nnlinear_utils.py:570\u001b[0m, in \u001b[0;36mNotearsNonlinear_lag.notears_nonlinear\u001b[0;34m(self, model, X)\u001b[0m\n\u001b[1;32m    568\u001b[0m dim \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mint\u001b[39m(X\u001b[38;5;241m.\u001b[39mshape[\u001b[38;5;241m1\u001b[39m]\u001b[38;5;241m/\u001b[39m\u001b[38;5;241m/\u001b[39m\u001b[38;5;241m2\u001b[39m)\n\u001b[1;32m    569\u001b[0m \u001b[38;5;28;01mfor\u001b[39;00m _ \u001b[38;5;129;01min\u001b[39;00m \u001b[38;5;28mrange\u001b[39m(\u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mmax_iter):\n\u001b[0;32m--> 570\u001b[0m     \u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mdual_ascent_step\u001b[49m\u001b[43m(\u001b[49m\u001b[43mmodel\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mX\u001b[49m\u001b[43m[\u001b[49m\u001b[43m:\u001b[49m\u001b[43m,\u001b[49m\u001b[43m:\u001b[49m\u001b[43mdim\u001b[49m\u001b[43m]\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mX\u001b[49m\u001b[43m[\u001b[49m\u001b[43m:\u001b[49m\u001b[43m,\u001b[49m\u001b[43mdim\u001b[49m\u001b[43m:\u001b[49m\u001b[38;5;241;43m2\u001b[39;49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43mdim\u001b[49m\u001b[43m]\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    572\u001b[0m     logging\u001b[38;5;241m.\u001b[39mdebug(\u001b[38;5;124m'\u001b[39m\u001b[38;5;124m[iter \u001b[39m\u001b[38;5;132;01m{}\u001b[39;00m\u001b[38;5;124m] h=\u001b[39m\u001b[38;5;132;01m{:.3e}\u001b[39;00m\u001b[38;5;124m, rho=\u001b[39m\u001b[38;5;132;01m{:.1e}\u001b[39;00m\u001b[38;5;124m'\u001b[39m\u001b[38;5;241m.\u001b[39mformat(_, \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mh, \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mrho))\n\u001b[1;32m    574\u001b[0m     \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mh \u001b[38;5;241m<\u001b[39m\u001b[38;5;241m=\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mh_tol \u001b[38;5;129;01mor\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mrho \u001b[38;5;241m>\u001b[39m\u001b[38;5;241m=\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mrho_max:\n",
      "File \u001b[0;32m~/causal_discovery/cagam/rhino_cnf/nnlinear_utils.py:537\u001b[0m, in \u001b[0;36mNotearsNonlinear_lag.dual_ascent_step\u001b[0;34m(self, model, X, Y)\u001b[0m\n\u001b[1;32m    534\u001b[0m     primal_obj\u001b[38;5;241m.\u001b[39mbackward()\n\u001b[1;32m    535\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m primal_obj\n\u001b[0;32m--> 537\u001b[0m \u001b[43moptimizer\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mstep\u001b[49m\u001b[43m(\u001b[49m\u001b[43mclosure\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mdevice\u001b[49m\u001b[43m)\u001b[49m  \u001b[38;5;66;03m# NOTE: updates model in-place\u001b[39;00m\n\u001b[1;32m    538\u001b[0m \u001b[38;5;28;01mwith\u001b[39;00m torch\u001b[38;5;241m.\u001b[39mno_grad():\n\u001b[1;32m    539\u001b[0m     model \u001b[38;5;241m=\u001b[39m model\u001b[38;5;241m.\u001b[39mto(\u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mdevice)\n",
      "File \u001b[0;32m~/.conda/envs/seizure_task/lib/python3.9/site-packages/torch/optim/optimizer.py:88\u001b[0m, in \u001b[0;36mOptimizer._hook_for_profile.<locals>.profile_hook_step.<locals>.wrapper\u001b[0;34m(*args, **kwargs)\u001b[0m\n\u001b[1;32m     86\u001b[0m profile_name \u001b[38;5;241m=\u001b[39m \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mOptimizer.step#\u001b[39m\u001b[38;5;132;01m{}\u001b[39;00m\u001b[38;5;124m.step\u001b[39m\u001b[38;5;124m\"\u001b[39m\u001b[38;5;241m.\u001b[39mformat(obj\u001b[38;5;241m.\u001b[39m\u001b[38;5;18m__class__\u001b[39m\u001b[38;5;241m.\u001b[39m\u001b[38;5;18m__name__\u001b[39m)\n\u001b[1;32m     87\u001b[0m \u001b[38;5;28;01mwith\u001b[39;00m torch\u001b[38;5;241m.\u001b[39mautograd\u001b[38;5;241m.\u001b[39mprofiler\u001b[38;5;241m.\u001b[39mrecord_function(profile_name):\n\u001b[0;32m---> 88\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43mfunc\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43margs\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43mkwargs\u001b[49m\u001b[43m)\u001b[49m\n",
      "File \u001b[0;32m~/causal_discovery/cagam/rhino_cnf/nnlinear_utils.py:412\u001b[0m, in \u001b[0;36mLBFGSBScipy.step\u001b[0;34m(self, closure, device)\u001b[0m\n\u001b[1;32m    409\u001b[0m bounds \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_gather_flat_bounds()\n\u001b[1;32m    411\u001b[0m \u001b[38;5;66;03m# Magic\u001b[39;00m\n\u001b[0;32m--> 412\u001b[0m sol \u001b[38;5;241m=\u001b[39m \u001b[43msopt\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mminimize\u001b[49m\u001b[43m(\u001b[49m\u001b[43mwrapped_closure\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m    413\u001b[0m \u001b[43m                    \u001b[49m\u001b[43minitial_params\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m    414\u001b[0m \u001b[43m                    \u001b[49m\u001b[43mmethod\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[38;5;124;43mL-BFGS-B\u001b[39;49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[43m,\u001b[49m\n\u001b[1;32m    415\u001b[0m \u001b[43m                    \u001b[49m\u001b[43mjac\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;28;43;01mTrue\u001b[39;49;00m\u001b[43m,\u001b[49m\n\u001b[1;32m    416\u001b[0m \u001b[43m                    \u001b[49m\u001b[43mbounds\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mbounds\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    418\u001b[0m final_params \u001b[38;5;241m=\u001b[39m torch\u001b[38;5;241m.\u001b[39mfrom_numpy(sol\u001b[38;5;241m.\u001b[39mx)\n\u001b[1;32m    419\u001b[0m final_params \u001b[38;5;241m=\u001b[39m final_params\u001b[38;5;241m.\u001b[39mto(torch\u001b[38;5;241m.\u001b[39mget_default_dtype())\n",
      "File \u001b[0;32m~/.conda/envs/seizure_task/lib/python3.9/site-packages/scipy/optimize/_minimize.py:710\u001b[0m, in \u001b[0;36mminimize\u001b[0;34m(fun, x0, args, method, jac, hess, hessp, bounds, constraints, tol, callback, options)\u001b[0m\n\u001b[1;32m    707\u001b[0m     res \u001b[38;5;241m=\u001b[39m _minimize_newtoncg(fun, x0, args, jac, hess, hessp, callback,\n\u001b[1;32m    708\u001b[0m                              \u001b[38;5;241m*\u001b[39m\u001b[38;5;241m*\u001b[39moptions)\n\u001b[1;32m    709\u001b[0m \u001b[38;5;28;01melif\u001b[39;00m meth \u001b[38;5;241m==\u001b[39m \u001b[38;5;124m'\u001b[39m\u001b[38;5;124ml-bfgs-b\u001b[39m\u001b[38;5;124m'\u001b[39m:\n\u001b[0;32m--> 710\u001b[0m     res \u001b[38;5;241m=\u001b[39m \u001b[43m_minimize_lbfgsb\u001b[49m\u001b[43m(\u001b[49m\u001b[43mfun\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mx0\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43margs\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mjac\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mbounds\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m    711\u001b[0m \u001b[43m                           \u001b[49m\u001b[43mcallback\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mcallback\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43moptions\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    712\u001b[0m \u001b[38;5;28;01melif\u001b[39;00m meth \u001b[38;5;241m==\u001b[39m \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mtnc\u001b[39m\u001b[38;5;124m'\u001b[39m:\n\u001b[1;32m    713\u001b[0m     res \u001b[38;5;241m=\u001b[39m _minimize_tnc(fun, x0, args, jac, bounds, callback\u001b[38;5;241m=\u001b[39mcallback,\n\u001b[1;32m    714\u001b[0m                         \u001b[38;5;241m*\u001b[39m\u001b[38;5;241m*\u001b[39moptions)\n",
      "File \u001b[0;32m~/.conda/envs/seizure_task/lib/python3.9/site-packages/scipy/optimize/_lbfgsb_py.py:365\u001b[0m, in \u001b[0;36m_minimize_lbfgsb\u001b[0;34m(fun, x0, args, jac, bounds, disp, maxcor, ftol, gtol, eps, maxfun, maxiter, iprint, callback, maxls, finite_diff_rel_step, **unknown_options)\u001b[0m\n\u001b[1;32m    359\u001b[0m task_str \u001b[38;5;241m=\u001b[39m task\u001b[38;5;241m.\u001b[39mtobytes()\n\u001b[1;32m    360\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m task_str\u001b[38;5;241m.\u001b[39mstartswith(\u001b[38;5;124mb\u001b[39m\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mFG\u001b[39m\u001b[38;5;124m'\u001b[39m):\n\u001b[1;32m    361\u001b[0m     \u001b[38;5;66;03m# The minimization routine wants f and g at the current x.\u001b[39;00m\n\u001b[1;32m    362\u001b[0m     \u001b[38;5;66;03m# Note that interruptions due to maxfun are postponed\u001b[39;00m\n\u001b[1;32m    363\u001b[0m     \u001b[38;5;66;03m# until the completion of the current minimization iteration.\u001b[39;00m\n\u001b[1;32m    364\u001b[0m     \u001b[38;5;66;03m# Overwrite f and g:\u001b[39;00m\n\u001b[0;32m--> 365\u001b[0m     f, g \u001b[38;5;241m=\u001b[39m \u001b[43mfunc_and_grad\u001b[49m\u001b[43m(\u001b[49m\u001b[43mx\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    366\u001b[0m \u001b[38;5;28;01melif\u001b[39;00m task_str\u001b[38;5;241m.\u001b[39mstartswith(\u001b[38;5;124mb\u001b[39m\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mNEW_X\u001b[39m\u001b[38;5;124m'\u001b[39m):\n\u001b[1;32m    367\u001b[0m     \u001b[38;5;66;03m# new iteration\u001b[39;00m\n\u001b[1;32m    368\u001b[0m     n_iterations \u001b[38;5;241m+\u001b[39m\u001b[38;5;241m=\u001b[39m \u001b[38;5;241m1\u001b[39m\n",
      "File \u001b[0;32m~/.conda/envs/seizure_task/lib/python3.9/site-packages/scipy/optimize/_differentiable_functions.py:285\u001b[0m, in \u001b[0;36mScalarFunction.fun_and_grad\u001b[0;34m(self, x)\u001b[0m\n\u001b[1;32m    283\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m np\u001b[38;5;241m.\u001b[39marray_equal(x, \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mx):\n\u001b[1;32m    284\u001b[0m     \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_update_x_impl(x)\n\u001b[0;32m--> 285\u001b[0m \u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43m_update_fun\u001b[49m\u001b[43m(\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    286\u001b[0m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_update_grad()\n\u001b[1;32m    287\u001b[0m \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mf, \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mg\n",
      "File \u001b[0;32m~/.conda/envs/seizure_task/lib/python3.9/site-packages/scipy/optimize/_differentiable_functions.py:251\u001b[0m, in \u001b[0;36mScalarFunction._update_fun\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m    249\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21m_update_fun\u001b[39m(\u001b[38;5;28mself\u001b[39m):\n\u001b[1;32m    250\u001b[0m     \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mf_updated:\n\u001b[0;32m--> 251\u001b[0m         \u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43m_update_fun_impl\u001b[49m\u001b[43m(\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    252\u001b[0m         \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mf_updated \u001b[38;5;241m=\u001b[39m \u001b[38;5;28;01mTrue\u001b[39;00m\n",
      "File \u001b[0;32m~/.conda/envs/seizure_task/lib/python3.9/site-packages/scipy/optimize/_differentiable_functions.py:155\u001b[0m, in \u001b[0;36mScalarFunction.__init__.<locals>.update_fun\u001b[0;34m()\u001b[0m\n\u001b[1;32m    154\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21mupdate_fun\u001b[39m():\n\u001b[0;32m--> 155\u001b[0m     \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mf \u001b[38;5;241m=\u001b[39m \u001b[43mfun_wrapped\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mx\u001b[49m\u001b[43m)\u001b[49m\n",
      "File \u001b[0;32m~/.conda/envs/seizure_task/lib/python3.9/site-packages/scipy/optimize/_differentiable_functions.py:137\u001b[0m, in \u001b[0;36mScalarFunction.__init__.<locals>.fun_wrapped\u001b[0;34m(x)\u001b[0m\n\u001b[1;32m    133\u001b[0m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mnfev \u001b[38;5;241m+\u001b[39m\u001b[38;5;241m=\u001b[39m \u001b[38;5;241m1\u001b[39m\n\u001b[1;32m    134\u001b[0m \u001b[38;5;66;03m# Send a copy because the user may overwrite it.\u001b[39;00m\n\u001b[1;32m    135\u001b[0m \u001b[38;5;66;03m# Overwriting results in undefined behaviour because\u001b[39;00m\n\u001b[1;32m    136\u001b[0m \u001b[38;5;66;03m# fun(self.x) will change self.x, with the two no longer linked.\u001b[39;00m\n\u001b[0;32m--> 137\u001b[0m fx \u001b[38;5;241m=\u001b[39m \u001b[43mfun\u001b[49m\u001b[43m(\u001b[49m\u001b[43mnp\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mcopy\u001b[49m\u001b[43m(\u001b[49m\u001b[43mx\u001b[49m\u001b[43m)\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43margs\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    138\u001b[0m \u001b[38;5;66;03m# Make sure the function returns a true scalar\u001b[39;00m\n\u001b[1;32m    139\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m np\u001b[38;5;241m.\u001b[39misscalar(fx):\n",
      "File \u001b[0;32m~/.conda/envs/seizure_task/lib/python3.9/site-packages/scipy/optimize/_optimize.py:77\u001b[0m, in \u001b[0;36mMemoizeJac.__call__\u001b[0;34m(self, x, *args)\u001b[0m\n\u001b[1;32m     75\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21m__call__\u001b[39m(\u001b[38;5;28mself\u001b[39m, x, \u001b[38;5;241m*\u001b[39margs):\n\u001b[1;32m     76\u001b[0m \u001b[38;5;250m    \u001b[39m\u001b[38;5;124;03m\"\"\" returns the function value \"\"\"\u001b[39;00m\n\u001b[0;32m---> 77\u001b[0m     \u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43m_compute_if_needed\u001b[49m\u001b[43m(\u001b[49m\u001b[43mx\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43margs\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m     78\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_value\n",
      "File \u001b[0;32m~/.conda/envs/seizure_task/lib/python3.9/site-packages/scipy/optimize/_optimize.py:71\u001b[0m, in \u001b[0;36mMemoizeJac._compute_if_needed\u001b[0;34m(self, x, *args)\u001b[0m\n\u001b[1;32m     69\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m np\u001b[38;5;241m.\u001b[39mall(x \u001b[38;5;241m==\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mx) \u001b[38;5;129;01mor\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_value \u001b[38;5;129;01mis\u001b[39;00m \u001b[38;5;28;01mNone\u001b[39;00m \u001b[38;5;129;01mor\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mjac \u001b[38;5;129;01mis\u001b[39;00m \u001b[38;5;28;01mNone\u001b[39;00m:\n\u001b[1;32m     70\u001b[0m     \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mx \u001b[38;5;241m=\u001b[39m np\u001b[38;5;241m.\u001b[39masarray(x)\u001b[38;5;241m.\u001b[39mcopy()\n\u001b[0;32m---> 71\u001b[0m     fg \u001b[38;5;241m=\u001b[39m \u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mfun\u001b[49m\u001b[43m(\u001b[49m\u001b[43mx\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43margs\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m     72\u001b[0m     \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mjac \u001b[38;5;241m=\u001b[39m fg[\u001b[38;5;241m1\u001b[39m]\n\u001b[1;32m     73\u001b[0m     \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_value \u001b[38;5;241m=\u001b[39m fg[\u001b[38;5;241m0\u001b[39m]\n",
      "File \u001b[0;32m~/causal_discovery/cagam/rhino_cnf/nnlinear_utils.py:401\u001b[0m, in \u001b[0;36mLBFGSBScipy.step.<locals>.wrapped_closure\u001b[0;34m(flat_params)\u001b[0m\n\u001b[1;32m    399\u001b[0m flat_params \u001b[38;5;241m=\u001b[39m flat_params\u001b[38;5;241m.\u001b[39mto(torch\u001b[38;5;241m.\u001b[39mget_default_dtype())\u001b[38;5;241m.\u001b[39mto(device)\n\u001b[1;32m    400\u001b[0m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_distribute_flat_params(flat_params)\n\u001b[0;32m--> 401\u001b[0m loss \u001b[38;5;241m=\u001b[39m \u001b[43mclosure\u001b[49m\u001b[43m(\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    402\u001b[0m loss \u001b[38;5;241m=\u001b[39m loss\u001b[38;5;241m.\u001b[39mitem()\n\u001b[1;32m    403\u001b[0m flat_grad \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_gather_flat_grad()\u001b[38;5;241m.\u001b[39mcpu()\u001b[38;5;241m.\u001b[39mdetach()\u001b[38;5;241m.\u001b[39mnumpy()\n",
      "File \u001b[0;32m~/causal_discovery/cagam/rhino_cnf/nnlinear_utils.py:526\u001b[0m, in \u001b[0;36mNotearsNonlinear_lag.dual_ascent_step.<locals>.closure\u001b[0;34m()\u001b[0m\n\u001b[1;32m    525\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21mclosure\u001b[39m():\n\u001b[0;32m--> 526\u001b[0m     \u001b[43moptimizer\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mzero_grad\u001b[49m\u001b[43m(\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    527\u001b[0m     X_hat \u001b[38;5;241m=\u001b[39m model(X_torch\u001b[38;5;241m.\u001b[39mfloat(),Y_torch\u001b[38;5;241m.\u001b[39mfloat())\n\u001b[1;32m    528\u001b[0m     loss \u001b[38;5;241m=\u001b[39m squared_loss(X_hat, X_torch)\n",
      "File \u001b[0;32m~/.conda/envs/seizure_task/lib/python3.9/site-packages/torch/optim/optimizer.py:222\u001b[0m, in \u001b[0;36mOptimizer.zero_grad\u001b[0;34m(self, set_to_none)\u001b[0m\n\u001b[1;32m    220\u001b[0m     p\u001b[38;5;241m.\u001b[39mgrad\u001b[38;5;241m.\u001b[39mrequires_grad_(\u001b[38;5;28;01mFalse\u001b[39;00m)\n\u001b[1;32m    221\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m (\u001b[38;5;129;01mnot\u001b[39;00m foreach \u001b[38;5;129;01mor\u001b[39;00m p\u001b[38;5;241m.\u001b[39mgrad\u001b[38;5;241m.\u001b[39mis_sparse):\n\u001b[0;32m--> 222\u001b[0m     \u001b[43mp\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mgrad\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mzero_\u001b[49m\u001b[43m(\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    223\u001b[0m \u001b[38;5;28;01melse\u001b[39;00m:\n\u001b[1;32m    224\u001b[0m     per_device_and_dtype_grads[p\u001b[38;5;241m.\u001b[39mgrad\u001b[38;5;241m.\u001b[39mdevice][p\u001b[38;5;241m.\u001b[39mgrad\u001b[38;5;241m.\u001b[39mdtype]\u001b[38;5;241m.\u001b[39mappend(p\u001b[38;5;241m.\u001b[39mgrad)\n",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m: "
     ]
    }
   ],
   "source": [
    "X = df_total[rearange_intra+rearange_inter].to_numpy()\n",
    "\n",
    "#X = (X - X.mean())/X.std()\n",
    "gamma_hat, model_n = CASTOR_1(X, 4, 2, 4000,torch.device('cuda:1'), 1.5,2500)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# CASTOR with regime labels:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 162,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/arahmani/causal_discovery/cagam/rhino_cnf/CASTOR.py:101: RuntimeWarning: invalid value encountered in divide\n",
      "  idx = np.argmax(gamma_hat/pall.reshape((m,1)), axis=-1)\n",
      "/home/arahmani/causal_discovery/cagam/rhino_cnf/CASTOR.py:60: UserWarning: Implicit dimension choice for softmax has been deprecated. Change the call to include dim=X as an argument.\n",
      "  return soft(y_pre),loss.item(),model\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-0.0\n",
      "[5000.] iter: 0 , p: [5000.]\n",
      "-0.0\n",
      "[7000.] iter: 0 , p: [7000.]\n",
      "-0.0\n",
      "[6000.] iter: 0 , p: [6000.]\n"
     ]
    }
   ],
   "source": [
    "list_dur  = np.array([0,5000,12000,18000]).astype(int)\n",
    "n_reg = 3\n",
    "list_model = []\n",
    "X = df_total[rearange_intra+rearange_inter].to_numpy()\n",
    "for i in range(n_reg):\n",
    "            _, model_n = CASTOR_1(X[list_dur[i]:list_dur[i+1]], 1, 2, list_dur[i+1] - list_dur[i],torch.device('cuda:1'), 1.5,0)\n",
    "            list_model.append(model_n)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 163,
   "metadata": {},
   "outputs": [],
   "source": [
    "def define_big_mat_CASTOR(N,regime, L,g_list,tr_lab, thresh_inst, thres_lag):\n",
    "            if tr_lab ==False:\n",
    "                        all_estimated_g = np.zeros((N*regime,N*regime))\n",
    "                        all_estimated_g_lag = np.zeros((N*regime,N*regime))\n",
    "                        for i in range(regime):\n",
    "                                    all_estimated_g[i*N:(i+1)*N,i*N:(i+1)*N] = L[:N,:N,i]\n",
    "            \n",
    "                                    all_estimated_g_lag[i*N:(i+1)*N,i*N:(i+1)*N] = L[N:2*N,:N,i]\n",
    "                        all_estimated_g[all_estimated_g<thresh_inst] = 0\n",
    "                        all_estimated_g[all_estimated_g>thresh_inst] = 1\n",
    "\n",
    "                        all_estimated_g_lag[all_estimated_g_lag<thres_lag] = 0\n",
    "                        all_estimated_g_lag[all_estimated_g_lag>thres_lag] = 1\n",
    "                        return all_estimated_g,all_estimated_g_lag\n",
    "            else:\n",
    "                        g_3_regime = np.zeros((N*regime,N*regime))\n",
    "                        g_3_regime_lag = np.zeros((N*regime,N*regime))\n",
    "                        for i in range(regime):\n",
    "                                    g_3_regime[(i)*N:(i+1)*N,(i)*N:(i+1)*N] = nx.to_numpy_array(g_list[i])[N:2*N,N:2*N]\n",
    "                                    g_3_regime_lag[(i)*N:(i+1)*N,(i)*N:(i+1)*N] = nx.to_numpy_array(g_list[i])[:N,N:2*N]\n",
    "                        return g_3_regime,g_3_regime_lag"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 164,
   "metadata": {},
   "outputs": [],
   "source": [
    "lags = 2\n",
    "reg_num = 3\n",
    "n_nodes = 10\n",
    "L = np.zeros((lags*n_nodes, lags*n_nodes, reg_num))\n",
    "w_thres_l = [0.0,0.,0.6,0.2]\n",
    "A_thres_l = [0,0,0.,0.3]\n",
    "for i,class_idx in enumerate(np.arange(reg_num)):#,2,3])):#,3,4])):\n",
    "            L[:n_nodes, :n_nodes, i] = np.array((abs(list_model[class_idx][0].W_no_thres) > w_thres_l[i]).astype(int)) \n",
    "            L[n_nodes:lags*n_nodes,:n_nodes, i] = (abs(list_model[class_idx][0].A_no_thres)> A_thres_l[i]).astype(int)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 165,
   "metadata": {},
   "outputs": [],
   "source": [
    "all_estimated_g,all_estimated_g_lag = define_big_mat_CASTOR(n_nodes,reg_num, L,g_list,False,0,0)\n",
    "g_3_regime,g_3_regime_lag = define_big_mat_CASTOR(n_nodes,reg_num, L, g_list,True,0,0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 166,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(108.0, 0.2469135802469136)"
      ]
     },
     "execution_count": 166,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "shd(g_3_regime,all_estimated_g), classification_metrics(g_3_regime,all_estimated_g.astype(int))['f1']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 167,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(137.0, 0.3353293413173652)"
      ]
     },
     "execution_count": 167,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "shd(g_3_regime_lag,all_estimated_g_lag), classification_metrics(g_3_regime_lag,all_estimated_g_lag.astype(int))['f1']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 168,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(0.20333333333333334, 0.27, 0.7530864197530864)"
      ]
     },
     "execution_count": 168,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "normalized_hamming_distance(adj_mat_to_edge_list(all_estimated_g), adj_mat_to_edge_list(g_3_regime))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 169,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(0.24666666666666667, 0.3711111111111111, 0.6646706586826348)"
      ]
     },
     "execution_count": 169,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "normalized_hamming_distance(adj_mat_to_edge_list(all_estimated_g_lag), adj_mat_to_edge_list(g_3_regime_lag))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "seizure_task",
   "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.16"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
