{
 "cells": [
  {
   "cell_type": "code",
   "id": "9e5fc7a1-3b94-40c6-aa55-d1ea1fdc8edd",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-10-05T08:18:08.846131Z",
     "start_time": "2024-10-05T08:18:06.133160Z"
    }
   },
   "source": [
    "import networkx as nx\n",
    "import numpy as np\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "from torch.utils.data import DataLoader, TensorDataset\n",
    "from CaT.model import CaT\n",
    "from CaT.datasets import reorder_dag, get_full_ordering\n",
    "from CFCN.model import CFCN\n",
    "from utils.inference import CausalInference\n",
    "from eval_utils import train_model\n",
    "import matplotlib.pyplot as plt\n",
    "from sklearn.ensemble import RandomForestRegressor\n",
    "from sklearn.neural_network import MLPRegressor\n",
    "import pandas as pd\n",
    "\n",
    "mse_figname = 'mse_all.png'\n",
    "ate_figname = 'ate_all.png'\n",
    "\n",
    "\n",
    "test_CAT = True\n",
    "test_CFCN = True\n",
    "test_RF = True\n",
    "test_transformer = True\n",
    "test_MLP = True\n",
    "\n",
    "num_sims = 1\n",
    "\n",
    "seed = 1\n",
    "standardize = 0\n",
    "sample_size = 100000\n",
    "batch_size = 100\n",
    "max_iters = 6000\n",
    "eval_interval = 20000\n",
    "eval_iters = 100\n",
    "validation_fraction = 0.3\n",
    "np.random.seed(seed=seed)\n",
    "torch.manual_seed(seed)\n",
    "device = 'cuda'\n",
    "dropout_rate_cat = 0.0\n",
    "learning_rate_cat = 5e-3\n",
    "ff_n_embed = 6\n",
    "num_heads = 2\n",
    "n_layers = 2\n",
    "embed_dim = 5\n",
    "head_size = 6\n",
    "\n",
    "\n",
    "# CFCN stuff\n",
    "neurons_per_layer = [4,8,8,8, 8, 4]\n",
    "dropout_rate_cfcn = 0.0\n",
    "learning_rate_cfcn = 1e-3\n",
    "max_iters_cfcn = 20000\n",
    "shuffling = 0"
   ],
   "outputs": [],
   "execution_count": 1
  },
  {
   "cell_type": "code",
   "id": "a8737cbb5720a9f4",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-10-05T08:58:41.438311Z",
     "start_time": "2024-10-05T08:58:41.417647Z"
    }
   },
   "source": [
    "def generate_data(N, d=1):\n",
    "    DAGnx1 = nx.DiGraph()\n",
    "    DAGnx2 = nx.DiGraph()\n",
    "    DAGnx3 = nx.DiGraph()  # correct graph\n",
    "    \n",
    "    Ud = np.random.randn(N,d)\n",
    "    D =  Ud\n",
    "    \n",
    "    Ul1 = np.random.randn(N,d) #  D ->  L1 = 0.5\n",
    "    L1 =  0.5*D + Ul1\n",
    "    \n",
    "    L1_0 = Ul1\n",
    "    L1_1 = 0.5 + Ul1  #  D ->  L1 = 0.5\n",
    "\n",
    "    Uy = np.random.randn(N,d)\n",
    "    Y =   0.5*D + 3.5 * L1 + Uy  #  D ->  Y = 1, L1 -> Y = 1.2,  ATE(Y|do(D=1)) = 0.5*3.5 + 0.5 = 1.75 + 0.5 = 2.25 \n",
    "\n",
    "    Ul2 = np.random.randn(N,d)\n",
    "    L2 = 0.9 * Y + 0.7 * D + Ul2  #  D ->  L2 = 0.7, Y -> L2 = 9.8\n",
    "\n",
    "    Y0 = 3.5 * L1_0 + Uy \n",
    "    Y1 = 0.5 + 3.5 * L1_1 + Uy\n",
    "\n",
    "    all_data_dict = {'D': D, 'L1': L1, 'Y': Y, 'L2': L2}  \n",
    "\n",
    "    # types can be 'cat' (categorical) 'cont' (continuous) or 'bin' (binary)\n",
    "    var_types = {'D': 'cont', 'L1': 'cont',  'Y': 'cont', 'L2': 'cont',}\n",
    "\n",
    "    DAGnx1.add_edges_from([('D', 'Y'), ('L1', 'Y'), ('L2', 'Y')])\n",
    "    DAGnx1 = reorder_dag(dag=DAGnx1)  # topologically sorted dag\n",
    "    var_names1 = list(DAGnx1.nodes())  # topologically ordered list of variables\n",
    "    all_data1 = np.stack([all_data_dict[key] for key in var_names1], axis=1)\n",
    "    causal_ordering1 = get_full_ordering(DAGnx1)\n",
    "    ordered_var_types1 = dict(sorted(var_types.items(), key=lambda item: causal_ordering1[item[0]]))\n",
    "    ex_dag_stuff = (all_data1, DAGnx1, var_names1, causal_ordering1, ordered_var_types1)\n",
    "    \n",
    "    DAGnx2.add_edges_from([('D', 'L1'), ('D', 'Y'), ('L1', 'Y'), ('L2', 'Y')])\n",
    "    DAGnx2 = reorder_dag(dag=DAGnx2)  # topologically sorted dag\n",
    "    var_names2 = list(DAGnx2.nodes())  # topologically ordered list of variables\n",
    "    all_data2 = np.stack([all_data_dict[key] for key in var_names2], axis=1)\n",
    "    causal_ordering2 = get_full_ordering(DAGnx2)\n",
    "    ordered_var_types2 = dict(sorted(var_types.items(), key=lambda item: causal_ordering2[item[0]]))\n",
    "    mediated_dag_stuff = (all_data2, DAGnx2, var_names2, causal_ordering2, ordered_var_types2)\n",
    "    \n",
    "    DAGnx3.add_edges_from([('D', 'Y'), ('D', 'L1'),  ('L1', 'Y') , ('D', 'L2'), ('Y', 'L2')])\n",
    "    DAGnx3 = reorder_dag(dag=DAGnx3)  # topologically sorted dag\n",
    "    var_names3 = list(DAGnx3.nodes())  # topologically ordered list of variables\n",
    "    all_data3 = np.stack([all_data_dict[key] for key in var_names3], axis=1)  # sorted data\n",
    "    causal_ordering3 = get_full_ordering(DAGnx3)\n",
    "    ordered_var_types3 = dict(sorted(var_types.items(), key=lambda item: causal_ordering3[item[0]]))\n",
    "    correct_dag_stuff =  (all_data3, DAGnx3, var_names3, causal_ordering3, ordered_var_types3)\n",
    "\n",
    "    return ex_dag_stuff, mediated_dag_stuff, correct_dag_stuff, Y0, Y1\n",
    "\n",
    "\n",
    "def apply_random_forest(train_data, val_data, all_data, cause_index, effect_index):\n",
    "    rf = RandomForestRegressor()\n",
    "    \n",
    "    # Prepare the training data: Input = all variables except effect_index, target = effect_index\n",
    "    X_train = train_data[:, np.arange(train_data.shape[1]) != effect_index, 0].numpy()  # Select all variables except effect_index\n",
    "    y_train = train_data[:, effect_index, 0].numpy()  # Target is the effect_index variable\n",
    "\n",
    "    # Train the RandomForest on the training data\n",
    "    rf.fit(X_train, y_train)\n",
    "\n",
    "    # 1st: Predict on the validation set to compute the MSE\n",
    "    X_val = val_data[:, np.arange(val_data.shape[1]) != effect_index, 0].numpy()  # Input without effect_index\n",
    "    y_val = val_data[:, effect_index, 0].numpy()  # True effect values for validation\n",
    "\n",
    "    preds_val = rf.predict(X_val)\n",
    "    mse = ((y_val - preds_val) ** 2).mean()\n",
    "\n",
    "    # 2nd: Copy the all_data (numpy array), and set cause_index to 0 and 1 in two copies\n",
    "    all_data0 = np.copy(all_data)\n",
    "    all_data1 = np.copy(all_data)\n",
    "\n",
    "    all_data0[:, cause_index, 0] = 0  # Set cause_index to 0\n",
    "    all_data1[:, cause_index, 0] = 1  # Set cause_index to 1\n",
    "\n",
    "    # Prepare the intervention data for prediction: all variables except effect_index\n",
    "    X_all_data0 = all_data0[:, np.arange(all_data.shape[1]) != effect_index, 0]  # Inputs for intervention where cause is 0\n",
    "    X_all_data1 = all_data1[:, np.arange(all_data.shape[1]) != effect_index, 0]  # Inputs for intervention where cause is 1\n",
    "\n",
    "    # Predict for the intervention datasets (cause set to 0 and 1)\n",
    "    preds0 = rf.predict(X_all_data0)\n",
    "    preds1 = rf.predict(X_all_data1)\n",
    "\n",
    "    # 3rd: Compute the estimated ATE (Average Treatment Effect)\n",
    "    estimated_ATE = (preds1 - preds0).mean()\n",
    "\n",
    "    print('RF MSE on validation set:', mse)\n",
    "    print('RF Estimated ATE:', estimated_ATE)\n",
    "\n",
    "    return estimated_ATE, mse, rf\n",
    "\n",
    "    \n",
    "def apply_mlp(train_data, val_data, all_data, cause_index, effect_index):\n",
    "    mlp = MLPRegressor(max_iter=max_iters, hidden_layer_sizes=(20,20,20), activation='relu')\n",
    "    \n",
    "    X_train = train_data[:, np.arange(train_data.shape[1]) != effect_index, 0].numpy()  # Select all variables except effect_index\n",
    "    y_train = train_data[:, effect_index, 0].numpy()  # Target is the effect_index variable\n",
    "\n",
    "    # Train the MLP on the training data\n",
    "    mlp.fit(X_train, y_train)\n",
    "\n",
    "    # 1st: Predict on the validation set to compute the MSE\n",
    "    X_val = val_data[:, np.arange(val_data.shape[1]) != effect_index, 0].numpy()  # Input without effect_index\n",
    "    y_val = val_data[:, effect_index, 0].numpy()  # True effect values for validation\n",
    "\n",
    "    preds_val = mlp.predict(X_val)\n",
    "    mse = ((y_val - preds_val) ** 2).mean()\n",
    "\n",
    "    # 2nd: Copy the all_data (numpy array), and set cause_index to 0 and 1 in two copies\n",
    "    all_data0 = np.copy(all_data)\n",
    "    all_data1 = np.copy(all_data)\n",
    "\n",
    "    all_data0[:, cause_index, 0] = 0  # Set cause_index to 0\n",
    "    all_data1[:, cause_index, 0] = 1  # Set cause_index to 1\n",
    "\n",
    "    # Prepare the intervention data for prediction: all variables except effect_index\n",
    "    X_all_data0 = all_data0[:, np.arange(all_data.shape[1]) != effect_index, 0]  # Inputs for intervention where cause is 0\n",
    "    X_all_data1 = all_data1[:, np.arange(all_data.shape[1]) != effect_index, 0]  # Inputs for intervention where cause is 1\n",
    "\n",
    "    # Predict for the intervention datasets (cause set to 0 and 1)\n",
    "    preds0 = mlp.predict(X_all_data0)\n",
    "    preds1 = mlp.predict(X_all_data1)\n",
    "\n",
    "    # 3rd: Compute the estimated ATE (Average Treatment Effect)\n",
    "    estimated_ATE = (preds1 - preds0).mean()\n",
    "\n",
    "    print('MLP MSE on validation set:', mse)\n",
    "    print('MLP Estimated ATE:', estimated_ATE)\n",
    "\n",
    "    return estimated_ATE, mse, mlp\n",
    "\n",
    "\n",
    "\n",
    "class TransformerRegressor(nn.Module):\n",
    "    def __init__(self, input_dim, hidden_dim=16, n_layers=2, n_heads=2):\n",
    "        super(TransformerRegressor, self).__init__()\n",
    "        # Define an encoder layer with the hidden_dim (embedding dimension)\n",
    "        encoder_layer = nn.TransformerEncoderLayer(d_model=hidden_dim, nhead=n_heads, dim_feedforward=hidden_dim, batch_first=True)\n",
    "        # Stack the encoder layers into a TransformerEncoder\n",
    "        self.transformer_encoder = nn.TransformerEncoder(encoder_layer, num_layers=n_layers)\n",
    "        # Project input_dim to hidden_dim for input embeddings\n",
    "        self.embedding = nn.Linear(input_dim, hidden_dim)\n",
    "        # Fully connected layer for final regression output (projecting hidden_dim to 1)\n",
    "        self.fc = nn.Linear((input_dim) * hidden_dim, 1) # Output a scalar per input sample\n",
    "\n",
    "    def forward(self, x):\n",
    "        # Project input_dim to hidden_dim\n",
    "        x = self.embedding(x)  # (batch_size, num_variables, hidden_dim)\n",
    "        # Pass input through the transformer encoder\n",
    "        out = self.transformer_encoder(x)  # (batch_size, num_variables, hidden_dim)\n",
    "        # Flatten the sequence dimension and pass through fully connected layer\n",
    "        out = out.view(out.size(0), -1)  # Flatten to (batch_size, num_variables * hidden_dim)\n",
    "        # Fully connected layer to output a prediction\n",
    "        out = self.fc(out)  # Adjust self.fc to match the flattened size\n",
    "        return out.squeeze(-1)  # (N,)\n",
    "    \n",
    "\n",
    "def create_data_loader(train_data, batch_size, effect_index):\n",
    "    # All variables except the one at effect_index\n",
    "    X_train = train_data[:, np.arange(train_data.shape[1]) != effect_index, 0]  \n",
    "    # Target is the effect_index variable\n",
    "    y_train = train_data[:, effect_index, 0]\n",
    "    \n",
    "    dataset = TensorDataset(X_train, y_train)\n",
    "    loader = DataLoader(dataset, batch_size=batch_size, shuffle=True)\n",
    "    \n",
    "    return loader   \n",
    "    \n",
    "    \n",
    "def apply_transformer(train_data, val_data, all_data, cause_index, effect_index, batch_size, max_iters, device):\n",
    "    input_dim = train_data.shape[1] - 1  # V dimension corresponds to the number of variables excluding effect_index\n",
    "    transformer = TransformerRegressor(input_dim=input_dim).to(device)\n",
    "    optimizer = torch.optim.Adam(transformer.parameters(), lr=1e-4)\n",
    "    criterion = nn.MSELoss()\n",
    "\n",
    "    # Prepare the training data with batching\n",
    "    train_loader = create_data_loader(train_data, batch_size=batch_size, effect_index=effect_index)\n",
    "    train_loader_iter = iter(train_loader)  # Create an iterator from the loader\n",
    "\n",
    "    # Training Loop\n",
    "    transformer.train()\n",
    "\n",
    "    for iter_ in range(max_iters):\n",
    "        try:\n",
    "            # Try getting the next batch\n",
    "            batch_X, batch_y = next(train_loader_iter)\n",
    "        except StopIteration:\n",
    "            # If the iterator is exhausted, recreate the iterator (i.e., reshuffle and restart)\n",
    "            train_loader_iter = iter(train_loader)\n",
    "            batch_X, batch_y = next(train_loader_iter)\n",
    "\n",
    "        batch_X, batch_y = batch_X.to(device), batch_y.to(device)\n",
    "        optimizer.zero_grad()\n",
    "    \n",
    "        # Pass batch_X to transformer with the correct shape (N, V-1, input_dim)\n",
    "        batch_X = batch_X.unsqueeze(-1).repeat(1, 1, input_dim)  # Repeat input_dim times if needed\n",
    "\n",
    "        preds = transformer(batch_X)  # Directly pass the features (N, V-1)\n",
    "        loss = criterion(preds, batch_y)\n",
    "        loss.backward()\n",
    "        optimizer.step()\n",
    "\n",
    "        # Optionally, print loss every 100 iterations for monitoring\n",
    "        if iter_ % eval_interval == 0:\n",
    "            print(f\"Iteration {iter_}/{max_iters}, Loss: {loss.item():.4f}\")\n",
    "            \n",
    "    X_val = val_data[:, np.arange(val_data.shape[1]) != effect_index, 0].to(device)  # Input without effect_index\n",
    "    X_val = X_val.unsqueeze(-1).repeat(1, 1, input_dim)\n",
    "    y_val = val_data[:, effect_index, 0].to(device)  # True effect values for validation\n",
    "    \n",
    "\n",
    "    transformer.eval()\n",
    "    with torch.no_grad():\n",
    "        preds_val = transformer(X_val).detach().cpu().numpy()\n",
    "        \n",
    "    \n",
    "    mse = ((y_val.cpu().numpy() - preds_val) ** 2).mean()\n",
    "\n",
    "    # 2nd: Copy the all_data (numpy array), and set cause_index to 0 and 1 in two copies\n",
    "    all_data0 = np.copy(all_data)\n",
    "    all_data1 = np.copy(all_data)\n",
    "\n",
    "    all_data0[:, cause_index, 0] = 0  # Set cause_index to 0\n",
    "    all_data1[:, cause_index, 0] = 1  # Set cause_index to 1\n",
    "\n",
    "    # Prepare the intervention data for prediction: all variables except effect_index\n",
    "    X_all_data0 = torch.from_numpy(all_data0[:, np.arange(all_data.shape[1]) != effect_index, 0]).float().to(device)\n",
    "    X_all_data0 = X_all_data0.unsqueeze(-1).repeat(1, 1, input_dim)\n",
    "    X_all_data1 = torch.from_numpy(all_data1[:, np.arange(all_data.shape[1]) != effect_index, 0]).float().to(device)\n",
    "    X_all_data1 = X_all_data1.unsqueeze(-1).repeat(1, 1, input_dim)\n",
    "\n",
    "    torch.cuda.empty_cache()\n",
    "\n",
    "    # Predict for the intervention datasets (cause set to 0 and 1)\n",
    "    transformer.eval()\n",
    "    with torch.no_grad():\n",
    "        preds0 = transformer(X_all_data0).detach().cpu().numpy()\n",
    "        preds1 = transformer(X_all_data1).detach().cpu().numpy()\n",
    "\n",
    "    # 3rd: Compute the estimated ATE (Average Treatment Effect)\n",
    "    estimated_ATE = (preds1 - preds0).mean()\n",
    "\n",
    "    print('Transformer MSE on validation set:', mse)\n",
    "    print('Transformer Estimated ATE:', estimated_ATE)\n",
    "\n",
    "    return estimated_ATE, mse, transformer\n",
    "\n",
    "\n",
    "\n",
    "\n"
   ],
   "outputs": [],
   "execution_count": 14
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-10-05T09:30:06.129957Z",
     "start_time": "2024-10-05T09:24:54.189574Z"
    }
   },
   "cell_type": "code",
   "source": [
    "\n",
    "d=1\n",
    "_, _, _, Y0, Y1 = generate_data(N=1000000, d=d)\n",
    "ATE = (Y1 - Y0).mean(0)  \n",
    "print(ATE)\n",
    "ATE_samples = []\n",
    "\n",
    "cause_var = 'D'\n",
    "int_nodes_vals0 = {cause_var: np.array([0.0,])}\n",
    "int_nodes_vals1 = {cause_var: np.array([1.0,])}\n",
    "effect_var = 'Y'\n",
    "\n",
    "\n",
    "if test_CAT:\n",
    "    mse_y_1s_CaT = []\n",
    "    mse_y_2s_CaT = []\n",
    "    mse_y_3s_CaT = []\n",
    "    est_ATE_1s_CaT = []\n",
    "    est_ATE_2s_CaT = []\n",
    "    est_ATE_3s_CaT = []\n",
    "\n",
    "if test_CFCN:\n",
    "    mse_y_1s_CFCN = []\n",
    "    mse_y_2s_CFCN = []\n",
    "    mse_y_3s_CFCN = []\n",
    "    est_ATE_1s_CFCN = []\n",
    "    est_ATE_2s_CFCN = []\n",
    "    est_ATE_3s_CFCN = []\n",
    "\n",
    "if test_RF:\n",
    "    mse_y_RF = []\n",
    "    est_ATE_RF = []\n",
    "\n",
    "if test_transformer:\n",
    "    mse_y_transformer = []\n",
    "    est_ATE_transformer = []\n",
    "\n",
    "if test_MLP:\n",
    "    mse_y_MLP = []\n",
    "    est_ATE_MLP = []\n",
    "\n",
    "for i in range(num_sims):\n",
    "    print('Simulation:', i)\n",
    "    \n",
    "    ex_dag_stuff, mediated_dag_stuff, correct_dag_stuff, Y0, Y1 = generate_data(N=sample_size, d=d)\n",
    "    ATE_samples.append((Y1-Y0).mean())\n",
    "    print('ATE sample:', (Y1-Y0).mean())\n",
    "    \n",
    "    all_data1, DAGnx1, var_names1, causal_ordering1, var_types1 = ex_dag_stuff\n",
    "    all_data2, DAGnx2, var_names2, causal_ordering2, var_types2 = mediated_dag_stuff\n",
    "    all_data3, DAGnx3, var_names3, causal_ordering3, var_types3 = correct_dag_stuff\n",
    "    \n",
    "    indices = np.arange(0, len(all_data3))\n",
    "    np.random.shuffle(indices)\n",
    "    val_inds = indices[:int(validation_fraction*len(indices))]\n",
    "    train_inds = indices[int(validation_fraction*len(indices)):]\n",
    "    \n",
    "\n",
    "    train_data = all_data1[train_inds]\n",
    "    val_data = all_data1[val_inds]\n",
    "    train_data, val_data = torch.from_numpy(train_data).float(),  torch.from_numpy(val_data).float()\n",
    "    effect_index = var_names1.index(effect_var)\n",
    "    cause_index = var_names1.index(cause_var)    \n",
    "\n",
    "    input_dim = all_data1.shape[2]\n",
    "\n",
    "    if test_CFCN:\n",
    "        print('Training CFCN on graph 1...')\n",
    "        model1_cfcn = CFCN(neurons_per_layer=neurons_per_layer, dag=DAGnx1, causal_ordering=causal_ordering1, var_types=var_types1, dropout_rate=dropout_rate_cfcn).to(device)\n",
    "        train_model(model1_cfcn, train_data, val_data, device, shuffling=shuffling, max_iters=max_iters_cfcn, eval_interval=eval_interval, eval_iters=eval_iters, learning_rate=learning_rate_cfcn, batch_size=batch_size, use_scheduler=False)\n",
    "        model1_cfcn.eval()    \n",
    "        inf = CausalInference(model=model1_cfcn, device=device)\n",
    "        effect_index = var_names1.index(effect_var)\n",
    "        preds0 = inf.forward(all_data1, int_nodes_vals0)\n",
    "        preds1 = inf.forward(all_data1, int_nodes_vals1)\n",
    "        ATE_pred = (preds1[:,effect_index,:] - preds0[:,effect_index,:]).mean(0)\n",
    "        eATE = np.abs(ATE_pred - ATE)\n",
    "        preds = model1_cfcn(val_data.to(device)).detach().cpu()\n",
    "        mse_y_1s_CFCN.append(((val_data[:,effect_index,:] - preds[:,effect_index,:])**2).mean())\n",
    "        est_ATE_1s_CFCN.append(ATE_pred)\n",
    "        print('CFCN1 ATE:', ATE_pred)\n",
    "        print('CFCN1 MSE:', ((val_data[:,effect_index,:] - preds[:,effect_index,:])**2).mean())\n",
    "\n",
    "    if test_CAT:\n",
    "        print('Training CaT on graph 1...')\n",
    "        model1 = CaT(input_dim=input_dim,\n",
    "                        dropout_rate=dropout_rate_cat,\n",
    "                        head_size=head_size,\n",
    "                        num_heads=num_heads,\n",
    "                        ff_n_embed=ff_n_embed,\n",
    "                        dag=DAGnx1,\n",
    "                        causal_ordering=causal_ordering1,\n",
    "                        n_layers=n_layers,\n",
    "                        device=device,\n",
    "                        var_types=var_types1,\n",
    "                        use_batch_norm=False,\n",
    "                        embed_dim=embed_dim\n",
    "                        ).to(device)\n",
    "        train_model(model1, train_data, val_data, device, shuffling=0, max_iters=max_iters, eval_interval=eval_interval, eval_iters=eval_iters, learning_rate=learning_rate_cat, batch_size=batch_size)\n",
    "        model1.eval()\n",
    "        inf = CausalInference(model=model1, device=device)\n",
    "        effect_index = var_names1.index(effect_var)\n",
    "        preds0 = inf.forward(all_data1, int_nodes_vals0)\n",
    "        preds1 = inf.forward(all_data1, int_nodes_vals1)\n",
    "        ATE_pred = (preds1[:,effect_index,:] - preds0[:,effect_index,:]).mean(0)\n",
    "        eATE = np.abs(ATE_pred - ATE)\n",
    "        preds = model1(val_data.to(device)).detach().cpu()\n",
    "        mse_y_1s_CaT.append(((val_data[:,effect_index,:] - preds[:,effect_index,:])**2).mean())\n",
    "        est_ATE_1s_CaT.append(ATE_pred)\n",
    "        print('CAT1 ATE:', ATE_pred)\n",
    "        print('CAT1 MSE:', ((val_data[:,effect_index,:] - preds[:,effect_index,:])**2).mean())\n",
    "\n",
    "\n",
    "    train_data = all_data2[train_inds]\n",
    "    val_data = all_data2[val_inds]\n",
    "    train_data, val_data = torch.from_numpy(train_data).float(),  torch.from_numpy(val_data).float()\n",
    "    effect_index = var_names2.index(effect_var)\n",
    "    cause_index = var_names2.index(cause_var)\n",
    "\n",
    "    input_dim = all_data2.shape[2]\n",
    "\n",
    "    print('Training CFCN on graph 2...')\n",
    "    if test_CFCN:\n",
    "        print('Training CFCN on graph 2...')\n",
    "        model2_cfcn = CFCN(neurons_per_layer=neurons_per_layer, dag=DAGnx2, causal_ordering=causal_ordering2, var_types=var_types2, dropout_rate=dropout_rate_cfcn).to(device)\n",
    "        train_model(model2_cfcn, train_data, val_data, device, shuffling=shuffling, max_iters=max_iters_cfcn, eval_interval=eval_interval, eval_iters=eval_iters, learning_rate=learning_rate_cfcn, batch_size=batch_size, use_scheduler=False)\n",
    "        model2_cfcn.eval()\n",
    "        inf = CausalInference(model=model2_cfcn, device=device)\n",
    "        effect_index = var_names2.index(effect_var)\n",
    "        preds0 = inf.forward(all_data2, int_nodes_vals0)\n",
    "        preds1 = inf.forward(all_data2, int_nodes_vals1)\n",
    "        ATE_pred = (preds1[:,effect_index,:] - preds0[:,effect_index,:]).mean(0)\n",
    "        eATE = np.abs(ATE_pred - ATE)\n",
    "        preds = model2_cfcn(val_data.to(device)).detach().cpu()\n",
    "        mse_y_2s_CFCN.append(((val_data[:,effect_index,:] - preds[:,effect_index,:])**2).mean())\n",
    "        est_ATE_2s_CFCN.append(ATE_pred)\n",
    "\n",
    "        print('CFCN2 ATE:', ATE_pred)\n",
    "        print('CFCN2 MSE:', ((val_data[:,effect_index,:] - preds[:,effect_index,:])**2).mean())\n",
    "\n",
    "\n",
    "    if test_CAT:\n",
    "        print('Training CaT on graph 2...')\n",
    "        model2 = CaT(input_dim=input_dim,\n",
    "                        dropout_rate=dropout_rate_cat,\n",
    "                        head_size=head_size,\n",
    "                        num_heads=num_heads,\n",
    "                        ff_n_embed=ff_n_embed,\n",
    "                        dag=DAGnx2,\n",
    "                        causal_ordering=causal_ordering2,\n",
    "                        n_layers=n_layers,\n",
    "                        device=device,\n",
    "                        var_types=var_types2,\n",
    "                        use_batch_norm=False,\n",
    "                        embed_dim=embed_dim\n",
    "                        ).to(device)\n",
    "        train_model(model2, train_data, val_data, device, shuffling=0, max_iters=max_iters, eval_interval=eval_interval, eval_iters=eval_iters, learning_rate=learning_rate_cat, batch_size=batch_size)\n",
    "        model2.eval()\n",
    "        inf = CausalInference(model=model2, device=device)\n",
    "        effect_index = var_names2.index(effect_var)\n",
    "        preds0 = inf.forward(all_data2, int_nodes_vals0)\n",
    "        preds1 = inf.forward(all_data2, int_nodes_vals1)\n",
    "        ATE_pred = (preds1[:,effect_index,:] - preds0[:,effect_index,:]).mean(0)\n",
    "        eATE = np.abs(ATE_pred - ATE)\n",
    "        preds = model2(val_data.to(device)).detach().cpu()\n",
    "        mse_y_2s_CaT.append(((val_data[:,effect_index,:] - preds[:,effect_index,:])**2).mean())\n",
    "        est_ATE_2s_CaT.append(ATE_pred)\n",
    "        print('CAT2 ATE:', ATE_pred)\n",
    "        print('CAT2 MSE:', ((val_data[:,effect_index,:] - preds[:,effect_index,:])**2).mean())\n",
    "    \n",
    "    train_data = all_data3[train_inds]\n",
    "    val_data = all_data3[val_inds]\n",
    "    train_data, val_data = torch.from_numpy(train_data).float(),  torch.from_numpy(val_data).float()\n",
    "    effect_index = var_names3.index(effect_var)\n",
    "    cause_index = var_names3.index(cause_var)\n",
    "    \n",
    "    input_dim = all_data3.shape[2]\n",
    "    \n",
    "    if test_CFCN:\n",
    "        print('Training CFCN on graph 3 (true graph)...')\n",
    "        model3_cfcn = CFCN(neurons_per_layer=neurons_per_layer, dag=DAGnx3, causal_ordering=causal_ordering3, var_types=var_types3, dropout_rate=dropout_rate_cfcn).to(device)\n",
    "        train_model(model3_cfcn, train_data, val_data, device, shuffling=shuffling, max_iters=max_iters_cfcn, eval_interval=eval_interval, eval_iters=eval_iters, learning_rate=learning_rate_cfcn, batch_size=batch_size, use_scheduler=False)\n",
    "        model3_cfcn.eval()\n",
    "        inf = CausalInference(model=model3_cfcn, device=device)\n",
    "        effect_index = var_names3.index(effect_var)\n",
    "        preds0 = inf.forward(all_data3, int_nodes_vals0)\n",
    "        preds1 = inf.forward(all_data3, int_nodes_vals1)\n",
    "        ATE_pred = (preds1[:,effect_index,:] - preds0[:,effect_index,:]).mean(0)\n",
    "        eATE = np.abs(ATE_pred - ATE)\n",
    "        preds = model3_cfcn(val_data.to(device)).detach().cpu()\n",
    "        mse_y_3s_CFCN.append(((val_data[:,effect_index,:] - preds[:,effect_index,:])**2).mean())\n",
    "        est_ATE_3s_CFCN.append(ATE_pred)\n",
    "        print('CFCN3 ATE:', ATE_pred)\n",
    "        print('CFCN3 MSE:', ((val_data[:,effect_index,:] - preds[:,effect_index,:])**2).mean())\n",
    "    \n",
    "    if test_CAT:\n",
    "        print('Training CaT on graph 3 (true graph)...')\n",
    "        model3 = CaT(input_dim=input_dim,\n",
    "                        dropout_rate=dropout_rate_cat,\n",
    "                        head_size=head_size,\n",
    "                        num_heads=num_heads,\n",
    "                        ff_n_embed=ff_n_embed,\n",
    "                        dag=DAGnx3,\n",
    "                        causal_ordering=causal_ordering3,\n",
    "                        n_layers=n_layers,\n",
    "                        device=device,\n",
    "                        var_types=var_types3,\n",
    "                        use_batch_norm=False,\n",
    "                        embed_dim=embed_dim\n",
    "                        ).to(device)\n",
    "        \n",
    "        train_model(model3, train_data, val_data, device, shuffling=0, max_iters=max_iters, eval_interval=eval_interval, eval_iters=eval_iters, learning_rate=learning_rate_cat, batch_size=batch_size)\n",
    "        model3.eval()\n",
    "        inf = CausalInference(model=model3, device=device)\n",
    "        \n",
    "        int_nodes_vals0 = {'D':np.array([0.0,])}\n",
    "        int_nodes_vals1 = {'D':np.array([1.0,])}\n",
    "        effect_var = 'Y'\n",
    "        effect_index = var_names3.index(effect_var)\n",
    "        \n",
    "        preds0 = inf.forward(all_data3, int_nodes_vals0)\n",
    "        preds1 = inf.forward(all_data3, int_nodes_vals1)\n",
    "        ATE_pred = (preds1[:,effect_index,:] - preds0[:,effect_index,:]).mean(0)\n",
    "        eATE = np.abs(ATE_pred - ATE)\n",
    "        preds = model3(val_data.to(device)).detach().cpu()\n",
    "        mse_y_3s_CaT.append(((val_data[:,effect_index,:] - preds[:,effect_index,:])**2).mean())\n",
    "        est_ATE_3s_CaT.append(ATE_pred)\n",
    "        print('ATE:', ATE, 'est ATE:', ATE_pred, 'error:', eATE)\n",
    "        \n",
    "    \n",
    "    if test_RF:\n",
    "        print('Training RF...')\n",
    "        estimated_ATE, mse, RF = apply_random_forest(train_data=train_data, val_data=val_data, all_data=all_data3,  cause_index=cause_index, effect_index=effect_index)\n",
    "        mse_y_RF.append(mse)\n",
    "        est_ATE_RF.append(estimated_ATE)\n",
    "    if test_MLP:\n",
    "        print('Training MLP...')\n",
    "        estimated_ATE, mse, MLP = apply_mlp(train_data=train_data, val_data=val_data, all_data=all_data3, cause_index=cause_index, effect_index=effect_index)\n",
    "        mse_y_MLP.append(mse)\n",
    "        est_ATE_MLP.append(estimated_ATE)\n",
    "\n",
    "    if test_transformer:\n",
    "        print('Training transformer...')\n",
    "        estimated_ATE, mse, transformer = apply_transformer(train_data=train_data, val_data=val_data, device='cpu', max_iters=max_iters, all_data=all_data3, cause_index=cause_index, effect_index=effect_index, batch_size=batch_size)\n",
    "        mse_y_transformer.append(mse)\n",
    "        est_ATE_transformer.append(estimated_ATE)\n",
    "\n",
    "\n",
    "    \n"
   ],
   "id": "2a3aae80-82a7-490f-bebc-f612a862f024",
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[2.25]\n",
      "Simulation: 0\n",
      "ATE sample: 2.25\n",
      "Training CFCN on graph 1...\n",
      "step 0 of 20000: train_loss 18.7916, val_loss 18.4226\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/matthewvowels/GitHub/Causal_Transformer/utils/inference.py:50: UserWarning: No mask has been specified. If padding has been used, the absence of a mask may lead to incorrect results.\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "CFCN1 ATE: [-0.08235398]\n",
      "CFCN1 MSE: tensor(0.5821)\n",
      "Training CaT on graph 1...\n",
      "step 0 of 6000: train_loss 39.2027, val_loss 40.5364\n",
      "CAT1 ATE: [-0.09017182]\n",
      "CAT1 MSE: tensor(0.5546)\n",
      "Training CFCN on graph 2...\n",
      "Training CFCN on graph 2...\n",
      "step 0 of 20000: train_loss 19.0518, val_loss 20.0333\n",
      "CFCN2 ATE: [0.97038542]\n",
      "CFCN2 MSE: tensor(0.5735)\n",
      "Training CaT on graph 2...\n",
      "step 0 of 6000: train_loss 72.4658, val_loss 73.5448\n",
      "CAT2 ATE: [0.80587636]\n",
      "CAT2 MSE: tensor(0.5552)\n",
      "Training CFCN on graph 3 (true graph)...\n",
      "step 0 of 20000: train_loss 39.1829, val_loss 39.1786\n",
      "CFCN3 ATE: [2.29954612]\n",
      "CFCN3 MSE: tensor(1.0386)\n",
      "Training CaT on graph 3 (true graph)...\n",
      "step 0 of 6000: train_loss 58.4891, val_loss 60.3794\n",
      "ATE: [2.25] est ATE: [2.25040048] error: [0.00040048]\n",
      "Training RF...\n",
      "RF MSE on validation set: 0.6214112434878913\n",
      "RF Estimated ATE: -0.07391231739152695\n",
      "Training MLP...\n",
      "MLP MSE on validation set: 0.55901724\n",
      "MLP Estimated ATE: -0.0803223966733916\n",
      "Training transformer...\n",
      "Iteration 0/6000, Loss: 17.3895\n",
      "Transformer MSE on validation set: 0.6166235\n",
      "Transformer Estimated ATE: -0.10567958\n"
     ]
    }
   ],
   "execution_count": 59
  },
  {
   "cell_type": "code",
   "id": "989c6b8f-9cc1-4fbb-aa08-526c2785c3c8",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-10-04T20:02:10.469450Z",
     "start_time": "2024-10-04T20:02:10.467467Z"
    }
   },
   "source": "",
   "outputs": [],
   "execution_count": 3
  },
  {
   "cell_type": "code",
   "id": "9de90f125710969f",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-10-04T20:02:10.472873Z",
     "start_time": "2024-10-04T20:02:10.471219Z"
    }
   },
   "source": "",
   "outputs": [],
   "execution_count": 3
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-10-04T20:02:10.477526Z",
     "start_time": "2024-10-04T20:02:10.473781Z"
    }
   },
   "cell_type": "code",
   "source": [
    "if mse_y_1s_CFCN:\n",
    "    mse_y_1s_CFCN = [mse.item() for mse in mse_y_1s_CFCN]\n",
    "if mse_y_2s_CFCN:\n",
    "    mse_y_2s_CFCN = [mse.item() for mse in mse_y_2s_CFCN]\n",
    "if mse_y_3s_CFCN:\n",
    "    mse_y_3s_CFCN = [mse.item() for mse in mse_y_3s_CFCN]\n",
    "\n",
    "if mse_y_1s_CaT:\n",
    "    mse_y_1s_CaT = [mse.item() for mse in mse_y_1s_CaT]\n",
    "if mse_y_2s_CaT:\n",
    "    mse_y_2s_CaT = [mse.item() for mse in mse_y_2s_CaT]\n",
    "if mse_y_3s_CaT:\n",
    "    mse_y_3s_CaT = [mse.item() for mse in mse_y_3s_CaT]"
   ],
   "id": "1fc3dd85cf601c30",
   "outputs": [],
   "execution_count": 4
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-10-04T20:02:10.492381Z",
     "start_time": "2024-10-04T20:02:10.478394Z"
    }
   },
   "cell_type": "code",
   "source": [
    "\n",
    "# Convert CFCN and CaT ATE to float\n",
    "if est_ATE_1s_CFCN:\n",
    "    est_ATE_1s_CFCN = [ate[0] for ate in est_ATE_1s_CFCN]\n",
    "    ate_errors_CFCN_1s = np.abs(np.asarray(est_ATE_1s_CFCN) - ATE_samples)\n",
    "if est_ATE_2s_CFCN:\n",
    "    est_ATE_2s_CFCN = [ate[0] for ate in est_ATE_2s_CFCN]\n",
    "    ate_errors_CFCN_2s = np.abs(np.asarray(est_ATE_2s_CFCN) - ATE_samples)\n",
    "if est_ATE_3s_CFCN:\n",
    "    est_ATE_3s_CFCN = [ate[0] for ate in est_ATE_3s_CFCN]\n",
    "    ate_errors_CFCN_3s = np.abs(np.asarray(est_ATE_3s_CFCN) - ATE_samples)\n",
    "\n",
    "if est_ATE_1s_CaT:\n",
    "    est_ATE_1s_CaT = [ate[0] for ate in est_ATE_1s_CaT] #\n",
    "    ate_errors_CaT_1s = np.abs(np.asarray(est_ATE_1s_CaT) - ATE_samples)\n",
    "if est_ATE_2s_CaT:\n",
    "    est_ATE_2s_CaT = [ate[0] for ate in est_ATE_2s_CaT]\n",
    "    ate_errors_CaT_2s = np.abs(np.asarray(est_ATE_2s_CaT) - ATE_samples)\n",
    "if est_ATE_3s_CaT:\n",
    "    est_ATE_3s_CaT = [ate[0] for ate in est_ATE_3s_CaT]\n",
    "    ate_errors_CaT_3s = np.abs(np.asarray(est_ATE_3s_CaT) - ATE_samples)\n",
    "\n",
    "if est_ATE_RF:\n",
    "    ate_errors_RF = np.abs(np.asarray(est_ATE_RF) - ATE_samples)\n",
    "if est_ATE_transformer:\n",
    "    ate_errors_transformer = np.abs(np.asarray(est_ATE_transformer) - ATE_samples)\n",
    "if est_ATE_MLP:\n",
    "    ate_errors_MLP = np.abs(np.asarray(est_ATE_MLP) - ATE_samples)"
   ],
   "id": "da1955823080d97",
   "outputs": [],
   "execution_count": 5
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-10-04T20:02:10.508350Z",
     "start_time": "2024-10-04T20:02:10.493399Z"
    }
   },
   "cell_type": "code",
   "source": [
    "\n",
    "model_data = {\n",
    "    'Model': [],\n",
    "    'MSE Mean': [],\n",
    "    'MSE Std': [],\n",
    "    'ATE Error Mean': [],\n",
    "    'ATE Error Std': []\n",
    "}\n",
    "\n",
    "# Append data only if the corresponding method was tested and the lists are not empty\n",
    "if test_CAT:\n",
    "    if mse_y_1s_CaT:\n",
    "        model_data['Model'].append('CaT False DAG 1')\n",
    "        model_data['MSE Mean'].append(np.mean(mse_y_1s_CaT))\n",
    "        model_data['MSE Std'].append(np.std(mse_y_1s_CaT))\n",
    "        model_data['ATE Error Mean'].append(np.mean(ate_errors_CaT_1s))\n",
    "        model_data['ATE Error Std'].append(np.std(ate_errors_CaT_1s))\n",
    "\n",
    "    if mse_y_2s_CaT:\n",
    "        model_data['Model'].append('CaT False DAG 2')\n",
    "        model_data['MSE Mean'].append(np.mean(mse_y_2s_CaT))\n",
    "        model_data['MSE Std'].append(np.std(mse_y_2s_CaT))\n",
    "        model_data['ATE Error Mean'].append(np.mean(ate_errors_CaT_2s))\n",
    "        model_data['ATE Error Std'].append(np.std(ate_errors_CaT_2s))\n",
    "\n",
    "    if mse_y_3s_CaT:\n",
    "        model_data['Model'].append('CaT True DAG')\n",
    "        model_data['MSE Mean'].append(np.mean(mse_y_3s_CaT))\n",
    "        model_data['MSE Std'].append(np.std(mse_y_3s_CaT))\n",
    "        model_data['ATE Error Mean'].append(np.mean(ate_errors_CaT_3s))\n",
    "        model_data['ATE Error Std'].append(np.std(ate_errors_CaT_3s))\n",
    "\n",
    "if test_CFCN:\n",
    "    if mse_y_1s_CFCN:\n",
    "        model_data['Model'].append('CFCN False DAG 1')\n",
    "        model_data['MSE Mean'].append(np.mean(mse_y_1s_CFCN))\n",
    "        model_data['MSE Std'].append(np.std(mse_y_1s_CFCN))\n",
    "        model_data['ATE Error Mean'].append(np.mean(ate_errors_CFCN_1s))\n",
    "        model_data['ATE Error Std'].append(np.std(ate_errors_CFCN_1s))\n",
    "\n",
    "    if mse_y_2s_CFCN:\n",
    "        model_data['Model'].append('CFCN False DAG 2')\n",
    "        model_data['MSE Mean'].append(np.mean(mse_y_2s_CFCN))\n",
    "        model_data['MSE Std'].append(np.std(mse_y_2s_CFCN))\n",
    "        model_data['ATE Error Mean'].append(np.mean(ate_errors_CFCN_2s))\n",
    "        model_data['ATE Error Std'].append(np.std(ate_errors_CFCN_2s))\n",
    "\n",
    "    if mse_y_3s_CFCN:\n",
    "        model_data['Model'].append('CFCN True DAG')\n",
    "        model_data['MSE Mean'].append(np.mean(mse_y_3s_CFCN))\n",
    "        model_data['MSE Std'].append(np.std(mse_y_3s_CFCN))\n",
    "        model_data['ATE Error Mean'].append(np.mean(ate_errors_CFCN_3s))\n",
    "        model_data['ATE Error Std'].append(np.std(ate_errors_CFCN_3s))\n",
    "\n",
    "if test_RF and mse_y_RF:\n",
    "    model_data['Model'].append('Rand. Forest')\n",
    "    model_data['MSE Mean'].append(np.mean(mse_y_RF))\n",
    "    model_data['MSE Std'].append(np.std(mse_y_RF))\n",
    "    model_data['ATE Error Mean'].append(np.mean(ate_errors_RF))\n",
    "    model_data['ATE Error Std'].append(np.std(ate_errors_RF))\n",
    "\n",
    "if test_transformer and mse_y_transformer:\n",
    "    model_data['Model'].append('Transformer')\n",
    "    model_data['MSE Mean'].append(np.mean(mse_y_transformer))\n",
    "    model_data['MSE Std'].append(np.std(mse_y_transformer))\n",
    "    model_data['ATE Error Mean'].append(np.mean(ate_errors_transformer))\n",
    "    model_data['ATE Error Std'].append(np.std(ate_errors_transformer))\n",
    "\n",
    "if test_MLP and mse_y_MLP:\n",
    "    model_data['Model'].append('MLP')\n",
    "    model_data['MSE Mean'].append(np.mean(mse_y_MLP))\n",
    "    model_data['MSE Std'].append(np.std(mse_y_MLP))\n",
    "    model_data['ATE Error Mean'].append(np.mean(ate_errors_MLP))\n",
    "    model_data['ATE Error Std'].append(np.std(ate_errors_MLP))\n",
    "\n",
    "df = pd.DataFrame(model_data)"
   ],
   "id": "c84d30fefa35ff46",
   "outputs": [],
   "execution_count": 6
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-10-04T20:02:10.533766Z",
     "start_time": "2024-10-04T20:02:10.509363Z"
    }
   },
   "cell_type": "code",
   "source": "df",
   "id": "7d9fe7af14690757",
   "outputs": [
    {
     "data": {
      "text/plain": [
       "              Model  MSE Mean   MSE Std  ATE Error Mean  ATE Error Std\n",
       "0   CaT False DAG 1  0.554363  0.003383        2.321087       0.006777\n",
       "1   CaT False DAG 2  0.555320  0.003520        1.372839       0.088711\n",
       "2      CaT True DAG  1.002963  0.006803        0.057658       0.037502\n",
       "3  CFCN False DAG 1  0.566993  0.014096        2.319929       0.013185\n",
       "4  CFCN False DAG 2  0.568137  0.013751        1.394440       0.218754\n",
       "5     CFCN True DAG  1.022626  0.014175        0.125140       0.313684\n",
       "6      Rand. Forest  0.621992  0.003876        2.311071       0.011955\n",
       "7       Transformer  0.614524  0.011974        2.378930       0.056684\n",
       "8               MLP  0.559406  0.005690        2.325352       0.013109"
      ],
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>Model</th>\n",
       "      <th>MSE Mean</th>\n",
       "      <th>MSE Std</th>\n",
       "      <th>ATE Error Mean</th>\n",
       "      <th>ATE Error Std</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>CaT False DAG 1</td>\n",
       "      <td>0.554363</td>\n",
       "      <td>0.003383</td>\n",
       "      <td>2.321087</td>\n",
       "      <td>0.006777</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>CaT False DAG 2</td>\n",
       "      <td>0.555320</td>\n",
       "      <td>0.003520</td>\n",
       "      <td>1.372839</td>\n",
       "      <td>0.088711</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>CaT True DAG</td>\n",
       "      <td>1.002963</td>\n",
       "      <td>0.006803</td>\n",
       "      <td>0.057658</td>\n",
       "      <td>0.037502</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>CFCN False DAG 1</td>\n",
       "      <td>0.566993</td>\n",
       "      <td>0.014096</td>\n",
       "      <td>2.319929</td>\n",
       "      <td>0.013185</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>CFCN False DAG 2</td>\n",
       "      <td>0.568137</td>\n",
       "      <td>0.013751</td>\n",
       "      <td>1.394440</td>\n",
       "      <td>0.218754</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>CFCN True DAG</td>\n",
       "      <td>1.022626</td>\n",
       "      <td>0.014175</td>\n",
       "      <td>0.125140</td>\n",
       "      <td>0.313684</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>Rand. Forest</td>\n",
       "      <td>0.621992</td>\n",
       "      <td>0.003876</td>\n",
       "      <td>2.311071</td>\n",
       "      <td>0.011955</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>Transformer</td>\n",
       "      <td>0.614524</td>\n",
       "      <td>0.011974</td>\n",
       "      <td>2.378930</td>\n",
       "      <td>0.056684</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>MLP</td>\n",
       "      <td>0.559406</td>\n",
       "      <td>0.005690</td>\n",
       "      <td>2.325352</td>\n",
       "      <td>0.013109</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "execution_count": 7
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-10-05T08:13:24.469016Z",
     "start_time": "2024-10-05T08:13:24.458746Z"
    }
   },
   "cell_type": "code",
   "source": [
    "# Plotting ATE Error Boxplot\n",
    "ate_error_data = []\n",
    "ate_error_labels = []\n",
    "\n",
    "if test_CAT:\n",
    "    if ate_errors_CaT_1s is not None:\n",
    "        ate_error_data.append(ate_errors_CaT_1s)\n",
    "        ate_error_labels.append('CaT False DAG 1')\n",
    "    if ate_errors_CaT_2s is not None:\n",
    "        ate_error_data.append(ate_errors_CaT_2s)\n",
    "        ate_error_labels.append('CaT False DAG 2')\n",
    "    if ate_errors_CaT_3s is not None:\n",
    "        ate_error_data.append(ate_errors_CaT_3s)\n",
    "        ate_error_labels.append('CaT True DAG')\n",
    "\n",
    "if test_CFCN:\n",
    "    if ate_errors_CFCN_1s is not None:\n",
    "        ate_error_data.append(ate_errors_CFCN_1s)\n",
    "        ate_error_labels.append('CFCN False DAG 1')\n",
    "    if ate_errors_CFCN_2s is not None:\n",
    "        ate_error_data.append(ate_errors_CFCN_2s)\n",
    "        ate_error_labels.append('CFCN False DAG 2')\n",
    "    if ate_errors_CFCN_3s is not None:\n",
    "        ate_error_data.append(ate_errors_CFCN_3s)\n",
    "        ate_error_labels.append('CFCN True DAG')\n",
    "\n",
    "if test_RF:\n",
    "    ate_error_data.append(ate_errors_RF)\n",
    "    ate_error_labels.append('Rand. Forest')\n",
    "\n",
    "if test_transformer:\n",
    "    ate_error_data.append(ate_errors_transformer)\n",
    "    ate_error_labels.append('Transformer')\n",
    "\n",
    "if test_MLP:\n",
    "    ate_error_data.append(ate_errors_MLP)\n",
    "    ate_error_labels.append('MLP')\n",
    "    \n",
    "    \n",
    "    \n",
    "# Plotting MSE Boxplot\n",
    "mse_data = []\n",
    "mse_labels = []\n",
    "\n",
    "if test_CAT:\n",
    "    if mse_y_1s_CaT:\n",
    "        mse_data.append(mse_y_1s_CaT)\n",
    "        mse_labels.append('CaT False DAG 1')\n",
    "    if mse_y_2s_CaT:\n",
    "        mse_data.append(mse_y_2s_CaT)\n",
    "        mse_labels.append('CaT False DAG 2')\n",
    "    if mse_y_3s_CaT:\n",
    "        mse_data.append(mse_y_3s_CaT)\n",
    "        mse_labels.append('CaT True DAG')\n",
    "\n",
    "if test_CFCN:\n",
    "    if mse_y_1s_CFCN:\n",
    "        mse_data.append(mse_y_1s_CFCN)\n",
    "        mse_labels.append('CFCN False DAG 1')\n",
    "    if mse_y_2s_CFCN:\n",
    "        mse_data.append(mse_y_2s_CFCN)\n",
    "        mse_labels.append('CFCN False DAG 2')\n",
    "    if mse_y_3s_CFCN:\n",
    "        mse_data.append(mse_y_3s_CFCN)\n",
    "        mse_labels.append('CFCN True DAG')\n",
    "\n",
    "if test_RF:\n",
    "    mse_data.append(mse_y_RF)\n",
    "    mse_labels.append('Rand. Forest')\n",
    "\n",
    "if test_transformer:\n",
    "    mse_data.append(mse_y_transformer)\n",
    "    mse_labels.append('Transformer')\n",
    "\n",
    "if test_MLP:\n",
    "    mse_data.append(mse_y_MLP)\n",
    "    mse_labels.append('MLP')\n",
    "    \n",
    "    \n",
    "df.to_csv('mse_eate_results_motivating_example.csv')\n",
    "\n",
    "\n",
    "# Function to combine mean and std into the desired format\n",
    "df['MSE'] = df.apply(lambda row: f\"{row['MSE Mean']:.3f} (± {row['MSE Std']:.3f})\", axis=1)\n",
    "df['ATE'] = df.apply(lambda row: f\"{row['ATE Error Mean']:.3f} (± {row['ATE Error Std']:.3f})\", axis=1)\n",
    "\n",
    "# Select the relevant columns in the desired format\n",
    "df_formatted = df[['Model', 'MSE', 'ATE']]\n",
    "\n",
    "df_formatted.to_csv('mse_eate_results_motivating_example_formatted.csv', index=False)"
   ],
   "id": "d46340df84f8b0c0",
   "outputs": [],
   "execution_count": 17
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-10-05T08:13:59.221607Z",
     "start_time": "2024-10-05T08:13:58.705616Z"
    }
   },
   "cell_type": "code",
   "source": [
    "\n",
    "plt.figure(figsize=(12, 6))\n",
    "plt.boxplot(ate_error_data, labels=ate_error_labels)\n",
    "plt.axhline(y=0, color='r', linestyle='--', label='True ATE')\n",
    "plt.title('Absolute ATE Error for Different Models')\n",
    "plt.ylabel('ATE Error')\n",
    "plt.grid(True)\n",
    "plt.xticks(rotation=45) \n",
    "plt.tight_layout()\n",
    "plt.savefig(ate_figname)\n",
    "plt.show()\n",
    "\n",
    "\n",
    "plt.figure(figsize=(12, 6))\n",
    "plt.boxplot(mse_data, labels=mse_labels)\n",
    "plt.title('MSE for Different Models')\n",
    "plt.ylabel('MSE')\n",
    "plt.grid(True)\n",
    "plt.ylim(0,1.2)\n",
    "plt.xticks(rotation=45) \n",
    "plt.tight_layout()\n",
    "plt.savefig(mse_figname)\n",
    "plt.show()"
   ],
   "id": "11b6843040636bdf",
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_152074/665083340.py:2: MatplotlibDeprecationWarning: The 'labels' parameter of boxplot() has been renamed 'tick_labels' since Matplotlib 3.9; support for the old name will be dropped in 3.11.\n",
      "  plt.boxplot(ate_error_data, labels=ate_error_labels)\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 1200x600 with 1 Axes>"
      ],
      "image/png": "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OaeVL1/eSDI//PBDmtd3u3379sV7LxtjTFBQkAkKCorXTpIZNGhQvGlxOfz3+/6JJ54wJUuWNJcuXYo3/eGHHzb58+d35iGp3DgcDlOlShXTvn1743A4nNOjoqJMxYoVTdu2bZ3T4t4Hjz/+eLx13XfffaZw4cLxpvn5+Zng4OAkX4uktu3QoUNGktm8ebMxxphp06aZvHnzmmvXriV4fVO6n9+8edMUK1bM1KlTx0RHRzvbffrpp0ZSvNd/7ty5xsPDw7n+ONOnTzeSzNatW53TypcvH28ba9eubTp37pyibQYAIL24fA8AgBSYP3++ihcvrlatWkmS805yX375pWJjYxO07969u0qXLu183LBhQzVq1EgrVqyQJOcYQRs2bEjyUrg1a9bo5s2bGjp0aLzxcvr37698+fLp+++/z8hNTOCbb75R/vz51bZtW126dMn5FxgYqLx582r9+vX/+Rzz589X/fr1nQPC+/v7q3Pnzum6hO+pp55SSEhIgr/q1aunaPlvv/02wbKzZs1K0C44ODjJcZcGDhwY7/GKFSvk6emp5557Lt704cOHyxijlStXxpseFBSU4ngTE/c+GjZsWIL1SUrw3qhYsaLat2+f5vXdLq53U0RERIY8nzFG3377re69914ZY+K919q3b6+rV69q79698Zb5d27279+vsLAwPfLII/rzzz+dy1+7dk333HOPNm3alOCugU8//XS8x82bN9eff/7pvBQwPWrUqKG77rpLX3zxhSRpwYIF6tatm3x9fRO0Tel+vnv3bl24cEFPP/10vDG8+vbtq/z588d7zm+++UbVqlVTQEBAvNezdevWkpTsvlugQAEdPnxYYWFhaX8BAABIIS7fAwDgP8TGxurLL79Uq1atdPz4cef0Ro0aadKkSVq7dq3atWsXb5kqVaokeJ6qVavq66+/lnTr7mbvvvuuhg8fruLFi6tx48bq0qWL+vTp47ys7eTJk5KU4FKr3Llz64477nDOzyxhYWG6evWqihUrluj8CxcuJLv8lStXtGLFCg0ePFi//PKLc3qzZs307bff6tixY4le/vVfqlSpojZt2qR6uTgtWrRI0UDnFStWTHR6rly5VKZMmXjTTp48qVKlSjnvKhinWrVqzvkpee6UOnnypDw8PBLc/bFEiRIqUKBAhq/vdpGRkZKUYFvT6uLFi7py5Yo+/fRTffrpp4m2+fd77d/bE1dAiRtAPzFXr15VwYIFnY/LlSsXb37cvMuXL8e7s2BaPfLII5o0aZKef/55bdu2TS+99FKi7VK6n8f9++9ji5eXl+64445408LCwnTkyBEVLVo00XUmt+++8cYb6tatm6pWraqaNWuqQ4cOeuyxx3TXXXcls7UAAKQNRSkAAP7DunXrdPbsWX355Zf68ssvE8yfP39+gqJUSgwdOlT33nuvlixZolWrVunVV1/V+PHjtW7dOtWtWzddMd8+WPntEuvVlRSHw6FixYol2aspqS+8cb755htFR0dr0qRJmjRpUoL58+fP19ixY1Mcj9WS6iXl7e2d7ju9JXfnu9RIKs+ZtT5JzgH7/10QS6u4Hky9e/dOsqj074LIv7cn7jkmTJigOnXqJPoccT284nh6eibazvxrYPq06tWrl/NOhYULF07TMSKtHA6HatWqpcmTJyc6//bxp/6tRYsW+vXXX7V06VKtXr1aM2fO1JQpUzR9+nQ9+eSTmRUyAMBNUZQCAOA/zJ8/X8WKFXPepe52ixYt0uLFizV9+vR4X5QTu/Tl2LFjCQa0rlSpkoYPH67hw4crLCxMderU0aRJkzRv3jznncqOHj0aryfEzZs3dfz48WR7C8X1+vj33bsS612VVGGjUqVKWrNmjZo1a5amosb8+fNVs2ZNjRkzJsG8GTNmaMGCBVm6KJUa5cuX15o1axQRERGvB1FoaKhzfkavz+FwKCwszNkbS7o1YPiVK1cyfH23mzt3rmw2W4YNel20aFH5+/srNjY2zT3g4gYgz5cvX7p60f1bSot+iSlXrpyaNWumDRs2aODAgUkOwp/S/TyuXVhYmPMyPOnW3fKOHz+u2rVrO6dVqlRJBw4c0D333JOmbShUqJD69eunfv36KTIyUi1atNDrr79OUQoAkOEYUwoAgGRcv35dixYtUpcuXdSzZ88Ef4MHD1ZERISWLVsWb7klS5bozJkzzse7du3Szp071bFjR0m37iB348aNeMtUqlRJ/v7+zlu2t2nTRrlz59aHH34Yr/fG//73P129elWdO3dOMu7y5cvL09NTmzZtijf9448/TtDWz89PUsIC1oMPPqjY2FiNGzcuwTIxMTGJ3q4+zu+//65NmzbpwQcfTPR169evn3755Rft3LkzyefITjp16qTY2FhNnTo13vQp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qRwortfFc889p169eunDDz9Ur169NHXqVIWHh+u7775zdYhIo7Nnz+rRRx9Vnz59NG7cOJUrV06S9N5776lVq1b65JNPGJcmm/Lx8VGDBg1kt9t18+ZNhYeHS+KH4ZysSZMmKlKkiHbv3q2jR486L7mGax06dEhNmzbVs88+q5CQEIWFhenVV1/V7Nmz9dNPP7k6PJeiKIVM5+XlpV69eqlz58568MEHNWrUKBUtWjReYcrDw4MPxhzi+vXrKliwoDp16iRJzss5WrZsyWUA2djFixd19uxZde/e3VlkmDt3rl566SUtWLBADodD48eP16pVq1wcKazm7++v+vXrq0uXLhozZowefPBBhYaGJlmY4lifvZ09e1bFihXTfffdJ+nWD09eXl7q2rWrIiIiJDGmWHa0Z88eeXh46KmnnnLm7+2339Ybb7yhxx57TF999ZVmzJhBYSobiTvWhoeHq3r16tq6das++OAD9e/f39nTGTnXjh071LhxY7377rvaunUrx2UX+/PPP9WyZUsFBgZq5MiR8vb2liQ9//zzKlasmH799VcXR+haFKVgiUaNGumpp56SJDVo0EAvvPBCgsJUbGys9u7d68owkQGKFCmiPn366IEHHpAk5y8zRYoUkXTrJCnuRIlrqLOPn376Sb/88osaNmzoHJegffv22rp1qx5++GEtW7ZM169f1+jRoxUaGuriaGG1kSNHqnfv3pKk5557Tg888ICzMHXx4kV5eHgoOjpasbGx/FqbzZUrV07333+/WrduLUnKlSuXJMnT01OXLl2S9M9xnwJk9rF582ZduXJFAQEBzmP8HXfcoUWLFumTTz7RK6+8os8//1yTJk3SlStXXBss/pMxxjnQ9eDBg7Vv3z41btxYTzzxhN555x0999xz+uSTT5z76ueff86PStlU3HF29+7d+vjjjzV16lStWLFCkrRt2zaVKFFCjz/+uLZv305hyoUKFy6sBx54QBcuXNCMGTOcl+v9+uuvunDhgrN3qruiKAVLxR04GzVqpBEjRjgLUwsXLtSwYcNUv359XblyhRPZbCoub4GBgc7HcSe3V65c0fnz552X740dO1a9evXStWvXXBYvUq5IkSLy8vLS2rVrnSc1xYoVU5MmTRQTE6PChQtr+PDhkiQ/Pz9XhgoXsdlsiomJkc1m09ChQ9WzZ0+FhobqxRdf1JkzZ/Tss8+qVatWkihWZFfGGPn7+6tHjx7Ox3Ffau12u/N4brPZNH78eL3wwgsuixWpU6RIEdntdp04ccK5fz788MNq166dJKl///5q27atDh48qLx587oyVKSAzWbTokWL9NBDD6ly5coqXbq0bDabfH19NXToUL311lsaNGiQhgwZokGDBmngwIGqWLGiq8NGGthsNn377bfq1KmTli5dqjVr1qhnz5566623JEm7du1SoUKF1L9/f23atInClAvEveaffPKJ2rdvr8mTJ2vlypXat2+funTpooEDB6pjx44ujtK1crk6ALiX238hb9y4sV544QVNnDhRffv2Ve7cubVz504VKFDAdQEiXf7dA+L2x97e3sqTJ4/8/Pz0+uuv6+2339aOHTsoYGRxcV86GzVqpDJlyuiTTz7R3Xff7ez5Jv3TU2LHjh2644472IfdWK5cuZx3Z3v++eedJ8tNmzbV5cuXFRISIinhsQLZQ3LH+CJFijjHmnv55Zc1ceJE7dy509L4kHbVq1fX2bNntXLlSg0cODDePIfDIWOMfH19Vbt2bb7UZgNHjhzR0KFD9eGHH+rxxx+XdCuPv/zyi0qWLKnRo0erWLFi+vDDD1WsWDFt2bJFVatWdXHUSIvDhw9r8ODBev311/XMM8/o0KFDWrFihc6fP6/Y2Fh5enpq586dqlKlioYPH64tW7bIx8fH1WG7FQ8PD2cuPvjgAxlj9OqrryoiIkL33Xef86YScedP7sg9txoZLrFfvVPyS3ijRo0UExMjLy8vbd68WQ0aNMiM8JDB0pLv/Pnzq0yZMnr++ef1zjvvaPv27apXr15mhYh0uHr1qvPyjLjeLz4+Ppo4caK2bdump556SidOnIjXftSoUZo1a5bGjh0rf39/1wSOTJOank23jyH1zDPP6MaNG4qIiNC2bdvUqFGjzAoRGSgtPdliY2Pl4+OjsWPHavLkydq2bZvq1KmT8cEh3ex2u3MfjYmJkSR17txZ/fr107BhwzRv3jzduHHD2d7hcOiVV17RokWLNHDgQOXOndslcSPlrl27pqJFi6p58+a6fv26pk2bplatWql9+/a69957dfr0aT3xxBPatGmTFi1apLp167o6ZKTR6dOnFRAQoGeeeUYnT55Ux44d9eSTT+rDDz+Up6encwDtsLAwLVy4kIKUxeLG1vX09HT+/8MPP9Rjjz0mh8Oh2rVr6/Lly5LktgUpiZ5SyABxVd0LFy7o6NGjOn/+vLp16yYvL6//XO6NN97QsmXLtGfPHtWoUcOiiJEeac33X3/9pU2bNmn37t3atm0bBaks6sSJE2rWrJlat26tOnXqaPjw4c4PyZYtW2ry5Ml64YUX1KZNGzVu3Fi5c+fW2bNn9dNPP2nt2rXsxzlQ3D5/9epV51/cLaaT4uHhIbvdrhdffFGHDx/Wjh07VLNmTYsiRnqkJd/SrZtczJ49W76+vtqyZYvzMm5kLaGhoXr++efVrFkzPfroo/Eu2Ro+fLguX76sfv36acOGDWrZsqX++usv7d69W8uXL9eaNWt05513ujB6pFRMTIwuXLigt956S5s3b1atWrV09913q1atWhozZozWr1+vxx57TPnz53d1qEgnh8OhmJgY7d69W/fff786deqkjz76SNKtMaXmzJmjF198URUrVuQSTYucPHlSs2bN0ujRo+Xt7e38XI0rTHl6euqtt95SZGSkPvjgA+XKlUsPPfRQvKsQ3I37luOQIeJ2ssOHD6tnz56aOnWqDh06FK9AEVcV/jcPDw917dpVP/30E7+mZhPpyXfJkiV1zz33aPfu3RSksrDdu3fr6tWr6tKli6ZPn677779fo0aN0pUrV1SwYEH1799fGzdu1F133aVff/1Vv/76q+rXr6+NGzfyS2sOFLfPh4aG6vHHH9cLL7yg5cuXS/qnN01Sl/J4eXkpf/782rJli+666y7LYkbapSffFStW1J133qldu3ZRkMqiHA6HZs2apf379ysqKkp169bVO++848xx9erVNXPmTL388stauXKlBgwYoE8++USxsbHaunUrn91ZVNy+eeHCBZ04cULXrl1T48aNNW3aNPn5+enRRx/V5MmT9dZbb+nhhx9W4cKF6e2WTSXWi7Vo0aKKiIhQ27Zt1aZNG82YMcN5t+tvvvlGZ8+eVcGCBa0O1a198803mjdvnsaMGaObN2/G60Hu6enp7KH6wQcf6L777tPo0aO1aNEit7402mYYbRRpFHfyeujQIbVs2VLPPPOM+vbtqzvuuEOStHbtWjVu3Fh+fn7OqvDtbh8gFVlfevMt3brMi1/lsr6GDRuqd+/eeuqppzRz5kytWbNGP/30kx577DG1bdtWd999t7NtTEyMc0wp5Cxx+/zBgwfVtm1bPfHEE+rQoYOaN28u6dalAFWqVInXNg7H9+wnPfmWpMuXL+v69esqVaqU5bEj5bZu3ap7771XP/74o44ePaply5Zp1apVat68uR5++GG1b99enp6eunz5siIjI1WwYEF5eXk5b1+OrCXuWLtkyRKNGTNGkZGR8vPzU4cOHTR8+HAVL148XvtXX31Vc+bM0aZNm1ShQgXXBI00icv1rl279PvvvytXrlzq1q2bJOndd9/V6NGjNX78eHXp0kV58uTR9OnT9dlnn2njxo30VLbIiRMn9NtvvykoKEjvvvuuFi9erJYtW+qtt95S7ty543123v5d6c0339RDDz3k/Ix1SwZIh7Nnz5q77rrLPPPMM/GmT5gwweTKlct07drVREREGGOMiYmJcUWIyEBpzbfD4bA0TqRNXM7mzJljevbsaaKiopzzypUrZ8qXL298fHzMwIEDzSeffOKqMGGhEydOmAoVKpjnn38+3vQpU6aYokWLmunTpzunxcbGWh0eMlha880xPnuIy9OgQYPMq6++aoy5ddy/ePGisdlspnz58qZWrVpmxYoV5sCBA64MFakQEhJi/Pz8zOTJk83Vq1fNiy++aPLkyWO+/PJLZ5uZM2eaxx9/3BQvXtzs3bvXhdEiPZYsWWL8/PxMlSpVTJEiRUzXrl2d80aNGmUCAgKMn5+fCQwMNNWrVzf79u1zXbBu5syZM6ZIkSKmSpUqZunSpSY2Nta88cYbpn79+mbEiBEmOjraGPPPZ2d0dLR56aWXzJQpU1wYddZBUQppEndis2TJEhMYGGiOHDninPfRRx+ZAgUKmGHDhplmzZqZ++67z1mo4MQ1eyLfOVNcfhwOR7xcHTlyxBQvXtx8++23xhhj+vbta0qUKGF+/PFHs2rVKtOoUSNTt25d88cff7gkbmS+uJOmCRMmmI4dO5pz584557333nvG19fX3HvvvaZ69epmxowZznns89kT+c6Zbs/P7f+fMWOGCQgIcE4bOHCgKVmypFm5cqXp06ePKVmypGncuLGJjIwkx1lYTEyMiYmJMf379zdDhgwxxhhz/vx5U6FChQQ/Hq5cudL079/fhIaGuiBSpJfD4TB2u9088MADZs6cOeaPP/4wK1euNGXKlDGtWrVytjt8+LBZt26d2b9/v7lw4YILI3Y/69evNx4eHqZBgwamS5cu5ttvv02yMBUVFWUGDRpkPD09zcGDB10cedbANRdIk7jLMnbu3KmIiAgFBAQ458XGxmrVqlVq2LChvvjiC3300Ue6//77tWzZMrp/Z1PkO2cyf3cFv3z5crzxBgICAjRy5Eh99tln+uyzz7R7926tXLnSOWZU3bp15eHhocKFC7sqdGSyuO7lmzdvlpeXl4oXLy5jjC5fvqy9e/cqJCREpUqV0rRp0zRlyhTFxMTomWee4ZK9bIp850y35+f2/z/11FOaN2+exo4dq+PHj2v16tVauXKl6tSpow4dOmjDhg2qXLmy/Pz8XBE2/kPcZ3dUVJT8/f117do1tWrVSpcuXVLdunXVpUsXTZ06VZK0ZMkS5+V8rVq14rwsm7n9PM3hcChfvnxq0KCBSpYsqRIlSuirr77SQw89pHvuuUdr165V9erVVb16dVeH7ZZatmypvn37au/evfL29nbe/fDll1+WJC1btkwvv/yyXnvtNY0dO1azZs3Srl27uLTybwx0jnTJnz+/Ll68qHPnzjmnDRkyRA0bNpQkPfjgg6pbt65iYmI4ec0ByHfOcfz4cb322mtq3Lixqlatqi5dumjGjBnO+fXr19eBAwcUFhamrVu3OgtSxhgVLVqUglQOZ/4ebjIiIsJZsLDZbCpUqJBmzpyppk2bqkKFChowYIAKFSqkbdu2uTJcpBP5znnOnDmjmTNn6sEHH1Tnzp319ttv69dff5V0K9+9e/fW5MmTtXv3bq1YsUJ16tRxDrLbsmVLlSlTxpXhIxk2m03z5s1T69atdfXqVeXKlUvvv/++GjRooPvuu0/Tpk1zFq2++uor7dq1S7GxsRSksiGbzabFixerefPmuu+++7Rw4UL99ddfznlNmjTRV199pePHjzvPxWG96OhoSdL999+vOnXq6KmnnlLhwoU1YcIELV++XC+//LK6du2qzZs3q27dupo2bZo2b97MzSNuQ1EKqWZuXfYpSbrrrrvk5eWlDz/8UJGRkZLkvKOAw+GQp6enHA5HvJ41yF7Id84TN5DxyZMndffdd+vVV1/VhQsXNHz4cA0ZMkSS1KJFC7Vr107e3t6qVKmSJAavdidx+3yLFi20Y8cOff/99855t3+xKV++vEqXLs0dVLM58p2zHDp0SJ07d9aiRYsUGRmp69ev68MPP1SbNm20e/du2Ww23XvvvSpQoIA6d+7s/NHh34PXI2uJ208jIyP1+eef66GHHlL+/Pk1btw4RUdHKyYmRlOnTlWuXLlkjNFbb72l7du366GHHkr05jPIuuJyvW/fPg0ePFhdu3ZVp06dVKhQIY0aNcr543BcYWr27NmKiorSqVOnXBm2W/n999+1ePFiSf98TjZo0EA7duxQWFiYpk+fruLFi8crTN1zzz3y9vbWzp07KUj9m8WXCyIbihtr4vZBj2/XrVs34+/vbyZMmGCuXr3qnB4VFWVefPFFU7x4ca5hz0bId862f/9+4+fnZ0aOHGnCw8Od08PCwsywYcOMp6enefHFF40xxuzdu9fUq1fPfPXVV64KFxaI2+f//a8xxvz444+maNGiJigoyGzYsCHBci+99JK54447zG+//WZdwEgX8p2z7du3z/j7+5sXXnjBnD592jn9yy+/NPXr1zcFCxY0e/bsMcYYM3nyZFOvXj0+s7OR9evXm/vuu888+OCDznEd7Xa7+eabb0yxYsVM7dq1TY8ePcx9991nChcuzKDm2dju3bvNZ599Zl5++WXntLCwMFOxYkUTFBRkzp4965zucDjM9evXXRGmWzp16pQpXLiwsdlsplOnTuarr74yR48eNcYYs2zZMtO8eXNz4cIF8/PPP5sePXqYVq1ama+//to4HA5z6dIlF0efNVGUQoocPnzYNGrUyLzyyivm7Nmz5saNG855DofD3H333aZAgQKmU6dO5rvvvjPvvvuu6dOnDx+I2RT5zpl+/fVX4+XlZcaOHWuM+edue3FfSk+dOmX69u1rypUrZ3788Udz7do1U61aNfPwww9z98wc7ueffzbPPvus2bdvX4JcL1682OTKlcs0aNDAvP/+++bixYtm2bJlZsCAASZfvnzs89kQ+c6Zjhw5Yry8vMw777xjjEk4EP3KlStNzZo1Tbt27Ux4eLjZtWuXKVCggPnss89cES5SKSYmxvzf//2fKVasmClZsmS8IoTdbje//fabGTx4sOnfv7954403zLFjx1wYLdLi9n22Zs2axmazmQcffDBem19++cXccccdpnXr1vEKz7DOiRMnTP369U2TJk1MvXr1zJNPPmnKly9vZsyYYb766ivTpUsXs2LFCmPMre9Ubdq0MZ06dXLeCAoJUZRCirz77rvmjjvuMDVq1DD33Xef6dGjhzl8+LD566+/jDG3DqIvvPCCqV27tvHx8TF33nmnCQ4ONj///LOLI0dakO+cJzY21kyePNkUKlTIvP76687p//5Cun37duPl5WXmzp3rfExec7aYmBhzzz33GC8vL1O+fHkzaNAgM336dOc8Y4z57rvvTLNmzUzu3LmNt7e3qVixomnTpo356aefXBk60oB850zXr183/fr1M97e3s7bwMfGxia4u+qYMWOMv7+/OXnypDHGmBEjRpjDhw+7ImSkwcWLF81nn31m/Pz8zOOPP+6czg9HOcfMmTPNc889Z65fv27q169vypUrZ3bu3BmvV+uvv/5qChQoYDp37kzuXeTYsWOmR48epnv37mbRokVm8eLFpmXLlqZ79+7GZrOZRo0aOe+2Fxoaan7//XcXR5y12Yz5+6JVIBnr16/Xp59+qrffflsXLlzQhx9+qF27dqlFixZq27atHn74YWfbY8eOqUKFCnI4HMqTJ48Lo0Zake+c6fz585o1a5bmzp2rLl266N1335V06w6KHh4ezvGiSpcurSFDhmjkyJGuDBcWmjZtmq5evapWrVpp+/btmjhxourXr69mzZrp6aefVv78+XXlyhX98ccfOnr0qGrVqqUiRYqoQIECrg4daUC+c6Z169ZpxowZOnbsmKZOnapmzZo5xwKMiYlRrly5dO7cOZUtW1bLli1Tx44dXR0ykhGXu0uXLskYI39/f+XJk0c3b97U559/rpEjR6pXr16aNm2aJOnmzZvKnTt3vGWRPcTl6+zZs7rnnnvUq1cvvfrqq4qIiFC9evVUsGBBffrpp/HG8ztx4oRiYmJUuXJl1wXu5o4eParnn39esbGx+uijj1S6dGkdPHhQb731lh566CH17t2bfTGlXFcPQ3YTFBRk+vbt63y8c+dOU6JECWOz2cx9991nJkyY4OxJY0zCbuPIXsh3znThwgXz1ltvmerVq5tRo0Y5p8f90rZz505Tu3Zts23bNleFCBfYv3+/yZcvn/nhhx+MMcbcuHHDTJw40fj6+pqqVauaiRMnml27drk4SmQU8p2z3P75u3HjRnP//febOnXqmK1btyaY/8UXX5iqVauac+fOWR4nUi4uZ4sXLza1a9c2VapUMaVKlTITJ040p0+fNg6Hw8ycOdMULVrUDB482MXRIiNs27bNDBkyxPTr18/cuHHD2csmPDzcVKpUydSvX9/s37+f8+0s5tixY6Zd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"
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_152074/665083340.py:14: MatplotlibDeprecationWarning: The 'labels' parameter of boxplot() has been renamed 'tick_labels' since Matplotlib 3.9; support for the old name will be dropped in 3.11.\n",
      "  plt.boxplot(mse_data, labels=mse_labels)\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 1200x600 with 1 Axes>"
      ],
      "image/png": "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r2nJkiWaM2cOwVQKEvtae/PmTZUoUULbt2/X1KlT1bVrV/tIZ6Rev/zyiypVqqSxY8dq+/btvC472D///KNatWqpXLlyGjBggNzd3SVJ7733nnLkyKETJ044uELHIpSCJfz8/PTmm29KkipUqKD+/fvfF0xFR0drz549jiwTScDb21sdOnTQyy+/LEn2b2a8vb0l3X2TFPtGiXOoU47ff/9dx48fV8WKFe3zEjRo0EDbt29XmzZttHLlSt26dUv+/v4KDg52cLWw2oABA9S+fXtJUs+ePfXyyy/bg6nLly/LxcVFERERio6O5tvaFK5AgQJ66aWXVKdOHUlSmjRpJEmurq66cuWKpP+97hNAphxbt27V9evX5evra3+NL1y4sAIDAzVr1ix98MEH+vLLLzVx4kRdv37dscXiPxlj7BNd9+jRQ3v37lWlSpXUpUsXffTRR+rZs6dmzZplf65++eWXfKmUQsW+zu7evVszZ87U9OnTtWbNGknSjh07lCtXLr3++uvauXMnwZQDZcuWTS+//LIuXbqkOXPm2E/XO3HihC5dumQfneqsCKVgqdgXTj8/P/Xr188eTC1dulR9+vRR+fLldf36dd7IplCxfStXrpz9duyb2+vXr+vixYv20/eGDx+utm3bKiwszGH14vF5e3vLzc1NGzZssL+pyZEjhypXrqyoqChly5ZNffv2lSR5eno6slQ4iM1mU1RUlGw2m3r37q1WrVopODhYgwYN0rlz5/Tuu++qdu3akggrUipjjLy8vNSyZUv77dgPtZGRkfbXc5vNpjFjxqh///4OqxXx4+3trcjISJ06dcr+/GzTpo3q168vSeratavq1aunAwcOKEOGDI4sFY/BZrMpMDBQrVu31tNPP628efPKZrPJw8NDvXv31qhRo/TOO++oV69eeuedd9StWzcVKlTI0WUjAWw2m7777js1atRIK1as0E8//aRWrVpp1KhRkqRdu3Ypa9as6tq1q7Zs2UIw5QCxP/NZs2apQYMGmjRpktauXau9e/eqSZMm6tatmxo2bOjgKh0rjaMLgHO59xvySpUqqX///powYYI6deqktGnT6tdff1XmzJkdVyAS5d8jIO697e7urnTp0snT01PDhg3T6NGj9csvvxBgJHOxHzr9/PyUL18+zZo1S9WqVbOPfJP+N1Lil19+UeHChXkOO7E0adLYr8723nvv2d8sV6lSRdeuXdP69esl3f9agZThUa/x3t7e9rnm3n//fU2YMEG//vqrpfUh4UqUKKHz589r7dq16tatW5z7YmJiZIyRh4eHSpUqxYfaFODIkSPq3bu3pk2bptdff13S3T4eP35cuXPnlr+/v3LkyKFp06YpR44c2rZtm4oWLergqpEQhw4dUo8ePTRs2DB1795dBw8e1Jo1a3Tx4kVFR0fL1dVVv/76q4oUKaK+fftq27ZtSp8+vaPLdiouLi72XkydOlXGGA0ZMkQhISFq0aKF/aISse+fnJFzHjWS3IO+9X6cb8L9/PwUFRUlNzc3bd26VRUqVHgS5SGJJaTfmTJlUr58+fTee+/po48+0s6dO1W2bNknVSIS4caNG/bTM2JHv6RPn14TJkzQjh079Oabb+rUqVNx1h84cKA+//xzDR8+XF5eXo4pHE9MfEY23TuHVPfu3XX79m2FhIRox44d8vPze1IlIgklZCRbdHS00qdPr+HDh2vSpEnasWOHSpcunfTFIdEiIyPtz9GoqChJUuPGjdW5c2f16dNHCxcu1O3bt+3rx8TE6IMPPlBgYKC6deumtGnTOqRuPL6wsDBlz55d1atX161btzRjxgzVrl1bDRo0UNOmTXX27Fl16dJFW7ZsUWBgoMqUKePokpFAZ8+ela+vr7p3767Tp0+rYcOGeuONNzRt2jS5urraJ9A+duyYli5dSiBlsdi5dV1dXe3/P23aNL322muKiYlRqVKldO3aNUly2kBKYqQUkkBsqnvp0iUdPXpUFy9eVLNmzeTm5vaf23344YdauXKlgoKC9Mwzz1hUMRIjof2+evWqtmzZot27d2vHjh0EUsnUqVOnVLVqVdWpU0elS5dW37597X8ka9WqpUmTJql///6qW7euKlWqpLRp0+r8+fP6/ffftWHDBp7HqVDsc/7GjRv2/2IvMf0wLi4uioyM1KBBg3To0CH98ssvKlmypEUVIzES0m/p7kUu5s+fLw8PD23bts1+GjeSl+DgYL333nuqWrWq2rVrF+eUrb59++ratWvq3LmzNm3apFq1aunq1avavXu3Vq1apZ9++knFihVzYPV4XFFRUbp06ZJGjRqlrVu36tlnn1W1atX07LPPKiAgQBs3btRrr72mTJkyObpUJFJMTIyioqK0e/duvfTSS2rUqJE+/vhjSXfnlPriiy80aNAgFSpUiFM0LXL69Gl9/vnn8vf3l7u7u/3vamww5erqqlGjRik0NFRTp05VmjRp1Lp16zhnITgb543jkCRin2SHDh1Sq1atNH36dB08eDBOQBGbCv+bi4uLXnzxRf3+++98m5pCJKbfuXPn1vPPP6/du3cTSCVju3fv1o0bN9SkSRPNnj1bL730kgYOHKjr168rS5Ys6tq1qzZv3qznnntOJ06c0IkTJ1S+fHlt3ryZb1pTodjnfHBwsF5//XX1799fq1atkvS/0TQPO5XHzc1NmTJl0rZt2/Tcc89ZVjMSLjH9LlSokIoVK6Zdu3YRSCVTMTEx+vzzz7Vv3z6Fh4erTJky+uijj+w9LlGihObOnav3339fa9eu1VtvvaVZs2YpOjpa27dv5293MhX73Lx06ZJOnTqlsLAwVapUSTNmzJCnp6fatWunSZMmadSoUWrTpo2yZcvGaLcU6kGjWLNnz66QkBDVq1dPdevW1Zw5c+xXu/722291/vx5ZcmSxepSndq3336rhQsXKiAgQHfu3IkzgtzV1dU+QnXq1Klq0aKF/P39FRgY6NSnRtsMs40igWLfvB48eFC1atVS9+7d1alTJxUuXFiStGHDBlWqVEmenp72VPhe906QiuQvsf2W7p7mxbdyyV/FihXVvn17vfnmm5o7d65++ukn/f7773rttddUr149VatWzb5uVFSUfU4ppC6xz/kDBw6oXr166tKli1544QVVr15d0t1TAYoUKRJn3Vi8vqc8iem3JF27dk23bt1Snjx5LK8dj2/79u1q2rSpfvvtNx09elQrV67UDz/8oOrVq6tNmzZq0KCBXF1dde3aNYWGhipLlixyc3OzX74cyUvsa+3y5csVEBCg0NBQeXp66oUXXlDfvn2VM2fOOOsPGTJEX3zxhbZs2SIfHx/HFI0Eie31rl279NdffylNmjRq1qyZJGns2LHy9/fXmDFj1KRJE6VLl06zZ8/WvHnztHnzZkYqW+TUqVP6888/VbNmTY0dO1bLli1TrVq1NGrUKKVNmzbO3857PyuNHDlSrVu3tv+NdUoGSITz58+b5557znTv3j3O8vHjx5s0adKYF1980YSEhBhjjImKinJEiUhCCe13TEyMpXUiYWJ79sUXX5hWrVqZ8PBw+30FChQwBQsWNOnTpzfdunUzs2bNclSZsNCpU6eMj4+Pee+99+Isnzx5ssmePbuZPXu2fVl0dLTV5SGJJbTfvManDLF9euedd8yQIUOMMXdf9y9fvmxsNpspWLCgefbZZ82aNWvM/v37HVkq4mH9+vXG09PTTJo0ydy4ccMMGjTIpEuXznz99df2debOnWtef/11kzNnTrNnzx4HVovEWL58ufH09DRFihQx3t7e5sUXX7TfN3DgQOPr62s8PT1NuXLlTIkSJczevXsdV6yTOXfunPH29jZFihQxK1asMNHR0ebDDz805cuXN/369TMRERHGmP/97YyIiDCDBw82kydPdmDVyQehFBIk9o3N8uXLTbly5cyRI0fs93388ccmc+bMpk+fPqZq1aqmRYsW9qCCN64pE/1OnWL7ExMTE6dXR44cMTlz5jTfffedMcaYTp06mVy5cpnffvvN/PDDD8bPz8+UKVPG/P333w6pG09e7Jum8ePHm4YNG5oLFy7Y7xs3bpzx8PAwTZs2NSVKlDBz5syx38dzPmWi36nTvf259//nzJljfH197cu6detmcufObdauXWs6dOhgcufObSpVqmRCQ0PpcTIWFRVloqKiTNeuXU2vXr2MMcZcvHjR+Pj43Pfl4dq1a03Xrl1NcHCwAypFYsXExJjIyEjz8ssvmy+++ML8/fffZu3atSZfvnymdu3a9vUOHTpkfv75Z7Nv3z5z6dIlB1bsfDZu3GhcXFxMhQoVTJMmTcx333330GAqPDzcvPPOO8bV1dUcOHDAwZUnD5xzgQSJPS3j119/VUhIiHx9fe33RUdH64cfflDFihW1ePFiffzxx3rppZe0cuVKhn+nUPQ7dTL/PxT82rVrceYb8PX11YABAzRv3jzNmzdPu3fv1tq1a+1zRpUpU0YuLi7Kli2bo0rHExY7vHzr1q1yc3NTzpw5ZYzRtWvXtGfPHq1fv1558uTRjBkzNHnyZEVFRal79+6cspdC0e/U6d7+3Pv/b775phYuXKjhw4fr5MmT+vHHH7V27VqVLl1aL7zwgjZt2qSnn35anp6ejigb/yH2b3d4eLi8vLwUFham2rVr68qVKypTpoyaNGmi6dOnS5KWL19uP52vdu3avC9LYe59nxYTE6OMGTOqQoUKyp07t3LlyqUlS5aodevWev7557VhwwaVKFFCJUqUcHTZTqlWrVrq1KmT9uzZI3d3d/vVD99/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KlXSgQMHdPbsWQdWDqvYbDb98MMPatu2rdq1a6d169bp5ZdfVs+ePRUcHOzo8pDE6HfqY7PZZLPZ9P3332vatGnq0qWLmjZtqoYNG2rPnj32QKNAgQJ69tln5eLiorZt2yosLIzLxiczsQHin3/+qXTp0qlz58767bff7FfSi/Xv2/Qx5bPZbMqUKZOku3PBXb58WR988IE6d+6sCRMmqHPnzho2bJgkacyYMfr6668JpID/RyjlJHbt2qWGDRuqc+fO+uOPP9S+fXt16dJFHTt2lCTduXPHwRUiKdHv1GH//v1q166dYmJidO7cOY0aNUqNGjVSpUqV1KZNG40cOVJffvllnGDq+PHjatCggfbt28eICScRExOjRYsW6e2331bv3r0VExOjVatW6Y033lDdunUdXR6SGP1OPQ4ePKiZM2dKkg4dOqQuXbqoRIkSqlmzpoYMGaKqVauqSZMm+v333+3bpE+fXnPmzNHRo0fl6enJCJxkxmazKSIiQmnTptXWrVt169YtDRo0SL/99ps9eIod+SxJJ06csG+HlO/27duqVKmStm/frty5c+v06dPq3Lmzfv/9d/Xo0UNBQUH29+DZsmVzcLVA8kEo5SQOHz6s7NmzyxijOnXqqE6dOvrkk08kSV988QXzz6Qy9Dvl279/v/z8/FS+fHlt27ZN06dPl6+vr1q1aiVJypgxo9q2bavRo0dr7ty5KlasmGrXrq2pU6fq5ZdfVvr06R18BLBKTEyMTp8+rTp16ig8PFx+fn6qVauW5syZI0lasGCBDh065OAqkVTod+qwb98+VaxYUenTp9eePXv0yy+/6NVXX1W7du1ks9n0zDPPaNiwYapWrZoqVaqk3r17q23btlq4cKEqVarEB9pkyhgjd3d3ffPNN+rfv7/y58+vTZs26Z133tHu3bvjzAM2evRoderUSdu3b3dw1UiI2JBx7969WrhwoTZv3qx06dLJ399fc+fOVWBgoAIDA9WxY0dlyJBBV65cUa5cubjCHvAAhFKpUOyL5MWLFxUaGipJatasmVavXq0sWbKoRYsWmjNnjv2P4o4dO7RlyxbdunXLYTUj4eh36nP48GFVqVJFffv21YABA7Rv3z6NHTtWa9eu1eXLl+3rZcqUSR07dtT27dtVr149Va1aVTt37lSJEiUcWD2etNjnfOzzPU2aNCpatKgm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pQen7xUDLpRZtrDfRKZDH1CkpqZi+PDhsLW1hY2NDTZv3gwHBwfs3r0bfn5+yMzMhJmZmbo/gwrjxH4TERERlS4cKVWMuFBm2cJ+Exk3fdCQkpKCNm3aICAgACNGjECNGjWg0Wig1Wphbm6OnJwc+Pj4QFEUBAcHw9vbm0GFEWK/iYiIiEofhlLFrKCggAtlliHsN5Fxy8nJga+vL5o1a4aIiAh1uz6A0B/j2dnZ8PX1hbm5OcaOHQtfX18GFEaI/SYiIiIqXbhiZzErvAgq8z7Tx34TGbdr167h6tWr6iLXevoAQn+MOzg4IC4uDllZWVixYgXy8/MNUi+9GvabiIiIqHThmlLFrPCdVN5VNX3sN5FxS0pKQnp6Ojw9PaEoylNPWFMUBfn5+Th16hTc3d1x5MgR5Obmonz58gasml4W+01ERERUunCkFBERlVm1a9eGubk5duzYAaDo6Ee9tWvXYtq0acjPz0flypVRu3btEq6Sigv7TURERFS6MJQiIqIyq1atWrCzs0N0dDTS09PV7YWn4168eBHNmzeHtbW1IUqkYsR+ExEREZUuDKWIiKjMcnJywvLly7Fv3z5MnToVqampAP47jSs4OBixsbEYPHgwp+iaAPabiIiIqHTh0/eIiKhM0+l0WLVqFQIDA1G3bl14eHjAysoKmZmZOHr0KPbu3QtXV1dDl0nFhP0mIiIiKj0YShEREQE4duwYwsPDkZaWBltbW7Rq1QpDhw6Fi4uLoUuj14D9JiIiIjI8hlJERET/UVBQADMzM0OXQSWE/SYiIiIyLK4pRURE9B+Fn8bGezamj/0mIiIiMiyOlCIiIiIiIiIiohLHkVJERERERERERFTiGEoREREREREREVGJYyhFREREREREREQljqEUERERERERERGVOIZSRERERERERERU4hhKERERERERERFRiWMoRUREREREREREJY6hFBERERERERERlTiGUkREREREREREVOIYShERERERERERUYljKEVERERERERERCXu/wHUSuH6Zud3oAAAAABJRU5ErkJggg=="
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "execution_count": 18
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-10-05T12:44:02.003251Z",
     "start_time": "2024-10-05T12:44:02.000173Z"
    }
   },
   "cell_type": "code",
   "source": "val_data.shape",
   "id": "60102ec4a6f7c55a",
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([30000, 4, 1])"
      ]
     },
     "execution_count": 65,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "execution_count": 65
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-10-05T12:44:07.785871Z",
     "start_time": "2024-10-05T12:44:07.782945Z"
    }
   },
   "cell_type": "code",
   "source": [
    "shift_var = 'L2'\n",
    "outcome_var = 'Y'\n",
    "shift_index = var_names3.index(shift_var)\n",
    "outcome_index = var_names3.index(outcome_var)\n",
    "shifted_data = val_data.clone()\n",
    "input_dim = val_data.shape[1] - 1\n",
    "# shift the data:\n",
    "shifted_data[:, shift_index] = shifted_data[:, shift_index] + shifted_data[:, shift_index].std()"
   ],
   "id": "cc73fc1aa8629166",
   "outputs": [],
   "execution_count": 66
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-10-05T12:54:29.443533Z",
     "start_time": "2024-10-05T12:54:29.407151Z"
    }
   },
   "cell_type": "code",
   "source": [
    "# CAT + CFCN\n",
    "preds_cat = model3(val_data.to(device)).detach().cpu()\n",
    "preds_cat = preds_cat[:, outcome_index,: ]\n",
    "preds_cfcn =  model3_cfcn(val_data.to(device)).detach().cpu()\n",
    "preds_cfcn = preds_cfcn[:, outcome_index,: ]\n",
    "\n",
    "\n",
    "shift_preds_cat = model3(shifted_data.to(device)).detach().cpu()\n",
    "shift_preds_cat = shift_preds_cat[:, outcome_index,: ]\n",
    "shift_preds_cfcn = model3_cfcn(shifted_data.to(device)).detach().cpu()\n",
    "shift_preds_cfcn = shift_preds_cfcn[:, outcome_index,: ]\n",
    "\n",
    "# split into X and y for MLP and RF\n",
    "X = val_data[:, np.arange(val_data.shape[1]) != outcome_index]\n",
    "y = val_data[:, effect_index, 0]\n",
    "\n",
    "\n",
    "y_shift = shifted_data[:, outcome_index, 0]\n",
    "X_shift = shifted_data[:, np.arange(shifted_data.shape[1]) != outcome_index]\n"
   ],
   "id": "183fb048d83c25c9",
   "outputs": [],
   "execution_count": 92
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-10-05T12:54:30.899565Z",
     "start_time": "2024-10-05T12:54:29.864463Z"
    }
   },
   "cell_type": "code",
   "source": [
    "# RF\n",
    "RF_preds = RF.predict(X[:,:,0].detach().cpu().numpy() )\n",
    "RF_preds_shift = RF.predict(X_shift[:,:,0].detach().cpu().numpy())\n",
    "\n",
    "# MLP\n",
    "mlp_preds = MLP.predict(X[:,:,0].detach().cpu().numpy() )\n",
    "mlp_preds_shift = MLP.predict(X_shift[:,:,0].detach().cpu().numpy())\n",
    "\n",
    "# transformer\n",
    "X_trans = X.repeat(1, 1, input_dim)\n",
    "transformer_preds = transformer(X_trans.to('cpu'))\n",
    "X_trans_shift = X_shift.repeat(1, 1, input_dim)\n",
    "transformer_preds_shift = transformer(X_trans_shift.to('cpu'))"
   ],
   "id": "c8a37d1ed79fa35e",
   "outputs": [],
   "execution_count": 93
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-10-05T12:54:30.906565Z",
     "start_time": "2024-10-05T12:54:30.900760Z"
    }
   },
   "cell_type": "code",
   "source": [
    "\n",
    "mse_cfcn = ((preds_cfcn[:,0] - y)**2).mean()\n",
    "mse_cat = ((preds_cat[:,0] - y)**2).mean()\n",
    "mse_rf = ((RF_preds - y.detach().cpu().numpy())**2).mean()\n",
    "mse_mlp = ((mlp_preds - y.detach().cpu().numpy())**2).mean()\n",
    "mse_transformer = ((transformer_preds - y)**2).mean()\n",
    "\n",
    "mse_cfcn_shift = ((shift_preds_cfcn[:,0] - y_shift)**2).mean()\n",
    "mse_cat_shift = ((shift_preds_cat[:,0] - y_shift)**2).mean()\n",
    "mse_rf_shift = ((RF_preds_shift - y_shift.detach().cpu().numpy())**2).mean()\n",
    "mse_mlp_shift = ((mlp_preds_shift - y_shift.detach().cpu().numpy())**2).mean()\n",
    "mse_transformer_shift = ((transformer_preds_shift - y_shift)**2).mean()\n",
    "\n"
   ],
   "id": "e85128c0de11a8ef",
   "outputs": [],
   "execution_count": 94
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-10-05T12:54:30.931899Z",
     "start_time": "2024-10-05T12:54:30.926435Z"
    }
   },
   "cell_type": "code",
   "source": [
    "mse_results = {\n",
    "    'Method': ['CFCN', 'CAT', 'Random Forest', 'MLP', 'Transformer'],\n",
    "    'MSE Before Shift': [mse_cfcn.detach().cpu().numpy(), mse_cat.detach().cpu().numpy(), mse_rf, mse_mlp, mse_transformer.detach().cpu().numpy()],\n",
    "    'MSE After Shift': [mse_cfcn_shift.detach().cpu().numpy(), mse_cat_shift.detach().cpu().numpy(), mse_rf_shift, mse_mlp_shift, mse_transformer_shift.detach().cpu().numpy()]\n",
    "}\n",
    "df_mse_results = pd.DataFrame(mse_results)\n",
    "# Display or return the DataFrame\n",
    "print(df_mse_results)"
   ],
   "id": "27d41cc7fa16ba9b",
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "          Method MSE Before Shift MSE After Shift\n",
      "0           CFCN        1.0386071       1.0386071\n",
      "1            CAT        1.0135077       1.0135077\n",
      "2  Random Forest         0.621411        4.754525\n",
      "3            MLP         0.559017        5.356762\n",
      "4    Transformer       0.61662346       6.1916833\n"
     ]
    }
   ],
   "execution_count": 95
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-10-05T13:08:21.355271Z",
     "start_time": "2024-10-05T13:08:21.194851Z"
    }
   },
   "cell_type": "code",
   "source": [
    "plt.figure(figsize=(5, 3))\n",
    "\n",
    "methods = df_mse_results['Method']\n",
    "mse_before_shift = df_mse_results['MSE Before Shift']\n",
    "mse_after_shift = df_mse_results['MSE After Shift']\n",
    "\n",
    "# Plot before and after MSE shift for each method with different markers and colors\n",
    "markers = [ 'D', '^', 'p','o', 's',]\n",
    "colors = ['blue', 'green', 'red', 'purple', 'orange']\n",
    "\n",
    "for i, method in enumerate(methods):\n",
    "    plt.plot(['No Shift', 'Shift'], [mse_before_shift[i], mse_after_shift[i]], \n",
    "             marker=markers[i], color=colors[i], ms=12, label=method, alpha=0.6, linewidth=2)\n",
    "plt.ylabel(\"Test MSE\")\n",
    "plt.legend()\n",
    "plt.grid(True)\n",
    "plt.tight_layout()\n",
    "plt.savefig('shift_impact.png', dpi=120)"
   ],
   "id": "a7c72c0e37d09d61",
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<Figure size 500x300 with 1 Axes>"
      ],
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAeoAAAEiCAYAAAA21pHjAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy80BEi2AAAACXBIWXMAAA9hAAAPYQGoP6dpAAB8iUlEQVR4nO3dd3gc1dnw4d9sVe+9S9bKvWDcGzbGnV4DJMGBkOSlBF4CIfCGYhN6CQQIKQRMKh8Bm+aOe8c2zcZNktV7X62krTPfH2NJuyq2JK+ade7r8gU6Mzt7VmWfPWfOeR5JURQFQRAEQRAGJE1/d0AQBEEQhM6JQC0IgiAIA5gI1IIgCIIwgIlALQiCIAgDmAjUgiAIgjCAiUAtCIIgCAOYCNSCIAiCMICJQC0IgiAIA5iuvztwPmRZpri4mMDAQCRJ6u/uCIIgCEKXKIpCfX09cXFxaDRnHzMP6kBdXFxMYmJif3dDEARBEHqkoKCAhISEs54zqAN1YGAgoL7QoKCg876ew+Fg06ZNLFy4EL1ef97XEwRBEC4M3o4PZrOZxMTEljh2NoM6UDdPdwcFBXktUPv5+REUFCQCtSAIwlBjqwanpcNDDsVBuE8DQbpa9NpO4oMuAIxh3XrKrty2HdSBWhAEQRC8wlYNh+8Da0WHh7WKzHhbBdpDH4DUyT1ln0i4+LVuB+tzEYFaEARBEJwWNUjrfEHr1+6wosjYJSuKMbzjQO1qVB/vtIhALQiCIAi9RusH+oD27bKMS/JVp7c7W6XtbOqVLg2JQO1yuXA4HOc8z+FwoNPpsFqtuFyuPuiZMNjp9Xq0Wm1/d0MQhAvYBR2oFUWhtLSU2traLp8fExNDQUFBuxv8O3YE8OmnQVx5pZlLLul4sYEwNIWEhBATEyP28guC0Csu6EDdHKSjoqLw8/M75xupLMtYLBYCAgI8NqCvX69h9WotZjOsXh1AdLSLJUvk3u6+MMApikJjYyPl5eUAxMbG9nOPBEG4EF2wgdrlcrUE6fDw8C49RpZl7HY7Pj4+LYF67Vr4859Bq4Xx4yE/H/78Zy0GAyxb1puvQBgMfH19ASgvLycqKkpMgwvChUqR8ZErQY4FjbFPn/qCzfXdfE/az6/96r2uWrsWXn8dJAmSktS2pCT169dfV48LQvPvWFfWQQiCMMgoCljLkaoP4a+UIzXm93kXLthA3ayn9w07CtLNRLAW3Il704JwgXKYoeZbMJ8A2a62WUtB7tsP5Rfs1Pf5WLsW3nyz4yDdLClJnQZ//XX1azENLgiCcIFwWcGSAzbP5Cd2KQC/kAmg6dvMlSJQt7Fxo4533pHQaDoP0s1EsBYEQbiQyNCYr2Ypw23BsNYPxT+V+qZ6QnT+fd6rfp/6Lioq4oc//CHh4eH4+voyduxYDh061C99WbsW/vIX41lH0m311jR4aWkp9957L2lpaRiNRhITE7niiivYsmULACkpKUiS5PGvbQWWr7/+mhtuuIHo6Gh8fHwwmUzceeednDp1CoDc3FwkSSIqKor6+nqPx06YMIEnn3zSey9IEARhoFJkqPoSzJnQVEJLkNboIcAEYReDIbTfutevgbqmpoaZM2ei1+tZv349x44d4+WXXyY0tO+/IWvXwhtvSN0K0s28Haxzc3O5+OKL2bp1Ky+++CJHjhxhw4YNzJs3j7vvvrvlvJUrV1JSUtLy7+uvv2459vnnnzNt2jRsNhv/+te/OH78OP/85z8JDg7mscce83i++vp6XnrppfPvuCAIwmBTdxyO/g4K1gDOM40a8EuEsMngF6u+wfejfp36fv7550lMTOTdd99taUtNTe3zfrgvHEtI6Nn+aG9Og991111IksSXX36Jv3/rNMvo0aO5/fbbW74ODAwkJiam3eMbGxv5yU9+wtKlS1mzZk1Le2pqKlOnTm2XAObee+/llVde4e677yYqKqrnHRcEQRgsmkog/0OoO+rZbgiDoJGg8+mffnWgX0fUn376KZMmTeKGG24gKiqKiy66iL/+9a992oezre7uLm+MrKurq9mwYQN33323R5BuFhIScs5rbNy4kcrKSn796193eLztNW6++WbS09NZuXJlT7osCIIweDgskPs+HFnpGaT94sE/FQJNAypIQz+PqE+fPs1bb73FAw88wKOPPsrBgwf55S9/icFg4Lbbbmt3vs1mw2aztXxtNpsBdf9q2z2sDocDRVGQZRlZbh0lP/ss1NWp0xjZ2fDVV2p7UBAUF4Msa8/kW1d6/LrMZrjnHnjnHRg2DIKDFR55pGuPPXXqFIqikJGR4dHvjjz88MP89re/bfn66aef5t577225B32uazQfUxSFZ555hquuuor77ruPYcOGtbSfqw+C+n1UFAWHwyESngjCQCU7kSp2IJWs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advjzf/tzjltn6eztubn7srrbnus+efZWT8AAgICPM5paGjgiiuu6HARXmxsLHq9ns2bN7N37142bdrEm2++yWOPPcaBAwdITU3t8Hnbav4edPR7KAi9xtmo7oUu2wqKq/U9xjcBkm6A4BEMthsxiqJQ8X0Fp9aeoua0WvO6+W/PL9yP9MXpJM5IPGtaT69y26IrZ2ejtdvRffghmm+/Pe8tut15r+jXQP3ggw9yxRVXkJycTHFxMU888QRarZabb765957UbUTWjr8/HD0KLhe0mUo/K4cDgoLUbVodbS8723N2gUaj4dFHH+WBBx7glltuwdfXlz179nDVVVe1jLJlWebUqVOMGjWqy9cdOXIkBQUFlJSUtIyY9+/f3+6cVatW0dDQ0DL1vWfPHjQajcdIvLeNHDmSjz76CEVRWj487Nmzh8DAwE7veQNMnDiRjz76iJSUlE63/kmSxMyZM5k5cyaPP/44ycnJrFmzhgceeACDwYDL5erwcYLQL2QXVOxSC2e4Glrb9UGQcDVETB90hTMURaH0m1Iy12VSl+852PGP8se0xET81Pg+SzACtNuiq4wYQVNxMUpcHOTn9+oW3bb6NVAXFhZy8803U1VVRWRkJLNmzWL//v093o7TJY8+2ukhRZaxh4Xhs2GDuqK7q44dg2uuAbdpeW+74YYbeOihh3jzzTd58MEHMZlMfPjhh+zdu5fQ0FBeeeUVysrKuhWoL7vsMjIyMrjtttt48cUXMZvN/N///Z/HObfeeitPPPEEt912G08++SQVFRXce++9/OhHPyI6uu+m1O666y5effVV7r33Xu655x5OnjzJE088wQMPPHDW0e7dd9/NX//6V26++eaW1e9ZWVm8//77vP322xw6dIgtW7awcOFCoqKiOHDgABUVFYwcORKAlJQUNm7cyMmTJwkPDyc4OFiMmoX+oShQ9726H9pa2tou6SF2AcQuAu3guvWiyArFh4vJXJdJfXG9x7HAuEBMS03EXRyHpOnDTGlWK3z8sZrcyn2LbvMi0j7aouuuXwP1+++/359P3yHX+PGwaZM6nd2V5CtOp7qw4KKLerVfOp2Oe+65hxdeeIH/+Z//4be//S2nT59m0aJF+Pn58bOf/Yyrr76aus6m9Tug0WhYs2YNd9xxB1OmTCElJYU//OEPLF68uOUcPz8/Nm7cyH333cfkyZPx8/Pjuuuu45VXXumNl9mp+Ph41q1bx0MPPcT48eMJCwvjjjvu4Le//e1ZHxcXF8eePXt4+OGHWbhwITabjeTkZBYvXoxGoyEoKIidO3fy6quvYjabSU5O5uWXX2bJkiUA3HnnnWzfvp1JkyZhsVjYtm0bc+fO7YNXLAhuGovUAG0+7tkePkVN+2kcXCmNZZdM0ZdFZK3PwlJm8TgWnBiMaZmJmAkxLbNnfUJR1N0777wD336rzpKOHt35wrHmLbpFReoW3d274Y47YMIEr6dgHVCrvrvLbDYTHBzc4ao5q9VKTk4OqampXV7gI8sy9Tk5BP3v/yLp9RDRhaoxlZXq1Pe776rbtIQhpye/a4LQJQ6zOsVdsRtwe6sOSFMTlgSk9lvXekJ2yhTsLSBrQxaNVY0ex0LTQslYlkHk6Mi+DdDNCgrUWdGSEhg2rN3o2CXLFOTnk5iUhLbtLJ7VCtnZatGmV17p0hbds8WvtgbUYrKBQAkPRxk1Cmn//q4F6qoqmD5dBGlBELxHdkDpFiheD7LbtiRDOCReC2EXD6rCGS67i/zd+WRtzMJa67nNKjwjnIxlGYQPD++fAN0sPh5CQtQFxx194FYUdA0NYLOpC4fd+fio65pCQ9XreJkI1B2ZPFmdxqivP/sfg6KoU99Tp/Zd3wRBuHApClQfhoLVYHfbJqrxgbglEDMfNINnjYTT6iRvZx7Zm7Kx1ds8jkWNjiJ9STrhpgEyyNFo1EHX8Ta3F1wuKC9HKioiuLwcycdHHXG31dgIM2b0SqEmEag7Mm6cOoVRXX3uc2Nj1fMFQRDOhyUH8j8Ay2m3RgkiZ0PCFeqq7kHC0eggZ1sOOVtysDfYPY7FjI/BtNRESEpI/3TubCZMAINBncqWZXUavKzMM5NbWRmkpnoGZKtVfVwvxQIRqDuSmgovv9z188+yPUgQBOGsbNVQuAaqvvRsDxqp7of28/5Uam+xW+yc3nKanK05OK2twU2SJGInxmJaaiIoYQB/4BgxQl1EfPBgh+mjHb6+6mi67UxrdTVERUE3dt10hwjUHdFooAdpRAVBELrMZYXiDVD6BShueZ99Ys4kLDnLiuMBxma2kb05m7wdeThtbgFaIxE/JZ70xekExnZS4GggqK9X90vv3Kn+f3W1er8Z1HgQHY0SHY25uprgyMj2P5faWpg378LcniUIgjDkKDJU7oPCj9VV3c20/mpt6MjZoBkcOcWaaprI3phN/u58XI7WxEAarYaE6QmkL07HP9K/H3t4FooCOTmwbRscPqzeiwZ1EXFuLhiN6mxpdLQ6ypbljm+H9sEWXRGoz0F2yZQfKcdSasFpc6Iz6giICSBqbFTfZskRBGHwqzuh7oduKmxtk7QQfSnELQVdNzIi9qPGykayNmRRsLcA2dVaTU6j05A0K4n0Ren4hvme5Qr9yG5Xp7a3bVO3ZLmTJJg1CywWdUTdleRbtbXqavFeXKskAnUnrLVW8nblkbU+i6pTVThtzpZc1TqjjvCMcNKXpJM8OxmfELF3VhCEs2gqg4IPofY7z/bQi9TtVj5R/dOvbrKUWshcn0nRl0UtdaABtAYtyXOSGbZw2MCtA11eDjt2wN696gptd/7+aoCeM0cdUdfWwr59XQvUfbBFVwTqDlSdqmLvC3upyqxCa9ASEBuAwb+1VKa9wU7lyUrKjpRxYs0JZv1mFuEZA2SLgSAIA4ezAYo+h7LtgFsdc78k9T50UPsCNAORuchM5rpMSg6X4J4jS+ejI3VeKqnzUzEGti+Y1O9kGb7/Xh09f/99++MpKTB3LkyaBO6pgadMUe9Zu2/RlWW0TU3qaLt5xXcfbdEVgbqNmqwaDr10iPqiesIzwjus0mLwNxCWHobslKk6VcW2x7cxb+U8EawFQVDJTijfoQZpl9voTR9ypnDGtEGxUKw2r5bMtZmUflvq0a7305M2P43US1PR+w3Afd0NDbBnjzqCrqz0PKbTqbky5s7tvJhGB1t0JVnGUF+PVFXluTWrD7boikDtxlpr5dCrh6gvrCdiZMQ5E8FrdBoiRkRQeaKS3c/vZtHLi7wyDb58+XLee+89fv7zn/OnP/3J49jdd9/NH//4R2677TZWrVrF8uXLqa2t5eOPP+7wWikpKeTl5QFq3u7hw4fzyCOPcMMNN5x3PwVBaENR1Ont/A/BVt7aLunVohmxC0E7AEeebVRnV5O5NpPy78s92o2BRtIWpJFySQo6nwEYPvLyYPt29R60w+F5LDwcLrkEZs6EgICzX6eDLbouh4Nvt21j3rx5aNoW5unlLboD8Dvdf/J35VObXUvUyKguV2uRNBLhGeFUnaoib1cew6/wTunHxMRE3n//fX7/+9/jeyZdndVq5d///jdJ3dw6tnLlSu68807MZjMvv/wyN910E/Hx8cyYMcMrfRUEAWgoUBeK1Z/0bA+fBonXgCGkX7rVVYqiUHWyisx1mVSe9ByF+oT4MGzhMJJnJ6M1DLAV6Q6Hump72zZ1tXZbo0ero+cxY7qeNayjLboOB02RkWp7H1fQE4H6DNklk7UhC41e0+2i5BqdBq1eS9aGLExLTV5ZDT5x4kSys7NZvXo1t956KwCrV68mKSmJ1NTuJeIPDAwkJiaGmJgY3nzzTf75z3/y2WefiUAtCN5gr4PCT6ByLx6FMwJN6n1o/+R+61pXKIpCxfcVZK7LpDrbc/uRX7gf6YvTSZiegFY/wAJ0VZW673n3bvW+sTs/PzWd5yWXqIlIBjkRqM8oP1JO1akq/KN7tucvIDaAqpNVlB8tJ2Z8jFf6dPvtt/Puu++2BOp33nmHn/zkJ2zfvr3H19TpdOj1eux2+7lPFgShcy67mqykZAPIbnmsjRGQeD2EThjQ96EVRaHs2zIy12VSm1frccw/yh/TEhPxU+MH1jZURVFzcW/frtaBbps9LCFBTTwyebK6D/oCMeQC9a5ndmGts7ZrrzldQ9XJKoyhRmo0NT2q4tJY2cjOp3cSmhrq0e4T7MPsR2d3+3o//OEPeeSRR1ruMe/Zs4f333+/x4Habrfz8ssvU1dXx6WXXtqjawjCkKcoarrPwjVgr2lt1/pC3DKIngeagfvWqsgKxYeLyVyXSX1xvcexwNhATEtNxE2K6/Ltvz7R2Khul9q+Xd1m5U6rhYkT1QCdljagPxz11MD9beol1jpruzJroKbAk10yLrsLevgBUnbJ2OpsHV6/JyIjI1m2bBmrVq1CURSWLVtGRFdKb7bx8MMP89vf/har1UpAQADPPfccy5Yt80ofBWFIqc9WC2c05Lo1aiBqDsRfDvqBmyZTdskUfVlE1vosLGWeU8XBicGYlpmImRDTv6Um2yosVIPzgQNqohJ3ISHq1PasWXCOes6D3ZAL1J1txjcGGdFoNWgNWjQaTY9+WTVaDcZgY7uV3+eTAOD222/nnnvuAeDNN9/s0TUeeughli9fTkBAANHR0QPrD1EQBgNrJRSuVktQugseA0nXg29s//SrC2SnTMG+ArI2ZNFY6ZnoIzQ1FNMyE1FjogbO+4LTCV9/rQborKz2x0eMUBeHjR/fKyUlB6IhF6g7m4Iu/aaUjb/aiDHMiH+oP3Tzd9ZusdNQ1sCc/5vjtXvUAIsXL8ZutyNJEosWLerRNSIiIkhPT/danwRhyHA2Qcl6KN0CilupQ9+4M4Uzeqdakje4HC7yd+eTvTGbppomj2PhGeGYlpqIGBExcAJ0ba26OGzXLjCbPY8ZjWr2r7lz1X3LQ8yQC9SdiRobRXhGOGXfl6mBupssJRYiRkYQNca7Kwy1Wi3HzxQy12o7XnVZV1fHN99849EWHh5OYmKiV/siCEOGIkPFbij8FJxu93F1gWcKZ8wCaWCO5pw2J3k78sjenI3NbPM4FjkqEtNSE+GmAZKcSVHg1Cl19PzNN2omMXexsWpwnjat1ypTDQYiUJ+h0WpIX5xOyTclyE4Zjb7rf4SyU8blcJG+OL1XVkgGneP+y/bt27moTeWWO+64g7ffftvrfRGEC17t92pe7qbi1jZJBzHz1cIZ2oEZMByNDnK353L6i9PYGzzv58aMj8G01ERISkj/dK4tqxX271cDdEmJ5zGNBiZMUBeHmUwX5OKw7hKB2k3S7CRC/htCVWaVOiXUhVWPiqxQdaqK8Ixwkmd7Z7/kqlWrznrcPQvZqlWrznp+bkcJAARBaK+pRM0oVnfUsz1sEiRcAz7dX8jZF+wWO6e3nCZnaw5Oq1staEkidmIs6UvSCU4M7sceuikpUYPz/v1qsHYXFASzZ6v/QkM7fPhQJQK1G58QHybdP4lDLx2i8kRlp7m+mzXn+g6KD2LWw7NEFS1BGIwc9WpO7vKdeBTO8E+BpBshcFh/9eysbGYb2ZuzyduRh9PmGaDjp8STviSdwNgBsApdltVp7e3b4eTJ9sfT09Xp7YsuUvNwC+2I70oboemhzH1yLntf3EvVqSq0ei0BcW2qZ1nsWEosuBwuwjPCmfWwqJ4lCIOO7ISyrVC8Dlxui60MoZBwLYRPHpDTrk01TWRvzCZ/dz4uh6ulXdJIJE5PJH1xOv5RPUvc5FVms5o1bOdOqKnxPGYwqBWn5s7t9TzZFwIRqDsQnhHOopcXedSjrrPVtRzXGXVEjIwgfbGoRy0Ig46iQM3XUPAR2NxyWmuMELsYYi4DraHzx/eTxspGsjZkUbC3ANnVOvLX6DQkzUoifVE6vmG+/dhD1O/t6dNq3u2vvgKXy/N4VJQanKdPV9N8Cl0iAnUnfEJ8GH7FcExLTZQfLcdSasFpdaLz0REQE0DUmKiBlVpPEIRza8g7Uzgj061RgogZkHAVGAbIvVw3ljILWeuzKDxQiCK3pszUGrQkz0lm2IJh/T9YsNngyy/V6e3CQs9jkqSWgZw7F0aOHJCzFAOdCNTnoNFq1H3R4/u7J4Ig9Ji9Bgo+hqr9nu2Bw88Uzhh4WxnNRWYy12VScrgExS2ntc5HR+q8VFLnp2IM7Od81uXlas3nvXvVNJ/uAgLUrGFz5qglJoUeE4FaEIQLl8sGJZugZCMobvWJjVFqRrGQcQNuhFebV0vmukxKvyn1aNf76Umbn0bqpano/fq2zKIHWYajR9XR8/fftz+ekqJurbr44j4vB3mhEoHana0aqakEtIE9S02nCwBjmPf7JQhC9ygKVO6Dwo/B0bq+BK2fmpM76pIBVzijOruazHWZlB/1LDphDDSStiCNlEtS0Pn0Y58tFtizRx1BV1V5HtPpYMoUdXo7eWCX9RyMuvxTLy8vJ+osdT2dTidfffUVU6ZM6VFHnnvuOR555BHuu+8+Xn311R5d47zYqpG+uh+/hhIknY5u5xAF8ImEi18TwVoQ+pP5lHofujHfrVGjVrWKXwa6AbAi+gxFUfMwZK7NpPJkpccxn2Afhi0aRtKsJHTGfgzQubnq4rBDh9Q83O4iItTCGDNngv/A+b5eaLr804+NjaWkpKQlWI8dO5Z169a1pKmsqqpi+vTpuNqu8uuCgwcP8uc//5lx48Z1+7Fe47SArQJF46MuKOnudJirEawV6nVEoBaEvmcth4LV6opudyHjIfE68I3un351QFEUKr6vIHNdJtXZ1R7HfMN8SV+cTuKMRLT6jtMG9zqHQw3M27ergbqt0aPV6e3Ro4dMYYz+1OVArbQp0J2bm4vD4TjrOV1hsVi49dZb+etf/8rvfve7bj/e2xStL+gDenbfytl07nMGqdLSUn70ox+xd+9e9Ho9tbW1/d0lQVA5G6F4LZRtA8VtoOCbcKZwxoj+61sbiqJQ9m0Zmesyqc2r9TjmH+WPaYmJ+Knx/bejpKpKndrevRsaGjyP+fnBjBnqCPoss6uC93l1PqUnVVjuvvtuli1bxmWXXXbOQG2z2bDZWpPMm89UWHE4HO0+NDgcDhRFQZZl5LaJ3jvido76eaObHzoUBVBQZLl9Yvlu6KzwRrPHH3+cJ554osfX76lXXnmFkpISvvrqK4KDg7v2PR0iZFlGURQcDsc5f36CFykupIpdSMVrweUWVHRBKPFXooRPUwtntHlv6A+KrFD6dSlZ67OoL673OBYQE0D6knRiL45F0ki4ZBcuufszkz3vnALHjqHZuVNdJNZ2wJWQgDJ3LsqkSWqiEhgQ39O+1hxj2saa871eV/Traor333+fr776ioMHD3bp/GeffZYVK1a0a9+0aRN+bTbP63Q6YmJisFgs2NsWHO+A1FSPn9MJenA4zn1+O047GqeTRks9ist87vM7ceLEiZb/X7NmDc8884zH98ff37/lA4qiKLhcLnR9kHbv5MmTjB07luhodfrQ3LYMXRfY7XYMhr5LJOFwOND3wapTu91OU1MTO3fuxNn2Hp7gfYpCoJJHnHMfPkprxisZHRXa8ZRrL0IuqgU29FsXmykuhcasRsyHzThrPX839BF6gi4OQklT+KbiG77Z8E2f9k1rsxF24gThR49irKvzOKZoNNSmp1M5ZgyN0dFqCcovvujT/g1Umzdv9sp1GttuZzuLLr/DS5JEfX09Pj4+KIqCJElYLJaWN+zuvnEXFBRw3333sXnzZny6WL7skUce4YEHHmj52mw2k5iYyMKFC9tVmLJarRQUFBAQENC162sDQadDBvR6Q/dnviUDKDoCAwLB/+zVrs7G/XVERUWh0WgwmUyAWiVr/vz5fP755zz++OMcOXKEDRs2kJiYyK9+9SsOHDhAQ0MDI0eO5Omnn+ayyy5ruVZaWhp33nknWVlZfPjhh4SGhvLoo4/ys5/9DFCDza9+9StWr15NTU0N0dHR/PznP+c3v/kNaWlp5OXlAeqHqx//+Me8++675Ofn88tf/pKtW7ei0WhYtGgRf/jDH1qC+YoVK/jkk0+46667ePbZZ8nLy8PpdKLVavnjH//I559/zrZt20hOTubtt98mMjKSn/3sZxw8eJDx48fz3nvvMWxYa57lTz75hKeeeopjx44RFxfHj3/8Yx599NGWDyparZY33niDDRs2sHXrVh588ME+mX2wWq34+voyZ86cLv8uCz3UVISm4COoPwEEnvkHStgUlPgrSTQMjPUhslOmcH8hpzeeRqqS8A/yhzN/2iEpIaQvSSdyTGT/1IIuKEDasQPp4EF1ZBwcrP4DCAlBmT0bZeZMEs5RtW+ocTgcbN68mQULFnhlANCdmNmte9QZGRkeX7uXVmwO3l11+PBhysvLmThxYkuby+Vi586dvPHGG9hstnbTiEajEaOx/QZ/vV7f7hvncrmQJAmNRoOmK4sdNJqWyW5J6sE0viQBEpJG47XFFc39bvvfRx99lJdeeom0tDRCQ0MpKChg2bJlPPPMMxiNRv7+979z1VVXcfLkSZKSklqu98orr/DUU0/xf//3f3z44YfcfffdzJs3j+HDh/PGG2/w2Wef8cEHH5CUlERBQQEFBQVoNBoOHjzIj3/8Y4KCgnjttdfw9VXTFF5zzTUEBASwY8cOnE4nd999NzfffDPbt28/8y2RyMrKYs2aNaxevRqtVtvyGp5++mleeeUVfv/73/Pwww/zwx/+kLS0NB555BGSkpK4/fbb+eUvf8n69esB2LVrF8uXL+cPf/gDs2fPJjs7m5/97GdIkuQRjFeuXMlzzz3Ha6+9hk6n69rP/jxpNBokSerw91DwEodZrQ1dsRtQWv/GAoap96EDUvu1e81cDhf5u/PJ3phNU426ZqX5dzA8IxzTUpNama+vA7TTqab03L4dsrNb25u/jyNGqFurxo8Xi8POwVt/5925RpcD9bZt23rUmc7Mnz+fI0eOeLT95Cc/YcSIETz88MO9d6/v+2fAXte+3WEG8ym0kgGafOj29izZrib2//5Z0Lf5JGoIhtGP9rjLba1cuZIFCxa0fB0WFsb48a2p05566inWrFnDp59+yj333NPSvnTpUu666y4AHn74YX7/+9+zbds2hg8fTn5+PiaTiVmzZiFJEslueyEjIyMxGo34+voSExMDqNM/R44cIScnp2Xl/9///ndGjx7NwYMHmTx5MqCO1P/+978TGRnp8Rp+8pOfcOONN7b0Zfr06Tz22GMsWrQIgPvuu4+f/OQnLeevWLGC3/zmN9x2222AOkPw1FNP8etf/9ojUN9yyy0ejxMGOdkBpV9A8XqQW9enYAiHxGsh7OIBkbDEaXOStyOP7M3Z2Mw2j2ORoyIxLTURbuqH7Fw1NWpRjF27oN7z3jg+PmrO7blz4czftTAwdTlQX3LJJV594sDAQMaMGePR5u/vT3h4eLt2r7LXgaO2fbvDAooTSZFA7sEnStkBilMN+PTuQqtJkyZ5fG2xWHjyySdZu3YtJSUlOJ1OmpqayM/P9zjPffubJEnExMRQXq4mV1i+fDkLFixg+PDhLF68mMsvv5yFCxd22ofjx4+TmJjYEqQBRo0aRUhICMePH28J1MnJye2CdNu+NE+Vjx071qPNarViNpsJCgri22+/Zc+ePTz99NMt57hcLqxWK42NjS1rFNp+b4RBSlGg+hAUrAG7W3INjQ/ELYWYS0HT/7MXjiYHudtyOf3FaewNnmtbYsbHYFpqIiQlpG87pShqOcnt2+Hbb9svbo2LU4Pz1KlqsBYGvC4HaqfTicvl8ph6Lisr409/+hMNDQ1ceeWVzJo1q1c66VWdJt3XgKRDkfSgMdD9hCeSujVEH9TxiNqL/NskFnjwwQfZvHkzL730Eunp6fj6+nL99de3W0TXdqpFkqSW1dsTJ04kJyeH9evX88UXX3DjjTdy2WWX8eGHH3q1rx31pXkasKO25v5ZLBZWrFjBtdde2+5a7veFO3s+YRCxnFYTllhOuzVKEDkbEq4Eff/XWLY32Dn9xWlyt+XiaGpdvStJErETY0lfkk5wYh8X+LBaYd8+dXtVSYnnMY1Grfc8dy6YTANiFkLoui4H6jvvvBODwcCf//xnAOrr65k8eTJWq5XY2Fh+//vf88knn7B06dIed6b53mav6mwKuiEfLKdxSYFo/cK6/4vssICtCkY/Av5J5z7fi/bs2cPy5cu55pprADWo5XaUpOAcgoKCuOmmm7jpppu4/vrrWbx4MdXV1YSFtV+gM3LkyJb72M2j6mPHjlFbW8uoUaPO6/V0ZOLEiZw8eZL09HSvX1sYIGxV6gi6us0ukKBR6n1ov7j+6Zcbm9lG9uZs8nbk4bS1ruKWJIn4KfGkL0knMLaPP0gUF6vBed8+tYqVu6AgtSjG7NkQEtK3/RK8psuBes+ePbzxxhstX//973/H5XKRmZlJcHAwDz/8MC+++OJ5BWqhZ0wmE6tXr+aKK65AkiQee+yxbu9zfuWVV4iNjeWiiy5Co9Hw3//+l5iYGEI6+eO+7LLLGDt2LLfeeiuvvvoqTqeTu+66i0suuaRXpp8ff/xxLr/8cpKSkrj++uvRaDR8++23HD16dEAkyhHOg8sKxRvUe9HuhTN8YtXCGcGj+30E2FTTRPambPJ35eNytO5xljQSidMTSV+cjn9UH87muFzqtPa2bXDqVPvjJpM6ep4wQc3DLQxqXf4JFhUVtWwTAtiyZQvXXXcdwWeW9d922228++673u+hcE6vvPIKt99+OzNmzCAiIoKHH36429vlAgMDeeGFF8jMzESr1TJ58mTWrVvX6appSZL45JNPuPfee5kzZw4ajYbFixfz+uuve+MltbNo0SI+//xzVq5cyfPPP49er2fEiBH89Kc/7ZXnE/qAIkPFXij65MzajjO0/uoUd+Rs0PRvApnGykayNmRRsLcA2dX64Vej05A0K4n0Ren4hvn2XYfM5tbFYW2zAxqN6n3nuXMhPr7v+iT0OknpYt7P8PBwdu3a1TKtGRcXx4svvsitt94KwOnTpxkzZky3NnGfL7PZTHBwMHV1dR3uo87JySE1NbVre1sb8lEO3IldCsTgF9b97RPNU99T/9LnU99C/+r275oAdSfU+9BNha1tkhai50PcEtD5df7YPmAps5C1PovCA4UocutbpNagJXlOMsMWDMMnpI9+1oqibqnavh0OH26/OCw6Wg3O06eDbx9+aBhiHA4H69atY+nSpV7bR91Z/GqryyPqCRMm8I9//INnn32WXbt2UVZWxqWXXtpyPDs7m7i4/r+HJAjCANZUBgUfQu13nu2hE9XtVj7tdwj0JXORmaz1WRQfKvaoXaDz0ZE6L5XU+akYA9vncugVNht8+aUaoAsLPY9JEowbpxbGGDGi328NCL2ry4H68ccfZ8mSJXzwwQeUlJSwfPlyYmNjW46vWbOGmTNn9kon+5LkalJHxz2pniUIQsecDVD4GZTvwGP7on8yJN4AQaZOH9oXavNqyVyXSek3pR7tej89afPTSL00Fb1fH20HKytTF4ft3QtNbQr9BAbCrFnqArEOFnkKF6Zu7aM+fPgwmzZtIiYmhhtuuMHj+IQJE3pci3pA0AWAMRKpoQTsTnpcj1oX4PWuCcKgJTuhfDsUrfX8MKsPgcRrIHxqv44Gq7OryVyXSfnRco92Y6CRtAVppFySgs6nDxZjyTIcOaIuDjt+vP3xtDR1evvii8XisCGoWz/xkSNHMnLkyA6PNeeMHrSMYSgTX6WxtoTAgEA1FWh36QJELWpBAPW+au23kP8R2NyCoMYAsYsgZgFo+2gKuV3XFKpOVZG5LpPKE5Uex3yCfRi2aBhJs5LQGfsgINbXw5496gKxqirPY3o9TJmiBugkse5lKOvyb+LOnTu7dN6cOXN63Jl+ZwxD8dWpRTVEvltB6JmGAsj/AOrbbBuKmA4JV4MhpD96haIoVByrIHNtJtXZ1R7HfMN8SV+cTuKMRLT6Xl5priiQm6veez50SM3D7S4iQq35PHMmiAQ+At0I1HPnzm1ZCd3ZQnFJknC5+rCOahd0cVG7IPSY+B07w14LhZ9A5T486rkHmtSEJf7JnT2yVymKQtl3ZWSuzaQ2r9bjmH+UP6YlJuKnxqPR9vKHc4cDDh5UA/SZanQtJAlGj1YXh43u/33jwsDS5UAdGhpKYGAgy5cv50c/+hERERG92a/z1rx8vrGxsaXakyD0huYtiUO2cpbLDqWboWSjZ+EMYyQkXgehE/ol8CiyQslXJWSuy8Rc5JlXIDA2ENNSE3GT4pA0vdy3ykp1cdiePdDQ4HnMz691cVgHOfEFAboRqEtKSlizZg3vvPMOL7zwAkuXLuWOO+5g8eLF/VNT9Ry0Wi0hISEtRSf8/PzO2U9ZlrHb7Vit1j4pjygMboqi0NjYSHl5OSEhIb1X8W2gUhSo+hIK14C9prVd6wvxl0PUXND0/cInRVYo+rKIzHWZWMosHseCE4MxLTURc1FM775vKQp8/706ej56VP3aXVKSOnqePFm9Fy0IZ9HlvyKDwdCSBzo/P59Vq1Zxzz33YLPZuO2221ixYgW6AbYasbkkY3OwPhdFUWhqasLX13dAfvgQBqaQkJCW37Uhoz5LTVjSkOvWqIGoS9Qgre/73Q+yU6ZgXwFZG7JorPTcLhmaGoppmYmoMVG9+7fd0KBuq9qxAyoqPI/pdOqq7blzITVVTG8LXdblzGQdycnJ4Y477mDHjh1UVFR0WLyhN3U1s4vL5cLhcHR6vJnD4WDnzp3MmTNn6E5jCt2i1+uH1kjaWgkFH0HNV57twWMh6Trwje34cb3I5XCRvzuf7I3ZNNV47jsON4VjWmYiYkRE7wbo/Hx19Pzll+q9aHdhYerU9qxZ6j5oYVAaFJnJmtlsNj766CPeeecd9u3bx7Jly1i7dm2fB+nu0Gq1XXoz1Wq1OJ1OfHx8RKAWBHfOJiheB2Vb1brrzXzjIOlGCO5422avdsnmJG9HHtmbs7GZPatGRY6KxLTURLgpvBc74FRTem7fDqdPtz8+cqQ6vT12rNhFIpyXLgfqL7/8knfffZf333+flJQUfvKTn/DBBx8M6AAtCMJ5UmQo3wVFn4LT7X6vLhASroLImSD1bRByNDnI3ZbL6S9OY2/wrLkePS4a01IToamhvdeBmhp1anv3bnUftDsfH5gxQ53ejo7uvT4IQ0qXA/W0adNISkril7/8JRdffDEAu3fvbnfelVde6b3eCYLQf2q/V+9DW0ta2yQdxFymFs7Q9m0BEnuDnZwtOeRszcHR1Dq9LEkSMRfFYFpqIjgxuHeeXFHg5Ek1c9i337ZfHBYfrwbnqVPVKlaC4EXdmvrOz8/nqaee6vT4QNxHLQhCNzUWq4Uz6r73bA+bpBbOMPbidHIHbGYb2ZuzyduRh9PWOu0uSRLxU+JJX5JOYGwv3fttaoL9+9Xp7VLPPOBoNDBxohqg09PF4jCh13Q5UMttS6sJgnBhcdRD0WfqVLdH4YxUSL4RAtL6tDtNNU1kb8omf1c+LkfrAEDSSCROTyR9cTr+Ub2Uuau4WB09HzigVrFyFxysLg6bPVv9f0HoZQNrP5UgCH1PdqqLxIrWgmxtbTeEqglLwib16WixsbKRrI1ZFOwtQHa2fmDQ6DQkzUpi2MJh+IX3Qr1qlwu+/lodPWdmtj+ekaGOnidMgKG00l/odyJQC8JQpShQ87W63crmVpxCY1TvQcdcBpq+2/1gKbOQtT6LwgOFKHLrPWCtXkvyJckMWzAMn5BeuC9eVwe7dqn/ams9jxmN6n3nefMgLs77zy0IXSACtSAMRZZcdaGYJcutUVJXcSdcBfqz7+v0pvriejLXZVJ8qNgjb7rOR0fqvFRS56diDPTyAi1FgawsdfT81VdqmUl3MTHq6HnaNBApiIV+JgK1IAwl9hooWANVBzzbg0aohTP8EvqsK7V5tWStz6Lk6xKPdr2fnrT5aaTMS8Hgb/Duk9ps6n3n7duhqMjzmCSp09pz58Lw4WJxmDBgiEAtCEOBy6YWzSjZBIpb5iyfaEi8HkLG9llgqjldw6m1pyg/6pna1xBgYNiCYaTMTUHn4+W3prIyNTjv3QtWq+exwEB1YdicORDai/uvBaGHuv3XkJaWxsGDBwkP99yiUVtby8SJEzndUYYeQRD6h6KoZScLPwZHXWu71g/ir1Bzc2t6f2GUoihUZ1Zzau0pKk9UehzzCfZh2KJhJM1KQmf0YoCWZfjuOzVAHz/e/nhamjp6vvhiNQ+3IAxQ3f7tzM3N7XCvtM1mo6jtVJIgCP3HfAryP4DGArdGDUTPg/hloOulrU1uFEWh4lgFmWszqc6u9jjmG+ZL+uJ0EmckotV78cNCfb2aNWzHDjWLmDu9HqZMUReHJSZ67zkFoRd1OVB/+umnLf+/ceNGgt32D7pcLrZs2UJKSopXOycIQg9Yy88UzvjGsz1kvLrdyrf3U1sqikLZd2Vkrs2kNq/W45h/pD/pS9JJmJqARuel9KOKAjk56uj58GE1D7e7yEh19DxjhloDWhAGkS4H6quvvhpQswHddtttHsf0ej0pKSm8/PLLXu2cIAjd4GyE4rVQtg0Ut1kvv0R1oVjQ8F7vgiIrlHxVQub6TMyFZo9jgbGBpC9JJ35yPJLGS/fDHQ61YtX27WoFK3eSBGPGqKPnUaPE4jBh0Op2ZrLU1FQOHjxIREREr3VKEIRukF1QsRMKPwNXQ2u7PggSroGIab1eOEORFYq+LCJzfSaWUovHseDEYExLTcRcFOO9UpMVFerU9p490OhZexp/f5g5Ey65BMT7lHAB6PY96pycnHZttbW1hISEeKM/giB0laJA7RE1L7e1rLVd0kPsQohdBNreLRAhO2UK9hWQtSGLxkrPgBmSEkLGsgyixkZ5J0ArChw9qo6ev/++fWGM5GR1envyZPVetCBcILodqJ9//nlSUlK46aabALjhhhv46KOPiI2NZd26dYwfP77L13rrrbd46623yM3NBWD06NE8/vjjLFmypLvdEoShpbFQTVhiPuHZHj4VEq9R03/2IpfDRf7ufLI3ZtNU0+TZBVM4pmUmIkZEeCdANzSoI+cdO6DSc8U4Oh1MmqROb4s1MsIFqtuB+k9/+hP/+te/ANi8eTNffPEFGzZs4IMPPuChhx5i06ZNXb5WQkICzz33HCaTCUVReO+997jqqqv4+uuvGT16dHe7JggXPocZCj+Bij2A24gyYBgk3QgBKb369E6bk7ydeWRvysZm9ixWETkyEtMyE+EmL1XXystTR88HD6r3ot2FhalT2zNnqvugBeEC1u1AXVpaSuKZbQ2ff/45N954IwsXLiQlJYWpU6d261pXXHGFx9dPP/00b731Fvv37xeBWhDcyQ4o/QKK14PsFiAN4ZB0HYRO7NXFUo4mB7nbcjn9xWnsDXaPY9HjojEtNRGa6oVRvNMJhw6pAbqD22yMGqVOb48dq5aZFIQhoNuBOjQ0lIKCAhITE9mwYQO/+93vAHU7xvnUona5XPz3v/+loaGB6dOnd3iOzWbD5lZyzmxWV5U6HA4cbT9x90DzNbxxLUHwCkVBqjmMVLRGTf/ZTOODErsYJWqeWjij7XYkL7E32Mndmkve9jwcTa1/F5IkET0hmvTF6QQlqnnBz+vvproaadcupL171X3Q7nx9UaZNQ5kzB6LPbC1zudR/gtBHvB0funOdbgfqa6+9lltuuQWTyURVVVXL/eSvv/6a9PT07l6OI0eOMH36dKxWKwEBAaxZs4ZRo0Z1eO6zzz7LihUr2rVv2rQJPy/ujdy8ebPXriUIPeUnlxLn3Iu/UtrSpiBRrR1FqXYKzhIn0Du/q65GF/Xf1mM5akFxuE2xS+Bn8iNoYhClYaWUHimFIz18EkUhoLCQiCNHCMrLQ2qzOKwpPJzKMWOozchA1uvV/dGC0M+8FR8a2+5WOAtJUdounTw7h8PBa6+9RkFBAcuXL+eiiy4C4Pe//z2BgYH89Kc/7VZn7XY7+fn51NXV8eGHH/L222+zY8eODoN1RyPqxMREKisrCQo6/2o/DoeDzZs3s2DBAvRi1ajQX2xVSEWfINUc8mwPGoWccC349l65RWutldObT1OwuwCXo3XEKmkkEqYmkLYoDf+o88xo1tSEtG8f0s6dUO6Z7xuNBmXiRHX0PGyY2PssDBjejg9ms5mIiAjq6urOGb+6Hah722WXXcawYcP485//fM5zzWYzwcHBXXqhXeFwOFi3bh1Lly4VgVroey4rFG+A0s2guE1l+8SqCUtCem/dRmNVI1kbsijYW4DsbC35qNFpSJqVxLCFw/ALP89Zq6Ii9d7zgQNqFSt3ISFqUYzZs8ELf8uC4G3ejg/diV89ykT/j3/8gz//+c+cPn2affv2kZyczKuvvkpqaipXXXVVjzrdTJZlj1GzIFzwFFldxV34CTjd7s/qAiD+Soia3WsJSyxlFrI2ZFG4vxBFbv3MrtVrSb4kmWELhuET4tPzJ3A64Ztv1ACdmdn+eEaGurVq/HjQ9n5xEEEYjLodqN966y0ef/xx7r//fp5++umWBWQhISG8+uqr3QrUjzzyCEuWLCEpKYn6+nr+/e9/s337djZu3NjdbgnC4FR3XN0P3eRW0EbSQfSlELcEdL2Tl7q+uJ7MdZkUHyrGfVJNZ9SRMi+FtMvSMAaeR7KU2lrYtQt27gSzZypRjEaYPl3dXhXXe9P4gnCh6Hagfv311/nrX//K1VdfzXPPPdfSPmnSJB588MFuXau8vJwf//jHlJSUEBwczLhx49i4cSMLFizobrcEYXBpKoX8D6GuzUqs0ImQeC34RPbK09bl15G5LpOSr0s82vV+etLmp5EyLwWDv6FnF1cUddS8bZs6ipZlz+OxserWqmnTwOc8RumCMMT0KIVo8wIyd0ajkYaGhg4e0bm//e1v3X16QRjcnA1qTu7yHYBbIPNPhsQbIMjUK09bc7qGU2tPUX7Uc/GWIcDAsAXDSJmbgs6nhzWZrVb1vvP27VBc7HlMo1GntefOheHDxeIwQeiBbv9lpqam8s0335CcnOzRvmHDBkaOHOm1jgnCBUV2Qvl2KFoLLrdtGfoQNeVn+FSvBzFFUajOrObU2lNUnvBMvekT7MOwhcNImp2EztjDAF1Soqb13LdPDdbugoJg1ix1gVho76YzFYQLXZf/QleuXMmDDz7IAw88wN13343VakVRFL788kv+85//8Oyzz/L222/3Zl8FYfBRFLUudMFqsLmNZjUGtWhGzELQ9nCqudOnVKg4VkHmukyqs6o9jvmG+ZK+KJ3EmYlo9T1YvCXL8O236uj5xIn2x4cNUxeHXXSRmodbEITz1uW/pBUrVvCLX/yCn/70p/j6+vLb3/6WxsZGbrnlFuLi4njttdf4wQ9+0Jt9FYTBpSFfXShWf8qtUYKI6ZBwFRhCvPp0iqJQ9l0Zmesyqc2t9TjmH+lP+pJ0EqYmoNH1YAW52Qy7d6uLw2pqPI/p9TB1qjq9fSa9sCAI3tPlQO2+MvTWW2/l1ltvpbGxEYvFQlRUVK90ThAGJXututWqch8ehTMCM9T90P5JXn06RVYo+aqEzPWZmAs9V1gHxgaSviSd+MnxSJpuTq0rCpw+rY6eDx9un7IzKkpduT1jBngxM6AgCJ66NTfVtmSdn5+fV1N3CsKg5rJD6SYo2QiyW+EKY5RaOCNkvFfvQyuyQtGXRWSuz8RSavE4FpQQRMayDGIuiul+qUm7Hb78Ug3QBQWexyRJLYgxd65aIEMsDhOEXtetQJ2RkXHOP/rq6uqzHheEC46iQNUBKFgDjtrWdq0fxC+DqLmg8d79WtkpU7i/kMz1mTRWeuYLDkkJIWNZBlFjo7ofoMvL1cVhe/dC2zzE/v7q4rBLLoFwL5WxFAShS7r17rFixQqCg4N7qy+CMPiYM6Hgv9CQ59aogahLIP5y0Ad47alcDhf5u/PJ3phNU02Tx7FwUzimZSYiRkR0L0DLMhw9qo6ev/++/fGUFHX0PGmSei9aEIQ+161A/YMf/EDcjxYEAGslFHwENV95tgePhaTrwTfGa0/ltDnJ25lH9qZsbGbP9LqRIyMxLTMRburmKLehoXVxWKXn1i10Opg8WQ3QKSnn1XdBEM5flwN1t6fRBOFC5GyC4nVQttWzcIZvvLpQLNh7uQQcTQ5yt+dyevNp7A12j2PR46IxLTERmtbNPcp5eero+csv29ewDg9Xp7ZnzoQA780ECIJwfnq06lsQhhxFhvKdUPQZON0WbukC1a1WkTO9VjjD3mAnZ2sOOVtzcDR6FpePnRiLaamJ4MRu3IJyONRV29u2QW5u++OjR6uj5zFj1ExigiAMKF0O1HLbvL2CMFTUHlXzclvd8mNLOohZAHGLQeudvNW2ehunN58md3suTlvraFeSJOKnxJO+OJ3AuMCuX7CqSl0ctmcPWDxXhePnp26ruuQSdZuVIAgDlkgdJAidaSyGgg+hrs0iq7DJatpPo3dWP1trrWRvyiZvZx4uR+teZUkjkTg9kfTF6fhH+XftYooCx4+r09vffad+7S4xUR09T56sVrESBGHAE4FaENpy1EPhp1CxC4+EJQFp6n3ogDSvPE1jVSNZG7Io2FuA7GydsdLoNCTNTGLYomH4hXcxT0Fjo5pze/t2dZuVO60WJk5UU3umpYm9z4IwyIhALQjNZAeUblUXi8luRSYMYWrpybBJXglyDeUNZK7PpHB/IYrc+kFAq9eSfEkywxYMwyeki9PphYVqcD5wQE1U4i4kRJ3anjVLLZIhCMKgJAK1ICiKus2qYDXY3LYqaYwQtwRiLgPN+e8hri+uJ3NdJsWHij0WZ+qMOlLmpZB2WRrGwC5MRzud8PXX6uKw7Oz2x0eMUKe3x48Xi8ME4QIgArUwtFlyIf8DsLgHPAkiZ0HClaA//5FoXX4dmesyKfm6xKNd76cn9dJUUi9NxeDfhQpatbXqvuddu9QiGe58fGDaNDVAx8aed58FQRg4RKAWhiZ7jZrys+qAZ3vQCPU+tF/CeT9FzekaMtdlUnakzKPdEGAg7bI0UuelovM5x5+gosCpU+r09jffqJnE3MXGqsF52jQ1WAuCcMERgVoYWlw2KNkAJZtBcduj7BMNiddDyNjzug+tKArVmdWcWnuKyhOeGb98gn0YtnAYSbOT0BnP8adntcL+/WqALvEciaPRwIQJ6uIwk0ksDhOEC5wI1MLQoMhq2cnCj8HhNm2s9YeEKyByDmi0Pb+8olBxrILMdZlUZ3kWpvEN9SV9cTqJMxPR6s/xHCUlanDetw9snulCCQqC2bPVf6HdzEgmCMKgJQK1cOEzn4T8/0KjW8lGSQvR8yBuGeh6XqpVURTKvisjc10mtbm1Hsf8I/1JX5JOwtQENLqzLOqSZXVae/t2OHmy/fH0dHV6+6KL1DzcgiAMKeKvXrhwNZWphTNqv/VsD50AideBT88zcimyQsnXJWSuy8Rc6LmwKzA2kPQl6cRPjkfSnGVa2mxWF4bt3KkuFHNnMMDUqWqATjj/++WCIAxeIlALFx5nAxSthbJtgNviK79ESLoRgjJ6fGlFVig6WETmukwspZ5pOYMSgshYlkHMRTGdF7FRFHVL1fbt8NVX4HJ5Ho+KUoPz9Olqmk9BEIY8EaiFC4fsgvIdUPQ5uBpa2/XBkHA1REzrceEM2SlTuL+QzPWZNFY2ehwLSQkhY1kGUWOjOg/QNptasWr7djVJiTtJgnHj1AA9cqRYHCYIggcRqIXBT1Gg9oial9vqthVK0kPsIohdCNqe5bV2OVwU7Ckga0MWTTVNHsfC0sPIWJZBxMiIzgN0ebkanPfuhSbPxxMQoGYNmzNHLTEpCILQARGohcGtsVBdKGY+4dkePg0SrwZDz1ZHO21O8nflk7UxC5vZc/V15MhITMtMhJs6Ca6yDEeOqAH62LH2x1NT1dHzxReD/vwzngmCcGETgVoYnBxmKPgYKvfiWTgj/UzhjJQeXdZpdZKzLYfTX5zGbvHMnR09LhrTEhOhaZ0Ef4tFLSm5Y4daYtKdTgdTpqgBOjm5R30TBGFoEoFaGFxkB5R+AcXrQXYb6Roj1JXcoRf16B6vvcFOztYccrbm4Gh0eByLnRiLaamJ4MTgjh+cm6vm3T50SM3D7S4iQi2MMXMm+HexVKUgCIIbEaiFwUFRoOogFK5W03820/hA/DKIvhQ03f91ttXbOL35NLnbc3HaWoOsJEnETY7DtMREYFxg+wc6HGpg3rYN8vLaHx8zRh09jx4tCmMIgnBe+jVQP/vss6xevZoTJ07g6+vLjBkzeP755xk+fHh/dksYaOqz1fvQDTlujRJEzYH4K0DfQSA9B2utlexN2eTtzMPlaN0iJWkkEqYlYFpiwj+qgxFwZaW673n3bmho8Dzm5wczZqgj6Kie79EWBEFw16+BeseOHdx9991MnjwZp9PJo48+ysKFCzl27Bj+YppQsFWppSerD3m2B49W83L7xXX7ko1VjWRtyKJgbwGys3WPtUanIWlmEsMWDcMvvM3+ZUVRF4Vt364uEnMrUQlAYqKad3vyZDVRiSAIghf1a6DesGGDx9erVq0iKiqKw4cPM2fOnH7qldDvXFb1HnTpF6C43fP1iVUXioWM7vYlG8obyFyfSeH+QhS5NdBq9VqS5yQzbOEwfELaVJ9qbFS3Ve3YoW6zcqfVwqRJ6vR2aqrY+ywIQq8ZUPeo6+rqAAgLC+vnngj9QpGhYg8UfgLO+tZ2XQAkXKXWiO5mwpL64noy12VSfKgYxW0krDPqSJmbQtqCNIyBbfZYFxSoo+cDB9R70e5CQ9V9z7NmqUUyBEEQetmACdSyLHP//fczc+ZMxowZ0+E5NpsNm1tFIbNZzbHscDhwtH1D7YHma3jjWkI3mY+jKfgQrG4lHSUdStQ8lNjFoPUFpwtwdXoJd3X5dWRvyKb0m1KPdr2fnpS5KSTPS8bgr05TOxwOcDqRvv4aaccOOH26/QWHD0eeMwfGj29dHCZ+TwRhyPB2fOjOdSRFaXvDrX/8z//8D+vXr2f37t0kdFKE4Mknn2TFihXt2v/973/jJ/IiD0pGuZo4116C5HyP9lrNMEp007FL3Ru12kptmA+bseZZPdo1PhoCxwcSMCYAjbF1VK63WAj//nvCjx1D1yZzmMtgoGb4cCrHjMEmykoKguBFjY2N3HLLLdTV1RF0jtm5ARGo77nnHj755BN27txJampqp+d1NKJOTEyksrLynC+0KxwOB5s3b2bBggXoRcao3uW0IBV/jlSxG8/CGUnIideriUu6SFEUqjOryV6fTeXJSo9jxiAjaQvSSJyViM6oa34AnDyJZudO+O47NZOYu9hYlEsuQZkyBXza3LcWBGFI8nZ8MJvNREREdClQ9+vUt6Io3HvvvaxZs4bt27efNUgDGI1GjMb2OZv1er1XA6u3rye4kZ1qVaviteBqAg2ARk31mXANhE9B28WFWYqiUHGsgsx1mVRnVQOgOTMt7RvqS/ridBJnJqLVa9UHWK2wb5+6OKzEbYpdo1H/XXSRujjMZBKLwwRB6JC34kN3rtGvgfruu+/m3//+N5988gmBgYGUlqr3E4ODg/H19e3PrgnepihQ841aH9pW0dquMUDsYohZANqubW1SFIWy78rIXJdJbW6txzG/CD9MS00kTE1AozszxV1crC4O279frWLlLjgYZs9W/4WE9PTVCYIg9Jp+DdRvvfUWAHPnzvVof/fdd1m+fHnfd0joHQ15asKS+ky3RgkipquruQ0hXbqMIiuUfF1C5rpMzIVmj2MBMQGYlpqInxyPpJHUOs+HD6sB+tSp9hczmdTR80UXqVutBEEQBqh+n/oWLmD2Wij8GCr341E4IzADkm4E/8QuXUaRFYoOFpG5LhNLqcXjWFBCEKalJmIvilUDdF0d7Nql/qut9byQ0QhTp6oBOj7+PF6YIAhC3xkw27OEC4jLBqWboWQjyG4VqIxRkHQ9hIzr0j1g2SlTuL+QzPWZNFY2ehwLSQkhY1kGUWOjkACystTR81dftV8cFh2tBufp00HcUhEEYZARgVrwHkWBqgNQsAYcta3tWj+IvxyiLulS4QyXw0XBngKyNmTRVOO5ZSosPYyMZRlEjIxAstvVkfOOHVBY6HkRSVL3PM+dCyNGiMVhgiAMWiJQC95hzoSC/6r3o1toIHquGqR1587d7rQ5yd+VT9bGLGxmz0VfkSMjMS01EZ4RDmVl8N//qrWfrZ77pQkMVLOGzZkDIsOdIAgXABGohfNjrVBXctd87dkeMk4tnOEbfc5LOK1OcrblcPqL09gtdo9j0WOjMS01EZoSrBbEePUfcPx4+4ukpamj54svBp34tRYE4cIh3tGEnnE2QvE6KNsKiltaT98E9T508MhzXsLeYCdnaw45W3NwNHqm04u9KBbTMhPBIRq1pORfd0J1tecF9HqYMkUN0ElJXnhRgiAIA48I1EL3KDKU74TCT8HlVo9ZHwTxV0HkjHMWzrDV2zi9+TS523Nx2lqrY0mSRNzkOEyL0wm0V8EXq+HQIXA6PS8QEaEG5xkzQJRDFQThAicCtdA1igJ130N++8IZxCyAuMWgPXu6TWutlexN2eTtzMPlaB2FSxqJhGkJpM9PJiD/OLz3BuTleT5YkmD0aLXu8+jRYnGYIAhDhgjUwrk1FqsJS8zHPNvDJkPiNWAMP/vDqxrJ2pBFwd4CZGfr1imNTkPijETSJ4fhd+QAvPJ3aGjwfLCfX+visMhIb70iQRCEQUMEaqFzjnp1irtiFx4JSwLSIOkG9b9n0VDeQOb6TAr3F6LIrY/X6rUkz05iWKIdn692witH1RG7u6QkdfQ8ebJ6L1oQBGGIEoFaaE92QOlWdbGY7Lb9yRAOiddC2MVnnXquL64nc30mxQeLPbLP6Yw6UqbFkOZXivHQ+7C1wvOBOp26anvuXEhNFdPbgiAIiEAtuFMUqD4MBavBXtXarvGBuCUQMx80nY9u6wrqyFybScnXJR7tel89qeMCSHVlYdi7FtoWTA8LU6e2Z81S90ELgiAILUSgFlSWXMj/ACzZbo0SRM6ChCvVVd2dqDldQ+a6TMqOlHm0G3x1pCW7SGn4Bv2BnPYPHDlSnd4eO1YtMykIgiC0IwL1UGerhsI1UPWlZ3vQSHU/tF9Cpw+tOlVF5rpMKo57TmEbDQrpEXUk1XyL7kS954N8fNRtVXPnqjm4BUEQhLMSgXqoctmgZAOUbAbFbSraJ1pdKBY8psN7xIqiUHm8ksx1mVRluk2PK+CrNJIeUEqi5Tja4jaLw+Lj1eA8dapaxUoQBEHoEhGohxpFhsp9avlJh1tNZ60/JFwBkXNA074+s6IolB8p59TaU9Tm1rYecLrws1Zj0ueSoC9D0wg0z2JrNDBxohqg09PF4jBBEIQeEIF6KKk7oe6HbnKrNCVpIXoexC0DnV+7hyiKQslXJWSuy8Rc6BbYGxoJaCzDpMslPqTBMwYHB6uLw2bPVv9fEARB6DERqIeCpjK1cEbtt57toRep2618oto9RJEVig4WkbU+i/qSM/eZFQUqqwhqKMHkX0xshMMzQGdkqKPnCRNA235ULgiCIHSfCNQXMmcDFK2Fsm1Aa0Yw/JLU+9BBGe0eIjtlCg8UkrU+i4aKM1nCbHYoLSWksRhTVC3Ryc7WAG00wrRpaoCOi+vtVyQIgjDkiEB9IZKdUL4Dij4HV2Nruz4EEq6GiGnt7he7HC4K9hSQtSGLppomNRGZ2QzFxYTZyzAlNhGZ5BagY2LU4Dx9urqSWxAEQegVIlBfSBQFar9TC2fYylvbJT3ELoLYhaD1XHHttDnJ35VP1sYsbGYbuGQoL4fiYiL0dWQkWQkLdqkBWpLUae25c2H4cLE4TBAEoQ+IQO1m3TqJl166GJC46qr+7k03NRRAwYdgPuHZHj4NEq8GQ6hHs9PqJGdbDqe/OI3dYofGJigphrIyooOsmEw2QoPOVLgKDFQXhs2ZA6Ge1xEEQRgK+jM+iEB9xtq18OabGioq/HjzTQ06HSxb1t+96gJ7HRR+ApV78SicEWhS70P7J3ue3mAnZ2sOOVtzcDQ4oLoKioqhtpbYCAemcTaCA84E6GHD1NHzxIlqHm5BEIQhqL/jg3j3Rf0hvP46aDQKyclmJCmY119Xjw3YYC071GQlJRtAtrW2GyMg8Tp1Rbfb1LSt3sbpzafJ3Z6L09IEpaVQXIJktxEX6cB0sZVAf1mtVDVlmpraMzGxH16YIAjCwDEQ4sOQD9TNPwRJgoQEyM9X41NhIQMzWCuKmu6zcA3Ya1rbNT4QvwyiLwVN64/VWmsle1M2eTvycFXXqtPbFZVIikxCtJ30BBsBfrJa63nuXDW9p1/7/dSCIAhDzUCJD0M6ULv/EJKSQHbbwZSUpP5QBlSwrs9WC2c05Lo1aiBqDsRfDvrWylONVY1kb8wmf2cuckkZFBeDxYJGA4nRdtITrfj5ohbEmDsXRo0Si8MEQRDOGEjxYcgG6rY/BIAa3XFOJf2RQN1dhMtjBk6wtlaqI+jqQ57twWPUwhm+sS1NDeUNZK7PpHBbFkpRsTrF7XSi1UByvI20BBu+YX4wcwFccglERPTxixEEQRjYBlp8GJKBuqMfgoJCru9qqrQ7yHXFENYwGgmpf4O1ywrF66B0CyjO1nbfOEi8HkJGtzTVF9eTufYUxZu/VwN0TTUooNMqpCTaSYu3YTQlqaPnyZPVe9GCIAiCh4EYH4ZcoO7ohwBQoztGqWEPemsopT57qLEdI8ypBsI+D9aKDBW7ofBTcLqVidQFqrWhI2eBpFa+qCuoI3PN95Rs/BaKS8BqBUCvU0iNt5Ga5MIwfZK6OCwlpZc7LgiCMHgN1PgwpAJ1Zz8EBYVcn9U4NBZ8bUk4/PLJ9VlNqGUUEup92z4L1nXHzhTOKG5tk3QQMx9il4DOF4CanBoy/3mAsq3fQ3lFyw0Ug14hLd5GypgA9PPnw8yZ6j5oQRAEoVMDOT70a6DeuXMnL774IocPH6akpIQ1a9Zw9dVX98pzdfZDgNZPS/6uWBxI+LtiKTXsoUbX+qkJevmH0VSiZhSrO+rZHjYJEq4BH/VectWxMjL/so2KfZlgbh1tGw0KwxJsJF+ahu6yeeoiMY0GQRAE4ewGenzo10Dd0NDA+PHjuf3227n22mt77XnO9kNo+bQkWfCXE3HQgEEOpVFb2u5TE/TCD8NhgaLPoHwnHoUz/FMg6UYIHIaiKFTuzSTzz9uo+joPHI6W03yNMsOGQdJ1k9HOnwvR0efZIUEQhKFjQMeHM/o1UC9ZsoQlS5b06nOc7YcArZ+W/FyxVFVJWK1GGpsknPpYTuj3UH/sGD71o9s9zmyGe+6Bd99VE3h1lwYnwwK2MiJoHXpNU0t7oyuU7+uuoaBxCsgK4dn7CD6yB111ucfjDToZ3+ggCkZcwtb4abi+NcK3bZ9FEARB6Ex2Nhw+rMaHoCAoKfE8bg08RtHYPWjMsTgcEna7EatNIjCy41E19E6wvuDvUf/jH2pQHTu2/TGPT0tKEg2BX+MIsOLQaFAAl7GK/HG/wKdqusenpmbWJvhCgixXd3qkMNy3nMtCThGia6QUQAa7omWvOZX99YHobP+Pi4+9RdpJJ/pGHTagOfeYVm+jMsnBoTFhFIRqQFoHrINu9UEQBEHIlcAxDnx8oa7NMQUFa/g+7AE5aG3hSIBLlnFJPoQrF9EolXQ4qgY1WB85osafIReobTYbNltrukyz2QyAw+HA4TYd7O7mmyXefFNDXp7SLiNmje57SvS78XPFICmA1g6KHTQaJEAjG3AE5KK3R6NzhHk81m4HjT+ERoDiWZCqU7H6ehYE5ZBsaP2VUIBvGqPZXp+CX42dRd+dIibLB8VuBCSQ1Ags+9rJHeHky3GBNPg0Lw6r7doTC4IgCO2ExkJlJdgBg8HzmEtfjSMgF41sQNLa1UZJBkmDpICfK4YS/W6SNUcIbTOqLiiAgACJm2+WcTgUOtJZzOrIoArUzz77LCtWrGjXvmnTJvzOkvZy6tRoPv88lfJyiIxUp5kVFE4nvEeDowoaw3BgQe8PWo225XEKRhzaRjRBeQTWh7d8amps1KGTYFh6HTExDefstz92pupLyNBWe7QXyQHst8URXOHgx1/moM0Jx+EIUA/q1QBtD3NQNNXK6Yk6ZK1EDOZzPp8gCILQNaWl/mRnBYMT/PzUfBUKCnWBeWi0DvRKAJJWfe/Xa7VoZLBYLCjoafCr4hv7e6QV3tMSHyoqfFEUuPzyHKCMdes6ft7GxsYu91FSFKXjcN/HJEk656rvjkbUiYmJVFZWEhQUdNbrr1unjqw1GnVkXaP7nv3BD2FQAjHK6mhZURQaGhrw9/dHOpNO06apxi7VM63uRUKdoykoAFmWuPtumaVLz/Gtc9mQyjYjlW4Gxe3TkzESOXgB8qFqCj88wOlTLppsbiu0NVpCx8Yz7I7ZRFwyqqUvgiAIgvf1R3wwm81ERERQV1d3zvg1qEbURqMRo7H9PLNer0d/jkxbV12lVmp8/XUoKFSoGvUJTk0DAc7klhzXzeFQkqSWNoMSRqO2lDy/T7AcGwtI3HcfLFt2lq1PigKV+6HwY3DUqheWNKD1BeUinHssFGz8mOx8A1a7BGjV5/bzI2JaOhm/uJSwMbEiQAuCIPSBPo0PZ5wrZrnr10BtsVjIyspq+TonJ4dvvvmGsLAwkjpaon2emm/qP/v2MXJdewh0xXa4SMydhISfK5Zc1x6MPsd45Kejz744wHxKTVjSmN/a5lKgNgbnXhc5hw5zusiI3XHmA4ckQUQ4UXNGkvGTmYQOC+v4uoIgCEKv6ZP40EP9GqgPHTrEvHnzWr5+4IEHALjttttYtWpVrzzn0qUK/ylezfcnLNjrkzAGnPsx9vpQnL4lpCxdzdKlo6CjH561HApWQ83XrW2NjVCix75fS87JWnKKjDicPuoxgwFiYohdNA7T9eMJTgr2yusTBEEQeqbX4sN56tdAPXfuXPr6FvmximNU+u5hdFIseSclLBYIOMsPw2JRPzWNToql0ncPxyqOMTrKbYWfsxGK10LZNlBcZ+pFV0FhI/Zvg8jODCO3xIDTeeaHFxSEFB9H3KKxmK4YQWCcSO8pCIIwEHg9PnjJoLpHfb4URWHdsX+it5ZwUZyROG0Zp08DTvD1A2SZZKWWBn0IaDQ0NYK/D6SlQXS0Qm5dCeuO/ZNRkc8gKTJU7ITCz8DVoO7XKi2FompsObFkHTWRV+KDSwa0GoiNRoqPI+Gy4aQvTicgugsf1QRBEIQ+oSgKq0+sprqpmvT4MHSShZOnoLYR/P0BFJyaBhwSIEk0NAAaGJ4BcXF6smqqWX1iNaMivb8AeEgFape1gjkVHzHPtxrsRRAK9rHQ1AR6WSG20Uqw0UGdr54SPx8cGglf3zP76+yAL7jKP8JVtghd+TY1P3d9PRQXQ3k1ttJ4Mr+bTF6Rn1ojw9cX4mLRxMeSOCeV9EXp+EV0vo1MEARB6B8uxUVJfQlhvmFUW6vxCYO4YZCXB3U2MPooOPRWrBorNquEooPkZPAJg2orhPmGUVJfgktxoZO8G1qHVKDWyVYmhiZil1JRtGoVKhQF8/EKnKeL0LsM2CQNAdUyKVoD2vR4glMiW1b4ae01GKzFaDP/BDVNaoC2WLBVRZP59Uxy84NQAMLCIS4WbWQEyZckk7YgDd9Q33573YIgCMLZ6TQ6nr70aert9R7tW7aAumTKhaIUI0lxgJbly2H+fM9rBBoC0Wm8H1aHVKAG0Gv06I3hoA/AWVWH5etMHKWNNNqDsLt0KIqCJEkYtE78TtTgrLURMCEFnaEGLPlgNUPu12DXYKsPJuvwNHJOR6LodJAQC7Gx6IL9SZmbQtplaRiDupi2TBAEQehXob6hhPqGerT95FqIMsJrr8nk5weTlBTCffdpeq/UcQeGXKAGwOXCevwUpUcqsNokJJ0Bo6+EXpaxWhV8fCQ0Gi02p0R9fRXS8Rz8/WR0ehk0LqwWPacPjeP0iXiUgCDIiIPICPT+RlIvTSV1fioGf8O5+yEIgiAMeMuWgdMp89JLjdx9d1CX9kl709AK1IoCZjPWzByKc7XYFT0+/s2L6RU0GvDxcaLT6TH6NeAXVING48SpSDQ2KBh1DhyuAPavnUGTfjhMiIPAAAz+BtIuSyNlXgp6365vYhcEQRAGBzXT2GGWLl3a5889tAJ1SQmu7BwqSvyxS774+Cjtdrzp9TaCwivRGVpTlWqAutpgmup9CA5qAtNIMKZjDDIybOEwkuckozMOrW+lIAiC0DeGVnSJiaHJZcCm6PAxegZpDXZ8g2sw+De2ZKORkbA2+FJbEYrDYUSjt+PUODEmRDFs/hiSZiWh1Ws7fi5BEARB8IIhFahlBRoVHyRFbjeSDoouR6N1oiggSxJ2m4G6ylBsTX4gSUga0KCgMeiZftd0dKGp/fIaBEEQhKGlb++I97PKk5U4XFp0WkW9X+2mqT4IGQmHy0B1eQTlhfHYrP5qkJYUjHoXvnoHsqSlOqu6k2cQBEEQBO8aUiPqxvJGdJIGrU6Dy+pSy6WcUVMTjNWlwVLrD+iQAI2kYNAramB3OtHqNSiShsaKrtcRFQRBEITzMaQCtdPuRCdJ4GOERofHMa1GwlIbjCLL6LQKBoOCTuM26pZl8PEByYXT5uzjnguCIAhD1ZCa+tYZdIACRp92x/R6Ga1GwaB34usjewbpZmdqYYsV3oIgCEJfGVKB2i/KD0kj4dLoQaMBl6vlmAbwNcpoNXL7B7pcoNHg0uiRNBJ+kSJftyAIgtA3hlSgjhgegd7fgNMuq9PfboH6rFwu8DHitMno/Q1EDI/o3Y4KgiAIwhlDKlBrtBr8IvxQZAXFeKZIhiyDcuafLKt7uNq2AYrRF0VR8IvwQ6MdUt82QRAEoR8NuZutvqG++IXYaayyY/SVkZTWDGQoChIutFpnS8UsAEUvYVPs+IVoRBUsQRAEoU8NrUCtC0AbEE1EupNqpRpnkw69r7alyLeCgmyzoTcaW7KTKYqCo8lFgK+DsPQwtAHRoAvoz1chCIIgDCFDK1Abw+Di1zA4LRiTa/jurYPU5NSg1Wnxi/ZD56OjuLiYuLg4nE1OGssbcTldhKaGMvl/JmNIC1WDtDGsv1+JIAiCMEQMrUANapA1hhE6Nok5zwwnb1ceWeuzqDxVhdPqpLraD7lcg87Hj/DhiaQvTid5djI+Ie23dAmCIAhCbxt6gdqNT4gPw68YjmmpifKj5dQV1nFgzwGmzpxKcEIwUWOixMIxQRAEoV8N6kCtnMnXbTabz/tafql+6BP06M16IqZFoNfrsTRYzvu6giAIwuDncDhobGzEbDaj1+vP+3rNcUtROkiu1cagDtT19fUAJCYm9nNPBEEQBKH76uvrCQ4OPus5ktKVcD5AybJMcXExgYGBLSu3z4fZbCYxMZGCggKCgoK80ENBEAThQuDt+KAoCvX19cTFxaHRnP0W66AeUWs0GhISErx+3aCgIBGoBUEQhHa8GR/ONZJuJlZKCYIgCMIAJgK1IAiCIAxgIlC7MRqNPPHEExjPlLMUBEEQBOjf+DCoF5MJgiAIwoVOjKgFQRAEYQATgVoQBEEQBjARqAVBEARhABOBugvmzp3L/ffff9ZzJEni448/bvn6xIkTTJs2DR8fHyZMmNCr/RMEQRC8p+37eVvbt29HkiRqa2tb2j7++GPS09PRarXnjBfdNSgC9fLly5Ekieeee86j/eOPPz7vjGQul4vnnnuOESNG4OvrS1hYGFOnTuXtt9/u1nVKSkpYsmRJy9dPPPEE/v7+nDx5ki1btrBq1SpCQkLOq6+CIAjC+auoqOB//ud/SEpKwmg0EhMTw6JFi9izZ0+XHj9jxgxKSko8Epb8/Oc/5/rrr6egoICnnnqK5cuXc/XVV3ulv4MmM5mPjw/PP/88P//5zwkNDfXadVesWMGf//xn3njjDSZNmoTZbObQoUPU1NR06zoxMTEeX2dnZ7Ns2TKSk5O91ldBEATh/F133XXY7Xbee+890tLSKCsrY8uWLVRVVXXp8QaDweM932KxUF5ezqJFi4iLi/N+h5VB4LbbblMuv/xyZcSIEcpDDz3U0r5mzRql7Uv48MMPlVGjRikGg0FJTk5WXnrppbNee/z48cqTTz551nMuueQS5d5771UeeughJTQ0VImOjlaeeOIJj3MAZc2aNS3/7/7vkksuadfW9vGCIAhC76upqVEAZfv27Z2eAyh//etflauvvlrx9fVV0tPTlU8++aTl+LZt2xRAqampafn/c73nb9u2rcd9HhRT3wBarZZnnnmG119/ncLCwg7POXz4MDfeeCM/+MEPOHLkCE8++SSPPfYYq1at6vS6MTExbN26lYqKirM+/3vvvYe/vz8HDhzghRdeYOXKlWzevLnDc0tKShg9ejS/+tWvKCkp4dNPP+XVV18lKCiIkpISSkpKePDBB7v82gVBEATvCAgIICAggI8//hibzdbpeStWrODGG2/ku+++Y+nSpdx6661UV1e3O2/GjBmcPHkSgI8++qjlPf/GG29k8eLFLe/5M2bM6HGfB02gBrjmmmuYMGECTzzxRIfHX3nlFebPn89jjz1GRkYGy5cv55577uHFF1/s9JqvvPIKFRUVxMTEMG7cOH7xi1+wfv36dueNGzeOJ554ApPJxI9//GMmTZrEli1bOrxmTEwMOp2OgIAAYmJiCAoKIjg4GEmSiImJISYmhoCAgJ59EwRBEIQe0+l0rFq1ivfee4+QkBBmzpzJo48+ynfffedx3vLly7n55ptJT0/nmWeewWKx8OWXX7a7nsFgICoqCoCwsLCW93xfX9+W+98xMTEYDIYe93lQBWqA559/nvfee4/jx4+3O3b8+HFmzpzp0TZz5kwyMzNxuVwdXm/UqFEcPXqU/fv3c/vtt1NeXs4VV1zBT3/6U4/zxo0b5/F1bGws5eXl5/lqBEEQhL523XXXUVxczKeffsrixYvZvn07EydO9Jh9dX/P9/f3JygoqN/e8wddoJ4zZw6LFi3ikUce8do1NRoNkydP5v7772f16tWsWrWKv/3tb+Tk5LSco9frPR4jSRKyLHutD4IgCELf8fHxYcGCBTz22GPs3buX5cuXe8zWDqT3/EEXqAGee+45PvvsM/bt2+fRPnLkyHbL6/fs2UNGRgZarbbL1x81ahQADQ0N59/ZMwwGQ6ejekEQBKF/jRo1asC+5w+a7Vnuxo4dy6233sof/vAHj/Zf/epXTJ48maeeeoqbbrqJffv28cYbb/DHP/6x02tdf/31zJw5kxkzZhATE0NOTg6PPPIIGRkZjBgxwmt9TklJwWKxsGXLFsaPH4+fnx9+fn5eu74gCIJwblVVVdxwww3cfvvtjBs3jsDAQA4dOsQLL7zAVVdd5bXnSUlJYePGjZw8eZLw8HCCg4PbjdK7alCOqAFWrlzZbhpi4sSJfPDBB7z//vuMGTOGxx9/nJUrV7J8+fJOr7No0SI+++wzrrjiCjIyMrjtttsYMWIEmzZtQqfz3ueYGTNm8Itf/IKbbrqJyMhIXnjhBa9dWxAEQeiagIAApk6dyu9//3vmzJnDmDFjeOyxx7jzzjt54403vPY8d955J8OHD2fSpElERkZ2OZlKR0SZS0EQBEEYwAbtiFoQBEEQhgIRqAVBEARhABOBWhAEQRAGMBGoBUEQBGEAE4FaEARBEAYwEagFQRAEYQATgVoQBEEQBjARqAVBEARhABOBWhAEQRAGMBGoBUEQBGEAE4FaEARBEAYwEagFQRAEYQD7/w+VqDkiAI0XAAAAAElFTkSuQmCC"
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "execution_count": 113
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-10-05T13:10:02.926055Z",
     "start_time": "2024-10-05T13:10:02.924376Z"
    }
   },
   "cell_type": "code",
   "source": "",
   "id": "508a50cfb77f94bd",
   "outputs": [],
   "execution_count": 113
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-10-05T08:56:59.910552Z",
     "start_time": "2024-10-05T08:56:59.908855Z"
    }
   },
   "cell_type": "code",
   "source": "\n",
   "id": "3db5717e-ad43-427c-96f4-86721025401b",
   "outputs": [],
   "execution_count": 11
  },
  {
   "cell_type": "code",
   "id": "f0d1a564-c4ee-430b-ada1-f70836c2f82b",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-10-05T08:56:58.829715Z",
     "start_time": "2024-10-05T08:56:58.827992Z"
    }
   },
   "source": "",
   "outputs": [],
   "execution_count": 11
  },
  {
   "cell_type": "code",
   "id": "536c980a-5081-4013-9a22-f785af9cb69c",
   "metadata": {},
   "source": "",
   "outputs": [],
   "execution_count": null
  },
  {
   "cell_type": "code",
   "id": "dce0d13d-feb2-4bb2-b123-d477e6163bca",
   "metadata": {},
   "source": "",
   "outputs": [],
   "execution_count": null
  },
  {
   "cell_type": "code",
   "id": "d315f48f-0388-4629-a547-0469ec2f5060",
   "metadata": {},
   "source": "",
   "outputs": [],
   "execution_count": null
  },
  {
   "cell_type": "code",
   "id": "2d77da15-bcb4-4f7b-b884-281b11f28dc1",
   "metadata": {},
   "source": "\n",
   "outputs": [],
   "execution_count": null
  },
  {
   "metadata": {},
   "cell_type": "code",
   "source": "",
   "id": "f4e3998b725f7d54",
   "outputs": [],
   "execution_count": null
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.9.19"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
