{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "initial_id",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-05-22T07:41:03.562265Z",
     "start_time": "2024-05-22T07:41:03.559003Z"
    }
   },
   "outputs": [],
   "source": [
    "# Standard Imports\n",
    "import copy\n",
    "\n",
    "# Third Party Imports\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "from sklearn.linear_model import LogisticRegression\n",
    "from sklearn.metrics import accuracy_score\n",
    "from sklearn.model_selection import train_test_split\n",
    "from sklearn.preprocessing import StandardScaler"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "644fbcb1-a948-4036-8fec-6f18369ec046",
   "metadata": {},
   "source": [
    "#### Data Preparation"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "bc9ca94d-fd7a-46c5-932d-01ca644994c9",
   "metadata": {},
   "source": [
    "**Reading the Diabetes Transfusion Dataset**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "77cb6a91a07ed68d",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-05-22T07:41:03.731947Z",
     "start_time": "2024-05-22T07:41:03.723709Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>Pregnancies</th>\n",
       "      <th>Glucose</th>\n",
       "      <th>BloodPressure</th>\n",
       "      <th>SkinThickness</th>\n",
       "      <th>Insulin</th>\n",
       "      <th>BMI</th>\n",
       "      <th>DiabetesPedigreeFunction</th>\n",
       "      <th>Age</th>\n",
       "      <th>Outcome</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>6</td>\n",
       "      <td>148</td>\n",
       "      <td>72</td>\n",
       "      <td>35</td>\n",
       "      <td>0</td>\n",
       "      <td>33.6</td>\n",
       "      <td>0.627</td>\n",
       "      <td>50</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1</td>\n",
       "      <td>85</td>\n",
       "      <td>66</td>\n",
       "      <td>29</td>\n",
       "      <td>0</td>\n",
       "      <td>26.6</td>\n",
       "      <td>0.351</td>\n",
       "      <td>31</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>8</td>\n",
       "      <td>183</td>\n",
       "      <td>64</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>23.3</td>\n",
       "      <td>0.672</td>\n",
       "      <td>32</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>1</td>\n",
       "      <td>89</td>\n",
       "      <td>66</td>\n",
       "      <td>23</td>\n",
       "      <td>94</td>\n",
       "      <td>28.1</td>\n",
       "      <td>0.167</td>\n",
       "      <td>21</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0</td>\n",
       "      <td>137</td>\n",
       "      <td>40</td>\n",
       "      <td>35</td>\n",
       "      <td>168</td>\n",
       "      <td>43.1</td>\n",
       "      <td>2.288</td>\n",
       "      <td>33</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   Pregnancies  Glucose  BloodPressure  SkinThickness  Insulin   BMI  \\\n",
       "0            6      148             72             35        0  33.6   \n",
       "1            1       85             66             29        0  26.6   \n",
       "2            8      183             64              0        0  23.3   \n",
       "3            1       89             66             23       94  28.1   \n",
       "4            0      137             40             35      168  43.1   \n",
       "\n",
       "   DiabetesPedigreeFunction  Age  Outcome  \n",
       "0                     0.627   50        1  \n",
       "1                     0.351   31        0  \n",
       "2                     0.672   32        1  \n",
       "3                     0.167   21        0  \n",
       "4                     2.288   33        1  "
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Reading the Blood Dataset\n",
    "diabetes = pd.read_csv(\"./../../../datasets/diabetes/diabetes.csv\")\n",
    "diabetes.head()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "317ecda9-87df-40b3-918d-19b7ccd05777",
   "metadata": {},
   "source": [
    "**Print Info and Missing Values**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "1b167864-ced8-46fd-89d8-74266115ab90",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "<class 'pandas.core.frame.DataFrame'>\n",
      "RangeIndex: 768 entries, 0 to 767\n",
      "Data columns (total 9 columns):\n",
      " #   Column                    Non-Null Count  Dtype  \n",
      "---  ------                    --------------  -----  \n",
      " 0   Pregnancies               768 non-null    int64  \n",
      " 1   Glucose                   768 non-null    int64  \n",
      " 2   BloodPressure             768 non-null    int64  \n",
      " 3   SkinThickness             768 non-null    int64  \n",
      " 4   Insulin                   768 non-null    int64  \n",
      " 5   BMI                       768 non-null    float64\n",
      " 6   DiabetesPedigreeFunction  768 non-null    float64\n",
      " 7   Age                       768 non-null    int64  \n",
      " 8   Outcome                   768 non-null    int64  \n",
      "dtypes: float64(2), int64(7)\n",
      "memory usage: 54.1 KB\n",
      "None\n",
      "\n",
      "\n",
      "\n",
      "Missing values:  False\n"
     ]
    }
   ],
   "source": [
    "print(diabetes.info())\n",
    "print(\"\\n\\n\")\n",
    "print(\"Missing values: \", diabetes.isnull().values.any())"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "d921143a-172f-4f29-80c6-5a877643d067",
   "metadata": {},
   "source": [
    "**Variance Check**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "948672e3-370b-466e-97ac-be927c47d05f",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Pregnancies                    11.354\n",
       "Glucose                      1022.248\n",
       "BloodPressure                 374.647\n",
       "SkinThickness                 254.473\n",
       "Insulin                     13281.180\n",
       "BMI                            62.160\n",
       "DiabetesPedigreeFunction        0.110\n",
       "Age                           138.303\n",
       "Outcome                         0.227\n",
       "dtype: float64"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "diabetes.var().round(3)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "039d6a5a-4cb2-43ea-b8c5-0c2488444861",
   "metadata": {},
   "source": [
    "Very different variance levels"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "0aac7df9-f6fe-43ef-96a9-b10fa43a1ebf",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Log Transformation of Monetary (c.c. blood) to reduce the variance and range\n",
    "# blood['Monetary (c.c. blood)'] = blood['Monetary (c.c. blood)'] / 100\n",
    "# blood.var().round(3)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "a9aaeed7-a7e6-4fac-83fb-213f6b0c3774",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>Pregnancies</th>\n",
       "      <th>Glucose</th>\n",
       "      <th>BloodPressure</th>\n",
       "      <th>SkinThickness</th>\n",
       "      <th>Insulin</th>\n",
       "      <th>BMI</th>\n",
       "      <th>DiabetesPedigreeFunction</th>\n",
       "      <th>Age</th>\n",
       "      <th>Outcome</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>6</td>\n",
       "      <td>148</td>\n",
       "      <td>72</td>\n",
       "      <td>35</td>\n",
       "      <td>0</td>\n",
       "      <td>33.6</td>\n",
       "      <td>0.627</td>\n",
       "      <td>50</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1</td>\n",
       "      <td>85</td>\n",
       "      <td>66</td>\n",
       "      <td>29</td>\n",
       "      <td>0</td>\n",
       "      <td>26.6</td>\n",
       "      <td>0.351</td>\n",
       "      <td>31</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>8</td>\n",
       "      <td>183</td>\n",
       "      <td>64</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>23.3</td>\n",
       "      <td>0.672</td>\n",
       "      <td>32</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>1</td>\n",
       "      <td>89</td>\n",
       "      <td>66</td>\n",
       "      <td>23</td>\n",
       "      <td>94</td>\n",
       "      <td>28.1</td>\n",
       "      <td>0.167</td>\n",
       "      <td>21</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0</td>\n",
       "      <td>137</td>\n",
       "      <td>40</td>\n",
       "      <td>35</td>\n",
       "      <td>168</td>\n",
       "      <td>43.1</td>\n",
       "      <td>2.288</td>\n",
       "      <td>33</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   Pregnancies  Glucose  BloodPressure  SkinThickness  Insulin   BMI  \\\n",
       "0            6      148             72             35        0  33.6   \n",
       "1            1       85             66             29        0  26.6   \n",
       "2            8      183             64              0        0  23.3   \n",
       "3            1       89             66             23       94  28.1   \n",
       "4            0      137             40             35      168  43.1   \n",
       "\n",
       "   DiabetesPedigreeFunction  Age  Outcome  \n",
       "0                     0.627   50        1  \n",
       "1                     0.351   31        0  \n",
       "2                     0.672   32        1  \n",
       "3                     0.167   21        0  \n",
       "4                     2.288   33        1  "
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "diabetes.head()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "06776d06-aac3-4cd8-b1e8-b8498381d713",
   "metadata": {},
   "source": [
    "**Checking the distribution of target values**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "339d9bbe-8754-4572-87e1-3365bed7af5e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Outcome\n",
       "0    0.651\n",
       "1    0.349\n",
       "Name: proportion, dtype: float64"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "diabetes[\"Outcome\"].value_counts(normalize=True).round(3)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "0ce86e3c-d237-459e-805b-83a02b971354",
   "metadata": {},
   "source": [
    "**Train-Test Split**"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "852899ac-5378-4914-a9e7-c206ded4d0de",
   "metadata": {},
   "source": [
    "Train - Test Split &nbsp;&nbsp;&nbsp;&nbsp; 60%-40%\n",
    "\n",
    "The Test-Set is Further split into Verb And Gen split\n",
    "\n",
    "Verb - Gen Split   &nbsp;&nbsp;&nbsp;&nbsp; 50%-50%"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "bf7ff54f-f3f4-40e6-8bc4-424d99ae8af8",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Train Test Split Stratified on Target Feature\n",
    "X_train, X_test, y_train, y_test = train_test_split(diabetes.drop(columns=\"Outcome\"), diabetes[\"Outcome\"], test_size=0.40, random_state=400, stratify=diabetes[\"Outcome\"])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "5cc4deea-e333-4ce0-890d-ad1078aac260",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Train Test Split on the Test set to get Verb and Gen Sets. Stratified on the Target Feature\n",
    "X_test_verb, X_test_gen, y_test_verb, y_test_gen = train_test_split(X_test, y_test, test_size=0.5, random_state=400, stratify=y_test)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "bda17883-3302-4fc9-8b3b-46c6c669a070",
   "metadata": {},
   "source": [
    "**Checking the distribution target values after the split**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "f79613d4",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Outcome\n",
      "0    0.65\n",
      "1    0.35\n",
      "Name: proportion, dtype: float64\n",
      "Outcome\n",
      "0    0.649\n",
      "1    0.351\n",
      "Name: proportion, dtype: float64\n",
      "Outcome\n",
      "0    0.656\n",
      "1    0.344\n",
      "Name: proportion, dtype: float64\n"
     ]
    }
   ],
   "source": [
    "print(y_train.value_counts(normalize=True).round(3))\n",
    "print(y_test_verb.value_counts(normalize=True).round(3))\n",
    "print(y_test_gen.value_counts(normalize=True).round(3))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ccf6c676-335d-4133-afa2-5161bd932f2a",
   "metadata": {},
   "source": [
    "**Variance Check**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "9bf865bb-067e-40f8-bfb8-03afba7c71a1",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Pregnancies                    10.487\n",
       "Glucose                      1113.213\n",
       "BloodPressure                 327.460\n",
       "SkinThickness                 261.244\n",
       "Insulin                     13817.680\n",
       "BMI                            65.503\n",
       "DiabetesPedigreeFunction        0.109\n",
       "Age                           131.501\n",
       "dtype: float64"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "X_train.var().round(3)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "0a7a2750-30fc-45f5-97d9-9bd0863cab60",
   "metadata": {},
   "source": [
    "**Standardization** - Skipping this because the resulting dataset has very high precision float values (that may not be good for the LLM)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "ebbccb2f-d31e-451c-83a4-ba3b35025796",
   "metadata": {},
   "outputs": [],
   "source": [
    "scaler = StandardScaler()\n",
    "X_train_scaled = scaler.fit_transform(X_train)\n",
    "X_test_gen_scaled = scaler.transform(X_test_gen)\n",
    "X_test_verb_scaled = scaler.transform(X_test_verb)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "99cb1c0e-8239-4489-a757-51307bfe7e8a",
   "metadata": {},
   "source": [
    "**Converting them back to dataframes** - No need for this now as there's no standardization"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "563a7aff-a958-42bf-a740-bfe04b397aee",
   "metadata": {},
   "outputs": [],
   "source": [
    "X_train_scaled_df = pd.DataFrame(X_train_scaled, columns=X_train.columns)\n",
    "X_test_gen_scaled_df = pd.DataFrame(X_test_gen_scaled, columns=X_test.columns)\n",
    "X_test_verb_scaled_df = pd.DataFrame(X_test_verb_scaled, columns=X_test.columns)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "d53928be",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Pregnancies                 1.002\n",
       "Glucose                     1.002\n",
       "BloodPressure               1.002\n",
       "SkinThickness               1.002\n",
       "Insulin                     1.002\n",
       "BMI                         1.002\n",
       "DiabetesPedigreeFunction    1.002\n",
       "Age                         1.002\n",
       "dtype: float64"
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "X_train_scaled_df.var().round(3)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "f17ef567-4f0f-495c-9621-6c2d1c30b7a4",
   "metadata": {},
   "outputs": [],
   "source": [
    "expansion_factor = 100\n",
    "X_train_scaled_df = X_train_scaled_df * expansion_factor\n",
    "X_test_verb_scaled_df = X_test_verb_scaled_df * expansion_factor\n",
    "X_test_gen_scaled_df = X_test_gen_scaled_df * expansion_factor"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "348f1077-16d7-47d1-a906-5b039c6573c9",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Pregnancies                 10021.786\n",
       "Glucose                     10021.786\n",
       "BloodPressure               10021.786\n",
       "SkinThickness               10021.786\n",
       "Insulin                     10021.786\n",
       "BMI                         10021.786\n",
       "DiabetesPedigreeFunction    10021.786\n",
       "Age                         10021.786\n",
       "dtype: float64"
      ]
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "X_train_scaled_df.var().round(3)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "97fe3ae9-5bdc-488c-9339-af497d6999ee",
   "metadata": {},
   "source": [
    "From here Onwards `X_test_verb_scaled_df` is going to be `X_test_scaled_df`. `X_test_gen_scaled_df` is not going to be used at all in the code"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "61841898",
   "metadata": {},
   "outputs": [],
   "source": [
    "X_test_scaled_df = X_test_verb_scaled_df\n",
    "y_test = y_test_verb"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c89636ce-0600-405c-ad76-9f9edb475f76",
   "metadata": {},
   "source": [
    "#### Model Variations"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "98c6a1a3",
   "metadata": {},
   "source": [
    "**Base Model**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "d0698840-a387-47f3-8b76-37a875fdcbdc",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/model_selection/_validation.py:540: FitFailedWarning: \n",
      "35 fits failed out of a total of 100.\n",
      "The score on these train-test partitions for these parameters will be set to nan.\n",
      "If these failures are not expected, you can try to debug them by setting error_score='raise'.\n",
      "\n",
      "Below are more details about the failures:\n",
      "--------------------------------------------------------------------------------\n",
      "5 fits failed with the following error:\n",
      "Traceback (most recent call last):\n",
      "  File \"/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/model_selection/_validation.py\", line 888, in _fit_and_score\n",
      "    estimator.fit(X_train, y_train, **fit_params)\n",
      "  File \"/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/base.py\", line 1473, in wrapper\n",
      "    return fit_method(estimator, *args, **kwargs)\n",
      "           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n",
      "  File \"/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py\", line 1194, in fit\n",
      "    solver = _check_solver(self.solver, self.penalty, self.dual)\n",
      "             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n",
      "  File \"/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py\", line 67, in _check_solver\n",
      "    raise ValueError(\n",
      "ValueError: Solver lbfgs supports only 'l2' or None penalties, got elasticnet penalty.\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "10 fits failed with the following error:\n",
      "Traceback (most recent call last):\n",
      "  File \"/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/model_selection/_validation.py\", line 888, in _fit_and_score\n",
      "    estimator.fit(X_train, y_train, **fit_params)\n",
      "  File \"/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/base.py\", line 1473, in wrapper\n",
      "    return fit_method(estimator, *args, **kwargs)\n",
      "           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n",
      "  File \"/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py\", line 1194, in fit\n",
      "    solver = _check_solver(self.solver, self.penalty, self.dual)\n",
      "             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n",
      "  File \"/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py\", line 67, in _check_solver\n",
      "    raise ValueError(\n",
      "ValueError: Solver lbfgs supports only 'l2' or None penalties, got l1 penalty.\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "5 fits failed with the following error:\n",
      "Traceback (most recent call last):\n",
      "  File \"/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/model_selection/_validation.py\", line 888, in _fit_and_score\n",
      "    estimator.fit(X_train, y_train, **fit_params)\n",
      "  File \"/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/base.py\", line 1473, in wrapper\n",
      "    return fit_method(estimator, *args, **kwargs)\n",
      "           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n",
      "  File \"/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py\", line 1194, in fit\n",
      "    solver = _check_solver(self.solver, self.penalty, self.dual)\n",
      "             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n",
      "  File \"/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py\", line 67, in _check_solver\n",
      "    raise ValueError(\n",
      "ValueError: Solver sag supports only 'l2' or None penalties, got elasticnet penalty.\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "5 fits failed with the following error:\n",
      "Traceback (most recent call last):\n",
      "  File \"/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/model_selection/_validation.py\", line 888, in _fit_and_score\n",
      "    estimator.fit(X_train, y_train, **fit_params)\n",
      "  File \"/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/base.py\", line 1473, in wrapper\n",
      "    return fit_method(estimator, *args, **kwargs)\n",
      "           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n",
      "  File \"/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py\", line 1194, in fit\n",
      "    solver = _check_solver(self.solver, self.penalty, self.dual)\n",
      "             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n",
      "  File \"/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py\", line 67, in _check_solver\n",
      "    raise ValueError(\n",
      "ValueError: Solver newton-cg supports only 'l2' or None penalties, got l1 penalty.\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "5 fits failed with the following error:\n",
      "Traceback (most recent call last):\n",
      "  File \"/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/model_selection/_validation.py\", line 888, in _fit_and_score\n",
      "    estimator.fit(X_train, y_train, **fit_params)\n",
      "  File \"/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/base.py\", line 1473, in wrapper\n",
      "    return fit_method(estimator, *args, **kwargs)\n",
      "           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n",
      "  File \"/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py\", line 1194, in fit\n",
      "    solver = _check_solver(self.solver, self.penalty, self.dual)\n",
      "             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n",
      "  File \"/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py\", line 75, in _check_solver\n",
      "    raise ValueError(\n",
      "ValueError: Only 'saga' solver supports elasticnet penalty, got solver=liblinear.\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "5 fits failed with the following error:\n",
      "Traceback (most recent call last):\n",
      "  File \"/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/model_selection/_validation.py\", line 888, in _fit_and_score\n",
      "    estimator.fit(X_train, y_train, **fit_params)\n",
      "  File \"/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/base.py\", line 1473, in wrapper\n",
      "    return fit_method(estimator, *args, **kwargs)\n",
      "           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n",
      "  File \"/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py\", line 1194, in fit\n",
      "    solver = _check_solver(self.solver, self.penalty, self.dual)\n",
      "             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n",
      "  File \"/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py\", line 67, in _check_solver\n",
      "    raise ValueError(\n",
      "ValueError: Solver newton-cg supports only 'l2' or None penalties, got elasticnet penalty.\n",
      "\n",
      "  warnings.warn(some_fits_failed_message, FitFailedWarning)\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/model_selection/_search.py:1102: UserWarning: One or more of the test scores are non-finite: [       nan 0.73695652 0.73478261 0.73695652 0.7326087  0.73913043\n",
      "        nan 0.7173913  0.73913043        nan 0.77391304        nan\n",
      " 0.74565217        nan 0.73478261        nan 0.74130435        nan\n",
      " 0.76304348 0.77391304]\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Best parameters found:  {'C': np.float64(2548.9737509899405), 'class_weight': None, 'l1_ratio': np.float64(0.17163875258096095), 'max_iter': 805, 'penalty': 'l2', 'solver': 'newton-cg', 'tol': np.float64(4.589080818436565e-06)}\n",
      "Best score:  0.773913043478261\n"
     ]
    }
   ],
   "source": [
    "from sklearn.model_selection import RandomizedSearchCV\n",
    "from sklearn.linear_model import LogisticRegression\n",
    "from scipy.stats import loguniform, uniform\n",
    "\n",
    "np.random.seed(400)\n",
    "\n",
    "param_dist = {\n",
    "    'C': loguniform(1e-4, 1e4),\n",
    "    'penalty': ['l1', 'l2', 'elasticnet'],\n",
    "    'solver': ['newton-cg', 'lbfgs', 'liblinear', 'sag', 'saga'],\n",
    "    'tol': loguniform(1e-6, 1e-1),\n",
    "    'max_iter': [int(x) for x in range(10, 1001)],\n",
    "    'class_weight': [None, 'balanced'],\n",
    "    'l1_ratio': uniform(0, 1)  # Only used if penalty is 'elasticnet'\n",
    "}\n",
    "\n",
    "# Create the logistic regression model\n",
    "log_reg = LogisticRegression()\n",
    "\n",
    "# Create the RandomizedSearchCV object\n",
    "random_search = RandomizedSearchCV(log_reg, param_distributions=param_dist, n_iter=20, cv=5, random_state=40)\n",
    "\n",
    "# Fit the model\n",
    "random_search.fit(X_train_scaled_df, y_train)\n",
    "\n",
    "# Print the best parameters and the best score\n",
    "print(\"Best parameters found: \", random_search.best_params_)\n",
    "print(\"Best score: \", random_search.best_score_)\n",
    "best_params = random_search.best_params_\n",
    "best_score = random_search.best_score_"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "9c1d7336",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n"
     ]
    }
   ],
   "source": [
    "# Train the base model\n",
    "def train_base_model(X_train, y_train):\n",
    "    # model = LogisticRegression(C=0.1, max_iter=1000, random_state=400)\n",
    "    model = LogisticRegression(**best_params)\n",
    "    model.fit(X_train, y_train)\n",
    "    return model\n",
    "\n",
    "base_model = train_base_model(X_train_scaled_df, y_train)\n",
    "base_pred = base_model.predict(X_test_scaled_df)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "1f78d8c6-c30d-4de5-9132-a264c4918529",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.7792207792207793\n"
     ]
    }
   ],
   "source": [
    "print(accuracy_score(y_test, base_pred))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "7d95c6fa-d11c-4c8f-8cd6-ada24341837b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'C': np.float64(2548.9737509899405),\n",
       " 'class_weight': None,\n",
       " 'l1_ratio': np.float64(0.17163875258096095),\n",
       " 'max_iter': 805,\n",
       " 'penalty': 'l2',\n",
       " 'solver': 'newton-cg',\n",
       " 'tol': np.float64(4.589080818436565e-06)}"
      ]
     },
     "execution_count": 21,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "best_params"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "087401a5-0018-4860-a224-9966a4e1b198",
   "metadata": {},
   "source": [
    "**Functions to copy and modify coefficients of a model**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "9296776c",
   "metadata": {},
   "outputs": [],
   "source": [
    "# This function works for binary classification only\n",
    "def modify_coefficients(model, modification_factor=0.2):\n",
    "    modified_model = copy.deepcopy(model)\n",
    "    \n",
    "    # Get the coefficients and intercept\n",
    "    coef = modified_model.coef_[0]\n",
    "    intercept = modified_model.intercept_[0]\n",
    "    \n",
    "    # Modify coefficients\n",
    "    noise = np.random.normal(0, modification_factor, size=coef.shape)\n",
    "    modified_coef = coef * (1 + noise) # This helps scale the noise to the coefficients\n",
    "\n",
    "    # Print Modifications and Noise\n",
    "    print(f\"Modification Factor: {modification_factor}\", f\"Noise: {noise}\")\n",
    "    \n",
    "    # Modify intercept\n",
    "    modified_intercept = intercept * (1 + np.random.normal(0, modification_factor))\n",
    "    \n",
    "    # Set the modified coefficients and intercept\n",
    "    modified_model.coef_[0] = modified_coef\n",
    "    modified_model.intercept_[0] = modified_intercept\n",
    "    \n",
    "    return modified_model\n",
    "    \n",
    "# Function to compute the differences\n",
    "def compute_difference(pred1, pred2):\n",
    "    return np.mean(pred1 != pred2)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "fb632903-7860-4b55-9fb8-b8a185e0ac82",
   "metadata": {},
   "source": [
    "**Generate and Compare Model Variations**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "0d218566-9014-42a2-8f4b-b0b231ab5ea0",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Modification Factor: 0.1 Noise: [-0.17497655  0.03426804  0.11530358 -0.0252436   0.09813208  0.05142188\n",
      "  0.02211797 -0.10700433]\n",
      "Modification Factor: 0.2 Noise: [ 0.05100029 -0.0916054   0.0870327  -0.11671901  0.16336941  0.13454416\n",
      " -0.02088223 -0.10625608]\n",
      "Modification Factor: 0.3 Noise: [-0.13144069 -0.33549547  0.4856945   0.46248155 -0.07556374 -0.25273072\n",
      "  0.05535561  0.28112466]\n",
      "Modification Factor: 0.4 Noise: [ 0.54462245 -0.13049522  0.02227041  0.08895984 -0.5772868  -0.30254092\n",
      "  0.3265816   0.3001779 ]\n",
      "Modification Factor: 0.5 Noise: [ 0.59481113 -0.84530841 -0.67819952 -0.61621726 -0.27221958 -0.33408587\n",
      "  0.00365728 -0.30646937]\n",
      "Modification Factor: 0.6 Noise: [-1.03985737 -0.58998606  0.21450465 -0.9681471   0.88242832 -0.71281056\n",
      " -0.32984772 -0.5640277 ]\n",
      "Modification Factor: 0.7 Noise: [ 0.07620443  0.35546671 -0.60355914  0.87462882 -0.05572787 -0.62281204\n",
      " -0.61725887  0.01304726]\n",
      "Modification Factor: 0.8 Noise: [ 0.01083884 -1.30842352 -0.8353679   0.49043111  0.58896417  0.82153715\n",
      " -1.14575249 -1.47295064]\n",
      "Modification Factor: 0.9 Noise: [-0.29859942 -0.62029618  1.83114681 -0.49564297  0.675408   -1.17629311\n",
      "  0.522516   -0.99407078]\n",
      "Modification Factor: 1.0 Noise: [ 0.68689007 -1.56668753  0.90497412  0.7788224   0.42823287  0.10887199\n",
      "  0.02828363 -0.57882582]\n",
      "Modification Factor: 1.1 Noise: [-1.87654721  0.40608035  2.06423077 -0.41459369  2.01512969  0.00331918\n",
      " -0.08362581  0.00435335]\n",
      "Modification Factor: 1.2 Noise: [-2.98458184 -2.04558145 -1.36351321 -3.56797857  0.03998073 -0.2986664\n",
      " -0.54021172  0.15891336]\n",
      "Modification Factor: 1.3 Noise: [ 0.41257837 -0.97813843 -1.68530935  0.12368128 -0.55082963 -1.54177863\n",
      " -0.47510059 -1.65232995]\n",
      "Modification Factor: 1.4 Noise: [ 0.97074692 -2.74131373 -0.18872184 -2.15686243  2.86539956 -1.95579908\n",
      " -1.53604078 -0.33419802]\n",
      "Modification Factor: 1.5 Noise: [ 1.42350716 -0.02909638  1.34189656  1.13953968 -2.24658057 -1.79082897\n",
      "  1.94439388  1.42841344]\n",
      "Modification Factor: 1.6 Noise: [-0.25162427 -2.41213626  0.17261461  1.19528905  0.6874823  -2.26406867\n",
      " -1.02521588  1.24740209]\n",
      "Modification Factor: 1.7 Noise: [ 3.52714839 -0.58360606 -1.04826993  1.2974122   0.32795923 -0.59238018\n",
      "  3.9077117  -0.28085624]\n"
     ]
    }
   ],
   "source": [
    "# np.random.seed(21)\n",
    "# np.random.seed(120)\n",
    "# np.random.seed(125)\n",
    "np.random.seed(100)\n",
    "\n",
    "# Create variations of the model\n",
    "variations = []\n",
    "# modification_factors = [0.1, 0.3, 0.5, 0.7, 0.9, 1.1, 1.3, 1.5]\n",
    "# modification_factors = [0.1, 4, 1.3, 1.2, 1.1, 1.0, 0.9, 0.8, 0.7, 0.6, 0.5, 0.4, 0.3, 0.2, 0.1]\n",
    "modification_factors = [0.1, 0.2, 0.3, 0.4, 0.5, 0.6, 0.7, 0.8, 0.9, 1.0, 1.1, 1.2, 1.3, 1.4, 1.5, 1.6, 1.7]\n",
    "\n",
    "for factor in modification_factors:\n",
    "    modified_model = modify_coefficients(base_model, factor)\n",
    "    variations.append((f\"Modified (factor={factor})\", modified_model))\n",
    "\n",
    "# Find the pair of models with the highest difference\n",
    "best_diff = 0\n",
    "best_pair = None"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "cdc0b596-9624-4775-a67d-e27d545d5187",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "With Model: Modified (factor=0.1), Diff: 0.006493506493506494\n",
      "With Model: Modified (factor=0.2), Diff: 0.025974025974025976\n",
      "With Model: Modified (factor=0.3), Diff: 0.08441558441558442\n",
      "With Model: Modified (factor=0.4), Diff: 0.045454545454545456\n",
      "With Model: Modified (factor=0.5), Diff: 0.2597402597402597\n",
      "With Model: Modified (factor=0.6), Diff: 0.16883116883116883\n",
      "With Model: Modified (factor=0.7), Diff: 0.045454545454545456\n",
      "With Model: Modified (factor=0.8), Diff: 0.2857142857142857\n",
      "With Model: Modified (factor=0.9), Diff: 0.2922077922077922\n",
      "With Model: Modified (factor=1.0), Diff: 0.5714285714285714\n",
      "With Model: Modified (factor=1.1), Diff: 0.12337662337662338\n",
      "With Model: Modified (factor=1.2), Diff: 0.487012987012987\n",
      "With Model: Modified (factor=1.3), Diff: 0.2987012987012987\n",
      "With Model: Modified (factor=1.4), Diff: 0.8246753246753247\n",
      "With Model: Modified (factor=1.5), Diff: 0.37662337662337664\n",
      "With Model: Modified (factor=1.6), Diff: 0.6883116883116883\n",
      "With Model: Modified (factor=1.7), Diff: 0.22727272727272727\n",
      "Best Model till now is Modified (factor=1.7)\n"
     ]
    }
   ],
   "source": [
    "# Comparison with the base model\n",
    "for name, model in variations:\n",
    "    modified_pred = model.predict(X_test_scaled_df)\n",
    "    diff = compute_difference(base_pred, modified_pred)\n",
    "    print(f\"With Model: {name}, Diff: {diff}\") \n",
    "    if diff > best_diff and (diff >= 0.20 and diff <=0.25):\n",
    "        print(\"Best Model till now is\", name)\n",
    "        best_diff = diff\n",
    "        best_pair = ((\"Base Model\", base_model), (name, model))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "1c0ac2be-b6b4-4eda-aeda-84c752debaae",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "With Models: Modified (factor=0.1) vs Modified (factor=0.2), Diff: 0.032467532467532464\n",
      "With Models: Modified (factor=0.1) vs Modified (factor=0.3), Diff: 0.07792207792207792\n",
      "With Models: Modified (factor=0.1) vs Modified (factor=0.4), Diff: 0.03896103896103896\n",
      "With Models: Modified (factor=0.1) vs Modified (factor=0.5), Diff: 0.2662337662337662\n",
      "With Models: Modified (factor=0.1) vs Modified (factor=0.6), Diff: 0.16233766233766234\n",
      "With Models: Modified (factor=0.1) vs Modified (factor=0.7), Diff: 0.05194805194805195\n",
      "With Models: Modified (factor=0.1) vs Modified (factor=0.8), Diff: 0.2922077922077922\n",
      "With Models: Modified (factor=0.1) vs Modified (factor=0.9), Diff: 0.2857142857142857\n",
      "With Models: Modified (factor=0.1) vs Modified (factor=1.0), Diff: 0.564935064935065\n",
      "With Models: Modified (factor=0.1) vs Modified (factor=1.1), Diff: 0.11688311688311688\n",
      "With Models: Modified (factor=0.1) vs Modified (factor=1.2), Diff: 0.4935064935064935\n",
      "With Models: Modified (factor=0.1) vs Modified (factor=1.3), Diff: 0.3051948051948052\n",
      "With Models: Modified (factor=0.1) vs Modified (factor=1.4), Diff: 0.8181818181818182\n",
      "With Models: Modified (factor=0.1) vs Modified (factor=1.5), Diff: 0.37012987012987014\n",
      "With Models: Modified (factor=0.1) vs Modified (factor=1.6), Diff: 0.6818181818181818\n",
      "With Models: Modified (factor=0.1) vs Modified (factor=1.7), Diff: 0.23376623376623376\n",
      "Best Model Pair till now is Modified (factor=0.1) vs Modified (factor=1.7)\n",
      "With Models: Modified (factor=0.2) vs Modified (factor=0.3), Diff: 0.07142857142857142\n",
      "With Models: Modified (factor=0.2) vs Modified (factor=0.4), Diff: 0.07142857142857142\n",
      "With Models: Modified (factor=0.2) vs Modified (factor=0.5), Diff: 0.23376623376623376\n",
      "With Models: Modified (factor=0.2) vs Modified (factor=0.6), Diff: 0.14285714285714285\n",
      "With Models: Modified (factor=0.2) vs Modified (factor=0.7), Diff: 0.045454545454545456\n",
      "With Models: Modified (factor=0.2) vs Modified (factor=0.8), Diff: 0.2597402597402597\n",
      "With Models: Modified (factor=0.2) vs Modified (factor=0.9), Diff: 0.2662337662337662\n",
      "With Models: Modified (factor=0.2) vs Modified (factor=1.0), Diff: 0.5584415584415584\n",
      "With Models: Modified (factor=0.2) vs Modified (factor=1.1), Diff: 0.13636363636363635\n",
      "With Models: Modified (factor=0.2) vs Modified (factor=1.2), Diff: 0.474025974025974\n",
      "With Models: Modified (factor=0.2) vs Modified (factor=1.3), Diff: 0.2727272727272727\n",
      "With Models: Modified (factor=0.2) vs Modified (factor=1.4), Diff: 0.8246753246753247\n",
      "With Models: Modified (factor=0.2) vs Modified (factor=1.5), Diff: 0.4025974025974026\n",
      "With Models: Modified (factor=0.2) vs Modified (factor=1.6), Diff: 0.6753246753246753\n",
      "With Models: Modified (factor=0.2) vs Modified (factor=1.7), Diff: 0.21428571428571427\n",
      "With Models: Modified (factor=0.3) vs Modified (factor=0.4), Diff: 0.09090909090909091\n",
      "With Models: Modified (factor=0.3) vs Modified (factor=0.5), Diff: 0.18831168831168832\n",
      "With Models: Modified (factor=0.3) vs Modified (factor=0.6), Diff: 0.13636363636363635\n",
      "With Models: Modified (factor=0.3) vs Modified (factor=0.7), Diff: 0.1038961038961039\n",
      "With Models: Modified (factor=0.3) vs Modified (factor=0.8), Diff: 0.2922077922077922\n",
      "With Models: Modified (factor=0.3) vs Modified (factor=0.9), Diff: 0.2077922077922078\n",
      "With Models: Modified (factor=0.3) vs Modified (factor=1.0), Diff: 0.551948051948052\n",
      "With Models: Modified (factor=0.3) vs Modified (factor=1.1), Diff: 0.16883116883116883\n",
      "With Models: Modified (factor=0.3) vs Modified (factor=1.2), Diff: 0.4155844155844156\n",
      "With Models: Modified (factor=0.3) vs Modified (factor=1.3), Diff: 0.22727272727272727\n",
      "With Models: Modified (factor=0.3) vs Modified (factor=1.4), Diff: 0.7792207792207793\n",
      "With Models: Modified (factor=0.3) vs Modified (factor=1.5), Diff: 0.38311688311688313\n",
      "With Models: Modified (factor=0.3) vs Modified (factor=1.6), Diff: 0.6038961038961039\n",
      "With Models: Modified (factor=0.3) vs Modified (factor=1.7), Diff: 0.19480519480519481\n",
      "With Models: Modified (factor=0.4) vs Modified (factor=0.5), Diff: 0.2792207792207792\n",
      "With Models: Modified (factor=0.4) vs Modified (factor=0.6), Diff: 0.18831168831168832\n",
      "With Models: Modified (factor=0.4) vs Modified (factor=0.7), Diff: 0.09090909090909091\n",
      "With Models: Modified (factor=0.4) vs Modified (factor=0.8), Diff: 0.33116883116883117\n",
      "With Models: Modified (factor=0.4) vs Modified (factor=0.9), Diff: 0.2987012987012987\n",
      "With Models: Modified (factor=0.4) vs Modified (factor=1.0), Diff: 0.538961038961039\n",
      "With Models: Modified (factor=0.4) vs Modified (factor=1.1), Diff: 0.15584415584415584\n",
      "With Models: Modified (factor=0.4) vs Modified (factor=1.2), Diff: 0.5064935064935064\n",
      "With Models: Modified (factor=0.4) vs Modified (factor=1.3), Diff: 0.3181818181818182\n",
      "With Models: Modified (factor=0.4) vs Modified (factor=1.4), Diff: 0.7792207792207793\n",
      "With Models: Modified (factor=0.4) vs Modified (factor=1.5), Diff: 0.33116883116883117\n",
      "With Models: Modified (factor=0.4) vs Modified (factor=1.6), Diff: 0.6558441558441559\n",
      "With Models: Modified (factor=0.4) vs Modified (factor=1.7), Diff: 0.2077922077922078\n",
      "With Models: Modified (factor=0.5) vs Modified (factor=0.6), Diff: 0.16883116883116883\n",
      "With Models: Modified (factor=0.5) vs Modified (factor=0.7), Diff: 0.24025974025974026\n",
      "With Models: Modified (factor=0.5) vs Modified (factor=0.8), Diff: 0.19480519480519481\n",
      "With Models: Modified (factor=0.5) vs Modified (factor=0.9), Diff: 0.08441558441558442\n",
      "With Models: Modified (factor=0.5) vs Modified (factor=1.0), Diff: 0.5714285714285714\n",
      "With Models: Modified (factor=0.5) vs Modified (factor=1.1), Diff: 0.3181818181818182\n",
      "With Models: Modified (factor=0.5) vs Modified (factor=1.2), Diff: 0.2532467532467532\n",
      "With Models: Modified (factor=0.5) vs Modified (factor=1.3), Diff: 0.03896103896103896\n",
      "With Models: Modified (factor=0.5) vs Modified (factor=1.4), Diff: 0.7077922077922078\n",
      "With Models: Modified (factor=0.5) vs Modified (factor=1.5), Diff: 0.5584415584415584\n",
      "With Models: Modified (factor=0.5) vs Modified (factor=1.6), Diff: 0.45454545454545453\n",
      "With Models: Modified (factor=0.5) vs Modified (factor=1.7), Diff: 0.24025974025974026\n",
      "With Models: Modified (factor=0.6) vs Modified (factor=0.7), Diff: 0.16233766233766234\n",
      "With Models: Modified (factor=0.6) vs Modified (factor=0.8), Diff: 0.2597402597402597\n",
      "With Models: Modified (factor=0.6) vs Modified (factor=0.9), Diff: 0.14935064935064934\n",
      "With Models: Modified (factor=0.6) vs Modified (factor=1.0), Diff: 0.5454545454545454\n",
      "With Models: Modified (factor=0.6) vs Modified (factor=1.1), Diff: 0.14935064935064934\n",
      "With Models: Modified (factor=0.6) vs Modified (factor=1.2), Diff: 0.38311688311688313\n",
      "With Models: Modified (factor=0.6) vs Modified (factor=1.3), Diff: 0.18181818181818182\n",
      "With Models: Modified (factor=0.6) vs Modified (factor=1.4), Diff: 0.7727272727272727\n",
      "With Models: Modified (factor=0.6) vs Modified (factor=1.5), Diff: 0.45454545454545453\n",
      "With Models: Modified (factor=0.6) vs Modified (factor=1.6), Diff: 0.5714285714285714\n",
      "With Models: Modified (factor=0.6) vs Modified (factor=1.7), Diff: 0.2792207792207792\n",
      "With Models: Modified (factor=0.7) vs Modified (factor=0.8), Diff: 0.2922077922077922\n",
      "With Models: Modified (factor=0.7) vs Modified (factor=0.9), Diff: 0.2727272727272727\n",
      "With Models: Modified (factor=0.7) vs Modified (factor=1.0), Diff: 0.6038961038961039\n",
      "With Models: Modified (factor=0.7) vs Modified (factor=1.1), Diff: 0.12987012987012986\n",
      "With Models: Modified (factor=0.7) vs Modified (factor=1.2), Diff: 0.4805194805194805\n",
      "With Models: Modified (factor=0.7) vs Modified (factor=1.3), Diff: 0.2662337662337662\n",
      "With Models: Modified (factor=0.7) vs Modified (factor=1.4), Diff: 0.8441558441558441\n",
      "With Models: Modified (factor=0.7) vs Modified (factor=1.5), Diff: 0.3961038961038961\n",
      "With Models: Modified (factor=0.7) vs Modified (factor=1.6), Diff: 0.6818181818181818\n",
      "With Models: Modified (factor=0.7) vs Modified (factor=1.7), Diff: 0.24675324675324675\n",
      "With Models: Modified (factor=0.8) vs Modified (factor=0.9), Diff: 0.22727272727272727\n",
      "With Models: Modified (factor=0.8) vs Modified (factor=1.0), Diff: 0.42857142857142855\n",
      "With Models: Modified (factor=0.8) vs Modified (factor=1.1), Diff: 0.33116883116883117\n",
      "With Models: Modified (factor=0.8) vs Modified (factor=1.2), Diff: 0.2662337662337662\n",
      "With Models: Modified (factor=0.8) vs Modified (factor=1.3), Diff: 0.19480519480519481\n",
      "With Models: Modified (factor=0.8) vs Modified (factor=1.4), Diff: 0.6688311688311688\n",
      "With Models: Modified (factor=0.8) vs Modified (factor=1.5), Diff: 0.6233766233766234\n",
      "With Models: Modified (factor=0.8) vs Modified (factor=1.6), Diff: 0.5454545454545454\n",
      "With Models: Modified (factor=0.8) vs Modified (factor=1.7), Diff: 0.37012987012987014\n",
      "With Models: Modified (factor=0.9) vs Modified (factor=1.0), Diff: 0.577922077922078\n",
      "With Models: Modified (factor=0.9) vs Modified (factor=1.1), Diff: 0.2857142857142857\n",
      "With Models: Modified (factor=0.9) vs Modified (factor=1.2), Diff: 0.2597402597402597\n",
      "With Models: Modified (factor=0.9) vs Modified (factor=1.3), Diff: 0.045454545454545456\n",
      "With Models: Modified (factor=0.9) vs Modified (factor=1.4), Diff: 0.6883116883116883\n",
      "With Models: Modified (factor=0.9) vs Modified (factor=1.5), Diff: 0.551948051948052\n",
      "With Models: Modified (factor=0.9) vs Modified (factor=1.6), Diff: 0.43506493506493504\n",
      "With Models: Modified (factor=0.9) vs Modified (factor=1.7), Diff: 0.2987012987012987\n",
      "With Models: Modified (factor=1.0) vs Modified (factor=1.1), Diff: 0.6038961038961039\n",
      "With Models: Modified (factor=1.0) vs Modified (factor=1.2), Diff: 0.44805194805194803\n",
      "With Models: Modified (factor=1.0) vs Modified (factor=1.3), Diff: 0.5974025974025974\n",
      "With Models: Modified (factor=1.0) vs Modified (factor=1.4), Diff: 0.34415584415584416\n",
      "With Models: Modified (factor=1.0) vs Modified (factor=1.5), Diff: 0.4805194805194805\n",
      "With Models: Modified (factor=1.0) vs Modified (factor=1.6), Diff: 0.45454545454545453\n",
      "With Models: Modified (factor=1.0) vs Modified (factor=1.7), Diff: 0.461038961038961\n",
      "With Models: Modified (factor=1.1) vs Modified (factor=1.2), Diff: 0.5194805194805194\n",
      "With Models: Modified (factor=1.1) vs Modified (factor=1.3), Diff: 0.33116883116883117\n",
      "With Models: Modified (factor=1.1) vs Modified (factor=1.4), Diff: 0.8181818181818182\n",
      "With Models: Modified (factor=1.1) vs Modified (factor=1.5), Diff: 0.3961038961038961\n",
      "With Models: Modified (factor=1.1) vs Modified (factor=1.6), Diff: 0.7077922077922078\n",
      "With Models: Modified (factor=1.1) vs Modified (factor=1.7), Diff: 0.3246753246753247\n",
      "With Models: Modified (factor=1.2) vs Modified (factor=1.3), Diff: 0.21428571428571427\n",
      "With Models: Modified (factor=1.2) vs Modified (factor=1.4), Diff: 0.4935064935064935\n",
      "With Models: Modified (factor=1.2) vs Modified (factor=1.5), Diff: 0.7207792207792207\n",
      "With Models: Modified (factor=1.2) vs Modified (factor=1.6), Diff: 0.38311688311688313\n",
      "With Models: Modified (factor=1.2) vs Modified (factor=1.7), Diff: 0.44155844155844154\n",
      "With Models: Modified (factor=1.3) vs Modified (factor=1.4), Diff: 0.6948051948051948\n",
      "With Models: Modified (factor=1.3) vs Modified (factor=1.5), Diff: 0.5974025974025974\n",
      "With Models: Modified (factor=1.3) vs Modified (factor=1.6), Diff: 0.42857142857142855\n",
      "With Models: Modified (factor=1.3) vs Modified (factor=1.7), Diff: 0.2792207792207792\n",
      "With Models: Modified (factor=1.4) vs Modified (factor=1.5), Diff: 0.551948051948052\n",
      "With Models: Modified (factor=1.4) vs Modified (factor=1.6), Diff: 0.2662337662337662\n",
      "With Models: Modified (factor=1.4) vs Modified (factor=1.7), Diff: 0.6493506493506493\n",
      "With Models: Modified (factor=1.5) vs Modified (factor=1.6), Diff: 0.5324675324675324\n",
      "With Models: Modified (factor=1.5) vs Modified (factor=1.7), Diff: 0.33116883116883117\n",
      "With Models: Modified (factor=1.6) vs Modified (factor=1.7), Diff: 0.512987012987013\n"
     ]
    }
   ],
   "source": [
    "# Comparing variations with each other\n",
    "for i in range(len(variations)):\n",
    "    for j in range(i + 1, len(variations)):\n",
    "        name1, model1 = variations[i]\n",
    "        name2, model2 = variations[j]\n",
    "        pred1 = model1.predict(X_test_scaled_df)\n",
    "        pred2 = model2.predict(X_test_scaled_df)\n",
    "        diff = compute_difference(pred1, pred2)\n",
    "        print(f\"With Models: {name1} vs {name2}, Diff: {diff}\")\n",
    "        if diff > best_diff and (diff >= 0.20 and diff <= 0.24):\n",
    "            print(f\"Best Model Pair till now is {name1} vs {name2}\")\n",
    "            best_diff = diff\n",
    "            best_pair = ((name1, model1), (name2, model2))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "666bc111-27bc-42a4-a4de-ee2504fb8e4e",
   "metadata": {},
   "outputs": [],
   "source": [
    "(model1_name, model1), (model2_name, model2) = best_pair"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "378e0cc3-ddf1-477a-8854-3239c10f51a8",
   "metadata": {},
   "outputs": [],
   "source": [
    "(model2_name, model2), (model1_name, model1) = best_pair"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "36a64e0c-4794-4fcf-8fae-ac3637815aae",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "edf89eda-b43a-4b78-9512-024bf9631d3b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "beea7442-3c60-49c1-a0a5-916121125835",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "id": "9ea03138-8060-44ec-80ba-72d49272ec80",
   "metadata": {},
   "source": [
    "**Evaluate Both Models**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "6e595955-68c6-41b3-8b0e-051de7cf86ba",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model 1: Modified (factor=0.1)\n",
      "Model 1 accuracy: 0.7857142857142857\n",
      "\n",
      "Model 2: Modified (factor=1.7)\n",
      "Model 2 accuracy: 0.7337662337662337\n",
      "\n",
      "Accuracy difference: 0.051948051948051965\n",
      "\n",
      "Percentage of different outputs: 23.38%\n",
      "\n",
      "\n",
      "\n",
      "[[ 0.00247033  0.01180872 -0.00232341  0.00033576 -0.00115916  0.0082093\n",
      "   0.00196231  0.0019061 ]]\n",
      "[[ 0.01355544  0.00475416  0.00010056  0.00079135 -0.00140176  0.00318262\n",
      "   0.00942204  0.00153502]]\n"
     ]
    }
   ],
   "source": [
    "# Evaluate both models\n",
    "y_pred_1 = model1.predict(X_test_scaled_df)\n",
    "y_pred_2 = model2.predict(X_test_scaled_df)\n",
    "\n",
    "accuracy1 = accuracy_score(y_test, y_pred_1)\n",
    "accuracy2 = accuracy_score(y_test, y_pred_2)\n",
    "\n",
    "# Print results\n",
    "print(f\"Model 1: {model1_name}\")\n",
    "print(\"Model 1 accuracy:\", accuracy1)\n",
    "print(f\"\\nModel 2: {model2_name}\")\n",
    "print(\"Model 2 accuracy:\", accuracy2)\n",
    "print(\"\\nAccuracy difference:\", abs(accuracy1 - accuracy2))\n",
    "print(f\"\\nPercentage of different outputs: {best_diff:.2%}\")\n",
    "\n",
    "print(\"\\n\\n\")\n",
    "print(model1.coef_)\n",
    "print(model2.coef_)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "cd8a30d3-da04-4c7f-953f-a6eec2515698",
   "metadata": {},
   "source": [
    "#### Compare Model Boundaries"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "15fea562-bb74-41a7-a270-87fc65b1fa25",
   "metadata": {},
   "source": [
    "**Plot Model Decision Boundaries**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "80b922f5-4307-452f-90d2-397fc5e969ad",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Function to plot decision boundary\n",
    "def plot_decision_boundary(X_test, y_pred, feature_1, feature_2):\n",
    "    # Create a scatter plot of the predictions\n",
    "    plt.figure(figsize=(8, 6))\n",
    "    plt.scatter(X_test[feature_1], X_test[feature_2], c=y_pred, cmap='rainbow', edgecolor='black', s=20, vmin=0, vmax=1)\n",
    "    \n",
    "    # Add labels and title\n",
    "    plt.xlabel(feature_1)\n",
    "    plt.ylabel(feature_2)\n",
    "    plt.title('Logistic Regression Decision Boundary')\n",
    "    \n",
    "    # Add a colorbar to indicate the predicted classes\n",
    "    cbar = plt.colorbar()\n",
    "    cbar.set_ticks([0, 1])\n",
    "    cbar.set_ticklabels([\"No\", \"Yes\"])\n",
    "\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "6d4d70a4-794b-4bc0-8659-d244baa22e7c",
   "metadata": {},
   "source": [
    "**Model 1 Decision Boundary**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "de4db779-ea88-4543-944d-46c15b3e31de",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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rJmMG/cxp0+fpkCBAgQHB3s6LBEREXECJZ3yyMmaNStZs2b1dBgiIiJOZdbk8CIiIiLiaibrzc2pvOXeOhq9LiIiIiJuoEqniIiIiBtY0vntdVU6RURERMTlVOkUERERcQNXTZnkLVTpFBERERGXU6VTRERExA3MNhMmq57pFBERERFxGVU6RURERNzA5ILR63hRpVNJp4iIiIgbmK03N2eyaXJ4EREREZG/qdIpIiIi4gZmmwlzOr69rkqniIiIiLicKp0iIiIibuCKZzrRM50iIiIiIn9TpVNERETEDVwxZZLTp2ByIVU6RURERMTlVOkUERERcQOLC57pNHnRM51KOkVERETcwGyA2ebkTg0n9+dCur0uIiIiIi6nSqeIiIiIG5itJsxWJw/8cXZ/LqRKp4iIiIi4nCqdIiIiIm5gst3cnN2nt1ClU0RERERcTpVOERERETewuOCZTpOe6RQRERER+ZsqnSIiIiJuYHLB5PCGF00Or0qniIiIiLicKp0iIiIibmC2mTDbnPsMpuHk/lxJSaeIiIiIG5iszl8r3ZvWXtftdRERERFxOVU6RURERNzAYjNhcfYUR150e12VThERERFxOVU6RURERNzArCmTRERERERcy2uSzmbNmpE/f34CAgLIlSsXHTt25MyZMw777N69m1q1ahEQEEC+fPkYM2bMbf0sWLCAEiVKEBAQQNmyZVm+fLm7TkFERETSMbPNNZu38Jqks06dOsyfP59Dhw6xcOFCjh07RsuWLe3vx8fH07BhQwoUKMD27dsZO3Ysb731Fl988YV9n82bN9OuXTu6devGjh07aNGiBS1atGDv3r2eOCURERGRdMNkGIbh6SBSY8mSJbRo0YLExER8fX2ZNGkSr732GrGxsfj5+QEwbNgwFi9ezMGDBwFo06YN165dY+nSpfZ+qlevToUKFZg8efJ9fW58fDwhISHExcURHBzs/BMTERERp/Pk3+9bn12u/3ks/s79bGtiPLvH5/CKvMRrKp3/dPHiRb766itq1KiBr68vAFFRUdSuXduecAJERERw6NAhLl26ZN+nfv36Dn1FREQQFRV1189KTEwkPj7eYRMRERF5UBarazZv4VVJ59ChQ8mYMSPZsmXj1KlTfP/99/b3YmNjyZkzp8P+t17Hxsbec59b79/JqFGjCAkJsW/58uVz1umIiIiIpBseTTqHDRuGyWS653br1jjA4MGD2bFjB6tXr8ZisdCpUydc/XTA8OHDiYuLs28xMTEu/TwRERFJm25NmeTszVt4dJ7OQYMG0aVLl3vuU7hwYfv/z549O9mzZ6dYsWKULFmSfPnysWXLFsLDwwkLC+PcuXMOx956HRYWZv/fO+1z6/078ff3x9/f/0FOS0RERET+h0eTztDQUEJDQ1N1rM12c46AxMREAMLDw3nttddITk62P+cZGRlJ8eLFyZIli32fNWvWMGDAAHs/kZGRhIeHP8RZiIiIiPw7k82E2cnLYNq0DKZzRUdHM2HCBHbu3MnJkydZu3Yt7dq1o0iRIvaEsX379vj5+dGtWzf27dvHvHnzGD9+PAMHDrT3079/f1auXMlHH33EwYMHeeutt9i2bRv9+vXz1KmJiIiIpAtekXQGBgby3XffUa9ePYoXL063bt0oV64cGzZssN/6DgkJYfXq1Rw/fpzKlSszaNAg3nzzTXr27Gnvp0aNGnz99dd88cUXlC9fnm+//ZbFixdTpkwZT52aiIiIpBMmm2s2b+G183R6iubpFBER8T6PwjydVXpcwMfPuZ+dkhTP1imhXpGXePSZThEREZH0whXzahoavS4iIiIi/2S2On8gkbP7cyWveKZTRERERLybKp0iIiIibuCKydy9aXJ4VTpFRERExOVU6RQRERFxA1U6RURERERcTJVOERERETfQ6HURERERERdTpVNERETEDcw2FzzT6UXLYCrpFBEREXEDsxXMTr7HrIFEIiIiIiL/oEqniIiIiBuYXFDpNKnSKSIiIiLyN1U6RURERNzAbDVhNmvKJBERERERl1GlU0RERMQNNHpdRERERMTFVOkUERERcYP0XulU0ikiIiLiBul9RSLdXhcRERERl1OlU0RERMQNzFYTZpOmTBIRERERcRlVOkVERETcwGwFJ88N71UDiVTpFBERERGXU6VTRERExA1U6RQRERERcTFVOkVERETcIL1XOpV0ioiIiLiByQVJp8mLkk7dXhcRERERl1OlU0RERMQNzDaT0ydzN9s0ObyIiIiIiJ0qnSIiIiJuYLY6v9rnTQOJVOkUEREREZdTpVNERETEDVTpFBERERFxMVU6RURERNwgvVc6lXSK/A+bzUZcXByZMmXCx0f/iYiIiHOk96RTt9dF/mIYBuPGjSNv7vxk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",
      "text/plain": [
       "<Figure size 800x600 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_decision_boundary(X_test_scaled_df, y_pred_1, \"BMI\", \"Glucose\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "599fcca1-20b3-4b16-89c4-4fba23c314ce",
   "metadata": {},
   "source": [
    "**Model 2 Decision Boundary**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "bff87fe6-d656-416c-88a7-47fd6d503a63",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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PK/q/v333+OVT5gw4a19NRrNWz+PP/744z97Wt/F09OT6tWrs3DhQhYtWkS1atU+euYKIayR9HSKJG327Nls2bLlrfJevXoxcuRItm3bRunSpenatStarZZp06YRExPDmDFjjPv279+fhQsXUqVKFXr06GGcMilDhgw8ffr0P3sqq1atire3N6VKlSJ16tT8888//Pnnn9SoUcPYI1OoUCEABg8eTOPGjbGxsaFWrVrvnAi6X79+rFy5koYNG9K2bVsKFSrE06dPWbduHVOnTqVAgQIffY2qV69O3rx5+fXXX+nWrRvlypWjU6dOjBo1ilOnTlG1alVsbGy4cuUKK1asYOLEiQQGBpI6dWp69erF+PHjqV27NtWqVeP06dNs3rwZT0/PBPXgurq6MmXKFFq0aEHBggVp3LgxXl5e3L59m40bN1KqVCn+/PNPLl++TKVKlfj666/JnTs3Wq2W1atX8+jRIxo3bgzAvHnzmDx5MvXq1SNLliw8f/6cGTNm4OrqSkBAwHtjSOjnwFRWrlyJs7MzsbGxxhWJDhw4QIECBVixYoVxP7VazcyZM6levTp58uShTZs2pE2blnv37rFr1y5cXV1Zv349AD///DNBQUGUK1eOjh07kitXLh48eMCKFSvYv3//WytdwcvpmLp3707Dhg3Jnj07Op2OBQsWoNFoaNCgwXvjHzhwIEuWLKF69er07NkTDw8P5s2bx40bN/jrr79MvnrR5s2bjT2Wjx8/ZvHixVy5coWBAwcavxDUqlWLChUqMHjwYG7evEmBAgUICgpi7dq19O7dO954y/bt2/PLL7/Qvn17ChcuzN69e7l8+fInx+fn50eTJk2YPHkyYWFhlCxZkh07drzzTkjNmjVZsGABbm5u5M6dm0OHDrF9+3ZSpkz50e22bNmSwMBAgHd+QRTii2Sx5+aF+A/vm27l1Xbnzh1FURTlxIkTir+/v+Ls7Kw4OjoqFSpUUA4ePPhWfSdPnlTKlCmj2NnZKenSpVNGjRql/P777wqgPHz40Ljfm1MmTZs2TSlbtqySMmVKxc7OTsmSJYvSr18/JSwsLF79I0aMUNKmTauo1ep40ye9OV2Norycrql79+5K2rRpFVtbWyVdunRKq1atlCdPnvznNcmYMaNSo0aNd743d+7ct6aSmT59ulKoUCHFwcFBcXFxUfLly6f0799fuX//vnEfnU6n/PDDD4q3t7fi4OCgVKxYUfnnn3+UlClTKp07d37r5/G+6Yx27dql+Pv7K25uboq9vb2SJUsWpXXr1srx48cVRVGUJ0+eKN26dVNy5sypODk5KW5ubkqxYsWU5cuXG+s4ceKE0qRJEyVDhgyKnZ2dkipVKqVmzZrGOl7hjWlsXh37oc/B+87hzamI3ufVFDyvNnt7eyVdunRKzZo1ldmzZyvR0dHvPO7kyZNK/fr1jZ+hjBkzKl9//bWyY8eOePvdunVLadmypeLl5aXY2dkpmTNnVrp162acrujNOK9fv660bdtWyZIli2Jvb694eHgoFSpUULZv3x6v3nd9Bq9du6YEBgYq7u7uir29vVK0aFFlw4YN77wub07J9F/TFr3uXb/D9vb2ip+fnzJlypS3pgh7/vy58s033yg+Pj6KjY2Nki1bNmXs2LFv7RcZGam0a9dOcXNzU1xcXJSvv/5aefz48XunTHpziqtXcb0+xVlUVJTSs2dPJWXKlIqTk5NSq1Yt5c6dO2/V+ezZM6VNmzaKp6en4uzsrPj7+ysXL1586xonZMq3mJgYJUWKFIqbm5sSFRX1n9dSiC+FSlE+c/S8EFaqd+/eTJs2jRcvXrz3YYPkKDQ0lBQpUjBy5EgGDx5s6XCE+CLpdDp8fHyoVasWs2bNsnQ4QiQKGdMpkoWoqKh4r0NCQliwYAGlS5dO1gnnm9cF/j+W7c3lQIUQprNmzRqCg4Np2bKlpUMRItFIT6dIFvz8/Chfvjy5cuXi0aNHzJo1i/v377Njxw7Kli1r6fAsZu7cucydO5eAgACcnZ3Zv38/S5YsoWrVqmzdutXS4QnxxTly5AhnzpxhxIgReHp6vnNSeSG+VPIgkUgWAgICWLlyJdOnT0elUlGwYEFmzZqVrBNOgPz586PVahkzZgzh4eHGh4veN92OEOLzTJkyhYULF+Ln58fcuXMtHY4QiUp6OoUQQgghkgFFUahSpQoajeatu1mTJ0/mu+++49y5cyZbXOJNMqZTCCGEECIZUKlUzJkzhyNHjjBt2jRj+Y0bN+jfvz9//PGH2RJOkKRTCCGEECLZSJ8+PRMnTuTbb7/lxo0bKIpCu3btqFq1Kl999RXVq1fH2dmZ1KlT06JFC548eWI8duXKleTLlw8HBwdSpkxJ5cqViYiISHDbcnv9IxkMBu7fv4+Li8tHLX8ohBBCCMtRFIXnz5/j4+Nj8kUQEiI6OprY2Fiz1K0oyls5iZ2dHXZ2du89pm7duoSFhVG/fn1GjBjB+fPnyZMnD+3bt6dly5ZERUUxYMAAdDodO3fu5MGDB2TIkIExY8ZQr149nj9/zr59+2jZsiXOzs4JilOSzo909+7dRFvLWQghhBCmdefOHbPeQn6X6OhofB0ceGim+p2dnd9abnfo0KEMGzbsvcc8fvyYPHny8PTpU/766y/OnTvHvn374o31fJXzXLp0iRcvXlCoUCFu3rxJxowZPylOeXr9I71a+vDOnTuJsqazEEIIIT5feHg46dOnN/4dT0yxsbE8BO4Aps4cwoH0L168lZf8Vy8nQKpUqejUqRNr1qyhbt26LFq0iF27dr2z1/LatWtUrVqVSpUqkS9fPvz9/alatSqBgYGkSJEiwbFK0vmRXnVfu7q6StIphBBCWBlLDo1zVatwNXX7igIG5ZPyEq1Wi1b7MhV88eIFtWrVYvTo0W/tlyZNGjQaDdu2bePgwYMEBQXxxx9/MHjwYI4cOYKvr2+C2pMHiYQQQgghEoNGZZ7NBAoWLMj58+fJlCkTWbNmjbc5OTkBLxP2UqVKMXz4cE6ePImtrS2rV69OcBuSdAohhBBCJHPdunXj6dOnNGnShGPHjnHt2jW2bt1KmzZt0Ov1HDlyhJ9//pnjx49z+/ZtVq1aRXBwMLly5UpwG3J7XQghhBAiMWjUYI7b63GGz67Gx8eHAwcOMGDAAKpWrUpMTAwZM2akWrVqqNVqXF1d2bt3LxMmTCA8PJyMGTMyfvx4qlevnuA25On1jxQeHo6bmxthYWEyplMIIYSwEpb8+21s215r8jGd4YqCW7TOKvIS6ekUQgghhEgMWpUZejpNW505yZhOIYQQQghhdtLTKYQQQgiRGMw1ptNKSE+nEEIIIYQwO+npFEIIIYRIDGrVy82UPv/B9UQjSacQQgghRGLQqE2fdKrk9roQQgghhBBG0tMphBBCCJEYpKdTCCGEEEII85KeTiGESILi4uJ48eIFbm5uqNXSPyDEF0FjhgeJTFydOcm/ZEIIkYRERUXRp08fUqbwxMPDg0wZMjN16lRkxWIhhLWTnk4hhEhCGn/dhC2bgihq6I03Bbh0bz1dunQhOjqa3r17Wzo8IcTnkDGdQlifsLAw+vXrRzpvb1K4uhJYvz5nzpyxdFhCfJaTJ0+ybsNaahlmUZmfyUsjGrCQQnRk5I8/ExMTY+kQhRDik0nSKaxOTEwMVSpWZNpvv9Hg0SP6PH/OmXXrKFW8uCSewqodOXIEFWpy0zBeeV4aE/IsmBs3blgoMiGESWhU5tmshCSdwuqsWLGCYydOsF2vZyLwA3BSrydNbCw/Dh9u6fCEGRkMBubPn0/5chXJm7sAnTp14vLly+/dPy4ujkmTJlG6eHH88uShT58+3L17NxEj/jgpU6ZEwUAYt+KVP+UaKpWKFClSWCgyIYRJaFSgVZt2k6RTCPPZsWMHBbVair5W5gS00OvZuW2bpcISiaBTp860atWKe/ttsP+nBMtmb6DQV4U5ceLEW/vq9Xoa1KtHzx49SHn0KIUvXGDe779T2M8vyfYY1qxZE48UnmxQdySc+wDc52/2aoZRvVoAqVOntnCEQgjx6STpFFbHycmJEN5ebjb43/fEl+nvv/9m5swZ1GQqzQ1bqcVUuuou4hyTif7fDnhr/02bNrF+40bWKAprFYWZwD96PTZhYQwfNizR408IBwcHVq1eSbDDcSaoMvCbTVqmU5g0WdyYMXO6pcMTQnwuub0uhHVp0qQJt3Q6xvL/xPMoMEejoUmLFhaMTJjThg0bcNJ4UJD2xjI7XCis78aOXduJiop6a/9cWi21XitLBbTR6Vi3Zk2ixPwpypUrx+27t5g8ZRI9B7Zj5cqVnDl3Ch8fH0uHJoQQn0WmTBJWp1SpUgwYMICBo0czRaslJXBCp8M7RQpcXV0JDg7Gy8vL0mEKE9NoNBjQo2AANMZyPXGoVCpUqvjf9tVqNTpAIf7cyTpAk8QnW3d3d6dTp06WDkMIYWoa9cstmUq+Zy6s2i+//MKBAwco3qAB59VqNEDK0FBGDh1KVl9fDhw4YOkQhYnVrVuXKH0Yh/jNWBbBE45pfqd6tQDs7e3j7V+vXj2u6HQseq3sFjBLq6Vew/hPhwshhDA/STqF1SpRogTnT58mt17PbeCcTsddg4ECUVE0adgQnU5n6RCFCeXNm5d+/fqxnQHM0BRmOV/zpyYLBtdnjP913Fv7V6lSheZNm9ICKKNWUx/IpVbj6O3NsCQ6plMI8YV71dNp6s1KWE+kQrzh9OnTnLt4kV/0el6NdvMExhsM3HnwgL1791oyPGEGo0ePZv369RSrkwmvMsH07t+NM2dPkTNnzrf2ValUzFuwgCVLlpCienVCy5blu+HDOX5KxkcKIYQlyJhOYbXCw8MBeDN9SPvG++LLoVKpqFmzJjVr1kzQ/mq1msaNG9O4cWMzRyaEEAlglqfN5el1IczOz88PZwcH5rxRPgew0WopXry4JcISQggh3k1urwthnVxdXRn0/ff8CjQEpgItge+Bnr164e3tbdH4hBBCCPF/cntdWLVBgwaRKlUqxo8ezV/XrpE5QwYmfPMNPXr0sHRoQgghRHxqM9xeV6zn9rokncKqqVQq2rdvT/v27VEU5a25GoUQQgiRNEjSKb4YknAKIYRI0swxBlMxbXXmZDVjOkeNGkWRIkVwcXEhVapU1K1bl0uXLsXbJzo6mm7dupEyZUqcnZ1p0KABjx49irfP7du3qVGjBo6OjqRKlYp+/frJfI5CCCGEEGZmNUnnnj176NatG4cPH2bbtm3ExcVRtWpVIiIijPt88803rF+/nhUrVrBnzx7u379P/fr1je/r9Xpq1KhBbGwsBw8eZN68ecydO5chQ4ZY4pSEEEIIkZy8mjLJ1JuVUCmKYkUds/8XHBxMqlSp2LNnD2XLliUsLAwvLy8WL15MYGAgABcvXiRXrlwcOnSI4sWLs3nzZmrWrMn9+/dJnTo1AFOnTmXAgAEEBwdja2v7wXbDw8Nxc3MjLCwMV1dXs56jEEIIIUzDkn+/jW2XTI+r1rT9feE6A24H71hFXmI1PZ1vCgsLA8DDwwOAv//+m7i4OCpXrmzcJ2fOnGTIkIFDhw4BcOjQIfLly2dMOAH8/f0JDw/n/Pnz72wnJiaG8PDweJsQQgghxEeTeTqtj8FgoHfv3pQqVYq8efMC8PDhQ2xtbXF3d4+3b+rUqXn48KFxn9cTzlfvv3rvXUaNGoWbm5txS58+vYnPRgghhBDJQjK/vW6VSWe3bt04d+4cS5cuNXtbgwYNIiwszLjduXPH7G0KkdTt2bOHFi1aUKVSJQYOHCi/F0IIIT7I6pLO7t27s2HDBnbt2kW6dOmM5d7e3sTGxhIaGhpv/0ePHhlXpvH29n7rafZXr9+3eo2dnR2urq7xNiGSs3HjxlG+fHmOL12K686dTBs3jvx58nDy5ElLhyaEEEmb3F63Doqi0L17d1avXs3OnTvx9fWN936hQoWwsbFhx44dxrJLly5x+/ZtSpQoAUCJEiU4e/Ysjx8/Nu6zbds2XF1dyZ07d+KciBBW7O7duwwcMIBvgQs6HX8BN/R6MkRG0rNbNwAePHjAzz//TLt27RgzZgzBwcEWjVkIIUTSYDWTw3fr1o3Fixezdu1aXFxcjGMw3dzccHBwwM3NjXbt2tGnTx88PDxwdXWlR48elChRguLFiwNQtWpVcufOTYsWLRgzZgwPHz7k+++/p1u3btjZ2Vny9ISwCmvXrkWtKAwBXo0icgf66fW0OHSINWvW0KJpUwwxMeRRq1lkMDBq5Ei2bt9O0aJFLRe4EEIkBWqV6XsmDdYzCZHV9HROmTKFsLAwypcvT5o0aYzbsmXLjPv89ttv1KxZkwYNGlC2bFm8vb1ZtWqV8X2NRsOGDRvQaDSUKFGC5s2b07JlS3788UdLnJIQVkev16NWqbB5o/zVV7auHTtSOCaGuwYDR3U67hgMZI+IoGXTpljp7GxCCCFMxGrn6bQUmadTJGdXrlwhe/bsjAH6/VsWA1RWq3mUMSNXbtzgGFD4tWN2ApWA48ePU6hQoUSOWAghXkoS83RWy4qrjca0dcfpcdty1SryEqvp6RRCWF62bNno06cP/YEqajW9gDxaLcc0Glq2bQtA6jeOSfXvf58/f56IkQohhEhqJOkUQnyUcePGsWjRInSlShGUOTPFv/6aw0eP0qlTJ2y1Wma8sf8MwMXRUXo5hRAimT+9bjUPEgkhkgaVSkXTpk1p2rTpW+/1GzCAET/9xD8qFaUUhV0qFesUhdFDh+Li4mKBaJO+GzducPv2bXLkyPHeqduEEF8Ic0zmbpDJ4YUQydCIESOYNm0a/2TPziBbW27nycP8+fPp37+/pUNLcoKDgwnw9ydz5syUL1+edGnT0qZVK6KioiwdmhBCmIX0dAohTEalUtGxY0c6duxo6VCSNEVRaFCnDpeOHWM+UBTYYjAwaOFCtDY2zJg509IhCiHMwRy3w2XKJCGEEO9z/Phx9h06xEydjhZADqAXMMJgYN68eTKhvhDiiyQ9nUIkAYqioCgKarV8D0wOLl26BLycSup1lYA4nY7r16/j5eWV6HEJIcxMxnQKISzl4cOHtG3TBmdHR2xsbPCvUoVjx45ZOixhZq+W8T34RvlBQK1SkTFjxkSPSQghzE16OoWwkBcvXlCuVClCb9+mv06HOzBr1y7KlSnDoSNHKFCggKVDFGZSsmRJvsqXj/b//MMUnY6iwFbgO42GhvXry1PsQnyp1GYY06mXMZ1CiA+YP38+127cYK9Ox1Bejuk7oteTTqfjp5EjLR2eMCOVSsXajRtJlS8fAYAn0AwoU7Uq0+UhIiHEF0p6OoWwkL1791JSpSLHayvROgCN9Hpm7tplucBEokifPj1H/v6bv//+m5s3b5InTx5y5cpl6bCEEOZkjjGdpq7PjCTpFMJC3N3dOaZWYzAY4t1yuAu4ublZKiyRiFQqFYULF6Zw4cIf3lkIYf3MMWWSRm6vCyE+oEWLFlzX6RgJxAEKsAlYrFbT4t91zIUQQogvhSSdQlhIqVKlGDJkCEOBtFotWWxsqAFUqFiRvn37Wjo8IYQQpvbq9rqpNysht9eFsKDhw4fToEEDli1bRlRUFFWqVMHf31/m6xRCCPHFkaRTCAvLnz8/+fPnt3QYQgghzE3GdAohhBBCCGFe0tMphEiw+/fvExQUhEajoXr16nh6elo6JCGEsB4alRl6Og2mrc+MpKdTCJEgI0aMIEP69LRp04aWLVuSzseHKVOmWDosIYQQVkKSTiHEB61evZohQ4Yw0GAgFHgMtI2Lo2vXrhw4cMDC0QkhhJVQq8yzWQlJOoUQHzR10iRKazSMBNwAL+BPILtWy/Tp0y0bnBBCWItXa6+bcrOi2U6sJ1IhhMXcvX2br/T6eGVqoIBOx91btywTlBBCCKsiSacQ4oMKFCrEVq2WuNfKIoDdWi35v/rKUmEJIYR1SeaTw0vSKYT4oD59+3JdUaipUrEFWAdUUauJtLGhW7duJm0rOjoa/Ru9qokpJiYGnU5nsfaFEOJLJUmnEOKDChcuzNp167ieMSPVgTrAixw52LptG1mzZjVJGxs2bOCrAoVwcHDA1cWNrl27EhYWZpK6E+LgwYOUL1MGe3t7nBwdada0Kffu3Uu09oUQyYCpx3OaY7J5M5J5OoUQCRIQEEC1a9e4fPkyWq2WLFmyoFKZ5rbO+vXrqVOnDr5UpDazCIu6xdzpEzl+7ASHDh9Ao9GYpJ33OX78OBXLlyefXs9UIDQujonLl1Pu4EFOnDmDq6urWdsXQojkQJJOIUSCqdVqcubMafJ6fxg8FF8q0lwJQv3vDRhffSXmHi/Hpk2bqFWrlsnbfN3PI0eS2WBgv8GA3b9lgXo9OW7fZv78+XTv3t2s7QshkglzjMGUMZ1CCJEw0dHRnD57knxKM2PCCZCJsqSwSZ8o84Ae2LePhnq9MeEEyAKUVKlkHlIhhDAR6ekUQliUjY0Njg5OhEbdjFcew3Mi9CF4eHiYPQaPFCm49fRpvDIDcFutJl8itC+ESCbUZphXU+bpFEKIhNFoNLRs1YKjmoncYh/wMuHcRA8MqliaNGli9hhatW/PYrWa1YACRAPfA7d0Olq2bGn29oUQIjmQnk4hhMWNGjWKv4+fZM7xsqSwyUCE/gkGVSyz58wmffr0Zm+/T58+HNy/n/obN+Kj1RKhKITp9YwaNYpixYqZvX0hRDKRzMd0StIphLA4d3d3Dh7az6ZNmzhw4AAeHh40bdo0URJOAFtbW9auX8/u3bsJCgrC0dGRr7/+mhw5ciRK+0KIZEJthimOrOj2uiSdQogkQavVUrt2bWrXrm2R9lUqFRUqVKBChQoWaV8IIb50knQKIYQQQiQGub0uhBDmFxcXx6ZNm7h16xZ58+alfPnyqJPAbSG9Xs/WrVu5evUq2bNnp0qVKmafjF4IIZIjSTqFEGZ3/vx5qvvX4M69W2hVtuiUWL4qUIjNWzeSOnVqi8V148YNAqpW5eLVq9ip1cQYDOTKlo1NQUFkypTJYnEJIb5QMmWSEEKYj16vp3bNusQ9dKUzpxmsRNOKXVw7d482rdpaLC5FUfi6fn3ibt7kCBBtMHAYiL5xgyYNG1osLiGE+FJJ0imEMKvdu3dz/eZVaupn4E1+VKjwpTwV9KPYvHUTd+7csUhcp06d4vipU/yu01H037JiwASdjsPHj3P27FmLxCWE+IK9GtNp6s1KSNIphDCr+/fvA5CKfPHKU5MfgIcPHyZ6TPD/uPK/UZ7/jfeFaURFRXH69Gnu3r1r6VCEEBYiSacQwqz8/PwAuMTaeOUXWYO9nQPZs2e3QFSQL18+VCoVa94oXwNo1Gry5cv39kHioymKwpgxY0jjnRY/Pz/Sp09P5UpVLdbDLYRFaVQv5+k06WY9PZ3yIJEQSYyiKISFheHo6Iitra2lw/ls+fLlo0ZALTZu7UiY/jY+FOEqWzis+pU+Pfrg5uZmkbgyZMhAy+bN+XbRIkIMBsoCe4BRajWtW7fGx8fHInF9aSZNmsSAAQMoSnfy0oRnXGP3nu+pVKEK5y6c+SI+4+YWExNDVFQUbm5uqFTWk2CId1CrXm6mrtNKSE+nEEnIwoULyZElCylSpCCFmxtdunQhPDzc0mF9tqXLFtO0VSP2aIcwn0qcdZrGoO8G8ssvoywa17QZM+jUrRtj7O2pCIy1t6drz55MmjzZonF9KQwGA7/8PIYCtCSAP8hASQrQgq/1a7ly7RJr1679cCXJWEhICG1at8HVxY0UKVKQO2deVq1aZemwhPhkKkVRFEsHYU3Cw8Nxc3MjLCwMV1dXS4cjviDz58+nVatW1AcCgcvArxoNfsWLs3vfvi+ihyMsLIzHjx+TNm1aHB0dLR2O0YsXL3jw4AFp0qTB2dnZ0uF8MUJDQ0mRIgWBLCUvjeK995tNWnoObMePP/5ooeiSNp1OR5FCxbhy/hbF9H1wJxNnVQu5omxm9erV1K1b19IhWh1L/v02tj3aH1d7G9PWHR2H24CtVpGXyO11IZIAg8HAsO+/pyGwDHiVXhbT66l+4AC7du2iYsWKFozQNNzc3Cx2O/2/ODs7ky1bNkuH8cVxdnbG1dmNBy9OxEs6w7lHuO4h6dOnt2B0Sdu6des4deYE7ThEeooDkE9pwkKVP0N/GC5Jp7BKcntdiCQgODiYG3fu0Jj/J5wA/kAKjYbDhw9bKDIhPp1Wq6Vj5w4cVU/kJHPREcNjLrBK3QRXZ1caNWr04UqSqcOHD5PSJpMx4QRQoSKP0pgz504RExNjwejEJ1Op/j+u01SbFd0Fk55OIZIAFxcXbLVarul08cofA+EGA56enpYJTAAvb4398ccfrFm5EkVRqF2/Pj179sTd3d3SoSV5I0eO5NbN26xY2Ya1tAEglYc3G9dsSPK3Ai3J09OT5/rHxPAcO1yM5c+4hrOjCzY2pr1FK0RikJ5OIZIAR0dHGjVuzGiNhv3/lgUDHVUq7O3tCQwMtGR4ydrz588pV6oUI4cMIfupU+Q8fZpfhg+nTIkShIWFWTq8JM/Ozo7lK5Zx7tw5Zs2axdq1a7l99yalSpWydGhJWtOmTVHUcWygM1E8Q0HhKkEc0/xB67atUFvR0ofiNSafLunfzUpIT6cQr7lx4wZTp07lwoULZMyYkY4dO5I//5vTh5vHbxMm8M+5c5Q5dQpvrZYQvR4bOzuWLV+Oh4dHosQg3jZt2jQuXLjAcYPBOL39PwYDBS9fZvLkyQwaNMii8VmLPHnykCdPHkuHYTXSpUvH/AXzadWyFRf1f2GvduO57jGlipXh559/tnR4QnwSeXr9I8nT61+u/fv3U61qVWxjYyml13NSq+WhwcDCRYto3LhxosSg1+vZvHkzx44dw8vLi8aNG8utdQsrV7o0KQ8c4M2JahoBd4oU4eDRo5YISyQTDx8+ZNmyZTx9+pRSpUpRuXJl6eX8REni6fXfauDqYOKn16PicPtmo1XkJdLTKazCgwcPmDdvHnfv3iVfvnw0bdoUFxeXDx+YQIqi0L51a/xiYthiMOAMxOl0tAQ6tW9PzZo1E2UqHY1GQ82aNalZs6bZ2xIJo9Fo0KlU8Mb38zhArdFYJiiRbHh7e9OrVy9LhyFMxRy3w63o9rr1RCqSrS1btpDF15cRgwezd/p0unbpQu7s2bl8+bLJ2jh37hyXrl1jyL8JJ4AN8BMQHhHBtm3bTNaWsC71AgPZDBx6rewosEGlop6MtRVCiASTpFMkaZGRkTRr3JgKsbHcMxg4ExfHVUXBMTiY9m3amKyd2NhYAJzeKHd6432R/LRv357ixYtTWqWimkpFgEpFSZWKQoUL06VLF0uHJ4SwJqaeLskcy2qakSSdIknbvHkzT8PC+F1RcP+3zBcYrtez7+BBbt26ZZJ28ufPj7enJxMBw2vlEwBbrZYKFSqYpB1hfRwcHNi2cyd/TpqEUqkSuooVmfjHH+zYvTtJraokhBBJnYzpFEnaqylpfN4oT/vvf021LrmNjQ3jJ06kefPmFFGrqarXc1StZqfBwIihQ0mVKpVJ2kmI69evc/z4cVKlSkWZMmXQyLhBi7O3t6dLly7SsymE+DwyplOIpKtMmTIAzHmtTAFmA6k8PMiRI4fJ2mratCnbt2/Hu0oVlqZNi75kSZYvX873339vsjb+S2xsLC2bNydLliw0atSIChUqkDNrVk6fPp0o7QshhBDmJD2dIknLli0bbdu0oefcuZxUFAoCm1QqNigKU376CVtbW5O2V7FiRYutcT548GCWL1nCFKAhcBnoducO1atU4dqtWzg4OFgkLiGEECZijjGYMqZTCNOZNn06I376iSAfH7qpVNzOlYvFixfTuXNnS4dmMrGxsUyfMoU+BgOdgZRACWCZXs+D4GBWr15t4QiFEEKIzyM9nSLJ02q1DBo0iEGDBhEXF0dISMgXt+b106dPCY+IoPgb5dkAT62WGzduWCIsIYQQpqQ2w5hOK1oswHoiFcmawWBgzJgx+HinI02aNHh6eNGrVy+ioqIsHZpJeHp64unuzpuzgZ4Cnuh05MqVywJRCSGEMCmZMkmIpG/EiBEMGDCATE/r05i1FIrqzdQ/Z9CieUtLh2YSWq2W3t9+y2SViiHAWWAl0ECrJZuvL7Vq1bJwhEIIIcTnsaqkc+/evdSqVQsfHx9UKhVr1qyJ976iKAwZMoQ0adLg4OBA5cqVuXLlSrx9nj59SrNmzXB1dcXd3Z127drx4sWLRDwL8bFevHjBuDHjKcm31GQKOalNRUYQYJjCX6tWcuHCBUuHaBKDBg2iX//+jLOzIz8vHybyKVKEoJ07sbEx7Vq9pvbo0SM6duxICldXnBwcqF+3LufPn7d0WEIIkbSo1ebZrIT1RApERERQoEABJk2a9M73x4wZw++//87UqVM5cuQITk5O+Pv7Ex0dbdynWbNmnD9/nm3btrFhwwb27t1Lx44dE+sUxCe4dOkSLyKfk4ev45W/en3s2DFLhGVyarWaX375hfsPH7Jv3z4uXbrEvoMHyZQpk6VD+0/h4eGULVmS1bNn0/X5c36Ijubshg2UKl6cS5cuWTo8IYQQSYRVJZ3Vq1dn5MiR1KtX7633FEVhwoQJfP/999SpU4f8+fMzf/587t+/b+wR/eeff9iyZQszZ86kWLFilC5dmj/++IOlS5dy//79RD4bkVBeXl4APOFivPInvExoEnPi9sTg7u5O6dKlyZ49u6VDSZA5c+Zw48YNDur1/AQMBP7W63GNjuaXX36xdHifbO3atVSqWIUsmbJTu1Yd9uzZY+mQhBDWTgNoVCbeLH1SCWdVSed/uXHjBg8fPqRy5crGMjc3N4oVK8ahQ4cAOHToEO7u7hQuXNi4T+XKlVGr1Rw5cuSd9cbExBAeHh5vE4krQ4YMVKpYhV3awdzjZa/mU66zUdOJtGnSU6VKFQtHmLzt3r2bsrx80v4VV+BrnY7d2958NMo6jB07lrp163JtbzSpb9Xm+OZbVKhQgSVLllg6NCGEsFpfzJRJDx8+BCB16tTxylOnTm187+HDh2/1imm1Wjw8PIz7vGnUqFEMHz7cDBGLjzF33myqVPJnxuWiOGk9iNA9xdM9FVvWb0Kr/WI+xmZ35swZJk+ezLUrV8iWIwddu3blzp07zJ0zl6dPn1GqdEm6du36Ub3HLi4uXFGrUfR6Xn+G8iHg4upq8nMwt5CQEL4f/APF+YZq+l8BMOgNrKQRvXv2ITAwMMmPsRVCJFHmGIMpYzq/HIMGDSIsLMy43blzx9IhJUvp0qXj7PnTrF27lkHD+rBgwQJu3b5BoUKFLB2a1Vi1ahWFChZk46xZuO/cydoZM/DLn5+AgAD2r7rMnR2O/DJyHPnz+nHt2rUE19usWTPO6/X8Dhj+LdsCLFepaNaqlTlOxax2795NbFwMJelrLFOjpgR9ePzkISdPnrRgdEIIYb2+mC4ib29v4OVTtGnSpDGWP3r0CD8/P+M+jx8/jnecTqfj6dOnxuPfZGdnh52dnXmCFh9Fq9VSu3ZtateubelQrE5MTAyd27enlsHAMkXBBojV6agL7MaJtvojaLHluf4hc56WoF+//qxa9VeC6q5atSq9evak9++/M06rxRG4rNNRtVIlevXqZcazMo9XPedxxJ8D9tXrz+3lVBSFXbt2sWrVKvR6PTVq1CAgIAC1FfVWCCE+kSyD+WXw9fXF29ubHTt2GMvCw8M5cuQIJUqUAKBEiRKEhoby999/G/fZuXMnBoOBYsWKJXrMQiSW/fv3E/zsGcP+TTgBbIHhQBQR3OPlmGYXvCms7866tWvR6XQJqlulUjFh4kQOHjxIYPfuVOrQgXXr1rFpyxbs7e3Ncj7mVKlSJVycXNnNEPS8vAaxRLJPPQLfjFkoUKDAJ9dtMBho27YdlSpVYum0TayauYtatWpRp3Zd4uLiTHUKQoikyuQPEf27WQmr6ul88eIFV69eNb6+ceMGp06dwsPDgwwZMtC7d29GjhxJtmzZ8PX15YcffsDHx4e6desCkCtXLqpVq0aHDh2YOnUqcXFxdO/encaNG+Pj42OhsxLmpigKx44dY/v27Tg4OBAYGEj69OktHVaiepVAvtln/+q1gf8nmFrsMSgGDAYDH6NEiRLGL3jWzNnZmanTp9CieQvuag6QWleIu9r96DQv2Dh7w2f1SK5atYq5c+dQh9n46VoDcIn1LN9Uj2nTptG9e3cTnYUQQiQ9KkVRFEsHkVC7d++mQoUKb5W3atWKuXPnoigKQ4cOZfr06YSGhlK6dGkmT54cb+qZp0+f0r17d9avX49araZBgwb8/vvvODs7JyiG8PBw3NzcCAsLw9UKH5JIbuLi4mjRrBnLVqzATaMhRlGIAyb+/jvdunWzdHiJ5sWLF6T19qZhRAQzABWgAK2AFTjQlxBscCCGF8zWFMevYnq2BG22bNAWdurUKaZOncqNGzfJkyc3Xbp0IVu2bB8+8D/UrVuPE+sf0s5wKF75MlU9XAs/4vDRg59VvxDi/Sz599vY9ormuDramrbuyFjcGi60irzEqpLOpECSTusybtw4Bvbvz1xFoQkQCXwH/AmcPHnSON43OZg2bRqdO3emsEZDab2ePRoNJ/V6AHKoauKqZOSKdg0623D2HdibrK5NYqlcqQp3dzrRhDXxytfTicgcB7lw8ex/Hq/T6dixYwePHj2iUKFCeHh4sGvXLuzs7PD390/wl2chkiNJOi3vixnTKcS7zJo6laaKQnNezp/rAvwG+Gi1zJ0716KxJbZOnTqxdetWUletyubMmUlfvTpBQUFMnz4dj6LPCMu6kwatqnP8xDFJOM2kYqUKXFdvJZRbxrIInnBJs4rKVd++i/O6kydPks3Xl2rVqtGqVSvy5s1Leh8fmjVrRmBgID7eaVm+fLm5T0EI8RkMKhUGtYk3lYzpFCJJeBISwps3RLVAZkUhODjYEiFZVNWqValatepb5R06dLBANMlPp06dmDZlBrMeFMVP3wENtpzWzMLOTUXfvn3fe1x0dDQ1/P3xefqUlUAu4C+gIyoK0I4yDGZH5ECaNW1G3rx5yZ07d2KdkhBCJJj0dIovWpFixVil0fD6c9i3gMMGA0WLFrVUWCKZSpkyJYeOHODr1rU54zqZv53GU+3r0hw+cpCMGTO+97g1a9bwIDiYxXo9hQBHoAUwAIVzLMSZ1NRV5uGoSsmMGTMS63SEEB/JoFabZbMW1hOpEJ/gu++/5xxQWaViMS/HcpbTaEjj7U3r1q0tG5xIlnx8fJg5cwahYU8JfxHG4sWLyJo1638ec+vWLdw0GrK/UV4EiCWaSELQYoeXvgC3bt16VxVCCGFxknSKL1rp0qXZuGkT4Xnz0gzopVbjFxDA3oMHcXNzs3R4QiRI3rx5CdPrOfxG+RbAGXecSEUUodxTHyJv3ryWCFEIkQAmH8/572YtZEyn+OJVrVqVKqdP8+zZM2xtbeUJX2F1qlWrRt6cOWl49So/63TGMZ2TgK8I5Drb2af5ERt7FR07drRwtEKI99Fr1Og1pu3vM3V95mQ9kQrxGVQqFR4eHpJwCquk0WjYsn07ucuVoyUvb6tPtLXF0dGZE8xkMTVwzR7Jth1BpEuXztLhCiHEO0lPpxBCWIG0adOydft2bt++zePHj8mRIwf29vacO3cOe3t7cubMicqKpk4RIjkyx+1wa7q9Lj2dQljA6dOnady4Cel8MlIg31dMmDAhwWudi6Th3LlzNG/WnHQ+Gcmf149ff/2V2NhYs7ebIUMGChcujIuLCzY2Nnz11VfkypXrrYQzNjaWcePGkS9PAdL5ZKR5s+acP3/e7PEJIcT7SE+nEInsyJEjlC9XASe9Dzl1jQl9eJO+fb7lwP6DLF+xTHqrrMDff/9N2TLlsI9LRS5dY8If3KH/twPYs3sva9autvjP0GAw0KB+IJs3bSa30pCMpGPz8hWsXl2M/Qf28dVXX1k0PiGSK0WtRjHxFEemrs+cJOkUIpEN6DcQj7ictDEcwAYHUOAsS1j5V1MOHOhJ6dKlLR2i+IBBA7/DNdaXtvoj2OIIQC4lkOXrG7Br1y4qVqxo0fh27NjBho3racRqclEXgPK6ocxSijH4u+/ZtHmjReMTQiRP1pMeC/EFiI6OZs++3RQ0dHqZcP4rD41w1aZmy5YtlgtOJIher2f7jm18pe9oTDgBclEPd206Nm/ebMHoXtqyZQse2ozkpI6xzBYn/PTt2Rq0BYPBYMHohEi+ZMokIUSi0Wg0aDVaYvUv4pUbiCPWEMnBgwdp3rw5WbNmpV27dqRPn97kMYSGhjJv3jyOHz9O6tSpad26dbKa2zEuLo7Vq1ezefNmbGxsCAwMpEqVKgm+Ja5SqbDR2hIT9zxeuQEdcURhZ2dnjrA/ip2dHXFEYkCP5rV/5mN5jq2NXYLPNTY2lhUrVrBt2zbs7e1p1KgR5cuXt/jwASGEdZKeTiESkY2NDXXq1uWoZiJh3AFAQWE9HYk1POf4nj3cXrqUX0eOJFeOHOzevduk7V+7do08ufLR95t+7FtynRkTF5I/f35mzZpl0naSqqioKPwrV6ZRo0acWriQPXPm4O/vT7u2bVEUJUF1qNVqAgMbcFzzJ8+4Cbz8GR5gDBG6EBo2bGjGM0iYhg0b8lwXzEHGofDyvJ5xg781k2nYMDBBSeOLFy8oW6Y8zZs3Z/uic/w1awcVK1akR4+eCb5WQoj4kntPp0qRfz0+Snh4OG5uboSFheHq6mrpcIQVunXrFqVLluXRw0dkUMoSpr5BqP4qJVUq1ikKbkA4UFet5pq3N9dv30aj0Zik7erVAji2/RIt9LtwJwM6YtlEd85q53Ln7h1Sp05tknaSqtGjRzPku+/YYjBQAVCAeUAbYPXq1dStWzdB9dy9e5dSJcpw//59Mihlea65Q7DuEoMHD2bkyJGfHefTp09ZunQp9+7dw8/Pjzp16mBra/tRdQwaNIhffvmFVNqcOOvTcYs9pE+fnv0H95I2bdoPHv/DDz8wZtSvtNBvJz0lUFA4yiQ204Nt27ZRuXLlTz09ISzCkn+/X7V9Y0dnXJ1MezckPCIG30pTrSIvkaTzI0nSKUzh6dOnzJo1iwMHDqDT6di4cSMHgRKv7XP439d79+6lTJkyn93ms2fPSJkyJTWUqRTm/6vWRPGMcapU/DHpd7p06fLZ7SRlX+XNS+7z51n0RnlhjYasgYEsXbo0wXWFhoYya9Ys9u/fT4oUKWjRogUVKlT47Bh37dpF7Vp1iIqMwlWbhmdxd8ieNSc7d29PULL4up07d7JgwQJCQ0MpU6YMbdu2xd3dPUHHZsmUjRS3KlKLacYyBYUp2lzUalWamTNnflQsQliaJJ2WJ2M6hbAADw8P+vXrR79+/di2bRsbN27E4419Uv7734iICJO0GR0djaIoOBprfskWF7QqO5O1k5RFRES8cfYvpTQYiHjx4h3vvJ+7uzt9+/alb9++pgkOiIyMJLB+Q1JHFaOeshDnuNQ84BTLbtSiQ/uOH/3UecWKFT/5SfqIiAh83rhaKlTYG1K+9VnR6XRs27aNO3fukD9/fooVKybjPoV4B0Vl+tvhihX9rsmYTiEsrGjRojjZ2zP1jfIpgKO9PcWLFzdJO97e3uTMnpu/VdMxoDeWn2EBMYaIZHG7tFK1aizXagl5rewisBOoXKWKhaL6v40bN/I0NIQahmk483KoQxr8KKsfxpatm3n06FGixVLFvxLntYuJJsxY9oBT3DEcivdZOX/+PFkzZycgIIBOnTpRokQJypYpz9OnTxMtViGEdZCkUwgLc3NzY+iPPzIBCFCr+QWooVbzGzBk2LAE3w79EJVKxdjxo7mubGOyOhdb+ZZVtGC9qgNNmzTDz8/PJO0kZQMGDMDg4oKfVsv3QB+ghEZDtqxZadu2raXDIyQkBBVq3MgQrzwFmVEUhWfPniVaLN//8D0GhzCma/zYyRA204t5mrLkz+dH06ZNgZc9nDUDahNz35mO/M0Q9DRhPScPn6NTx86JFqsQ1kKvUptlsxbWE6kQX7B+/fqxaNEiQvz8GOPiQnCBAixcuJABAwaYrI2nT58yZdJUFBSeGK5wiPFcd1zH8B+HMW/+XJO1k5RlypSJQ8eOUalpU6anSMHyVKlo2a0bew8exMXFxdLhUbx4cRQMnGd5vPKzLCZlCi8yZ86caLHkyJGDw0cPUbVhCc65T+Gu92q6f9OJ3Xt34uDwco7Z7du3c/P2dWrr5+BDQdSoyUFNyulHsGrVXzx+/DjR4hVCJH0yplMIC1IUhevXr2NjY0PTpk2NPUjm0KRxMw7sPEY9FpCRMtxkN0ExvTl25DhabfL5pyBLlizMnTfP0mG8k5+fH3Xr1GP9+nY8MpwmNQW4zHrOsZSJwyZ+9BPsnytnzpwsWbL4ve/fvXsXAG/84pWn4SsMioGHDx+SKlUqc4YohFUxxxRH1jRlkvR0CmEhmzdvJke2XGTNmpWMGTNSuGBRjh07Zpa2Ll68SNC2LVTT/0EBmuNORvxoRRX9b6zbsJbr16+bpV3x8ZYsXUyvPt055zKdVTTjRYajTJ8+nR49elg6tLfkz58fgMvEf8DpMhtwtHfC19fXEmEJIZIoSTqFsICjR49Su1ZtDNcz0JQNNGQFD88YqFShMrdv3zZ5e1evXgUgI+XilWeiPABXrlwxeZvi09jb2zN27FhCnj0hPDyc6zev0qFDhyT5NHiRIkUoV7YC6zStOcKf3OYAOxjMAdVoevTqniSGLAiRlCT3yeEl6RTCAsaOHYeHKitNlU1kpwZ5CKSFfgf6aDWTJ082eXtZsmQB4Db745XfZl+890XSodFocHFxSZLJ5isqlYrVa/6iZv2qBKl7M5vSnHD4nX79vzXJJPlCfGkUtdosm7VIPgO5hEhCThw7RRZdrXjrYtvjRgZ9eU6ePGXy9nLlykXlSlXZsqc76BQyUJqb7CFI05uAqjXJmjWrydsUyUOKFClYtnwpwcHBPHz4EF9fX5ydnS0dlhAiCbKe9FiYze3bt+nUqRM+qdOR3icjffr04cmTJ5YO6y0//vgjHu6eaNV2ODu40qZNGwwGg6XD+iTpMqTlsfp0vDIDBp5oz5I2rY9Z2lyydBHFy33FShrzK+lYRTPKVCrGwkXzzdKeSF68vLzIly+fJJxC/IfkfntdejqTuXv37lG0cHGinink1bVATwzTfp/Dpg1bOHr8cJJZUqtz585MmzaNdBTHjwDuRR9l7ty5/PPPPxw+fNjS4X20zl060nRfU/YwkuL0Rk8MuxjCE901OnZcaJY2PT092bZ9KxcvXuTq1atky5aNHDlymKUtIYQQ4k2SdCZz48aN48XTGDrrz+OCNwBF9F2Zei0/M2bMMOkSf58qMjKSmdPnkJdGNGAJKl5+q9vDSHYdGcLx48cpXLiwhaP8OI0bN+bMmTOMGT2U3cpQFAzY2NgyacIkk61A9D45c+YkZ86c733/xYsXTJ06lbWrVqEoCnXq16dLly7Sg/WRYmJimDVrFkuXLCcmOoaAmtXo3r07KVO+ayFOIURyYFCrMZh4DKap6zMn64lUmMWWTdvIqQ80JpwAnuTA11CZoK3bLBjZ/61fvx69EksRuhkTToCidAcUZs2aZbngPpFKpWLUqFFcv3GdqdOmMHv2bO7du0vXrl0tGldERAQVypRh8IABpDp0CO/Dh/l+4EDKlSrF8+fPLRqbNYmLi6NmQC16dO/JowMuRB7PxKgRYylauLhMmC6ESLYk6UzmHB0diCb0rfIYdSgOjg6JH9A7vLrF/2ac0bxcEtCae+AyZsxIx44dadOmDV5eXpYOh2nTpnHq1ClGGAw4AHbACIOBs2fPMnXqm6vDi/dZvnw523duo7mylabKegJZQif9GR7eecKYMWMsHZ4AHjx4wI8//khgYCDffPMN58+ft3RIIhkwqFRm2ayFJJ3JXJNmjbioWs0NdhnLzrGM24aDNGnS2IKR/Z+/vz8Ods7sYiiRhAAQRzRB9EONhn79+lk4wi/H6pUrSYmaAcBuCrAXPwYAHoqK1StWWDo8q7Fu3TrSq4uTmUrGMg8yk0fflFUr1lguMAHAiRMnyJ0zDz//OIZTq8KY/edSCuQvwOLF7199SQjx+WRMZzLXvXt3Nq7fxLy9FUmnKYxOFcND3Vm+btiIwMBAS4cHgFqtZvrMKbRq0YZfSUdaivGIM0QTSp8+3yTLZfauX7/O4sWLCQsLo2zZsgQEBKDRaD673sfBwTxCoRmbyEZ1AK6ylUVUxykJzmhgbRSUJD3vZnKgKArt23bEMSITHfXbccQDnS6WtbShQ/uO1KxZM8k8QCm+PLIMpkjW7O3tCdq+lSVLllCucQ78mxVk3bp1LFm62CRJjKk0b96cv08eo2zFkhjSXydv4Sxs2rSR8ePHWzq0RDd16lSyZcvG2GHDWDFhArVr16Zc6dImGXOpoCYLVYwJJ0BW/MmCP5B0Pg9JXZ06dbhjOMw1/j8u+inXOK9ZTL3AOhaMTFy/fp2Tp/+mjP4HHPEAQIstlRlNZFQEmzZtsnCEQny5pKdTYGNjQ+PGjWncOGncTn8fPz8/duzYYekwLOry5ct07dqVzorCeMAB2A3UOnaMoUOH8uuvv35W/R4pUvIC97fK7UmBndvb5eLdGjZsyLw581m0oxpZ8MdWceGKej3pM6RjwIABlg4vWYuOjgbADrd45fb/vo6Kikr0mETyoZjh6XVrWpHIeiIVQrBo0SLc1Gp+5WXCCVAe6KLXM2/27M+uP6BmNa6oN/CMG8ayUG5xRb2OmnVqfHb9yYWNjQ3rN65j0uRJpC0bg2uxe/ww/DuOHj+cJB4YS85y5MhB2jTpOcYkDPx/cYmj/IlapaZSpUr/cbQQn0ePCr3KxBvWc3tdejqFsCLPnj0jtVqNvV4frzwD8Cw8HEX5vDGD3bp1Y+7s+cy4W4h8+haAinOaBXj7pKJ79+6fF3wyY2trS+fOnencubOlQ0nSbt++zalTp0idOjVFixY1+5hXrVbLuF/H0LRpU2ari5NFH8BD1QkuKev5tu+3ZMiQwaztC5GcSU+nEFakVKlSXIqL4+hrZXpgkVpN6RIlPvsPdsqUKTl05ADtu7Xgvs9a7vusoV235hw+ehBPT8/PqluI18XGxtKmdVt8M/lSp04dihcvTr48Bbh06ZLZ227cuDFBQUHkKp+Cf1JOw6nAA2bNmiXTWQmze/kgkdrEm/X0dKoURVEsHYQ1CQ8Px83NjbCwMHnCUSS62NhYShQpwo3z5+mh15MWmK9WcxjYGhT0WbcGg4ODuXfvHr6+vri5uX34ACE+w7fffsvE3/6gimE8uajPE/5hi6YH9mmiuHLtEra2tpYOUXxhLPn3+1Xbh08NxNnF3qR1v3geTXG/X6wiL5GeTiGsiK2tLdt27aJhu3aMd3CgE6AvVIgtW7d+csIZHh5Os6bNSeOdhq+++orUqbzp2bMXsbGxpg1eiH9FR0czdfI0Shj6UYzuuOJDZirRQL+M23dvsmHDBkuHKIRZKCqVWTZrIWM6RbIRHh6Ora0t9vam/ZaZ2Dw8PJg2bRpTpkxBr9djY2PzWfU1/roJu7cfoKrhN9JSlGux25gyaQQ6nY7Jkyd9dH2xsbFERkbi5uYmc1KKdwoODiYi6gUZKBWvPDX5cNC4cu3aNQtFJoQwJ+npFF+8nTt3UqRQMdzc3HB2cqZB/UBu375t6bA+m1qt/uyE89y5c2zeuokA/VSK0YN0FKMc31POMJyZM2YSEhKS4LpCQ0Pp0KEjbq7upEiRghzZcrF06dLPik98mby8vHB1duMmu+OV3+cEUfpwsmfPbpnAhDCzV5PDm3qzFpJ0ii/aoUOHqOZfjeBTNtRlLpUNY9m57ghlSpUjPDzc0uFZ3NmzZwHIRkC88mwEEKeL5fLlywmqx2AwUM0/gMVzVlAiZhANWIzmeg6aNGnCkiVLTB63sG729vZ069GVw6pf2c9oQrjKRdbxl/Zrsvhmo0YNmZ5LiC+RJJ3CpG7fvk2bNm1JmcILT49UdOzYkXv37lksnpEjfsJTyUVLwy78aEUJvqGVfi/37t1l3rx5FovL1G7evEmbNm3wcPfE0yMVnTp14v79+x88Ll26dAA85GS88gecACBt2rQJaj8oKIgjRw/RUL+KcvxAPprQSFlDTuow9IfhyPOK4k0//vgjnbt2Zo/2B/4gG0upQ+YCnmzbsRWtVkZ+iS+TQaU2y2YtrCdSkeQ9ePCAYkVKsGrhFvKEdiTXs3Ysnb2WEsVK8cRC63YfPnSEnPpANPz/NnQKfEmnLsbhw4ctEpOp3bt3j+JFS7J6YRB5wzqT81lbFs9aTcnipT94e7x06dLkzpmXDZoO3OYAenRcYTM7NQMIqFYjwXMWHj58GBdtKjJR3limQkUeGnPl2iVCQ0M/4wzFl0ir1fLnn39w5+4dtm3bxtmzZzl6/DC+vr6WDk0Is5Hb60KYyIQJEwgLiaCD7m8q8ROVGUV7/XEeP3zCpEkf/0CKKaT0SMlT4j+UYEBPmOrmZ807qSgKCxYsoEK5iuTNXYCOHTsmyvyC7/Lbb7/x/Gk0HXQnqMRIqvAL7fXHeHDvIVOmTPnPY1UqFWvXryZlZi2zKc0IbFhEAHkKZWXu/DkJjsHT05MoQyhRPI1X/oxr2Nna4+Tk9EnnlpTodDqmT59O2ZIl8cuTh549e3Lr1i1Lh2X1UqdOTeXKlcmbN6+lQxFCmJkkncJktm3ZQXZ9XVxIYyxzIz1Z9AFsC7LMmuntOrbhnGoRZ1mKAQOxRBDEt4Tq7tGqVatPrrdLl660bNmSO/s1OPxTkuVzNlLoq8L8/fffJow+YbZv3Ul2fV2cSW0scycjWQzV2Z6A6541a1YuXDzH9u3bmTlzJgcPHuTg4f0ftVxjo0aN0GjVbKATkYSgoHCD3RzWjKdZ82ZWP+eioig0bdyYzp064Xb4MEUvXGDplCkU8vOz2JcNIYT1MahUZtmshQycESbj7OrMI9UTeGP4XpT6CemdLdPT9c0333Dk8FH+WtOELdruxBmi0BHNhF8nULBgwU+q89SpU0ybNpUAJlHU0BWAGN1Y5iql+bZvf3btTtwE28nFiaeqkHdedydnlwTVoVZ/3prTXl5eLF22hMaNmvCrzgdHtQfhuocU+aoY48eP++R6k4odO3aw4q+/WAZ8/e/41F90Ogo/f86QH35g2fLllg1QCCGsgCSdwmSaNW9C1wNducg6clIbBYXzrOCGYRfDm8+3SEy2trb8tWolBw8eZPv27Tg6OtKwYUMyZcr0yXVu2LABR407hfQdjWV2OFNY3531ezrw4sULnJ2dTRB9wjRr3oQeh3twiQ3koCYKCudYyk3DXkY2W5hocdStW5fbd26xbNkynjx5QrFixahWrRpqtfXfUNmwYQOZtFoa6nTGMg+go17P8LVrLReYEMKqGNRq9Cb+N9FgRf/GStIpTKZt27Zs3LCJpRvqkFqbGwU9j3WXaBj4NU2bNrVYXCqVilKlSlGqVKkP75wAarUaBQMKhnjlBuJQqVSJnmR16NCBTRs3s2RTLby1eTCge3ndG36NwWCgR48epEyZkubNm5M1a1azxpIqVSp69Ohh1jYsQa1Wo+dlZ/LrN7LiAI1GY5mghBDCylhPeiySPBsbG9asXc26deuo1bokddqUZdOmTSxdtuSL+sNcr149ovThHGK8sSySEI5qJlK1ij+Ojo6JGo+NjQ1r161h7dq11Gxdgrpty7FkyRLOn71Ay5YtWTFtB2NHTiRHjhzMmZPwh4PE/9WrV487Oh2zXiu7B0zTaqlXv76lwhJCWJnkPqZTpcgEeh8lPDwcNzc3wsLCcHV1tXQ4wsT0ej1btmzhwoULZMyYkdq1a79z2cxBgwbxyy+/kFZTEDd9Fm5ogrB30bL/wF5y585tgcjja9miJauXbKGZPog0+BFHFJvowVnNPK7fuE769OnN0m5YWBirVq0iJCSEYsWKUbp0aZMthXnu3DmCgoKwt7enXr16pEmT5sMHmYiiKHTs0IGZs2ZRQq3Gx2Bgi0ZDCi8v9h8+TMaMGRMtFiHEp7Hk3+9XbW+7PBwnF9MuxRzxPJoq2YdaRV4iSedHkqTzy3Xv3j2qVa7MuYsXcdVoCNfrSZs6NZuCgsifP3+8fRVFYfPmzcyePYcnj59QolRxunXrZpxs3ZJiY2NxcXahTNxwyjDQWB5NOL+qvflp9I98++23Jm9369atNGzwNS8inmOncSJa/4Ly5SqyfsPazxrjqtfr6dSpM7NmzcRW7YBeiUOlht//+J0uXbqY8Az+m6Io/PXXXyxcsIDw0FDKVaxIly5dSJUqVaLFIIT4dEkh6dx65UezJJ3+2YZYRV4iYzqF1YqJiWHnzp1ERERQpkwZUqdO/eGD3iE8PJxdu3Yx7PvvCbtyhUNAcb2eS0DjJ0+oV6sWl69fjzdEQKVSERAQQEBAwHvrtZSYmBhi42JxwSdeuR0u2KtdzbL859OnT2lQP5C0UWWpyXRc9D5cZiOr9zelf//+TJ48+ZPrnjZtGrNnzaIGUyhoaEcsEezUD6Zr164UK1bsk2ch+FgqlYrAwEACAwMTpT0hxJdHUatRTDzu39T1mZP1RCrEa7Zu3Uo6nwwEBATQsGFD0qdLz3fffffRyy3OnDkTH++01K1bl1PnzjFKr6f4v+/lAKbp9Vy/fZvdu3eb+hTMxsXFhQL5vuKMah6G1x52usJmwnWPKFu2rMnbXLZsGdFR0dRW5uBKWlSoyEFNiun7MG/ufGJjYz+57ulTZ5JLVZ8idEaDDQ64U53fSaFNz+zZs014FkIIIcxJkk5hdW7fvk2d2nVJ8awgXThLXx5QUvcdo0aNYtasWR+u4F979+6lQ4cOZI9qRCNWAfDmaMxc//734cOHH6wvJiaG48ePc+HChQQnv3FxcZw4cYIzZ85gMBg+fEAC/TRqBDfZzTx1WY7wJ1vow0p1QyqUr/RZ83G+z6NHj3DSpMSZ+LeavchFZFQEERERn1z3wwcP8VRyxStToyGFPnuCfi5CCJFUJPcHiSTpFFZn1qxZqPW2BCorSE1eXPCmAsPIrarPxN/+SHA9kyZNJrU2D7WZQSryoUXNX2/s8+p1oUKF/rOu6dOnk87bmyJFipAnTx788ublxIkT/3nM8uXLyZAuE4UKFaJAgQLkyJbLZD2qNWrUYNPmTfgUha3qXlxJsZBefbuxYeM6kz3Y87pChQoRrnvEbQ7GK/+HVWTKkBl3d/dPrrtIscJc0axDz//nyHzOQ+6oDlC4cOFPrlcIIUTikjGdwmpER0cTGhrKtWvXSEVe7Ij/cEpapTiHb21PcH3Xr9zAR1cMgFU0R4U9o4jkBeAPHAV+UakIrFePnDlzvreeVatW0alTJ1oBXYAnwJBLl6hSsSL/XL78zgdN9u7dS+PGjcmp1KM636Ajin03RxJQvQZnzp42yXya/v7++Pv7oyiKWRLN1wUEBOCXvyDLz9ellP47PMjKOZZynuXMHjb7o9sPCQlBo9Hg7u7OwEEDKL+lPItU/hRWuhJNGIc0Y3B3d6N9+/ZmOiMhhDA9c/RMSk+nECYUGRn5coLzFJ6kSZOGNavXct9wggieGPdRULiu3kbOnLn+o6b48uTLxW3tLm6ym3sc4Wv+oizDmYkbAcBINEQrEKvT8+jRo/fWM+6XX6ikVjMHKAbUALbo9UQ+f/7eMYe/jv8Nb3U+GrKCjJQmC1VoatiMJs7xsx66eRdzJ5zwcoL0oO1bqBFYiR2afiyhFk/T7GX69Om0adMmwfXs37+fIoWK4enpSYoUKahUoTLu7u6s37Ae+xyPWU4g62hH/rLp2bt/N56enmY8KyGEEKYkPZ0iyWvSqClbNm2jhOFb0lCQ85ErOMdSFqmqUVH5CUe8OM5Urhm2MWpAwtfA7tmrJ4sWLWIzvQAVWfEnG9UozUAieEQIl5lPZbZv2E/F8pU5efpvbG1t36rnwj//8J3BEG+lGi+gkErF+fPn39n22dPnyaSvjfq17322OJJOX4Zz5959TFLn5eXF0qVLCA+fRnh4OGnSpPmoRQFOnz5N5UpVSKUrQD0WoCeGw/vGU6Z0Oc6eO825C2d48OAB9vb2eHh4mPFMhBDCPAyYoacT6elM8iZNmkSmTJmwt7enWLFiHD161NIhiXc4c+YM6zaspaZhBhUYTk7q0ICF5KEhjznLQqoxnUJcc13JH3/8QcOGDRNcd8GCBflr1V9Eu9wGFB7wcgymFlvcSM9DTqNCTT3DQi5cPMeaNWveWU/GDBk49sY/IhHAOXjvGu+ZMmfkgSb+Z06PjsfaE/j6vvsYa+Hq6kq6dOk+ehWqcWPH4WzwoaVhNwVoTkHa0Vq/j6jnsUyZMgWVSoWPj48knEJ8oXbu3En5MmWwt7UlberUDB48mKioKEuHJUwoWSady5Yto0+fPgwdOpQTJ05QoEAB/P39efz4saVDE284duwYAHmIn0wWpQc6JZbly5dz4MABHjy8R/fu3T+6/tq1a/PTzyNRo2UVLbjFfmJ4wVmWsIfhKBhwIwOeNpmNsbypa8+erFQUfuLleM5LQGOVimi1mnbt2r3zmB49u3FTv48g+vGchzzjBmtpQ6j+Dp07d/7o8/gSHD54jKy6Wtjw/4mTHUlJJn0ljh5597UXQnwZtm7dSpXKlYk+eJBRcXHUf/yYX3/5hbq1an30VHhJmUGlNstmLawnUhP69ddf6dChA23atCF37txMnToVR0dHmfMvCXr1EM4TLsUrD/n3dalSpShZsiQODg6f3EbatGkxoENPDHMowyhc+IumuOMLgAYbwvUP3rvyTMeOHenXrx9D1Wq8gJzAITc3Vq5a9d6ezrp16/LLL79w3OYPxpOGiWTmuuNa5s2fx1dfffXJ52LNUnun4qk6/s9ZQeGp9hKpvd997W/evEnXrl3JliUnBf0KM378eGJiYhIjXCGECQ0eMIAywAGDgW+AP4AVBgNBO3awa9cuC0dnOgaVOaZNsvRZJVyyWwYzNjYWR0dHVq5cSd26dY3lrVq1IjQ0lLVr18bbPyYmJt4fsfDwcNKnT28Vy019CWJjY8mY3hfbJxmpZ1hECny5yxFWaBtQslIBNm3Z+NltxMTEkNLDC/fIPJSgNwZ0KChspQ9uZMBDlZkr2rXcuHkDHx+f99Zz79499u7di5OTE1WqVElQIvzkyRN27NiBjY0NVapUwcXF5bPPx1rNnTuXNm3aUJ3fKUQnDMSxl5/Yzyh27dpF+fLl4+1/5coVihcrSVy4mpz6hkQSzEXVKipVqsSmLRs/+va+EMIyXrx4gYuLC3OBVq+VK0AarZaOgwbx448/fnY7SWEZzFW3RuPk+umdJO8SER5F/YwDrCIvSXYPEj158gS9Xv/WkompU6fm4sWLb+0/atQohg8fnljhiTfY2tqydv1qAqrX5PenWXDUpiBC95Q82fIxc/YM434PHjxg8uTJHD50BE+vlLRp04aqVasmqI3Hjx8TGfkcA8f4iyY44kIE4big4THBhGjPsXjJ4v9MOOFlj2mTJk0+6vw8PT1p1KjRRx3zpWrVqhVHjx5jypSe7FQPwoAenRLDzz/9/FbCCTBs6DCUcEe66E/gSEoAripbWbi9GuvXr4/3pVIIkXTZ2tpia2PDw7i4eOURwHOD4Yv6Mm5Qq9CrTfwgkYnrM6dkl3R+rEGDBtGnTx/j61c9nSLxFC1alFu3b7Bq1Sru3LlDvnz5CAgIMPZkXbp0idIly/I8LBJffWXOac6zdKk/33//PSNGjPhg/UFBQSjAdfQEAXcJpwAAemoCB/btoVixYuY7QQG8nNpp8uRJdOvWlY0bN2JjY0O9evXeO0Rh44bN+Ol7GhNOgKz4463Nw8aNGyXpFMJK2Nra0rBhQ35bvpwaOh15gRig37//lS/mX45kl3R6enqi0Wjemnfx0aNHeHt7v7W/nZ0ddnZ2iRXeJ3vw4AFz5szh+vXrZM+endatW793DGJSdu/ePebMmcPNmzfJmTMnrVu3xtPTEycnJ1q0aPHOY/p80xfCXOmpP4cTXih6hb2MZOTIITRr1uw/J3YHsLGxAUADtHytfPW//zXXddTr9WzcuJHNmzej1Wpp0KAB5cqVQ6/Xs3btWoKCgnBwcODrr7+mZMmSZokhKcqTJw958uT54H5arRYd8Z9sVVDQEW38mSYXFy5cYP78+YSEhFC8eHGaNGmCo6OjpcMSIsHG//orFY4dI9+VK+TXarkHPNXrmTplChkyZLB0eCZjjgd/rOlBomQ3phOgWLFiFC1alD/+eLlkosFgIEOGDHTv3p2BAwf+57GWHBPyPnv37qVG9eoYoqPJo1Zz1mDA3smJLdu2WVUP3fbt26lTqxaquDhyq1ScMRhwdnUlaMcOChYs+M5joqKicHJyorryB0XpZizXEcM4jRc//DiQ77777j/bDQkJIW2aNLSOi2MyL5+uCwcqq9Xo8uTh79OnTT7BemxsLHVq1WVL0GZSaXOiI5qnupu0bt2G69dusHffbry1eYghnGe6O3zzTR/Gjx+XKBO9W4suXbqwYMYK2uoPk5KXKzidYBbraM+OHTuoWLGihSNMHFOnTqVr166k1GhID5zS6cieJQu79u0jTZo0lg5PiASLiopi+fLlHDx4EE9PT1q2bEmOHDlMVn9SGNO5/O44HE08pjMyPIqv032bpPKS90l2PZ0Affr0oVWrVhQuXJiiRYsyYcIEIiIiPmrllKRCp9PRvHFjCkVHs9pgIIXBwBOgZkQELZs25Z8rV1Crk/63oNjYWJo3bkyp2FhWGAy4AY+AamFh1A4I4Mjff5M2bdq3jjMYDCiKgob4vdEqNKjRotPp3jrmTSlTpmTiH3/QuXNntmm15Nfp2KPRoLOzY9uMGWZJ9CZNmsS2bdtoykay6wJQUPibGcyd2wmtyp5W7MRXVwEDBg4zgd9+60vNmjWsNpF6/Pgxy5cvJzQ0lNKlS1OuXLnPvq7Dhg1j29YdTLmVB19DJaI0wdzVH6dt23ZUqFDBRJEnbbdv36Z7t250VhQm6HTYAheASjdv0rdPHxYvWWLpEIVIMAcHB1q1akWrVq0+vLOVUlQqFBP/TTF1feaU9LMRM2jUqBHjxo1jyJAh+Pn5cerUKbZs2fLWw0XWYP/+/dx58IAxBgMp/i3zBEYZDFy+fp2///7bkuEl2M6dO3kUEsK4fxNOgNTAz4rCvUePyJghI7NmzXrrOCcnJ8qVKc9xzSRiiTSWn2Q2kfpn1KxZM0Htd+rUicOHD1OhVSuiqlalQ9++nL1wwWw9xQvnLyYn9chOAAAqVBSmIzY4kU9pii8vkyY1akrwDV7a7CxevNgssZjbsmXLSJ8uA7179uGX4b9RoUIFKleqSkRExGfVmzp1ao6fOMqo0T+RpRqUqO/L6tWrmTnTPF8UkqJly5ZhB4wBXq2VlRv4Rq9n5cqVMn2UECJJSZY9nQDdu3f/pMnEk5oXL14ALxO01716/fz580SN51N96DyyGALo2KEjpUqVemuM5tjxYyhfrgJT4nKSTVeHUPV1Lhs20bZtu/feln+XYsWKJdpwhPDw53go7/6S4/TGVVChwsmQ2mp+lq+7e/cuLZq3IKcukOr8gYPOg8ts5K89jRg6dCjjxo37rPrd3d359ttv+fbbb00UsXV58eIFzmo1TgZDvPLUQJxOR2xsrFWMSRciuTCgMvmylbIMpkg0xYsXx87GhhlvlM8AnB0cKFy4sCXC+milSpVCq9G88zwccaEe83DQpGDevHlvHVukSBGOHT9KneaVeZZlO57Fwpk1axYzZkxPlNg/ReWqFbioXUkUz4xlT7mOjijOqRcRw/8TzMec57ZywCpvGS9cuBC1YktNpuFISlSoyEFNChu6MWvG7C9qpRFLqFChAo91Ota9VqYHZqtUFCpQ4IuaakaIL4HpJ4Y3/Vru5pRsezq/FJ6envQfOJARI0ZwUaWitKKwS6VinaLwy9ChSX5Q8Stp0qThmz59+GHsWM4CJYBtqNiEQkk6Y487KchEcHDwO4/PnTs3c+ZYz4pS/fv3Z9nSFcx4XpAC+rbEEcUpzUx8UqclNPQZM2IKkV/fmhjCOKmZQY6sud779H5iMxgMnDp1isjISAoWLPjOp6Rv3brFjRs3uHHjBq7qNNjp4yc/KclGaPgz9Ho9Wq38M/SpypUrR/WqVWm0fTttDQYyA8s1Gk4oCpvGjLF0eEIIEY/0dH4Bhg8fzvTp07mUIweDbG25lTs3c+fOpX///pYO7aOMHj2ayZMns9negW95mXQCHGQsv5ONe7oTFC1a1LJBmoivry+HjxykSmBxjjmO5ZzrNJq2q8ex40c4dPgAZWvn54jDKC6mmEPbLs3Yu383Tk5Olg6bQ4cOkSNbLgoVKkSZMmXw8U7Ln3/+aXw/NDSUurVfzq1ZoUIFZkyfQXDcVe5zwriPgsIF1Qr88heUhPMzqVQqVq1dy4Dvv2dDmjQMsbPDpXRptu/YkeDFEYQQiSe5r72eLKdM+hxJccqkL813333HqFGjKEI3CtGBCB6znYE8Vp3l6vXL750s/HM8ePAAQKaY+Q8PHjwgR7acpIjKQ3nDSBzw4DhT+JvprFy5kgYNGlDdP4C9Ow5TWT+ODJTiGkEE0Rc7lRullAG4kYEzqgVcVjawevVqmcBdCJFoksKUSQseTDTLlEkt0vSyirzEetJjkWxs2rCF7KoAavAn3hQgC1VozhZUKjUrVqwwaVuHDh2icMGi+Pj44OPjQ+GCRTl06JBJ2/hSzJw5k9hoPU0MG8lMRdLgR02mkkVdmbGjx/PPP/+wJWgz1fWTKEhbPMlBMXpQkZ+IVELYpfmOlTSCLFdZvny5JJxCiGQnuY/plKRTJDmXLl/EV6kcr8wJL9KoC3Dx4kWTtXP58mUqV6rCo9MqAllKIEt5dFpF5YpVuHTpksna+VJcunSJNBTEwTg518sn6zMZKvHPP/8Yr5kvleIdl5N6gMKatasJDg7m4uULNGzYMDFD/yDDG09/CyGEMD1JOkWS45spM3dV8XsbowjlsXIeX19fk7UzYcIEbOJcaWnYRV4akZdGtDTswkbnysSJE03WzpfC19eXR5whhhfxyu+qDpI5c2bjz+YOB+O9/+p1rly58PT0TDJzaEZFRTFw4EBSenih0WgoXLAo69evt3RYQogvmF6lMstmLSTpFElOr296cF5ZwW6GE859HnCKFepA1DaKSVeNOn70BL46f2z5/9PXtjjiq/Pn2GHrmFQ/MbVr1w6DJoaVqoY85Azh3GMH33NJWU+vb3pQoEABSpUowxZtNy6yjkhCOM9Ktmv6ElCtBpkzZ7b0KRgpikL9ug34bezvZH/WghpM4dlpF2rXrs3KlSstHZ4QQnyRJOlMxrZt24Z/lWqkTZOBUiXLsGzZsiQxb2LHjh0ZNGgQB7Q/8StpmcZXRKS8wIaN69+5FOanSuPjzRPN+bfKQzQXSJPWO0F1rFq1irJlypPWOz2VKlZh06ZNJosvqcmUKRNr160h1OMkUynAr6TjsHYsQ4cONS5bt3LVcvIUycxS6jAGT1bQkGLlvmL+wrfnV7WkAwcOsCVoM/UMi6nGrxShMy0M28muqsF3A79PEr8HQogvj4zpFMnSggULqFq1Khd2PSXLwxY8OmJP48aNGTlypKVDQ6VS8fPPP3P33l1WrVpFUFAQd+7dMvm64x06tueu/hi7GEosEcQSwS6GcUd/lI6dOnzw+HHjxtGgQQPuHVST5VErru6NoEaNGsyY8eYU918Of39/7t6/zdatW1m1ahX37t9l2LBhxlvm3t7eHDi4jxMnTrBixQrOnDnD9h1BpEyZ0sKRx7d3714cNe7koLaxTIWKAkorrly7xJMnTywYnRDiS2VAbZbNWsiUSR/pS5gyKTY2lnQ+GUgdUoEGLEb173yY2/mOI9rx3L13h1SpUlk4ysQxfPhwfhz+Iyo0ABjQMWTIEIYNG/afxz179gyfNGnxi+lENX4DXs4/uZa23HRbx/0Hd3FweDktRmRkJDNmzGDdmvWo1Crq1qtDu3btjO8nVHBwMJMnT2bH9l24uDjTtFkTmjRpglptPf/gJBWTJ0+mZ/fe9FUe4oiHsfwQv7FD05/QsNAkMS+qEMJ0ksKUSdMfTzbLlEkdU3W1irxE/lolQ2fOnCE45BHF6GlMOAGK04s4XSy7d++2XHCJbOjQoVy/cZ0Jv//KhN9/5caNGx9MOAH27dtHdEwUxehlLFOhohi9CA17yvHjxwGIiIigXJkK9P3mW+7uduD2Llt69exNpYpViIqKSnCcd+/epaBfYX7+cQwh+724sPU5zZs3p3mzFnIr+BMEBgai0arZQk/jg1EPOcMhzRjq1a8vCacQwjxUKhQTb1jR7XVZDiQZsrW1BSD2jaeQX633bWdn90n1RkZGsnjxYvbu3YubmxvNmjWjePHinxdsIsiYMSPdu3f/z33u3bvH7NmzuXTpElmyZCFr1qzA29cw9o1rOHnyZE6dOkU75TA+FAIF7nCYOUdKM3PmTHr06JGgGIcOHUbY4xi6GS7iRnowwBkWsWRpc1q3aSWrzyTQ8+fPWbBgAYcOHaJipQps37acy6zDTZ2WR3EXyZE5F7//nrCZCyIiIli0aBH79+/H3d2dFi1aUKRIETOfgRBCWC+5vf6RvoTb64qikCNbLmJveNLUsBk7XNARy2pVc+44BXH/4b2P7ukJDg6mQpkyXLh0iaIaDQ9UKm7rdAwfPpwhQ4aY6UwSx/79+wnw90eJieEr4DSgs7FBq7XDJ6IcgcpytNgRSwRL1LXQ+9zg+s2raDQaShQrRfjRNHxN/CeiF6tq4VMmgl17diYoBg93T/KGdaYS/x9zq6AwSZudwPaVmTJlignP+Mt07949ypQqx63bN0mnLkqY6hZhuvsEBASQNWtWihYtSmBgYIK+dD169Iiypctz9dpl0qmL8lx1j2e6O4waNYqBAwcmwtkIIT5WUri9PvXJVBxMfHs9KjyKzp6drSIvkZ7OZEilUjF77kyqVa3OxNgMpNWX4JH2JJHKExbPXvxJtxa///57Hl69yhkgr16PAfiRl7ev69SpQ4ECBUx9GonCYDDQqlkzCkRHs95gwB14DtRXFE7Z23NVvYmJqgx46wpxX3MEvTaKjfM2oNFojMe/Gi/6OrWi+agJyQ0GA+p31cPH1fMu9+/fZ+nSpTx9+pRSpUrh7+9vteNEQ0NDWbZsGbdv3yZfvnzUq1fPmET26dOXp3ej6KZcJKU+K3p0bKM/mzdP4OrVqx81pdPAgQO5fyOELso5vPS5MKBnJz8waNAg6tSpQ65cucx1ikIIYbWs8y+L+GylS5fm/D/n6NW/C7lq29C669ecOn3qk1aKURSFpYsW0UWvJ++/ZWpgMOCl1bJ06VJThp6ojh07xvXbt/n534QTwAUYZTDwJDSUmbNm0r5HM3LVtqFb3/acv3Au3lP2derV4rJ6HY+5YCx7yGmuqDZRp15tEqp2nZqc0s7iBY+NZRdZy2PdJWrXTng9b1qyZAmZMmZiYL/B/Dl6NgEBAZQuVZbw8PBPrtNS9u/fj2+GDHTr0oUFY8fSpEkT8ubMya1bt4iNjWXVX39RVP8NKXk5NEKDloqMxE7txPLlyxPcjsFgYOmSZRTR98CLl8mlGg3lGYqjJoVVf96FEOZlQGWWzVpIT2cyljFjRn7++WeT1BUZHc2bk+LYAG4qFZGRkSZpwxJexe7xRvmrc/X09OTXX3997/Hdu3dnyaJlzLhYiByGuigYuKxeS768+ejYsWOC4xj+43C2btnG5Gc5ya6vS6TqMVeUTdSpXZfq1at/5Fm9dPfuXVq1bEUuXSMC+BM7gys32MWKY/X47rvv+PPPPz+pXkuIiYmhYb165I+IYImi4BMXxzmg1p07tG3VinUbN6LT63B44ydpgwM2KseP+owqikJ0TNRbdWmwxU7lQkREhClOSQghvjjS0yk+m0qlolKFCszRaIh+rXw7cDUujkqVKr3v0CSvcOHCuDg6MvWN8imAva0tJUqU+M/jXV1d2X9wL0N//B77gtdxLHSLH38axt79u3F2dk5wHL6+vpw4dZyu37SDfKdJVfI5U6ZOYcXK5Z98K3zx4sWoDDbUYDL2uKFCRWYqUkTfk7mz51nVeuRBQUE8fPKEKQYDPv+W5QVG6vXs3LOHkJAQihYpzin1TPTEGY/7h1U81z3+qM+oRqOhfNkKnFLPRkeMsfwKm3mmu03lypVNdFZCiC/Ny8nc1SbepKdTJDM//vQT5cuW5SugiV7PfWCeWk2F0qWpUaOGpcP7JFFRURw/fpyWbdrw56RJXFGrKW8wsF+tZqPBwMghQ/DweLMP9G1ubm4MHjyYwYMHf1Y8adOmZezYsTD2s6oxCgkJwVnjhZ3BJV55CjITEfWC2NhY7O3tP7ud2NhYDh8+jF6vp3jx4h89P2lChISEAOD7RvmrUZpPnz7ll9E/41/Vn5mqwuTUNySUG5xRLaBmQC3Kli37Ue39NGokFcpXZIaqELn1jQjjDmfV86lcvkqSmUng9eteokQJk/wshRCfxxy3w63p9von93TqdDq2b9/OtGnTeP785TQx9+/f58WLFx84UnyJihYtyv6DB8lVsyYTXV0JSpeOfoMHs2HzZuNDNdZkzpw5pPX2pmLFikyaNAl3Fxdu+voy2tmZR/nzM3/+fL777jtLh/lZSpQowdO4W9zmoLFMQeGcagkF8n1lkiRl7dq1pE+bkXLlylGxYkV80qRj3jzTL4lZrFgxAJa8Ub4YSOHqSo4cOahQoQJ79u7hq6rpOeHyK2EZ9zJ8xFD+WrXSuKJSQpUsWZL9B/ZRtHoWTrpO4FmGnQweMoj1G9cliYewVq9eTTqfDP+/7t7pWLBggaXDEkIkc580ZdKtW7eoVq0at2/fJiYmhsuXL5M5c2Z69epFTEwMU6e+eTPyy/ElTJn0pQkJCSE4OJhMmTKZJFHauXMnlSpVogXQD4gFhqtUbNFoOHHyJHnz5v1ADdZBp9NRrEgJLp69RjH9N7iTibOqhVxVglizZg116tT5rPrPnDlDoYKFyGoIoKwyBDU2HGQsZ1jIrl27KF++vGlO5F9NGzfmrxUr6G4wUBjYBCwERo8eTf/+/U3aVlJ28uRJihQuQnalFmWUH1Cj5QCjOadawp49eyhTpoylQxTCIpLClEkTns7EwdXRpHVHhUfS26O9VeQln/SVvFevXhQuXJhnz57Fu1VWr149duzYYbLghPgvISEhfN2wEalTpSZXrlx4p/bh559//uwVeib+9ht+Gg3zgHxAIWClopAKmDRpkgkiTxq0Wi3bdwbRuFV9DtmNYjUtsc/1kNWrV392wgkvr5WLKg0NlZX4UAhv8lOXeaTR5GfCbwmbgP1jzJ0/nz79+zPH1ZWmwL60aZk0aRL9+vUzeVtJ2Z9/TsJNnY5AZTk+FMSb/NRjAak1ecxy3YUQIqE+aUznvn37OHjwoHFlm1cyZcrEvXv3TBKYSJoURSE6Ohp7e/uPviVp6jgCqtfkwomr+Bsm4kUeLoavYfDgwajV6s+aoPvKP/9QVa+PN0rGFiip03H54sXPjj0pSZEiBbNmzWTq1CnExMR88OGm6OhobGxsEjRk4tI/l0mrK4UGG2OZGjXp9eW4dDFhk+InVExMDFqtllGjRjFy5EgiIiJwcXGx6GfUUi5fvPLu664ry6WL+y0YmRBCjwq9icdgmro+c/qknk6DwYBer3+r/O7du7i4uLzjCGHt9Ho9o0aNIk3qtDg6OpIhXSYmTpxosXW/d+/ezdFjh6mnX0JRuuFLeaozgSJ0Y+zo8cTGxn5y3Vlz5mS/RsPrZxYHHNZqyZo9+2fHnhTZ2Nj8Z8K5adMmCn1VBAcHB1xd3OjUqRPPnj37zzqzZs/Kfe2heE+LKyjc1ewje46sJol79+7dlP73IRknBwdatWzJkydPcHV1TZYJJ0DW7Fn+ve46Y5mCwl3tfpNddyGE+BSflHRWrVqVCRMmGF+rVCpevHjB0KFDCQgIMFVsIgnp1as33w/+nvTBdajHfFLer0Dv3r0ZNmyYReI5deoUtmoHMhN/qpsc1OZp6JPP6nHv2bs3f+v1tAf+4eWyl41UKh4oCt26dfusuK3R5s2bqVmzJs/OuFCbWRSJ+paFs5ZTuVJVdDrde4/r3r0bYYa7rKQxDzlNMP+wlnbc15+iV++enx3XwYMHqVqlCvqjR5kODImLY8vixZQvXdqq54b9XN27dyPUcJu/aMJDzvCYC6yhDQ90Z+jZq4elwxMiWXs5ZZLpN2vxSUnn+PHjOXDgALlz5yY6OpqmTZsab62PHj3a1DEKC7t37x5Tp0yhkjKamkyhAC2ox1xKM5CxY8YRGhoKvHxwpNHXX+OdMiU5MmdmxIgRREVFmSWmtGnTEmuI4ilX45U/4jQ2WltSpnxzqvqEq1y5MtOnT+cvZ2dyA37Afnd3li1fTv78+T8r7oS4cuUKrVu1wsfLi8zp0zNo0CDCwsLM3u77/DB4KBlVZWlh2E5B2lKBYTTWb+TEyeOsX7/+vcf5+fmxdNlSHqXYy1T8mERurjuvYsaMGfFWbfpUPw4dSh5FYa/BQAfgO2CXXs+lq1dZsuTlc+wREREMGTKELJmykdozDU2bNuPChQv/Wa+1K1SoEIuXLOaB+y6mUoDJ5OGmy1pmzZpl8oe3hBDiY3zS0+vw8snXZcuWcfr0aV68eEHBggVp1qyZWebgS0qS49Prq1atokGDBvTlAS54G8sfc57J5GX37pcTnZctXZq0cXE01uu5ByxSqylTrhxbtm0z+bRJ0dHRZEifCftnvtTWzyYlObjMBtZpWtGwWR3mzpv72W1ERESwf/9+tFotpUuXNq7hbU5Xr16lWOHCOEZE0FynIxyYr9GQI29e9h06lOi/X3Fxcdja2lKL6RSiQ7z3/rDJTOue9Rk3btx/1hETE8P+/fvR6/WUKlUKJycnk8Tm6uTEd5GRvDl6t7BWS/4WLZg2bRrly1Xk+JG/yWdogSNenNcuJs4uhIOHD3wxsxC8T3R0NPv378dgMFC6dGkcHU37xKwQ1iYpPL0+5tkcszy93j9FG6vISz55cnitVkuzZs1o1qyZKeMRbwgLC2Py5MmsW7MBjVZDYMP6dOzYMVH/gLyaAD2MW/GSzlBuGt8f0K8fmePiOKLX8yqyrw0Gqu3aZbw9a0r29vZs3LSeWjXqMCk4N2qVBoOip3zpikz83TRP6Do5OeHv72+SuhLqp59+wjEigjM6HSn+LfPT6+l4+gy5cuSlbLlS9OzVk8KFCydKPFqtFmdHF0Ijb8YrjyWC57rHCRrDbWdnZ5ZVqVK4u3PrjdvoOuCOwUAJJydWrVrFwUP7acM+MlIagNK6AcxQCjJs2HBWrlxh8phM7datW0yYMIF9uw+Q0tOD1m1b0bhx4wSNV7W3t5fVkYRIYpR/VxEydZ3W4pMinTdvHhs3bjS+7t+/P+7u7pQsWZJbt26ZLLjkLiwsjFIlyjD0+x8JP5qWkIMp+fZ/7d13eBTV28bx7+6mEUJCC4QSQpNeRUpAVGoQ+AkiXZo0ab6gSLOhWEBQEUFB6YJKEUGlhy4QIyBFeocIBFAgoYSQ7M77B7K6UoSwhU3uz3XNpTs7c+aZybJ58sycc14aQJ3a9Vx22/pWatasSUR4IZZZ+pLI9Wclz3GYlZZBlC9bkdKlSxO9YgWd/5FwAtQHivj6Eh0d7ZK4KleuzLG4I8ybN49Pxo4hJiaGVatXEBIS4pLjuUP04sW0/UfCORHoDoRSnOxxtVgyayPVqlZj/vz5bonHZDLRqXNHNlnGcZS1ACRzicW8wDXjCt8v+JGrV6/+Ryuu0alrV6aZzSwCDCAJGAicsdlYumQ5ixYtIo9POXvCCeBPFspaOxC9zDWfSWfavXs3Fcs/zMSxM0jdVooDq5Jp27YtPXr09HRoIiJpkqak87333rPf5ouJiWHcuHGMHDmSnDlz8uKLLzo1wIxszJgxHNh3kG62LbRkDq2Zz3PGen75JZZp06a5LQ6LxcLcebO5nOUgH5siGOdblLEUxZTjPF/PmonJZCKTvz8X/rWfFbhoGC69Jezv70+zZs3o3bs31apV8/oey5kyZbJfx0TgRcxUpAu92E0TJtEzdS9FjYZ07dKdLl260LJlS8aNG2efFcwV3n33XXLmzso0nuAjCvABYWznS2ryKtu3b3XrZ/GfBg8eTKGiRWkM5MVCbix8jInqDOTYkeMcOHCAZBKw4TiH/FUuEBDw4D8GNHDAIHwu5aSP9QBPM42OttU04jO++OJzNm3a5OnwRCQNbkyD6ezFW6Qp6YyLi6No0etDbyxYsIDmzZvTvXt3hg8fzk8//eTUADOyBd/9QHFbM3JRyr4uP1UpTD3mf7fArbFUrlyZw0cP8eln43iuXzMmTZ7EwcP7KVWqFCaTiVZt2vCZxcKNUSxtwAjgTGoqrVq1cmus3qxVu3bMNJv5BVgDXMZGTV7B9NeXigUf/I1snDv/B2unT+fMvHn0+7//45EKFYiPj3dJTMHBwWTPlp2C1KIsbXiM1+jLYerwNoWpy4L537vkuP8lU6ZMhOXNTz6qUISXeYQ36cN+6vM+xW1NuXAukXOpx/iZjzH+GgArnh1ss0ymbbvWHon5bqWkpLBk6WIqWXuRyV73hkp0J4tPKN9/75lrLiJyP9L0TGdQUBB//vknBQoUYPny5bz00kvA9WeI3HnbN72w2WwsW7aM1atXExQURJs2bXjooYfusIfhkYpeSEgIPXr0uOV77773HuvXrqX0oUNUN5k4aTZzODWVQYMGsWXLFmbOnEmhQoV49tlnyZYt2y3bEBg0aBDRS5dSdcsWipnNYHOs0p1iKzv4kneAV/4awH4/8OixY7z26qtMmjzZJXGZzWaCyU89HEenMDz0WbzBbDYTaMpJPWOEw3oDg6CgIPr1e5GPP+7PVp8JZLKFEmeLoXTxsrz++utpPubZs2f56quviIuLo3z58rRo0cKtHbyccc3379/PrFmzuHTpErVq1SIqKsojc8YnJyfz3XffsWXLFnLnzk27du3IkyeP2+MQcRdXVCbTfaWzXr16dO3ala5du7J//3772Jy7du2iYMGCzowv3bty5Qp1atWlYcOGTBo9mxHDPqJ48eKMGTOGp59pwj7zd5xmp337OGI4TDRNn77/aQqdKVeuXGzaupVPP/uM/C1bUq9LF2bMmMH0qTN4vvvzzBj7I/3+7yUKRRQmJibG0+E+sLJkycLa9euZNm0a5Zo1w9fHn3W8bb9F/BvfkB0Tg8D+NVMM6GW1Mvubb1w2WH/TZ55ir3keZ/h7uKHjbOQIKz36WWz6dBMOsYzfibWvi2cH+80LePqZJnz00YesWrWKJp0ep3rLAnwx8QtiN8XYO8fdqxUrVlAwohAD+w9mxtgf6dixIyWLl+bIkSPOOiXg+mD9DZ9sxGbLOK5wzr5+M59zKfUPmjZtmua2R48eTYkSJXh/2GgmjZ5Nw4YNqVunvtvHNj116hQVy5albdu2LPjkE4YOHkyhiAhVcUXSsTQNmXThwgVee+014uLi6NmzJw0aNABg6NCh+Pn58eqrrzo90AeFs4dceOWVV/jw/Y9paVtAEeqRSjIreYWfGc2GDRt4vltP9u3dR1FbI2ymFA6wmGrVIlm5KpqAgAAnnJFrGIZBpYqVObkzidbWhWSjEBeJ51tzc1JzH+fo8cP4+Ny60G4YBuvXr2fr1q3ky5ePxo0bu2W4ogfR5MmT6dq1K6HmEuSzRbLH9C25jIscA4e/bUcDAy0WrqWkuKTyeKNT2/59+3nI1phUUzIHWUJkZHVWrFzu8FlMTU1l2bJlHDp0iBIlSlC3bl2XVdGSkpKoXasum375haJGQ8xYOGBeRKlSpVi/cZ1TZ0hLSkoif95wsidUopnxNYHk4Cx7mWVpRLmahVi1eoXTjgWwZ88ealSvybWLBkWsDUkwH+WYbT09evRk/PjP0tTm9u3bqVChApH0pzbv4IM/h1jOHPPTDHylP2+//bZTz+FOnnn6aWJ+/JElVivlgQTgOZOJ5QEBxJ04oTsi4nQPwpBJb1+YSYCTh0y6mniF17O284ohk9I8TmdG5ewPbd6w/ISfbkZDPrGvs5LCxz756fFiR1577TUmTJjA9wt+xMdi4ZkWzejWrdsDPx7q7t27KV26NG34geL8z77+JFv4gkeIjo6+5XAu58+f53+Nm7Bh40/4mPxINa6ROzQPCxf/4LZhgh4k+/bto9bjtTl1+iQWfO1TSi4Cbsz9dQWoYrEQUa8ei5YscVksiYmJjB8/nh++X4iPxULzls/QrVs3h4Tz4MGDNKjfkENHDth/fqVKlGHp8sWEh4e7JK4rV67wxRdfMH/eAqw2G02a/o8ePXo4fUreefPm0bx5c17gADn4ezrJ7cxkPu2Ji4sjf/78Tj1mXFwcY8aM4ae114dM6tipAy1btkzzHxYvv/wyE8d8Rd/UOCz/eLpqEb05medHfj953Fmh31FCQgLZs2dnjM1Gn3+sjwfymUx8MXEiXbp0cUssknEo6fS8NI/TeeHCBSZPnsyePXsAKF26NJ07d/bq4Wo84ULCecrg+MvYgi9ZyMv58+cJDg5m4MCBDBw40EMRps2NeblDKOCw/sbr283b3atXb7bF7uJZllDUiOJP9rPgzw40bvgUx+KOZKiKp2EYPN3kGax/hPA8CwmjAsf4ia+pT1OSaQvkA2b7+BDv68uX777r0niCg4MZNGgQgwYNum28zZo2J/G4ie5sJo/xMHHEMP9AG9q0epb1G9e5JK7AwED69etHv379XNL+DX9/ph3/vd74TF+4cMHpSWd4ePh/Dr5/L86fP08W8joknHD9HHZfuPW/SVe4ePEiNpvtX98OkAvIZDLd9vtBxNtZTSasTr4b5ez2XClN97w2b95MkSJFGD16NOfOnePcuXN89NFHFClShF9//dXZMaZrNarXYJflG3sFCyCe7ZxM3cajjz56hz0fbOXKlSNzpiC2M8Nh/XZmYDaZqVat2k37nD9/nm/nzqWm9Q0eogEmTOSkOE1s0zh99pTD2LAZwcaNG9mzbxcNrePJQ0VMmCjIYzTkC1KADRERTAsN5ZFmzYiJjeXhhx/2aLybNm3it13baWAdR14qYcJEAapTz/oRG2J+Yu/evf/dyAOsRo0aAOxgpsP6HcwgR7bQ/+j892B49NFHOZm6ldP8Zl9nJYVdlm/c+n2TN29eCubPzwzgn7fa5gOX/5pBSUTSnzRVOl988UWeeuopJk6caH8uLzU1la5du9KvXz/WrXNNRSM9GvrWG9SuVZtp5pqUs3XiMqfZZBlLqYfKePVQQ1myZGHwK4N4/fXXucQpClOP34lhq2kS3Z9//pa3Ws+ePUuqNZXcOM5vnoPiWEy+nDx50l3hPxBunG8uyjqsz8v1xwymzJhBzZo17ettNht79+7FYrFQrFgxt/cqvxHvv39+N16fPHmSEiVKuDWmW0lKSmL//v1kz579nm75lyxZkjat2zJndk/ijW3k4WH2s5A9fMcnb33iFVX41q1bM3LEB8w4VJtHrC+QmVxsN0/lD9Nu3ngzbc+JpoXZbGbYe+/RoUMHGptMPGMY7AY+NZtpWL8+VatWdVssIu6k3utpsHnzZgYNGuTQEcTHx4eBAweyefNmpwWXETz66KMsj15OeFVfFtGTn/3fp2WHJqxZt+qB7ih0N1599VU+/fRTLhb4me95jhO5FvLOu+8wbtzYW25foEABQoKzsZcFDusPsgSrkULFihXdEPWDo3z58gDsw7E3714W4OvjR8mSJe3rlixZwkNFilO6dGlKlChByeKlWbNmjTvDpVy5cvb4/mkvC/Cx+FC6dGm3xvNvhmHwwQcfkCcsHxUqVKBAgQLUqV3vnmZRmzZ9Kq++PoRD2WbzPZ1JLbKLqVOn8sILL7gwcufJlCkTa39aTfP2/+Nn/xEsoicR1fxZsXIF1atXd2ss7du3Z/bs2cSVKEEXYEpwMC/078+3333n9ZM8iNyODbNLFm+Rpo5EuXPnZsaMGdSvX99h/bJly+jQoQOnT592WoAPGlc+iJySkoLFYvHIeHlpdeXKFWw2G0FBQXfc7tq1a/j6+v7nL5N3332X1157jSq8QAmacprt/GR5m4erlWXdT2sy3C+jFs1b8sP8RTxqe4VwqnOIaGJMo+jZuydjx17vfLZlyxYiq0USYa1FNaM/NlLZYB7Bad/NbNu+leLFi7st3rZtnmXenPnUsA2hAI9yhFVsML1P1+5dmDBh/C33uXr1KteuXXP5A/Djx4+nV69eVKYXZWnLeY6w1vI62Qr4smvPb/dUqTQMg5SUFPz8/FwYsWvZbDasViu+vr6eDuWuvx9E7seD0JHotYRZLulI9E5Ia6/oSJSm7KZVq1Z06dLl+l+pcXHExcUxa9YsunbtSps2bZwdY4bh6+vrNQnn7t27aVD/STJnzkyWLFmo9XhttmzZctvt/fz8/vMXSkpKCleuXCHAPxOb+IwvqUO0aQBNWj7Jjwu/z5C/kKZ/OY1OXduzwe8dplObrZnG0n/AS3z00Yf2bUaP/pgQImhjLKQo9SlGQ9rZluFnDWHs2FtXlV1lytTJdO3RmRj/4UynNpsDRtPvpf+zJ8j/dOrUKVq3bkOWoCyEhIRQodzDLF261CVxGYbB8HffpyzP0ohPKUANytOOVtYfOHTkwD3PZW8ymbw64YTrt7gfhIQT7u77QSQ9MDC5ZPEWaXqm84MPPsBkMtGhQwdSU1OB6wlTz549GTFixH/sLd7u999/59Eaj+FzMSeN+AwzPmzaMI4nHqvFlq2bKVasWJraff75Hnw5fQZVbC8QRkX28SO7jTkULVqErFmzOvckvERgYCCffz6BUaNGcvr0afLly0dgoONfydt+3UHB1HpY+DuB8CUTEam12b71t3836VIBAQF8+uk4RowYTnx8PHnz5iVz5sw3bXflyhUer1mL00cTqGUdThC52bZrCo0aNiJ6RTS1a9d2alyXLl0i7sQxKvOew/rclCWbbzi//fYbrVs/2FNjioh4uzSV1fz8/BgzZgznz59n27ZtbNu2jXPnzjF69GiveJhe7s+4ceNIvmjlOetGKtOTSnTjOesGLNey8OGHH/53A7dw9OhRpk2bSn3bR0TxIeVpR0tm8yiD+WDUhyQkJDj5LLxLcHAwDz300E0JJ0BEwXBOWxxHjTAwOO3zKwUinDuEz93KkiULV69epWPHToQEZyNvWH5efvll+8/xm2++4eCh/bSzrqQGL1Oe9rS3rSCfuTJvv/WO0+MJDAwka3A24tnqsP4ip0hIPemyMURFRP7pRkciZy/eIk1JZ0JCAufOnSMwMJCyZctStmxZAgMDOXfuHImJic6OUR4wGzf8TCFrfQL5eypBf4Iomvo/Nvz0c5ra/OWXXzAMg7I4Pp5RhjYkXb3Czp07b7On9OzVgzhrLMsZyBX+5BJnWERvzqTupUfPHh6JaefOnURWrc7aBdt4+OKLFDjdnE8//oJaj9chOTmZ2NhY8vpUIBel7PuYsVDS2pKYn50/TarFYuH5nt35xfwJW5lKKsmcZQ/fmdsQlDlIVU4RETdIU9LZunVrZs2addP6OXPm6Ms7AwjNlZMLlkM3rb9gPkRorpxpajNnzuv7ncOx3fN/vb7xvrNs3bqVdu3aU7pkORrUf9Kr53tu3LgxI0aMYJPPx4wkJx+Qmx2+U/j0008dhlRyp7feGkama2F0s27lCd7gST6mvXUVW7dvYfbs2eTIkYME4kgl2WG/8xwiZ45QF8X0Fs80b8b3dOYdAviUUlzKtpeFi3/MsI9viIh7GS6ocnrTM51pSjpjY2OpVavWTeufeOIJYmNj7zsoebC1adOaE9Yt/MQIUknGSiq/8CmHbCto3aZlmtp8/PHHiQgvxFJLHy5wfQibM+xmpWUQVStHOrUH9vLly6lapRrLZseQeW9N9q66SNOmTRk2bJjTjuFugwYNIu73OL788ktmzpzJyVMn6NWrl8fiWbF8JWWs7fDn71EN8vEI+S2PsHLlSjp06MBl658soS/JXMTAYA8L2GaeTOeunVwSk7+/P7Nmf8OuXbuYPHkyCxYsIO7EMY8l5iIiGU2aOhIlJyfbOxD9U0pKCklJSfcdlDzYfv/9d0yYWMkQ1jMcE2aucgEzPpw6dSpNbVosFubNn0tU/Sf55Hxhgn3ycCHlBAXyFGTm1186LXbDMHihd1/CrY/S1liCD35ghZW8xrC3htG1a1fy5s3rtOO5U+7cuWnfvr2nwwAgc+bMXEn8w2GdDRtJpj/JnDkzJUuWZMKECfTq2Yvf+BI/c2Yupf5Bg3pP8sorr7g0tlKlSlGqVKn/3lBExMk0OHwaVKlShS+++OKm9RMmTKBSpUr3HZQ82Bb+uIiHaEgvdlGDQUTSn+fZShla88OChWlut1KlShw9dpiJkybywuDOfP311+w/uJeiRYs6LfZDhw6x/+BeqhkvXU84/1KDgVhtVpYsWeK0Y2Vkz7Zvw3bLVH7n+p0PGzZi+JA/U4/Qtm1bALp3786Ro0d4b+Tb9H+1N2vWrGHxkkVePymCiMjtWAErJicv3iNNlc533nmHunXrsn37durUqQPAypUr2bRpE8uXL3dqgPLgsVgs2Eyp5DJKOXQEsZKCn8VyX20HBQXRuXPnu9p2x44dfPPNN5w7dw6bzYaPjw9FixalQ4cOhIbe+rnAG+Og2nCs1N94bbnP+OW6V199lVUr1zBpSzXy+VQkiXOcSz3GgAEDHObVDg8Pp3///vfU9sGDB5k5cyZ//vkn1apVo3nz5ho1Q0TEC6Qp6axRowYxMTGMGjWKOXPmkClTJsqVK8fkyZN56KGHnB2jPGCebtaU3it6c4yfiOD683An+ZX95gUMa/GmW2J45513eP311wmy5MTHGsQFjuJPFqymZN4aOowlyxZTo0aNm/YrVKgQZUuXZ+Oe9ylsq4sfmTEwWMOb+Pr40bBhQ7fEn94FBwezYeNPzJ07l5UrVxIYGEibNm1u+TO5F1OmTKFbt24EmILJYs7DuHHjeO+dEaxZt+q2f2iIiDwoXDGYuzd1JErTNJgZmSen0XpQJCcnE1WvAT+tX0ch6mDGl8Msp3z5Cqz9afV/Tol5vzZt2kSVKlV4jNd5nNex4MthVvE1jXmEHsSbN5OS+yhHjx/Gx+fmv6s2bNhA/XpRWFIyE5FamzM+2zmTuocxY8bwf//3fy6NXdIuLi6OQgULUd72HE/yCb5k4hRb+coSRbO2TzL9y+meDtHrpKamsmTJEvbu3UvBggV56qmnVDWWdOtBmAbzpYR5+AffPGHG/UhOvMxHIc94RV6Spkrn8ePH7/h+gQIF0hSMeAd/f3+WRS9l2rRpfDdvPjZbCi80+YjOnTvfcvYZZ5s5cyZZffLzROpQzFy/HV6Y2lSgE3uYR0vbt0w8VYV169bdcmabGjVqsH3HNsaOHcvWX7dTLrwiz/eYwGOPPeby2CXtZs+ejQV/ovgIXzIBkIeKVLW+yKxZbzFp8qQHZlpHb3D8+HHq123AvgN7yGQJJsmaSL484SyLXkLp0qU9HZ5IupTROxKlKeksWLDgHefJtVq96bFWSQt/f3+ef/55nn/+ebcfOyEhgSAjzJ5w3hBMPpJJJAv5AO44UUHRokUZM2aMS+MU50pISCDAHIyfzbGSnoW8XEtJJjk5WUnnPXi2bXvOHL5CN34hn7UyZ9jNd2da83STZ9i7f7f9+WcREWdJ07fK1q1b+fXXX+1LbGwsEyZMoFixYsydO9fZMYo4ePzxxzlh3UI8O+zrUrjKb3xNBI+xjan4+PhSrVo1D0YpzvbYY4+RmBrPQZbZ19mwsd00nQrlHnb5Yx3pyYEDB1i/YR11raPIR2UAclGKJ62fceDQPtavX+/hCEXSJ6thcsniLdJU6SxfvvxN6x555BHy5s3LqFGjaNas2X0HJnI7rVu35sNRo5mxvxYPW3sQSChbmcw5DpKVgqziNfr37U9YWNg9tx0XF8fJkycpVqwY2bJlc0H0NzMMg927d5OUlES5cuXw8/P7750yoDp16vDE47WZ+9MzPGx7nmwUZrd5FnFGDD8O/9HT4XmV06dPA5CTkg7rQ/96HR8f7/aYRCT9c+r9k+LFi7Np0yZnNilyk0yZMjFm7Gj8g02s532W8RJ/sAcr10iN2MfHH3/MyJEj76nNM2fO0PjJJylQoADVqlUjT+7c9Ovbl5SUFBedxXWxsbGULlmWMmXKULlyZfLlCWfq1KkuPaa3MpvNLFz0A3379+ZAtpksM/clbxVYsnSJRh24R6VKlcLP1589fOew/sZrjbcs4hrOngLTFc+IulKaKp3/flbOMAxOnTrFm2++qSGTxGkMw+Ds2bNkypSJLFmy2NefPXuWFs+0JPBSQRownUzkYAufs41pfPDRyHuutBuGwVMNG3J02zamAeWBhSkpvDV2LL5+fowaNcqp53XDyZMnqV83iuArxXmWxQSQlV/OfUrnzp3JlSsXjRo1cslxvVnmzJkZOXIkI0eOxDCMOz5bLreXPXt2+rzQh49HD+OqcYEi1COOGGLMo2jTsi1FihTxdIgi6VJGHzIpTUln1qxZb/qyNwyD8PBwZs2a5ZTAJGP78ccfGfjyYHuHhsaN/sfYcZ9QoEABpkyZwqWLV+hqW0pmro/NmJ+qJJrjeH/4vT/esX79emK3bGE5UO+vdRWAZMNg9LhxDB061CXPC06cOJFrSVaetS0lE9dv5eenGomWo4x8/wMlnf9BCef9GTnyfYKCMjPm47H8nDiawIDM9Hr+eUaMGOHp0EQknUpT0rl69WqH12azmdDQUIoWLXrLcRFF7kV0dDRNmjShMPVozlAu286wbvFIHnv0CXbu3sGuXbvIa3rYnnACmDBRxBbFz3veuefj7dq1CxNQ91/rGwDvXL3KsWPHXDKEzO7du8lrVLEnnHD9PApbo/ht5zinH0/knywWC2+99RavvPIKZ86cIWfOnGTKlMnTYYmkazbM2Jz7ZKPT23OlNGWIjz/+uLPjEC83d+5chr/7Pjt3/0a+PPnp/UJPXnzxxTRNK/n2sHcJN1XjWdsSzH/9YypqbcCnvxfnq6++IiIigjP8wDUu48ff44KeNP1CgQIR93y8iIgIDOBX4J9PssUCvj4+5MmT557bvNvjLjavIsV2FV/+nm/8pOkXIgre+3mIpIW/vz/h4eGeDkNEMoC7To9/+OGHu15c4d1336V69eoEBgaSNWvWW25z/PhxGjVqRGBgILly5WLAgAGkpjrOsb1mzRoefvhh/P39KVq0KNOmTXNJvBnJxIkTadmyJRd35KBOyihCjtdk0MBB9OzZK03tbd68iRK2Z+wJJ0AOipLXUpFNmzbRpUsXrOarfGtqzVn2coU/Wce77DK+5YW+ve/5ePXr16dowYK0t1hYD1wCvgHeslho06YN2bNnT9N5/JeuXbuSTALfmdryJwe4zFlW8yb7jIVpOg8REXmwGYYJm5MXIz0OmdS0adO72s5kMrlkcPhr167RokULIiMjmTx58k3vW61WGjVqRFhYGBs3buTUqVN06NABX19f3nvvPQCOHDlCo0aN6NGjB1999RUrV66ka9eu5MmTh6ioKKfHnBFcu3aNV4e8Tjna87QxHdNfDzTnNSoxaVJfBg0aeM+dEkJz5uKP3/c5rEslmfMcJVeu+hQsWJDv5s+jfbuOfHrh+hAvFrOFAf0H0L1793s+B4vFwsKlS2nauDE1Dx60rw/y82fnb3v47LPP6N69u9MfHSlWrBiz58ymc6cujE0sBoCPxYdXB79Khw4dbrtfSkoKEyZMYPrUGVy4kMATtR9j0KCB6sQnIiIPNK+be33atGn069ePCxcuOKxfsmQJjRs35uTJk+TOnRuACRMmMGjQIM6ePYufnx+DBg1i0aJF7Ny5075f69atuXDhAkuXLr2r42vudUe//fYb5cqVoxNrKcjf00he4wrvkZkpU6bw3HPP3VOb77zzDm++MYymxnRK05JkLrKc/mw3T2P37t0UL14cgKSkJKKjo7l8+TKPPfYY+fLlu69zsdlsTJkyhT69X8DfGkJJaysSTcfZxw80b96CWbO/cUnnlStXrhAdHU1SUhJPPPHEHccXNQyDZk8/ww8//EAJmhBk5GOfzzyMgMtsiFlPmTJlnB6fiEh68CDMvd71/CL8nDz3+rXEy0zK1sgr8pJ7Kt1cvXqVFStW0LhxYwCGDBlCcnLy3435+DBs2DACAgJu14TLxMTEULZsWXvCCRAVFUXPnj3ZtWsXFStWJCYmhrp1HbuLREVF0a9fv9u2m5yc7HCOd5paMSO6MZTRJRwHk77x+p9DHd2tgQMH8uuWrcxb0JbFlh5csyVhtsCkLybZE064Pl7nU089dR/RO4qNjWXoG28RfK0gXdmEP0FgwA6+Ys7cdvR5oTc1a9Z02vFuCAwMpEmTJne17YoVK1jw/Xxa8i2leAaA2qnvMDmpMq++8hrf/7DA6fGJiIg4wz0lndOmTWPRokX2pHPcuHGULl3a3uNx7969hIWF8dJLLzk/0v8QHx/vkHAC9tc3Zte43TaJiYkkJSXdsufm8OHDeeutt1wUtfcrWLAg1apWZ93mNwm3RhJCOMlcZJmpHyFBWdM0aLefnx/zvvuWX375hdWrVxMUFETz5s3TNMPQ3Ro/fjy9el1/BvVJPrmecP6lDG1Y6TOAxYsXuyTpvBdLliwhu08EJVP/HhYqgGAqWLuxZMkrGrtSROQBZrjgGUxveqbznvrZf/XVVzc9M/f111+zevVqVq9ezahRo+5p7vXBgwdjMpnuuOzdu/deQnS6IUOGkJCQYF/i4uI8Gs+DaOq0yZiyX+ATU2Em+jzMaEtejvpG89U3MwkMDExTmyaTiapVqzJ48GD69Onj0oTzjz/+oF/fF6nE85jxJZWrDu8bWEnlGr6+vi6L4W75+Phg5RoGNof1qSRhsWi4MhGRB5lmJLoHBw8epGzZsvbXAQEBmM1/561VqlShd++773Xbv39/OnXqdMdtChcufFdthYWF8csvvzisuzG/8I2EJSwszL7un9sEBwffdnw6f39//P397yqGjKpEiRLsO7CHGTNm8NtvvxEe3oxOnTqRP39+T4d2VxYtWsS1lGRq8w5JnCOWsZSlLcHkw8AghtFcTv3zngedd4VnnnmGUaNG8QvjqEZfAC5wnF99JtCiRXNVOUVE5IF1T0nnhQsXHJ5vPHv2rMP7NpvN4f3/EhoaSmho6H9veBciIyN59913OXPmDLly5QKuDzIeHBxMqVKl7NssXrzYYb/o6GgiIyOdEkNGFhISQp8+fTwdRprcGG3BB3/qMZIpPMonPERh6nCew5xlNwMHDqRChQoui+H8+fPMnTuX06dPU7lyZerXr+/wB90NVatW5YUX/o+xY/uxwzKNzNZ8HDWvJCx3bt59712XxSciIvfPapiwOvl2uLPbc6V7Sjrz58/Pzp07HTpz/NOOHTtcVt06fvw4586d4/jx41itVrZt2wZA0aJFCQoKon79+pQqVYr27dszcuRI4uPjee211+jdu7e9UtmjRw/GjRvHwIED6dy5M6tWrWLOnDksWrTIJTGLd6hfvz4Ws4WNtg+oxVv0YBub+IxfGIs5czKL5y6mQYMGLjv+smXLeKZZc5KSkgi0ZONS6h9UrlSVpcsX33KM0DFjPiYqqj4zZlwfMum5x9+ge/fu5MiRw2UxioiI3K97GjKpb9++rFixgi1bttzUQz0pKYlHHnmEunXrMmbMGKcH2qlTJ6ZPn37T+tWrV/PEE08AcOzYMXr27MmaNWvInDkzHTt2ZMSIEQ7jK65Zs4YXX3yR3bt3kz9/fl5//fX/vMX/TxoyKX0aOnQow4YNo5D5cXLZKnDYZynnjUN8/8P399QZ6sKFCyxfvhyr1UrdunX/s5KfkJBA/nzh5LnyKE8ZUwgiN0dZy7eWZ3imbWOmf3nzZ15ERO7dgzBkUrs/l7lkyKSZOaK8Ii+5p6Tz9OnTVKhQAT8/P/r06UOxYtcHtN63bx/jxo0jNTWVrVu33tRDPD1R0pk+GYbBvHnzGP/Z58Qd+52Kj5Tn5Zf7U7ly5btuY9KkSfR94QWuXL3eEcnf15d33nuPl19++bb7TJ48mW7duvOS8TtZ+Hu6zQ2MYo3Pa5y/cI7MmZ37BSUikhEp6fS8e7q9njt3bjZu3EjPnj0ZPHgwN/JVk8lEvXr1+Oyzz9J1winpl8lkonnz5jRv3jxN+8fExNCtWze6AG9x/R/W+ykpDBgwgFKlSt22Wnr27FkCzFkIsjr2zs/OQ6SkXiMxMVFJpxvExcVx+PBhihQp4jUd4ETE+2jIpHtUqFAhli5dytmzZ/n555/5+eefOXv2LEuXLr3rnuYi6c2ECRMo5uPDF0A+IDfwIVDFYuGzceNuu1+VKlVIsiZwiGiH9buYQ/68BfRHnIslJCTwTLPmRERE8MQTT1CgQAFatmilSSBERFwgzQP7Zc+enSpVqjgzFhGvdezwYR5OTXX4K84EVLZaWXv48G33q1WrFjWq12RebEsirQPISQl2M5edzGbiWxNv2YNdHNlsNn7//XcCAwPJmTPnPe3bvl1HVixZQ2PjCyKoyVFjLQvnD+A5a2fmffetiyIWkYzKFeNqetM4nfqNJuIEZcqXZ62PD0n/WJcKRPv4UOYOQy2ZTCYWLf6Rtp1asMHvHebQnMT8sUyePJmuXbu6OmyvN2/ePB4qUpyIiAhCQ0OJqteAQ4cO3dW+Bw4c4MeF3xNl/YRKdCUnxXmE7tSzjua7+fM4cuSIi6MXkYzGZphcsngLJZ3pmGEY3EM/MbkPffr04bzZTEOzmWhgDdDUZOKQzcaL/zEtbEhICJMmTeRCwnnOnDnDkWOH6Ny5szvC9mrLli2jRYsW+BwrTmu+5ykmsWX1AR6vWeuubo/v378fgMLUcVh/4/W+ffucH7SISAampDMdOnr0KG3atCXAPxN+vn40eaopu3bt8nRY6VqJEiVYtGQJJwsWpD5QC9iZNy/zvvvurh9DCQgIIDQ0VLfU79K77wwn3BRJa+MHSvAUD9OFdtaVxMef4ssvv/zP/QsVKgRAHBsd1t94rWfURcTZbH8NDu/MxZsqnZqsOZ05e/Ys1as9StKfJmqmDsWCHxsXf06NNY+yZetmihQp4ukQ063atWuz58ABdu/ejdVqpUyZMlgsFk+HlW79umUL1W1vYP7H387ZKEhey8Ns2bLlP/cvVaoUTzxem6XrX8Bs9b3+TCdrWe7Tj7qP17cPCSciIs6hkko6M378eP48e57OqbHUZAjV6U9X6yaMpAA+/PBDT4eX7pnNZsqUKUP58uWVcLpY7txhnMGxgp/CVc5xiLCwsNvs5Wj2nG+oEFmC2TzNSHIyh2eoVKMMX38z0xUhyy0cPnyYrl27EZG/ECWLlebtt9/m8uXLng5LxCUMwMDk5MV7qNKZzqxb+xOFbfUJJq99XQAhFEt9mtUr13kwMhHner5nN4YMfoUI4zHK056rJLCMl7hqu8Bzzz13V23kypWLdT+tYfv27Rw4cIBixYpRrlw51wYudgcPHqRK5WrYLvlTMrUVVznP22++x9Ily1m9ZiV+fn6eDlFEnEhJZzqTNVtW9lmOgtVx/UXT72TPltUTIYm4xEsvvcSO7b/x1dddWGLuTartGn5+fkybPO2eb42XL1+e8uXLuyhSuZ23h72NcSmQ51O3EUh2ACraujA1pibz5s2jTZs2Ho5QxLlc0dvcm57p1O31dKZ9+3b8bt1MLOOwYcXA4Ddmsd9YSIdO7TwdnojT+Pj4MPOrGWzfvp2RHw7ni4mfc+Lk77Rrp8+5t1i8aCllU9vbE06ACB4ln6USS5Ys8WBkIuIKqnSmM0899RS9e/fh009fYIPPu1jw5XxqHC2at9S4j5IulStXTrfEvZS/nz/XuOSwzsAgxXQJf39/D0Ul4jpWw4TZyZVJqyqd4ikmk4lx48YSGxtLz/4d6dy3JatXr2b2nFn4+OhvDBF5cLRq24IdlmmcZidwPeH8lcmcSd1HixYtPBydiPPZDNcs3kJZSDpVpUoVTVMqt5SamsrChQvZvHkzuXPnpnXr1oSGht7Vvps3b2bRokVYLBaefvppSpcu7eJoJT177bXXWLYkms/3ViCCmlw1n+OUdQddunSlXr16ng5PRJzMZGjKmnuSmJhISEgICQkJBAcHezockXty9uxZ6tauz46d28jqm49L1rP4+vkw99s5NGrU6Lb72Ww2unXrzpQpk8lsyY4NK0nWBAYPHsx7772HyeQ9t3fkwXL58mWmT5/OihUryJw5M61ataJRo0b6TInTefL3941jNz65Bt/gIKe2nZJ4iYV5n/CKvESVTpEM5IUX/o8je07SlZ/Jn1KVK/zJD8mdadWyNb+fiCNr1qz2bS9fvsyiRYtITEzk7NmzTJkymf/xBRWtnbFhJYaPGDFiCDVr1qRhw4aeOynxapkzZ6ZXr1706tXL06GIiIsp6RTJIC5evMi8b7+ljnUU+akKQCA5aGRM4KOk/MybN48uXboAsHDhQp5t047ESwkAmLBQlCgq0Q0AMxYeZRB7LHOYPm26kk4RkbugIZNEJENITEwk1ZpKNhznFA8kF76mAGJiYvjzzz/5/fffaf5MC/Jcfoy+HOFVkggijGw4TqFqwkSItTBnz/zhztMQEREvpaRTJIPIkycP4fki+I2vMf6aOC2eHYwjgmu2K0yePJl8efLQtm1bSLXwtDGTbBTElwAe4kn2MJ/kfwxvc5mzHLEsp/qjkZ46JRERr2LD5JLFWyjpFMkgzGYzw955k13MZg7PsIVJTKMa+TnBCuAAMDglhfU//YQ/IQTw9wPp1XmZq5xnEtXYzOfEMpapluoEhWSid+/eHjsnERHxHko6RTKQTp06MWPGDFKL7OZHupFMEj8CdYCiwJtAJ+CK7STnOGLfLwfFyENFrmb+nYX0YJm5H1WjSrB+4zry5MnjiVMREfE6VsPkksVbKOkUcTObzUZSUhKeGq2sXbt27Duwh759+1LY15eIf73/BJAKfG2uzw6+5ghrmE8H4ohh8tSJXLlyhcuXL7Nw0Y8UL17c/ScgIuKlDMPkksVbKOkUcZPk5GSGDBlCzuyhBAYGUvyhknz55ZceicVkMlGqVCmOpqYS96/31gNhOXJQvFoevuNZplOL+JwrmDhxIi1atCBTpkwEBAR4ImwREfFiGjJJxE3atG7Lwh8W8YitN7kpx75DP9CxY0euXLlCjx493B5P69ateW3IEJ5OSOBDq5WCwExgEvD+oEEMGDCAuLg4EhMTKVasGL6+vm6PUUQkPTFsJmw251YmDSe350qqdIq4wbZt25i/4Dv+Z5tMFB9SgY60Yh7l6cibbwwjJSXF7TEFBwezbMUKLkZE8ARQEHjLx4cXX3yR/v37AxAeHk7p0qWVcIqIyH1TpVPEDTZs2IDF5ENpo5XD+nK0Y/vZ6Rw5coRixYq5Pa6KFSuy58ABYmNjOXfuHJUrVyZXrlxuj0NEJCOwGiZMTn4G05s6EinpFHGD7NmzYzVSucgJsv6j684FjmIymRymn3Q3s9lMZKTG2hQREdfS7XURN3jqqacIyZKVRaaeXOb6DD6n+Y2fLMNoEPWkqosiIhnAjWkwnb14CyWdIm6QOXNm5nw7mxMB6xhtzsc43yKMpxw5IzLx+RcTPB2eiIiIy+n2uoib1K9fn6PHjvD1119z4sQJKlasSLNmzfD39/d0aCIi4gYGzh9X0/CiaTCVdIq4UWhoKH379vV0GCIi4gGuuB2u2+siIiIiIv+gSqeIiIiIG9iM64uz2/QWqnSKiIiIiMup0ikiIiLiBlabCZOTp620ahpMEREREZG/qdIpIiIi4gaG4YIhk9R7XURERETkb6p0ioiIiLhBRh+nU0mniIiIiBvYbCand/yxqSORiIiIiMjfVOkUERERcQObYcKUgW+vq9IpIiIiIi6nSqeIiIiIGxi264uz2/QWqnSKiIiIiMup0ikiIiLiBjYDFzzT6dTmXEqVThERERFxOVU6RURERNzAZjNh0jidIiIiIiKuo0qniIiIiBtYDRM4+ZlOqxeN06mkU0RERMQNDJsJw8m3w53dnivp9rqIiIiIuJwqnSIiIiJuYANMTh7iyIvGhlelU0RERERcT5VOERERETew2UygIZNERERERFxHlU4RERERN1ClU0RERETExZR0imRgly9fZsiQIeQOzYO/XwC1Hq/N2rVrPR2WiEi6ZBgmlyzeQrfXRTIom81G44b/Y+OGWCpauxJCBLs2fEOd2nVYtnwZderU8XSIIiLpis2G08c4snnRmEleUek8evQoXbp0oVChQmTKlIkiRYowdOhQrl275rDdjh07qFmzJgEBAYSHhzNy5Mib2po7dy4lSpQgICCAsmXLsnjxYnedhsgDZfny5axZt5qW1u94kjFU5yU6W2PIR1VeHfK6p8MTEZF0xiuSzr1792Kz2fj888/ZtWsXo0ePZsKECbzyyiv2bRITE6lfvz4RERFs2bKFUaNG8eabb/LFF1/Yt9m4cSNt2rShS5cubN26laZNm9K0aVN27tzpidMS8ag1a9aQ1Sc/RahvX2fBh/K2TsRuiiE5OdmD0YmIpD82m8kli7fwitvrDRo0oEGDBvbXhQsXZt++fYwfP54PPvgAgK+++opr164xZcoU/Pz8KF26NNu2beOjjz6ie/fuAIwZM4YGDRowYMAAAN5++22io6MZN24cEyZMcP+JiXhQlixZuGokkEISfgTa118ingD/TPj4eMXXg4iIeAmvqHTeSkJCAtmzZ7e/jomJ4bHHHsPPz8++Lioqin379nH+/Hn7NnXr1nVoJyoqipiYmNseJzk5mcTERIdFJD1o3bo114zLrGAQqVx/VCWe7WyyfELrNq2xWCwejlBEJH2x2kwuWbyFVyadBw8eZOzYsTz//PP2dfHx8eTOndthuxuv4+Pj77jNjfdvZfjw4YSEhNiX8PBwZ52GiEcVKVKETz75hE2mT/nYJx+f+5RjAhUo8FAYI0e+7+nwREQk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",
      "text/plain": [
       "<Figure size 800x600 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_decision_boundary(X_test_scaled_df, y_pred_2, \"BMI\", \"Glucose\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "a4eb139e-cef6-427d-ac43-5b7e0a723152",
   "metadata": {},
   "outputs": [],
   "source": [
    "def round_values(data, precision=3):\n",
    "    if isinstance(data, list):\n",
    "        return [round_values(item, precision) for item in data]\n",
    "    elif isinstance(data, dict):\n",
    "        return {key: round_values(value, precision) for key, value in data.items()}\n",
    "    elif isinstance(data, (int, float)):\n",
    "        return round(data, precision)\n",
    "    return data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "de5711bb-9cf1-4e1e-a792-a1ff44901df2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "65efe92b-b1b9-4376-8892-e75c68422888",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "54f1ff23-e1a9-4c16-9b2e-8a61d024067c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c3249b8a-a969-4b3c-a2a4-77e0e6f99f42",
   "metadata": {},
   "outputs": [],
   "source": [
    "    "
   ]
  },
  {
   "cell_type": "markdown",
   "id": "43a1d4fa-fb39-46e7-8c14-645e213aa7f3",
   "metadata": {},
   "source": [
    "#### Sample Data Creation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "id": "a4c67e91-d622-4a73-bedd-f3535c46c5a1",
   "metadata": {},
   "outputs": [],
   "source": [
    "def write_data(data, file_name, varname):\n",
    "    datastr = f\"\\n{varname} = {data}\"\n",
    "    \n",
    "    # Write this string to the file\n",
    "    with open(file_name, 'a') as file:\n",
    "        file.write(datastr)\n",
    "\n",
    "# This stays constant for this iPython file\n",
    "FILE_NAME = \"./../samples/diabetes/level_3.py\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "id": "166d67f7-55ae-4e56-8ee5-a45649a95bf0",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Number of mismatched samples: 36\n"
     ]
    }
   ],
   "source": [
    "print(f\"Number of mismatched samples: {np.sum(y_pred_1 != y_pred_2)}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "id": "d2ba908c-9ccc-43ed-aebc-34c5e3eeac92",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Number of samples in verb_data: 154\n"
     ]
    }
   ],
   "source": [
    "verb_data = []\n",
    "for idx in range(len(X_test_scaled_df)):\n",
    "    data_point = {\n",
    "        \"input\": round_values(X_test_scaled_df.iloc[idx].to_list()),\n",
    "        \"output\": {\n",
    "            \"model1\": int(y_pred_1[idx]),\n",
    "            \"model2\": int(y_pred_2[idx])\n",
    "        }\n",
    "    }\n",
    "    verb_data.append(data_point)\n",
    "\n",
    "print(f\"Number of samples in verb_data: {len(verb_data)}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "97da7c78-ebf8-4ce7-913f-88dc065fcf6e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "id": "8b0374cf-250d-4b9c-ad17-b30db0b6d8bf",
   "metadata": {},
   "outputs": [],
   "source": [
    "varname = \"verb_data\"\n",
    "data = verb_data\n",
    "write_data(data, FILE_NAME, varname)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "53874348-fd8d-402c-86a5-8c1372bc8706",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d415f065-bda1-47a2-963a-d610530a5332",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f094023f-354c-465c-af91-64085494585d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "id": "32b9d1e8-7c1a-4839-8b3f-05eea5e03bcc",
   "metadata": {},
   "outputs": [],
   "source": [
    "y_gen_pred_1 = model1.predict(X_test_gen_scaled_df)\n",
    "y_gen_pred_2 = model2.predict(X_test_gen_scaled_df)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "id": "5b11b0a3-deea-4f17-99f7-c992d2b470df",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Number of samples in gen_data: 154\n"
     ]
    }
   ],
   "source": [
    "gen_data = []\n",
    "for idx in range(len(X_test_gen_scaled_df)):\n",
    "    data_point = {\n",
    "        \"input\": round_values(X_test_gen_scaled_df.iloc[idx].to_list()),\n",
    "        \"output\": {\n",
    "            \"model1\": int(y_gen_pred_1[idx]),\n",
    "            \"model2\": int(y_gen_pred_2[idx])\n",
    "        }\n",
    "    }\n",
    "    gen_data.append(data_point)\n",
    "\n",
    "print(f\"Number of samples in gen_data: {len(gen_data)}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "id": "64268a33-c206-4002-b456-f9ed0d5651dc",
   "metadata": {},
   "outputs": [],
   "source": [
    "varname = \"gen_data\"\n",
    "data = gen_data\n",
    "write_data(data, FILE_NAME, varname)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f132e020-5ee2-4c63-94a1-ab02b41d9a52",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "id": "569c615f-6aaa-42a0-bd78-57f67a13c8fa",
   "metadata": {},
   "outputs": [],
   "source": [
    "def prune_data(gen_data):\n",
    "    return [{\"input\": inst[\"input\"], \"output\": {\"model1\": inst[\"output\"][\"model1\"]}} for inst in gen_data]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "id": "ca15745c-cc52-4855-a227-06aef729d537",
   "metadata": {},
   "outputs": [],
   "source": [
    "varname = \"gen_data_pruned\"\n",
    "data = prune_data(gen_data)\n",
    "write_data(data, FILE_NAME, varname)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "39486abe-a340-480f-a7e4-8449c05d372d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0acfe6a3-a651-4bcf-91a6-1cf038ff43a6",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f985bf05-ccf6-4ba9-a6ee-c4a5eb7dc8f0",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bfe59780-2e74-4418-9a06-cff330c76e6c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "59b12448-1adf-43a5-bdad-c3b85be3fcc1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "id": "3e988969-a87e-42f7-8a5e-d161adb0d32a",
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_accuracy(a, b):\n",
    "    correct = 0\n",
    "    total = 93\n",
    "    \n",
    "    for i in range(len(b)):\n",
    "        if(a[i]['input'] == b[i]['input']):\n",
    "            if(a[i]['output']['model2'] == b[i]['output']['model2']):\n",
    "                correct += 1\n",
    "        else:\n",
    "            print(\"Mismatch\")\n",
    "            print(a[i])\n",
    "            print(b[i])\n",
    "            print(\"\\n\\n\\n\")\n",
    "    \n",
    "    print(correct)\n",
    "    print(correct/total)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6e2e5462-92f8-43f3-9f15-c39d7a3c2916",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ee838346-dd7c-4f4b-bb37-5ed87af56ce3",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d9d1faa7-f554-4b39-a9a5-a00ea353ce79",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "id": "01bd30d5-ac2e-45a5-9e89-3250d2eacf9a",
   "metadata": {},
   "outputs": [],
   "source": [
    "def prediction_zero(data):\n",
    "    prediction0_1 = [i for i in range(len(data)) if data[i][\"output\"][\"model1\"] == 0]\n",
    "    prediction0_2 = [i for i in range(len(data)) if data[i][\"output\"][\"model2\"] == 0]\n",
    "    return prediction0_1, prediction0_2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "id": "ae70c842-45ed-46b6-981c-eb8d7ee9cbdd",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model 1: 107\n",
      "Model 2: 111\n"
     ]
    }
   ],
   "source": [
    "print(f\"Model 1: {len(prediction_zero(verb_data)[0])}\")\n",
    "print(f\"Model 2: {len(prediction_zero(verb_data)[1])}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "id": "e3eb3fd8-3cc7-4adf-a3ad-0130ff33a6f0",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model 1: 125\n",
      "Model 2: 123\n"
     ]
    }
   ],
   "source": [
    "print(f\"Model 1: {len(prediction_zero(gen_data)[0])}\")\n",
    "print(f\"Model 2: {len(prediction_zero(gen_data)[1])}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "id": "86e06dda-b35d-49b8-999f-97b80d243978",
   "metadata": {},
   "outputs": [],
   "source": [
    "mismatches = [i['output'] for i in gen_data if i[\"output\"][\"model1\"] != i[\"output\"][\"model2\"]]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "id": "3142a7b7-fa95-4787-96cc-88ab653d36e0",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "28"
      ]
     },
     "execution_count": 49,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(mismatches)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "id": "9c599d47-8876-4ef7-9e86-f6d78b2756d9",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[{'model1': 1, 'model2': 0},\n",
       " {'model1': 0, 'model2': 1},\n",
       " {'model1': 1, 'model2': 0},\n",
       " {'model1': 0, 'model2': 1},\n",
       " {'model1': 1, 'model2': 0},\n",
       " {'model1': 1, 'model2': 0},\n",
       " {'model1': 0, 'model2': 1},\n",
       " {'model1': 1, 'model2': 0},\n",
       " {'model1': 0, 'model2': 1},\n",
       " {'model1': 0, 'model2': 1},\n",
       " {'model1': 1, 'model2': 0},\n",
       " {'model1': 1, 'model2': 0},\n",
       " {'model1': 0, 'model2': 1},\n",
       " {'model1': 0, 'model2': 1},\n",
       " {'model1': 0, 'model2': 1},\n",
       " {'model1': 1, 'model2': 0},\n",
       " {'model1': 0, 'model2': 1},\n",
       " {'model1': 0, 'model2': 1},\n",
       " {'model1': 1, 'model2': 0},\n",
       " {'model1': 0, 'model2': 1},\n",
       " {'model1': 1, 'model2': 0},\n",
       " {'model1': 1, 'model2': 0},\n",
       " {'model1': 0, 'model2': 1},\n",
       " {'model1': 0, 'model2': 1},\n",
       " {'model1': 0, 'model2': 1},\n",
       " {'model1': 1, 'model2': 0},\n",
       " {'model1': 0, 'model2': 1},\n",
       " {'model1': 1, 'model2': 0}]"
      ]
     },
     "execution_count": 50,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "mismatches"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "05375133-7679-48d7-a37c-752780695a42",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d19fbe94-398b-43d8-bb50-070fa09f6127",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "11e882f3-4b9b-4b36-9902-cda0eb9d152b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "81064099-224d-4a1c-9338-6d996db66aa8",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "390722d9-c0ef-4b4b-bfe2-9e2b37177dee",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "55bc8389-a58c-4b20-9dee-915f67927849",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a3916d75-25f1-4f5f-9487-751d39703f8e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d6c8263d-62b4-450a-a7de-be177b872981",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2563935d-3304-4dae-8f12-7eef14647a6d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f384a827-dd28-42bd-9073-d464085ddd2d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ca4da95d-2b2e-4f08-a249-8476df331f80",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.12.4"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
