{"nbformat":4,"nbformat_minor":0,"metadata":{"colab":{"provenance":[{"file_id":"14_ipeAU7hkJQwUDot6TFoElbOL82CJEr","timestamp":1706861276480}],"mount_file_id":"14_ipeAU7hkJQwUDot6TFoElbOL82CJEr","authorship_tag":"ABX9TyP7akINd9Yd+Q2gGr4LTo+a"},"kernelspec":{"name":"python3","display_name":"Python 3"},"language_info":{"name":"python"}},"cells":[{"cell_type":"code","execution_count":null,"metadata":{"id":"3P3cxd_Wx2II","colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"status":"ok","timestamp":1706858738847,"user_tz":480,"elapsed":23467,"user":{"displayName":"Ezinne Nwankwo","userId":"03581561058008593041"}},"outputId":"ba138250-4571-40c9-b6c4-9c1f0847e1f1"},"outputs":[{"output_type":"stream","name":"stdout","text":["Mounted at /content/gdrive\n"]}],"source":["# Connect to drive\n","from google.colab import drive\n","drive.mount('/content/gdrive')"]},{"cell_type":"code","source":["import numpy as np\n","import pandas as pd\n","from numpy.linalg import svd\n","import random\n","from scipy.linalg import sqrtm\n","from scipy.special import expit, logit\n","from scipy.stats import bernoulli\n","# for plotting\n","%matplotlib inline\n","import matplotlib.pyplot as plt\n","plt.style.use('seaborn-white')\n","plt.rcParams.update(plt.rcParamsDefault)\n","from sklearn.linear_model import LogisticRegression\n","from sklearn.linear_model import LinearRegression\n","from sklearn.metrics import mean_squared_error\n","import patsy\n","from sklearn import linear_model, ensemble, base, neural_network\n","import statsmodels.formula.api as smf\n","import statsmodels.api as sm\n","from sklearn.utils._testing import ignore_warnings\n","from sklearn.exceptions import ConvergenceWarning"],"metadata":{"id":"acAr40-FykjF","colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"status":"ok","timestamp":1706858771741,"user_tz":480,"elapsed":277,"user":{"displayName":"Ezinne Nwankwo","userId":"03581561058008593041"}},"outputId":"ec05af42-ed46-46cf-95e2-c0df696cb4bd"},"execution_count":null,"outputs":[{"output_type":"stream","name":"stderr","text":["<ipython-input-3-2b420d7a2f3d>:11: MatplotlibDeprecationWarning: The seaborn styles shipped by Matplotlib are deprecated since 3.6, as they no longer correspond to the styles shipped by seaborn. However, they will remain available as 'seaborn-v0_8-<style>'. Alternatively, directly use the seaborn API instead.\n","  plt.style.use('seaborn-white')\n"]}]},{"cell_type":"code","source":["pip install econml"],"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"ExqYuzHCAb47","executionInfo":{"status":"ok","timestamp":1706858787300,"user_tz":480,"elapsed":13226,"user":{"displayName":"Ezinne Nwankwo","userId":"03581561058008593041"}},"outputId":"d1cb7726-bf9f-41f5-cbb3-0798e37ba1b1"},"execution_count":null,"outputs":[{"output_type":"stream","name":"stdout","text":["Collecting econml\n","  Downloading econml-0.14.1-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (3.5 MB)\n","\u001b[2K     \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m3.5/3.5 MB\u001b[0m \u001b[31m9.7 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m\n","\u001b[?25hRequirement already satisfied: numpy in /usr/local/lib/python3.10/dist-packages (from econml) (1.23.5)\n","Requirement already satisfied: scipy>1.4.0 in /usr/local/lib/python3.10/dist-packages (from econml) (1.11.4)\n","Requirement already satisfied: scikit-learn<1.3,>0.22.0 in /usr/local/lib/python3.10/dist-packages (from econml) (1.2.2)\n","Collecting sparse (from econml)\n","  Downloading sparse-0.15.1-py2.py3-none-any.whl (116 kB)\n","\u001b[2K     \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m116.3/116.3 kB\u001b[0m \u001b[31m11.1 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m\n","\u001b[?25hRequirement already satisfied: joblib>=0.13.0 in /usr/local/lib/python3.10/dist-packages (from econml) (1.3.2)\n","Requirement already satisfied: statsmodels>=0.10 in /usr/local/lib/python3.10/dist-packages (from econml) (0.14.1)\n","Requirement already satisfied: pandas in /usr/local/lib/python3.10/dist-packages (from econml) (1.5.3)\n","Collecting shap<0.42.0,>=0.38.1 (from econml)\n","  Downloading shap-0.41.0-cp310-cp310-manylinux_2_12_x86_64.manylinux2010_x86_64.whl (572 kB)\n","\u001b[2K     \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m572.6/572.6 kB\u001b[0m \u001b[31m36.0 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m\n","\u001b[?25hRequirement already satisfied: lightgbm in /usr/local/lib/python3.10/dist-packages (from econml) (4.1.0)\n","Requirement already satisfied: threadpoolctl>=2.0.0 in /usr/local/lib/python3.10/dist-packages (from scikit-learn<1.3,>0.22.0->econml) (3.2.0)\n","Requirement already satisfied: tqdm>4.25.0 in /usr/local/lib/python3.10/dist-packages (from shap<0.42.0,>=0.38.1->econml) (4.66.1)\n","Requirement already satisfied: packaging>20.9 in /usr/local/lib/python3.10/dist-packages (from shap<0.42.0,>=0.38.1->econml) (23.2)\n","Collecting slicer==0.0.7 (from shap<0.42.0,>=0.38.1->econml)\n","  Downloading slicer-0.0.7-py3-none-any.whl (14 kB)\n","Requirement already satisfied: numba in /usr/local/lib/python3.10/dist-packages (from shap<0.42.0,>=0.38.1->econml) (0.58.1)\n","Requirement already satisfied: cloudpickle in /usr/local/lib/python3.10/dist-packages (from shap<0.42.0,>=0.38.1->econml) (2.2.1)\n","Requirement already satisfied: patsy>=0.5.4 in /usr/local/lib/python3.10/dist-packages (from statsmodels>=0.10->econml) (0.5.6)\n","Requirement already satisfied: python-dateutil>=2.8.1 in /usr/local/lib/python3.10/dist-packages (from pandas->econml) (2.8.2)\n","Requirement already satisfied: pytz>=2020.1 in /usr/local/lib/python3.10/dist-packages (from pandas->econml) (2023.4)\n","Requirement already satisfied: llvmlite<0.42,>=0.41.0dev0 in /usr/local/lib/python3.10/dist-packages (from numba->shap<0.42.0,>=0.38.1->econml) (0.41.1)\n","Requirement already satisfied: six in /usr/local/lib/python3.10/dist-packages (from patsy>=0.5.4->statsmodels>=0.10->econml) (1.16.0)\n","Installing collected packages: slicer, sparse, shap, econml\n","Successfully installed econml-0.14.1 shap-0.41.0 slicer-0.0.7 sparse-0.15.1\n"]}]},{"cell_type":"code","source":["import econml\n","from econml.grf import CausalForest, CausalIVForest, RegressionForest\n","from econml.dml import CausalForestDML, LinearDML\n","import numpy as np\n","import scipy.special\n","from sklearn.tree import plot_tree"],"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"LWIlq_iyAZ6R","executionInfo":{"status":"ok","timestamp":1706858808455,"user_tz":480,"elapsed":14592,"user":{"displayName":"Ezinne Nwankwo","userId":"03581561058008593041"}},"outputId":"edef5929-a131-4930-c7ce-15a36ac2aa21"},"execution_count":null,"outputs":[{"output_type":"stream","name":"stderr","text":["/usr/local/lib/python3.10/dist-packages/shap/utils/_clustering.py:35: NumbaDeprecationWarning: The 'nopython' keyword argument was not supplied to the 'numba.jit' decorator. The implicit default value for this argument is currently False, but it will be changed to True in Numba 0.59.0. See https://numba.readthedocs.io/en/stable/reference/deprecation.html#deprecation-of-object-mode-fall-back-behaviour-when-using-jit for details.\n","  def _pt_shuffle_rec(i, indexes, index_mask, partition_tree, M, pos):\n","/usr/local/lib/python3.10/dist-packages/shap/utils/_clustering.py:54: NumbaDeprecationWarning: The 'nopython' keyword argument was not supplied to the 'numba.jit' decorator. The implicit default value for this argument is currently False, but it will be changed to True in Numba 0.59.0. See https://numba.readthedocs.io/en/stable/reference/deprecation.html#deprecation-of-object-mode-fall-back-behaviour-when-using-jit for details.\n","  def delta_minimization_order(all_masks, max_swap_size=100, num_passes=2):\n","/usr/local/lib/python3.10/dist-packages/shap/utils/_clustering.py:63: NumbaDeprecationWarning: The 'nopython' keyword argument was not supplied to the 'numba.jit' decorator. The implicit default value for this argument is currently False, but it will be changed to True in Numba 0.59.0. See https://numba.readthedocs.io/en/stable/reference/deprecation.html#deprecation-of-object-mode-fall-back-behaviour-when-using-jit for details.\n","  def _reverse_window(order, start, length):\n","/usr/local/lib/python3.10/dist-packages/shap/utils/_clustering.py:69: NumbaDeprecationWarning: The 'nopython' keyword argument was not supplied to the 'numba.jit' decorator. The implicit default value for this argument is currently False, but it will be changed to True in Numba 0.59.0. See https://numba.readthedocs.io/en/stable/reference/deprecation.html#deprecation-of-object-mode-fall-back-behaviour-when-using-jit for details.\n","  def _reverse_window_score_gain(masks, order, start, length):\n","/usr/local/lib/python3.10/dist-packages/shap/utils/_clustering.py:77: NumbaDeprecationWarning: The 'nopython' keyword argument was not supplied to the 'numba.jit' decorator. The implicit default value for this argument is currently False, but it will be changed to True in Numba 0.59.0. See https://numba.readthedocs.io/en/stable/reference/deprecation.html#deprecation-of-object-mode-fall-back-behaviour-when-using-jit for details.\n","  def _mask_delta_score(m1, m2):\n","/usr/local/lib/python3.10/dist-packages/shap/links.py:5: NumbaDeprecationWarning: The 'nopython' keyword argument was not supplied to the 'numba.jit' decorator. The implicit default value for this argument is currently False, but it will be changed to True in Numba 0.59.0. See https://numba.readthedocs.io/en/stable/reference/deprecation.html#deprecation-of-object-mode-fall-back-behaviour-when-using-jit for details.\n","  def identity(x):\n","/usr/local/lib/python3.10/dist-packages/shap/links.py:10: NumbaDeprecationWarning: The 'nopython' keyword argument was not supplied to the 'numba.jit' decorator. The implicit default value for this argument is currently False, but it will be changed to True in Numba 0.59.0. See https://numba.readthedocs.io/en/stable/reference/deprecation.html#deprecation-of-object-mode-fall-back-behaviour-when-using-jit for details.\n","  def _identity_inverse(x):\n","/usr/local/lib/python3.10/dist-packages/shap/links.py:15: NumbaDeprecationWarning: The 'nopython' keyword argument was not supplied to the 'numba.jit' decorator. The implicit default value for this argument is currently False, but it will be changed to True in Numba 0.59.0. See https://numba.readthedocs.io/en/stable/reference/deprecation.html#deprecation-of-object-mode-fall-back-behaviour-when-using-jit for details.\n","  def logit(x):\n","/usr/local/lib/python3.10/dist-packages/shap/links.py:20: NumbaDeprecationWarning: The 'nopython' keyword argument was not supplied to the 'numba.jit' decorator. The implicit default value for this argument is currently False, but it will be changed to True in Numba 0.59.0. See https://numba.readthedocs.io/en/stable/reference/deprecation.html#deprecation-of-object-mode-fall-back-behaviour-when-using-jit for details.\n","  def _logit_inverse(x):\n","/usr/local/lib/python3.10/dist-packages/shap/utils/_masked_model.py:363: NumbaDeprecationWarning: The 'nopython' keyword argument was not supplied to the 'numba.jit' decorator. The implicit default value for this argument is currently False, but it will be changed to True in Numba 0.59.0. See https://numba.readthedocs.io/en/stable/reference/deprecation.html#deprecation-of-object-mode-fall-back-behaviour-when-using-jit for details.\n","  def _build_fixed_single_output(averaged_outs, last_outs, outputs, batch_positions, varying_rows, num_varying_rows, link, linearizing_weights):\n","/usr/local/lib/python3.10/dist-packages/shap/utils/_masked_model.py:385: NumbaDeprecationWarning: The 'nopython' keyword argument was not supplied to the 'numba.jit' decorator. The implicit default value for this argument is currently False, but it will be changed to True in Numba 0.59.0. See https://numba.readthedocs.io/en/stable/reference/deprecation.html#deprecation-of-object-mode-fall-back-behaviour-when-using-jit for details.\n","  def _build_fixed_multi_output(averaged_outs, last_outs, outputs, batch_positions, varying_rows, num_varying_rows, link, linearizing_weights):\n","/usr/local/lib/python3.10/dist-packages/shap/utils/_masked_model.py:428: NumbaDeprecationWarning: The 'nopython' keyword argument was not supplied to the 'numba.jit' decorator. The implicit default value for this argument is currently False, but it will be changed to True in Numba 0.59.0. See https://numba.readthedocs.io/en/stable/reference/deprecation.html#deprecation-of-object-mode-fall-back-behaviour-when-using-jit for details.\n","  def _init_masks(cluster_matrix, M, indices_row_pos, indptr):\n","/usr/local/lib/python3.10/dist-packages/shap/utils/_masked_model.py:439: NumbaDeprecationWarning: The 'nopython' keyword argument was not supplied to the 'numba.jit' decorator. The implicit default value for this argument is currently False, but it will be changed to True in Numba 0.59.0. See https://numba.readthedocs.io/en/stable/reference/deprecation.html#deprecation-of-object-mode-fall-back-behaviour-when-using-jit for details.\n","  def _rec_fill_masks(cluster_matrix, indices_row_pos, indptr, indices, M, ind):\n","/usr/local/lib/python3.10/dist-packages/shap/maskers/_tabular.py:186: NumbaDeprecationWarning: The 'nopython' keyword argument was not supplied to the 'numba.jit' decorator. The implicit default value for this argument is currently False, but it will be changed to True in Numba 0.59.0. See https://numba.readthedocs.io/en/stable/reference/deprecation.html#deprecation-of-object-mode-fall-back-behaviour-when-using-jit for details.\n","  def _single_delta_mask(dind, masked_inputs, last_mask, data, x, noop_code):\n","/usr/local/lib/python3.10/dist-packages/shap/maskers/_tabular.py:197: NumbaDeprecationWarning: The 'nopython' keyword argument was not supplied to the 'numba.jit' decorator. The implicit default value for this argument is currently False, but it will be changed to True in Numba 0.59.0. See https://numba.readthedocs.io/en/stable/reference/deprecation.html#deprecation-of-object-mode-fall-back-behaviour-when-using-jit for details.\n","  def _delta_masking(masks, x, curr_delta_inds, varying_rows_out,\n","/usr/local/lib/python3.10/dist-packages/shap/maskers/_image.py:175: NumbaDeprecationWarning: The 'nopython' keyword argument was not supplied to the 'numba.jit' decorator. The implicit default value for this argument is currently False, but it will be changed to True in Numba 0.59.0. See https://numba.readthedocs.io/en/stable/reference/deprecation.html#deprecation-of-object-mode-fall-back-behaviour-when-using-jit for details.\n","  def _jit_build_partition_tree(xmin, xmax, ymin, ymax, zmin, zmax, total_ywidth, total_zwidth, M, clustering, q):\n","/usr/local/lib/python3.10/dist-packages/shap/explainers/_partition.py:676: NumbaDeprecationWarning: The 'nopython' keyword argument was not supplied to the 'numba.jit' decorator. The implicit default value for this argument is currently False, but it will be changed to True in Numba 0.59.0. See https://numba.readthedocs.io/en/stable/reference/deprecation.html#deprecation-of-object-mode-fall-back-behaviour-when-using-jit for details.\n","  def lower_credit(i, value, M, values, clustering):\n","The 'nopython' keyword argument was not supplied to the 'numba.jit' decorator. The implicit default value for this argument is currently False, but it will be changed to True in Numba 0.59.0. See https://numba.readthedocs.io/en/stable/reference/deprecation.html#deprecation-of-object-mode-fall-back-behaviour-when-using-jit for details.\n","The 'nopython' keyword argument was not supplied to the 'numba.jit' decorator. The implicit default value for this argument is currently False, but it will be changed to True in Numba 0.59.0. See https://numba.readthedocs.io/en/stable/reference/deprecation.html#deprecation-of-object-mode-fall-back-behaviour-when-using-jit for details.\n"]}]},{"cell_type":"code","source":["# Helper imports\n","from itertools import product\n","from sklearn.linear_model import (Lasso, LassoCV, LogisticRegression,\n","                                  LogisticRegressionCV,LinearRegression,\n","                                  MultiTaskElasticNet,MultiTaskElasticNetCV)\n","from sklearn.ensemble import RandomForestRegressor,RandomForestClassifier\n","from sklearn.preprocessing import PolynomialFeatures\n","from sklearn.model_selection import train_test_split"],"metadata":{"id":"KwJbLanGBbKp"},"execution_count":null,"outputs":[]},{"cell_type":"code","source":["import sys\n","sys.path.append('ICML_2024_code')\n","import samplers\n","import reduced_rank_regressor\n","import optimization_v3\n","import estimation_v3\n","import utils\n","import data"],"metadata":{"id":"F2Qi7R46yzb2"},"execution_count":null,"outputs":[]},{"cell_type":"markdown","source":["# 1. Load and Format Real Data"],"metadata":{"id":"STh4pIFOy3S4"}},{"cell_type":"code","source":["# Load real data\n","file_path = 'data/allrounds_NER_hh.csv'\n","full_data = pd.read_csv(file_path)\n","print(full_data.shape)\n","\n","background_path = 'data/baseline_NER_hh.csv'\n","background_data = pd.read_csv(background_path)\n","print(background_data.shape)\n","\n","full_data = full_data.merge(background_data,how ='left', on = 'hhid')\n","\n","# Get turn into binary treatment\n","# Full data copy and drop nas\n","full_data_all = full_data.copy().dropna()\n","\n","# control and treatment arm 1\n","full_data_01 = full_data[(full_data['treatment_x'] == 0) | (full_data['treatment_x'] == 1)]\n","\n","# control and treatment arm 2\n","full_data_02 = full_data[(full_data['treatment_x'] == 0) | (full_data['treatment_x'] == 2)]\n","full_data_02['treatment_x'].replace({2: 1}, inplace=True)\n","\n","# control and treatment arm 3\n","full_data_03 = full_data[(full_data['treatment_x'] == 0) | (full_data['treatment_x'] == 3)]\n","full_data_03['treatment_x'].replace({3: 1}, inplace=True)\n","\n","# control and any treatment arm\n","full_data_all.replace({3: 1}, inplace=True)\n","full_data_all.replace({2: 1}, inplace=True)"],"metadata":{"id":"yhdJE7-dy88m","colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"status":"ok","timestamp":1706858930765,"user_tz":480,"elapsed":759,"user":{"displayName":"Ezinne Nwankwo","userId":"03581561058008593041"}},"outputId":"c53a9af0-1931-4dc9-b8b5-aec23f141978"},"execution_count":null,"outputs":[{"output_type":"stream","name":"stdout","text":["(8779, 401)\n","(4712, 31)\n"]},{"output_type":"stream","name":"stderr","text":["\n","A value is trying to be set on a copy of a slice from a DataFrame\n","\n","See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n","\n","A value is trying to be set on a copy of a slice from a DataFrame\n","\n","See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n"]}]},{"cell_type":"code","source":["# Get baseline variables\n","baseline_features = [col for col in full_data_all.columns if col.endswith('_bl')]\n","# items to be removed\n","unwanted_features = {'equiv_n_bl',\n"," 'tot_empl_2rev12_hh_ppp_bl',\n"," 'tot_empl_2rev12_ben_ppp_bl',\n"," 'na_bus2_op_wn_12_bl',\n"," 'bus2_dum_bl',\n"," 'bus2_ben_dum_bl',\n"," 'tot_hh_rev30_ppp_bl',\n"," 'tot_hh_pro30_ppp_bl',\n"," 'tot_ben_rev12_ppp_bl',\n"," 'tot_hh_rev12_ppp_bl',\n"," 'bus_assval_98_ppp_bl',\n"," 'dec_pow_earn_bl',\n"," 'dec_pow_spend_bl',\n"," 'dec_pow_large_bl',\n"," 'dec_pow_fert_bl',\n"," 'dec_pow_edu_bl',\n"," 'dec_pow_ag_bl',\n"," 'dec_pow_liv_bl',\n"," 'dec_pow_bus_bl',\n"," 'dec_could_earn_bl',\n"," 'dec_could_spend_bl',\n"," 'dec_could_large_bl',\n"," 'dec_could_fert_bl',\n"," 'emp_work_bl',\n"," 'crop_ctrl_dum_bl',\n"," 'ani_ben_dum_bl',\n"," 'sleep_prod_dum_bl',\n"," 'ctrl_earn_index_trim_bl',\n"," 'ctrl_hh_index_trim_bl',\n"," 'depressed_11_bl',\n"," 'depressed_13_bl',\n"," 'depressed_15_bl',\n"," 'gse1_bl',\n"," 'gse3_bl',\n"," 'gse4_bl',\n"," 'gse7_bl',\n"," 'gse8_bl',\n"," 'gse9_bl',\n"," 'ros4_bl',\n"," 'stair_good_today_bl',\n"," 'stair_respect_new_bl',\n"," 'stair_opinion_new_bl',\n"," 'stair_status_today_bl',\n"," 'soc_stand_index_bl',\n"," 'gse_index_trim_bl',\n"," 'FIES_rvrs_raw_bl',\n"," 'consum_2_year_xof_trim_bl',\n"," 'consum_2_day_eq_xof_trim_bl',\n"," 'consum_2_year_ppp_trim_bl',\n"," 'consum_2_day_eq_ppp_trim_bl',\n"," 'hh_ass_index_bl',\n"," 'tot_ani_count_tlu_bl',\n"," 'ag_any_bl',\n"," 'ag_plot_ha_bl',\n"," 'ag_plotnotown_bl',\n"," 'ag_r_seeds_d_bl',\n"," 'ag_r_comm_bl',\n"," 'ag_r_lost_bl',\n"," 'ag_r_sold_bl',\n"," 'ag_r_fert_d_bl',\n"," 'ag_r_pest_d_bl',\n"," 'ag_r_entraide_d_bl',\n"," 'ag_r_paidlab_d_bl',\n"," 'ag_input_index_bl',\n"," 'ag_harvest_12_ppp_imp_98_bl',\n"," 'ag_harvest_12_ben_ppp_imp_bl',\n"," 'ag_sale_ppp_imp_98_bl',\n"," 'trans_fam_bl',\n"," 'revs_sum_hh_wempl_trim_bl',\n"," 'revs_sum_ben_wempl_trim_bl',\n"," 'consum_2_day_eq_ppp_std_bl',\n"," 'FIES_rvrs_raw_std_bl',\n"," 'revs_sum_hh_wempl_std_bl',\n"," 'revs_sum_ben_wempl_std_bl',\n"," 'tot_ben_bus_days_bl',\n"," 'tot_hh_bus_days_bl',\n"," 'tot_ben_ag_days_bl',\n"," 'tot_hh_ag_days_bl',\n"," 'tot_benchef_emp_days_bl',\n"," 'tot_ben_emp_days_bl',\n"," 'rel_disagree_bl',\n"," 'rel_interest_bl',\n"," 'los3_bl',\n"," 'partner_vars_index_bl',\n"," 'emp_move_bl',\n"," 'los1_bl',\n"," 'hh_vars_index_trim_bl',\n"," 'intrahh_vars_index_trim_bl',\n"," 'ce3_new_bl',\n"," 'accesstofunds_rvrs_bl',\n"," 'los2_bl',\n"," 'scs3_new_bl',\n"," 'scs5_new_rvrs_bl',\n"," 'tg1_new_bl',\n"," 'tg4_new2_bl',\n"," 'soc_cohsn_index_trim_bl'}\n","baseline_features = [ele for ele in baseline_features if ele not in unwanted_features]\n","bkgd_features = ['hhh_fem',\n"," 'pben_fem',\n"," 'hhh_age',\n"," 'pben_age',\n"," 'hhh_poly',\n"," 'pben_poly',\n"," 'pben_handicap',\n"," 'phy_lift_hhh',\n"," 'phy_walk_hhh',\n"," 'phy_work_hhh',\n"," 'phy_lift_pben',\n"," 'phy_walk_pben',\n"," 'phy_work_pben',\n"," 'pben_edu',\n"," 'pben_prim',\n"," 'pben_lit',\n"," 'hhh_edu',\n"," 'hhh_prim',\n"," 'hhh_lit',\n"," 'hou_room',\n"," 'hou_hea_min',\n"," 'hou_mar_min',\n"," 'hou_wat_min',\n"," 'km_to_com']\n","\n","full_baseline_features = baseline_features + bkgd_features\n","for features in full_baseline_features:\n","  print(features)"],"metadata":{"id":"43d22r6w0fKO","colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"status":"ok","timestamp":1706858950998,"user_tz":480,"elapsed":411,"user":{"displayName":"Ezinne Nwankwo","userId":"03581561058008593041"}},"outputId":"25adf185-d29d-4f70-cb15-cc07dbaedc4e"},"execution_count":null,"outputs":[{"output_type":"stream","name":"stdout","text":["less_depressed_bl\n","less_disability_bl\n","stair_satis_today_bl\n","ment_hlth_index_trim_bl\n","hhh_fem\n","pben_fem\n","hhh_age\n","pben_age\n","hhh_poly\n","pben_poly\n","pben_handicap\n","phy_lift_hhh\n","phy_walk_hhh\n","phy_work_hhh\n","phy_lift_pben\n","phy_walk_pben\n","phy_work_pben\n","pben_edu\n","pben_prim\n","pben_lit\n","hhh_edu\n","hhh_prim\n","hhh_lit\n","hou_room\n","hou_hea_min\n","hou_mar_min\n","hou_wat_min\n","km_to_com\n"]}]},{"cell_type":"code","source":["# some data prep for later\n","treatment_variable = ['treatment_x']\n","financial_outcomes = ['tot_empl_2rev12_ben_ppp', 'consum_2_day_eq_ppp','health_bus_ind',  'tot_ben_rev12_ppp',\n"," 'bus_assval_98_ppp','bus2_invest_ppp','tot_sav3_ppp']\n","full_features = full_baseline_features + treatment_variable + financial_outcomes\n","df_03 = full_data_03[full_features]\n","print(df_03.shape)\n","\n","formula_bpr = \"\"\"\n","tot_empl_2rev12_ben_ppp ~ treatment_x + less_depressed_bl + less_disability_bl + stair_satis_today_bl + ment_hlth_index_trim_bl+ hhh_fem + pben_fem + hhh_age + pben_age\n","+ hhh_poly + pben_poly + pben_handicap + phy_lift_hhh + phy_walk_hhh + phy_work_hhh + phy_lift_pben + phy_walk_pben + phy_work_pben + pben_edu + pben_prim\n","+ pben_lit + hhh_edu + hhh_prim + hhh_lit + hou_room + hou_hea_min + hou_mar_min + hou_wat_min + km_to_com\n","\"\"\"\n","tot_empl_2rev12_ben_ppp, X_bpr = patsy.dmatrices(formula_bpr, df_03, return_type=\"dataframe\")\n","tot_empl_2rev12_ben_ppp = tot_empl_2rev12_ben_ppp.iloc[:,0]\n","\n","formula_consump = \"\"\"\n","consum_2_day_eq_ppp ~ treatment_x + less_depressed_bl + less_disability_bl + stair_satis_today_bl + ment_hlth_index_trim_bl+ hhh_fem + pben_fem + hhh_age + pben_age\n","+ hhh_poly + pben_poly + pben_handicap + phy_lift_hhh + phy_walk_hhh + phy_work_hhh + phy_lift_pben + phy_walk_pben + phy_work_pben + pben_edu + pben_prim\n","+ pben_lit + hhh_edu + hhh_prim + hhh_lit + hou_room + hou_hea_min + hou_mar_min + hou_wat_min + km_to_com\n","\"\"\"\n","consum_2_day_eq_ppp, X_consump = patsy.dmatrices(formula_consump, df_03, return_type=\"dataframe\")\n","consum_2_day_eq_ppp = consum_2_day_eq_ppp.iloc[:,0]\n","\n","formula_bus_health = \"\"\"\n","health_bus_ind ~ treatment_x + less_depressed_bl + less_disability_bl + stair_satis_today_bl + ment_hlth_index_trim_bl+ hhh_fem + pben_fem + hhh_age + pben_age\n","+ hhh_poly + pben_poly + pben_handicap + phy_lift_hhh + phy_walk_hhh + phy_work_hhh + phy_lift_pben + phy_walk_pben + phy_work_pben + pben_edu + pben_prim\n","+ pben_lit + hhh_edu + hhh_prim + hhh_lit + hou_room + hou_hea_min + hou_mar_min + hou_wat_min + km_to_com\n","\"\"\"\n","health_bus_ind, X_bushealth = patsy.dmatrices(formula_bus_health, df_03, return_type=\"dataframe\")\n","health_bus_ind = health_bus_ind.iloc[:,0]\n","\n","formula_bus_revenue = \"\"\"\n","tot_ben_rev12_ppp ~ treatment_x + less_depressed_bl + less_disability_bl + stair_satis_today_bl + ment_hlth_index_trim_bl+ hhh_fem + pben_fem + hhh_age + pben_age\n","+ hhh_poly + pben_poly + pben_handicap + phy_lift_hhh + phy_walk_hhh + phy_work_hhh + phy_lift_pben + phy_walk_pben + phy_work_pben + pben_edu + pben_prim\n","+ pben_lit + hhh_edu + hhh_prim + hhh_lit + hou_room + hou_hea_min + hou_mar_min + hou_wat_min + km_to_com\n","\"\"\"\n","tot_ben_rev12_ppp, X_bus_revenue = patsy.dmatrices(formula_bus_revenue, df_03, return_type=\"dataframe\")\n","tot_ben_rev12_ppp = tot_ben_rev12_ppp.iloc[:,0]\n","\n","formula_bus_assval = \"\"\"\n","bus_assval_98_ppp ~ treatment_x + less_depressed_bl + less_disability_bl + stair_satis_today_bl + ment_hlth_index_trim_bl+ hhh_fem + pben_fem + hhh_age + pben_age\n","+ hhh_poly + pben_poly + pben_handicap + phy_lift_hhh + phy_walk_hhh + phy_work_hhh + phy_lift_pben + phy_walk_pben + phy_work_pben + pben_edu + pben_prim\n","+ pben_lit + hhh_edu + hhh_prim + hhh_lit + hou_room + hou_hea_min + hou_mar_min + hou_wat_min + km_to_com\n","\"\"\"\n","bus_assval_98_ppp, X_busassval = patsy.dmatrices(formula_bus_assval, df_03, return_type=\"dataframe\")\n","bus_assval_98_ppp = bus_assval_98_ppp.iloc[:,0]\n","\n","formula_bus_invest = \"\"\"\n","bus2_invest_ppp ~ treatment_x + less_depressed_bl + less_disability_bl + stair_satis_today_bl + ment_hlth_index_trim_bl+ hhh_fem + pben_fem + hhh_age + pben_age\n","+ hhh_poly + pben_poly + pben_handicap + phy_lift_hhh + phy_walk_hhh + phy_work_hhh + phy_lift_pben + phy_walk_pben + phy_work_pben + pben_edu + pben_prim\n","+ pben_lit + hhh_edu + hhh_prim + hhh_lit + hou_room + hou_hea_min + hou_mar_min + hou_wat_min + km_to_com\n","\"\"\"\n","bus2_invest_ppp, X_businvest = patsy.dmatrices(formula_bus_invest, df_03, return_type=\"dataframe\")\n","bus2_invest_ppp = bus2_invest_ppp.iloc[:,0]\n","\n","formula_bus_savings = \"\"\"\n","tot_sav3_ppp ~ treatment_x + less_depressed_bl + less_disability_bl + stair_satis_today_bl + ment_hlth_index_trim_bl+ hhh_fem + pben_fem + hhh_age + pben_age\n","+ hhh_poly + pben_poly + pben_handicap + phy_lift_hhh + phy_walk_hhh + phy_work_hhh + phy_lift_pben + phy_walk_pben + phy_work_pben + pben_edu + pben_prim\n","+ pben_lit + hhh_edu + hhh_prim + hhh_lit + hou_room + hou_hea_min + hou_mar_min + hou_wat_min + km_to_com\n","\"\"\"\n","tot_sav3_ppp, X_bussavings = patsy.dmatrices(formula_bus_savings, df_03, return_type=\"dataframe\")\n","tot_sav3_ppp = tot_sav3_ppp.iloc[:, 0]\n","\n","\n","treatment = X_bpr[\"treatment_x\"]\n","Xl = X_bpr.drop([\"Intercept\", \"treatment_x\"], axis=1)\n","#cluster_id = df_03.loc[X_bpr.index, \"strata_x\"].astype(\"category\")\n","import re\n","# remove [ ] from names for compatibility with xgboost\n","Xl = Xl.rename(columns=lambda x: re.sub('\\[|\\]','_',x))"],"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"ziL5zISl2T3V","executionInfo":{"status":"ok","timestamp":1706858956967,"user_tz":480,"elapsed":600,"user":{"displayName":"Ezinne Nwankwo","userId":"03581561058008593041"}},"outputId":"85d67765-1bdb-4f83-b2fd-f0261a84f626"},"execution_count":null,"outputs":[{"output_type":"stream","name":"stdout","text":["(4464, 36)\n"]}]},{"cell_type":"code","source":["# tmp = pd.DataFrame(dict(ben_wage_revenue=tot_empl_2rev12_ben_ppp,treatment=treatment,consump_ind=consum_2_day_eq_ppp,\n","#                         business_health=health_bus_ind,\n","#                         business_revenue=tot_ben_rev12_ppp,\n","#                         business_asset_val=bus_assval_98_ppp,\n","#                         business_investments=bus2_invest_ppp,\n","#                         other_savings=tot_sav3_ppp,\n","#                         hhh_age = X_bpr.loc[:,'hhh_age'],\n","#                         pben_age = X_bpr.loc[:,'pben_age'],\n","#                         hhh_edu = X_bpr.loc[:,'hhh_edu'],\n","#                         pben_edu = X_bpr.loc[:,'pben_edu'],\n","#                         hhh_fem = X_bpr.loc[:,'hhh_fem'],\n","#                         pben_fem = X_bpr.loc[:,'pben_fem'],\n","#                         hou_hea_min = X_bpr.loc[:,'hou_hea_min'],\n","#                         hou_mar_min = X_bpr.loc[:, 'hou_mar_min'],\n","#                         hou_wat_min = X_bpr.loc[:, 'hou_wat_min']\n","#                         ))"],"metadata":{"id":"VBEWK65A0i5U"},"execution_count":null,"outputs":[]},{"cell_type":"markdown","source":["## 0. Data Processing\n"],"metadata":{"id":"jtlFYczQ44Fa"}},{"cell_type":"markdown","source":["- use beneficiary wages and consumption as outcomes because they have some people with negative treatment effects"],"metadata":{"id":"5iVUiAj15pRT"}},{"cell_type":"code","source":["# Data\n","\n","print(\"Current Dataset Shape:\",df_03.shape)\n","\n","# Drop NA's\n","df_03_dropna = df_03.dropna()\n","print(\"Dataset Shape After Drop:\",df_03_dropna.shape)\n","\n","# Split into train/test\n","\n","from sklearn.model_selection import train_test_split\n","# Splitting the data into 80% train and 20% test\n","data_shuffled = df_03_dropna.sample(frac=1, random_state=42)  # Shuffle the data, setting a random state for reproducibility\n","\n","# Define the split ratio\n","split_ratio = 0.8  # 80% train, 20% test\n","\n","# Calculate the number of rows for the train set\n","train_size = int(split_ratio * len(data_shuffled))\n","\n","# Split the dataset\n","train_data = data_shuffled[:train_size]\n","test_data = data_shuffled[train_size:]\n","\n","X_train = train_data[full_baseline_features].to_numpy()\n","T_train = train_data['treatment_x'].to_numpy()\n","Y_train = train_data[financial_outcomes].to_numpy()\n","\n","X_test = test_data[full_baseline_features].to_numpy()\n","T_test = test_data['treatment_x'].to_numpy()\n","Y_test = test_data[financial_outcomes].to_numpy()\n","\n","# Standardize X data\n","from sklearn import preprocessing\n","x_scaler_train = preprocessing.StandardScaler().fit(X_train)\n","X_train_sc = x_scaler_train.transform(X_train)\n","x_scaler_test = preprocessing.StandardScaler().fit(X_test)\n","X_test_sc = x_scaler_test.transform(X_test)\n","\n","# Standardize Y data\n","y_scaler_train = preprocessing.StandardScaler().fit(Y_train)\n","Y_train_sc = y_scaler_train.transform(Y_train)\n","y_scaler_test = preprocessing.StandardScaler().fit(Y_test)\n","Y_test_sc = y_scaler_test.transform(Y_test)\n"],"metadata":{"id":"nBZEwXfKHGiy","colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"status":"ok","timestamp":1706858963229,"user_tz":480,"elapsed":617,"user":{"displayName":"Ezinne Nwankwo","userId":"03581561058008593041"}},"outputId":"a48343ac-b467-490d-ea7f-8e89aa8e5fe7"},"execution_count":null,"outputs":[{"output_type":"stream","name":"stdout","text":["Current Dataset Shape: (4464, 36)\n","Dataset Shape After Drop: (4139, 36)\n"]}]},{"cell_type":"markdown","source":["## 1. Policy Evaluation"],"metadata":{"id":"4ecHjps4v2NI"}},{"cell_type":"code","source":["np.random.seed(9822)\n","#rho = np.random.randn(1, Y_train_sc.shape[1])\n","rho = np.array([8.28,1.31,0.21,0.061,0.59,0.01,1.12])\n","# Policy Optimization\n","results_direct_y = optimization_v3.subgradient_descent(num_iter = 60,step_size = 3,key_start=1,X_samples=X_train_sc, T_samples = T_train, Y_samples = Y_train_sc, rho = rho, method = 'direct', Z_estimation=False)\n","opt_idx_y = results_direct_y['obj_values'].argmin()\n","\n","results_direct_z = optimization_v3.subgradient_descent(num_iter = 60,step_size = 3,key_start=1,X_samples=X_train_sc, T_samples = T_train, Y_samples = Y_train_sc, rho = rho, method = 'direct', Z_estimation=True)\n","opt_idx_z = results_direct_z['obj_values'].argmin()\n","\n","# Objective Values\n","opt_objval_direct_y = np.min(results_direct_y['obj_values'])\n","opt_polval_direct_y = np.min(results_direct_y['pol_values'])\n","\n","opt_objval_direct_z = np.min(results_direct_z['obj_values'])\n","opt_polval_direct_z = np.min(results_direct_z['pol_values'])\n","\n","# Optimal Pi^*\n","phi_opt_direct_y = results_direct_y['phi_values'][opt_idx_y]\n","b_opt_direct_y = results_direct_y['b_values'][opt_idx_y]\n","\n","phi_opt_direct_z = results_direct_z['phi_values'][opt_idx_z]\n","b_opt_direct_z = results_direct_z['b_values'][opt_idx_z]"],"metadata":{"id":"iyXjRACoKURI"},"execution_count":null,"outputs":[]},{"cell_type":"code","source":["print(\"Optimal Objective Value (y,z):\", opt_objval_direct_y, opt_objval_direct_z)\n","print(\"Optimal Policy Value (y,z):\", opt_polval_direct_y,opt_polval_direct_z)\n","print(\"Optimal Phi Value (y,z):\", phi_opt_direct_y,phi_opt_direct_z)\n","print(\"Optimal Beta Value (y,z):\", b_opt_direct_y,b_opt_direct_z)"],"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"XyDpoB8IXpbN","executionInfo":{"status":"ok","timestamp":1706849957516,"user_tz":480,"elapsed":122,"user":{"displayName":"Ezinne Nwankwo","userId":"03581561058008593041"}},"outputId":"c5b5b028-b6ed-4e92-ff93-743778f6227a"},"execution_count":null,"outputs":[{"output_type":"stream","name":"stdout","text":["Optimal Objective Value (y,z): -0.6176600456237793 -0.2836199402809143\n","Optimal Policy Value (y,z): -0.6176600456237793 -0.2836199402809143\n","Optimal Phi Value (y,z): [ 1.27569199e+00  5.49714506e-01 -7.33511329e-01  1.09507895e+00\n"," -5.46984076e-01  4.01634723e-03  1.90362245e-01  3.18340993e+00\n","  5.68909228e-01 -1.18696451e-01  5.90590835e-01  2.34158540e+00\n","  4.51370567e-01 -8.53318751e-01  3.99715692e-01  3.85056362e-02\n"," -4.13427496e+00 -1.45573780e-01  3.54207963e-01  8.00736964e-01\n"," -3.52289224e+00 -1.53268206e+00 -7.33235627e-02 -1.49420530e-01\n","  1.41963446e+00 -6.38104320e-01  2.66758263e-01 -1.86967775e-01] [-0.02336191 -0.05831043 -1.66033363 -0.21107087  1.79309261  0.59765959\n","  0.94566518 -0.13188793 -1.26956308 -2.5903511   0.50826144  2.77895999\n"," -0.46669632 -0.30632919  1.24454939 -1.80178535 -1.86243129 -1.81205714\n"," -0.22254656 -0.91911334 -1.54646337 -1.5959419  -0.48707396  0.5771935\n","  1.80725956 -0.27888161  1.18389857  0.06103096]\n","Optimal Beta Value (y,z): 0.2855904698371887 0.30856993794441223\n"]}]},{"cell_type":"code","source":["poleval_results = np.zeros((8,2))\n","######################\n","#### Direct\n","######################\n","\n","# Mu lists are also called phi functions/score functions\n","mu_0_list_y_in, mu_1_list_y_in = optimization_v3.gen_mu_values(X_samples=X_train_sc, T_samples=T_train,Y_samples=Y_train_sc, rho=rho, method='direct',Z_estimation=False)\n","mu_0_list_z_in, mu_1_list_z_in = optimization_v3.gen_mu_values(X_samples=X_train_sc, T_samples=T_train,Y_samples=Y_train_sc, rho=rho, method='direct',Z_estimation=True)\n","\n","\n","mu_0_list_y, mu_1_list_y = optimization_v3.gen_mu_values(X_samples=X_test_sc, T_samples=T_test,Y_samples=Y_test_sc, rho=rho, method='direct',Z_estimation=False)\n","mu_0_list_z, mu_1_list_z = optimization_v3.gen_mu_values(X_samples=X_test_sc, T_samples=T_test,Y_samples=Y_test_sc, rho=rho, method='direct',Z_estimation=True)\n","\n","#compute OPT x\n","pol_value_y_direct, pi_0_list_y_in, pi_1_list_y_in = optimization_v3.compute_x_opt(phi=phi_opt_direct_y, b=b_opt_direct_y, X_samples=X_train_sc, T_samples=T_train, mu_0_list=mu_0_list_y_in,mu_1_list=mu_1_list_y_in)\n","pol_value_z_direct, pi_0_list_z_in, pi_1_list_z_in = optimization_v3.compute_x_opt(phi=phi_opt_direct_z, b=b_opt_direct_z, X_samples=X_train_sc, T_samples=T_train, mu_0_list=mu_0_list_z_in,mu_1_list=mu_1_list_z_in)\n","\n","pol_value_y_direct, pi_0_list_y, pi_1_list_y = optimization_v3.compute_x_opt(phi=phi_opt_direct_y, b=b_opt_direct_y, X_samples=X_test_sc, T_samples=T_test, mu_0_list=mu_0_list_y,mu_1_list=mu_1_list_y)\n","pol_value_z_direct, pi_0_list_z, pi_1_list_z = optimization_v3.compute_x_opt(phi=phi_opt_direct_z, b=b_opt_direct_z, X_samples=X_test_sc, T_samples=T_test, mu_0_list=mu_0_list_z,mu_1_list=mu_1_list_z)\n","\n","\n","print(\"---- Direct ----\")\n","print(\"In-Sample Variance of Phi - pTY:\", np.round(np.var(pi_0_list_y_in + pi_1_list_y_in),3))\n","print(\"In-Sample Variance of Phi - pTAZ:\", np.round(np.var(pi_0_list_z_in + pi_1_list_z_in),3))\n","print(\"Out-of-Sample Variance of Phi - pTY:\", np.round(np.var(pi_0_list_y + pi_1_list_y),3))\n","print(\"Out-of-Sample Variance of Phi -pTAZ:\", np.round(np.var(pi_0_list_z + pi_1_list_z),3))\n","print(\"Policy Value pTY:\", pol_value_y_direct)\n","print(\"Policy Value pTAZ:\", pol_value_z_direct)\n","\n","poleval_results[0,0] = np.round(np.var(pi_0_list_y_in + pi_1_list_y_in),3)\n","poleval_results[1,0] = np.round(np.var(pi_0_list_z_in + pi_1_list_z_in),3)\n","poleval_results[0,1] = np.round(np.var(pi_0_list_y + pi_1_list_y),3)\n","poleval_results[1,1] = np.round(np.var(pi_0_list_y + pi_1_list_y),3)\n","\n","#########################\n","#### IPW-obs/DR-obs\n","########################\n","\n","mu_0_list_y_ipwobs_in, mu_1_list_y_ipwobs_in = optimization_v3.gen_mu_values(X_samples=X_train_sc, T_samples=T_train,Y_samples=Y_train_sc, rho=rho, method='IPW-obs',Z_estimation=False)\n","mu_0_list_y_drobs_in, mu_1_list_y_drobs_in = optimization_v3.gen_mu_values(X_samples=X_train_sc, T_samples=T_train,Y_samples=Y_train_sc, rho=rho, method='DR-obs',Z_estimation=False)\n","\n","\n","mu_0_list_y_ipwobs, mu_1_list_y_ipwobs = optimization_v3.gen_mu_values(X_samples=X_test_sc, T_samples=T_test,Y_samples=Y_test_sc, rho=rho, method='IPW-obs',Z_estimation=False)\n","mu_0_list_y_drobs, mu_1_list_y_drobs = optimization_v3.gen_mu_values(X_samples=X_test_sc, T_samples=T_test,Y_samples=Y_test_sc, rho=rho, method='DR-obs',Z_estimation=False)\n","\n","#compute OPT x\n","pol_value_y_ipw, pi_0_list_y_ipwobs_in, pi_1_list_y_ipwobs_in = optimization_v3.compute_x_opt(phi=phi_opt_direct_y, b=b_opt_direct_y, X_samples=X_train_sc, T_samples=T_train, mu_0_list=mu_0_list_y_ipwobs_in,mu_1_list=mu_1_list_y_ipwobs_in)\n","pol_value_y_dr, pi_0_list_y_drobs_in, pi_1_list_y_drobs_in = optimization_v3.compute_x_opt(phi=phi_opt_direct_y, b=b_opt_direct_y, X_samples=X_train_sc, T_samples=T_train, mu_0_list=mu_0_list_y_drobs_in,mu_1_list=mu_1_list_y_drobs_in)\n","\n","\n","pol_value_y_ipw, pi_0_list_y_ipwobs, pi_1_list_y_ipwobs = optimization_v3.compute_x_opt(phi=phi_opt_direct_y, b=b_opt_direct_y, X_samples=X_test_sc, T_samples=T_test, mu_0_list=mu_0_list_y_ipwobs,mu_1_list=mu_1_list_y_ipwobs)\n","pol_value_y_dr, pi_0_list_y_drobs, pi_1_list_y_drobs = optimization_v3.compute_x_opt(phi=phi_opt_direct_y, b=b_opt_direct_y, X_samples=X_test_sc, T_samples=T_test, mu_0_list=mu_0_list_y_drobs,mu_1_list=mu_1_list_y_drobs)\n","\n","\n","\n","######################\n","#### IPW\n","######################\n","\n","mu_0_list_yipw_in, mu_1_list_yipw_in = optimization_v3.gen_mu_values(X_samples=X_train_sc, T_samples=T_train,Y_samples=Y_train_sc, rho=rho, method='IPW',Z_estimation=False)\n","mu_0_list_zipw_in, mu_1_list_zipw_in = optimization_v3.gen_mu_values(X_samples=X_train_sc, T_samples=T_train,Y_samples=Y_train_sc, rho=rho, method='IPW',Z_estimation=True)\n","\n","\n","mu_0_list_yipw, mu_1_list_yipw = optimization_v3.gen_mu_values(X_samples=X_test_sc, T_samples=T_test,Y_samples=Y_test_sc, rho=rho, method='IPW',Z_estimation=False)\n","mu_0_list_zipw, mu_1_list_zipw = optimization_v3.gen_mu_values(X_samples=X_test_sc, T_samples=T_test,Y_samples=Y_test_sc, rho=rho, method='IPW',Z_estimation=True)\n","\n","#compute OPT x\n","pol_value_yipw, pi_0_list_yipw_in, pi_1_list_yipw_in = optimization_v3.compute_x_opt(phi=phi_opt_direct_y, b=b_opt_direct_y, X_samples=X_train_sc, T_samples=T_train, mu_0_list=mu_0_list_yipw_in,mu_1_list=mu_1_list_yipw_in)\n","pol_value_zipw, pi_0_list_zipw_in, pi_1_list_zipw_in = optimization_v3.compute_x_opt(phi=phi_opt_direct_z, b=b_opt_direct_z, X_samples=X_train_sc, T_samples=T_train, mu_0_list=mu_0_list_zipw_in,mu_1_list=mu_1_list_zipw_in)\n","\n","pol_value_yipw, pi_0_list_yipw, pi_1_list_yipw = optimization_v3.compute_x_opt(phi=phi_opt_direct_y, b=b_opt_direct_y, X_samples=X_test_sc, T_samples=T_test, mu_0_list=mu_0_list_yipw,mu_1_list=mu_1_list_yipw)\n","pol_value_zipw, pi_0_list_zipw, pi_1_list_zipw = optimization_v3.compute_x_opt(phi=phi_opt_direct_z, b=b_opt_direct_z, X_samples=X_test_sc, T_samples=T_test, mu_0_list=mu_0_list_zipw,mu_1_list=mu_1_list_zipw)\n","\n","\n","print(\"---- IPW ----\")\n","print(\"In-Sample Variance of Phi - pTY-obs:\", np.round(np.var(pi_0_list_y_ipwobs_in + pi_1_list_y_ipwobs_in),3))\n","print(\"In-Sample Variance of Phi - pTY:\", np.round(np.var(pi_0_list_yipw_in + pi_1_list_yipw_in),3))\n","print(\"In-Sample Variance of Phi - pTAZ:\", np.round(np.var(pi_0_list_zipw_in + pi_1_list_zipw_in),3))\n","print(\"Out-of-Sample Variance of Phi - pTY-obs:\", np.round(np.var(pi_0_list_y_ipwobs + pi_1_list_y_ipwobs),3))\n","print(\"Out-of-Sample Variance of Phi - pTY:\", np.round(np.var(pi_0_list_yipw + pi_1_list_yipw),3))\n","print(\"Out-of-Sample Variance of Phi - pTAZ:\", np.round(np.var(pi_0_list_zipw + pi_1_list_zipw),3))\n","print(\"Policy Value pTY-obs:\", pol_value_y_ipw)\n","print(\"Policy Value pTY:\", pol_value_yipw)\n","print(\"Policy Value pTAZ:\", pol_value_zipw)\n","\n","poleval_results[2,0] = np.round(np.var(pi_0_list_y_ipwobs_in + pi_1_list_y_ipwobs_in),3)\n","poleval_results[3,0] = np.round(np.var(pi_0_list_yipw_in + pi_1_list_yipw_in),3)\n","poleval_results[4,0] = np.round(np.var(pi_0_list_zipw_in + pi_1_list_zipw_in),3)\n","poleval_results[2,1] = np.round(np.var(pi_0_list_y_ipwobs + pi_1_list_y_ipwobs),3)\n","poleval_results[3,1] = np.round(np.var(pi_0_list_yipw + pi_1_list_yipw),3)\n","poleval_results[4,1] = np.round(np.var(pi_0_list_zipw + pi_1_list_zipw),3)\n","\n","\n","\n","######################\n","#### CV\n","######################\n","\n","mu_0_list_ycv_in, mu_1_list_ycv_in = optimization_v3.gen_mu_values(X_samples=X_train_sc, T_samples=T_train,Y_samples=Y_train_sc, rho=rho, method='CV',Z_estimation=False)\n","mu_0_list_zcv_in, mu_1_list_zcv_in = optimization_v3.gen_mu_values(X_samples=X_train_sc, T_samples=T_train,Y_samples=Y_train_sc, rho=rho, method='CV',Z_estimation=True)\n","\n","mu_0_list_ycv, mu_1_list_ycv = optimization_v3.gen_mu_values(X_samples=X_test_sc, T_samples=T_test,Y_samples=Y_test_sc, rho=rho, method='CV',Z_estimation=False)\n","mu_0_list_zcv, mu_1_list_zcv = optimization_v3.gen_mu_values(X_samples=X_test_sc, T_samples=T_test,Y_samples=Y_test_sc, rho=rho, method='CV',Z_estimation=True)\n","\n","#compute OPT x\n","pol_value_ycv, pi_0_list_ycv_in, pi_1_list_ycv_in = optimization_v3.compute_x_opt(phi=phi_opt_direct_y, b=b_opt_direct_y, X_samples=X_train_sc, T_samples=T_train, mu_0_list=mu_0_list_ycv_in,mu_1_list=mu_1_list_ycv_in)\n","pol_value_zcv, pi_0_list_zcv_in, pi_1_list_zcv_in = optimization_v3.compute_x_opt(phi=phi_opt_direct_z, b=b_opt_direct_z, X_samples=X_train_sc, T_samples=T_train, mu_0_list=mu_0_list_zcv_in,mu_1_list=mu_1_list_zcv_in)\n","\n","pol_value_ycv, pi_0_list_ycv, pi_1_list_ycv = optimization_v3.compute_x_opt(phi=phi_opt_direct_y, b=b_opt_direct_y, X_samples=X_test_sc, T_samples=T_test, mu_0_list=mu_0_list_ycv,mu_1_list=mu_1_list_ycv)\n","pol_value_zcv, pi_0_list_zcv, pi_1_list_zcv = optimization_v3.compute_x_opt(phi=phi_opt_direct_z, b=b_opt_direct_z, X_samples=X_test_sc, T_samples=T_test, mu_0_list=mu_0_list_zcv,mu_1_list=mu_1_list_zcv)\n","\n","\n","print(\"---- DR/CV ----\")\n","print(\"In-Sample Variance of Phi - pTY-obs:\", np.round(np.var(pi_0_list_y_drobs_in + pi_1_list_y_drobs_in),3))\n","print(\"In-Sample Variance of Phi - pTY:\", np.round(np.var(pi_0_list_ycv_in + pi_1_list_ycv_in),3))\n","print(\"In-Sample Variance of Phi - pTAZ:\", np.round(np.var(pi_0_list_zcv_in + pi_1_list_zcv_in),3))\n","print(\"Out-of-Sample Variance of Phi - pTY-obs:\", np.round(np.var(pi_0_list_y_drobs + pi_1_list_y_drobs),3))\n","print(\"Out-of-Sample Variance of Phi - pTY:\", np.round(np.var(pi_0_list_ycv + pi_1_list_ycv),3))\n","print(\"Out-of-Sample Variance of Phi - pTAZ:\", np.round(np.var(pi_0_list_zcv + pi_1_list_zcv),3))\n","# print(\"Cost lists:\")\n","# print(\"In-Sample Variance of Phi - pTY-obs:\", np.var(costs_0_list_y_dr_in) + np.var(costs_1_list_y_dr_in))\n","# print(\"In-Sample Variance of Phi - pTY:\", np.var(costs_0_list_ycv_in) + np.var(costs_1_list_ycv_in))\n","# print(\"In-Sample Variance of Phi - pTAZ:\", np.var(costs_0_list_zcv_in) + np.var(costs_1_list_zcv_in))\n","# print(\"Out-of-Sample Variance of Phi - pTY-obs:\", np.var(costs_0_list_y_dr) + np.var(costs_1_list_y_dr))\n","# print(\"Out-of-Sample Variance of Phi - pTY:\", np.var(costs_0_list_ycv) + np.var(costs_1_list_ycv))\n","# print(\"Out-of-Sample Variance of Phi - pTAZ:\", np.var(costs_0_list_zcv) + np.var(costs_1_list_zcv))\n","print(\"Policy Value pTY-obs:\", pol_value_y_dr)\n","print(\"Policy Value pTY:\", pol_value_ycv)\n","print(\"Policy Value pTAZ:\", pol_value_zcv)\n","\n","poleval_results[5,0] = np.round(np.var(pi_0_list_y_drobs_in + pi_1_list_y_drobs_in),3)\n","poleval_results[6,0] = np.round(np.var(pi_0_list_ycv_in + pi_1_list_ycv_in),3)\n","poleval_results[7,0] = np.round(np.var(pi_0_list_zcv_in + pi_1_list_zcv_in),3)\n","poleval_results[5,1] = np.round(np.var(pi_0_list_y_drobs + pi_1_list_y_drobs),3)\n","poleval_results[6,1] = np.round(np.var(pi_0_list_ycv + pi_1_list_ycv),3)\n","poleval_results[7,1] = np.round(np.var(pi_0_list_zcv + pi_1_list_zcv),3)\n"],"metadata":{"id":"2bB8O4D6Fyeq","executionInfo":{"status":"ok","timestamp":1706849963775,"user_tz":480,"elapsed":3057,"user":{"displayName":"Ezinne Nwankwo","userId":"03581561058008593041"}},"colab":{"base_uri":"https://localhost:8080/"},"outputId":"4909742c-08ff-4c23-c772-ef88b336d1ca"},"execution_count":null,"outputs":[{"output_type":"stream","name":"stdout","text":["---- Direct ----\n","In-Sample Variance of Phi - pTY: 1.4460001\n","In-Sample Variance of Phi - pTAZ: 0.279\n","Out-of-Sample Variance of Phi - pTY: 4.373\n","Out-of-Sample Variance of Phi -pTAZ: 3.0600002\n","Policy Value pTY: 0.17305675148963928\n","Policy Value pTAZ: -0.050930868834257126\n","---- IPW ----\n","In-Sample Variance of Phi - pTY-obs: 53.870003\n","In-Sample Variance of Phi - pTY: 3.1750002\n","In-Sample Variance of Phi - pTAZ: 0.60200006\n","Out-of-Sample Variance of Phi - pTY-obs: 111.746\n","Out-of-Sample Variance of Phi - pTY: 8.369\n","Out-of-Sample Variance of Phi - pTAZ: 5.0090003\n","Policy Value pTY-obs: 0.12853169441223145\n","Policy Value pTY: 0.09458599984645844\n","Policy Value pTAZ: -0.06887369602918625\n","---- DR/CV ----\n","In-Sample Variance of Phi - pTY-obs: 53.941\n","In-Sample Variance of Phi - pTY: 1.544\n","In-Sample Variance of Phi - pTAZ: 0.60200006\n","Out-of-Sample Variance of Phi - pTY-obs: 111.23601\n","Out-of-Sample Variance of Phi - pTY: 2.7570002\n","Out-of-Sample Variance of Phi - pTAZ: 5.058\n","Policy Value pTY-obs: 0.2124083936214447\n","Policy Value pTY: 0.029059791937470436\n","Policy Value pTAZ: -0.06909790635108948\n"]}]},{"cell_type":"code","source":["poleval_results"],"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"w8BYEDtzh1UJ","executionInfo":{"status":"ok","timestamp":1706849974549,"user_tz":480,"elapsed":115,"user":{"displayName":"Ezinne Nwankwo","userId":"03581561058008593041"}},"outputId":"c4b17e9e-e9a7-4af3-9bec-00d6277ef7f4"},"execution_count":null,"outputs":[{"output_type":"execute_result","data":{"text/plain":["array([[  1.4460001 ,   4.37300014],\n","       [  0.27900001,   4.37300014],\n","       [ 53.87000275, 111.7460022 ],\n","       [  3.17500019,   8.36900043],\n","       [  0.60200006,   5.0090003 ],\n","       [ 53.94100189, 111.23600769],\n","       [  1.54400003,   2.75700021],\n","       [  0.60200006,   5.05800009]])"]},"metadata":{},"execution_count":15}]},{"cell_type":"code","source":["from tabulate import tabulate\n","\n","\n","# Replace 'row_names' and 'column_names' with your desired names\n","column_names = ['In-Sample Variance', 'Out-of-Sample Variance']\n","row_names = ['$\\\\rho^\\\\top \\\\mu$-DM', '$\\\\rho^\\\\top \\\\mu^{RRR}$-DM', '$\\\\rho^\\\\top Y$-IPW', '$\\\\rho^\\\\top \\\\mu$-IPW', '$\\\\rho^\\\\top \\\\mu^{RRR}$-IPW', '$\\\\rho^\\\\top Y$-DR', '$\\\\rho^\\\\top \\\\mu$-CV', '$\\\\rho^\\\\top \\\\mu^{RRR}$-CV']\n","\n","# Add row and column names to the matrix\n","matrix_with_names = np.column_stack((row_names, poleval_results))\n","matrix_with_names = np.row_stack(([''] + column_names, matrix_with_names))\n","\n","# Convert the matrix to a LaTeX table using tabulate\n","latex_table = tabulate(matrix_with_names, tablefmt='latex_raw', headers='firstrow')\n","\n","# Display or use the LaTeX table\n","print(latex_table)\n"],"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"A0MXuaPkSR8p","executionInfo":{"status":"ok","timestamp":1706849977999,"user_tz":480,"elapsed":126,"user":{"displayName":"Ezinne Nwankwo","userId":"03581561058008593041"}},"outputId":"c555bba5-43d6-4bf9-d00c-9e32aea18870"},"execution_count":null,"outputs":[{"output_type":"stream","name":"stdout","text":["\\begin{tabular}{lrr}\n","\\hline\n","                           &   In-Sample Variance &   Out-of-Sample Variance \\\\\n","\\hline\n"," $\\rho^\\top \\mu$-DM        &                1.446 &                    4.373 \\\\\n"," $\\rho^\\top \\mu^{RRR}$-DM  &                0.279 &                    4.373 \\\\\n"," $\\rho^\\top Y$-IPW         &               53.87  &                  111.746 \\\\\n"," $\\rho^\\top \\mu$-IPW       &                3.175 &                    8.369 \\\\\n"," $\\rho^\\top \\mu^{RRR}$-IPW &                0.602 &                    5.009 \\\\\n"," $\\rho^\\top Y$-DR          &               53.941 &                  111.236 \\\\\n"," $\\rho^\\top \\mu$-CV        &                1.544 &                    2.757 \\\\\n"," $\\rho^\\top \\mu^{RRR}$-CV  &                0.602 &                    5.058 \\\\\n","\\hline\n","\\end{tabular}\n"]}]},{"cell_type":"markdown","source":["## 2. Predictive Fit of Log(Outcomes)"],"metadata":{"id":"mXMeyUs0aV7n"}},{"cell_type":"markdown","source":["- Outcome 1: Beneficiary Wages"],"metadata":{"id":"4UjY1Od2gRfo"}},{"cell_type":"code","source":["X_train = train_data[full_baseline_features+['treatment_x']].to_numpy()\n","X_test = test_data[full_baseline_features+['treatment_x']].to_numpy()\n","\n","Y_train = train_data['tot_empl_2rev12_ben_ppp'].to_numpy()\n","\n","Y_test = test_data['tot_empl_2rev12_ben_ppp'].to_numpy()\n","# Scale the data\n","scaler = preprocessing.StandardScaler()\n","X_train_scaled = scaler.fit_transform(X_train)\n","X_test_scaled = scaler.transform(X_test)\n","\n","Y_train_scaled = scaler.fit_transform(Y_train.reshape(-1,1))\n","Y_test_scaled = scaler.transform(Y_test.reshape(-1,1))\n","\n","# Log-transform the wages\n","logY_train = np.log1p(Y_train_scaled)\n","logY_test = np.log1p(Y_test_scaled)\n","\n","# Train a linear regression model on both original and log-transformed data\n","model_original = LinearRegression()\n","model_original.fit(X_train_scaled, Y_train_scaled)\n","\n","model_log_transformed = LinearRegression()\n","model_log_transformed.fit(X_train_scaled, logY_train)\n","\n","# Predict on the test set\n","y_pred_original = model_original.predict(X_test_scaled)\n","y_pred_log_transformed = model_log_transformed.predict(X_test_scaled)\n","\n","# Evaluate the models\n","mse_original = mean_squared_error(Y_test_scaled, y_pred_original)\n","mse_log_transformed = mean_squared_error(logY_test, y_pred_log_transformed)\n","\n","# Print mean squared error for both models\n","print(f'Mean Squared Error (Original): {mse_original}')\n","print(f'Mean Squared Error (Log Transformed): {mse_log_transformed}')\n","\n","# Plot the predicted versus actual values for both models\n","plt.scatter(Y_test_scaled, y_pred_original, label='Original Wages')\n","plt.scatter(logY_test, y_pred_log_transformed, label='Log Transformed Wages')\n","plt.xlabel('Actual Wages')\n","plt.ylabel('Predicted Wages')\n","plt.legend()\n","plt.show()\n"],"metadata":{"colab":{"base_uri":"https://localhost:8080/","height":483},"id":"5fOQgxVxvfrm","executionInfo":{"status":"ok","timestamp":1706068813112,"user_tz":480,"elapsed":1182,"user":{"displayName":"Ezinne Nwankwo","userId":"03581561058008593041"}},"outputId":"2429c975-8a1d-4135-dcc2-3faa7668b154"},"execution_count":null,"outputs":[{"output_type":"stream","name":"stdout","text":["Mean Squared Error (Original): 0.6971153124304854\n","Mean Squared Error (Log Transformed): 0.063231050846399\n"]},{"output_type":"display_data","data":{"text/plain":["<Figure size 640x480 with 1 Axes>"],"image/png":"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96ewsBDJycl4//33kZycjJ9++glpaWl4+umnzRCpCAKZXXBwsDB58mT1fblcLnh7ewsLFiwwY1SW6/bt2wIA4bfffjN3KBYlLy9PaNWqlbB//34hNDRUmD59urlDshizZs0Sevfube4wLNaTTz4pvPLKKxrHnn32WWHkyJFmisiyABB+/vln9X2FQiHIZDJh8eLF6mP3798X7OzshC1btpghQvMq//5ok5SUJAAQrl69apqgDMAeITMrKSnBqVOnEB4erj4mlUoRHh6OxMREM0ZmuXJycgAA7u7uZo7EskyePBlPPvmkxv9LpLRz50507doVL7zwAjw9PdGpUyfExsaaOyyL0bNnTxw4cAAXLlwAAJw5cwaHDx/GwIEDzRyZZcrIyEBWVpbGvzVXV1d0796dn9s65OTkQCKRwM3NzdyhVMBNV83szp07kMvlaNKkicbxJk2a4Pz582aKynIpFArMmDEDvXr1QlBQkLnDsRhbt25FcnIyTpw4Ye5QLNLly5exevVqREdH45133sGJEycwbdo02NraYuzYseYOz+xmz56N3NxctGnTBlZWVpDL5fj4448xcuRIc4dmkbKysgBA6+e26jF6qKioCLNmzcKIESMsYiPW8pgIUa0yefJknD17FocPHzZ3KBbj+vXrmD59Ovbv3w97e3tzh2ORFAoFunbtik8++QQA0KlTJ5w9exZr1qxhIgTgu+++w+bNm/Htt9/i8ccfR0pKCmbMmAFvb2++P1QtpaWlePHFFyEIAlavXm3ucLTi0JiZNWrUCFZWVrh165bG8Vu3bkEmk5kpKss0ZcoU7N69G/Hx8WjWrJm5w7EYp06dwu3bt9G5c2dYW1vD2toav/32Gz777DNYW1tDLpebO0Sz8/LyQmBgoMaxtm3b4tq1a2aKyLK89dZbmD17NoYPH4527dph9OjRmDlzJhYsWGDu0CyS6rOZn9uVUyVBV69exf79+y2yNwhgImR2tra26NKlCw4cOKA+plAocODAAYSEhJgxMsshCAKmTJmCn3/+GQcPHkRAQIC5Q7IoAwYMwJ9//omUlBT1rWvXrhg5ciRSUlJgZWVl7hDNrlevXhVKLly4cAF+fn5misiyFBYWQirV/DqwsrKCQqEwU0SWLSAgADKZTONzOzc3F8ePH+fn9r9USdDFixfx66+/wsPDw9wh6cShMQsQHR2N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\n"},"metadata":{}}]},{"cell_type":"markdown","source":["- 2. Consumption Index"],"metadata":{"id":"OW7aSAgGoJ8W"}},{"cell_type":"code","source":["X_train = train_data[full_baseline_features+['treatment_x']].to_numpy()\n","X_test = test_data[full_baseline_features+['treatment_x']].to_numpy()\n","\n","Y_train = train_data['consum_2_day_eq_ppp'].to_numpy()\n","Y_test = test_data['consum_2_day_eq_ppp'].to_numpy()\n","\n","# Log-transform the wages\n","logY_train_usc = np.log1p(Y_train)\n","logY_test_usc = np.log1p(Y_test)\n","\n","# Scale the data\n","scaler = preprocessing.StandardScaler()\n","X_train_scaled = scaler.fit_transform(X_train)\n","X_test_scaled = scaler.transform(X_test)\n","\n","Y_train_scaled = scaler.fit_transform(Y_train.reshape(-1,1))\n","Y_test_scaled = scaler.transform(Y_test.reshape(-1,1))\n","\n","logY_train = scaler.fit_transform(logY_train_usc.reshape(-1,1))\n","logY_test = scaler.transform(logY_test_usc.reshape(-1,1))\n","\n","\n","# Train a linear regression model on both original and log-transformed data\n","model_original = LinearRegression()\n","model_original.fit(X_train_scaled, Y_train_scaled)\n","\n","model_log_transformed = LinearRegression()\n","model_log_transformed.fit(X_train_scaled, logY_train)\n","\n","# Predict on the test set\n","y_pred_original = model_original.predict(X_test_scaled)\n","y_pred_log_transformed = model_log_transformed.predict(X_test_scaled)\n","\n","# Evaluate the models\n","mse_original = mean_squared_error(Y_test_scaled, y_pred_original)\n","mse_log_transformed = mean_squared_error(logY_test, y_pred_log_transformed)\n","\n","# Print mean squared error for both models\n","print(f'Mean Squared Error (Original): {mse_original}')\n","print(f'Mean Squared Error (Log Transformed): {mse_log_transformed}')\n","\n","# Plot the predicted versus actual values for both models\n","plt.scatter(Y_test_scaled, y_pred_original, label='Original Consumption Index')\n","plt.scatter(logY_test, y_pred_log_transformed, label='Log Transformed Consumption Index')\n","plt.xlabel('Actual Consumption Index')\n","plt.ylabel('Predicted Consumption Index')\n","plt.legend()\n","plt.show()"],"metadata":{"colab":{"base_uri":"https://localhost:8080/","height":489},"id":"KT9HwlJJoEd5","executionInfo":{"status":"ok","timestamp":1706069096972,"user_tz":480,"elapsed":914,"user":{"displayName":"Ezinne Nwankwo","userId":"03581561058008593041"}},"outputId":"d13004cf-27c8-4062-dbd5-a7a0a36482c7"},"execution_count":null,"outputs":[{"output_type":"stream","name":"stdout","text":["Mean Squared Error (Original): 1.092120911210582\n","Mean Squared Error (Log Transformed): 1.0386294865221783\n"]},{"output_type":"display_data","data":{"text/plain":["<Figure size 640x480 with 1 Axes>"],"image/png":"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P8M333yT2NhYoqKieO211ygqKuL5558nOjqa2rVr88UXXxi3MXhclixZQseOHQkJCaF58+b8/fffxve7desGQLVq1ZAkiUcffRSwDo1dvnyZIUOGUK1aNcLCwrjjjjv4999/je8vXLiQqKgoVq9eTbNmzQgPD6d3796kpaU5/RxcuY4Ab731FrGxsURERDB8+HCuXbtmta9PP/2UZs2aERISQtOmTZk7d67xvccee4ybbrqJ/Px8QG8Qt2rViiFDhqgeq8so5YzZs2crdevWVYKDg5WkpCRl27ZtDtf/4IMPlMaNGyshISFK7dq1lfHjxytXr15VfbzMzEwFUDIzMz0dukDgd1y9elU5ePCgS78JKw78rCiTqyrK5EiLv6r6vwM/e2m05gwdOlS5++67bb73f//3f0pYWJgycuRI5dChQ8pPP/2kVK9eXZk8ebJxnccff1ypW7eu8scffyj79u1T7rnnHiUiIkIZN26c02OfOHFCAZTdu3cblwFKzZo1lc8//1w5duyYcurUKaWgoECZNGmSsn37duX48ePKN998o4SFhSnfffed2XlERkYqTz/9tHLo0CHll19+UcLCwpRPPvlEURRF2b59u6LVapVvv/1WOXnypLJr1y7lww8/VBRFUa5cuaK89tprSu3atZW0tDTl/PnziqIoytixY5WEhARl1apVyoEDB5ShQ4cq1apVUy5duqQoiqL89ddfCqDcdNNNyu+//64cPXpUuXTpknLrrbcqERERyrRp05QjR44o06ZNU7RarXLHHXcon3zyiXLkyBFlxIgRSkxMjJKbm6soiqJcvnxZqVGjhjJx4kTl0KFDyq5du5SePXsq3bp1M57jiBEjlOuuu075448/lH/++Ufp06eP02t90003KbfffrvTz0LtubZr105Zt26dcuDAAeWWW25ROnbsaNzHDTfcoAwaNEg5dOiQcuTIEWXp0qXKnj17FEVRlMmTJystWrQwO+YHH3yg1K1b1+wzjIiIUEaNGqWkpqYqn332mQIovXr1Ut544w3jtQwMDFTOnDlj9h2qXbu28sMPPygHDx5UHn/8cSUiIkK5ePGiUlRUpCxbtkwBlMOHDytpaWnKlStXFEVRlFtvvdXs2vXr109p1qyZsn79emXPnj1Kr169lEaNGikFBQWKoijKF198oQQGBio9evRQtm/fruzcuVNp1qyZ8sgjj9i9rpbfcTXX8bvvvlOCg4OVTz/9VElNTVVefvllJSIiwuz6ffPNN0p8fLyybNky5fjx48qyZcuU6OhoZeHChYqiKEp2drbSoEEDZfz48YqiKMpzzz2n1KtXz+4c7Ogepnb+LleG0JIlS5SgoCDl888/Vw4cOKA88cQTSlRUlHLu3Dmb6y9atEgJDg5WFi1apJw4cUJZvXq1Eh8frzzzzDOqjykMIUFFxmNDSFekKO81tWEEmRhD7zXTr+dlHBlCL730ktKkSRNFlmXjsjlz5ijh4eGKTqdTsrKylMDAQOX77783vn/lyhUlLCzMI0PIcPN2xKhRo5T77rvP7Dzq1q2rFBWVXKMHHnhAeeihhxRFUZRly5YpkZGRSlZWls39WU7KOTk5SmBgoLJo0SLjsoKCAiUhIUF5++23FUUpmdSWL19utq9bb71V6dy5s/F1UVGRUqVKFWXw4MHGZWlpaQqgbNmyRVEURZk2bZqVwXLmzBnjBJ6dna0EBQUpS5cuNb5/6dIlJTQ01OG1Dg0NVcaOHWv3fVfP9Y8//jCu8+uvvyqA8XsfERFhnIgtUWsI1a1bV9HpdMZlTZo0UW655Rbja8O1XLx4saIoJd+ht956y7hOYWGhUrt2bWXGjBlmY798+bLZ8U0NoSNHjiiAsmnTJuP7Fy9eVEJDQ43X/IsvvlAA5ejRo8Z15syZo8TGxto8Z9PxWRpCjq5jhw4dlJEjR5rtp127dmbXr2HDhsq3335rts60adOUDh06GF9v3rxZCQwMVF599VUlICBA2bBhg91xesMQKlehsffff58nnniCYcOGkZiYyPz58wkLC+Pzzz+3uf7mzZvp1KkTjzzyCPXq1eP222/n4YcfJiUlpZRHLhBUUE5tNm8aa4UCWf/p1ytFDh06RIcOHZAkybisU6dO5OTk8H//938cP36cwsJCkpKSjO9XrVqVJk2aeHTctm3bWi2bM2cObdq0oUaNGoSHh/PJJ59w+vRps3VuuOEGtNqSfKr4+HjOnz8PQM+ePalbty4NGjRg8ODBLFq0iLy8PLtjOHbsGIWFhXTq1Mm4LDAwkKSkJA4dOuR0vDfddJPx31qtlpiYGG688UbjstjYWADj+Pbu3ctff/1FeHi48a9p06bGsRw7doyCggLatWtn3Ed0dLTTa62o6Afuyrmanld8fLzZOUyYMIHHH3+cHj168NZbb3Hs2DGnx7bkhhtuQKMpmVJjY2PNrpvhWhqOaaBDhw7GfwcEBNC2bVursTvi0KFDBAQEmF3fmJgYmjRpYrafsLAwGjZsaHxt+h1zBUfX8dChQ2bjAPPzy83N5dixYwwfPtzs+/L666+bXfMOHTrw3HPPMW3aNJ599lk6d+7s8jhdodwYQgUFBezcuZMePXoYl2k0Gnr06MGWLVtsbtOxY0d27txpNHyOHz/OqlWruPPOO+0eJz8/n6ysLLM/gUBgh5xz3l2vnFOlShWz10uWLOG5555j+PDh/P777+zZs4dhw4YZk64NWCZVS5KELMsAREREsGvXLhYvXkx8fDyTJk2iRYsWVpVE3hivvbGYLjMYl4bx5eTk0LdvX/bs2WP29++//9KlSxe3x9a4cWNSU1Pd3t4SR+cwZcoUDhw4wF133cWff/5JYmIiP/30E6CfZyyNMlsVa86um2GZ4Zilja2xqDE2He3H8jo6IycnB4AFCxaYfVf279/P1q1bjevJssymTZvQarUcPXrU5TG6SrkxhC5evIhOpzM+jRiIjY0lPT3d5jaPPPIIr732Gp07dyYwMJCGDRvStWtXXnrpJbvHmT59OlWrVjX+1alTx6vnIRBUKMJjna/jynpeolmzZmzZssXsRr9p0yYiIiKoXbs2DRo0IDAw0CypNjMzkyNHjnh1HJs2baJjx46MHDmSVq1a0ahRI7e8DQEBAfTo0YO3336bf/75h5MnT/Lnn3/aXLdhw4YEBQWxadMm47LCwkK2b99OYmKi2+dij9atW3PgwAHq1atHo0aNzP6qVKlCw4YNCQwMZNu2bcZtLl++7PRaP/LII/zxxx/s3r3b6r3CwkJyc3O9eq6NGzfmmWee4ffff+fee+81JjbXqFGD9PR0s++SN0vKTQ2AoqIidu7cSbNmzYCSSkSdTmd3+2bNmlFUVGR2fS9dusThw4d98nk7olmzZmbjAPPzi42NJSEhgePHj1t9V+rXr29c75133iE1NZW///6b5ORksyRzX1BuDCF3WLduHW+++SZz585l165d/Pjjj/z6668O9RcmTpxIZmam8e/MmTOlOGKBoJxRtyNEJgCSnRUkiKylX88HZGZmWnkizpw5w8iRIzlz5gxjxowhNTWVn3/+mcmTJzNhwgQ0Gg0REREMHTqU559/nr/++osDBw4wfPhwNBqNWTjNU66//np27NjB6tWrOXLkCK+++qqZ8aWGlStXMmvWLPbs2cOpU6f46quvkGXZbmipSpUqjBgxgueff57k5GQOHjzIE088QV5eHsOHD/fGaZkxatQoMjIyePjhh9m+fTvHjh1j9erVDBs2DJ1OR3h4OMOHD+f555/nzz//ZP/+/Tz66KNmYSRbjB8/nk6dOnHbbbcxZ84c9u7dy/Hjx1m6dCnt27fn33//9cq5Xr16ldGjR7Nu3TpOnTrFpk2b2L59u9EY6dq1KxcuXODtt9/m2LFjzJkzx6pqzhPmzJnDTz/9RGpqKqNGjeLy5cs89thjANStWxdJkli5ciUXLlwwelRMuf7667n77rt54okn2LhxI3v37mXQoEHUqlWLu+++22vjVMO4ceP4/PPP+eKLLzhy5AiTJ0/mwIEDZutMnTqV6dOnM2vWLI4cOcK+ffv44osveP/99wHYvXs3kyZN4tNPP6VTp068//77jBs3juPHj/ts3P4jGuGE6tWro9VqOXfO3MV+7tw54uLibG7z6quvMnjwYB5//HEAbrzxRnJzc3nyySd5+eWXbf4Qg4ODCQ4O9v4JCAQVEY0Wes+ApUPQG0OmrvZig6L3Wz7TE1q3bh2tWrUyWzZ8+HA+/fRTVq1axfPPP0+LFi2Ijo5m+PDhvPLKK8b13n//fZ5++mn69OlDZGQk//vf/zhz5gwhISFeG99TTz3F7t27eeihh5AkiYcffpiRI0e6NJFGRUXx448/MmXKFK5du8b111/P4sWLjfpFtnjrrbeQZZnBgweTnZ1N27ZtWb16NdWqVfPGaZmRkJDApk2beOGFF7j99tvJz8+nbt269O7d23iPfeedd4whtIiICJ599lkyMzMd7jc4OJg1a9bwwQcf8PHHH/Pcc88RFhZGs2bNGDt2rFE40tNz1Wq1XLp0iSFDhnDu3DmqV6/Ovffey9SpUwG9l2Pu3Lm8+eabTJs2jfvuu4/nnnuOTz75xIOrVsJbb73FW2+9xZ49e2jUqBErVqygevXqANSqVYupU6fy4osvMmzYMIYMGcLChQut9vHFF18wbtw4+vTpQ0FBAV26dGHVqlWlomNlykMPPcSxY8f43//+x7Vr17jvvvsYMWIEq1evNq7z+OOPExYWxjvvvMPzzz9PlSpVuPHGGxk/fjzXrl1j0KBBPProo/Tt2xeAJ598kl9//ZXBgwezfv16s1w6byEp7gQJy4h27dqRlJTERx99BOjjiNdddx2jR4/mxRdftFq/TZs29OjRgxkzZhiXLV68mOHDh5Odna3qgmZlZVG1alUyMzOJjIz03skIBH7AtWvXOHHiBPXr1/fMADi4ApJfME+cjqylN4IS+3k+0FIgNzeXWrVq8d577/nEcyIQmHLy5Enq16/P7t27K60wpDdwdA9TO3+XG48Q6DP7hw4dStu2bUlKSmLmzJlGoS+AIUOGUKtWLaZPnw5A3759ef/992nVqhXt2rXj6NGjvPrqq/Tt29cnVqVAUGlJ7AdN7ypXytK7d+8mNTWVpKQkMjMzee211wBKPZwgEAjKlnJlCD300ENcuHCBSZMmkZ6eTsuWLUlOTjYmUJ8+fdos3PXKK68gSRKvvPIK//33HzVq1KBv37688cYbZXUKAkHFRaOF+reU9Shc4t133+Xw4cMEBQXRpk0bNmzYYAxLCASCykG5Co2VBSI0JqjIeC00JhAIBGWAN0JjFbpqTCAQCAQCgcARwhASCARuCasJBAJBWeONe5cwhASCSoyhvNZRywaBQCDwVwz3Lk+kAspVsrRAIPAuWq2WqKgoY6+gsLAwrwoKCgQCgS9QFIW8vDzOnz9PVFSUR5XgwhASCCo5BkFSdxowCgQCQVkSFRVlV1RZLcIQEggqOZIkER8fT82aNW02kxQIBAJ/JDAw0CuagMIQEggEgD5MJoRGBQJBZUMkSwsEAoFAIKi0CENIIBAIBAJBpUUYQgKBQCAQCCotwhASCAQCgUBQaRGGkEAgEAgEgkqLMIQEAoFAIBBUWoQhJBAIBAKBoNIiDCGBQCAQCASVFmEICQQCgUAgqLQIQ0ggEAgEAkGlRRhCAoFAIBAIKi3CEBIIBAKBQFBpEYaQQCAQCASCSoswhAQCgUAgEFRahCEkEAgEAoGg0iIMIYFAIBAIBJUWYQgJBAKBQCCotAhDSCAQCAQCQaVFGEICgUAgEAgqLcIQEggEAoFAUGkRhpBAIBAIBIJKizCEBAKBQCAQVFqEISQQCAQCgaDSUu4MoTlz5lCvXj1CQkJo164dKSkpDte/cuUKo0aNIj4+nuDgYBo3bsyqVatKabQCgUAgEAj8mYCyHoArfPfdd0yYMIH58+fTrl07Zs6cSa9evTh8+DA1a9a0Wr+goICePXtSs2ZNfvjhB2rVqsWpU6eIiooq/cELBAKBQCDwOyRFUZSyHoRa2rVrx80338zs2bMBkGWZOnXqMGbMGF588UWr9efPn88777xDamoqgYGBbh0zKyuLqlWrkpmZSWRkpEfjFwgEAoFAUDqonb/LTWisoKCAnTt30qNHD+MyjUZDjx492LJli81tVqxYQYcOHRg1ahSxsbE0b96cN998E51OV1rDFggqBrIOTmyAfT/o/y+L35BAIKgYlJvQ2MWLF9HpdMTGxpotj42NJTU11eY2x48f588//2TgwIGsWrWKo0ePMnLkSAoLC5k8ebLNbfLz88nPzze+zsrK8t5JCATlkYMrIPkFyDpbsiwyAXrPgMR+ZTcugUAg8ALlxiPkDrIsU7NmTT755BPatGnDQw89xMsvv8z8+fPtbjN9+nSqVq1q/KtTp04pjljgCTpZYcuxS/y85z+2HLuETi43UV//5eAKWDrE3AgCyErTLz+4omzGJRAIBF6i3HiEqlevjlar5dy5c2bLz507R1xcnM1t4uPjCQwMRKvVGpc1a9aM9PR0CgoKCAoKstpm4sSJTJgwwfg6KytLGEPlgOT9aUz95SBpmdeMy+KrhjC5byK9m8eX4cjKMbJO7wnClkGpABIkvwhN7wKN1sY6AoFA4P+UG49QUFAQbdq0Ye3atcZlsiyzdu1aOnToYHObTp06cfToUWRZNi47cuQI8fHxNo0ggODgYCIjI83+BP5N8v40Rnyzy8wIAkjPvMaIb3aRvD+tjEbm3zj1oJ3abO0JMkOBrP/06wkEAkE5pdx4hAAmTJjA0KFDadu2LUlJScycOZPc3FyGDRsGwJAhQ6hVqxbTp08HYMSIEcyePZtx48YxZswY/v33X958803Gjh1blqch8CI6WWHqLwcd+SyY+stBeibGodVIpT62lBMZnM++Rs2IEJLqR5f6GOxhy4MWFxnMw0nXUa96FWpGhNAuN13dk1LOOefrCAQCgZ9Srgyhhx56iAsXLjBp0iTS09Np2bIlycnJxgTq06dPo9GU3Lrr1KnD6tWreeaZZ7jpppuoVasW48aN44UXXiirUxB4mZQTGVaeIFMUIC3zGiknMujQMKbUxuXPoTqDB83SeEzPyueDP/41vr4z4ixz1ewwPNb5OgKBQOCnlCsdobJA6AiVMrJOH2rJOaefYOt2dJh/8vOe/xi3ZI/T3X44oCV3t6zlxYHax56hYfAFzRvUusyMIZ2s0HnGnw6NRwNaZDYEjyVeuoxk0+cm6avHxu8TOUICgcDvUDt/lyuPkKCC40aZds2IEFW7Vruep/hzqA6ce9BM0aHhtcIhzAuaiYJkYQwVj733W8IIEggE5ZpykywtqOC4WaadVD+a+Koh2DMpJPQhqaT60V4drj1cCdUZKM2y//PZ6owgA8lyEk8XjKcgzCL8FZkAD34ldIQEAkG5R3iEBGWPB2XaWo3E5L6JjPhmF5LFHgzG0eS+iaXmfVFraBjWK+1cInc8Y6vlJJJ7DufuqFOqQ5YCgUBQXhCGkKDscaVMu/4tVu/2bh7PvEGtraugyiA52dTQ0CCTpEmlJlc4TxQpclMAkjSpNLt4npQ/qzHqdy06C8esoezfaS6Ri/lUUOJBS8+8ZtPstHtekVVKrr0bxxUIBAJ/RRhCgrJHbfm1g/V6N4+nZ2JcmZerGwyNFtnrmRT4FQlSSQgsQwkHIFrKgY36ZRuCo5laOITVcpJxPVW5RG62vXDkQbOFhN6gNIYWRbsNgUBQwRA5QoKyR235tZP1tBqJDg1juLtlLTo0jCmTZGStRmJu6/9jbuBM4sgwe68aOVQjx2xZHBnMC5xJL02K2XJbuURGPGx7YfCgxVV1HCazCi2KdhsCgaACIjxCgrKnbke9VyErDds+iuIy7bodS3tkLqMrKiJx75tIElYJ3JINu0wjgazA5MCvWZPfFtni2cQq58hLbS8sPWgnL+axOOU06Vl2Qoui3YZAIKigCENIUPZotPrQytIhYC/luRyUaSfvT2PFz0uZW5ju0nYaCRK4RJImla1yotl7VsnNavOpTmzQXy8HeTwGD5qB0d0b2Q8tepjHJRAIBP6KMIQE/kFiP305ts38k7f8Pv/EIKLYV3MebLexc0pNrhj/bczNqVtVb9QYDJpslX3TfngUrl4uea0yf8iu+rYX8rgEAoHAHxGGkMB/SOynD62Us4okUxHF80S5vR/DtoYI2uwWp9C90whtvolBE6ayTYipEQQleTzuav94KY9LIBAI/A1hCAn8C4223IVWTEUUU+SmnFWiiSMDtbnaMpCuxBjL6+OqhvB+tWW0TllklWek5F2yKx7pGNt5PKobw1agPC6BQCAwRRhCAoGHmCY0y2iYWjiEeYEzkRXMjCFDWbw5EhKQ3XUaH1RrTc2IEIIOr6D1tkWGty3WNt2PmgJ4U8zzeJL3pzFtxT7q5Ow1ah2dCW/Bq/1uLNEvMtUMav0orJtu47jlJ49LIBAILBGGkEDgIZYJzavlJEYUjmdy4FckmJTQFwVFEajVwFWTkvjIBKTeb9EksR9N0FedZX09yWaFmQHjW2ExkHex5I3QatYhMVvknCN5fxrLv53P94FfkRBUMp6z+dG89u0QeORpemu2W+dshVbTj8DiHMpDHpdAIBDYQhhCAoGH2FJrXi0nsSa/rVFZuqhKTT763yi9i8hBDlTqttXcQJa6A/eeDhHxJftSZPjKuTGiq1KTdd9+ztzAmVbvxZHB3MCZLPrxJIr8s3XX+atXAAW6vgQxDctNHpdAIBDYQxhCAoGH2FNrltGwrbgcft7drdEGFP/cTHKgdLJCyrFLxhydgIz/1B849wJImhJjBFTl8aQUXs/YwqEAVnlMBl2jR3QrQHKgGbTrSxi/TxhAAoGg3CMMIYHAC7jT78xWw9WeYbncrOJ4ChLS6pdKFhjK41XoMelObzVr/WGJ3jiSHR5daAYJBIKKgjCEBAIv4Uq/M4PukKXPZW1eI84GRxNPhs08IcWYKW2xpWl5vBM9pppnv/DwTIsRmkECgaACIAwhgcCLOBQlLMZUd8gSGQ2vFQ5iXuAsFMW6LYck2as+MymPH7/PoR5TwwYNjU1fPUJoBgkEggqAMIQEAh9jqdUjy4pZOMySK0SqqxqzwjxkpavbWX/czGvUPHGFpLpV0Z7ZgjYnnfygagTmX7apdSQrgKRBg4LQDBIIBBUdYQgJBD7EVh5QVGggGmRjRdl5okiRmxobrpq22nCL4vJ40+P20qTQIOhrYrkEQDCgSPpMINM2rzIgSRJSx9Gw+SOEZpBAIKjoCENIIPAR9vKA2uVvYnLwV2YJy2eVaKYWDmG1nORRmw6AlAsBjPi95Li9NCnMC5xpFVOz5VmSImshGTSBat9sO9fo9jf1ekL7fhDl8wKBoNwjDCGBwAfYywMyGiUWxJHBvMCZjCgczxq5rcM2HbZyh0Af0roWFsczW8NQKARAg8zkwK/0/7axjYSkF2Ys1iSSTI0aW73f8i7B6ok2ErEdN3S1i6lytTCqBAJBGaBxvopAIHAV0/5jBhwZJYbXkwO/BmBq4RCgOF/HBKX4teVyw+vNjZ7jv6xC4/IkTSoJkqO+Z4penToiXl8Kb2mEGHq/3Xi/XrX6+0fNjSAoqVg7uMLeQWxzcAXMbA5f9oFlw/X/n9nc9f0IBAKBBwhDSFB+kXVwYoM+RHNig/61n2Daf8yAM6NEI0GCdIkkTaqxTUc60WbrpBHDx0V9rJanE8NLgf8ju/4dZstV5xsVl8LrZIUtxy7x857/2HLsEjqDhSXr9GEym8nTxcuSX1T/GRxcoTeevGVUCQQCgZuI0JigfHJwhR2tHDdDNF7Gsv8YqDdKDOtZtukwTap+WzfAbPl2uSlzHmhL1dAgs32pzjcKj7WZ2B1vEISsctTaaDHDBZFFp0ZVsQxA07tEmEwgEPgcYQgJ/As1OSMGb4IjUcEyNoZs9R9Ta5SYriejYWtxmw4DUaGBXLlaaFweXzWEOcXq1TpZMTtuitzUYb6RoRQ+Oac+IxZZJ3anZ15jxDe7WN7lLC3UDF6NyOKpzd4zqgQCgcBDhCEk8B/UeHnKiTfBVv8xZ0aJrOhDXClyU4f7nvNIazQayUy9GmBLcc+yATfX4YM//kVCb0hNLRzCvMCZyIplbpL+ha7XdKauOOzoivLx7jzmqjlxNSKLahWphXK1QCAoBYQhJPAP1Hp5ypE3wbL/mMEomR80U98rzORcFSQkCd7XDDPqCVkioe9d1r5hjFnbDptaRWGBAFzJKzTmG71moiMEGNtupAR3Ii1zq93zUIDk7AbkR8cRnJdu/4Qja6kTWVSrSO1N5WpRnSYQCOwgDCFB2eOKl6eceROs+4+1R77WGu3qF80MOqnYKOkh38yyb3YBNmUMmdw30coIsqVVlJmnrxx7pkdj6lUPo2ZEe6rXfRXObLEyBs7vcd7xXkbD6YQ7uf7o5/ZXan6fOuOibke9EZaVRqkoV/t5PplAIChbhCEkKHtc8fKUhTfBVSy8D9q6HS36j90NzfrY9FD0BtVd7B31LDOEtJZsP83GF7qXGE82vGS2Erst0SBz3dlVjlfavwx6THFuDGm0eiNk6RB8rlxdDvLJBAJB2SIMIUHZ44qX54Z7HHoTFCSuhsayt6gJSbJis/O7T1HrfTDo89hAbRf7rccvOexZpgBpmddIOZHhsBGsrcRuUySgd8Rxx2ExcC0kmdhPb4TYvFZvecc4KSf5ZAKBoGwpdzpCc+bMoV69eoSEhNCuXTtSUlJUbbdkyRIkSaJ///6+HaDAdVzx8hi8CYBlkwgZUBSFZzIH8PBn2+k840+S96d5dagO8aI2jqGL/d0ta9HBIicI9CGxUYt2qdqXLU0jy2NN7quvQLM0Gw2vn2oVpupYtoxau9pEif1g/H4YuhLu+0z///H7vOehccXTKBAIKi3lyhD67rvvmDBhApMnT2bXrl20aNGCXr16cf78eYfbnTx5kueee45bbhGluH6JIWfEbl91yTwR1+BNiIw3WytdiWFE4XhWy0n618Wl36ViDHlbcNABhrygK1cLna+MndCXhRhl78SazBvUmriq5uvGVQ1h3qDWtGjmuJLNiIVRm7w/jc4z/uThBVsZt2QPDy/Yam6gmipX21K29oRylk8mEAjKBklRFFt3br+kXbt23HzzzcyePRsAWZapU6cOY8aM4cUXX7S5jU6no0uXLjz22GNs2LCBK1eusHz5ctXHzMrKomrVqmRmZhIZGemN0xDYwpjLATZzRmzlcsg6dCc3MfXbPzmSV8Wsg7vp1nFVQ8zzZHzBiQ36FhHOGLrSo2o2nazQecafDkNiBuyeu4Pwna5pX9shOVmnb3/hLMF5/D6jMWMvkdswknmDWpvlPHmdUvpMBAKBf6J2/i43HqGCggJ27txJjx49jMs0Gg09evRgy5Ytdrd77bXXqFmzJsOHD1d1nPz8fLKyssz+BKWAHS8PkQn2E1o1WlKUG/gq52a2yok2y85N82R8Sil5H2z1MLOHAgy4+TrzhU7Cd9rUX2yH5ByEJG0lODtL5AaY+svBkjCZL3DV01jR8eOWNAJBWVJukqUvXryITqcjNtbc9R4bG0tqaqrNbTZu3Mhnn33Gnj17VB9n+vTpTJ061ZOhCtzFVrdzJ3ovzvJfDGw6etFh4rHHlFI1m9rzNfDBH0dYsv20vuIssaZnycMuJDg7M9jUJnJ7RGlWp/k7FURCQCcrTosIBAJXKTeGkKtkZ2czePBgFixYQPXq1VVvN3HiRCZMmGB8nZWVRZ06dXwxRIEtHFRT2UJN6TfA7L+O6nePTO+I4zzVKkyf9+ItYb1S0sZRe76mGHKlvru9kCRPxShVGqtqDDYNMrrj6yFP5zuRw9KoTvN3KoiEgMNeeL4MsQoqPOXGEKpevTparZZz58xDC+fOnSMuLs5q/WPHjnHy5En69u1rXCbLMgABAQEcPnyYhg0bWm0XHBxMcHCwl0fvJ1RAdV1npd+m9NKkMDnwKxIKMyAF/Z+3nopLyfvgyvkaMGgKrdy8hyQ1GzgL36kwVp0ZbMbPYpNJyNJXHgo3PI0VhgoiIWAv38xg5Ps830xQofFKjtCVK1e8sRuHBAUF0aZNG9auXWtcJssya9eupUOHDlbrN23alH379rFnzx7jX79+/ejWrRt79uypfF6egyv0ya5f9oFlw/X/n9ncpZJuf8RR6bcpvTQpzAucSRzmuUKKG6XtdrGX5xQWA+1HQGg1+3kZKvM31J6vJQpwJK+KupW9IEZpMNhsjdH4WUgWeVve/Cws8WV1mj9TASQE/CLfTFChcdkQmjFjBt99953x9YMPPkhMTAy1atVi7969Xh2cJRMmTGDBggV8+eWXHDp0iBEjRpCbm8uwYcMAGDJkCBMnTgQgJCSE5s2bm/1FRUURERFB8+bNCQoK8ulY/Qov6tv4Y8KloaeXZem3AQ0ykwO/0v/bYmaWvFnaLusgtBrybVM40eYVjjYYTEFQNci7CFvnwpd9UD64gcN/LTLX1HHFSJV19K5ylOVdznJHxFE0yA6HpEGmveYg/TSbkZC5GlwTnyQPW3wvtMg2DTazz8JqJ96VGRBQISQEXMk3EwjcweXQ2Pz581m0aBEAa9asYc2aNfz2228sXbqU559/nt9//93rgzTw0EMPceHCBSZNmkR6ejotW7YkOTnZmEB9+vRpNJpyUwhXOnjTNe7HCZeWasz/nstm9l/HAEjSpJJg6X0wQ/9UvHHtCrT1OpGkTUWbe961EIrJtdEA9QGjMIWpJZCdxvXrRvJ+sd7RgPA9TC96x6wBK2A7f8PkGC2AuUB+dBx7m09kX0QXpv16yGwXxvCTybkXKlGUBMu8FL6z873o3XsGcx65mVd+3k9GbgGg/rPwh6a5FYLy0JLGCWoLBFwtJBAIDLhsCKWnpxvDSitXruTBBx/k9ttvp169erRr187rA7Rk9OjRjB492uZ769atc7jtwoULvT8gf8db3drLQcKlQY0ZYMuxS0ZDqCZXVG2fuu477gyYgFZyMW+l+NooKNaF5VYeKD3TAz9lbX5rxhZ+qt/OykljYaSm/mrz+gfnnSMpZTxtHviST6uGG3OHDOEnSwIKMvX/CI2Cq5ctzvMtvY7QsUvqq3IcfC+UpUNYH/A8GbktjYvrB2fbtsktseehqIB5bj6ltBvc+gC1BQLuFBIIBOCGIVStWjXOnDlDnTp1SE5O5vXXXwf0rQ10OuHO9ju84RovhwmXpknF54lStc3wgN+sz9CZoVd8bdQYQabLo8lhiHa1Ou/IiQ1Or7929UQm9/mdEYv26sNSDkOBEgSGwf0L9WG7YoMi+eB5plqINTqsynHyvVAUGFv4GUv50KjxdCI/AtREpYs9FKbl0k0vr6Px7teR/NAj6bdUAAkBNb3w4qrqjXZB+cJf5BBcjiPde++9PPLII/Ts2ZNLly5xxx13ALB7924aNWrk9QEKPMQbrvFylHBp6Gu18p+zDLi5DgqwXW7KWSUae7mUsgI6RYOCteHgNG+l+Nq489NNkg6rW/HURlXXv3f4CeYNak2viOMkSBk2zsV8fTRaY/Jw8sHzjPhml1UuhsM2JU6+FxoJEqRLJGlKdL5SDJ+F3a1K8pRM23OsWvoJ168bieKNPLfKhjtipX6Eml54k/smCj2hcobT9juliMseoQ8++IB69epx5swZ3n77bcLDwwFIS0tj5MiRXh+gwEO84RovJwmXtnRGosICAZh6bQjzAmciK+bGjsE40kqOko5thw91ssLqLbu5083x5koqZRrUFsPknKP3jbdwu5wAP6pbHxxX5UjIJGlS2bx8Oz3DuqOt1wk0WnSywrFjR2ms4jCmoUkZDVML9Z+FIkkWuVElHgqDYaagJsFanUfSX54+y4RyLiFgKIiw/H3HCR2hcom/ySG4bAgFBgby3HPPWS1/5plnvDIggZfxhmu8HCRc2vthZebpG5Mm9hjEjoL6tNg/neC8dOP76cSwSnczjwckOz+IiaGXvD+NCUv3clNRPne6WYC4THcLHTSHiMOe96bYSK1/C2x4x/kOi6+/JsJaV8vR+vaqcsySrYuArz6AyAR23/AiI3fVpm72RZaoOHfL0ORqOYkRheP5IHIxYddKrqkSmYBUnKc0dcafxs/S1QRrWwbPmoPpQozPRbFSf8OyIKLSGbMVBGdyCBJ6OYSeiXGl9tm6Jaj49ddf8/HHH3P8+HG2bNlC3bp1mTlzJvXr1+fuu+/29hgFnuKpum5ZJVyqTIxV88Nasv00o18Yirb3YDi1mSPHjjLpz4ukyE1J0qTyOCoMoWLDIXl/Gk9/swuAFJqSoVShGrl2c4KsxqTAZcLZKjc3ekdkLL0dJkZqvc4uXf/knPq0IoYayiWHBpauTgdSjl3iNxNXtKbYA9RD2mkzZ0rJSqPF5rHcVDietXJrLioRRJNt8ziyojc0U2TrzvWr5SS6FLSnUcF+anKF80Rx5loLXpVvpKqFYaY22Z2cc3a9gleKDWJThBifA/w0Kd20IEJQPvGL9jsWuGwIzZs3j0mTJjF+/HjeeOMNY4J0VFQUM2fOFIaQv+KJa7wsEi4PrkBJfsEsMVbvMbBOjHX5h1X/FhrW7cyp7X+iZF4z5q049czU7YhOVpiy4oDxnf9pl7hkBBmYWPg4Mhp+l5MYWTieD6ouIfRqiafKykhVef2T96cxYtFebtcMthkKNGz5a8I4Xn/7b9KzSq6brXJ765wMBQV4L3A++QQQI+XYPD9DoHFq4WBkNEYDy2D0pMhNuZgHF0ks2XdWISO+2cWwTvXM9qU22T3lQgAjfrf2CtoygqDsnj79Hj+WyRCUf/xRDsHlZOmPPvqIBQsW8PLLL6PVlkx8bdu2Zd++fV4dnMDLeKKuW5oJlwdXoCwdYpUYq2SdRbGRGHs+K9coGthec9CuyKDpD8s0AVMpzlsBbCRUmxsaKScySM/K1y/SbOWpgJUun95nRXewWtY3u4irGkL/R54m9PmDMHQl8r2fcqDnt/zcLZktwZ1K1HJVXH+DkaZQEn5Kx7ySJk2J4emCcYzeU9vKCLKlvG0LjQTh0jW7RhBAfmgcIwvH87ucRC9NChuDx7Ik6HVmBc1mSdDrbAweSy9Nitk2hkv/8x7zzz3FSbI7SCiRtXhma5jqdCrTYwoxPhO8Kb7qTfxQyFXgHv4oh+CyR+jEiRO0atXKanlwcDC5ubleGZTATymNhEtZx9VfnidYUay8MxpAVhSu/fI8oYbE2IMr6L3mee4OKvGmnFWimVo4xGhsGLD8YZkmYK7O1BsOkwO/IsHUGLDwzBiMKQ0yrwd+7rInCKDDnYP5sEpLqxyH5NxGTP21oNi7pX+oMMtjcXL9Z/951Gikgd4YWpPf1soTYyhlN3hpYsng1cCvkbBf8q8WRYH84GhCn91H/9RLRC3/nDcLZ1qtF0cG8wJnMqJYWNK4PXApt4DoKoFczi1EwTzB2tLDZTBUj7R6mf9W2/b8qEGI8eG/MhnCQ1Wh8Ec5BJcNofr167Nnzx7q1q1rtjw5OZlmzZp5bWACP8XHCZe6k5v0ISI7E7JGgtCr6ehObkJ77QosHUKQxc/JcpJ19MMyT8Bsyakqo4h1oCxtMKZGaZdT3YFHxBYyIEXW4oYOvbnBYiJRXUVh5/on70/jgz+O2Dimhq1yotVyW2EwbyBJEFKQAWe20btpO3oFfQZF1h+nRtJ73yYHfs2a/LZG48zAPS1r8dmmk8bXBg+XPUM1taANsMftcQsxPrwnvupNyoGQq8A1DN74Ed/sshfoL3U5BJcNoQkTJjBq1CiuXbuGoiikpKSwePFipk+fzqeffuqLMQoqEceOH1NVkn3s2L803vcu2BAyNJ1k/yieZB39sKwTMGvaPW5S/WgGhO9mQuEPKkZZgiGsszu8C61PbTYzsDytojBsrxZ7qtNe5fAq+H4oUt4lu6toJEhArzNkaax1bxrLst3/meX3WHq45LDqfNivJdqrl2iUuwcNspVB5QwhxmeCv8lk+KuHSuAx/iaH4LIh9PjjjxMaGsorr7xCXl4ejzzyCAkJCXz44YcMGDDAF2MUVCLOK1GqDKH8zHPOxfy4RK+I4/S7+0Gv/bD0qs1fg4tRGIP90vrsYvhysZlr39MqCmfbm43Dgeq0V9k6V/WqplVhEpAQGUjkua10ubaF8xrzcJ7Bw9VLk8Lkwllov9F7h24AtoTEMLlgMMlyks3kbEsjSYjxWeBvMhn+6KESeA1/kkNwq3x+4MCBDBw4kLy8PHJycqhZ0/4TtEDgCtp6nTi70X4Fl6EkO7iqupvx7L4JaLz5dHFqs8PQnWpMXPvnC9qo2sReHosr+S3ONXm8gaXD2zGGqjAJvbfqA+0SQv9IZ1axRpFlzpc9j1ZNMpgbOJNPivrQL2Cz2XmeVaJ5V/MYP15tbVwmxPgs8Le+ZGXgoarUoptlgL/IIbhlCBkICwsjLCzMW2MRCEhqWIOXAx/nzcK37apAzwoczhsNr4dNzvenWlxQLV676Za49hslzaCfZqtdz4UBe3ksruS3qNbksYF1orI91BlBMpCulOgMPRS+h+lFHyJdtZ/ztUZu67iPmgRPBa5EsRhCvHSZ95T3eKrXHFKrdRWTnC38rS9ZKXuobGlQVTrRzUqKy4ZQq1atkGyUlkiSREhICI0aNeLRRx+lW7duXhmgoHKh1Uh07f8YI78tYJJFYmw6MbxWOJj+DzyGtl7Nsnl69WpYQO/av+GPQXa9HwbiHeSx2KvCsBUeUqvJY4qswBXCiSLHBWPIORIS2V2n8UG11tSsEkj7X55DyrL+LE1zvrIKwxx6tAxDs7xFGZrNNtn9Bk3GDxA5JfbwVHzVm5Sih8rfWj4ISheXdYR69+7N8ePHqVKlCt26daNbt26Eh4dz7Ngxbr75ZtLS0ujRowc///yzL8YrqAT0bh5P/0ee5oHgjxlQ8ApjC0YzoOAV+mjm0Kz7IHomxuknstunY/cGCT55ek3Oqe9E08YzDN4PS42dV+9q5jDZ27IppT3tnmpkOxy/pSfFsN7Ewsdt6hK5TVh1pAe/okm3gfS5KYHI89vNu8pbYGjg2kFSnxRujf80B/ZrEvvB+P0wdCXc95n+/+P3lX51lsFDBdhtt+qF37izYgXQFyvofPWjF5Q5LhtCFy9e5Nlnn2XDhg289957vPfee6xfv57nnnuO3Nxcfv/9d1555RWmTZvmi/EKKgm9m8ez/sWedOh+N+uDb2WrnEjGVZkP/jhC5xl/snv1l/D7RNsbh8VA+xEQWs2rwms6WWHqysMOxBc9x2DrTA782kwYsloVxw1aDVUYcVVD7IojxpHBnMAPWVGkf4K2HL+lEQR6L5xBhmC1nETn/FnMKurv8nmZEVYdJhyCxH7GDtQf/6rSOPGGN6qMmwOXCzwRX/UmpSDk6kqxgqBi4nJobOnSpezcudNq+YABA2jTpg0LFizg4Ycf5v333/fKAAWVlzUH05n5x79WT2otstfTYvNMFMnOvJh3UV+1tHWuV4XXDDfMNOxo2ngJW2XllgnRtpI6ezePp2fTGhS9PxIpz752T7+ALYwsHMukwG/Mxn9OimFqwSAuE2G32kpGw2a5OWNZ7saZFY+ozwcQEGQWjjiviVK1hy1yIvcr6x20Q1HBpWNubigoE3ws5OqPLR8EpYvLhlBISAibN2+mUaNGZss3b95MSIg+aVOWZeO/BQIjLjRyNHVXm+a6XCDSmCyrah50U3jNlqFheiM01bQxKDPbaz7qLqaJzaYJ0XaTOvs0oXfOz2jz0rGHwci6QiS35M+iV8RxfWVdRBw16nRgyKlM1hxM53MTMUNLnPdms4NJnklBkcxLP+03GrnO9mmoFtwmJzpQmVbJri+hy3PuT6TOvsd+2rC0XONDIVd/bPkgKF1cNoTGjBnD008/zc6dO7n55psB2L59O59++ikvvfQSAKtXr6Zly5ZeHaignOOiTL7B++K5ArLrwmv2DI0BN19ntp6pavO1wiDPJmcb1JPSSgT/6laFExvYeyiVhRuvcE5uimlku0X2em764XFQeZ0Ga1dTkysM6nAzmuZ9QaNFiz7xesQia4+vKY5bXtih15vQ7mljY9iXftpHRm6JGJOjfRpCeIuLutJHs5ULRDKz6F6GBaymGiZtfSJrQZ12cOBHx2PxRHvG2fdYtIMod/hjywdB6SIpiq3MAMcsWrSI2bNnc/jwYQCaNGnCmDFjeOSRRwC4evWqsYqsvJOVlUXVqlXJzMwkMjKyrIdTPrEnk2/w6djw1vy85z9WLf3EqBfjDeNiQ6eFHAlpQXSVIOKqhpJUtyraM1vMntyTD563qh4x9UjlBVfnr6uN0NlIr7NltF1UIlmu60iaUo1XAxe7NF6dAgt1vehyU2Ou/79lZpOraXWZqa6OW9fJZKKetSaVzX/94lCI0EBvTQpTg74i1mF4sLiyZ/w+oxFkqzrHgK1reJlwFAWi7bQ0ySSc8FvHoL31eTjwEywb7vyck56EZv3Ue2tkHax/F9a9afscATqOgc0fYfk9N2ifyw98ifaGu50fS1DqGL6XYLvlg6gaK5+onb/dMoQqE8IQ8hBZBzOb21WIVZC4GhrL3ns3kNSwhr4yStZxYPMqEtY8RVVyveZhGVswmhWyPlG4lyaFqUFfE0dJCwglMoGJeYNYktPSuMzWxHxWiea1wiEkW5S4g3kj0xgpi0tKJNdJ53g4YC0J0hXvnAglXpJRheN4NfBrz3Jmim/3ug6jubDlW7NrclGJYLmuE3/Iba2MIgmYN7AFvS8tcmwgFBu6Olmh84w/napgmxqez7UNoM4/H6LYaMJrQEHSH+nBr/QJ8l/2UX/qarw1trw8tpA0oMg235IVOC/FsOe+9fS+sbb68QlKDaEjVPEQhpCXEIaQChzlRJzYoGpiGlDwCqciWjO39f/R6sBbzicdNxhQ8IqxPYMtD4qCvnLKUCXlaD2ApwvGW+n9gG3jSVE87+xuiaxABpFUl7K8sj/D+dszOEy9UJIET95Sn4l3FvcIsxkSqmWmPbPl2CUeXrDV4RhMjSAlNJpZQbORrqoJ9xV7nsbugVktULLSirWDrM9RstwO7OeQ2fVmuseAgld49JFBYmL1U4SydMVC7fztco6QTqfjgw8+YOnSpZw+fZqCggKz9zMyRIlhpcJZToTKUuWaXCHKWTWYmxgSbXfIjemg2c9bgQsAW8rE+ulucuDXrM1v7UDBWO+FmBX1HbNveoiP1p0wvmev/YO3jSDDuKrjHSMI9OflaJymCs+r5SQ+WX+CVtdV00/qKip7nFXdWBmQOuCq2tEXawSd2cbuG16kxeax+kR7UwPWpjHqIIfMYdNP96jJFYcNdAVli7+0fBCULi7rCE2dOpX333+fhx56iMzMTCZMmMC9996LRqNhypQpPhiiwG8xPC1bem8MlVoHV6hWYr5AJJNcqQZTiSGEtKKoA+uDx7M46E2qSfbDbQbhviHa30mQ7IebJBSC89Jopz1csi0y0wM/RcLHDU3LCMM5vRH4OXdrNtJOc5BpK/aVCM2ZaM/o6nZmy4kr/LznP7Ycu4ROVsyqbjTItNccpJ9mM+01B+mt2WpT+8hV5Ox0Ru6qbVP80b6RZ0do0WnTT9c5T5TQpDFF1um9xvt+0P/fi7pfAoFaXPYILVq0iAULFnDXXXcxZcoUHn74YRo2bMhNN93E1q1bGTt2rC/GKfA3HD4tmzxlj93jUCbf4K0BXKwMkyAiHu6ZD7kX9AZX7iW9yKLJ5JVODCuKOvBkwEoX9g1JmkOq1qspXQH0TYdHaZfbTej1JReVCLul+94OyRm8UB8G6bvLn82P5ujfr9Ok20BjiHTvoVQ+3p1HcnYDY05RfNUQXr0rkfiqIbTIXq9vn2LyeesUybh/T/i/Y/tJy0wijRJ5g96aFB4N+N35xpbeSxeEF2UFFDRIyA7L/w191YQmDaLCTuA3uGwIpaenc+ONNwIQHh5OZmYmAH369OHVV1/17ugE/ovTp+WSUIW9Ro4GR8LUwsHUcCnEUzzT3DEDGtxq/lZiX1LW/cJPG3ZxIj+CHXJj1gePB1ybZHtrHZeQG2jYoCHxVQs5n5nHYwHJ6g/gBQyT62uFA5kbOMuq7Lw0kv/iyCD+71FQmAr7f4Css7QA5gJng0tyitIzrzHq21282/wU9/w702o/Wsk7o62zdya9NPrQnUHeQELmUVQYQmHVzV+r9GYa0qMXFN3JkwEr7Zb/Ty0cbDQMK70mjb3cKzd1vwQCT3A5NFa7dm3S0tIAaNiwIb//rr/BbN++neBgx20ABBUItU/LOefsyuSbtm9wqRmoQV6/6V1WbvVV+8/x4O+BLL7ajq1yIm01RxyGuByhKLbbTuiRILIW2nqdmNw3kZs1qVQrRW+Q6eSaLLe3GQoqCq7GVQJ9Og79dVVQNs9CsTCMTfumGYQxOx99F0nybehweuCnZu1JVHNuv3loxtD000mwNl2JZkTheN7SPWLzczD9nks4bqBbKXDqTUbvTRZhMkEp4bJH6J577mHt2rW0a9eOMWPGMGjQID777DNOnz7NM88844sxCvwRtV3YDesVJ9PqTm5i6rd/ciSvilk5tiq14tBouP8LfR5K6q9WZflXQ+P4JWsAUFLJZarO7CqSVGIMmYeXzBs+9m4eT9PEM3DU7UM5xbLaKZ0YphYOZrWchAaZTMKZUTiAGCmLAV1b0zjwIgHr3kSrwuDQoeFU46E0OLIQd/xI9g5h2jV+TX5bbtakEmtSmu8LJPR6Q6O0y/lIdy+Aem/j7y/D1jkloRlD008b3kwDh5qO5q497Y3fY1PFcUstJsN1mtw3sXInSqv1JrsreikQuIjLhtBbb71l/PdDDz3Eddddx5YtW7j++uvp27evVwcn8GMMT8t2b2jF5cx1O5Ys0mjRNuhCx/7X83WxeJkBGQ2vFQ5hbuDMYl0YG7JmfT+Ehl3tutWD89KZEzCTz6XeRt0blzxNts7CxnyVHxZHwF0z0Ba77nVFRdQ8+bNHx7HE0vA5RzSLCrtxSok3m1xtlepf3bkGpAJ9FZijYxi1iEaT/E97furWilZ7p0Ke94wV075pnhilBtTmPD0WkMxcXX90aFz7DliGZgzeTDvSAFeCOyHvMZcEMFUcNyXOiSZNpSnddsWbLCgVKs13zw6qDaG6devSvXt3unfvTteuXalTpw4AHTp0oEOHDj4boMBPsNQKyr0EhfZqm809JpYYOqVbipftjejC3tYNrHWETHpUOXKrG363jwck8zjJxcKHg9zri2VBclFbjlCbLXIi264lErsijMmKPkT8zXeL+EZ7xf2d28Aw1KNNn+aVf6rbVHi2V6ofck39BKKgT/IFGLQpln9eOYR2ZqK+ca0XMXhHPEFW1FcUVpNy6BVxnFXZjUq8jVKGilwAG+X0DqQBkmTFYXsGgKiwQOY83Jr2DWPsTi6VSszPVW+ywKdUqu+eHVQLKk6ZMoV169axbds2CgoKqF+/Pt26deO2226ja9euxMXF+XqsZYIQVES9sq6B0Gi998ZJsqPdpxAvCDRCSR7NJ0V9jFVjznVlHHNZCefzot7M0fUHcK0qyQ2WSHfx4tWBxtemytWTihu9elIVZki47pz/ITIa+twUz+yW/+dVEUHQCwlul5uyOWQcNcmwLXZYvMje+ZxVYphWOIg3Az+lmpRreyUT5Fue46hSm/NKFDGabJpuGONQMNIS3ZBf0Dbo4nQ9T9sz2Gs7UmHbOxjV5m1Xklq2ZRH4jor+3fOZsnR+fj6bNm3i77//NhpGhYWFNG7cmO7duzNnzhyPB++IOXPm8M4775Cenk6LFi346KOPSEqyVvcFWLBgAV999RX79+8HoE2bNrz55pt217dFpTeE3FHWjUiAZ/Z7fBOzaSgdWKaul1Qxhol+WuEgXg382uXmrfaMpWwlhEICfF4un6mE0Sr/E0Bfnv9YQLJPkrINqtsScPj1OwhaOwm2fOR0O2fGpOH631JsaP3Y7SKttozD1vdJKf6P6f4MXqD3i+5njq4/MhrGaJfxbOAyl84vPyyOLzLb0i9gEwnSZVXbTAp4ho79n1I1Ebj7VO2s7Yih4efGF7pXrFCF8b4CNs1HUTXmcyrDd6/UWmxcvnyZ9957j48++oicnBx0Ot9l+n/33XcMGTKE+fPn065dO2bOnMn333/P4cOHqVmzptX6AwcOpFOnTnTs2JGQkBBmzJjBTz/9xIEDB6hVq5aqY1ZqQ8hJnzCHDF3pUaKjvYnlw3bZJK0f6vL+BhS8QorclCRNKv2DdjAA56XujiZ5W94LX7TRAHiv8D6GBaz2qdFl2oft05vP0mPfcx7v0+CRG1E4nn8iupQYBb+/CptnWa1v3f6iZD+mXisNMjuCn6YaOaqvt4KEoihcIVz1dRxQ8Arb5ETVT8Xu5FmoaTsCsPiJ9hVP8VhFWxaB76gM3z2ftdgoKChgy5YtrFu3zugRqlWrFvfffz+33nqr8x14wPvvv88TTzzBsGHDAJg/fz6//vorn3/+OS+++KLV+osWLTJ7/emnn7Js2TLWrl3LkCFDrNYXWOCJsq4HiY623LUaZOpm72LRHxk0DIygmh0BQXvU5EpJEmsBDAhybgg5mmRtvWeoMvO2MfRMwDKvqm3b4gL6m4QGmZtTZ3hlnxlE8krhYzTrNpC5t11fEvbc/4PN9R1VnxkSrrfKichomFj4OPMCZ6oOdRlCcdVwbgRZih+qbYnhTnsGtcKKFVKAUUVbFoHvqNTfPQtUG0Kvvfaa0fCpW7cuXbp04cknn2TRokUkJCT4coyA3gDbuXMnEydONC7TaDT06NGDLVu2qNpHXl4ehYWFREfb1/DIz88nPz/f+Dory3u9nModnlRtuJnoqJMVpv5y0MwIstfE1BWjwzRR11mpvqUgnivYGo+nxlFpeqWTNKlULbzglX1NKxxEspzE6rX/0jQ+Qu9V8cC4Nq06Wy0nMaJwvP57obIth9rPQELfksWQnG5oieGLp2K1wooVVoDR0JZFUOpU+u+eCaoNoSlTpnDdddfx3nvv8cADDxATU7qusosXL6LT6YiNNZ9gY2NjSU1NVbWPF154gYSEBHr06GF3nenTpzN16lSPxlphcMuYsVE27wIpJzLMwmH2KqPUYujQHksG7TUHjdVXUwuHMC9wpl0VYG/ii3CZtzFo7fTQ7PDaPs+ZCAsavSoeGNd5wdXNmrBaava0DEnnMdm2t8kVFODJgJXsVhqxWtbnE9p9KnaU2K+CpPrRDqvODHkalVqAUeATxHevBNXK0r/99hsDBgxg4cKFJCQkcOONNzJmzBh++OEHLlzwzhOkL3nrrbdYsmQJP/30EyEh9i3ciRMnkpmZafw7c+ZMKY7Sz1CprFuC47J5hxQ3Xzy78Svaaw6iQUaDbL8DvOTcwFCKE22rS/reWEuCXmdj8Fh6aVKMHgVbKsAjC8dyVon2iVFkGJdj1erS5zxR9NKk8JjW8zYhsqKv8DKElhRKvCopF1yOxgMS+WHx/Hm1kfWxisOdK+SO/H6tqWcDL8bwXZsc+LVRodrmU/HBFfocui/76BP4v+yjf31whepjaTUSk/vqNYcsv85GAcY+TdCe2igakwq8iqrvXiUR/1R9V+rVqxe9evUCIDs7mw0bNvD333/z9ttvM3DgQBo1akS3bt2YPXu2TwZavXp1tFot586ZP1GeO3fOaen+u+++y1tvvcUff/zBTTfd5HDd4OBg0SrEgAplXTNM9X5cwSRp8j7gviA4q0SzuKi7y1VephhydkwxtH0wtDywpQIMcH3RWSYE/OCTnB9f5RK5gyEfxrQnm2vY7x9nqXuUnnmVd7eG8b2DsKR1wrT+1d7mLyKvd/zcpkqdXCWmeUmnIlpbPxV7sVdW7+bxzBvYghUrlhGQe974PYytGsbc1v9HqzU9y6wxqT8J7fnTWCoK9jTdnIl/VjQ8qhrT6XSkpKSwYsUK5s6d6/OqsXbt2pGUlMRHH+nLemVZ5rrrrmP06NE2k6UB3n77bd544w1Wr15N+/btXT5mpa4aM+BMRyi0GrQbAV2ec90TZGdCMZRN+8JYMITLphUO4hzRZmKFtvKRKiqmVV2ZhLMk6HX1G9/6IsTeYPW9OKuUtP6wZHD761i09SSjtD/xTIC+/N0yLGn1mRdXEW0J7qSqwsU0lOqNOXJswWjufGS0+YTgtJrSRR0cG7+v/LA4Alo8gHbLbKwfQEqnxNyfhPb8aSwVkYpqZPqkfF6WZXbs2MFff/3FunXr2LRpE7m5udSuXZtu3brRrVs3hg51vbRZLd999x1Dhw7l448/JikpiZkzZ7J06VJSU1OJjY1lyJAh1KpVi+nTpwMwY8YMJk2axLfffkunTp2M+wkPDyc8PFzVMYUhVIysg/Xvwro3bbzpwo3ZNKcirDr8PMLuhOJJ0rIrnFX0XdIBm5Oov3hvvI1BefsKka6LQoZWg76zHPaPs8SZkXlWieG1woEM6taaznE6s5wbg+aJIwVntcdxhZQuX5LUvb/5QrWinhYSEjYnm9Rf7Oh0OfPAumZsuTrR+ZPQnj+NRVC+8Hr5/B133MHmzZvJzs4mISGBbt268cEHH9CtWzcaNGjglUE746GHHuLChQtMmjSJ9PR0WrZsSXJysjGB+vTp02g0JTfhefPmUVBQwP3332+2n8mTJzNlypRSGXOFYtdCO2/YaEtgCxcVqkvrgcQQLrtCuM3jlpUR5AsDzOB1Warrwgb5Jt4I/IIYKdv1HV29bAwBaRP72ewfZ4q9pHdbgolDG7QHiwotQz7DiG92WZkIlq9NQ54GBW57cgv2rrFSbGgkdbXRP9GNXlm2PBq1IgP5Q/s8oY66sNtFfWNSV70ptio3TUcloV5SwFP8aSyCiotqQygqKop33nmHbt26cf311/tyTA4ZPXo0o0ePtvneunXrzF6fPHnS9wOqDMg62Dbfs47R7ihUOz4aoD6N2xGGLum+Vol2FV8YYIa54qGA9TyorPf8GMXGr71cA9BrE00J/NJmqNNw7R8O+Iu5uv7EO6hSMT3Gucw8Y25XUZWa9OlzH9NWHTZ6jEwbn14rDLJZIWjwhVt7HiX998pe0r+LvbLseTTq5OwlNChd3b7s4cQos3fs9MxrjPhml01vimXlpiWmye++Ftrzp7EIKi6qDaHFixf7chwCf8XVPmO2bswOGqW6ixQUjqINgqveyeWpDA+T3vcwmRu/vZvH071pLNNWHuDrraeNa30QMJt4B20tDInJQ7XJRLUdw8p/ztoN3/RuHk9PKYWiX/9HcF6xEVEIrJ1PfOsXufev6lYeot/taA6lEcOKog70C9hstjw/LI69zV9EF9yJJFmx9jQYqimd9cqq29GhR8NUF8ltHBhl7npT/Eloz5/GIqi4uFPLKqgsuOPFsXVj9kSh2g5KQQ6pt3zEa2vT+CTwfSIkcSN0hqUR5DWjqNj4tRWCeVH7Lf20zpOcASYFfsPZjb+yuKg7a5V4vq5Sk3797qP3jbVLVjq4Au33Q9HaqNZqtWUcP3b7kJG7altVwNzT92n+UZ7gdRuVWfX6zCAh/AR7D6Xy8e48kjMa6CvU1m+1HUJyWE1pLiGRcuySXY+Gqcin6zjX63LXm+JPQnv+NBZBxUUYQgLbuOzFcXBj9kSh2gFRG6awXf6ABUV38kzAj16Z2O31uxI4IKw6KX8uZ9Uf26lLFOfQJ0wHUcATAb+6tKt4Lpc0VC2ESz+8w8m991Kv0wNQp52D76T+k2t1YAYbn/+HlFOZNhODe94wVp80nJXLq3n7aFLlEoez9jLtRB0+22ytkG83hJTYT18cYNUry1xCwpGnwv1yf3V6XZbH1iBbSUXIaKzW8yehPX8ai6DiIgwhgW1c8uI4uTG72W7D2RHjucTW4FFUdyfZ1wJD2MjWfFRRq8Y8R4LQaijLR5CUfZakIP3Ss0o0K4o68nDAWrSSa+FQy+scI2UTc/RLOPolSnAkUr6jljf6UJ32zBY6NLSdQKzVSHTI3wR/lRgwNwDVlGj+TzPEquzfYUKuil5ZjjwVpgrndg3wJndC2h6HxpY9TI9tq5LOUC1ZM8JcVsRZYjqUntCeP41F4JzyWobvcff5ik6lLZ/f94NeLVcNzjpGG3VXHORURMTDPfMh5xz5v/yPwILLqp6SS6vE3t+4qESyoqg99wVsIIKrpX4NFCRjI1PLSdxwR1Eoo8/mvs/gxvttv1cc7lX0dWFGTDWVbGkggXtduJ2V/UvAa2FLGSQvt+OJlOCBhRAW43IbD8OxW2SvZ64NWQjDOe9u/yFt7njUant/0u7xp7EIbOOPn5FXdYRcaTxa0YyFSmsIqdVK6fUmtHva+Y3ZmG8ENp/rTDSIDv+1iOvXjayUBo49LEUgq5HNq4Ffl5nwY15ILGFSod1k9TL1olno9xgpNsiVrLM2jQ6Dynbn/A9taiF9OKAld7es5fJwDJVbYP3N1yCzv9pzhF61Vz3mojij5bH3/R83/XCLwwbD6cTwz/3rzXOxivGnJ3x/GovAHH/VelI7f6vqNRYVFUW1atVU/QkqCE77jEl6T5AaIwhKcioiLX4MkQlWQozHYrozumgsOkXc5KDEw/Jy4WP8LHemKjnMCfyQOJVd153t1xVmFfZnQMErnOj8nsOKvTIzgiJr2U8gLg732huaRoIESd9WwxbuJuQayv7jqppvH1c1hMW36xwYQWBWmefOscNPkCDZz0EynPOKFcvQ2Wiup9VIdGgYw90ta9GhYUyZGh7+NBZBCc6qE0EfWrb1/fIXVOUI/fXXX8Z/nzx5khdffJFHH32UDh06ALBlyxa+/PJLo6KzoALgQmWMauzkVOjQkHLsEuezr3HyYi4f/PEv0B5FkZgb+KH+iOVI6dnb41OAT4ruZLWc5LARratj0KE+SdDgOZipu5/YqmEUZB5XuWXpYAzPNb/P/ndSZdK+ZVm7NxJyezePp2dinLVH48AydTtwt+BA5XYBueeFFo/ALSqC1pOq++Ctt95q/Pdrr73G+++/z8MPP2xc1q9fP2688UY++eQTn7bYEJQyKitj7GLaTsM0t8EkbGErrmzgN7kdT9vQf8mQIonBebi2rAymXEJQFAjnmm3VYgWyCWFS4aO8GrjIruqxAY0ETwWsAjSsU1p6FA4zVXL+RNeHgdo/6KzZRxvNv1SV8uxuAyWNVJvXimTGpissCXJ7GF7HePn2L4MeUzxK2jcta/dmQq7Bo+HOmNwuOHDhnIUWj8AdKoLWk8tVY1u2bGH+/PlWy9u2bcvjjz/ulUEJ/AgVlTE2sSXEaNE1215c2RRbHeI7db2D+zb1IZ7Ldg0dRQEZyVpvphR4onACkeTpW0oo1t4sBVhQdBcyASws6sUzAT+oSvp+KmAlgUWFqsZg6HCvIKExqdxKR98UtUpwAH8rzxLHJeN7GUQgRTegWs5xKMi22saQRLzm4Hk0OC79ttu6wolx6rHx6kjdvDjcq2SlGRO9TTF4vVLkpsZlPu/C7YI4o7v7zw+LIzA33WGOUIrclHFCi0fgBhVB68llQ6hOnTosWLCAt99+22z5p59+Sp06dbw2MIEfYOnRueEe9d20bQkxZqUZ+1Ppmva1G1e2GoZJuwSAh2tWI/eGQUgHP7K7jSSh2ggy5Mp46j0yTCrb5aa01Rzhc11v+ms3Up2S1h2Xi/uZGbVygAwlnEB0RHDV7r4NY7s/YIPq8ejlABReKxzERSXKqB3TU7ODd+V3i1cqWb8a2UgZe0vGqoTzeVFvYw8ws3M1Kf1W27rC4Fl6v/A+TiuxxEhZZCjhxAXkkV5UhY6aA/TU7qQauarP0Sb2wkHF4V5p6RCzqjfTsRm8XsM71aNHYpzvE3J9EYK22H/AXW8jfT/E7ufxWuFgYquGCS0egVtUBK0nlw2hDz74gPvuu4/ffvuNdu3aAZCSksK///7LsmUq490C/0eFR8cmDoUYS5qzpgS2dxhXdkTNiBCub9YSDrq1uc1RXSGcaNzvNWaYVFYUdWB98Hiz8NUlJYKfijqTSRWeCfjBatsoF45bVcrjohJBtJNwmuX+LxaHexzlGFnurio5PBPwA0eU2jZLyle72LrC0rNkoFeRtcbNVSWQEArdM04dhYOKw72SxXfbMLZ/Irowv7TLfT0NQTtBe8Pd7P6/WcRunmL1ebxW/HnMcxT6sxfiFgioGFpPbukInTlzhnnz5pGaqq+uaNasGU8//XSF9AhVyvJ5u601rEvdrVBZdr+x00IGrXUtycTwZLHxhe5oT21UV96vgvcK72OO7h5jt/IYKYtqUjZjAn5WvQ+DiOCTASsB20/eVwinGjluhYxM2a1rSAvNMavjqOGSEuFSt3lnJeVgX7HY3nJTTLvS27pmuYQSIZV4ynSKhAbFzrVyodS8eHKXs9M5lB3G0bAbqRlZRb0HSKVx4FLJt48NjuR9/8cKGy1GHIb+3H0g8hRhfJU7KryOUGWmQhtCtm42UCx+aE9V2slko1KI8Ujnmdz+R02Xhzz3kVZUqxLM+axceq/pSVDeOQf5HtGAQhy2xRkN63TOn2U1QWuQ2Rg8VnUOzCUlnGCKqGInQboshB9thfzczcGZVdSfzXJzM2NGjaHzVJf6fLz+hM19OrvGhs/n2cKnqUEWdaV0JhR71Oyew4Nf+3aCBr1x8Nv/IDutZFlEPNzxttmx/XFicMkw8+SByBPKyvgSeIy/aT351BDasGEDH3/8McePH+f777+nVq1afP3119SvX5/OnTt7NHB/o8IaQvuXw6oJkFeSLEtkArR+FNa96Xx7e6J1Kj1ChYN+ocln2bgiLREWpCUyJJD0LP3E0kuTwvygmWAn32NU4TgaSf8xIeAHK5VjNUrC9rwV3sopsoWjfdsyYmy5oX2JoS0DYKNlQzUWF3XnlBJPUVgN+t19Pz1vqEWb19dwJc88yVuDzKPaZCYFfuP0mAMKXiFFburYMAWkoAj433EI8GE528EVsHSw/feLDTF/FZhTjVEN3s0HIncpK+NLUCHxqqCiKcuWLaNXr16Ehoaya9cu8vPzAcjMzOTNN1VMoIKy5/dX4Yeh5kYQ6G96aowgsJ+QqlKIcYfS1CUjCCCvQMf5rDzaaw7ST7OZTMIZWTCONMVcyDOdGD4p6sOrgV/zbOAPSJK1NyadaD4oup9gimivOYgGGdBP0Kb7H104hstEWJ+Fj6wOSbK/b1vLJZO/0iCODOYHzmRe4EwrQUdDw9RZQbOZWzSZ3mt6cvTvb62MoF6aFDYGj1VlBIFe16ed5qBDYUAJ9JVu7zfTT6a+QNbBL2Mdr/PLOHRFRQ4F5hT8X2DOea9Bz4QebeI0vxBIflG/nkDgRVxOln799deZP38+Q4YMYcmSJcblnTp14vXXX/fq4AQ+4MBy2DzL8/3YS0hVWQVzPlddGbgp9hpHTiscRGFQNGEFFzlPFFFkMTfQ+hwN885KXXvaag/zbOAPZvtZUdRRn+Brsn+dAlrLpGL/zfnzOZrisnwJ6+tgdV2y0mj89yh6acYZvW6mXja11JXSmBrwhap1lbyLSMWViV73HJzYAFcvO17nagapW38jLdPxM6a/C8ypFnC0tZ67+T2uGF/1b/G7MIwvqAzn6A+4bAgdPnyYLl26WC2vWrUqV65c8caYBL5C1sGvz3q4ExW6JiqqYGoeu2R/exvYm0DjyGBO4CxGFIxnhdzRmHcC1l4gwyTeV7vV6pkzjgyeKk50NsXSCHKXitQcVr0hqK8SnBz4NWvy2wKoUsU2ICv6BPNnApapdnnpTW8F6Zdxev0rb4ZtTm1UtZr21Hraa2o6zJ0CjCFev8RdoUdP8ntcML78Mf/K21SGc/QXXDaE4uLiOHr0KPXq1TNbvnHjRho0aOCtcQl8wanNkHfRhQ080DVpehcER+onDwV9PlG9zsbtnGlPmOKo5Fsj6SfMyYFfs4V2JBamOlReNkzilvOqRrLuou4tDGrOeUqgvlFpJUJCMevf5YoqtiRBlUAtUqFrn4sE+j5o69+Fri+4NF6HqIxkNTi+iCVBJVpIhrwqy1y0jJx8743N27gj9KhCP8yhMaTS+Eq5EMCI363zr9IzrzHim13+n3+lAns5ZhXpHP0Jl3OEnnjiCcaNG8e2bduQJImzZ8+yaNEinnvuOUaMGOGLMQq8hSv9irq+pKpBqk0OrtAnWn59N6x/Bza8A8ufhtRfjasYtCfA+SSXpElV1Thy0o2ZVn2iXMFXDhtDGKmyGUGmxJLh8mcjNbub4MJM9z+XbfM8yyeRdfpw2L4f9P+v20nVZoE6c0HIODKYFziTXpoUs+XRVayTunWywpZjl/h5z39sOXap7PKIDCFuwPqXYeOByBv5PSryC5XIWjyzNaxcN/h0RkVoYlrecNkj9OKLLyLLMrfddht5eXl06dKF4OBgnnvuOcaMGeOLMQq8hVp3d1h16PKc/u/kRv0kIAF1O9uuFDPFhadCQ1duS/evwctj4PrQHH2HUCfc20hDflEzsN08XFCGTAr8moVFvVzbqEZjOOTBQa9ett9uwxm2QjwR8RQFVEFblOvQOLPlbTR4LdfktzWGyeKqhpqt53ehEFeEHl3M77GJivzCI61e5r/V9h8oykODT2dUhCam5Q2XDSFJknj55Zd5/vnnOXr0KDk5OSQmJhIeHu6L8Qm8idHd7eiGBdz5nv6mZDUZvOM43q9SVdo0d8NWV+42daux89TlkgRBKQK+mun09DS/T2Tgne9z9VQcwXm2eyuVBZU5udpANbJ5JuAHMpRwoshx8tkYwi6dgXc8O7DBC+pKAq8dY17JTkdTrG+g4Jo+k0aCBPQhwq1yIvEWLQf8NhSittegJ8nVlsdzYHylFrQB9jg9jD83+HRGRWhiWt5w2RB67LHH+PDDD4mIiCAxsaT/U25uLmPGjOHzzz/36gAFXsTsicuOW7XjWGje3714v5tPhba6cpu+1hV15Bwx1FAuOZxAlbxLSD88SmjHMSibP0JWFL8xhio7ll4+p/lYvd+Ca1eM3z63P8bwWPuaWbYMegfGvISCgr5fXD5BxJvIB1yhiqoeaTW5goR5ywFnoRAJfSikZ2Jc2VQMabTOvWruJlfbwoHxpbbIwp8bfDqjIjQxLW+4nCP05ZdfcvWqdXPIq1ev8tVXX3llUAIfYnjiikwwXx5WHR74Em6f5n6839OS2+J8DN3x9Wz597wxT2LriStMKtCL2DkKixuniP3LkO//gmxJeCn9CY0E0VIOHxTdR0FYnM11lMhaHL51Dj/ntyT75+dB8cAIiqwFR1bb18xaOsRac8iJMW84hwmFTzOg4BXGFoxmQMErjCwcp2pIRVVqWnl3XAmF+C0q9cMcVpuaYjC+brxf/3+LIgsHR7HytpU3KsM5+huqPUJZWVkoioKiKGRnZxMSUmKN6nQ6Vq1aRc2arrdMEJQBztzdbnp2Ui4EYFuj2QInJbdaoK4SzcLCIayR29I95ChhFPFB0X08GrCaGIdNSvVj01apzuFbPiJpwzA1IxKUIqeVWHbcvZ5OQUf0bSpyL0CVGqRcDOKZrWH8t7qQ9prvuDvovGcZ7Df0hy0fOVhBsQrVqjXma5DFCrlkUtcgc1aJJl66bLPli4JEQVgcH00YhTbA/LbraijEL7VlVOqHeSpnUFYNPkvzmleEJqblDdWGUFRUFJIkIUkSjRs3tnpfkiSmTp3q1cEJfIgjd7cbnp3k/WmM+l3LhuBou20QXCm5NVTaGLvCFxfYXFaqqB5bUrd7uLojjuCr6TZdn6723XK3T5fAnFcDv+b4sSZw56PGZcn704pLovWJsJ5U/xnZ9bXzdSwNepUhnvNEmb2W0TC1cAjzgz60ub6EQnDLByDA+pbrSijEKwnVvmpo6kpytQfYK7KI81FieVkksZf2OVZ2VBtCf/31F4qi0L17d5YtW0Z0dIlbLigoiLp165KQkOBgD4Jyg4vxfkOOg654MpgXONNKQFCmuIxcZcmtQfywmoX3J0pFHoZxbBotoX3fQVk6pDjXwvw4aoyai0oky4s6kUmYXthPGEMeE002MSnjoV40JPazmSNjaWi4RX6WuvVMDX8n+jn6RrAxpMhNzZZLwD8RXZBb69Da80Jt/ghq32xlEDjT1JLQT4CXcwsY9a2HCdUqG8a6jdrkag+xVWThCy9NWSaxl9Y5ClwwhG699VYATpw4wXXXXYckZoPyg6tPgC6KqZnmOKyWkxhROF7fCsMkmTRdiSG76zSauFBya7O3VvEy+94ZC69TYj+kB7/S94hy1h7BBgVo2a40YbWcxBGlDu8EzicSUa3hCQbxSkNYKuXEFc5l5tHepJP9DrkxZxVH3kUvEh5rFvpo2uoVGv89CskiMGH412uFg82Uoo3hij5N0K4Z7fhYlqE41IVCXr2rGdN+9SChWtbpBSZt9RLMTtM3ki1uGOsxapKrywH+kMRuq5BE4H1crhr7888/CQ8P54EHHjBb/v3335OXl8fQoUO9NjiBF3BH8t7FeL9ljsNqOYk1+W1JMpnYUuSmfFCtNU1M1tt7KJUWbp6WJFkbQ0rx1EXP12HbfLh8EqrVg4h4lKtXTEevmjguMy9wJqMKx3GZCH7S3cLQgDVOt7Mam/AkmSGZ5JlpDx9jY/BUqx5yK4o68mTASivvYnEFu93rKStwRYokGuceoYKAcA4dOsjH3+7i9+x6tNUcoSZXaB7yEAO0a4ksvGBcN02J4V3NMLaGtAOTRrLGcEWVo25r6TgLhVQNDXJfW8bWPcAWvmhL4iNKI1wl9HwqDy4bQtOnT+fjjz+2Wl6zZk2efPJJYQj5E3ZL4M/qnwC7vqQXTbR143Mh3m8rx0FGw1Y50WyZ6XrJ+9NYuPEKS6zFdd3mamgsYde1hh+HgyIbl3tSgm0I0X0UOIsASb2Sq9OGpCopDwaUR61JDq/i5pR5xYXpJcSRwZMBK/mkqI++Ea6JdzGNGH4pas+TAXqlctPrY6gqfLngUV4N/IZ4MmxeP4MxFVSUQ4uU/zEX0AVLaA2fsQxpumgWFN3PKSXOaMwraNCQz7ttc6gXkk1otVo0bXerPgF63yZ152wnB880FJKedY2MnHyiqwRRNTRIdV8yq8Rre/cAW1zN0FduNuyq6lhlRWmFq4SeT+XBZUPo9OnT1K9f32p53bp1OX36tFcGJfACDkvgi1n3JuxaaN87pDLebyvHQYNs5hE6E97CWO5pcDmfk5t6FP4wTHCzCvuzWWnOe83SCTv0qfV6ru/a6jgBluJ6KgwUbxgxjrb3FyPJoyH8sxSw1nsy6A71C9hCl/yZRk+NwSDpqdnBZcKJlsxzyK4QzhdFvQhEZnFRdyYE/KD6OmksPuNYMngm4AdGFI43GvW9NCn6sO9+k1L2bcUeVi9o6Wg1EplXC3g7OdXMGxFdJVDVrs0eStTcAyw5tdGvDaHSDFcJPZ/Kg8s6QjVr1uSff/6xWr53715iYnzvHpwzZw716tUjJCSEdu3akZKS4nD977//nqZNmxISEsKNN97IqlWrfD5Gv8BpCXwx9vRUDNjR8zDFsm9YL00KG4PHsiTodWYFzWZJ0Ov8oR2DNvUXoMTlbKi0AWt9IEUpeWp3xlGlNseCEklILT0xTzUTq6+NlHSq8ZfuJt8exGdIeu2qvIt2DSlDD7m2miNI9TqxQu7IVjmRnpodzAucSZRFIr0huf7ZwGXMCprNs4E/2NyvvdCa5WvDPDo58Gs0yPTSpDAvcCZxWOj5GERG8y451NJRVGjpGLwdliGZjFzHfepsasuovQeYD9KvKU3NJaHnU3lw2RB6+OGHGTt2LH/99Rc6nQ6dTseff/7JuHHjGDBggC/GaOS7775jwoQJTJ48mV27dtGiRQt69erF+fPnba6/efNmHn74YYYPH87u3bvp378//fv3Z//+/T4dp1/gSoNVcN4Q0QmGHIeHwvfYnCxCr54zGlymrmRDcnU65jeTy6gXQzxPFA+yGskkHFYZCOMq3bTWDyXlAwVuelDVmi90imJAUl1A72mcHKgXbrV84LdneNoyeNQaqQZjrJ3moN3jGq2H1S/B7dOLl5ivJCugoLCz2f/s5uA48naYjd/OayttGVfvAaAqybksG8OWZrjKUWNooedTsXDZEJo2bRrt2rXjtttuIzQ0lNDQUG6//Xa6d+/Om2/aqEjwIu+//z5PPPEEw4YNIzExkfnz5xMWFma3rceHH35I7969ef7552nWrBnTpk2jdevWzJ4926fj9AvUuukBsyROD+idWJPpYd8gSQ4mi+QXqWnh5l8tJ9E5f5aZUm/b/PmsaPImimT/KyorcFkJR0KmZpGLT74VgPJcvXa6xXh0je9Qte6CPXmsOaif1JM0qSRI9kOp3srNsqSD5qDD4xp/Q1Vi2N3hQ9KUambvphPDiILx3Pd3DaavOmhzD868HQaqWXStj6saYjsvxqV7ABAaDfU6O1wleX8anWf8ycMLtjJuyR4eXrCVzjP+JHl/msPtvEVph6sMD3hxVc33Z/eaC8olLucIBQUF8d133zFt2jT27t1LaGgoN954I3Xr1vXF+IwUFBSwc+dOJk6caFym0Wjo0aMHW7ZssbnNli1bmDBhgtmyXr16sXz5crvHyc/PJz8/3/g6K0ulFom/4bQE3gbuPEGacmozkoqqGen0ZsDcGJLRkCI3NeYV9Y44Tp8HRyGl1kL5YSiKjcohjaQPhSwOepMcxYtZ1+UEVyd5y+qrsuS97QWE7f+bN9CgwbYnz6DZk5zdAPkf/UTrFaFFd1D5E5Kz0xm5qzbn8meZ5cjtkBvTVnOEfprN7N14kFW1IrmzRW2zbdV6MYp05tdLsRdDdvUe0PdDhxVj/tAYVq3mkjfDVULPp+LjsiFkoHHjxjYVpn3FxYsX0el0xMaaP+XExsaSmppqc5v09HSb66enp9s9zvTp0yuGQrZZCbxKXH2CtESlIbVqyx7gZqAkqbqHZjsPaNdTVSruY1cIfDgP2gwjrelQqhxaSlWse9wZhy4VeDb2CohlkvAVwolSnHV+d74fte85oqNmPw8Urde/cFDVNa1wEEmaVGLJIEbKohrZrh/MAwzG2BYlkbEsd7r+oeywYq+OxizBen3weDN5gHM/zUMX8AHaG+42LlPrxci6VmT2+lxWvm1DxKEMhgmRtZwqP/uDpg6UXfsJoedTsVFlCE2YMIFp06ZRpUoVKw+LJe+//75XBlZWTJw40ewcs7KyqFOnThmOyAMMJfCWSrJW2Gh94Q4qDakjefo2GcYKHMlOYmN2Gqx7k4TiIRpwNvn6SzWVM3w9Tst9W6p0u4K3x3q7dgdg30OlQ8NnRXfwauDXNr8fno7HVsm/tS6V/vXUgsFskxP1FY5Shp18Av1v6GjYjcA+41JDgrUlNZRLSN8PBekrowHizNvh7FxsGiL2ZDDCqutztJrcqUr52Z80dUT7CYG3UWUI7d69m8LCQuO/7eFLtenq1auj1Wo5d87c63Du3Dni4mx3so6Li3NpfYDg4GCCg4M9H7C/YCiBt6cq68WGiNRpB5LGTMPHEhkNO+TGxgnCnW+Ms6+Z5ftqS93V7NublIWx5s4xbW1zTQkkGMeVTI6oJuU5fD9Ako06QfbwxBiSgMKAKgQWmbRs0Zh/d6XIWuh6TefRkM7cmX2N7MuvE//3KMPRLfYG9H6LmsElvfAcJXZbqmuj0Zp5O1zFoSHihbYXpZakrFIFX4SrBN5ElSH0119/2fx3aRIUFESbNm1Yu3Yt/fv3B0CWZdauXcvo0bZl7Tt06MDatWsZP368cdmaNWvo0KFDKYzYj9BooesLULOZbxsintnm0AgC/eRwsybVOEH42hi4qmgJwXE1XHnxIHmKt85RViCYQrf2pyj6iiqNSnFKR5VgauUV7PF83lAe6dGOpBpFEB6LVKed/jtsMglrNVpK7hYDITbC4W8oSVaIrhJIRm6hMbHb7rnZUJo2eDte+mmf05J5W9g1RDxse1EqScouquCLcFXZYtqWprwbom7nCJUFEyZMYOjQobRt25akpCRmzpxJbm4uw4YNA2DIkCHUqlWL6dP1Jazjxo3j1ltv5b333uOuu+5iyZIl7Nixg08++aQsT6Ps8HVDRJU5Qj1Dj5Cg81znQw2hknNJgKsEEuaBd6Oy4cm9TpKsm986WteT952RTjTjtkWw8YXuJTdwZ8aCk9+QViPxWt8bGL1kj/rEbovfTe/m8VwtlHnmuz2unRC+E/fzeZKyXRX8Yo2mB7/yWvd6geeURouT0kSVIXTvvfeq3uGPP/7o9mCc8dBDD3HhwgUmTZpEeno6LVu2JDk52ZgQffr0aTSakgh+x44d+fbbb3nllVd46aWXuP7661m+fDnNmzf32Rj9Hl82RFSZI9Tl+upgO7+9TFgv30Rv7c6yHkalwhcJ2Gox7SAvu5PX4uA3lLw/jTd+03+560oqS8pt/G7iIm0bNJaK7SlyU2Q0PqmWMsWnScoOFbCLM6BsNKv1NyqSh8QR/lA96G1UGUJVq1Y1/ltRFH766SeqVq1K27ZtAdi5cydXrlxxyWByl9GjR9sNha1bt85q2QMPPGDVILbMcbUbfHlBZdf6RjffAanzfToUWYEMIqkuOZc/SJGblktDqCzymryFozF783wsJQMM2n9TTTrIe6tXlOkE0UuTwjMBy5wYdfaLFGx5YGwVF5xVonmtcAir5SSfi/sZwnbTVuyjTs5es/Y5r/a70f3Jz6kCtv1mtf5CRfOQ2MNfqge9jSpD6IsvvjD++4UXXuDBBx9k/vz5aLX6yVun0zFy5EgiIyN9M8qKhDvd4MsLarvW178FIhNQstJUh0kscTTBGCa7SYVD+ShwNhoUu403ZSS+1d3G6ICfqUaO3fW8NTm7ui9765dnI0gN1wIiCS7Kdvj9cHwNJAqDo7hwDRK4bFyaTgxTCwezWk4yLnMpnGTnIcZ0gjBNknb6+dgpUrD0wNxup/osjgzmBc1kT4dZtCqFCbe3Zju9Ql5AKii5fykhCUiaGYCb9y+1+mWe6pz5iIroIbGHP1UPehOXlaU///xznnvuOaMRBKDVapkwYYJdhWdBMYY4uOXTjyEObq/fV3nCUK4bafHDj0woifMXG0zuzuFK8d97hffzaVFvLioRZu+nE8OIwvFkUBWtZNsIAv0kpZUUNgWPY2lRV/2+bcy73jQ2XN1XaXlO/I2QzqNVfz+sOzzot9T0+5AHgj8xUyzvnP+h0QhyuVfUwRUwszl82QeWDdf/f2ZzOLjCbIJwpn5tpOtEhw8/Bg9MQmSgw+ozkGh1YIZHLXJUUXz/shRNlTy9f3mhWW1Z4cxDAnoPSWm2IfElpdnipDRxOVm6qKiI1NRUmjRpYrY8NTUVWa5cvZ5cooLEwVWhJinbnr6JCtIU86f6N4sG2cyb6KdR1zIkmmyeDFjJx0V9uDtgM/GWTTXdxBe5Lp5WStnaX2kZVIoCl6lCPsHEYttQkBXID6pGaHR9vaGw8wu7GliGyjEZybxzfHEVlzaxH68qaYz4Rp8Ib/DWtNccNH5XOrbtq27wTpJ5tUkzgRqAC+rX5w7o7wsOfu+9m8fTM+xftF85rz47sCWZph3u9E1Iwpf3L5UhdY91znxARfWQ2KO0W5yUFi4bQsOGDWP48OEcO3aMpCT9RLRt2zbeeustY/WWwAYVIA7uEmqSsk0Npuw0yD4HG96Fa1fsbnItKJouWR8go6GDZj8dpIMgwRY5kZVye2PeB+ibsapBKo7iPRiwjqT8udysSaWj5gDDtb8R5qZiteEB8Jei9vTRbgW8196iPHqCDAbcxMInAJgXONMqf0dR9F6a0MLL8KN+PcIcTx6SBAEofKAdxri7O6GJiDMzuk3F927KXm+dY7NxLi9ve5yu/R+zH75QYQS02P8WGt5BRqP6e8ehn+GdRvrWFg48Q9pc202lLfn4181sX++jvBRf3r/UhtR98IDoaYJzRfWQ2KMsWpyUBi4bQu+++y5xcXG89957pKXpn9Ti4+N5/vnnefbZZ70+wApDOY+Dew1ZByc3wokN+l9N3c76G6dGq1/mwAgCCCnIYIT2Z4YFrCZaKlFKHstyMpRwXip8jCtEUpMrXCKCS0oVoslVVYodTQ7vBczlZu0Rh/ovalDQ8GnRHfQN0PfB81cjqDSNKsONc7WcxIjC8XqjxML7ZqX4nHdJ1b77Xh+Mpvm99sX3pBQ038+08qjFkcGbhW8z8tsCeORp2waECiMgOC+N3hHH+S27ESlyU70KtR2vlxlXM5yXh6sMCZ0nynd5Kb6+f9nzEHtT58wCbyQ4V1QPiT3KqsWJr5EUux37nGNoSFqRk6SzsrKoWrUqmZmZnp3niQ36nAJnDF1ZMTxCtji4An4Zp7/5mxJaDfrOAl2BPvfCCUrxf2wpSIOHrReU4hCKh79judi7UR69N77CULbeOf9D5OJmq4Y+Yq8Gfk002Z5dd3tFB7IOZWZzlKyzNpMiDeN6IHg+61/saX0T3/eDqu/lyUZD6ba/F1CS3Kz6fCJrwfh9tr0esk6fi2QndGR5XQ1P5Wb6SJ5SWvevUqqotZfgbLhaag1JnazQecafTj0kXv0s/IDyUiWndv52OVka9HlCf/zxB4sXLza21Th79iw5Oe73MqrwGOLgdlNAJf3N0A/j4F7h4ApYOtjaCAK4eln/3qVjqndny8DwhtEhSd7x3lSge57X0EiQIF3iUW0y/TSbSdKkkiI35RzRVJc8NILAftHBqc1Idowg03HVydlLygkb30+VHpl6R7/kx24Xiasawmo5ic91vV0Ye3FYyeYAi0NHgOX9w5YcgGleitcorfuXIaR+4/0lnmIv480EZ4OHBKyvTHn2kDijd/N4Nr7QncVPtOfDAS1Z/ER7Nr7Q3a+MIFdwOTR26tQpevfuzenTp8nPz6dnz55EREQwY8YM8vPzmT/ft/ow5ZYyjIO7hTefzIw5Fk7Y8YWTpEk9jm4p/uSB8aex+BOTAr8x/vusEs0qXZKDtUtwnthtJ2lXZbimJlds53IYk3mdJfXrq7c2Pv8PKacy0R0vgE3Jqo7tdJx2Qke25AAMOM1LceU3Xt7uXw7wdoJzZW0CW5FanLhsCI0bN462bduyd+9eYmJKLsI999zDE0884dXBVTjKIA7uFt7WOnKaY1FMThp0fQnWTcf2zbZilKB6SkXSEIojg8e06owFGXA+zdpI2nUhx8ZmLofRCBis6tjaM1vo0PAWqN8P9qkxoFA3zuLiggNbkvn4181mFZK2cJiX4s5vvAzuX75Qa/ZFgrNoAlu+cdkQ2rBhA5s3byYoKMhseb169fjvv/+8NrAKi6/7fXmKL3r+uJJAGdMQ3QNfUrTyeYKvmmwXEQ9tHoV1b7p27AqGwVvvrdtrWTec1Uj6c7KsILOFVnJhvKbfubodUSITnOYInQlvYb/aJbEftB8JW+eqP7ZKA0pW4LwUw56c+jgNpmm0NO1wJ9vXe1C548lvvBTvX+7moTgznnyV4FyRPCSVDZdzhGRZRqezFu76v//7PyIiImxsIbCiFOLgbuG0TFiBlc9AkYsl5S4IoaVcCODln/aTkWfeBPVqkQ5qNCE/NNbrWjr+gprzukI4uXinAsVfNN40LuRlqTbaTL9zGi1S7xlISFbnbHj9WuFgXu13o+Mn+CZ3un7sxH7w4Nf6ggAbGI4/pWAwIxbtJXm/8/5kHuWlOP2Now8tHlunTxI/scFaqLEU7l+GZGbLEJahKs7edUren0bnGX/y8IKtjFuyh4cXbKXzjD/N1jeUgDvIdnJNaFNQ7nHZELr99tuZOXOm8bUkSeTk5DB58mTuvFPljUJQOsg6/Y3M3g3NEjUhrLyL8H5T11RkjYmWjrkaEssXf+zizcK3ibUoqw7OO4fy/aOcrnWX3iTzk0ncmzib5GUFqpFDhHTNLS+O5TVLJ4ZfdO1c35G/YytpN7Ef0oNfkR8WZ7Y4nRheCvwf/e2VzpvibsJwYj94/hi6WyeSSbjV8UcUjie5OMdHbZKuIS8lrqq5URxXNcRxxZNaPaCv77ZSzy4t3E1mVms8VdYEZ4F9XC6fP3PmDL1790ZRFP7991/atm3Lv//+S/Xq1Vm/fj01a9b01VjLBK+Vz5c27uQAqCwT1iO5FiYzVI3ZwPAFfI4JPKsstKu/IgO64GoEXNP3jnLVGCjrMJA38PQcFAU+K7qDP5Q27JAbsz14JNWkClbt+eDX9r+Xsg7dyU0cO36M80oU2nqdSGpYQ/2kZwwrgc2EYQe/iS3HLjFwwWabKuimLH6iveoQi8s5NC79xg04PzdvsuXYJR5esNXpeqbXyVDGbi8J2lYZe3kpARe4j9r52+UcoTp16rB3716+++479u7dS05ODsOHD2fgwIGEhoZ6NGiBl3A3B8DVXj6uSOobQgQ2dIQuK+G8xpOkF4aREGS/5FcDaPIvI0tu6j64iCdGh68Smr2xv/sCNrC2sBU3a1L9wghSkx+kmltfdDxZa7RoG3ShcYMuNLYaiIoqKnsJw2ExcNOD+hCYnbYZ57OvIaNhq5zo8BRcSdJ1OS/FrX5dpdsCyJ1kZncqwUSCs8CAS4ZQYWEhTZs2ZeXKlQwcOJCBAwf6alwCd/GkJ5DTnj8W+3JVUj+xH8m61ny1eBHtNQdBgS1KItvkRJd6g7liBGUqoVSVrgIlvanUGhOeGB35BCIDYRQ6Xbc0kSR9eG1x0JvkKGWvdmuIbmQoVYgi16ZBpP4zk+AWN9XtXfGgmiYMH14F/3ynDxlvnav/s7Od15J0PZG2cOk3bor5790X1VwG3LlO7laCiQRnAbhoCAUGBnLtWsXomVJh8aQnkJlWiEpcqAjTyQpTVx4mTW7OZrm51fuqezSpwKDsHMFVs+WlFRqbV9SH8QE/+XU4rgrqfsv2zsEbXq90YlhR1IEHA9bZNYLUo8CZba4rG7vjQdVo9UKgW+ep3s4rfZo8lbZwqAekgpxzPg8puXOdKlurC4F3cTnCMGrUKGbMmEFRUZEvxiPwFE97Ahlc/2HV1e3HlYowJ+5rQ48me7miaidFgxEEZafwPDbgJ8B/jSBwzTNmee0NxpG755ethPBwwUt8oBnKU4ErHYboXDqGq72unHhQFSB/5f/4efdpthy7VJKgq7b6yqRAweMkXYPBZvmgY09R2x6G33ik60ZLyoUAt6q5XMGd6yQqwQSe4LIhtH37dn788Ueuu+46evXqxb333mv2Jyhj1BomjtZL7AcTDkGQEzmE0Gio0051ZZoz97WMhqmFem+UvTJnNeQQ5NEk7Q20Pjh+WVbKOTsXtWNTFP3f84VPsk1O5Bl5obHrvDvHtcLVHBgnHlSpuKHq4u+/My/FdsXzaoLb1V5uGF4OSewH4/fre4Pd9xkMWaHX6nJgSiiRtXhma5hXWlM4w9XrJCrBBJ7gcrJ0VFQU9913ny/GIvAGTnMAJP37znoCabSgdfL10BXArBaq3fRq3NL2OpOnE8NG3Q08GLDe6T5c/lKXEyQJdIqEBkWVYeILQzBHCaYK+Vb7NvUaOTvux0V9SJbb015zkATJW/2wVH6vLXGh/QaUeD6WdzlLCzf371aSrichb3sY9IAM3PG2wxYaR1q9zH+r7ee8udqawhmuXqfK2upC4DkuzxlffPGFL8Yh8Bbe6gl0arM+B8IRBTn6P1Mc5FU4i/0bupEHU8SzhU+jQSmeLC9yVq4OkronzVBcFHz0MxwZMZLKnA5fecPCpXy3j3lRieTVwmH8Juu1iwzGhed40OvKhfYbYCw34OPdeajQmLa7f5eTdD0NeavBSQuN1II2wB6nu3Gl6s0Zrl4nUQkmcAfVhpAsy7zzzjusWLGCgoICbrvtNiZPnixK5v0Rb/QEcvuGar8yzeC+HvHNLisTrbcmhUmBX5l5CHSKhNZg/Lgwv/nKCPBqmbcD0qhGuHKVcK5ZHc/QksKfb+uzCvtzVKnNBfS6HXWDcjlZEGGlmeO15HhPel058aAa2m+kyE2NyxQgObsB+dFxBOeds7md2x4qe3gj5K0GBy00ah67pGoXZZ2QLCrBBK6i2hB64403mDJlCj169CA0NJQPP/yQ8+fP8/nnn/tyfAJ38bQnkEc3VPtuelvu616aFOYFzbTai8bGBFOWDUczCKc6vtXdmVXYny1KIouD7PdUKw8Pt6ZigVvsOAgMyfH2BDQNn7WC+TkbUlA+1/VmV2hH+vW8j96Jtd0bqAMPquE4UwsHW4keymjY23wiSSnjrbbzSTd2b4W81WAZMivGK1VvAoEfojpZ+quvvmLu3LmsXr2a5cuX88svv7Bo0SJkWfbl+ASe4ElPIKftBFRgx6vUu3k8G1/ozuIn2vPhQzcyK2oJ2DiSLWPHsKw0E4cVBTKUcNrnz+W1wkE+PdYVwq3aizgaV2lzSYlwWtU3NnA5S4JeZ2PwWHppUgCICg1Ei0x7zUH6aTbrdaTAYXK8gj6fKB3zidXQluL1oiGsym6kukeXXexUURmOs7q4/YUluiZ9bVdfRSZ4X4XZYLABdtOBvWl42UAkJAsqKqpbbAQHB3P06FHq1KljXBYSEsLRo0epXdvNp7FyQLltseEN7LYTUMnQlXqDyp5XStbBtvmw+iWvDdnbGH4dTxdPiBpkUoJHUF3K9tkxzUKCPsYyH8lefpIhRDStcBBzAj8EzL00tjx1BuNmROF4+t6UQOtDb5mFPs8q0bxWbAhNCfqaOC6ZvBfD1MLBxmvuqC2FrfYJblEsVChnpzP6l7Oszm6AzsazotXxPBE4dBWbOkK13A8NuoFoTSEoL6idv1UbQlqtlvT0dGrUqGFcFhERwT///EP9+vU9H7GfUqkNIbB9441IgKJrxcnUDtz0vd6E1RNtV5WB9X79AEtD4KwSzdTCIayR2xon416aFO4KSCm1MVjirVwlW8aLM4NmtZxEL02KvqrPxKhxZEBlSuFEkQsoZp4EuXibPR1mcS7hNhYuXuywB5czXOnR5QxDA0+wGfRyXOrua0rT8LKDL5WlBQJv4XVDSKPRcMcddxAcHGxc9ssvv9C9e3eqVKliXPbjjz96MGz/o9IbQmD7xpv6q+Pmkx3HwOaPsDaU3FCzLQMuK1X4vKg3c3T30FOzw2riLysMRom3DCE1uVam3hkDBi9NR81+xgYsd38MSEiRCTB+H8kHz1t5Ghxh6Sl6+IGHuLvVdW6PxRLh+RAIyjdeN4SGDRum6sAVrbxeGEI2MBhGh1fBP0v1fZYMhFWH5vfD/u8hT12ViT9iMDg+KerDkwErAeehoNIgSwnl06I7GBDwF3Fc9mnitKzAB0X3MUd3DzIaY8WagfiqIcxvcZwWKc95frChK816WKVnXmXar4e4nFtg02y25ZXKD4sjuM87Xg0Rlbnnww+8PwJBecXrhlBlRRhCFtgKlYXFQO228H87zY0iD7HlsTD9tnrLCHEU1lFQJ2BY2mQrIYQX9wqzCm1J3imv1+cFRfNc4dNUJ4tHbrsZ5bqOnM8tLDEKTm2EL/t4frD7PtMn9ZtgLzzVS5PCvMCZgIVxiqQ/b28nKpcVnvYV84AyNwAFAi8gDCEvIQwhE+w1pyxFMpRwlhZ15cmAlR57Q0pLF6g0yVDCCaLQofChR1hOxLIOZjZ3o5u5BcUeIUssw1MaZDYGj7Vbcm/MTxu/r3x7Tuz+1opP2ofGnggJCioKwhDyEsIQKsY44ZVucvPson76pFkFtiiJbJMTkdHwSsBXPB6Q7PZ+DaKE/ubpcReluNx8ZOFYMgl3qEPk0XFseV2cGchB4VCQa+d954aLwTvxx8F0Tu/+nQXyFOcDtWNYlQuc/tZ8Z+wZvHB2zK+yTRIXCFxE7fztctPVsiIjI4OBAwcSGRlJVFQUw4cPJyfHvrhdRkYGY8aMoUmTJoSGhnLdddcxduxYMjMzS3HUFQinvY58wwDtXxyQ6/G+7kG2yM2NlUR/yG092m86MazQdfDGEP0CqTgcNinwG7bLTUknxqJGy0vHQdH3ZF/5DBQVtzJpehfccI/9jQpyKGlOYb43wKn+jUEp+NW+N/Bxf5VSHZ60mihr3Gzo6ik6WWHqLwdLpamqQOBPlBtDaODAgRw4cIA1a9awcuVK1q9fz5NPPml3/bNnz3L27Fneffdd9u/fz8KFC0lOTmb48OGlOOoKRBlNLNFkMy9wplGYz8AOuTGXlAiXRAUVBS4r4Txc8BJd8j8gSXu4TDu6extJggQpg7EBP7KosBuKovgkiCmBPhfsvSbw+6vwfiIccFQtKkFoNETEmS92Q3hQY7kPe3jaaqIsKY2+YjZIOZHhsGLPtKmqQFCRKBeNug8dOkRycjLbt2+nbVu9J+Cjjz7izjvv5N133yUhIcFqm+bNm7Ns2TLj64YNG/LGG28waNAgioqKCAgoF6fuP5TRxGKoVJoc+DVr8vWf/SjtTzwWkEw1KVf1fgwGzyuFQ1HQMFb7I/F+UA7vCwzl7FlKCJF4rwGmJcrVDKTNs9SsCVczYMgKkDSeVUCVZquJsqK0+opZoLZZqjebqgoE/kC5sAa2bNlCVFSU0QgC6NGjBxqNhm3btnHPPQ7c8iYY4oSOjKD8/Hzy80sSTbOystwfeEXCOAF5EB4LCi8Ok7imJaSRIIFLjNIuZ1hAMtGS6/2+DLlAswLnlppqc1kT4UMjCNyoTMu9YFUZ5jIOeoOVVqsJn1NGxp7aZqll3VRVIPA25SI0lp6eTs2aNc2WBQQEEB0dTXp6uqp9XLx4kWnTpjkMpwFMnz6dqlWrGv9MW4qUO2QdnNgA+37Q/1/Wub8vs15HblJQ7MEJrWa+PCBM1eYTAn6gmodNT201cvUERSmbnl9qcDURfFrhI+Qowb47H295MOz0BvNJj6+yoIz6ihmaqtr72kjoq8dEU1VBRaNMDaEXX3wRSZIc/qWmpnp8nKysLO666y4SExOZMmWKw3UnTpxIZmam8e/MmTMeH79MOLhCX3nyZR9YNlz//5nN9cvdJbEfdPWkL1hxwmxACLouL1IYFKVfXJSneg+eVnl5u0osB/3TcXnOH5UVvXp0Fa4RLuX7oJJO0vfD8qYHI7EfjN+vrw677zP9/8fvK/9GkIEyMPZEU1VBZaVMy+cvXLjApUuO1YcbNGjAN998w7PPPsvly5eNy4uKiggJCeH77793GBrLzs6mV69ehIWFsXLlSkJCXHPrlsvyeV9qkHipjF5B70kxF8SzHW7xJ72fi0oE2+SmHFNqsUXWl/P31OxgeuCnboXsSgtHopEAowrH8Wbgpy7lXbnEA1/CDf19s28XUCMU6FdigmWgLC10hAQVBbXzd5nmCNWoUcOsias9OnTowJUrV9i5cydt2rQB4M8//0SWZdq1a2d3u6ysLHr16kVwcDArVqxw2Qgql8g6vRqt3SJYCZJf1Jc8u3NDNcvRMOzTDWwYN4aMD8l8tTLX+lEUyCWEJwonGHWMLIkiR7XBZnj0UCg9A8/eNUxH30csk3DfGUGgb74radw2wN0yTiyMiOSc+kxdedjhBO93RoBGW+p6SL2bx9MzMc5/jEGBwMeUG0HFO+64g3PnzjF//nwKCwsZNmwYbdu25dtvvwXgv//+47bbbuOrr74iKSmJrKwsbr/9dvLy8vjpp5/MGsPWqFEDrVadEVDuPEInNqhreeCp4NzBFfDLOH01kC8Jq666bYfaJqKuoihwmXDa5s+3MoKcKx1bY6qODaXv7Vqta80RuQ6KJBm9Wn00W5kVNNuHR3XfG+mWcWKjPcVZJZqphUPMmseaCgUCQkxQ4BF+5U0UlA+PkCssWrSI0aNHc9ttt6HRaLjvvvuYNaukdLewsJDDhw+Tl6fPN9m1axfbtm0DoFGjRmb7OnHiBPXq1Su1sZcqpaVB0vQu+O1/Lm+m1mtyvP4jXG3Uh2ZVctAsd5zgDr4zgkC/32hySNKkslVONHsvSZPqclf6L4tu50Pd/exWGukbh1K6ZfydNQfopdX38BrLcs4q0Swu6u7WvtQ3n3XPG2lP6Tg98xojvtll2zixExqOI4N5gTMZUTjeaAwZPJBTfzloV3fJdJ2eiXFiYhPYxO+8iQLVlBtDKDo62uj9sUW9evUwdW517dqVcuLs8i6lpUFyajNkp7m0iezCui8dbsDWQ9Az7CwLVKyv1giyNJhc6SJfkyuqljljfMCPpCrXsVpOYm1+a7YGjyKabKcGoj1jz5VzAAjDvA9ZHBk8E/ADOUqwSz3KXD2umSKyCm+kM6Vjm8aJg9CwQZPqrcBPySoMM4Y5DUKBTkZuFBPs0DDG6dgFlQu3DHaB31AuyucFLmDQIHFUBOuNCh43PErpSgwjC8dyVom2W2VlqGBKkZsCsDavkX59O/t01daVLa7LZcLJRl3u2HmiVC1zhoJeIFKDTFvNEapLzo0g0Bsclucru2CMGEr9Ldc12hAu3g7SiOazojtc2gZQ/d1xS+nYSXsKjQTVpBwWB73JxuCxVorlzhBiggJLRGuS8o8whCoapaVBotKj9FrhIMYWjGZAwSt0zv+QZLk9Uwv1idaW9wXD66mFg42TsoyGqYVDkGzo9bjaXuOiEsmN+Qv4sqgHf+tu5MuiHrTPn03r/E/IVkLt7s/SODMlRW7q0LCzhUaCBOkS7TQH6SjtV7+hDRQk1upaqVpXkuwbTBoJIqWr5ClBdq+DwZD6tKhX8ec5iz+UNq4PWuV3xy2lYxcMdEOozBVjSIgJCiwRrUnKP+UmNFbp8KRs1qBBYpEsSmSC3gjyhgaJE/VbWYH/b+/O45sqs/+Bf+5N04WuFAptpUBZS0XWUmQHobYWQRTcAEW/CAyyCPIbAUcpuIGjDoVhU8cFEBA3tOhYZIDKYqGFAoKlMGzK0JYipXspae7z+yO9aZZ7k5s0aRpy3q8XL+xNcvMkqdyT5znPOaUIwBnW1myn1W4hDitrJ+jaZBgUSCxGEL6tHYRSBICHYPQYua31cselHNN2ximfafrK0sNwCpNVe/AfbR/4o1ryMayuS71hcGb0OusCtfXqVJu3+a9Tr7J5p5bZbA4YRqqO23QOS5pxt/Wd7M3C6LqlpWTVUbxVq3s/xEAwnCtW8K3KtorIdlU6tmHJt759yyZ4qUMQykrw3+oAZAkxZp81ByCcigkSCdSaxP25za4xV3HJrjGJHS+6IOZt24IYZ9cg0SelAobBkOnySwELxdba+/A7C0c7rhATvfYa9fm6xdQQwKEZd1t/TNzhs1uIs7grS2C6WREeTHa2Q8t0syYJdQnCUjlCpscNb5fbMWYokc/SJT7bkDjtqARvw8BF7jXcQCBacuUNf7I6z6tfQ9f+yWjfshlibmagy8+z6gInuX9ObN81phUYBr+9F4Wlt+QaTSA82BcHF95nnCOU2h2srACcnaUdTHeX0a4xEy6obdSUZV64gSc/PGz1ftum3Uv5ZY1M6fWbAiErGj0QcmYxRFuI7Tl+P6gbSvQQoP1g83/wJII2qYRkSz9LPn3dy19ZOwEL1F9ZHa5U4q54bLZmFlar11kMlqx54vYrZjvGTPEQEM/nIYHLxjNePzWJnmaC/j2Yg9fVnyIU5Q4JvoRH/gW+x6P1B6SCd0NBd9k1GykmoQKSXcUkg5Pjuzai5y9zAdhXmkCoezJxdxnt/DHgqC9pdxC7AnbSKCgQcpBGDYSsVm2uW1qYd8q538By04Cdc4Hqm8bH/UKBMavM/8ETg6avngGrvml7M04Z4vJacwUVm/+leQDjvQ6Y3beYBWC3tg8e99rfoLHMvT0baYLlJR0xEGqFErTn8jHP6xvdcRf+25fPWiCtdgDGev1i8zZ/i6TqUBnOFPiHQSsIuHD5MopYCFTtByG+Y5hdFwJbtiWLF6Ue5fttnqEzxMCh2q81Tj5ywO5x33Gaype0JsiegJ043x1XR8gjWNnxYuv2Y7vkpgFfPCV9W3Wx7rbHNhv/g8erdH8cGAQBdTt8FDZZLYU/giWqO4egAo+pGhYEAcB1BOFePhetUIIihJjlkUgtjRWzAHihFkF2dIG3fWu6MYEB5WiGdG0cpnt979DPBQBQJdEax6AKcn3wIjZLzjYOXmxYXpGsdNwuGKormcCpQ0aPFxNXCxCP3TVx6M/nYp16NYJRYVNAyoGhWXUhBnidBfhW1h9wp3N2xXo3l9Q9Ausn9zEL2MNpNtEtUCDUlDRWMUQ5glZZkUSpf/CcNSYAN5k/glEpmyNUiFBM9NoLwHz2paFf5AUGlCAA/1BvMMprMswjSeIPY516tdljQxQGcVJuwRu+uG39jjJ4DghGFf7Pa5fd57Bo18tAtzGSFz1rNVW+GfEnev+2wqblFRXP1edX5KYBq6WXZ4pu1+9iE8AjU+iORZrn7EpmB+DU32u30hS+pDVx1JrEfdH2+aaksYohylFaJFH8B68xxgTg49okAPLb7bfVjkAEp7zFhSlxW7jc+ZujAq1Nqj+LW68Xq7Zgrfqf4DnHBmE+uA0GoJz52X8SZ5L6HYD1miqJfBZ6Zc4FM72olhXoll1y0yw/r7g8I/P4mJsZZg/ZJcRjpmYeCmHHji8n/l67FVd/SXMTYsD+UK+7MKBjCwqC3AQFQk1JYxVDlGPLP2LlBcCFDGDvG8CeNwBtLRDo2OlfsX7PWu3DkheyQrTATM08/M7sf15xCeonbV+J84eiBAGSzVF5TvcpTff6wWJStH4zk42ZeOLjyuGHf2geQQXzse0EjUHi98VSTRUeApaoN+lLEhire4PSF+lmJqVYXZ4Buhx/E3cFqc3Ov0uIx+Ca1Xji9itYzL2AWaoU5LPmFj4XJ/+/5m5c/SWNECeipbGmxKizu9iLXeTAYohybPlH7Pv5wG2DpZ8D7wBejis2Z1pccZegy/kQk5EN83Tu5XPtfh4tePyrNhkrtBPB1wpG5+cgYJv3W7KPtSV/h4PyPmsingMiUaxPum5yJH5fLNVKsd6XTX55RSsw5GWm424ryzNc2VWsHFqFx39Sm/0fxMDjsBCLw3Ulo2r5KTJLZo3w/5q7sVI3zNYaUYQ0JTQj1NSIxRCDTGY5giKdvyuj3UDlszq3JfJfah1XMKyIa2HUHBPQ5XwcFmKRJgzEYSEWPmpdHG9PdWdANxs0T/M8MlgvjOV/QTyfhywhRn/+MJQ57PX8o3YCbiLQ7sc3pRl2BsjOllgqgqi4L5vJTFP66QIMfnsv3v/BfClOSnxYLdZP7oPwYOOxhAf7IqSZWv+z3JIZa4z/19xNY1WsJ8QFaEaoKYodq0tGbuyiZbwKeODv8rvGHIXjgW4PAZf2AdUl9cebtQR6PAZ0TcaJimjs2nLS4mn+MqwjVv7nvw2q7pyqXgsvg6Wtm8wfH9cmYa32Ybv6iJnSJXO3wFrtOPzBWmGV9zqbz9GUgiAAAAOO370QvSV+H+OjQxER7CtZU0Xx+2kw02SYeF3EK398UrR54qogMEz66IjRXaVmGl8YMwUDOtNOMTONUbGeEBegQKipMtiK3Khix+q2x0vVEfIJAmocMEsy4RPg7nHGW6ibtQSYAPzxC3DxZ4Ry18FDLVvNeWRMGOLahyI8yAfXymr03+5T1JsQCWW1YzgO8DK5XDfnKrFA/TWe9dqFv2mm6tpHyFS1VvQcqF/eu2Zjsq6jKk8r1qwlUPWn1bv9o3YCvsppg4MJzCwZVMVzSBkTi5mf5ZgtTWXXzdxFcDdlqj4bL6+YJl7r23lY+jz8QvWPN9ppBuC7E1clHyLONIqerNRYePUezlVf0ghxIgqEiDnxHzvTytIV14BvpjXs3MNf1gVBQH2wl5sGfPWMUeAVD+CoTwAWa54zWh4T7cm7jj151xHSTK2/UBp+ux/FHcNUrx/tDiSaowJr1avwQe2DmO71vX1brwGsrB2vH7+iC3kdQTKh2MECI4G+zwAtOuouaFH9gdU9ZdtTiKUK1mrHQahrIinVMkCupkqr4Ga41mcpIjNfgJIcONPEa3Hmb4M6VT5IrC4G8n6QnJ2wq3cZMeeqL2mEOAkFQkQarwI6Dtf9EV060LBzBkYCQ/+f8TELBRybowIb1Kn4qPYB/If1lWyGWVJl/O1d/HZ/GLEoRTMsUH9t11C5uuv0BK/9mKWZjVfVWxXPNAG62ZxKPgBrtA8bjU1uCc/0wl6IFnhdMxmvqjdb7LOmODgLugtIfAto1sLyN/m6ZH3Tc9cnrz+t/wwsJUZbrKkS1VzR8orU+XcLcbiJAAuFNuUL+1latqt7JDVWJcQDUSBElBOTqZXUGpLywNvGFycrBRzFwOA59Y94Dj8inzXHMs0U7BLijdpZSFV65iHgKOuKm8wfIai0a2aI44CWKMPr6o14VfN/iOBuYIn6M8WP9Rs6B0EHfIyCNbklvAKEYptmBH5nEbgOXSn4MJRhW+0IzPf6WrJfm2KJbwH9/6Js+SJ2LM4NW4vAjFeMxleIFlimecpods7azInp0pThc5gur2ijBiDr91IUnbiqD5qkzh/P5yHUYssV+Z1nKp5DyoNd8em2bWa/N+JbmzImlmq/EOJhKBAiyjUkmdpP4lu20gKOdSJwE+vVqfig9kGz3lmGlZ6l2l00JN8mFOVYq16FWZoXkM+aIwI3FZ1L1bITVjxyj1mV5V1CPPbU9MHTqp/QlivCH6wVNmnvRy28kMhn4T31BrOxS1H0coLuUh4E1ek0bCKGZoYhquKkZKApNXOiFZhtFXVN23G887NZL7FXR3dDqL83iivrK2zbu/MMAJCbhqTdC5HkXT8TJf7e/Bo4lFohEOKhqOmqFY3efd4dyDVltUiiMeOpr4Cvp9r01OJvq2mRQ3HpRszpASwvPdUyDjzHFNePEHd/vaaZhHXq1cqWpOoak5o2DZUK1PJZKNJqByoau7XjgL77E/DoxvqcLBvY0kTSlqaocs8j08YTzw2JxocHLumP38vn4nPvN6y/ANOmsDINQ1ndMwmPboTq7oesn5cQ4jaUXr+pjhCxXexYYME5wE9i2UOWROVgO6rQcpzuj1w7i+e8fjD62fBxAgNusgBMvP0y5mjmmKXrWsJzQCR3AyUIwvOaudAy+UhIYECVX7h+91JS9wgcXHgfXh3dDYl8FtarUxEu0bJjRl1zVKmxS7E0K6W/qZktn1E9MeFZqhaPaRA087Mcs2rSYl+x9NPyM37W2nEAwPe/FmDakGj9ces1oyQqQluoSM3VhUKqXYvlK1oTQu5otDR2p7Chm7dDXDkCVEt0ILfIJH+joTlHJngO4C2ENmI3+xB/X4x96GlwfD+bZ7ZaoQRpwkDM1nBYp14FwDggES/QV+KXoKvB+6/iObQM8EKKepN+LKZjc4ozdb277Ph9sNZE0logwwFYtjMXCbHhkstkltpxiOcoKL2F+2Jao3dUCF757jSKKzX1Cecw/SYnU9iPGoYSQiygQOhOkJsmswtHvpt3gzWgueK5C+dxprSD7sKa9DZUXz7twIFZt2ZMJPjuEQDqknb3vwv8slq6WraJllwJxvK/oAgheF7zAl5VbzZLKl6tnoo3h000e2ynqlNWWkw4QdYHQNYHqGkWDj757zjqN9imztiyCc9QHshkXSrGgOgQs0Dd0q4zAPqEePWZq0i+uxsSF9+nS6gu74X/3uyCLsffUFbYjxqGEkIsoEDI3cnkPui7eTujVYCgbdBF4/N9R/GptiUE8Hi92TeYjEaomWOADww3+EEFDF8IDJ4P/CMGqJKe5WIM0IIz2jWWz0LxmmYyShCkTyrOFmKw9tE4yQCjW2CVw1+LHH2OUB11ZSHw5dP41KBtiWwej8LZRWuBjEh1difw3dtmQUtM71cAmWrTRnlURwEcBVRBkRiQ9DbQayyAScCwJ5TNglLDUEKIBZQj5M4UdOO22M3bHrlpQGp3YNfLdp9iifozHPSZiwf4XzBR+53yRB3o7ip3d4HpkqDl8keYpY7iXt7Ag6nQhQ8SYRkH8CZd5sNRjHXq1QhGBdKEgTjr2xNrJ8fJJggbBWBOZBoEAfVLbynqzeAhAJDJ4xE/340P6hLZNz6o+zk3zex5lBQeTOSz0C9rnvnSVFkBuvw8C08EnDAbq1welT64F8ci7jy7Z4Lub7mlP7FhqEy4LSbCp1dES95OCLmzUSDkzmzJfXAEcfbJ4nPKjsRIOIqxVr0GKo7Z3MWd0/9XPTH4+VftaKOf65+f0z1CpjGkVmDI9BmErPhU1DQzmRngdHVmTP9nEYOLpd6b8eLIDjj6SoLlXVJ1F2RB5mbG6v7In0ERubdTTPiO5/N0z1d3fNnOXGgFJv/5mgYgdcQChXLPp4KA17w3Qy5Q5wCkqDeBh6A/Bw9BNo/K7uDeoGEok/m9WXr7KczcctJicjch5M5EgZA7a8zcB4uzTyb8Qs3qBsnNUNgk6C5dH7THNgNBxgFHIXTd6ldoJ0p2FOcsdBQXu5s/+eFhPLY/DN2K38Xz6tdwMv5dXTFCJhe66F5HBG5gbqc/rRfi41XQ3v+WbreaxNsouxWe44EBs3Vbwsd/pPt7wsa6WQ4D3v6Wn7+OYS0efR7Phes2zy6KfcUA6X7k/fg8tMYNC8ueDH7Vhdh2v1a/Oy2ez0MkZ6kFiZ3BfexYaB/diCKT3wvx9ya9brlQHxTKEbS6CuunvtL9TTvNCHF7lCPkzhoz98Hq7FMdsYoxABzZYHEJTXEwdM/jQJ+njHNA6ioTnzyTh+UHS4wK/pl2FK/1b4WxCeORFNvG7NT//jUfz289bnRMAI8fyzvhx/3At0Pz0VPJGBUGm3ml3rgbkJ22ka4XJACZa8BF9dctA4lixxjnyAhaYLP1WjjtuEKzY9rLh+zaWSXXVyw82BeLe4YAWVaHg/iwWhxceB+yLhVDfeaqLifIGjuC+yzfwXjq1krJQpaASXK3VIK4KzYlEEKcjgIhdybmPpQVQPqbvHE37wZReuEJaF0frCgMwCxWfeZUwJhVwNWjwG87jJNio4egZ/QQ9EQuDu+/ZPQwo47i5cCPW05i/WSV0dLVv38twOxtxkGQfkzQxSrvH6/COiUvQuFrrb4p3QHdEh6696jm2znwMeyhZdr8UtCiplk41JWFskEmY8B8r69wjrUxbpfBlSgbjMTvgew2+9+9FQVCCGhdvzuN76YsELIjuFed3Yn9PsuMdu495/VvfUVykWQSuCs2JRBCGgUtjbkzg9wH6cUJyObE2Mye2ScbLlayixFdEoE1fWSTd7UCQ9pJ63kdDMbLHumnC/D81hwLhfl0j0kv74CaZuGQz7yxkIAtwa/5XYruZ/YsHOBzuwTan9+RvxOvgtfov4PjLLTlMEma5qDbPdaxQ0dlA5H5TMVA5qFed2FAxxa6ZUIrScqS7509j1EiNw39suZJFrJcr05FIl8fsZklgbtiUwIhpNFQIOTuYsfqvo2a5MzAQk6MXZxwURMYkM9a4IPa0TBrdsGpgK7JwNkfLSbvWqtlY0hc9tDW1iLtuy8wlv8F9/K5+l1UkmMEj5PdF9e/RtPXDNgUbMb0T8Q1tLAYgFkiZK63eMFV3f0QzsfOsZiAbpo0nTImFqr2gxwfgNgTqDsjuDcIZOQKWaaoN0MFARFS3ecbe1MCIaRRUSB0J4gdC8w7bZxMO++UY6fqHXxREwOB1eqpaPfke+BfuabLL4qfrvt78VWg4ASsfQsvKqu06WWozu5E7T/uxjrNEqz2XoPPvd/AQZ+5RjMCpjRdHnRYsKny8kL+gBQA5jvblFDfLrF6we3crZeic3VpVlnfLsNZs4v2BOqODu7rAhlru+n68XnS3eepICMhdzS3yREqLi7GnDlzsHPnTvA8j/Hjx2PVqlUICAiw+ljGGJKTk5Geno4dO3Zg3Lhxzh9wYzPNF3EG8QIlmTAqUdHXwmNuNQvHlfgleHPYxPoLz4BZ9cX8Dryn6Ft4p6pTAOqrEEt1SxfpatqsgmlwJS6PzDQoNmj6VIgdq0/Qbmgbk96JU3AcQGTmMrRGfQFHoa4RrFXWLrgKlyRTJt4HVYeI+vdcexsYvhjI+VT556uEPe+dA99vpQHK4sEh6ClV/oAKMhJyR3ObQGjSpEkoKCjA7t27odFo8Oyzz2L69OnYunWr1cempqaCs6VYDZHnoItas3YDjXpxAZDelWNFt8AqPBFwDnM1/zLr5m6YBMsb1LSR2sovMN3yyO6aOLMASp8868Bgs3fiFGhHTsJvR3ah+uZV+IRE4vCebzGNfWn9wdYuuAqT6FXtB0m/54ERwPCXgRYdHde3zp73zlHvt8IApWe3GOkbGnNTAiGk0blFIHTmzBmkp6cjOzsbcXFxAIB//vOfSE5OxrvvvovIyEjZx544cQLvvfcejh49iogIC8XuiHLOuKjJ7cqxdtrii1he+w6YlVme+LqaNrLn4YBI6PJm9LvN6hRX3lY0Fq3AZBuUSlF5eeHuQaP1P18N7oXir35Ec1RIb6MHp6uHJGh1dWzkghRxmeuLp6Fb1jJ8bwyWufJ+kH7PywuBjOW6mbym2oTUlibDDQ1klL6fzmxyTAhxGrcIhDIzMxESEqIPggBg1KhR4HkeR44cwcMPPyz5uKqqKkycOBFr165FeLiy9gY1NTWoqanR/1xWVtawwRPrbCnWqMfpZi5yPgUH8+rUhrM8p30G4ckoNXDB+lkNiw2KQgN8rD4u/XSBUS0dHgKSAi9iRu9mupkGBbMqSfe0wfH8t9A8cy4EZlxnSVcZmwGaKuNaQXJ1bKwtY8aM1u2+s9Q7Pn2R7n5N7QJvaz0fRwQy9iwLE0LcglsEQoWFhWjVqpXRMS8vL4SGhqKw0Lw4nGj+/PkYOHAgHnrIepE50fLly7Fs2TK7x+oxbPlGbo3SYo1GGND3GSDjLdl7iLM87/Wvwqo9NXjI2/pZryPI7Fh4kOWeWumnCzDzsxz95VXfMFRTrKujkwXFhfd6J06Btk0Ian94CT5V9b/bnF9zoLoYqL5p/ABLdWwsLWNeOmBXAUUz4u9BeQFQeR3wD9MFqI5YTpNibz0fRwQyjsxbIoQ0GS4NhBYtWoS3337b4n3OnDlj17nT0tKwd+9eHD8uXTBPzuLFi/Hiiy/qfy4rK0NUVJRdY7hjObjCrlBeaPv2Rb9QIFRZk8x/Z54A4GfrMwCA9HZqA1qBYdnOXKMgaL061ex+rCwf+OIp5A1Zhy4jJlpeMrv7Iai6PVh/wfUPA3bMkLm3ldkbuSVJR+yEspTT5YyKy1br+ViZxXJEINMYmxIIIY3KpYHQggUL8Mwzz1i8T4cOHRAeHo6ioiKj47W1tSguLpZd8tq7dy8uXLiAkJAQo+Pjx4/HkCFDkJGRIfk4Hx8f+PhYXwrxWA6usJt+ugBpO/OVVW82VF2sm4FQ4FyVP0ZxxxTdNwz1S6EcIL2d2oBhHSNLDUM56Jbqgve/iv4HQrBuqAbxYbWW83zEC+6lA7oZF1kKZ28MKUwg/q3MD+dy/ofiytsIDfBBeFBd7lPeTss5XWX5jq+4bEs9H7n3gQIZQogJlwZCYWFhCAsLs3q/AQMGoKSkBMeOHUPfvn0B6AIdQRDQv39/yccsWrQIzz33nNGxe+65BytXrsSYMWMaPnhP1NBv5CbEJSUOHZDvE4pwWGq2KcE/zGoSbJVfazS/XY6pXj8qOqXYhyvET40V4++x3E0exu0YxIahcsSlunQ2Ay33l9ffIM6eyM1WOKOOjZUEYgYO1xCKMTsFCDhpdNtdQWr8R/VX+CnJ6XJknhHV8yGEOIFbFFTs1q0bkpKSMG3aNGRlZeHQoUOYPXs2nnjiCf2OsatXryImJgZZWbrCeOHh4ejevbvRHwBo27YtoqOVLakQEw6ssGu4pCSAxzLN0wBsLDIYGGG1COCVfq/gVfVmRWnYjAFPeu0FDwFrJ/WxGgQBxu0YpBKtpYSi3PhAWQHwxVPAOx2lW4k4o46NhQKKDBwYY0i5/ZRZKQEAiKo4Cb9q+dw8wzM5tOKym9Tz0QoMmRdu4LsTV5F54YblbvaEEJdzi0AIALZs2YKYmBiMHDkSycnJGDx4MD744AP97RqNBmfPnkVVVZULR3mHc+A3ctPWGLuEeMzUzEMh5PNxRMyw3YOVKsSd2kYhklM208RxQCRXjKTAi7i3g0T3cQnx0aGICPYFB6AIIYoeYz6WugulXCJ01Q3n9N+See+uIVS+uCSUB3x6jpqhcVYfMgdKP12AwW/vxZMfHsYLn5/Akx8exuC39yL9tPV+eIQQ13CLXWMAEBoaarF4Yvv27cHkOk3WsXY7scKB38ilOnzvEuKxuyYO8XweRvFH8X+qdADGgYPuyzXDibsXore43CKXBJv3A1RfT1E2ZgMzejezmBdkSMVzSBkTi5mf5SBbiEE+s2OJT1bdcuOul4H7lwNfPQOH17Exee9+K/OrWw6T/46kNODTc9QMTROv52O6e1BUWHoLMz/LqW9nQghpUtxmRog4mKDVJeGe+kr3t5LO2Q78Rm7W4VscFngcFmLxRu3TkjNEhWiBmZp5eD6njfGSg5gEe88E3d9iscDqEuuvy4RshWEZSd0jsH5yH7QKbia7xGd/DF63vOTfwnnNdQ3eu/P+vSwGQQCQVRfwWV/xccIMTWM1GbaR6e5BQ+KxZTtzaZmMkCbIbWaEiAPZu/3dgd/IxSWlwtJbsvk7hjNEZj3E6jrJD+gosYRlV4FGg8rNdly4k7pHICE2HFmXeiH7THu0O/o6wg0qWd9AEFoa7EizWcU1XZDn5Do2cgGqITGna706VZyzkueMGZomWM/HdKnXFANQYOl3lhDiMhQIeZqGbn93UIVdwyUl05DKkDhDJEVqeQ2AnQUaOd0FvQEXbhXP6S5yHZ9FersEfLptmz6AOyp0wX6fefYvm4nLS07e/i0GqJYu6gDwkxCPl9UvYXmzz2TqCN3l3IrLTWwbvOzvop33I4Q0HgqEPImjtr876Bu5uKRk2JrCFrKzF/Yk5zq4VULSPW0AbjIWfXMKJVUaANDPopi1z6j7OKT7AjduQ0/DANXafNrwcf8HLnZR41aWbqKUzKTZcj9CSOOhQMiTOKIgnchB38jrl5Tqm5XeKK/B3O3HZXNQOADhlio+K03Ovf8N3UXbSiBnazNV09d2+OINbPzlEnbl6nbGpag3IRL19YZuIgAhqABjpjvKXJMAnBAbjnmjuuCTQ5dQUq0xuz0i2BcpY2LrE3+b0MyMq1hb6rX6O0sIcRkKhDxJQ7e/O7K/mAH9kpIBnufw/NYcs/uKcYLFis9Ku43f+7zV8Zs2UwUkAgELVDyHQZ1aguc4/JRbhN1CHMo0zTCAzwUYkMlicUSIRQJ/1CxAckVDT6nXG+zrhYTY1hjUOay+srRjtsXdMSwt9Sr6nSWEuAwFQp6kIdvfHdxfzJrkHhHYwJsvm4UrCUIclNTtyO3Q8dGheCLgBOZq/mVUfXoC249lmqfxkxCP0z6DsP8JX6gqi1ySACz3estu1eLrnKsYFduaEn0tkFvqVfQ7SwhxGY5RcR2LysrKEBwcjNLSUgQFmXcmdyuCVlet2NpMybxTxhdguQRrMahw4rZle5elAMgEb8qSeLUCw+C396Kg9BZ4CGY71xh4hAf74uDC+5SNJzcN7IunwRiTqIsEPK+Zh3ET/+Kyi6Xh65UiLu3oX6+TZgfvBA36nSWEOIzS6zfNCHkSe2ZKHNxfzFZSy2aKNSCpW9wOnchn6ZasDGZx8lkolmmexq7SeGXboeveQw7MLCGa5wABwMrgz+EXu8SOF+kYNm3/rjnUqLOD7qZBv7OEkEZHBRU9ja0F6RzYX8wlTAstKgzWisp1QdB6dSrCDfN2AISjGOvVqUjks5Rth7byHvKArneXC99Dpdu6VWfrus6bvh6x/EJumhNGRwghzkMzQp7IlpkSD+343cpfjRT1JgDmvcF4TreklaLejN/9Z1k/mRu8h0q2dfMQ0PP0crhqdpAQQpyBAiFPpXT7u5t0/Ha0eFUeVFyx7O08B0TiBlqr8gC0snwyN3gPlWz/Tgq8CJ8qS13nbSi/QAghTQQtjRHL3KDjtzOoKoscdz83eA/F7d91ozEi/jyjdzNlJ7vDZgcJIXc2CoSIZWKCNQDZS6QLO347jSNncdzkPRS3f4cHGy+ThQf7Yv3kPsqb0d5hs4OEkDsbbZ+34o7aPt8QDdiK7pbsLTVgiZ3vYWNvx5Z9Pme8J4QQ4iRKr98UCFlBgZABT6sdo6+fBEiWGrCnfpKN72FDK1s7nDPeE0IIcQIKhByEAiEP58KZMLlKz+JckC2VrR3K02YHCSFuiQIhB6FAiLhiJszmSs+NzdNmBwkhbocqSxPiKEpLDTiQTZWeXVHF2AXvCSGEOAMFQoQ0QUorPevvRzM0hBBiFwqECGmClFR61t9PMmeHen8RQogSVEeIkCZIrPRsoQQjIoJ9EX/rIPX+IoSQBqBAiJAmSEml55QHu0K1axHke39B1/tL0DpplIQQ4v4oECJEJGiBSweAU1/p/nZxAGGt0nNSwCWLXe2Nen8RQgiRRDlCxO1oBYbDF28g88INAAwDOrTEvR1bNGwbuUSeTU2zcJzsvhjarmOcXs1ZTlL3CCTEhiPrUjEKy26huKIGof7eCPbzhlBeqOybDPX+IoQQWRQIEbeSfroAi745hZIqjf7Ymn0XENJMjRWP3GNfgUF9tWTjJSZ1ZSHijryAmQcv4cXAoS6r5qziOZRW38bf0/OMttQnB+ZjnZITUO8vQgiRRUtjxG2kny7AXz7LMQqCRCVVGvzlsxykny6w7aSCVjcTJJFnI04Apag3o6i0CjPtOb8DiBWmTesK7SrvgHwWCiabUg3AL9SlXe0JIaSpo0CIuAWtwLA0Ldfq/Zam/QatYEOx9N9/sZhnw3NAJHcD/fg8AMCynbm2nb+BtALDsp25kunQWvB4TaObyZIdUXUxkPeD8wZICCFujgIh4hbEHBlrCstqkHWpWPmJFebPtEKJUTXnxmKtwvRPQhxusgALZ+Bo5xghhFhAgRBxC0orLdt6X6X5M0UIse/8DWTtueL5PIRyFRYWx2jnGCGEWEKBEHELSist23pftBuoq8IsE0oIDMhnLZAlxNh3/gay9lytUKLsRLRzjBBCJLlNIFRcXIxJkyYhKCgIISEhmDp1KioqKqw+LjMzE/fddx/8/f0RFBSEoUOHorq6uhFGTBwpPjoU4UHWA5DwIB/ER4cqPzGv0rWiAMySjsVUoGWapyCAr6/mbMv5G8hahWnDmSqLaOcYIYRIcptAaNKkSfjtt9+we/dufP/999i/fz+mT59u8TGZmZlISkrC/fffj6ysLGRnZ2P27Nngebd52aSOiuewdGys1fstHXu37fV+YscCj20CF2S8Nb4QLTBTMw+7hPj6as5jYhu1npC1CtPZQgyq/cIlbjW4V9BdtHOMEEJkcIyxxtsCY6czZ84gNjYW2dnZiIuLAwCkp6cjOTkZ//vf/xAZGSn5uHvvvRcJCQl4/fXX7X7usrIyBAcHo7S0FEFBQXafx6OJndHLC4DK64B/GBAYYVeHdKk6QgAaVkfIZJwnz+Th/eNVSC/vAKHuu0JEsK/L6ggBute9bGeuUeK0fkx8dl0dJMC4DEBdcPTYJmq+SgjxOEqv324RCH388cdYsGABbt68qT9WW1sLX19ffPnll3j44YfNHlNUVITWrVtj9erV2LZtGy5cuICYmBi8+eabGDx4sOxz1dTUoKamRv9zWVkZoqKiKBCyl1RndJGdHdKdUlla4jmyLhWjqPwWWgX6uqyytOIxSXagvwtIWkFBECHEIykNhNyisnRhYSFatWpldMzLywuhoaEoLCyUfMzFixcBAEuXLsW7776LXr16YdOmTRg5ciROnz6Nzp07Sz5u+fLlWLZsmWNfgKeSqdisV5avu93GGQsVz2FQp5YY1KmlY8Yp8xwDOrZw2vntYXFMsWOBmNG6mbeKa7qcIDtm3AghxNO4NFlm0aJF4DjO4p+8vDy7zi0IAgBgxowZePbZZ9G7d2+sXLkSXbt2xccffyz7uMWLF6O0tFT/58qVK3Y9v8ezULHZGKM6N47Cq4DoIcA9E3R/UxBECCFWuXRGaMGCBXjmmWcs3qdDhw4IDw9HUVGR0fHa2loUFxcjPDxc8nEREbpcjthY4wTbbt264Y8//pB9Ph8fH/j4+CgYPbHISsVmI2Kdm+ghzh0TIYQQYsKlgVBYWBjCwsKs3m/AgAEoKSnBsWPH0LdvXwDA3r17IQgC+vfvL/mY9u3bIzIyEmfPnjU6fu7cOTzwwAMNHzyxzNa6NVTnhhBCiAu4xT7ybt26ISkpCdOmTUNWVhYOHTqE2bNn44knntDvGLt69SpiYmKQlZUFAOA4Dn/961+xevVqfPXVVzh//jxeffVV5OXlYerUqa58OZ7B1ro1VOeGEEKIC7hFsjQAbNmyBbNnz8bIkSPB8zzGjx+P1atX62/XaDQ4e/Ysqqqq9MfmzZuHW7duYf78+SguLkbPnj2xe/dudOzY0RUvwbOIFZvLCmA1T4jq3BBCCHERt9g+70pUR6gBrO0aAwBwVOeGEEKIwym9frvF0hhxU3UVm3W9vCQE3UVBECGEEJdym6Ux4qYM69s4oLI0IYQQ4kgUCBHnE+vbEEIIIU0MLY0RQgghxGNRIEQIIYQQj0VLY4QYaIrNVgkhhDgPBUKE1Ek/XYBlO3NRUHpLfywi2BcpY2KR1D3ChSMjhBDiLLQ0RoigRdbeb/HvrWvQrjwHPAT9TYWltzDzsxykny5w4QAJIYQ4C80IEc+WmwaWvhDxZfmI99YdymehWKZ5GruEeDAAHIBlO3OREBtOy2SEEHKHoRkh4rnEytdl+UaHw1GM9epUJPK6vnUMQEHpLWRdKnbBIAkhhDgTBULEMwlaIH0hAAbTOR5x0idFvdlomayo/BYIIYTcWSgQIp7p91/MZoIM8RwQyd1APJ+nP9Yq0LcxRkYIIaQRUY4Q8UwV1xTdrRVKwAEID9ZtpSeEEHJnoRkh4pkCWiu6WxFCAAApY2IpUZoQQu5AFAgRz9RuIBAUCZhlCOkIDMhnLXAloCfWT+5DdYQIIeQORUtjxDPxKiDpbd2uMXDQ7Q3TYeDAcUD5sNexf1gCzQQRQsgdjGaEiOeKHQs8tgkIMp7t4YIiwT22CV1HTKIgiBBC7nA0I0Q8W+xYIGa0bhdZxTVd7lC7gboZI0IIIXc8CoQI4VVA9BBXj4IQQogL0NIYIYQQQjwWBUKEEEII8VgUCBFCCCHEY1EgRAghhBCPRYEQIYQQQjwWBUKEEEII8VgUCBFCCCHEY1EgRAghhBCPRYEQIYQQQjwWVZa2gjFdM86ysjIXj4QQQgghSonXbfE6LocCISvKy8sBAFFRUS4eCSGEEEJsVV5ejuDgYNnbOWYtVPJwgiAgPz8fgYGB4DjP6kReVlaGqKgoXLlyBUFBQa4eDqlDn0vTRJ9L00WfTdPk7M+FMYby8nJERkaC5+UzgWhGyAqe59GmTRtXD8OlgoKC6B+PJog+l6aJPpemiz6bpsmZn4ulmSARJUsTQgghxGNRIEQIIYQQj0WBEJHl4+ODlJQU+Pj4uHooxAB9Lk0TfS5NF302TVNT+VwoWZoQQgghHotmhAghhBDisSgQIoQQQojHokCIEEIIIR6LAiFCCCGEeCwKhIhVly9fxtSpUxEdHQ0/Pz907NgRKSkpuH37tquH5pHWrl2L9u3bw9fXF/3790dWVparh+TRli9fjn79+iEwMBCtWrXCuHHjcPbsWVcPi5hYsWIFOI7DvHnzXD0UAuDq1auYPHkyWrRoAT8/P9xzzz04evSoS8ZCgRCxKi8vD4Ig4P3338dvv/2GlStXYsOGDXj55ZddPTSPs337drz44otISUlBTk4OevbsicTERBQVFbl6aB7r559/xqxZs3D48GHs3r0bGo0G999/PyorK109NFInOzsb77//Pnr06OHqoRAAN2/exKBBg6BWq/Hjjz8iNzcX7733Hpo3b+6S8dD2eWKXd955B+vXr8fFixddPRSP0r9/f/Tr1w9r1qwBoOuFFxUVhTlz5mDRokUuHh0BgOvXr6NVq1b4+eefMXToUFcPx+NVVFSgT58+WLduHd544w306tULqamprh6WR1u0aBEOHTqEAwcOuHooAGhGiNiptLQUoaGhrh6GR7l9+zaOHTuGUaNG6Y/xPI9Ro0YhMzPThSMjhkpLSwGA/v9oImbNmoXRo0cb/X9DXCstLQ1xcXF49NFH0apVK/Tu3Rsffvihy8ZDgRCx2fnz5/HPf/4TM2bMcPVQPMqff/4JrVaL1q1bGx1v3bo1CgsLXTQqYkgQBMybNw+DBg1C9+7dXT0cj/f5558jJycHy5cvd/VQiIGLFy9i/fr16Ny5M3bt2oWZM2di7ty52Lhxo0vGQ4GQB1u0aBE4jrP4Jy8vz+gxV69eRVJSEh599FFMmzbNRSMnpGmaNWsWTp8+jc8//9zVQ/F4V65cwQsvvIAtW7bA19fX1cMhBgRBQJ8+ffDWW2+hd+/emD59OqZNm4YNGza4ZDxeLnlW0iQsWLAAzzzzjMX7dOjQQf/f+fn5GDFiBAYOHIgPPvjAyaMjplq2bAmVSoVr164ZHb927RrCw8NdNCoimj17Nr7//nvs378fbdq0cfVwPN6xY8dQVFSEPn366I9ptVrs378fa9asQU1NDVQqlQtH6LkiIiIQGxtrdKxbt274+uuvXTIeCoQ8WFhYGMLCwhTd9+rVqxgxYgT69u2LTz75BDxPk4mNzdvbG3379sWePXswbtw4ALpvVnv27MHs2bNdOzgPxhjDnDlzsGPHDmRkZCA6OtrVQyIARo4ciVOnThkde/bZZxETE4OFCxdSEORCgwYNMisxce7cObRr184l46FAiFh19epVDB8+HO3atcO7776L69ev62+jmYjG9eKLL2LKlCmIi4tDfHw8UlNTUVlZiWeffdbVQ/NYs2bNwtatW/Hdd98hMDBQn68VHBwMPz8/F4/OcwUGBprlafn7+6NFixaUv+Vi8+fPx8CBA/HWW2/hscceQ1ZWFj744AOXrTRQIESs2r17N86fP4/z58+bTflT9YXG9fjjj+P69etYsmQJCgsL0atXL6Snp5slUJPGs379egDA8OHDjY5/8sknVpeeCfFE/fr1w44dO7B48WK89tpriI6ORmpqKiZNmuSS8VAdIUIIIYR4LEr0IIQQQojHokCIEEIIIR6LAiFCCCGEeCwKhAghhBDisSgQIoQQQojHokCIEEIIIR6LAiFCCCGEeCwKhAghHoHjOHz77beuHgYhpImhQIgQ4lCZmZlQqVQYPXq0zY9t3749UlNTHT8oKzZs2IDAwEDU1tbqj1VUVECtVptVjM7IyADHcbhw4UIjj5IQ4gwUCBFCHOqjjz7CnDlzsH//fuTn57t6OIqMGDECFRUVOHr0qP7YgQMHEB4ejiNHjuDWrVv64/v27UPbtm3RsWNHVwyVEOJgFAgRQhymoqIC27dvx8yZMzF69Gh8+umnZvfZuXMn+vXrB19fX7Rs2RIPP/wwAF2vrt9//x3z588Hx3HgOA4AsHTpUvTq1cvoHKmpqWjfvr3+5+zsbCQkJKBly5YIDg7GsGHDkJOTo3jcXbt2RUREBDIyMvTHMjIy8NBDDyE6OhqHDx82Oj5ixAgAwObNmxEXF4fAwECEh4dj4sSJKCoqMjp3WloaOnfuDF9fX4wYMQIbN24Ex3EoKSnR3+fgwYMYMmQI/Pz8EBUVhblz56KyslJ/+7p16/TnaN26NSZMmKD4tRFCLKNAiBDiMF988QViYmLQtWtXTJ48GR9//LFRY94ffvgBDz/8MJKTk3H8+HHs2bMH8fHxAIBvvvkGbdq0wWuvvYaCggIUFBQoft7y8nJMmTIFBw8exOHDh9G5c2ckJyejvLxc8TlGjBiBffv26X/et28fhg8fjmHDhumPV1dX48iRI/pASKPR4PXXX8fJkyfx7bff4vLly0aNVi9duoQJEyZg3LhxOHnyJGbMmIG//e1vRs974cIFJCUlYfz48fj111+xfft2HDx4ELNnzwYAHD16FHPnzsVrr72Gs2fPIj09HUOHDlX8ugghVjBCCHGQgQMHstTUVMYYYxqNhrVs2ZLt27dPf/uAAQPYpEmTZB/frl07tnLlSqNjKSkprGfPnkbHVq5cydq1ayd7Hq1WywIDA9nOnTv1xwCwHTt2yD7mww8/ZP7+/kyj0bCysjLm5eXFioqK2NatW9nQoUMZY4zt2bOHAWC///675Dmys7MZAFZeXs4YY2zhwoWse/fuRvf529/+xgCwmzdvMsYYmzp1Kps+fbrRfQ4cOMB4nmfV1dXs66+/ZkFBQaysrEx27IQQ+9GMECHEIc6ePYusrCw8+eSTAAAvLy88/vjj+Oijj/T3OXHiBEaOHOnw57527RqmTZuGzp07Izg4GEFBQaioqMAff/yh+BzDhw9HZWUlsrOzceDAAXTp0gVhYWEYNmyYPk8oIyMDHTp0QNu2bQEAx44dw5gxY9C2bVsEBgZi2LBhAKB/3rNnz6Jfv35GzyPOgIlOnjyJTz/9FAEBAfo/iYmJEAQBly5dQkJCAtq1a4cOHTrgqaeewpYtW1BVVdWQt4sQYsDL1QMghNwZPvroI9TW1iIyMlJ/jDEGHx8frFmzBsHBwfDz87P5vDzPGy2vAbolKUNTpkzBjRs3sGrVKrRr1w4+Pj4YMGAAbt++rfh5OnXqhDZt2mDfvn24efOmPqiJjIxEVFQUfvnlF+zbtw/33XcfAKCyshKJiYlITEzEli1bEBYWhj/++AOJiYk2PW9FRQVmzJiBuXPnmt3Wtm1beHt7IycnBxkZGfjpp5+wZMkSLF26FNnZ2QgJCVH8PIQQaTQjRAhpsNraWmzatAnvvfceTpw4of9z8uRJREZGYtu2bQCAHj16YM+ePbLn8fb2hlarNToWFhaGwsJCo2DoxIkTRvc5dOgQ5s6di+TkZNx9993w8fHBn3/+afPrGDFiBDIyMpCRkWG0bX7o0KH48ccfkZWVpc8PysvLw40bN7BixQoMGTIEMTExZonSXbt2NdqJBugSuw316dMHubm56NSpk9kfb29vALrZtVGjRuHvf/87fv31V1y+fBl79+61+fURQiS4eGmOEHIH2LFjB/P29mYlJSVmt7300kssLi6OMcbYvn37GM/zbMmSJSw3N5f9+uuvbMWKFfr7JiQksLFjx7L//e9/7Pr164wxxnJzcxnHcWzFihXs/PnzbM2aNax58+ZGOUK9e/dmCQkJLDc3lx0+fJgNGTKE+fn5GeUbwUqOEGOMffzxx8zPz495eXmxwsJC/fGNGzeywMBABoDl5+czxhgrKipi3t7e7K9//Su7cOEC++6771iXLl0YAHb8+HHGGGMXL15karWavfTSS+zs2bNs+/btrE2bNgyA/r06efIk8/PzY7NmzWLHjx9n586dY99++y2bNWsWY4yxnTt3slWrVrHjx4+zy5cvs3Xr1jGe59np06eVfTiEEIsoECKENNiDDz7IkpOTJW87cuQIA8BOnjzJGGPs66+/Zr169WLe3t6sZcuW7JFHHtHfNzMzk/Xo0YP5+Pgww+9p69evZ1FRUczf3589/fTT7M033zQKhHJyclhcXBzz9fVlnTt3Zl9++aVZ4rWSQOjSpUsMAIuJiTE6fvnyZQaAde3a1ej41q1bWfv27ZmPjw8bMGAAS0tLMwqEGGPsu+++Y506dWI+Pj5s+PDhbP369QwAq66u1t8nKyuLJSQksICAAObv78969OjB3nzzTcaYLnF62LBhrHnz5szPz4/16NGDbd++3eLrIIQoxzFmsvhOCCHEad58801s2LABV65ccfVQCCGgZGlCCHGqdevWoV+/fmjRogUOHTqEd955R18jiBDiehQIEUKIE/33v//FG2+8geLiYrRt2xYLFizA4sWLXT0sQkgdWhojhBBCiMei7fOEEEII8VgUCBFCCCHEY1EgRAghhBCPRYEQIYQQQjwWBUKEEEII8VgUCBFCCCHEY1EgRAghhBCPRYEQIYQQQjwWBUKEEEII8Vj/H/Mb3JPJ0Rq8AAAAAElFTkSuQmCC\n"},"metadata":{}}]},{"cell_type":"markdown","source":["- 3. Business Health"],"metadata":{"id":"KuNl4VMhpubr"}},{"cell_type":"code","source":["X_train = train_data[full_baseline_features+['treatment_x']].to_numpy()\n","X_test = test_data[full_baseline_features+['treatment_x']].to_numpy()\n","\n","Y_train = train_data['health_bus_ind'].to_numpy()\n","Y_test = test_data['health_bus_ind'].to_numpy()\n","\n","# Log-transform the wages\n","logY_train_usc = np.log10(Y_train)\n","logY_test_usc = np.log10(Y_test)\n","\n","# Scale the data\n","scaler = preprocessing.StandardScaler()\n","X_train_scaled = scaler.fit_transform(X_train)\n","X_test_scaled = scaler.transform(X_test)\n","\n","Y_train_scaled = scaler.fit_transform(Y_train.reshape(-1,1))\n","Y_test_scaled = scaler.transform(Y_test.reshape(-1,1))\n","\n","logY_train = scaler.fit_transform(logY_train_usc.reshape(-1,1))\n","logY_test = scaler.transform(logY_test_usc.reshape(-1,1))\n","\n","# Train a linear regression model on both original and log-transformed data\n","model_original = LinearRegression()\n","model_original.fit(X_train_scaled, Y_train_scaled)\n","\n","model_log_transformed = LinearRegression()\n","model_log_transformed.fit(X_train_scaled, logY_train)\n","\n","# Predict on the test set\n","y_pred_original = model_original.predict(X_test_scaled)\n","y_pred_log_transformed = model_log_transformed.predict(X_test_scaled)\n","\n","# Evaluate the models\n","mse_original = mean_squared_error(Y_test_scaled, y_pred_original)\n","mse_log_transformed = mean_squared_error(logY_test, y_pred_log_transformed)\n","\n","# Print mean squared error for both models\n","print(f'Mean Squared Error (Original): {mse_original}')\n","print(f'Mean Squared Error (Log Transformed): {mse_log_transformed}')\n","\n","# Plot the predicted versus actual values for both models\n","plt.scatter(Y_test_scaled, y_pred_original, label='Original Business Health Index')\n","plt.scatter(logY_test, y_pred_log_transformed, label='Log Transformed Business Health Index')\n","plt.xlabel('Actual Business Health Index')\n","plt.ylabel('Predicted Business Health Index')\n","plt.legend()\n","plt.show()"],"metadata":{"colab":{"base_uri":"https://localhost:8080/","height":453},"id":"hTgY760ipx0f","executionInfo":{"status":"error","timestamp":1706069473681,"user_tz":480,"elapsed":338,"user":{"displayName":"Ezinne Nwankwo","userId":"03581561058008593041"}},"outputId":"ad745dfb-a42e-410a-b981-c115749920a0"},"execution_count":null,"outputs":[{"output_type":"stream","name":"stderr","text":["<ipython-input-44-9e84ca5523fe>:8: RuntimeWarning: invalid value encountered in log10\n","  logY_train_usc = np.log10(Y_train)\n","<ipython-input-44-9e84ca5523fe>:9: RuntimeWarning: invalid value encountered in log10\n","  logY_test_usc = np.log10(Y_test)\n"]},{"output_type":"error","ename":"ValueError","evalue":"Input y contains NaN.","traceback":["\u001b[0;31m---------------------------------------------------------------------------\u001b[0m","\u001b[0;31mValueError\u001b[0m                                Traceback (most recent call last)","\u001b[0;32m<ipython-input-44-9e84ca5523fe>\u001b[0m in \u001b[0;36m<cell line: 27>\u001b[0;34m()\u001b[0m\n\u001b[1;32m     25\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     26\u001b[0m \u001b[0mmodel_log_transformed\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mLinearRegression\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 27\u001b[0;31m \u001b[0mmodel_log_transformed\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mfit\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mX_train_scaled\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mlogY_train\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     28\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     29\u001b[0m \u001b[0;31m# Predict on the test set\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n","\u001b[0;32m/usr/local/lib/python3.10/dist-packages/sklearn/linear_model/_base.py\u001b[0m in \u001b[0;36mfit\u001b[0;34m(self, X, y, sample_weight)\u001b[0m\n\u001b[1;32m    646\u001b[0m         \u001b[0maccept_sparse\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;32mFalse\u001b[0m \u001b[0;32mif\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mpositive\u001b[0m \u001b[0;32melse\u001b[0m \u001b[0;34m[\u001b[0m\u001b[0;34m\"csr\"\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m\"csc\"\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m\"coo\"\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    647\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 648\u001b[0;31m         X, y = self._validate_data(\n\u001b[0m\u001b[1;32m    649\u001b[0m             \u001b[0mX\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0my\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0maccept_sparse\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0maccept_sparse\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0my_numeric\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;32mTrue\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mmulti_output\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;32mTrue\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    650\u001b[0m         )\n","\u001b[0;32m/usr/local/lib/python3.10/dist-packages/sklearn/base.py\u001b[0m in \u001b[0;36m_validate_data\u001b[0;34m(self, X, y, reset, validate_separately, **check_params)\u001b[0m\n\u001b[1;32m    582\u001b[0m                 \u001b[0my\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mcheck_array\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0my\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0minput_name\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m\"y\"\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mcheck_y_params\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    583\u001b[0m             \u001b[0;32melse\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 584\u001b[0;31m                 \u001b[0mX\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0my\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mcheck_X_y\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mX\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0my\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mcheck_params\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    585\u001b[0m             \u001b[0mout\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mX\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0my\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    586\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n","\u001b[0;32m/usr/local/lib/python3.10/dist-packages/sklearn/utils/validation.py\u001b[0m in \u001b[0;36mcheck_X_y\u001b[0;34m(X, y, accept_sparse, accept_large_sparse, dtype, order, copy, force_all_finite, ensure_2d, allow_nd, multi_output, ensure_min_samples, ensure_min_features, y_numeric, estimator)\u001b[0m\n\u001b[1;32m   1120\u001b[0m     )\n\u001b[1;32m   1121\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m-> 1122\u001b[0;31m     \u001b[0my\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0m_check_y\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0my\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mmulti_output\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mmulti_output\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0my_numeric\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0my_numeric\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mestimator\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mestimator\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m   1123\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1124\u001b[0m     \u001b[0mcheck_consistent_length\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mX\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0my\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n","\u001b[0;32m/usr/local/lib/python3.10/dist-packages/sklearn/utils/validation.py\u001b[0m in \u001b[0;36m_check_y\u001b[0;34m(y, multi_output, y_numeric, estimator)\u001b[0m\n\u001b[1;32m   1130\u001b[0m     \u001b[0;34m\"\"\"Isolated part of check_X_y dedicated to y validation\"\"\"\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1131\u001b[0m     \u001b[0;32mif\u001b[0m \u001b[0mmulti_output\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m-> 1132\u001b[0;31m         y = check_array(\n\u001b[0m\u001b[1;32m   1133\u001b[0m             \u001b[0my\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1134\u001b[0m             \u001b[0maccept_sparse\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m\"csr\"\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n","\u001b[0;32m/usr/local/lib/python3.10/dist-packages/sklearn/utils/validation.py\u001b[0m in \u001b[0;36mcheck_array\u001b[0;34m(array, accept_sparse, accept_large_sparse, dtype, order, copy, force_all_finite, ensure_2d, allow_nd, ensure_min_samples, ensure_min_features, estimator, input_name)\u001b[0m\n\u001b[1;32m    919\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    920\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mforce_all_finite\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 921\u001b[0;31m             _assert_all_finite(\n\u001b[0m\u001b[1;32m    922\u001b[0m                 \u001b[0marray\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    923\u001b[0m                 \u001b[0minput_name\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0minput_name\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n","\u001b[0;32m/usr/local/lib/python3.10/dist-packages/sklearn/utils/validation.py\u001b[0m in \u001b[0;36m_assert_all_finite\u001b[0;34m(X, allow_nan, msg_dtype, estimator_name, input_name)\u001b[0m\n\u001b[1;32m    159\u001b[0m                 \u001b[0;34m\"#estimators-that-handle-nan-values\"\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    160\u001b[0m             )\n\u001b[0;32m--> 161\u001b[0;31m         \u001b[0;32mraise\u001b[0m \u001b[0mValueError\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mmsg_err\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    162\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    163\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n","\u001b[0;31mValueError\u001b[0m: Input y contains NaN."]}]},{"cell_type":"markdown","source":["- 4. Beneficiary Productive Revenue"],"metadata":{"id":"G8rM9SYguhRH"}},{"cell_type":"code","source":["X_train = train_data[full_baseline_features+['treatment_x']].to_numpy()\n","X_test = test_data[full_baseline_features+['treatment_x']].to_numpy()\n","\n","Y_train = train_data['tot_ben_rev12_ppp'].to_numpy()\n","\n","Y_test = test_data['tot_ben_rev12_ppp'].to_numpy()\n","# Scale the datascaler = preprocessing.StandardScaler()\n","X_train_scaled = scaler.fit_transform(X_train)\n","X_test_scaled = scaler.transform(X_test)\n","\n","Y_train_scaled = scaler.fit_transform(Y_train.reshape(-1,1))\n","Y_test_scaled = scaler.transform(Y_test.reshape(-1,1))\n","\n","# Log-transform the wages\n","logY_train = np.log1p(Y_train_scaled)\n","logY_test = np.log1p(Y_test_scaled)\n","\n","# Train a linear regression model on both original and log-transformed data\n","model_original = LinearRegression()\n","model_original.fit(X_train_scaled, Y_train_scaled)\n","\n","model_log_transformed = LinearRegression()\n","model_log_transformed.fit(X_train_scaled, logY_train)\n","\n","# Predict on the test set\n","y_pred_original = model_original.predict(X_test_scaled)\n","y_pred_log_transformed = model_log_transformed.predict(X_test_scaled)\n","\n","# Evaluate the models\n","mse_original = mean_squared_error(Y_test_scaled, y_pred_original)\n","mse_log_transformed = mean_squared_error(logY_test, y_pred_log_transformed)\n","\n","# Print mean squared error for both models\n","print(f'Mean Squared Error (Original): {mse_original}')\n","print(f'Mean Squared Error (Log Transformed): {mse_log_transformed}')\n","\n","# Plot the predicted versus actual values for both models\n","plt.scatter(Y_test_scaled, y_pred_original, label='Original Beneficiary Productive Revenue')\n","plt.scatter(logY_test, y_pred_log_transformed, label='Log Transformed Beneficiary Productive Revenue')\n","plt.xlabel('Actual Beneficiary Productive Revenue')\n","plt.ylabel('Predicted Beneficiary Productive Revenue')\n","plt.legend()\n","plt.show()"],"metadata":{"colab":{"base_uri":"https://localhost:8080/","height":483},"id":"jSuxFuh0uiD1","executionInfo":{"status":"ok","timestamp":1706070990294,"user_tz":480,"elapsed":728,"user":{"displayName":"Ezinne Nwankwo","userId":"03581561058008593041"}},"outputId":"e473d28a-e4a2-444e-8514-806b2f8a81a2"},"execution_count":null,"outputs":[{"output_type":"stream","name":"stdout","text":["Mean Squared Error (Original): 0.8141368820708406\n","Mean Squared Error (Log Transformed): 0.23892558370695965\n"]},{"output_type":"display_data","data":{"text/plain":["<Figure size 640x480 with 1 Axes>"],"image/png":"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\n"},"metadata":{}}]},{"cell_type":"markdown","source":["- 5. Asset Value"],"metadata":{"id":"HCJTot_ZwA8M"}},{"cell_type":"code","source":["X_train = train_data[full_baseline_features+['treatment_x']].to_numpy()\n","X_test = test_data[full_baseline_features+['treatment_x']].to_numpy()\n","\n","Y_train = train_data['bus_assval_98_ppp'].to_numpy()\n","\n","Y_test = test_data['bus_assval_98_ppp'].to_numpy()\n","# Scale the datascaler = preprocessing.StandardScaler()\n","X_train_scaled = scaler.fit_transform(X_train)\n","X_test_scaled = scaler.transform(X_test)\n","\n","Y_train_scaled = scaler.fit_transform(Y_train.reshape(-1,1))\n","Y_test_scaled = scaler.transform(Y_test.reshape(-1,1))\n","\n","# Log-transform the wages\n","logY_train = np.log1p(Y_train_scaled)\n","logY_test = np.log1p(Y_test_scaled)\n","\n","# Train a linear regression model on both original and log-transformed data\n","model_original = LinearRegression()\n","model_original.fit(X_train_scaled, Y_train_scaled)\n","\n","model_log_transformed = LinearRegression()\n","model_log_transformed.fit(X_train_scaled, logY_train)\n","\n","# Predict on the test set\n","y_pred_original = model_original.predict(X_test_scaled)\n","y_pred_log_transformed = model_log_transformed.predict(X_test_scaled)\n","\n","# Evaluate the models\n","mse_original = mean_squared_error(Y_test_scaled, y_pred_original)\n","mse_log_transformed = mean_squared_error(logY_test, y_pred_log_transformed)\n","\n","# Print mean squared error for both models\n","print(f'Mean Squared Error (Original): {mse_original}')\n","print(f'Mean Squared Error (Log Transformed): {mse_log_transformed}')\n","\n","# Plot the predicted versus actual values for both models\n","plt.scatter(Y_test_scaled, y_pred_original, label='Original Business Asset Value')\n","plt.scatter(logY_test, y_pred_log_transformed, label='Log Transformed Business Asset Value')\n","plt.xlabel('Actual Business Asset Value')\n","plt.ylabel('Predicted Business Asset Value')\n","plt.legend()\n","plt.show()"],"metadata":{"colab":{"base_uri":"https://localhost:8080/","height":483},"id":"gllXM_lmwEDP","executionInfo":{"status":"ok","timestamp":1706071070393,"user_tz":480,"elapsed":1767,"user":{"displayName":"Ezinne Nwankwo","userId":"03581561058008593041"}},"outputId":"1c6387f9-4ae5-4532-a11c-a72753ba323e"},"execution_count":null,"outputs":[{"output_type":"stream","name":"stdout","text":["Mean Squared Error (Original): 0.7891174764634193\n","Mean Squared Error (Log Transformed): 0.2407031684198673\n"]},{"output_type":"display_data","data":{"text/plain":["<Figure size 640x480 with 1 Axes>"],"image/png":"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\n"},"metadata":{}}]},{"cell_type":"markdown","source":["- 6. Investments"],"metadata":{"id":"gPl4INw2wwZN"}},{"cell_type":"code","source":["X_train = train_data[full_baseline_features+['treatment_x']].to_numpy()\n","X_test = test_data[full_baseline_features+['treatment_x']].to_numpy()\n","\n","Y_train = train_data['bus2_invest_ppp'].to_numpy()\n","\n","Y_test = test_data['bus2_invest_ppp'].to_numpy()\n","# Scale the datascaler = preprocessing.StandardScaler()\n","X_train_scaled = scaler.fit_transform(X_train)\n","X_test_scaled = scaler.transform(X_test)\n","\n","Y_train_scaled = scaler.fit_transform(Y_train.reshape(-1,1))\n","Y_test_scaled = scaler.transform(Y_test.reshape(-1,1))\n","\n","# Log-transform the wages\n","logY_train = np.log1p(Y_train_scaled)\n","logY_test = np.log1p(Y_test_scaled)\n","\n","# Train a linear regression model on both original and log-transformed data\n","model_original = LinearRegression()\n","model_original.fit(X_train_scaled, Y_train_scaled)\n","\n","model_log_transformed = LinearRegression()\n","model_log_transformed.fit(X_train_scaled, logY_train)\n","\n","# Predict on the test set\n","y_pred_original = model_original.predict(X_test_scaled)\n","y_pred_log_transformed = model_log_transformed.predict(X_test_scaled)\n","\n","# Evaluate the models\n","mse_original = mean_squared_error(Y_test_scaled, y_pred_original)\n","mse_log_transformed = mean_squared_error(logY_test, y_pred_log_transformed)\n","\n","# Print mean squared error for both models\n","print(f'Mean Squared Error (Original): {mse_original}')\n","print(f'Mean Squared Error (Log Transformed): {mse_log_transformed}')\n","\n","# Plot the predicted versus actual values for both models\n","plt.scatter(Y_test_scaled, y_pred_original, label='Original Investments')\n","plt.scatter(logY_test, y_pred_log_transformed, label='Log Transformed Investments')\n","plt.xlabel('Actual Investments')\n","plt.ylabel('Predicted Investments')\n","plt.legend()\n","plt.show()"],"metadata":{"colab":{"base_uri":"https://localhost:8080/","height":483},"id":"QM10A2A2wv3o","executionInfo":{"status":"ok","timestamp":1706071181438,"user_tz":480,"elapsed":823,"user":{"displayName":"Ezinne Nwankwo","userId":"03581561058008593041"}},"outputId":"2843e916-778a-4413-9251-4b17868979d9"},"execution_count":null,"outputs":[{"output_type":"stream","name":"stdout","text":["Mean Squared Error (Original): 0.7160541601379695\n","Mean Squared Error (Log Transformed): 0.24185482119864044\n"]},{"output_type":"display_data","data":{"text/plain":["<Figure size 640x480 with 1 Axes>"],"image/png":"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\n"},"metadata":{}}]},{"cell_type":"markdown","source":["- 7. Savings"],"metadata":{"id":"K_iA936qxO1U"}},{"cell_type":"code","source":["X_train = train_data[full_baseline_features+['treatment_x']].to_numpy()\n","X_test = test_data[full_baseline_features+['treatment_x']].to_numpy()\n","\n","Y_train = train_data['tot_sav3_ppp'].to_numpy()\n","\n","Y_test = test_data['tot_sav3_ppp'].to_numpy()\n","# Scale the datascaler = preprocessing.StandardScaler()\n","X_train_scaled = scaler.fit_transform(X_train)\n","X_test_scaled = scaler.transform(X_test)\n","\n","Y_train_scaled = scaler.fit_transform(Y_train.reshape(-1,1))\n","Y_test_scaled = scaler.transform(Y_test.reshape(-1,1))\n","\n","# Log-transform the wages\n","logY_train = np.log1p(Y_train_scaled)\n","logY_test = np.log1p(Y_test_scaled)\n","\n","# Train a linear regression model on both original and log-transformed data\n","model_original = LinearRegression()\n","model_original.fit(X_train_scaled, Y_train_scaled)\n","\n","model_log_transformed = LinearRegression()\n","model_log_transformed.fit(X_train_scaled, logY_train)\n","\n","# Predict on the test set\n","y_pred_original = model_original.predict(X_test_scaled)\n","y_pred_log_transformed = model_log_transformed.predict(X_test_scaled)\n","\n","# Evaluate the models\n","mse_original = mean_squared_error(Y_test_scaled, y_pred_original)\n","mse_log_transformed = mean_squared_error(logY_test, y_pred_log_transformed)\n","\n","# Print mean squared error for both models\n","print(f'Mean Squared Error (Original): {mse_original}')\n","print(f'Mean Squared Error (Log Transformed): {mse_log_transformed}')\n","\n","# Plot the predicted versus actual values for both models\n","plt.scatter(Y_test_scaled, y_pred_original, label='Original Savings')\n","plt.scatter(logY_test, y_pred_log_transformed, label='Log Transformed Savings')\n","plt.xlabel('Actual Savings')\n","plt.ylabel('Predicted Savings')\n","plt.legend()\n","plt.show()"],"metadata":{"colab":{"base_uri":"https://localhost:8080/","height":483},"id":"nQdzjH1BxR4k","executionInfo":{"status":"ok","timestamp":1706071304569,"user_tz":480,"elapsed":1123,"user":{"displayName":"Ezinne Nwankwo","userId":"03581561058008593041"}},"outputId":"421d6c14-a809-4edd-9b04-2b2c859b4484"},"execution_count":null,"outputs":[{"output_type":"stream","name":"stdout","text":["Mean Squared Error (Original): 0.8507558141449181\n","Mean Squared Error (Log Transformed): 0.1917461514424349\n"]},{"output_type":"display_data","data":{"text/plain":["<Figure size 640x480 with 1 Axes>"],"image/png":"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Erp27Qp/f38EBgbisccew7lz57TPx8XFVdhcdP36dbi5uWHv3r0AKk6NCYKAr776Co8//jhq1aqFpk2bYvNm3e/jzZs3a/8+/vOf/+Dbb7+FIAi4ffs2AHXpkfj4eNSpUwe1a9dGy5Yt8csvv5h8zZXFQMgBSN1dduFGYTX3hIgsLn0z8MMIIO+q7vG8TPVxGwRDV65cQb9+/dCxY0ccP34cixcvxtdff40PPvhA22by5MnYv38/Nm/ejB07duCPP/5Aampqle773nvv4fHHH8eJEyfw/PPPQ6VSoWHDhvjxxx+Rnp6O6dOn46233sIPP/ygc97u3btx7tw57N69G99++y2WL1+O5cuXAwCOHDmCCRMm4P3338eZM2eQlJSEhx56CACwYMECvP/++2jYsCEyMzO1wc6bb76J9evX49tvv0VqaioeeOAB9OnTBzk5ujndpk6ditmzZ+PUqVNo06YNAODbb79F3bp1kZKSgvHjx2P06NF46qmnEBcXh9TUVPTu3RvDhw9HUVERAOD27dvo3r07HnzwQRw5cgRJSUm4du0ann76ae193njjDfz+++/46aef8Ouvv2LPnj0m32u5XI5du3bh+vXrBtsUFhZi8uTJOHLkCHbu3AmZTIbHH39cm3svISEBa9asQdk9VWvXrkVISAi6detm8LozZszA008/jT///BP9+vVDQkKC9r3LyMjAk08+iUGDBuH48eN4+eWX8fbbb+ucP3bsWBQXF2Pv3r04ceIE5syZA29vb6Ovt0pEMio3N1cEIObm5tqsD6VKldj5o9/E8ClbxTATX9tOXLVZP4lqmjt37ojp6eninTt3KncBZakozo0UxURfA19+oji3hbqdhY0cOVIcOHCg3ufeeustsXnz5qJKpdIeW7Rokejt7S0qlUoxLy9PdHNzE3/88Uft87dv3xZr1aolTpw40eS9MzIyRADisWPHtMcAiJMmTTJ57tixY8XBgwfrvI6wsDCxtPT+e/TUU0+JQ4YMEUVRFNevXy/6+vqKeXl5eq83b948MSwsTPu4oKBAdHNzE1euXKk9VlJSIoaEhIgff/yxKIqiuHv3bhGAuGnTJp1rPfzww2LXrl21j0tLS8XatWuLw4cP1x7LzMwUAYjJycmiKIrizJkzxd69e+tc5/LlyyIA8cyZM2J+fr7o7u4u/vDDD9rnb968KXp5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Phw3b95EUVERAKBfv35wc3PD5s2bAQDr16+Hr68vevbsafTebdq00f45ODgYAJCdnQ1A/b5qRs00yj4OCAjAs88+iz59+iA+Ph4LFiwwazSNiHQxECKiSvn6669RWlqKkJAQuLq6wtXVFYsXL8b69euRm5sLAPDy8jL7ujKZTGd6DQAUCoXO45EjRyItLQ0LFizAgQMHkJaWhsDAQJSUlJh1L09PT/Tq1QvvvvsuDhw4gGeffRaJiYkA1FvfH3vsMbRp0wbr16/H0aNHsWjRIgDQ3sfd3R1PPvmkdnps1apVGDJkCFxdje9DcXNz0/5ZM6WlUqkk9/t///sfkpOTERcXh7Vr16JZs2Y4ePCg9BdORFoMhIjIbKWlpVixYgXmzp2LtLQ07dfx48cREhKC1atXA1CPfOzcudPgddzd3aFUKnWO1atXD1lZWTrBUPk8PPv378eECRPQr18/tGzZEh4eHrhx40aVX1dUVBQKCwsBAEePHoVKpcLcuXPRuXNnNGvWDFevXq1wTkJCApKSkvDXX39h165dSEhIqFIfmjdvjsOHD+scK/8YAB588EFMmzYNBw4cQKtWrSqsVSIiabh9nojMtnXrVty6dQujRo2Cn5+fznODBw/G119/jVdeeQWJiYno0aMHmjRpgqFDh6K0tBS//PILpkyZAkCdR2jv3r0YOnQoPDw8ULduXTzyyCO4fv06Pv74Yzz55JNISkrCtm3b4Ovrq71H06ZN8d133yE6Ohp5eXl44403zBp9unnzJp566ik8//zzaNOmDXx8fHDkyBF8/PHHGDhwIADggQcegEKhwOeff474+Hjs378fS5YsqXCthx56CHK5HAkJCYiIiECnTp0q85ZqjR8/Hi+++CKio6O1Iz5//vknGjduDADIyMjA0qVLMWDAAISEhODMmTP4+++/MWLEiCrdl6jGsvUiJSJyPI899pjYr18/vc8dOnRIBKBdeLx+/XqxXbt2oru7u1i3bl3xiSee0LZNTk4W27RpI3p4eIhl/zlavHixGBoaKtauXVscMWKE+OGHH+oslk5NTRWjo6NFT09PsWnTpuKPP/5YYeE1jCyWvnv3rjh16lSxffv2op+fn1irVi2xefPm4jvvvCMWFRVp23322WdicHCw6OXlJfbp00dcsWKFCEC8deuWzvXefPNNEYA4ffp0neOGFkuXPf/YsWMiADEjI0N77P333xfr1q0rent7i88//7w4YcIEsXPnzqIoimJWVpY4aNAgMTg4WHR3dxfDwsLE6dOni0qlUu9rJSLjBFEsNxlPRER2pVevXpDL5fjuu+9s3RUip8OpMSIiO1JUVIQlS5agT58+cHFxwerVq/Hbb79hx44dtu4akVPiiBARkR25c+cO4uPjcezYMdy9exfNmzfHO++8gyeeeMLWXSNySgyEiIiIqMbi9nkiIiKqsRgIERERUY3FQIiIiIhqLAZCREREVGMxECIiIqIai4EQERER1VgMhIiIiKjGYiBERERENdb/A56fifCHtAojAAAAAElFTkSuQmCC\n"},"metadata":{}}]},{"cell_type":"markdown","source":["## 3. Policy Optimization"],"metadata":{"id":"Iziht1BG8UZD"}},{"cell_type":"code","source":["X_train = train_data[full_baseline_features].to_numpy()\n","T_train = train_data['treatment_x'].to_numpy()\n","Y_train = train_data[financial_outcomes].to_numpy()\n","\n","X_test = test_data[full_baseline_features].to_numpy()\n","T_test = test_data['treatment_x'].to_numpy()\n","Y_test = test_data[financial_outcomes].to_numpy()\n","\n","# Standardize X data\n","from sklearn import preprocessing\n","x_scaler_train = preprocessing.StandardScaler().fit(X_train)\n","X_train_sc = x_scaler_train.transform(X_train)\n","x_scaler_test = preprocessing.StandardScaler().fit(X_test)\n","X_test_sc = x_scaler_test.transform(X_test)"],"metadata":{"id":"Dt4MHvOr0AY4"},"execution_count":null,"outputs":[]},{"cell_type":"markdown","source":["### Without Log Transformation"],"metadata":{"id":"nUWBz1rszel5"}},{"cell_type":"code","source":["# Standardize negative Y data so that we are maximizing\n","y_scaler_train = preprocessing.StandardScaler().fit(-Y_train)\n","Y_train_sc = y_scaler_train.transform(-Y_train)\n","y_scaler_test = preprocessing.StandardScaler().fit(-Y_test)\n","Y_test_sc = y_scaler_test.transform(-Y_test)"],"metadata":{"id":"8vyIeSC2kupT"},"execution_count":null,"outputs":[]},{"cell_type":"code","source":["np.random.seed(9827)\n","rho = np.random.randn(1, Y_train_sc.shape[1])\n","print(np.round(rho,4))"],"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"qxb--xvn7_Wk","executionInfo":{"status":"ok","timestamp":1706812263852,"user_tz":480,"elapsed":224,"user":{"displayName":"Ezinne Nwankwo","userId":"03581561058008593041"}},"outputId":"4e7fc364-eed7-431a-a215-ca770c1694ee"},"execution_count":null,"outputs":[{"output_type":"stream","name":"stdout","text":["[[-1.1751 -1.0402 -1.3361  0.0082  0.4042  2.3783 -1.2227]]\n"]}]},{"cell_type":"code","source":["##### Policy Optimization Attempt 2\n","# storage\n","np.random.seed(9827)\n","rho = np.random.randn(1, Y_train_sc.shape[1])\n","var_results = np.zeros((6,5))\n","polval_results = np.zeros((6,5))\n","polval_true = np.zeros((6,5))\n","method_tr = ['direct', 'direct','IPW-obs','IPW','DR-obs', 'CV']\n","z_est_tr = [False, True, False, True, False, True]\n","method_te = ['direct', 'IPW-obs','DR-obs','DR']\n","z_est_te = [True, False, False, False]\n","\n","for i in range(var_results.shape[0]):\n","  results = optimization_v3.subgradient_descent(num_iter = 60,step_size = 3,key_start=1,X_samples=X_train_sc, T_samples = T_train, Y_samples = Y_train_sc, rho = rho, method = method_tr[i], Z_estimation=z_est_tr[i])\n","  opt_idx = results['obj_values'].argmin()\n","  phi_opt = results['phi_values'][opt_idx]\n","  b_opt = results['b_values'][opt_idx]\n","\n","  #print(i)\n","  #print('Phi_opt:',phi_opt)\n","  #print('B_opt:',b_opt)\n","\n","  mu_0_list_self, mu_1_list_self = optimization_v3.gen_mu_values(X_samples=X_test_sc, T_samples=T_test,Y_samples=Y_test_sc, rho=rho, method=method_tr[i],Z_estimation=z_est_tr[i])\n","  pol_value_self, pi_0_list_self, pi_1_list_self = optimization_v3.compute_x_opt(phi=phi_opt, b=b_opt, X_samples=X_test_sc, T_samples=T_test, mu_0_list=mu_0_list_self,mu_1_list=mu_1_list_self)\n","\n","  var_results[i,0] = np.std(pi_0_list_self + pi_1_list_self)\n","  polval_true[i,0] = pol_value_self\n","  polval_results[i,0] = np.mean(pi_0_list_self + pi_1_list_self)\n","\n","  for j in range(1,var_results.shape[1]):\n","\n","    mu_0_list, mu_1_list = optimization_v3.gen_mu_values(X_samples=X_test_sc, T_samples=T_test,Y_samples=Y_test_sc, rho=rho, method=method_te[j-1],Z_estimation=z_est_te[j-1])\n","    pol_value, pi_0_list, pi_1_list = optimization_v3.compute_x_opt(phi=phi_opt, b=b_opt, X_samples=X_test_sc, T_samples=T_test, mu_0_list=mu_0_list,mu_1_list=mu_1_list)\n","\n","    var_results[i,j] = np.std(pi_0_list + pi_1_list)\n","    polval_true[i,j] = pol_value\n","    polval_results[i,j] = np.mean(pi_0_list + pi_1_list)\n","\n","print('######## RANK=2 ########')\n","print('Out-of-sample Variances:', np.round(var_results,3))\n","print('Policy Values:', np.round(polval_results,3))\n","print('Policy Values Direct:', np.round(polval_true,3))\n"],"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"lyG7dYdN5eUN","executionInfo":{"status":"ok","timestamp":1706072131542,"user_tz":480,"elapsed":153745,"user":{"displayName":"Ezinne Nwankwo","userId":"03581561058008593041"}},"outputId":"2e487690-da50-4405-8f48-c5d692ac56aa"},"execution_count":null,"outputs":[{"output_type":"stream","name":"stdout","text":["Out-of-sample Variances: [[0.726 0.342 4.479 4.435 0.973]\n"," [0.364 0.364 4.182 4.128 0.962]\n"," [4.103 0.351 4.103 4.045 0.935]\n"," [0.642 0.363 4.215 4.162 0.974]\n"," [4.103 0.352 4.16  4.103 0.946]\n"," [0.644 0.363 4.215 4.162 0.974]]\n","Policy Values: [[0.036 0.078 0.131 0.13  0.054]\n"," [0.041 0.041 0.103 0.108 0.127]\n"," [0.155 0.074 0.155 0.158 0.112]\n"," [0.03  0.036 0.098 0.104 0.112]\n"," [0.185 0.079 0.185 0.185 0.113]\n"," [0.03  0.036 0.098 0.104 0.112]]\n","Policy Values Direct: [[0.036 0.078 0.131 0.13  0.054]\n"," [0.041 0.041 0.103 0.108 0.127]\n"," [0.155 0.074 0.155 0.158 0.112]\n"," [0.03  0.036 0.098 0.104 0.112]\n"," [0.185 0.079 0.185 0.185 0.113]\n"," [0.03  0.036 0.098 0.104 0.112]]\n"]}]},{"cell_type":"markdown","source":["- Try different ranks"],"metadata":{"id":"B8uTT3Uw0rpG"}},{"cell_type":"code","source":["##### Policy Optimization Attempt 2\n","# storage\n","np.random.seed(9827)\n","rho = np.random.randn(1, Y_train_sc.shape[1])\n","rank = 3\n","var_results = np.zeros((6,5))\n","polval_results = np.zeros((6,5))\n","polval_true = np.zeros((6,5))\n","method_tr = ['direct', 'direct','IPW-obs','IPW','DR-obs', 'CV']\n","z_est_tr = [False, True, False, True, False, True]\n","method_te = ['direct', 'IPW-obs','DR-obs','DR']\n","z_est_te = [True, False, False, False]\n","\n","for i in range(var_results.shape[0]):\n","  results = optimization_v3.subgradient_descent(num_iter = 60,step_size = 3,key_start=1,X_samples=X_train_sc, T_samples = T_train, Y_samples = Y_train_sc, rank=rank, rho = rho, method = method_tr[i], Z_estimation=z_est_tr[i])\n","  opt_idx = results['obj_values'].argmin()\n","  phi_opt = results['phi_values'][opt_idx]\n","  b_opt = results['b_values'][opt_idx]\n","\n","  #print(i)\n","  #print('Phi_opt:',phi_opt)\n","  #print('B_opt:',b_opt)\n","\n","  mu_0_list_self, mu_1_list_self = optimization_v3.gen_mu_values(X_samples=X_test_sc, T_samples=T_test,Y_samples=Y_test_sc, rank=rank, rho=rho, method=method_tr[i],Z_estimation=z_est_tr[i])\n","  pol_value_self, pi_0_list_self, pi_1_list_self = optimization_v3.compute_x_opt(phi=phi_opt, b=b_opt, X_samples=X_test_sc, T_samples=T_test, mu_0_list=mu_0_list_self,mu_1_list=mu_1_list_self)\n","\n","  var_results[i,0] = np.std(pi_0_list_self + pi_1_list_self)\n","  polval_true[i,0] = pol_value_self\n","  polval_results[i,0] = np.mean(pi_0_list_self + pi_1_list_self)\n","\n","  for j in range(1,var_results.shape[1]):\n","\n","    mu_0_list, mu_1_list = optimization_v3.gen_mu_values(X_samples=X_test_sc, T_samples=T_test,Y_samples=Y_test_sc, rank=rank, rho=rho, method=method_te[j-1],Z_estimation=z_est_te[j-1])\n","    pol_value, pi_0_list, pi_1_list = optimization_v3.compute_x_opt(phi=phi_opt, b=b_opt, X_samples=X_test_sc, T_samples=T_test, mu_0_list=mu_0_list,mu_1_list=mu_1_list)\n","\n","    var_results[i,j] = np.std(pi_0_list + pi_1_list)\n","    polval_true[i,j] = pol_value\n","    polval_results[i,j] = np.mean(pi_0_list + pi_1_list)\n","\n","print('######## RANK=3 ########')\n","print('Out-of-sample Variances:', np.round(var_results,3))\n","print('Policy Values:', np.round(polval_results,3))\n","print('Policy Values Direct:', np.round(polval_true,3))"],"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"AHNdJNSo0ZyZ","executionInfo":{"status":"ok","timestamp":1706073275133,"user_tz":480,"elapsed":121295,"user":{"displayName":"Ezinne Nwankwo","userId":"03581561058008593041"}},"outputId":"a2429d4a-40f0-44fe-ac7c-c1b9853be4a5"},"execution_count":null,"outputs":[{"output_type":"stream","name":"stdout","text":["######## RANK=3 ########\n","Out-of-sample Variances: [[0.726 0.455 4.479 4.425 0.944]\n"," [0.465 0.465 4.176 4.128 0.936]\n"," [4.103 0.457 4.103 4.039 0.898]\n"," [0.713 0.464 4.193 4.146 0.937]\n"," [4.196 0.453 4.259 4.196 0.919]\n"," [0.714 0.464 4.193 4.146 0.937]]\n","Policy Values: [[0.036 0.041 0.131 0.124 0.049]\n"," [0.058 0.058 0.071 0.073 0.099]\n"," [0.155 0.073 0.155 0.149 0.104]\n"," [0.059 0.06  0.077 0.077 0.102]\n"," [0.195 0.077 0.205 0.195 0.115]\n"," [0.059 0.06  0.077 0.077 0.102]]\n","Policy Values Direct: [[0.036 0.041 0.131 0.124 0.049]\n"," [0.058 0.058 0.071 0.073 0.099]\n"," [0.155 0.073 0.155 0.149 0.104]\n"," [0.059 0.06  0.077 0.077 0.102]\n"," [0.195 0.077 0.205 0.195 0.115]\n"," [0.059 0.06  0.077 0.077 0.102]]\n"]}]},{"cell_type":"code","source":["##### Policy Optimization Attempt 2\n","# storage\n","np.random.seed(9827)\n","rho = np.random.randn(1, Y_train_sc.shape[1])\n","rank = 4\n","var_results = np.zeros((6,5))\n","polval_results = np.zeros((6,5))\n","polval_true = np.zeros((6,5))\n","method_tr = ['direct', 'direct','IPW-obs','IPW','DR-obs', 'CV']\n","z_est_tr = [False, True, False, True, False, True]\n","method_te = ['direct', 'IPW-obs','DR-obs','DR']\n","z_est_te = [True, False, False, False]\n","\n","for i in range(var_results.shape[0]):\n","  results = optimization_v3.subgradient_descent(num_iter = 60,step_size = 3,key_start=1,X_samples=X_train_sc, T_samples = T_train, Y_samples = Y_train_sc, rank=rank, rho = rho, method = method_tr[i], Z_estimation=z_est_tr[i])\n","  opt_idx = results['obj_values'].argmin()\n","  phi_opt = results['phi_values'][opt_idx]\n","  b_opt = results['b_values'][opt_idx]\n","\n","  #print(i)\n","  #print('Phi_opt:',phi_opt)\n","  #print('B_opt:',b_opt)\n","\n","  mu_0_list_self, mu_1_list_self = optimization_v3.gen_mu_values(X_samples=X_test_sc, T_samples=T_test,Y_samples=Y_test_sc, rank=rank, rho=rho, method=method_tr[i],Z_estimation=z_est_tr[i])\n","  pol_value_self, pi_0_list_self, pi_1_list_self = optimization_v3.compute_x_opt(phi=phi_opt, b=b_opt, X_samples=X_test_sc, T_samples=T_test, mu_0_list=mu_0_list_self,mu_1_list=mu_1_list_self)\n","\n","  var_results[i,0] = np.std(pi_0_list_self + pi_1_list_self)\n","  polval_true[i,0] = pol_value_self\n","  polval_results[i,0] = np.mean(pi_0_list_self + pi_1_list_self)\n","\n","  for j in range(1,var_results.shape[1]):\n","\n","    mu_0_list, mu_1_list = optimization_v3.gen_mu_values(X_samples=X_test_sc, T_samples=T_test,Y_samples=Y_test_sc, rank=rank, rho=rho, method=method_te[j-1],Z_estimation=z_est_te[j-1])\n","    pol_value, pi_0_list, pi_1_list = optimization_v3.compute_x_opt(phi=phi_opt, b=b_opt, X_samples=X_test_sc, T_samples=T_test, mu_0_list=mu_0_list,mu_1_list=mu_1_list)\n","\n","    var_results[i,j] = np.std(pi_0_list + pi_1_list)\n","    polval_true[i,j] = pol_value\n","    polval_results[i,j] = np.mean(pi_0_list + pi_1_list)\n","\n","print('######## RANK=4 ########')\n","print('Out-of-sample Variances:', np.round(var_results,3))\n","print('Policy Values:', np.round(polval_results,3))\n","print('Policy Values Direct:', np.round(polval_true,3))"],"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"T1u7zmB83jsk","executionInfo":{"status":"ok","timestamp":1706073436856,"user_tz":480,"elapsed":124269,"user":{"displayName":"Ezinne Nwankwo","userId":"03581561058008593041"}},"outputId":"a253cc80-4d02-4a8d-fc97-8d541bf63477"},"execution_count":null,"outputs":[{"output_type":"stream","name":"stdout","text":["######## RANK=4 ########\n","Out-of-sample Variances: [[0.726 0.548 4.479 4.435 0.916]\n"," [0.55  0.55  4.142 4.101 0.862]\n"," [4.103 0.536 4.103 4.052 0.869]\n"," [0.759 0.549 4.144 4.105 0.86 ]\n"," [4.409 0.548 4.455 4.409 0.926]\n"," [0.761 0.549 4.144 4.105 0.86 ]]\n","Policy Values: [[ 0.036  0.014  0.131  0.12   0.045]\n"," [-0.011 -0.011  0.114  0.097  0.072]\n"," [ 0.155  0.025  0.155  0.144  0.099]\n"," [ 0.008 -0.009  0.127  0.109  0.079]\n"," [ 0.129  0.035  0.148  0.129  0.077]\n"," [ 0.008 -0.009  0.127  0.109  0.079]]\n","Policy Values Direct: [[ 0.036  0.014  0.131  0.12   0.045]\n"," [-0.011 -0.011  0.114  0.097  0.072]\n"," [ 0.155  0.025  0.155  0.144  0.099]\n"," [ 0.008 -0.009  0.127  0.109  0.079]\n"," [ 0.129  0.035  0.148  0.129  0.077]\n"," [ 0.008 -0.009  0.127  0.109  0.079]]\n"]}]},{"cell_type":"code","source":["##### Policy Optimization Attempt 2\n","# storage\n","np.random.seed(9827)\n","rho = np.random.randn(1, Y_train_sc.shape[1])\n","rank = 5\n","var_results = np.zeros((6,5))\n","polval_results = np.zeros((6,5))\n","polval_true = np.zeros((6,5))\n","method_tr = ['direct', 'direct','IPW-obs','IPW','DR-obs', 'CV']\n","z_est_tr = [False, True, False, True, False, True]\n","method_te = ['direct', 'IPW-obs','DR-obs','DR']\n","z_est_te = [True, False, False, False]\n","\n","for i in range(var_results.shape[0]):\n","  results = optimization_v3.subgradient_descent(num_iter = 60,step_size = 3,key_start=1,X_samples=X_train_sc, T_samples = T_train, Y_samples = Y_train_sc, rank=rank, rho = rho, method = method_tr[i], Z_estimation=z_est_tr[i])\n","  opt_idx = results['obj_values'].argmin()\n","  phi_opt = results['phi_values'][opt_idx]\n","  b_opt = results['b_values'][opt_idx]\n","\n","  #print(i)\n","  #print('Phi_opt:',phi_opt)\n","  #print('B_opt:',b_opt)\n","\n","  mu_0_list_self, mu_1_list_self = optimization_v3.gen_mu_values(X_samples=X_test_sc, T_samples=T_test,Y_samples=Y_test_sc, rank=rank, rho=rho, method=method_tr[i],Z_estimation=z_est_tr[i])\n","  pol_value_self, pi_0_list_self, pi_1_list_self = optimization_v3.compute_x_opt(phi=phi_opt, b=b_opt, X_samples=X_test_sc, T_samples=T_test, mu_0_list=mu_0_list_self,mu_1_list=mu_1_list_self)\n","\n","  var_results[i,0] = np.std(pi_0_list_self + pi_1_list_self)\n","  polval_true[i,0] = pol_value_self\n","  polval_results[i,0] = np.mean(pi_0_list_self + pi_1_list_self)\n","\n","  for j in range(1,var_results.shape[1]):\n","\n","    mu_0_list, mu_1_list = optimization_v3.gen_mu_values(X_samples=X_test_sc, T_samples=T_test,Y_samples=Y_test_sc, rank=rank, rho=rho, method=method_te[j-1],Z_estimation=z_est_te[j-1])\n","    pol_value, pi_0_list, pi_1_list = optimization_v3.compute_x_opt(phi=phi_opt, b=b_opt, X_samples=X_test_sc, T_samples=T_test, mu_0_list=mu_0_list,mu_1_list=mu_1_list)\n","\n","    var_results[i,j] = np.std(pi_0_list + pi_1_list)\n","    polval_true[i,j] = pol_value\n","    polval_results[i,j] = np.mean(pi_0_list + pi_1_list)\n","\n","print('######## RANK=5 ########')\n","print('Out-of-sample Variances:', np.round(var_results,3))\n","print('Policy Values:', np.round(polval_results,3))\n","print('Policy Values Direct:', np.round(polval_true,3))"],"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"ltuKjMof3uW6","executionInfo":{"status":"ok","timestamp":1706073610127,"user_tz":480,"elapsed":124881,"user":{"displayName":"Ezinne Nwankwo","userId":"03581561058008593041"}},"outputId":"af2d60d5-83fa-4650-f0fe-56328f8193b4"},"execution_count":null,"outputs":[{"output_type":"stream","name":"stdout","text":["######## RANK=5 ########\n","Out-of-sample Variances: [[0.726 0.617 4.479 4.418 0.848]\n"," [0.615 0.615 4.168 4.099 0.816]\n"," [4.103 0.599 4.103 4.031 0.807]\n"," [0.887 0.614 4.164 4.097 0.815]\n"," [4.397 0.628 4.469 4.397 0.836]\n"," [0.889 0.614 4.164 4.097 0.815]]\n","Policy Values: [[ 0.036  0.002  0.131  0.115  0.04 ]\n"," [-0.    -0.     0.118  0.1    0.07 ]\n"," [ 0.155  0.048  0.155  0.149  0.104]\n"," [ 0.022  0.005  0.13   0.112  0.077]\n"," [ 0.129  0.041  0.145  0.129  0.079]\n"," [ 0.023  0.005  0.13   0.112  0.077]]\n","Policy Values Direct: [[ 0.036  0.002  0.131  0.115  0.04 ]\n"," [-0.    -0.     0.118  0.1    0.07 ]\n"," [ 0.155  0.048  0.155  0.149  0.104]\n"," [ 0.022  0.005  0.13   0.112  0.077]\n"," [ 0.129  0.041  0.145  0.129  0.079]\n"," [ 0.023  0.005  0.13   0.112  0.077]]\n"]}]},{"cell_type":"code","source":["##### Policy Optimization Attempt 2\n","# storage\n","np.random.seed(9827)\n","rho = np.random.randn(1, Y_train_sc.shape[1])\n","rank = 6\n","var_results = np.zeros((6,5))\n","polval_results = np.zeros((6,5))\n","polval_true = np.zeros((6,5))\n","method_tr = ['direct', 'direct','IPW-obs','IPW','DR-obs', 'CV']\n","z_est_tr = [False, True, False, True, False, True]\n","method_te = ['direct', 'IPW-obs','DR-obs','DR']\n","z_est_te = [True, False, False, False]\n","\n","for i in range(var_results.shape[0]):\n","  results = optimization_v3.subgradient_descent(num_iter = 60,step_size = 3,key_start=1,X_samples=X_train_sc, T_samples = T_train, Y_samples = Y_train_sc, rank=rank, rho = rho, method = method_tr[i], Z_estimation=z_est_tr[i])\n","  opt_idx = results['obj_values'].argmin()\n","  phi_opt = results['phi_values'][opt_idx]\n","  b_opt = results['b_values'][opt_idx]\n","\n","  #print(i)\n","  #print('Phi_opt:',phi_opt)\n","  #print('B_opt:',b_opt)\n","\n","  mu_0_list_self, mu_1_list_self = optimization_v3.gen_mu_values(X_samples=X_test_sc, T_samples=T_test,Y_samples=Y_test_sc, rank=rank, rho=rho, method=method_tr[i],Z_estimation=z_est_tr[i])\n","  pol_value_self, pi_0_list_self, pi_1_list_self = optimization_v3.compute_x_opt(phi=phi_opt, b=b_opt, X_samples=X_test_sc, T_samples=T_test, mu_0_list=mu_0_list_self,mu_1_list=mu_1_list_self)\n","\n","  var_results[i,0] = np.std(pi_0_list_self + pi_1_list_self)\n","  polval_true[i,0] = pol_value_self\n","  polval_results[i,0] = np.mean(pi_0_list_self + pi_1_list_self)\n","\n","  for j in range(1,var_results.shape[1]):\n","\n","    mu_0_list, mu_1_list = optimization_v3.gen_mu_values(X_samples=X_test_sc, T_samples=T_test,Y_samples=Y_test_sc, rank=rank, rho=rho, method=method_te[j-1],Z_estimation=z_est_te[j-1])\n","    pol_value, pi_0_list, pi_1_list = optimization_v3.compute_x_opt(phi=phi_opt, b=b_opt, X_samples=X_test_sc, T_samples=T_test, mu_0_list=mu_0_list,mu_1_list=mu_1_list)\n","\n","    var_results[i,j] = np.std(pi_0_list + pi_1_list)\n","    polval_true[i,j] = pol_value\n","    polval_results[i,j] = np.mean(pi_0_list + pi_1_list)\n","\n","print('######## RANK=6 ########')\n","print('Out-of-sample Variances:', np.round(var_results,3))\n","print('Policy Values:', np.round(polval_results,3))\n","print('Policy Values Direct:', np.round(polval_true,3))"],"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"JeFYE8Lr3xI-","executionInfo":{"status":"ok","timestamp":1706073961408,"user_tz":480,"elapsed":123694,"user":{"displayName":"Ezinne Nwankwo","userId":"03581561058008593041"}},"outputId":"96251684-6cc4-4688-b3e3-9c4bf3e9f698"},"execution_count":null,"outputs":[{"output_type":"stream","name":"stdout","text":["######## RANK=6 ########\n","Out-of-sample Variances: [[0.726 0.695 4.479 4.419 0.757]\n"," [0.69  0.69  4.171 4.115 0.734]\n"," [4.103 0.679 4.103 4.028 0.72 ]\n"," [1.045 0.686 4.156 4.102 0.733]\n"," [4.265 0.7   4.322 4.265 0.743]\n"," [1.046 0.686 4.156 4.102 0.733]]\n","Policy Values: [[0.036 0.025 0.131 0.114 0.039]\n"," [0.052 0.052 0.146 0.123 0.069]\n"," [0.155 0.105 0.155 0.158 0.113]\n"," [0.082 0.058 0.157 0.133 0.071]\n"," [0.157 0.081 0.168 0.157 0.091]\n"," [0.082 0.058 0.157 0.133 0.071]]\n","Policy Values Direct: [[0.036 0.025 0.131 0.114 0.039]\n"," [0.052 0.052 0.146 0.123 0.069]\n"," [0.155 0.105 0.155 0.158 0.113]\n"," [0.082 0.058 0.157 0.133 0.071]\n"," [0.157 0.081 0.168 0.157 0.091]\n"," [0.082 0.058 0.157 0.133 0.071]]\n"]}]},{"cell_type":"code","source":["##### Policy Optimization Attempt 2\n","# storage\n","np.random.seed(9827)\n","rho = np.random.randn(1, Y_train_sc.shape[1])\n","rank = 7\n","var_results = np.zeros((6,5))\n","polval_results = np.zeros((6,5))\n","polval_true = np.zeros((6,5))\n","method_tr = ['direct', 'direct','IPW-obs','IPW','DR-obs', 'CV']\n","z_est_tr = [False, True, False, True, False, True]\n","method_te = ['direct', 'IPW-obs','DR-obs','DR']\n","z_est_te = [True, False, False, False]\n","\n","for i in range(var_results.shape[0]):\n","  results = optimization_v3.subgradient_descent(num_iter = 60,step_size = 3,key_start=1,X_samples=X_train_sc, T_samples = T_train, Y_samples = Y_train_sc, rank=rank, rho = rho, method = method_tr[i], Z_estimation=z_est_tr[i])\n","  opt_idx = results['obj_values'].argmin()\n","  phi_opt = results['phi_values'][opt_idx]\n","  b_opt = results['b_values'][opt_idx]\n","\n","  #print(i)\n","  #print('Phi_opt:',phi_opt)\n","  #print('B_opt:',b_opt)\n","\n","  mu_0_list_self, mu_1_list_self = optimization_v3.gen_mu_values(X_samples=X_test_sc, T_samples=T_test,Y_samples=Y_test_sc, rank=rank, rho=rho, method=method_tr[i],Z_estimation=z_est_tr[i])\n","  pol_value_self, pi_0_list_self, pi_1_list_self = optimization_v3.compute_x_opt(phi=phi_opt, b=b_opt, X_samples=X_test_sc, T_samples=T_test, mu_0_list=mu_0_list_self,mu_1_list=mu_1_list_self)\n","\n","  var_results[i,0] = np.std(pi_0_list_self + pi_1_list_self)\n","  polval_true[i,0] = pol_value_self\n","  polval_results[i,0] = np.mean(pi_0_list_self + pi_1_list_self)\n","\n","  for j in range(1,var_results.shape[1]):\n","\n","    mu_0_list, mu_1_list = optimization_v3.gen_mu_values(X_samples=X_test_sc, T_samples=T_test,Y_samples=Y_test_sc, rank=rank, rho=rho, method=method_te[j-1],Z_estimation=z_est_te[j-1])\n","    pol_value, pi_0_list, pi_1_list = optimization_v3.compute_x_opt(phi=phi_opt, b=b_opt, X_samples=X_test_sc, T_samples=T_test, mu_0_list=mu_0_list,mu_1_list=mu_1_list)\n","\n","    var_results[i,j] = np.std(pi_0_list + pi_1_list)\n","    polval_true[i,j] = pol_value\n","    polval_results[i,j] = np.mean(pi_0_list + pi_1_list)\n","\n","print('######## RANK=7 ########')\n","print('Out-of-sample Variances:', np.round(var_results,3))\n","print('Policy Values:', np.round(polval_results,3))\n","print('Policy Values Direct:', np.round(polval_true,3))"],"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"WfW93O4934Qm","executionInfo":{"status":"ok","timestamp":1706074500446,"user_tz":480,"elapsed":145636,"user":{"displayName":"Ezinne Nwankwo","userId":"03581561058008593041"}},"outputId":"f0b5d8ba-a5c6-4247-92c5-f29d76f18f7a"},"execution_count":null,"outputs":[{"output_type":"stream","name":"stdout","text":["######## RANK=7 ########\n","Out-of-sample Variances: [[0.726 0.711 4.479 4.413 0.735]\n"," [0.711 0.711 4.461 4.397 0.735]\n"," [4.103 0.683 4.103 4.023 0.703]\n"," [1.077 0.709 4.51  4.44  0.734]\n"," [4.572 0.711 4.642 4.572 0.733]\n"," [1.078 0.709 4.509 4.44  0.734]]\n","Policy Values: [[0.036 0.03  0.131 0.112 0.036]\n"," [0.03  0.03  0.135 0.115 0.036]\n"," [0.155 0.102 0.155 0.152 0.106]\n"," [0.044 0.023 0.127 0.107 0.028]\n"," [0.099 0.07  0.12  0.099 0.076]\n"," [0.044 0.023 0.127 0.107 0.028]]\n","Policy Values Direct: [[0.036 0.03  0.131 0.112 0.036]\n"," [0.03  0.03  0.135 0.115 0.036]\n"," [0.155 0.102 0.155 0.152 0.106]\n"," [0.044 0.023 0.127 0.107 0.028]\n"," [0.099 0.07  0.12  0.099 0.076]\n"," [0.044 0.023 0.127 0.107 0.028]]\n"]}]},{"cell_type":"markdown","source":["#### Save best result"],"metadata":{"id":"p6bkJwmO3CuX"}},{"cell_type":"code","source":["from tabulate import tabulate\n","\n","\n","# Replace 'row_names' and 'column_names' with your desired names\n","row_names = ['$\\\\rho^\\top \\\\mu$-DM', '$\\\\rho^\\top \\\\mu^{RRR}$-DM', '$\\\\rho^\\top Y$-IPW', '$\\\\rho^\\top \\\\mu^{RRR}$-IPW', '$\\\\rho^\\top Y$-DR', '$\\\\rho^\\top \\\\mu^{RRR}$-CV']\n","column_names = ['SELF', '$\\\\rho^\\top \\\\mu^{RRR}$-DM', '$\\\\rho^\\top Y$-IPW', '$\\\\rho^\\top Y}$-DR', '$\\\\rho^\\top \\\\mu$-DR']\n","\n","# Calculate mean $\\pm$ standard error for each entry\n","table_data = []\n","for i in range(len(polval_results)):\n","    row = [row_names[i]]\n","    for j in range(len(polval_results[i])):\n","        entry = f\"{polval_results[i, j]:.2f} $\\\\pm$ {var_results[i, j]:.2f}\"\n","        row.append(entry)\n","    table_data.append(row)\n","\n","# Convert the table data to a LaTeX table using tabulate\n","latex_table = tabulate(table_data, headers=[''] + column_names, tablefmt='latex_raw')\n","\n","# Display or use the LaTeX table\n","print(latex_table)\n"],"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"6_zhPrUZF8ho","executionInfo":{"status":"ok","timestamp":1705700749557,"user_tz":480,"elapsed":203,"user":{"displayName":"Ezinne Nwankwo","userId":"03581561058008593041"}},"outputId":"bbdde6b7-0f81-4f4a-dd4c-97b3b88bf312"},"execution_count":null,"outputs":[{"output_type":"execute_result","data":{"text/plain":["array([[ 0.46 ,  0.125, 13.924, 13.928,  0.85 ],\n","       [ 0.132,  0.132, 19.084, 18.648,  0.835],\n","       [15.071,  0.109, 15.071, 14.997,  0.819],\n","       [ 0.384,  0.13 , 18.852, 18.395,  0.832],\n","       [14.966,  0.109, 15.031, 14.966,  0.815],\n","       [ 0.386,  0.13 , 18.854, 18.397,  0.832]])"]},"metadata":{},"execution_count":20}]},{"cell_type":"markdown","source":["### With Log Transformations"],"metadata":{"id":"XhBGa4NQzVBD"}},{"cell_type":"code","source":["# Log-transform the desired columns\n","Y_train_log = Y_train.copy()\n","Y_test_log = Y_test.copy()\n","\n","column_indices_to_pick = [0,3,4,5,6]\n","Y_train_log[:, column_indices_to_pick] = np.log1p(Y_train_log[:, column_indices_to_pick])\n","Y_test_log[:, column_indices_to_pick] = np.log1p(Y_test_log[:, column_indices_to_pick])\n","# Standardize Y data so that we are maximizing\n","y_scaler_train = preprocessing.StandardScaler().fit(Y_train_log)\n","Y_train_sc = y_scaler_train.transform(Y_train_log)\n","y_scaler_test = preprocessing.StandardScaler().fit(Y_test_log)\n","Y_test_sc = y_scaler_test.transform(Y_test_log)\n","# Standardize negative Y data so that we are maximizing\n","y_scaler_train = preprocessing.StandardScaler().fit(-Y_train_log)\n","Y_train_sc_opt = y_scaler_train.transform(-Y_train_log)\n","y_scaler_test = preprocessing.StandardScaler().fit(-Y_test_log)\n","Y_test_sc_opt = y_scaler_test.transform(-Y_test_log)"],"metadata":{"id":"1syBsd_K-q9N"},"execution_count":null,"outputs":[]},{"cell_type":"code","source":["##### Policy Optimization Attempt 2\n","# storage\n","#np.random.seed(9827)\n","#rho = np.random.randn(1, Y_train_sc.shape[1])\n","rho1= np.array([1,1,1,1,1,1,1])\n","var_results = np.zeros((6,5))\n","polval_results = np.zeros((6,5))\n","polval_true = np.zeros((6,5))\n","method_tr = ['direct', 'direct','IPW-obs','IPW','DR-obs', 'CV']\n","z_est_tr = [False, True, False, True, False, True]\n","method_te = ['direct', 'IPW-obs','DR-obs','DR']\n","z_est_te = [True, False, False, False]\n","\n","for i in range(var_results.shape[0]):\n","  results = optimization_v3.subgradient_descent(num_iter = 60,step_size = 3,key_start=1,X_samples=X_train_sc, T_samples = T_train, Y_samples = Y_train_sc_opt, rho = rho1, method = method_tr[i], Z_estimation=z_est_tr[i])\n","  opt_idx = results['obj_values'].argmin()\n","  phi_opt = results['phi_values'][opt_idx]\n","  b_opt = results['b_values'][opt_idx]\n","\n","  #print(i)\n","  #print('Phi_opt:',phi_opt)\n","  #print('B_opt:',b_opt)\n","\n","  mu_0_list_self, mu_1_list_self = optimization_v3.gen_mu_values(X_samples=X_test_sc, T_samples=T_test,Y_samples=Y_test_sc, rho=rho1, method=method_tr[i],Z_estimation=z_est_tr[i])\n","  pol_value_self, pi_0_list_self, pi_1_list_self = optimization_v3.compute_x_opt(phi=phi_opt, b=b_opt, X_samples=X_test_sc, T_samples=T_test, mu_0_list=mu_0_list_self,mu_1_list=mu_1_list_self)\n","\n","  var_results[i,0] = np.std(pi_0_list_self + pi_1_list_self)\n","  polval_true[i,0] = pol_value_self\n","  polval_results[i,0] = np.mean(pi_0_list_self + pi_1_list_self)\n","\n","  #if z_est_tr[i] == True:\n","  #  pi_1 = np.ones\n","  #  pi_0 = np.zeros\n","  #  ate_new0 = np.mu\n","  #  print(ate_new0)\n","  #  print(ate_new1)\n","\n","  for j in range(1,var_results.shape[1]):\n","\n","    mu_0_list, mu_1_list = optimization_v3.gen_mu_values(X_samples=X_test_sc, T_samples=T_test,Y_samples=Y_test_sc, rho=rho1, method=method_te[j-1],Z_estimation=z_est_te[j-1])\n","    pol_value, pi_0_list, pi_1_list = optimization_v3.compute_x_opt(phi=phi_opt, b=b_opt, X_samples=X_test_sc, T_samples=T_test, mu_0_list=mu_0_list,mu_1_list=mu_1_list)\n","\n","    var_results[i,j] = np.std(pi_0_list + pi_1_list)\n","    polval_true[i,j] = pol_value\n","    polval_results[i,j] = np.mean(pi_0_list + pi_1_list)\n","\n","\n","print('Out-of-sample Variances:', np.round(var_results,3))\n","print('Policy Values:', np.round(polval_results,3))\n","print('Policy Values Direct:', np.round(polval_true,3))"],"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"TgxsopPXva6P","executionInfo":{"status":"ok","timestamp":1706819723926,"user_tz":480,"elapsed":124427,"user":{"displayName":"Ezinne Nwankwo","userId":"03581561058008593041"}},"outputId":"2e488229-9bd1-4c77-8ece-e44a56867a12"},"execution_count":null,"outputs":[{"output_type":"stream","name":"stdout","text":["Out-of-sample Variances: [[1.133 1.119 5.287 5.241 1.196]\n"," [1.099 1.099 5.35  5.282 1.185]\n"," [5.701 1.245 5.701 5.64  1.293]\n"," [1.486 1.118 5.374 5.249 1.211]\n"," [5.645 1.25  5.705 5.645 1.294]\n"," [1.492 1.118 5.374 5.249 1.211]]\n","Policy Values: [[0.116 0.155 0.281 0.344 0.12 ]\n"," [0.18  0.18  0.257 0.298 0.15 ]\n"," [1.009 0.066 1.009 0.991 0.042]\n"," [0.11  0.127 0.208 0.225 0.095]\n"," [0.981 0.068 0.994 0.981 0.042]\n"," [0.11  0.127 0.208 0.225 0.095]]\n","Policy Values Direct: [[0.116 0.155 0.281 0.344 0.12 ]\n"," [0.18  0.18  0.257 0.298 0.15 ]\n"," [1.009 0.066 1.009 0.991 0.042]\n"," [0.11  0.127 0.208 0.225 0.095]\n"," [0.981 0.068 0.994 0.981 0.042]\n"," [0.11  0.127 0.208 0.225 0.095]]\n"]}]},{"cell_type":"code","source":["from tabulate import tabulate\n","\n","\n","# Replace 'row_names' and 'column_names' with your desired names\n","row_names = ['$\\\\rho^\\\\top \\\\mu$-DM', '$\\\\rho^\\\\top \\\\mu^{RRR}$-DM', '$\\\\rho^\\\\top Y$-IPW', '$\\\\rho^\\\\top \\\\mu^{RRR}$-IPW', '$\\\\rho^\\\\top Y$-DR', '$\\\\rho^\\\\top \\\\mu^{RRR}$-CV']\n","column_names = ['SELF', '$\\\\rho^\\\\top \\\\mu^{RRR}$-DM', '$\\\\rho^\\\\top Y$-IPW', '$\\\\rho^\\\\top Y$-DR', '$\\\\rho^\\\\top \\\\mu$-DR']\n","\n","# Calculate mean $\\pm$ standard error for each entry\n","table_data = []\n","for i in range(len(polval_results)):\n","    row = [row_names[i]]\n","    for j in range(len(polval_results[i])):\n","        entry = f\"{polval_results[i, j]:.3f} $\\\\pm$ {var_results[i, j]:.3f}\"\n","        row.append(entry)\n","    table_data.append(row)\n","\n","# Convert the table data to a LaTeX table using tabulate\n","latex_table = tabulate(table_data, headers=[''] + column_names, tablefmt='latex_raw')\n","\n","# Display or use the LaTeX table\n","print(latex_table)\n","\n"],"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"DEqvEpKFLiz5","executionInfo":{"status":"ok","timestamp":1706819728186,"user_tz":480,"elapsed":272,"user":{"displayName":"Ezinne Nwankwo","userId":"03581561058008593041"}},"outputId":"6260cdc2-b3a7-48d9-c246-4c45a101f3c8"},"execution_count":null,"outputs":[{"output_type":"stream","name":"stdout","text":["\\begin{tabular}{llllll}\n","\\hline\n","                           & SELF              & $\\rho^\\top \\mu^{RRR}$-DM   & $\\rho^\\top Y$-IPW   & $\\rho^\\top Y$-DR   & $\\rho^\\top \\mu$-DR   \\\\\n","\\hline\n"," $\\rho^\\top \\mu$-DM        & 0.116 $\\pm$ 1.133 & 0.155 $\\pm$ 1.119          & 0.281 $\\pm$ 5.287   & 0.344 $\\pm$ 5.241  & 0.120 $\\pm$ 1.196    \\\\\n"," $\\rho^\\top \\mu^{RRR}$-DM  & 0.180 $\\pm$ 1.099 & 0.180 $\\pm$ 1.099          & 0.257 $\\pm$ 5.350   & 0.298 $\\pm$ 5.282  & 0.150 $\\pm$ 1.185    \\\\\n"," $\\rho^\\top Y$-IPW         & 1.009 $\\pm$ 5.701 & 0.066 $\\pm$ 1.245          & 1.009 $\\pm$ 5.701   & 0.991 $\\pm$ 5.640  & 0.042 $\\pm$ 1.293    \\\\\n"," $\\rho^\\top \\mu^{RRR}$-IPW & 0.110 $\\pm$ 1.486 & 0.127 $\\pm$ 1.118          & 0.208 $\\pm$ 5.374   & 0.225 $\\pm$ 5.249  & 0.095 $\\pm$ 1.211    \\\\\n"," $\\rho^\\top Y$-DR          & 0.981 $\\pm$ 5.645 & 0.068 $\\pm$ 1.250          & 0.994 $\\pm$ 5.705   & 0.981 $\\pm$ 5.645  & 0.042 $\\pm$ 1.294    \\\\\n"," $\\rho^\\top \\mu^{RRR}$-CV  & 0.110 $\\pm$ 1.492 & 0.127 $\\pm$ 1.118          & 0.208 $\\pm$ 5.374   & 0.225 $\\pm$ 5.249  & 0.095 $\\pm$ 1.211    \\\\\n","\\hline\n","\\end{tabular}\n"]}]},{"cell_type":"markdown","source":["- Finding the right $\\rho$"],"metadata":{"id":"39aLXndLbftn"}},{"cell_type":"code","source":["##### Policy Optimization Attempt 2\n","# storage\n","#np.random.seed(9827)\n","#rho = np.random.randn(1, Y_train_sc.shape[1])\n","rho1= np.array([1,0,0,0,0,0,0])\n","var_results = np.zeros((6,5))\n","polval_results = np.zeros((6,5))\n","polval_true = np.zeros((6,5))\n","method_tr = ['direct', 'direct','IPW-obs','IPW','DR-obs', 'CV']\n","z_est_tr = [False, True, False, True, False, True]\n","method_te = ['direct', 'IPW-obs','DR-obs','DR']\n","z_est_te = [True, False, False, False]\n","\n","for i in range(var_results.shape[0]):\n","  results = optimization_v3.subgradient_descent(num_iter = 60,step_size = 3,key_start=1,X_samples=X_train_sc, T_samples = T_train, Y_samples = Y_train_sc_opt, rho = rho1, method = method_tr[i], Z_estimation=z_est_tr[i])\n","  opt_idx = results['obj_values'].argmin()\n","  phi_opt = results['phi_values'][opt_idx]\n","  b_opt = results['b_values'][opt_idx]\n","\n","  #print(i)\n","  #print('Phi_opt:',phi_opt)\n","  #print('B_opt:',b_opt)\n","\n","  mu_0_list_self, mu_1_list_self = optimization_v3.gen_mu_values(X_samples=X_test_sc, T_samples=T_test,Y_samples=Y_test_sc, rho=rho1, method=method_tr[i],Z_estimation=z_est_tr[i])\n","  pol_value_self, pi_0_list_self, pi_1_list_self = optimization_v3.compute_x_opt(phi=phi_opt, b=b_opt, X_samples=X_test_sc, T_samples=T_test, mu_0_list=mu_0_list_self,mu_1_list=mu_1_list_self)\n","\n","  var_results[i,0] = np.std(pi_0_list_self + pi_1_list_self)\n","  polval_true[i,0] = pol_value_self\n","  polval_results[i,0] = np.mean(pi_0_list_self + pi_1_list_self)\n","\n","  #if z_est_tr[i] == True:\n","  #  pi_1 = np.ones\n","  #  pi_0 = np.zeros\n","  #  ate_new0 = np.mu\n","  #  print(ate_new0)\n","  #  print(ate_new1)\n","\n","  for j in range(1,var_results.shape[1]):\n","\n","    mu_0_list, mu_1_list = optimization_v3.gen_mu_values(X_samples=X_test_sc, T_samples=T_test,Y_samples=Y_test_sc, rho=rho1, method=method_te[j-1],Z_estimation=z_est_te[j-1])\n","    pol_value, pi_0_list, pi_1_list = optimization_v3.compute_x_opt(phi=phi_opt, b=b_opt, X_samples=X_test_sc, T_samples=T_test, mu_0_list=mu_0_list,mu_1_list=mu_1_list)\n","\n","    var_results[i,j] = np.std(pi_0_list + pi_1_list)\n","    polval_true[i,j] = pol_value\n","    polval_results[i,j] = np.mean(pi_0_list + pi_1_list)\n","\n","\n","#print('Out-of-sample Variances:', np.round(var_results,3))\n","#print('Policy Values:', np.round(polval_results,3))\n","#print('Policy Values Direct:', np.round(polval_true,3))\n","# Replace 'row_names' and 'column_names' with your desired names\n","row_names = ['$\\\\rho^\\\\top \\\\mu$-DM', '$\\\\rho^\\\\top \\\\mu^{RRR}$-DM', '$\\\\rho^\\\\top Y$-IPW', '$\\\\rho^\\\\top \\\\mu^{RRR}$-IPW', '$\\\\rho^\\\\top Y$-DR', '$\\\\rho^\\\\top \\\\mu^{RRR}$-CV']\n","column_names = ['SELF', '$\\\\rho^\\\\top \\\\mu^{RRR}$-DM', '$\\\\rho^\\\\top Y$-IPW', '$\\\\rho^\\\\top Y$-DR', '$\\\\rho^\\\\top \\\\mu$-DR']\n","\n","# Calculate mean $\\pm$ standard error for each entry\n","table_data = []\n","for i in range(len(polval_results)):\n","    row = [row_names[i]]\n","    for j in range(len(polval_results[i])):\n","        entry = f\"{polval_results[i, j]:.3f} $\\\\pm$ {var_results[i, j]:.3f}\"\n","        row.append(entry)\n","    table_data.append(row)\n","\n","# Convert the table data to a LaTeX table using tabulate\n","latex_table = tabulate(table_data, headers=[''] + column_names, tablefmt='latex_raw')\n","\n","# Display or use the LaTeX table\n","print(latex_table)"],"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"1tlzsElBbZWY","executionInfo":{"status":"ok","timestamp":1706820770963,"user_tz":480,"elapsed":132597,"user":{"displayName":"Ezinne Nwankwo","userId":"03581561058008593041"}},"outputId":"834824f3-c312-4d44-9066-0128430240f7"},"execution_count":null,"outputs":[{"output_type":"stream","name":"stdout","text":["\\begin{tabular}{llllll}\n","\\hline\n","                           & SELF               & $\\rho^\\top \\mu^{RRR}$-DM   & $\\rho^\\top Y$-IPW   & $\\rho^\\top Y$-DR   & $\\rho^\\top \\mu$-DR   \\\\\n","\\hline\n"," $\\rho^\\top \\mu$-DM        & 0.007 $\\pm$ 0.232  & -0.018 $\\pm$ 0.153         & -0.016 $\\pm$ 1.245  & -0.012 $\\pm$ 1.237 & 0.015 $\\pm$ 0.292    \\\\\n"," $\\rho^\\top \\mu^{RRR}$-DM  & -0.011 $\\pm$ 0.152 & -0.011 $\\pm$ 0.152         & -0.012 $\\pm$ 1.232  & -0.008 $\\pm$ 1.223 & 0.020 $\\pm$ 0.293    \\\\\n"," $\\rho^\\top Y$-IPW         & -0.019 $\\pm$ 1.240 & -0.028 $\\pm$ 0.150         & -0.019 $\\pm$ 1.240  & -0.018 $\\pm$ 1.232 & 0.004 $\\pm$ 0.290    \\\\\n"," $\\rho^\\top \\mu^{RRR}$-IPW & -0.016 $\\pm$ 0.205 & -0.012 $\\pm$ 0.151         & -0.013 $\\pm$ 1.232  & -0.009 $\\pm$ 1.222 & 0.017 $\\pm$ 0.293    \\\\\n"," $\\rho^\\top Y$-DR          & -0.019 $\\pm$ 1.230 & -0.029 $\\pm$ 0.150         & -0.020 $\\pm$ 1.239  & -0.019 $\\pm$ 1.230 & 0.004 $\\pm$ 0.290    \\\\\n"," $\\rho^\\top \\mu^{RRR}$-CV  & -0.016 $\\pm$ 0.206 & -0.012 $\\pm$ 0.151         & -0.013 $\\pm$ 1.232  & -0.009 $\\pm$ 1.222 & 0.017 $\\pm$ 0.293    \\\\\n","\\hline\n","\\end{tabular}\n"]}]},{"cell_type":"code","source":["##### Policy Optimization Attempt 2\n","# storage\n","#np.random.seed(9827)\n","#rho = np.random.randn(1, Y_train_sc.shape[1])\n","rho1= np.array([0,1,0,0,0,0,0])\n","var_results = np.zeros((6,5))\n","polval_results = np.zeros((6,5))\n","polval_true = np.zeros((6,5))\n","method_tr = ['direct', 'direct','IPW-obs','IPW','DR-obs', 'CV']\n","z_est_tr = [False, True, False, True, False, True]\n","method_te = ['direct', 'IPW-obs','DR-obs','DR']\n","z_est_te = [True, False, False, False]\n","\n","for i in range(var_results.shape[0]):\n","  results = optimization_v3.subgradient_descent(num_iter = 60,step_size = 3,key_start=1,X_samples=X_train_sc, T_samples = T_train, Y_samples = Y_train_sc_opt, rho = rho1, method = method_tr[i], Z_estimation=z_est_tr[i])\n","  opt_idx = results['obj_values'].argmin()\n","  phi_opt = results['phi_values'][opt_idx]\n","  b_opt = results['b_values'][opt_idx]\n","\n","  #print(i)\n","  #print('Phi_opt:',phi_opt)\n","  #print('B_opt:',b_opt)\n","\n","  mu_0_list_self, mu_1_list_self = optimization_v3.gen_mu_values(X_samples=X_test_sc, T_samples=T_test,Y_samples=Y_test_sc, rho=rho1, method=method_tr[i],Z_estimation=z_est_tr[i])\n","  pol_value_self, pi_0_list_self, pi_1_list_self = optimization_v3.compute_x_opt(phi=phi_opt, b=b_opt, X_samples=X_test_sc, T_samples=T_test, mu_0_list=mu_0_list_self,mu_1_list=mu_1_list_self)\n","\n","  var_results[i,0] = np.std(pi_0_list_self + pi_1_list_self)\n","  polval_true[i,0] = pol_value_self\n","  polval_results[i,0] = np.mean(pi_0_list_self + pi_1_list_self)\n","\n","  #if z_est_tr[i] == True:\n","  #  pi_1 = np.ones\n","  #  pi_0 = np.zeros\n","  #  ate_new0 = np.mu\n","  #  print(ate_new0)\n","  #  print(ate_new1)\n","\n","  for j in range(1,var_results.shape[1]):\n","\n","    mu_0_list, mu_1_list = optimization_v3.gen_mu_values(X_samples=X_test_sc, T_samples=T_test,Y_samples=Y_test_sc, rho=rho1, method=method_te[j-1],Z_estimation=z_est_te[j-1])\n","    pol_value, pi_0_list, pi_1_list = optimization_v3.compute_x_opt(phi=phi_opt, b=b_opt, X_samples=X_test_sc, T_samples=T_test, mu_0_list=mu_0_list,mu_1_list=mu_1_list)\n","\n","    var_results[i,j] = np.std(pi_0_list + pi_1_list)\n","    polval_true[i,j] = pol_value\n","    polval_results[i,j] = np.mean(pi_0_list + pi_1_list)\n","\n","\n","#print('Out-of-sample Variances:', np.round(var_results,3))\n","#print('Policy Values:', np.round(polval_results,3))\n","#print('Policy Values Direct:', np.round(polval_true,3))\n","# Replace 'row_names' and 'column_names' with your desired names\n","row_names = ['$\\\\rho^\\\\top \\\\mu$-DM', '$\\\\rho^\\\\top \\\\mu^{RRR}$-DM', '$\\\\rho^\\\\top Y$-IPW', '$\\\\rho^\\\\top \\\\mu^{RRR}$-IPW', '$\\\\rho^\\\\top Y$-DR', '$\\\\rho^\\\\top \\\\mu^{RRR}$-CV']\n","column_names = ['SELF', '$\\\\rho^\\\\top \\\\mu^{RRR}$-DM', '$\\\\rho^\\\\top Y$-IPW', '$\\\\rho^\\\\top Y$-DR', '$\\\\rho^\\\\top \\\\mu$-DR']\n","\n","# Calculate mean $\\pm$ standard error for each entry\n","table_data = []\n","for i in range(len(polval_results)):\n","    row = [row_names[i]]\n","    for j in range(len(polval_results[i])):\n","        entry = f\"{polval_results[i, j]:.3f} $\\\\pm$ {var_results[i, j]:.3f}\"\n","        row.append(entry)\n","    table_data.append(row)\n","\n","# Convert the table data to a LaTeX table using tabulate\n","latex_table = tabulate(table_data, headers=[''] + column_names, tablefmt='latex_raw')\n","\n","# Display or use the LaTeX table\n","print(latex_table)\n","\n"],"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"p8R9yipHbvJd","executionInfo":{"status":"ok","timestamp":1706820984348,"user_tz":480,"elapsed":127293,"user":{"displayName":"Ezinne Nwankwo","userId":"03581561058008593041"}},"outputId":"8389207f-bf0e-4972-de19-442d6bf5af3e"},"execution_count":null,"outputs":[{"output_type":"stream","name":"stdout","text":["\\begin{tabular}{llllll}\n","\\hline\n","                           & SELF              & $\\rho^\\top \\mu^{RRR}$-DM   & $\\rho^\\top Y$-IPW   & $\\rho^\\top Y$-DR   & $\\rho^\\top \\mu$-DR   \\\\\n","\\hline\n"," $\\rho^\\top \\mu$-DM        & 0.064 $\\pm$ 0.334 & 0.050 $\\pm$ 0.299          & 0.096 $\\pm$ 1.686   & 0.083 $\\pm$ 1.524  & 0.062 $\\pm$ 0.364    \\\\\n"," $\\rho^\\top \\mu^{RRR}$-DM  & 0.057 $\\pm$ 0.297 & 0.057 $\\pm$ 0.297          & 0.094 $\\pm$ 1.677   & 0.082 $\\pm$ 1.516  & 0.068 $\\pm$ 0.363    \\\\\n"," $\\rho^\\top Y$-IPW         & 0.111 $\\pm$ 1.529 & 0.054 $\\pm$ 0.265          & 0.111 $\\pm$ 1.529   & 0.098 $\\pm$ 1.455  & 0.060 $\\pm$ 0.333    \\\\\n"," $\\rho^\\top \\mu^{RRR}$-IPW & 0.073 $\\pm$ 0.542 & 0.059 $\\pm$ 0.297          & 0.098 $\\pm$ 1.683   & 0.084 $\\pm$ 1.520  & 0.072 $\\pm$ 0.359    \\\\\n"," $\\rho^\\top Y$-DR          & 0.093 $\\pm$ 1.430 & 0.053 $\\pm$ 0.264          & 0.104 $\\pm$ 1.491   & 0.093 $\\pm$ 1.430  & 0.057 $\\pm$ 0.336    \\\\\n"," $\\rho^\\top \\mu^{RRR}$-CV  & 0.073 $\\pm$ 0.543 & 0.059 $\\pm$ 0.297          & 0.098 $\\pm$ 1.683   & 0.084 $\\pm$ 1.520  & 0.072 $\\pm$ 0.359    \\\\\n","\\hline\n","\\end{tabular}\n"]}]},{"cell_type":"code","source":["##### Policy Optimization Attempt 2\n","# storage\n","#np.random.seed(9827)\n","#rho = np.random.randn(1, Y_train_sc.shape[1])\n","rho1= np.array([0,0,1,0,0,0,0])\n","var_results = np.zeros((6,5))\n","polval_results = np.zeros((6,5))\n","polval_true = np.zeros((6,5))\n","method_tr = ['direct', 'direct','IPW-obs','IPW','DR-obs', 'CV']\n","z_est_tr = [False, True, False, True, False, True]\n","method_te = ['direct', 'IPW-obs','DR-obs','DR']\n","z_est_te = [True, False, False, False]\n","\n","for i in range(var_results.shape[0]):\n","  results = optimization_v3.subgradient_descent(num_iter = 60,step_size = 3,key_start=1,X_samples=X_train_sc, T_samples = T_train, Y_samples = Y_train_sc_opt, rho = rho1, method = method_tr[i], Z_estimation=z_est_tr[i])\n","  opt_idx = results['obj_values'].argmin()\n","  phi_opt = results['phi_values'][opt_idx]\n","  b_opt = results['b_values'][opt_idx]\n","\n","  #print(i)\n","  #print('Phi_opt:',phi_opt)\n","  #print('B_opt:',b_opt)\n","\n","  mu_0_list_self, mu_1_list_self = optimization_v3.gen_mu_values(X_samples=X_test_sc, T_samples=T_test,Y_samples=Y_test_sc, rho=rho1, method=method_tr[i],Z_estimation=z_est_tr[i])\n","  pol_value_self, pi_0_list_self, pi_1_list_self = optimization_v3.compute_x_opt(phi=phi_opt, b=b_opt, X_samples=X_test_sc, T_samples=T_test, mu_0_list=mu_0_list_self,mu_1_list=mu_1_list_self)\n","\n","  var_results[i,0] = np.std(pi_0_list_self + pi_1_list_self)\n","  polval_true[i,0] = pol_value_self\n","  polval_results[i,0] = np.mean(pi_0_list_self + pi_1_list_self)\n","\n","  #if z_est_tr[i] == True:\n","  #  pi_1 = np.ones\n","  #  pi_0 = np.zeros\n","  #  ate_new0 = np.mu\n","  #  print(ate_new0)\n","  #  print(ate_new1)\n","\n","  for j in range(1,var_results.shape[1]):\n","\n","    mu_0_list, mu_1_list = optimization_v3.gen_mu_values(X_samples=X_test_sc, T_samples=T_test,Y_samples=Y_test_sc, rho=rho1, method=method_te[j-1],Z_estimation=z_est_te[j-1])\n","    pol_value, pi_0_list, pi_1_list = optimization_v3.compute_x_opt(phi=phi_opt, b=b_opt, X_samples=X_test_sc, T_samples=T_test, mu_0_list=mu_0_list,mu_1_list=mu_1_list)\n","\n","    var_results[i,j] = np.std(pi_0_list + pi_1_list)\n","    polval_true[i,j] = pol_value\n","    polval_results[i,j] = np.mean(pi_0_list + pi_1_list)\n","\n","\n","#print('Out-of-sample Variances:', np.round(var_results,3))\n","#print('Policy Values:', np.round(polval_results,3))\n","#print('Policy Values Direct:', np.round(polval_true,3))\n","# Replace 'row_names' and 'column_names' with your desired names\n","row_names = ['$\\\\rho^\\\\top \\\\mu$-DM', '$\\\\rho^\\\\top \\\\mu^{RRR}$-DM', '$\\\\rho^\\\\top Y$-IPW', '$\\\\rho^\\\\top \\\\mu^{RRR}$-IPW', '$\\\\rho^\\\\top Y$-DR', '$\\\\rho^\\\\top \\\\mu^{RRR}$-CV']\n","column_names = ['SELF', '$\\\\rho^\\\\top \\\\mu^{RRR}$-DM', '$\\\\rho^\\\\top Y$-IPW', '$\\\\rho^\\\\top Y$-DR', '$\\\\rho^\\\\top \\\\mu$-DR']\n","\n","# Calculate mean $\\pm$ standard error for each entry\n","table_data = []\n","for i in range(len(polval_results)):\n","    row = [row_names[i]]\n","    for j in range(len(polval_results[i])):\n","        entry = f\"{polval_results[i, j]:.3f} $\\\\pm$ {var_results[i, j]:.3f}\"\n","        row.append(entry)\n","    table_data.append(row)\n","\n","# Convert the table data to a LaTeX table using tabulate\n","latex_table = tabulate(table_data, headers=[''] + column_names, tablefmt='latex_raw')\n","\n","# Display or use the LaTeX table\n","print(latex_table)"],"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"7ZO4mZFEb3mQ","executionInfo":{"status":"ok","timestamp":1706821214597,"user_tz":480,"elapsed":129621,"user":{"displayName":"Ezinne Nwankwo","userId":"03581561058008593041"}},"outputId":"559c06c6-1da3-4024-8b68-d3b81c3278a9"},"execution_count":null,"outputs":[{"output_type":"stream","name":"stdout","text":["\\begin{tabular}{llllll}\n","\\hline\n","                           & SELF               & $\\rho^\\top \\mu^{RRR}$-DM   & $\\rho^\\top Y$-IPW   & $\\rho^\\top Y$-DR   & $\\rho^\\top \\mu$-DR   \\\\\n","\\hline\n"," $\\rho^\\top \\mu$-DM        & -0.005 $\\pm$ 0.236 & 0.009 $\\pm$ 0.166          & -0.020 $\\pm$ 1.184  & -0.020 $\\pm$ 1.197 & -0.006 $\\pm$ 0.320   \\\\\n"," $\\rho^\\top \\mu^{RRR}$-DM  & 0.009 $\\pm$ 0.166  & 0.009 $\\pm$ 0.166          & -0.020 $\\pm$ 1.184  & -0.020 $\\pm$ 1.197 & -0.006 $\\pm$ 0.320   \\\\\n"," $\\rho^\\top Y$-IPW         & 0.118 $\\pm$ 1.447  & 0.009 $\\pm$ 0.187          & 0.118 $\\pm$ 1.447   & 0.119 $\\pm$ 1.450  & 0.004 $\\pm$ 0.311    \\\\\n"," $\\rho^\\top \\mu^{RRR}$-IPW & 0.009 $\\pm$ 0.226  & 0.009 $\\pm$ 0.166          & -0.020 $\\pm$ 1.184  & -0.020 $\\pm$ 1.197 & -0.006 $\\pm$ 0.320   \\\\\n"," $\\rho^\\top Y$-DR          & 0.119 $\\pm$ 1.449  & 0.009 $\\pm$ 0.186          & 0.119 $\\pm$ 1.445   & 0.119 $\\pm$ 1.449  & 0.005 $\\pm$ 0.312    \\\\\n"," $\\rho^\\top \\mu^{RRR}$-CV  & 0.009 $\\pm$ 0.227  & 0.009 $\\pm$ 0.166          & -0.020 $\\pm$ 1.184  & -0.020 $\\pm$ 1.197 & -0.006 $\\pm$ 0.320   \\\\\n","\\hline\n","\\end{tabular}\n"]}]},{"cell_type":"code","source":["##### Policy Optimization Attempt 2\n","# storage\n","#np.random.seed(9827)\n","#rho = np.random.randn(1, Y_train_sc.shape[1])\n","rho1= np.array([0,0,0,1,0,0,0])\n","var_results = np.zeros((6,5))\n","polval_results = np.zeros((6,5))\n","polval_true = np.zeros((6,5))\n","method_tr = ['direct', 'direct','IPW-obs','IPW','DR-obs', 'CV']\n","z_est_tr = [False, True, False, True, False, True]\n","method_te = ['direct', 'IPW-obs','DR-obs','DR']\n","z_est_te = [True, False, False, False]\n","\n","for i in range(var_results.shape[0]):\n","  results = optimization_v3.subgradient_descent(num_iter = 60,step_size = 3,key_start=1,X_samples=X_train_sc, T_samples = T_train, Y_samples = Y_train_sc_opt, rho = rho1, method = method_tr[i], Z_estimation=z_est_tr[i])\n","  opt_idx = results['obj_values'].argmin()\n","  phi_opt = results['phi_values'][opt_idx]\n","  b_opt = results['b_values'][opt_idx]\n","\n","  #print(i)\n","  #print('Phi_opt:',phi_opt)\n","  #print('B_opt:',b_opt)\n","\n","  mu_0_list_self, mu_1_list_self = optimization_v3.gen_mu_values(X_samples=X_test_sc, T_samples=T_test,Y_samples=Y_test_sc, rho=rho1, method=method_tr[i],Z_estimation=z_est_tr[i])\n","  pol_value_self, pi_0_list_self, pi_1_list_self = optimization_v3.compute_x_opt(phi=phi_opt, b=b_opt, X_samples=X_test_sc, T_samples=T_test, mu_0_list=mu_0_list_self,mu_1_list=mu_1_list_self)\n","\n","  var_results[i,0] = np.std(pi_0_list_self + pi_1_list_self)\n","  polval_true[i,0] = pol_value_self\n","  polval_results[i,0] = np.mean(pi_0_list_self + pi_1_list_self)\n","\n","  #if z_est_tr[i] == True:\n","  #  pi_1 = np.ones\n","  #  pi_0 = np.zeros\n","  #  ate_new0 = np.mu\n","  #  print(ate_new0)\n","  #  print(ate_new1)\n","\n","  for j in range(1,var_results.shape[1]):\n","\n","    mu_0_list, mu_1_list = optimization_v3.gen_mu_values(X_samples=X_test_sc, T_samples=T_test,Y_samples=Y_test_sc, rho=rho1, method=method_te[j-1],Z_estimation=z_est_te[j-1])\n","    pol_value, pi_0_list, pi_1_list = optimization_v3.compute_x_opt(phi=phi_opt, b=b_opt, X_samples=X_test_sc, T_samples=T_test, mu_0_list=mu_0_list,mu_1_list=mu_1_list)\n","\n","    var_results[i,j] = np.std(pi_0_list + pi_1_list)\n","    polval_true[i,j] = pol_value\n","    polval_results[i,j] = np.mean(pi_0_list + pi_1_list)\n","\n","\n","#print('Out-of-sample Variances:', np.round(var_results,3))\n","#print('Policy Values:', np.round(polval_results,3))\n","#print('Policy Values Direct:', np.round(polval_true,3))\n","# Replace 'row_names' and 'column_names' with your desired names\n","row_names = ['$\\\\rho^\\\\top \\\\mu$-DM', '$\\\\rho^\\\\top \\\\mu^{RRR}$-DM', '$\\\\rho^\\\\top Y$-IPW', '$\\\\rho^\\\\top \\\\mu^{RRR}$-IPW', '$\\\\rho^\\\\top Y$-DR', '$\\\\rho^\\\\top \\\\mu^{RRR}$-CV']\n","column_names = ['SELF', '$\\\\rho^\\\\top \\\\mu^{RRR}$-DM', '$\\\\rho^\\\\top Y$-IPW', '$\\\\rho^\\\\top Y$-DR', '$\\\\rho^\\\\top \\\\mu$-DR']\n","\n","# Calculate mean $\\pm$ standard error for each entry\n","table_data = []\n","for i in range(len(polval_results)):\n","    row = [row_names[i]]\n","    for j in range(len(polval_results[i])):\n","        entry = f\"{polval_results[i, j]:.3f} $\\\\pm$ {var_results[i, j]:.3f}\"\n","        row.append(entry)\n","    table_data.append(row)\n","\n","# Convert the table data to a LaTeX table using tabulate\n","latex_table = tabulate(table_data, headers=[''] + column_names, tablefmt='latex_raw')\n","\n","# Display or use the LaTeX table\n","print(latex_table)"],"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"T-KG9kg2ednw","executionInfo":{"status":"ok","timestamp":1706821427777,"user_tz":480,"elapsed":131542,"user":{"displayName":"Ezinne Nwankwo","userId":"03581561058008593041"}},"outputId":"cc9ce5be-fc81-4140-d6dd-7748349e617f"},"execution_count":null,"outputs":[{"output_type":"stream","name":"stdout","text":["\\begin{tabular}{llllll}\n","\\hline\n","                           & SELF              & $\\rho^\\top \\mu^{RRR}$-DM   & $\\rho^\\top Y$-IPW   & $\\rho^\\top Y$-DR   & $\\rho^\\top \\mu$-DR   \\\\\n","\\hline\n"," $\\rho^\\top \\mu$-DM        & 0.023 $\\pm$ 0.334 & 0.022 $\\pm$ 0.305          & 0.036 $\\pm$ 1.300   & 0.032 $\\pm$ 1.282  & 0.027 $\\pm$ 0.384    \\\\\n"," $\\rho^\\top \\mu^{RRR}$-DM  & 0.022 $\\pm$ 0.305 & 0.022 $\\pm$ 0.305          & 0.036 $\\pm$ 1.300   & 0.032 $\\pm$ 1.282  & 0.027 $\\pm$ 0.384    \\\\\n"," $\\rho^\\top Y$-IPW         & 0.165 $\\pm$ 1.393 & 0.028 $\\pm$ 0.294          & 0.165 $\\pm$ 1.393   & 0.166 $\\pm$ 1.373  & 0.019 $\\pm$ 0.362    \\\\\n"," $\\rho^\\top \\mu^{RRR}$-IPW & 0.026 $\\pm$ 0.392 & 0.022 $\\pm$ 0.305          & 0.036 $\\pm$ 1.300   & 0.032 $\\pm$ 1.282  & 0.027 $\\pm$ 0.384    \\\\\n"," $\\rho^\\top Y$-DR          & 0.170 $\\pm$ 1.375 & 0.027 $\\pm$ 0.295          & 0.169 $\\pm$ 1.396   & 0.170 $\\pm$ 1.375  & 0.018 $\\pm$ 0.363    \\\\\n"," $\\rho^\\top \\mu^{RRR}$-CV  & 0.026 $\\pm$ 0.394 & 0.022 $\\pm$ 0.305          & 0.036 $\\pm$ 1.300   & 0.032 $\\pm$ 1.282  & 0.027 $\\pm$ 0.384    \\\\\n","\\hline\n","\\end{tabular}\n"]}]},{"cell_type":"code","source":["##### Policy Optimization Attempt 2\n","# storage\n","#np.random.seed(9827)\n","#rho = np.random.randn(1, Y_train_sc.shape[1])\n","rho1= np.array([0,0,0,0,1,0,0])\n","var_results = np.zeros((6,5))\n","polval_results = np.zeros((6,5))\n","polval_true = np.zeros((6,5))\n","method_tr = ['direct', 'direct','IPW-obs','IPW','DR-obs', 'CV']\n","z_est_tr = [False, True, False, True, False, True]\n","method_te = ['direct', 'IPW-obs','DR-obs','DR']\n","z_est_te = [True, False, False, False]\n","\n","for i in range(var_results.shape[0]):\n","  results = optimization_v3.subgradient_descent(num_iter = 60,step_size = 3,key_start=1,X_samples=X_train_sc, T_samples = T_train, Y_samples = Y_train_sc_opt, rho = rho1, method = method_tr[i], Z_estimation=z_est_tr[i])\n","  opt_idx = results['obj_values'].argmin()\n","  phi_opt = results['phi_values'][opt_idx]\n","  b_opt = results['b_values'][opt_idx]\n","\n","  #print(i)\n","  #print('Phi_opt:',phi_opt)\n","  #print('B_opt:',b_opt)\n","\n","  mu_0_list_self, mu_1_list_self = optimization_v3.gen_mu_values(X_samples=X_test_sc, T_samples=T_test,Y_samples=Y_test_sc, rho=rho1, method=method_tr[i],Z_estimation=z_est_tr[i])\n","  pol_value_self, pi_0_list_self, pi_1_list_self = optimization_v3.compute_x_opt(phi=phi_opt, b=b_opt, X_samples=X_test_sc, T_samples=T_test, mu_0_list=mu_0_list_self,mu_1_list=mu_1_list_self)\n","\n","  var_results[i,0] = np.std(pi_0_list_self + pi_1_list_self)\n","  polval_true[i,0] = pol_value_self\n","  polval_results[i,0] = np.mean(pi_0_list_self + pi_1_list_self)\n","\n","  #if z_est_tr[i] == True:\n","  #  pi_1 = np.ones\n","  #  pi_0 = np.zeros\n","  #  ate_new0 = np.mu\n","  #  print(ate_new0)\n","  #  print(ate_new1)\n","\n","  for j in range(1,var_results.shape[1]):\n","\n","    mu_0_list, mu_1_list = optimization_v3.gen_mu_values(X_samples=X_test_sc, T_samples=T_test,Y_samples=Y_test_sc, rho=rho1, method=method_te[j-1],Z_estimation=z_est_te[j-1])\n","    pol_value, pi_0_list, pi_1_list = optimization_v3.compute_x_opt(phi=phi_opt, b=b_opt, X_samples=X_test_sc, T_samples=T_test, mu_0_list=mu_0_list,mu_1_list=mu_1_list)\n","\n","    var_results[i,j] = np.std(pi_0_list + pi_1_list)\n","    polval_true[i,j] = pol_value\n","    polval_results[i,j] = np.mean(pi_0_list + pi_1_list)\n","\n","\n","#print('Out-of-sample Variances:', np.round(var_results,3))\n","#print('Policy Values:', np.round(polval_results,3))\n","#print('Policy Values Direct:', np.round(polval_true,3))\n","# Replace 'row_names' and 'column_names' with your desired names\n","row_names = ['$\\\\rho^\\\\top \\\\mu$-DM', '$\\\\rho^\\\\top \\\\mu^{RRR}$-DM', '$\\\\rho^\\\\top Y$-IPW', '$\\\\rho^\\\\top \\\\mu^{RRR}$-IPW', '$\\\\rho^\\\\top Y$-DR', '$\\\\rho^\\\\top \\\\mu^{RRR}$-CV']\n","column_names = ['SELF', '$\\\\rho^\\\\top \\\\mu^{RRR}$-DM', '$\\\\rho^\\\\top Y$-IPW', '$\\\\rho^\\\\top Y$-DR', '$\\\\rho^\\\\top \\\\mu$-DR']\n","\n","# Calculate mean $\\pm$ standard error for each entry\n","table_data = []\n","for i in range(len(polval_results)):\n","    row = [row_names[i]]\n","    for j in range(len(polval_results[i])):\n","        entry = f\"{polval_results[i, j]:.3f} $\\\\pm$ {var_results[i, j]:.3f}\"\n","        row.append(entry)\n","    table_data.append(row)\n","\n","# Convert the table data to a LaTeX table using tabulate\n","latex_table = tabulate(table_data, headers=[''] + column_names, tablefmt='latex_raw')\n","\n","# Display or use the LaTeX table\n","print(latex_table)"],"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"HaRrKZdrgWpq","executionInfo":{"status":"ok","timestamp":1706821919015,"user_tz":480,"elapsed":129445,"user":{"displayName":"Ezinne Nwankwo","userId":"03581561058008593041"}},"outputId":"1ac7fe5f-6cd2-4987-a817-8bc752429aaf"},"execution_count":null,"outputs":[{"output_type":"stream","name":"stdout","text":["\\begin{tabular}{llllll}\n","\\hline\n","                           & SELF              & $\\rho^\\top \\mu^{RRR}$-DM   & $\\rho^\\top Y$-IPW   & $\\rho^\\top Y$-DR   & $\\rho^\\top \\mu$-DR   \\\\\n","\\hline\n"," $\\rho^\\top \\mu$-DM        & 0.037 $\\pm$ 0.336 & 0.011 $\\pm$ 0.254          & 0.060 $\\pm$ 1.326   & 0.059 $\\pm$ 1.305  & 0.036 $\\pm$ 0.360    \\\\\n"," $\\rho^\\top \\mu^{RRR}$-DM  & 0.011 $\\pm$ 0.254 & 0.011 $\\pm$ 0.254          & 0.060 $\\pm$ 1.326   & 0.059 $\\pm$ 1.305  & 0.036 $\\pm$ 0.360    \\\\\n"," $\\rho^\\top Y$-IPW         & 0.096 $\\pm$ 1.373 & 0.004 $\\pm$ 0.235          & 0.096 $\\pm$ 1.373   & 0.094 $\\pm$ 1.347  & 0.014 $\\pm$ 0.346    \\\\\n"," $\\rho^\\top \\mu^{RRR}$-IPW & 0.013 $\\pm$ 0.320 & 0.011 $\\pm$ 0.254          & 0.060 $\\pm$ 1.326   & 0.059 $\\pm$ 1.305  & 0.036 $\\pm$ 0.360    \\\\\n"," $\\rho^\\top Y$-DR          & 0.107 $\\pm$ 1.352 & 0.009 $\\pm$ 0.235          & 0.104 $\\pm$ 1.378   & 0.107 $\\pm$ 1.352  & 0.018 $\\pm$ 0.348    \\\\\n"," $\\rho^\\top \\mu^{RRR}$-CV  & 0.013 $\\pm$ 0.322 & 0.011 $\\pm$ 0.254          & 0.060 $\\pm$ 1.326   & 0.059 $\\pm$ 1.305  & 0.036 $\\pm$ 0.360    \\\\\n","\\hline\n","\\end{tabular}\n"]}]},{"cell_type":"code","source":["##### Policy Optimization Attempt 2\n","# storage\n","#np.random.seed(9827)\n","#rho = np.random.randn(1, Y_train_sc.shape[1])\n","rho1= np.array([0,0,0,0,0,1,0])\n","var_results = np.zeros((6,5))\n","polval_results = np.zeros((6,5))\n","polval_true = np.zeros((6,5))\n","method_tr = ['direct', 'direct','IPW-obs','IPW','DR-obs', 'CV']\n","z_est_tr = [False, True, False, True, False, True]\n","method_te = ['direct', 'IPW-obs','DR-obs','DR']\n","z_est_te = [True, False, False, False]\n","\n","for i in range(var_results.shape[0]):\n","  results = optimization_v3.subgradient_descent(num_iter = 60,step_size = 3,key_start=1,X_samples=X_train_sc, T_samples = T_train, Y_samples = Y_train_sc_opt, rho = rho1, method = method_tr[i], Z_estimation=z_est_tr[i])\n","  opt_idx = results['obj_values'].argmin()\n","  phi_opt = results['phi_values'][opt_idx]\n","  b_opt = results['b_values'][opt_idx]\n","\n","  #print(i)\n","  #print('Phi_opt:',phi_opt)\n","  #print('B_opt:',b_opt)\n","\n","  mu_0_list_self, mu_1_list_self = optimization_v3.gen_mu_values(X_samples=X_test_sc, T_samples=T_test,Y_samples=Y_test_sc, rho=rho1, method=method_tr[i],Z_estimation=z_est_tr[i])\n","  pol_value_self, pi_0_list_self, pi_1_list_self = optimization_v3.compute_x_opt(phi=phi_opt, b=b_opt, X_samples=X_test_sc, T_samples=T_test, mu_0_list=mu_0_list_self,mu_1_list=mu_1_list_self)\n","\n","  var_results[i,0] = np.std(pi_0_list_self + pi_1_list_self)\n","  polval_true[i,0] = pol_value_self\n","  polval_results[i,0] = np.mean(pi_0_list_self + pi_1_list_self)\n","\n","  #if z_est_tr[i] == True:\n","  #  pi_1 = np.ones\n","  #  pi_0 = np.zeros\n","  #  ate_new0 = np.mu\n","  #  print(ate_new0)\n","  #  print(ate_new1)\n","\n","  for j in range(1,var_results.shape[1]):\n","\n","    mu_0_list, mu_1_list = optimization_v3.gen_mu_values(X_samples=X_test_sc, T_samples=T_test,Y_samples=Y_test_sc, rho=rho1, method=method_te[j-1],Z_estimation=z_est_te[j-1])\n","    pol_value, pi_0_list, pi_1_list = optimization_v3.compute_x_opt(phi=phi_opt, b=b_opt, X_samples=X_test_sc, T_samples=T_test, mu_0_list=mu_0_list,mu_1_list=mu_1_list)\n","\n","    var_results[i,j] = np.std(pi_0_list + pi_1_list)\n","    polval_true[i,j] = pol_value\n","    polval_results[i,j] = np.mean(pi_0_list + pi_1_list)\n","\n","\n","#print('Out-of-sample Variances:', np.round(var_results,3))\n","#print('Policy Values:', np.round(polval_results,3))\n","#print('Policy Values Direct:', np.round(polval_true,3))\n","# Replace 'row_names' and 'column_names' with your desired names\n","row_names = ['$\\\\rho^\\\\top \\\\mu$-DM', '$\\\\rho^\\\\top \\\\mu^{RRR}$-DM', '$\\\\rho^\\\\top Y$-IPW', '$\\\\rho^\\\\top \\\\mu^{RRR}$-IPW', '$\\\\rho^\\\\top Y$-DR', '$\\\\rho^\\\\top \\\\mu^{RRR}$-CV']\n","column_names = ['SELF', '$\\\\rho^\\\\top \\\\mu^{RRR}$-DM', '$\\\\rho^\\\\top Y$-IPW', '$\\\\rho^\\\\top Y$-DR', '$\\\\rho^\\\\top \\\\mu$-DR']\n","\n","# Calculate mean $\\pm$ standard error for each entry\n","table_data = []\n","for i in range(len(polval_results)):\n","    row = [row_names[i]]\n","    for j in range(len(polval_results[i])):\n","        entry = f\"{polval_results[i, j]:.3f} $\\\\pm$ {var_results[i, j]:.3f}\"\n","        row.append(entry)\n","    table_data.append(row)\n","\n","# Convert the table data to a LaTeX table using tabulate\n","latex_table = tabulate(table_data, headers=[''] + column_names, tablefmt='latex_raw')\n","\n","# Display or use the LaTeX table\n","print(latex_table)"],"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"cUlTCW5lhKRl","executionInfo":{"status":"ok","timestamp":1706822135826,"user_tz":480,"elapsed":135787,"user":{"displayName":"Ezinne Nwankwo","userId":"03581561058008593041"}},"outputId":"6d89665b-18b1-4cea-a2d2-5ac64c0d969a"},"execution_count":null,"outputs":[{"output_type":"stream","name":"stdout","text":["\\begin{tabular}{llllll}\n","\\hline\n","                           & SELF              & $\\rho^\\top \\mu^{RRR}$-DM   & $\\rho^\\top Y$-IPW   & $\\rho^\\top Y$-DR   & $\\rho^\\top \\mu$-DR   \\\\\n","\\hline\n"," $\\rho^\\top \\mu$-DM        & 0.004 $\\pm$ 0.308 & 0.024 $\\pm$ 0.282          & 0.025 $\\pm$ 1.279   & 0.021 $\\pm$ 1.274  & 0.007 $\\pm$ 0.343    \\\\\n"," $\\rho^\\top \\mu^{RRR}$-DM  & 0.024 $\\pm$ 0.282 & 0.024 $\\pm$ 0.282          & 0.025 $\\pm$ 1.279   & 0.021 $\\pm$ 1.274  & 0.007 $\\pm$ 0.343    \\\\\n"," $\\rho^\\top Y$-IPW         & 0.173 $\\pm$ 1.448 & 0.025 $\\pm$ 0.278          & 0.173 $\\pm$ 1.448   & 0.173 $\\pm$ 1.433  & 0.028 $\\pm$ 0.336    \\\\\n"," $\\rho^\\top \\mu^{RRR}$-IPW & 0.028 $\\pm$ 0.374 & 0.024 $\\pm$ 0.282          & 0.025 $\\pm$ 1.279   & 0.021 $\\pm$ 1.274  & 0.007 $\\pm$ 0.343    \\\\\n"," $\\rho^\\top Y$-DR          & 0.175 $\\pm$ 1.435 & 0.025 $\\pm$ 0.278          & 0.175 $\\pm$ 1.450   & 0.175 $\\pm$ 1.435  & 0.028 $\\pm$ 0.336    \\\\\n"," $\\rho^\\top \\mu^{RRR}$-CV  & 0.028 $\\pm$ 0.375 & 0.024 $\\pm$ 0.282          & 0.025 $\\pm$ 1.279   & 0.021 $\\pm$ 1.274  & 0.007 $\\pm$ 0.343    \\\\\n","\\hline\n","\\end{tabular}\n"]}]},{"cell_type":"code","source":["##### Policy Optimization Attempt 2\n","# storage\n","#np.random.seed(9827)\n","#rho = np.random.randn(1, Y_train_sc.shape[1])\n","rho1= np.array([0,0,0,0,0,0,1])\n","var_results = np.zeros((6,5))\n","polval_results = np.zeros((6,5))\n","polval_true = np.zeros((6,5))\n","method_tr = ['direct', 'direct','IPW-obs','IPW','DR-obs', 'CV']\n","z_est_tr = [False, True, False, True, False, True]\n","method_te = ['direct', 'IPW-obs','DR-obs','DR']\n","z_est_te = [True, False, False, False]\n","\n","for i in range(var_results.shape[0]):\n","  results = optimization_v3.subgradient_descent(num_iter = 60,step_size = 3,key_start=1,X_samples=X_train_sc, T_samples = T_train, Y_samples = Y_train_sc_opt, rho = rho1, method = method_tr[i], Z_estimation=z_est_tr[i])\n","  opt_idx = results['obj_values'].argmin()\n","  phi_opt = results['phi_values'][opt_idx]\n","  b_opt = results['b_values'][opt_idx]\n","\n","  #print(i)\n","  #print('Phi_opt:',phi_opt)\n","  #print('B_opt:',b_opt)\n","\n","  mu_0_list_self, mu_1_list_self = optimization_v3.gen_mu_values(X_samples=X_test_sc, T_samples=T_test,Y_samples=Y_test_sc, rho=rho1, method=method_tr[i],Z_estimation=z_est_tr[i])\n","  pol_value_self, pi_0_list_self, pi_1_list_self = optimization_v3.compute_x_opt(phi=phi_opt, b=b_opt, X_samples=X_test_sc, T_samples=T_test, mu_0_list=mu_0_list_self,mu_1_list=mu_1_list_self)\n","\n","  var_results[i,0] = np.std(pi_0_list_self + pi_1_list_self)\n","  polval_true[i,0] = pol_value_self\n","  polval_results[i,0] = np.mean(pi_0_list_self + pi_1_list_self)\n","\n","  #if z_est_tr[i] == True:\n","  #  pi_1 = np.ones\n","  #  pi_0 = np.zeros\n","  #  ate_new0 = np.mu\n","  #  print(ate_new0)\n","  #  print(ate_new1)\n","\n","  for j in range(1,var_results.shape[1]):\n","\n","    mu_0_list, mu_1_list = optimization_v3.gen_mu_values(X_samples=X_test_sc, T_samples=T_test,Y_samples=Y_test_sc, rho=rho1, method=method_te[j-1],Z_estimation=z_est_te[j-1])\n","    pol_value, pi_0_list, pi_1_list = optimization_v3.compute_x_opt(phi=phi_opt, b=b_opt, X_samples=X_test_sc, T_samples=T_test, mu_0_list=mu_0_list,mu_1_list=mu_1_list)\n","\n","    var_results[i,j] = np.std(pi_0_list + pi_1_list)\n","    polval_true[i,j] = pol_value\n","    polval_results[i,j] = np.mean(pi_0_list + pi_1_list)\n","\n","\n","#print('Out-of-sample Variances:', np.round(var_results,3))\n","#print('Policy Values:', np.round(polval_results,3))\n","#print('Policy Values Direct:', np.round(polval_true,3))\n","# Replace 'row_names' and 'column_names' with your desired names\n","row_names = ['$\\\\rho^\\\\top \\\\mu$-DM', '$\\\\rho^\\\\top \\\\mu^{RRR}$-DM', '$\\\\rho^\\\\top Y$-IPW', '$\\\\rho^\\\\top \\\\mu^{RRR}$-IPW', '$\\\\rho^\\\\top Y$-DR', '$\\\\rho^\\\\top \\\\mu^{RRR}$-CV']\n","column_names = ['SELF', '$\\\\rho^\\\\top \\\\mu^{RRR}$-DM', '$\\\\rho^\\\\top Y$-IPW', '$\\\\rho^\\\\top Y$-DR', '$\\\\rho^\\\\top \\\\mu$-DR']\n","\n","# Calculate mean $\\pm$ standard error for each entry\n","table_data = []\n","for i in range(len(polval_results)):\n","    row = [row_names[i]]\n","    for j in range(len(polval_results[i])):\n","        entry = f\"{polval_results[i, j]:.3f} $\\\\pm$ {var_results[i, j]:.3f}\"\n","        row.append(entry)\n","    table_data.append(row)\n","\n","# Convert the table data to a LaTeX table using tabulate\n","latex_table = tabulate(table_data, headers=[''] + column_names, tablefmt='latex_raw')\n","\n","# Display or use the LaTeX table\n","print(latex_table)"],"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"NHDOSsdfh_Lx","executionInfo":{"status":"ok","timestamp":1706822354325,"user_tz":480,"elapsed":137989,"user":{"displayName":"Ezinne Nwankwo","userId":"03581561058008593041"}},"outputId":"14b33c0d-75db-4857-edac-66a798c016dd"},"execution_count":null,"outputs":[{"output_type":"stream","name":"stdout","text":["\\begin{tabular}{llllll}\n","\\hline\n","                           & SELF              & $\\rho^\\top \\mu^{RRR}$-DM   & $\\rho^\\top Y$-IPW   & $\\rho^\\top Y$-DR   & $\\rho^\\top \\mu$-DR   \\\\\n","\\hline\n"," $\\rho^\\top \\mu$-DM        & 0.020 $\\pm$ 0.251 & 0.023 $\\pm$ 0.190          & 0.055 $\\pm$ 1.252   & 0.049 $\\pm$ 1.254  & 0.024 $\\pm$ 0.300    \\\\\n"," $\\rho^\\top \\mu^{RRR}$-DM  & 0.023 $\\pm$ 0.190 & 0.023 $\\pm$ 0.190          & 0.055 $\\pm$ 1.252   & 0.049 $\\pm$ 1.254  & 0.024 $\\pm$ 0.300    \\\\\n"," $\\rho^\\top Y$-IPW         & 0.231 $\\pm$ 1.249 & 0.025 $\\pm$ 0.183          & 0.231 $\\pm$ 1.249   & 0.232 $\\pm$ 1.247  & 0.024 $\\pm$ 0.285    \\\\\n"," $\\rho^\\top \\mu^{RRR}$-IPW & 0.029 $\\pm$ 0.252 & 0.023 $\\pm$ 0.190          & 0.055 $\\pm$ 1.252   & 0.049 $\\pm$ 1.254  & 0.024 $\\pm$ 0.300    \\\\\n"," $\\rho^\\top Y$-DR          & 0.232 $\\pm$ 1.250 & 0.025 $\\pm$ 0.184          & 0.232 $\\pm$ 1.251   & 0.232 $\\pm$ 1.250  & 0.023 $\\pm$ 0.284    \\\\\n"," $\\rho^\\top \\mu^{RRR}$-CV  & 0.029 $\\pm$ 0.253 & 0.023 $\\pm$ 0.190          & 0.055 $\\pm$ 1.252   & 0.049 $\\pm$ 1.254  & 0.024 $\\pm$ 0.300    \\\\\n","\\hline\n","\\end{tabular}\n"]}]},{"cell_type":"code","source":["X_names = ['less_depressed_bl','less_disability_bl', 'stair_satis_today_bl', 'ment_hlth_index_trim_bl', 'hhh_fem',\n","'pben_fem', 'hhh_age', 'pben_age','hhh_poly','pben_poly', 'pben_handicap', 'phy_lift_hhh', 'phy_walk_hhh',\n","'phy_work_hhh', 'phy_lift_pben', 'phy_walk_pben', 'phy_work_pben', 'pben_edu', 'pben_prim', 'pben_lit',\n","'hhh_edu', 'hhh_prim', 'hhh_lit','hou_room','hou_hea_min', 'hou_mar_min', 'hou_wat_min', 'km_to_com']"],"metadata":{"id":"Rt46SrbW7FJZ"},"execution_count":null,"outputs":[]},{"cell_type":"code","source":["X_names[np.argsort(phi_opt)[-3:][0]]"],"metadata":{"colab":{"base_uri":"https://localhost:8080/","height":35},"id":"sHF5sF1BGd6r","executionInfo":{"status":"ok","timestamp":1706831851095,"user_tz":480,"elapsed":385,"user":{"displayName":"Ezinne Nwankwo","userId":"03581561058008593041"}},"outputId":"64f4e4b8-4c4e-498c-c1f3-eac4cc0719c9"},"execution_count":null,"outputs":[{"output_type":"execute_result","data":{"text/plain":["'phy_lift_pben'"],"application/vnd.google.colaboratory.intrinsic+json":{"type":"string"}},"metadata":{},"execution_count":121}]},{"cell_type":"code","source":["##### Policy Optimization Attempt 2\n","# storage\n","#np.random.seed(9827)\n","#rho = np.random.randn(1, Y_train_sc.shape[1])\n","#rho1= np.array([10.28,1.31,0.21,0.061,0.59,0.01,1.12])\n","rho1= np.array([8.28,1.31,0.21,0.061,0.59,0.01,1.12])\n","var_results = np.zeros((6,5))\n","polval_results = np.zeros((6,5))\n","polval_true = np.zeros((6,5))\n","method_tr = ['direct', 'direct','IPW-obs','IPW','DR-obs', 'CV']\n","z_est_tr = [False, True, False, True, False, True]\n","method_te = ['direct', 'IPW-obs','DR-obs','DR']\n","z_est_te = [True, False, False, False]\n","\n","for i in range(var_results.shape[0]):\n","  results = optimization_v3.subgradient_descent(num_iter = 60,step_size = 3,key_start=1,X_samples=X_train_sc, T_samples = T_train, Y_samples = Y_train_sc_opt, rho = rho1, method = method_tr[i], Z_estimation=z_est_tr[i])\n","  opt_idx = results['obj_values'].argmin()\n","  phi_opt = results['phi_values'][opt_idx]\n","  b_opt = results['b_values'][opt_idx]\n","\n","  top_three_ind = np.argsort(phi_opt)[-3:]\n","\n","  print(method_tr[i] + str(z_est_tr[i]))\n","  print('Top three features :'+ X_names[top_three_ind[0]]+','+ X_names[top_three_ind[1]]+','+X_names[top_three_ind[2]])\n","\n","  #print(i)\n","  #print('Phi_opt:',phi_opt)\n","  #print('B_opt:',b_opt)\n","\n","  mu_0_list_self, mu_1_list_self = optimization_v3.gen_mu_values(X_samples=X_test_sc, T_samples=T_test,Y_samples=Y_test_sc, rho=rho1, method=method_tr[i],Z_estimation=z_est_tr[i])\n","  pol_value_self, pi_0_list_self, pi_1_list_self = optimization_v3.compute_x_opt(phi=phi_opt, b=b_opt, X_samples=X_test_sc, T_samples=T_test, mu_0_list=mu_0_list_self,mu_1_list=mu_1_list_self)\n","\n","  var_results[i,0] = np.std(pi_0_list_self + pi_1_list_self)\n","  polval_true[i,0] = pol_value_self\n","  polval_results[i,0] = np.mean(pi_0_list_self + pi_1_list_self)\n","\n","#  pi_1 = np.ones((Y_test_sc.shape[0],))\n","#  pi_0 = np.zeros((Y_test_sc.shape[0],))\n","\n","#  pi_1_alltrt = np.multiply(pi_1, mu_1_list_self)\n","#  pi_0_alltrt = np.multiply(pi_1, mu_0_list_self)\n","#  ate_alltrt = np.mean(pi_0_alltrt + pi_1_alltrt)\n","\n","#  pi_1_notrt = np.multiply(pi_0, mu_1_list_self)\n","#  pi_0_notrt = np.multiply(pi_0, mu_0_list_self)\n","#  ate_notrt = np.mean(pi_0_notrt + pi_1_notrt)\n","#. print(method_tr[i] + str(z_est_tr[i]))\n","#  print(np.round(ate_alltrt,5))\n","#  print(np.round(ate_notrt,5))\n","\n","  for j in range(1,var_results.shape[1]):\n","\n","    mu_0_list, mu_1_list = optimization_v3.gen_mu_values(X_samples=X_test_sc, T_samples=T_test,Y_samples=Y_test_sc, rho=rho1, method=method_te[j-1],Z_estimation=z_est_te[j-1])\n","    pol_value, pi_0_list, pi_1_list = optimization_v3.compute_x_opt(phi=phi_opt, b=b_opt, X_samples=X_test_sc, T_samples=T_test, mu_0_list=mu_0_list,mu_1_list=mu_1_list)\n","\n","    var_results[i,j] = np.std(pi_0_list + pi_1_list)\n","    polval_true[i,j] = pol_value\n","    polval_results[i,j] = np.mean(pi_0_list + pi_1_list)\n","\n","\n","#print('Out-of-sample Variances:', np.round(var_results,3))\n","#print('Policy Values:', np.round(polval_results,3))\n","#print('Policy Values Direct:', np.round(polval_true,3))\n","# Replace 'row_names' and 'column_names' with your desired names\n","row_names = ['$\\\\rho^\\\\top \\\\mu$-DM', '$\\\\rho^\\\\top \\\\mu^{RRR}$-DM', '$\\\\rho^\\\\top Y$-IPW', '$\\\\rho^\\\\top \\\\mu^{RRR}$-IPW', '$\\\\rho^\\\\top Y$-DR', '$\\\\rho^\\\\top \\\\mu^{RRR}$-CV']\n","column_names = ['SELF', '$\\\\rho^\\\\top \\\\mu^{RRR}$-DM', '$\\\\rho^\\\\top Y$-IPW', '$\\\\rho^\\\\top Y$-DR', '$\\\\rho^\\\\top \\\\mu$-DR']\n","\n","# Calculate mean $\\pm$ standard error for each entry\n","from tabulate import tabulate\n","table_data = []\n","for i in range(len(polval_results)):\n","    row = [row_names[i]]\n","    for j in range(len(polval_results[i])):\n","        entry = f\"{polval_results[i, j]:.3f} $\\\\pm$ {var_results[i, j]:.3f}\"\n","        row.append(entry)\n","    table_data.append(row)\n","\n","# Convert the table data to a LaTeX table using tabulate\n","latex_table = tabulate(table_data, headers=[''] + column_names, tablefmt='latex_raw')\n","\n","# Display or use the LaTeX table\n","print(latex_table)"],"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"DXbFHgHSivov","executionInfo":{"status":"ok","timestamp":1706859551090,"user_tz":480,"elapsed":182398,"user":{"displayName":"Ezinne Nwankwo","userId":"03581561058008593041"}},"outputId":"90f107ea-6c72-4fcc-f9d2-55bd298965cd"},"execution_count":null,"outputs":[{"output_type":"stream","name":"stdout","text":["directFalse\n","Top three features :stair_satis_today_bl,phy_work_pben,hhh_edu\n","directTrue\n","Top three features :hhh_fem,hhh_age,phy_lift_hhh\n","IPW-obsFalse\n","Top three features :phy_lift_pben,hhh_edu,pben_fem\n","IPWTrue\n","Top three features :hhh_fem,hhh_age,phy_lift_hhh\n","DR-obsFalse\n","Top three features :phy_lift_pben,hhh_edu,pben_fem\n","CVTrue\n","Top three features :hhh_fem,hhh_age,phy_lift_hhh\n","\\begin{tabular}{llllll}\n","\\hline\n","                           & SELF                & $\\rho^\\top \\mu^{RRR}$-DM   & $\\rho^\\top Y$-IPW   & $\\rho^\\top Y$-DR    & $\\rho^\\top \\mu$-DR   \\\\\n","\\hline\n"," $\\rho^\\top \\mu$-DM        & 0.101 $\\pm$ 1.836   & -0.126 $\\pm$ 1.037         & 0.180 $\\pm$ 11.959  & 0.177 $\\pm$ 11.908  & 0.133 $\\pm$ 2.531    \\\\\n"," $\\rho^\\top \\mu^{RRR}$-DM  & -0.006 $\\pm$ 0.909  & -0.006 $\\pm$ 0.909         & 0.144 $\\pm$ 11.461  & 0.147 $\\pm$ 11.407  & 0.236 $\\pm$ 2.469    \\\\\n"," $\\rho^\\top Y$-IPW         & -0.224 $\\pm$ 10.120 & -0.330 $\\pm$ 1.026         & -0.224 $\\pm$ 10.120 & -0.225 $\\pm$ 10.094 & -0.283 $\\pm$ 2.485   \\\\\n"," $\\rho^\\top \\mu^{RRR}$-IPW & -0.045 $\\pm$ 1.227  & -0.044 $\\pm$ 0.919         & 0.046 $\\pm$ 11.217  & 0.046 $\\pm$ 11.166  & 0.184 $\\pm$ 2.490    \\\\\n"," $\\rho^\\top Y$-DR          & -0.258 $\\pm$ 10.244 & -0.305 $\\pm$ 1.029         & -0.253 $\\pm$ 10.276 & -0.258 $\\pm$ 10.244 & -0.263 $\\pm$ 2.556   \\\\\n"," $\\rho^\\top \\mu^{RRR}$-CV  & -0.045 $\\pm$ 1.231  & -0.044 $\\pm$ 0.919         & 0.046 $\\pm$ 11.217  & 0.046 $\\pm$ 11.166  & 0.184 $\\pm$ 2.490    \\\\\n","\\hline\n","\\end{tabular}\n"]}]},{"cell_type":"markdown","source":["- Finding the right rank"],"metadata":{"id":"reewycR8bpzw"}},{"cell_type":"code","source":["##### Policy Optimization Attempt 2\n","# storage\n","np.random.seed(9827)\n","rho = np.array([8.28,1.31,0.21,0.061,0.59,0.01,1.12])\n","rank = 3\n","var_results = np.zeros((6,5))\n","polval_results = np.zeros((6,5))\n","polval_true = np.zeros((6,5))\n","method_tr = ['direct', 'direct','IPW-obs','IPW','DR-obs', 'CV']\n","z_est_tr = [False, True, False, True, False, True]\n","method_te = ['direct', 'IPW-obs','DR-obs','DR']\n","z_est_te = [True, False, False, False]\n","\n","for i in range(var_results.shape[0]):\n","  results = optimization_v3.subgradient_descent(num_iter = 60,step_size = 3,key_start=1,X_samples=X_train_sc, T_samples = T_train, Y_samples = Y_train_sc_opt, rank=rank, rho = rho, method = method_tr[i], Z_estimation=z_est_tr[i])\n","  opt_idx = results['obj_values'].argmin()\n","  phi_opt = results['phi_values'][opt_idx]\n","  b_opt = results['b_values'][opt_idx]\n","\n","  #print(i)\n","  #print('Phi_opt:',phi_opt)\n","  #print('B_opt:',b_opt)\n","\n","  mu_0_list_self, mu_1_list_self = optimization_v3.gen_mu_values(X_samples=X_test_sc, T_samples=T_test,Y_samples=Y_test_sc, rank=rank, rho=rho, method=method_tr[i],Z_estimation=z_est_tr[i])\n","  pol_value_self, pi_0_list_self, pi_1_list_self = optimization_v3.compute_x_opt(phi=phi_opt, b=b_opt, X_samples=X_test_sc, T_samples=T_test, mu_0_list=mu_0_list_self,mu_1_list=mu_1_list_self)\n","\n","  var_results[i,0] = np.std(pi_0_list_self + pi_1_list_self)\n","  polval_true[i,0] = pol_value_self\n","  polval_results[i,0] = np.mean(pi_0_list_self + pi_1_list_self)\n","\n","  for j in range(1,var_results.shape[1]):\n","\n","    mu_0_list, mu_1_list = optimization_v3.gen_mu_values(X_samples=X_test_sc, T_samples=T_test,Y_samples=Y_test_sc, rank=rank, rho=rho, method=method_te[j-1],Z_estimation=z_est_te[j-1])\n","    pol_value, pi_0_list, pi_1_list = optimization_v3.compute_x_opt(phi=phi_opt, b=b_opt, X_samples=X_test_sc, T_samples=T_test, mu_0_list=mu_0_list,mu_1_list=mu_1_list)\n","\n","    var_results[i,j] = np.std(pi_0_list + pi_1_list)\n","    polval_true[i,j] = pol_value\n","    polval_results[i,j] = np.mean(pi_0_list + pi_1_list)\n","\n","print('######## RANK=3 ########')\n","print('Out-of-sample Variances:', np.round(var_results,3))\n","print('Policy Values:', np.round(polval_results,3))\n","print('Policy Values Direct:', np.round(polval_true,3))"],"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"5tI-m7O-BTYX","executionInfo":{"status":"ok","timestamp":1706859882596,"user_tz":480,"elapsed":171177,"user":{"displayName":"Ezinne Nwankwo","userId":"03581561058008593041"}},"outputId":"3d53b2bb-2408-44ae-db99-8cffd02206e5"},"execution_count":null,"outputs":[{"output_type":"stream","name":"stdout","text":["######## RANK=3 ########\n","Out-of-sample Variances: [[ 1.836  1.548 11.959 11.851  2.148]\n"," [ 1.609  1.609 12.557 12.437  2.254]\n"," [10.12   1.672 10.12  10.098  2.085]\n"," [ 2.376  1.639 12.348 12.24   2.272]\n"," [10.275  1.682 10.355 10.275  2.059]\n"," [ 2.381  1.639 12.349 12.241  2.272]]\n","Policy Values: [[ 0.101  0.083  0.18   0.149  0.105]\n"," [ 0.168  0.168  0.363  0.315  0.272]\n"," [-0.224 -0.255 -0.224 -0.199 -0.257]\n"," [ 0.195  0.151  0.321  0.278  0.27 ]\n"," [ 0.008 -0.208 -0.025  0.008 -0.208]\n"," [ 0.194  0.151  0.321  0.278  0.27 ]]\n","Policy Values Direct: [[ 0.101  0.083  0.18   0.149  0.105]\n"," [ 0.168  0.168  0.363  0.315  0.272]\n"," [-0.224 -0.255 -0.224 -0.199 -0.257]\n"," [ 0.195  0.151  0.321  0.278  0.27 ]\n"," [ 0.008 -0.208 -0.025  0.008 -0.208]\n"," [ 0.194  0.151  0.321  0.278  0.27 ]]\n"]}]},{"cell_type":"code","source":["from tabulate import tabulate\n","row_names = ['$\\\\rho^\\\\top \\\\mu$-DM', '$\\\\rho^\\\\top \\\\mu^{RRR}$-DM', '$\\\\rho^\\\\top Y$-IPW', '$\\\\rho^\\\\top \\\\mu^{RRR}$-IPW', '$\\\\rho^\\\\top Y$-DR', '$\\\\rho^\\\\top \\\\mu^{RRR}$-CV']\n","column_names = ['SELF', '$\\\\rho^\\\\top \\\\mu^{RRR}$-DM', '$\\\\rho^\\\\top Y$-IPW', '$\\\\rho^\\\\top Y$-DR', '$\\\\rho^\\\\top \\\\mu$-DR']\n","\n","# Calculate mean $\\pm$ standard error for each entry\n","table_data = []\n","for i in range(len(polval_results)):\n","    row = [row_names[i]]\n","    for j in range(len(polval_results[i])):\n","        entry = f\"{polval_results[i, j]:.3f} $\\\\pm$ {var_results[i, j]:.3f}\"\n","        row.append(entry)\n","    table_data.append(row)\n","\n","# Convert the table data to a LaTeX table using tabulate\n","latex_table = tabulate(table_data, headers=[''] + column_names, tablefmt='latex_raw')\n","\n","# Display or use the LaTeX table\n","print(latex_table)"],"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"7Gf-OjXou83U","executionInfo":{"status":"ok","timestamp":1706859887225,"user_tz":480,"elapsed":369,"user":{"displayName":"Ezinne Nwankwo","userId":"03581561058008593041"}},"outputId":"e0b9ef44-a148-4cea-f46a-90593e414138"},"execution_count":null,"outputs":[{"output_type":"stream","name":"stdout","text":["\\begin{tabular}{llllll}\n","\\hline\n","                           & SELF                & $\\rho^\\top \\mu^{RRR}$-DM   & $\\rho^\\top Y$-IPW   & $\\rho^\\top Y$-DR    & $\\rho^\\top \\mu$-DR   \\\\\n","\\hline\n"," $\\rho^\\top \\mu$-DM        & 0.101 $\\pm$ 1.836   & 0.083 $\\pm$ 1.548          & 0.180 $\\pm$ 11.959  & 0.149 $\\pm$ 11.851  & 0.105 $\\pm$ 2.148    \\\\\n"," $\\rho^\\top \\mu^{RRR}$-DM  & 0.168 $\\pm$ 1.609   & 0.168 $\\pm$ 1.609          & 0.363 $\\pm$ 12.557  & 0.315 $\\pm$ 12.437  & 0.272 $\\pm$ 2.254    \\\\\n"," $\\rho^\\top Y$-IPW         & -0.224 $\\pm$ 10.120 & -0.255 $\\pm$ 1.672         & -0.224 $\\pm$ 10.120 & -0.199 $\\pm$ 10.098 & -0.257 $\\pm$ 2.085   \\\\\n"," $\\rho^\\top \\mu^{RRR}$-IPW & 0.195 $\\pm$ 2.376   & 0.151 $\\pm$ 1.639          & 0.321 $\\pm$ 12.348  & 0.278 $\\pm$ 12.240  & 0.270 $\\pm$ 2.272    \\\\\n"," $\\rho^\\top Y$-DR          & 0.008 $\\pm$ 10.275  & -0.208 $\\pm$ 1.682         & -0.025 $\\pm$ 10.355 & 0.008 $\\pm$ 10.275  & -0.208 $\\pm$ 2.059   \\\\\n"," $\\rho^\\top \\mu^{RRR}$-CV  & 0.194 $\\pm$ 2.381   & 0.151 $\\pm$ 1.639          & 0.321 $\\pm$ 12.349  & 0.278 $\\pm$ 12.241  & 0.270 $\\pm$ 2.272    \\\\\n","\\hline\n","\\end{tabular}\n"]}]},{"cell_type":"code","source":["##### Policy Optimization Attempt 2\n","# storage\n","np.random.seed(9827)\n","#rho = np.random.randn(1, Y_train_sc.shape[1])\n","rho = np.array([8.28,1.31,0.21,0.061,0.59,0.01,1.12])\n","rank = 4\n","var_results = np.zeros((6,5))\n","polval_results = np.zeros((6,5))\n","polval_true = np.zeros((6,5))\n","method_tr = ['direct', 'direct','IPW-obs','IPW','DR-obs', 'CV']\n","z_est_tr = [False, True, False, True, False, True]\n","method_te = ['direct', 'IPW-obs','DR-obs','DR']\n","z_est_te = [True, False, False, False]\n","\n","for i in range(var_results.shape[0]):\n","  results = optimization_v3.subgradient_descent(num_iter = 60,step_size = 3,key_start=1,X_samples=X_train_sc, T_samples = T_train, Y_samples = Y_train_sc_opt, rank=rank, rho = rho, method = method_tr[i], Z_estimation=z_est_tr[i])\n","  opt_idx = results['obj_values'].argmin()\n","  phi_opt = results['phi_values'][opt_idx]\n","  b_opt = results['b_values'][opt_idx]\n","\n","  #print(i)\n","  #print('Phi_opt:',phi_opt)\n","  #print('B_opt:',b_opt)\n","\n","  mu_0_list_self, mu_1_list_self = optimization_v3.gen_mu_values(X_samples=X_test_sc, T_samples=T_test,Y_samples=Y_test_sc, rank=rank, rho=rho, method=method_tr[i],Z_estimation=z_est_tr[i])\n","  pol_value_self, pi_0_list_self, pi_1_list_self = optimization_v3.compute_x_opt(phi=phi_opt, b=b_opt, X_samples=X_test_sc, T_samples=T_test, mu_0_list=mu_0_list_self,mu_1_list=mu_1_list_self)\n","\n","  var_results[i,0] = np.std(pi_0_list_self + pi_1_list_self)\n","  polval_true[i,0] = pol_value_self\n","  polval_results[i,0] = np.mean(pi_0_list_self + pi_1_list_self)\n","\n","  for j in range(1,var_results.shape[1]):\n","\n","    mu_0_list, mu_1_list = optimization_v3.gen_mu_values(X_samples=X_test_sc, T_samples=T_test,Y_samples=Y_test_sc, rank=rank, rho=rho, method=method_te[j-1],Z_estimation=z_est_te[j-1])\n","    pol_value, pi_0_list, pi_1_list = optimization_v3.compute_x_opt(phi=phi_opt, b=b_opt, X_samples=X_test_sc, T_samples=T_test, mu_0_list=mu_0_list,mu_1_list=mu_1_list)\n","\n","    var_results[i,j] = np.std(pi_0_list + pi_1_list)\n","    polval_true[i,j] = pol_value\n","    polval_results[i,j] = np.mean(pi_0_list + pi_1_list)\n","\n","print('######## RANK=4 ########')\n","print('Out-of-sample Variances:', np.round(var_results,3))\n","print('Policy Values:', np.round(polval_results,3))\n","print('Policy Values Direct:', np.round(polval_true,3))"],"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"elZgaPQUBPwm","executionInfo":{"status":"ok","timestamp":1706860614279,"user_tz":480,"elapsed":202141,"user":{"displayName":"Ezinne Nwankwo","userId":"03581561058008593041"}},"outputId":"04e964d0-35d0-4788-d194-dfb0ec53c8eb"},"execution_count":null,"outputs":[{"output_type":"stream","name":"stdout","text":["######## RANK=4 ########\n","Out-of-sample Variances: [[ 1.836  1.582 11.959 11.835  2.131]\n"," [ 1.618  1.618 12.166 11.994  2.144]\n"," [10.12   1.691 10.12  10.1    2.076]\n"," [ 2.461  1.628 12.313 12.143  2.142]\n"," [10.149  1.71  10.228 10.149  2.073]\n"," [ 2.468  1.628 12.313 12.144  2.142]]\n","Policy Values: [[ 0.101  0.085  0.18   0.148  0.104]\n"," [ 0.108  0.108  0.18   0.145  0.118]\n"," [-0.224 -0.304 -0.224 -0.216 -0.273]\n"," [ 0.124  0.103  0.211  0.19   0.155]\n"," [-0.056 -0.265 -0.077 -0.056 -0.238]\n"," [ 0.124  0.103  0.211  0.19   0.155]]\n","Policy Values Direct: [[ 0.101  0.085  0.18   0.148  0.104]\n"," [ 0.108  0.108  0.18   0.145  0.118]\n"," [-0.224 -0.304 -0.224 -0.216 -0.273]\n"," [ 0.124  0.103  0.211  0.19   0.155]\n"," [-0.056 -0.265 -0.077 -0.056 -0.238]\n"," [ 0.124  0.103  0.211  0.19   0.155]]\n"]}]},{"cell_type":"code","source":["from tabulate import tabulate\n","row_names = ['$\\\\rho^\\\\top \\\\mu$-DM', '$\\\\rho^\\\\top \\\\mu^{RRR}$-DM', '$\\\\rho^\\\\top Y$-IPW', '$\\\\rho^\\\\top \\\\mu^{RRR}$-IPW', '$\\\\rho^\\\\top Y$-DR', '$\\\\rho^\\\\top \\\\mu^{RRR}$-CV']\n","column_names = ['SELF', '$\\\\rho^\\\\top \\\\mu^{RRR}$-DM', '$\\\\rho^\\\\top Y$-IPW', '$\\\\rho^\\\\top Y$-DR', '$\\\\rho^\\\\top \\\\mu$-DR']\n","\n","# Calculate mean $\\pm$ standard error for each entry\n","table_data = []\n","for i in range(len(polval_results)):\n","    row = [row_names[i]]\n","    for j in range(len(polval_results[i])):\n","        entry = f\"{polval_results[i, j]:.3f} $\\\\pm$ {var_results[i, j]:.3f}\"\n","        row.append(entry)\n","    table_data.append(row)\n","\n","# Convert the table data to a LaTeX table using tabulate\n","latex_table = tabulate(table_data, headers=[''] + column_names, tablefmt='latex_raw')\n","\n","# Display or use the LaTeX table\n","print(latex_table)"],"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"VAX6xQyBzw0T","executionInfo":{"status":"ok","timestamp":1706860630125,"user_tz":480,"elapsed":625,"user":{"displayName":"Ezinne Nwankwo","userId":"03581561058008593041"}},"outputId":"c09a77ca-a403-4147-a6bc-8adb11794ced"},"execution_count":null,"outputs":[{"output_type":"stream","name":"stdout","text":["\\begin{tabular}{llllll}\n","\\hline\n","                           & SELF                & $\\rho^\\top \\mu^{RRR}$-DM   & $\\rho^\\top Y$-IPW   & $\\rho^\\top Y$-DR    & $\\rho^\\top \\mu$-DR   \\\\\n","\\hline\n"," $\\rho^\\top \\mu$-DM        & 0.101 $\\pm$ 1.836   & 0.085 $\\pm$ 1.582          & 0.180 $\\pm$ 11.959  & 0.148 $\\pm$ 11.835  & 0.104 $\\pm$ 2.131    \\\\\n"," $\\rho^\\top \\mu^{RRR}$-DM  & 0.108 $\\pm$ 1.618   & 0.108 $\\pm$ 1.618          & 0.180 $\\pm$ 12.166  & 0.145 $\\pm$ 11.994  & 0.118 $\\pm$ 2.144    \\\\\n"," $\\rho^\\top Y$-IPW         & -0.224 $\\pm$ 10.120 & -0.304 $\\pm$ 1.691         & -0.224 $\\pm$ 10.120 & -0.216 $\\pm$ 10.100 & -0.273 $\\pm$ 2.076   \\\\\n"," $\\rho^\\top \\mu^{RRR}$-IPW & 0.124 $\\pm$ 2.461   & 0.103 $\\pm$ 1.628          & 0.211 $\\pm$ 12.313  & 0.190 $\\pm$ 12.143  & 0.155 $\\pm$ 2.142    \\\\\n"," $\\rho^\\top Y$-DR          & -0.056 $\\pm$ 10.149 & -0.265 $\\pm$ 1.710         & -0.077 $\\pm$ 10.228 & -0.056 $\\pm$ 10.149 & -0.238 $\\pm$ 2.073   \\\\\n"," $\\rho^\\top \\mu^{RRR}$-CV  & 0.124 $\\pm$ 2.468   & 0.103 $\\pm$ 1.628          & 0.211 $\\pm$ 12.313  & 0.190 $\\pm$ 12.144  & 0.155 $\\pm$ 2.142    \\\\\n","\\hline\n","\\end{tabular}\n"]}]},{"cell_type":"code","source":["##### Policy Optimization Attempt 2\n","# storage\n","np.random.seed(9827)\n","#rho = np.random.randn(1, Y_train_sc.shape[1])\n","rho = np.array([8.28,1.31,0.21,0.061,0.59,0.01,1.12])\n","rank = 5\n","var_results = np.zeros((6,5))\n","polval_results = np.zeros((6,5))\n","polval_true = np.zeros((6,5))\n","method_tr = ['direct', 'direct','IPW-obs','IPW','DR-obs', 'CV']\n","z_est_tr = [False, True, False, True, False, True]\n","method_te = ['direct', 'IPW-obs','DR-obs','DR']\n","z_est_te = [True, False, False, False]\n","\n","for i in range(var_results.shape[0]):\n","  results = optimization_v3.subgradient_descent(num_iter = 60,step_size = 3,key_start=1,X_samples=X_train_sc, T_samples = T_train, Y_samples = Y_train_sc_opt, rank=rank, rho = rho, method = method_tr[i], Z_estimation=z_est_tr[i])\n","  opt_idx = results['obj_values'].argmin()\n","  phi_opt = results['phi_values'][opt_idx]\n","  b_opt = results['b_values'][opt_idx]\n","\n","  #print(i)\n","  #print('Phi_opt:',phi_opt)\n","  #print('B_opt:',b_opt)\n","\n","  mu_0_list_self, mu_1_list_self = optimization_v3.gen_mu_values(X_samples=X_test_sc, T_samples=T_test,Y_samples=Y_test_sc, rank=rank, rho=rho, method=method_tr[i],Z_estimation=z_est_tr[i])\n","  pol_value_self, pi_0_list_self, pi_1_list_self = optimization_v3.compute_x_opt(phi=phi_opt, b=b_opt, X_samples=X_test_sc, T_samples=T_test, mu_0_list=mu_0_list_self,mu_1_list=mu_1_list_self)\n","\n","  var_results[i,0] = np.std(pi_0_list_self + pi_1_list_self)\n","  polval_true[i,0] = pol_value_self\n","  polval_results[i,0] = np.mean(pi_0_list_self + pi_1_list_self)\n","\n","  for j in range(1,var_results.shape[1]):\n","\n","    mu_0_list, mu_1_list = optimization_v3.gen_mu_values(X_samples=X_test_sc, T_samples=T_test,Y_samples=Y_test_sc, rank=rank, rho=rho, method=method_te[j-1],Z_estimation=z_est_te[j-1])\n","    pol_value, pi_0_list, pi_1_list = optimization_v3.compute_x_opt(phi=phi_opt, b=b_opt, X_samples=X_test_sc, T_samples=T_test, mu_0_list=mu_0_list,mu_1_list=mu_1_list)\n","\n","    var_results[i,j] = np.std(pi_0_list + pi_1_list)\n","    polval_true[i,j] = pol_value\n","    polval_results[i,j] = np.mean(pi_0_list + pi_1_list)\n","\n","print('######## RANK=5 ########')\n","print('Out-of-sample Variances:', np.round(var_results,3))\n","print('Policy Values:', np.round(polval_results,3))\n","print('Policy Values Direct:', np.round(polval_true,3))"],"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"jiKk7QjPBLeU","executionInfo":{"status":"ok","timestamp":1706860797496,"user_tz":480,"elapsed":149654,"user":{"displayName":"Ezinne Nwankwo","userId":"03581561058008593041"}},"outputId":"686fdfe1-37eb-4b78-b181-c702ef3e3220"},"execution_count":null,"outputs":[{"output_type":"stream","name":"stdout","text":["######## RANK=5 ########\n","Out-of-sample Variances: [[ 1.836  1.723 11.959 11.772  1.962]\n"," [ 1.765  1.765 11.928 11.719  1.997]\n"," [10.12   1.822 10.12  10.103  1.963]\n"," [ 2.498  1.733 11.632 11.458  1.948]\n"," [10.445  1.814 10.546 10.445  1.96 ]\n"," [ 2.505  1.733 11.632 11.459  1.948]]\n","Policy Values: [[ 0.101  0.128  0.18   0.16   0.116]\n"," [ 0.117  0.117  0.149  0.125  0.124]\n"," [-0.224 -0.326 -0.224 -0.217 -0.275]\n"," [ 0.081  0.079  0.129  0.127  0.089]\n"," [ 0.05  -0.278  0.028  0.05  -0.221]\n"," [ 0.082  0.079  0.13   0.127  0.089]]\n","Policy Values Direct: [[ 0.101  0.128  0.18   0.16   0.116]\n"," [ 0.117  0.117  0.149  0.125  0.124]\n"," [-0.224 -0.326 -0.224 -0.217 -0.275]\n"," [ 0.081  0.079  0.129  0.127  0.089]\n"," [ 0.05  -0.278  0.028  0.05  -0.221]\n"," [ 0.082  0.079  0.13   0.127  0.089]]\n"]}]},{"cell_type":"code","source":["from tabulate import tabulate\n","row_names = ['$\\\\rho^\\\\top \\\\mu$-DM', '$\\\\rho^\\\\top \\\\mu^{RRR}$-DM', '$\\\\rho^\\\\top Y$-IPW', '$\\\\rho^\\\\top \\\\mu^{RRR}$-IPW', '$\\\\rho^\\\\top Y$-DR', '$\\\\rho^\\\\top \\\\mu^{RRR}$-CV']\n","column_names = ['SELF', '$\\\\rho^\\\\top \\\\mu^{RRR}$-DM', '$\\\\rho^\\\\top Y$-IPW', '$\\\\rho^\\\\top Y$-DR', '$\\\\rho^\\\\top \\\\mu$-DR']\n","\n","# Calculate mean $\\pm$ standard error for each entry\n","table_data = []\n","for i in range(len(polval_results)):\n","    row = [row_names[i]]\n","    for j in range(len(polval_results[i])):\n","        entry = f\"{polval_results[i, j]:.3f} $\\\\pm$ {var_results[i, j]:.3f}\"\n","        row.append(entry)\n","    table_data.append(row)\n","\n","# Convert the table data to a LaTeX table using tabulate\n","latex_table = tabulate(table_data, headers=[''] + column_names, tablefmt='latex_raw')\n","\n","# Display or use the LaTeX table\n","print(latex_table)"],"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"boIJUKpGv5zh","executionInfo":{"status":"ok","timestamp":1706860827272,"user_tz":480,"elapsed":401,"user":{"displayName":"Ezinne Nwankwo","userId":"03581561058008593041"}},"outputId":"ba378b1b-bdde-4920-f231-0c806a9f55b1"},"execution_count":null,"outputs":[{"output_type":"stream","name":"stdout","text":["\\begin{tabular}{llllll}\n","\\hline\n","                           & SELF                & $\\rho^\\top \\mu^{RRR}$-DM   & $\\rho^\\top Y$-IPW   & $\\rho^\\top Y$-DR    & $\\rho^\\top \\mu$-DR   \\\\\n","\\hline\n"," $\\rho^\\top \\mu$-DM        & 0.101 $\\pm$ 1.836   & 0.128 $\\pm$ 1.723          & 0.180 $\\pm$ 11.959  & 0.160 $\\pm$ 11.772  & 0.116 $\\pm$ 1.962    \\\\\n"," $\\rho^\\top \\mu^{RRR}$-DM  & 0.117 $\\pm$ 1.765   & 0.117 $\\pm$ 1.765          & 0.149 $\\pm$ 11.928  & 0.125 $\\pm$ 11.719  & 0.124 $\\pm$ 1.997    \\\\\n"," $\\rho^\\top Y$-IPW         & -0.224 $\\pm$ 10.120 & -0.326 $\\pm$ 1.822         & -0.224 $\\pm$ 10.120 & -0.217 $\\pm$ 10.103 & -0.275 $\\pm$ 1.963   \\\\\n"," $\\rho^\\top \\mu^{RRR}$-IPW & 0.081 $\\pm$ 2.498   & 0.079 $\\pm$ 1.733          & 0.129 $\\pm$ 11.632  & 0.127 $\\pm$ 11.458  & 0.089 $\\pm$ 1.948    \\\\\n"," $\\rho^\\top Y$-DR          & 0.050 $\\pm$ 10.445  & -0.278 $\\pm$ 1.814         & 0.028 $\\pm$ 10.546  & 0.050 $\\pm$ 10.445  & -0.221 $\\pm$ 1.960   \\\\\n"," $\\rho^\\top \\mu^{RRR}$-CV  & 0.082 $\\pm$ 2.505   & 0.079 $\\pm$ 1.733          & 0.130 $\\pm$ 11.632  & 0.127 $\\pm$ 11.459  & 0.089 $\\pm$ 1.948    \\\\\n","\\hline\n","\\end{tabular}\n"]}]},{"cell_type":"code","source":["##### Policy Optimization Attempt 2\n","# storage\n","np.random.seed(9827)\n","#rho = np.random.randn(1, Y_train_sc.shape[1])\n","rho = np.array([8.28,1.31,0.21,0.061,0.59,0.01,1.12])\n","rank = 6\n","var_results = np.zeros((6,5))\n","polval_results = np.zeros((6,5))\n","polval_true = np.zeros((6,5))\n","method_tr = ['direct', 'direct','IPW-obs','IPW','DR-obs', 'CV']\n","z_est_tr = [False, True, False, True, False, True]\n","method_te = ['direct', 'IPW-obs','DR-obs','DR']\n","z_est_te = [True, False, False, False]\n","\n","for i in range(var_results.shape[0]):\n","  results = optimization_v3.subgradient_descent(num_iter = 60,step_size = 3,key_start=1,X_samples=X_train_sc, T_samples = T_train, Y_samples = Y_train_sc_opt, rank=rank, rho = rho, method = method_tr[i], Z_estimation=z_est_tr[i])\n","  opt_idx = results['obj_values'].argmin()\n","  phi_opt = results['phi_values'][opt_idx]\n","  b_opt = results['b_values'][opt_idx]\n","\n","  #print(i)\n","  #print('Phi_opt:',phi_opt)\n","  #print('B_opt:',b_opt)\n","\n","  mu_0_list_self, mu_1_list_self = optimization_v3.gen_mu_values(X_samples=X_test_sc, T_samples=T_test,Y_samples=Y_test_sc, rank=rank, rho=rho, method=method_tr[i],Z_estimation=z_est_tr[i])\n","  pol_value_self, pi_0_list_self, pi_1_list_self = optimization_v3.compute_x_opt(phi=phi_opt, b=b_opt, X_samples=X_test_sc, T_samples=T_test, mu_0_list=mu_0_list_self,mu_1_list=mu_1_list_self)\n","\n","  var_results[i,0] = np.std(pi_0_list_self + pi_1_list_self)\n","  polval_true[i,0] = pol_value_self\n","  polval_results[i,0] = np.mean(pi_0_list_self + pi_1_list_self)\n","\n","  for j in range(1,var_results.shape[1]):\n","\n","    mu_0_list, mu_1_list = optimization_v3.gen_mu_values(X_samples=X_test_sc, T_samples=T_test,Y_samples=Y_test_sc, rank=rank, rho=rho, method=method_te[j-1],Z_estimation=z_est_te[j-1])\n","    pol_value, pi_0_list, pi_1_list = optimization_v3.compute_x_opt(phi=phi_opt, b=b_opt, X_samples=X_test_sc, T_samples=T_test, mu_0_list=mu_0_list,mu_1_list=mu_1_list)\n","\n","    var_results[i,j] = np.std(pi_0_list + pi_1_list)\n","    polval_true[i,j] = pol_value\n","    polval_results[i,j] = np.mean(pi_0_list + pi_1_list)\n","\n","print('######## RANK=6 ########')\n","print('Out-of-sample Variances:', np.round(var_results,3))\n","print('Policy Values:', np.round(polval_results,3))\n","print('Policy Values Direct:', np.round(polval_true,3))"],"metadata":{"id":"uUw9p51jBGi9"},"execution_count":null,"outputs":[]},{"cell_type":"code","source":["##### Policy Optimization Attempt 2\n","# storage\n","np.random.seed(9827)\n","#rho = np.random.randn(1, Y_train_sc.shape[1])\n","rho = np.array([8.28,1.31,0.21,0.061,0.59,0.01,1.12])\n","rank = 7\n","var_results = np.zeros((6,5))\n","polval_results = np.zeros((6,5))\n","polval_true = np.zeros((6,5))\n","method_tr = ['direct', 'direct','IPW-obs','IPW','DR-obs', 'CV']\n","z_est_tr = [False, True, False, True, False, True]\n","method_te = ['direct', 'IPW-obs','DR-obs','DR']\n","z_est_te = [True, False, False, False]\n","\n","for i in range(var_results.shape[0]):\n","  results = optimization_v3.subgradient_descent(num_iter = 60,step_size = 3,key_start=1,X_samples=X_train_sc, T_samples = T_train, Y_samples = Y_train_sc_opt, rank=rank, rho = rho, method = method_tr[i], Z_estimation=z_est_tr[i])\n","  opt_idx = results['obj_values'].argmin()\n","  phi_opt = results['phi_values'][opt_idx]\n","  b_opt = results['b_values'][opt_idx]\n","\n","  #print(i)\n","  #print('Phi_opt:',phi_opt)\n","  #print('B_opt:',b_opt)\n","\n","  mu_0_list_self, mu_1_list_self = optimization_v3.gen_mu_values(X_samples=X_test_sc, T_samples=T_test,Y_samples=Y_test_sc, rank=rank, rho=rho, method=method_tr[i],Z_estimation=z_est_tr[i])\n","  pol_value_self, pi_0_list_self, pi_1_list_self = optimization_v3.compute_x_opt(phi=phi_opt, b=b_opt, X_samples=X_test_sc, T_samples=T_test, mu_0_list=mu_0_list_self,mu_1_list=mu_1_list_self)\n","\n","  var_results[i,0] = np.std(pi_0_list_self + pi_1_list_self)\n","  polval_true[i,0] = pol_value_self\n","  polval_results[i,0] = np.mean(pi_0_list_self + pi_1_list_self)\n","\n","  for j in range(1,var_results.shape[1]):\n","\n","    mu_0_list, mu_1_list = optimization_v3.gen_mu_values(X_samples=X_test_sc, T_samples=T_test,Y_samples=Y_test_sc, rank=rank, rho=rho, method=method_te[j-1],Z_estimation=z_est_te[j-1])\n","    pol_value, pi_0_list, pi_1_list = optimization_v3.compute_x_opt(phi=phi_opt, b=b_opt, X_samples=X_test_sc, T_samples=T_test, mu_0_list=mu_0_list,mu_1_list=mu_1_list)\n","\n","    var_results[i,j] = np.std(pi_0_list + pi_1_list)\n","    polval_true[i,j] = pol_value\n","    polval_results[i,j] = np.mean(pi_0_list + pi_1_list)\n","\n","print('######## RANK=7 ########')\n","print('Out-of-sample Variances:', np.round(var_results,3))\n","print('Policy Values:', np.round(polval_results,3))\n","print('Policy Values Direct:', np.round(polval_true,3))"],"metadata":{"id":"E2wIzVNRA5SO"},"execution_count":null,"outputs":[]}]}