{
 "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 scipy.stats import loguniform, uniform\n",
    "from sklearn.linear_model import LogisticRegression\n",
    "from sklearn.metrics import accuracy_score\n",
    "from sklearn.model_selection import train_test_split, RandomizedSearchCV"
   ]
  },
  {
   "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>buying</th>\n",
       "      <th>maint</th>\n",
       "      <th>doors</th>\n",
       "      <th>persons</th>\n",
       "      <th>lug_boot</th>\n",
       "      <th>safety</th>\n",
       "      <th>class</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>vhigh</td>\n",
       "      <td>vhigh</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>small</td>\n",
       "      <td>low</td>\n",
       "      <td>unacc</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>vhigh</td>\n",
       "      <td>vhigh</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>small</td>\n",
       "      <td>med</td>\n",
       "      <td>unacc</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>vhigh</td>\n",
       "      <td>vhigh</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>small</td>\n",
       "      <td>high</td>\n",
       "      <td>unacc</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>vhigh</td>\n",
       "      <td>vhigh</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>med</td>\n",
       "      <td>low</td>\n",
       "      <td>unacc</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>vhigh</td>\n",
       "      <td>vhigh</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>med</td>\n",
       "      <td>med</td>\n",
       "      <td>unacc</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1718</th>\n",
       "      <td>low</td>\n",
       "      <td>low</td>\n",
       "      <td>5more</td>\n",
       "      <td>4</td>\n",
       "      <td>big</td>\n",
       "      <td>high</td>\n",
       "      <td>vgood</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1719</th>\n",
       "      <td>low</td>\n",
       "      <td>low</td>\n",
       "      <td>5more</td>\n",
       "      <td>more</td>\n",
       "      <td>small</td>\n",
       "      <td>low</td>\n",
       "      <td>unacc</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1720</th>\n",
       "      <td>low</td>\n",
       "      <td>low</td>\n",
       "      <td>5more</td>\n",
       "      <td>more</td>\n",
       "      <td>small</td>\n",
       "      <td>med</td>\n",
       "      <td>acc</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1721</th>\n",
       "      <td>low</td>\n",
       "      <td>low</td>\n",
       "      <td>5more</td>\n",
       "      <td>more</td>\n",
       "      <td>small</td>\n",
       "      <td>high</td>\n",
       "      <td>good</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1722</th>\n",
       "      <td>low</td>\n",
       "      <td>low</td>\n",
       "      <td>5more</td>\n",
       "      <td>more</td>\n",
       "      <td>med</td>\n",
       "      <td>low</td>\n",
       "      <td>unacc</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>1723 rows × 7 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "     buying  maint  doors persons lug_boot safety  class\n",
       "0     vhigh  vhigh      2       2    small    low  unacc\n",
       "1     vhigh  vhigh      2       2    small    med  unacc\n",
       "2     vhigh  vhigh      2       2    small   high  unacc\n",
       "3     vhigh  vhigh      2       2      med    low  unacc\n",
       "4     vhigh  vhigh      2       2      med    med  unacc\n",
       "...     ...    ...    ...     ...      ...    ...    ...\n",
       "1718    low    low  5more       4      big   high  vgood\n",
       "1719    low    low  5more    more    small    low  unacc\n",
       "1720    low    low  5more    more    small    med    acc\n",
       "1721    low    low  5more    more    small   high   good\n",
       "1722    low    low  5more    more      med    low  unacc\n",
       "\n",
       "[1723 rows x 7 columns]"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Reading the Car Dataset\n",
    "car = pd.read_csv(\"./../../../datasets/car/car.data\")\n",
    "car.head(-5)"
   ]
  },
  {
   "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: 1728 entries, 0 to 1727\n",
      "Data columns (total 7 columns):\n",
      " #   Column    Non-Null Count  Dtype \n",
      "---  ------    --------------  ----- \n",
      " 0   buying    1728 non-null   object\n",
      " 1   maint     1728 non-null   object\n",
      " 2   doors     1728 non-null   object\n",
      " 3   persons   1728 non-null   object\n",
      " 4   lug_boot  1728 non-null   object\n",
      " 5   safety    1728 non-null   object\n",
      " 6   class     1728 non-null   object\n",
      "dtypes: object(7)\n",
      "memory usage: 94.6+ KB\n",
      "None\n",
      "\n",
      "\n",
      "\n",
      "Missing values:  False\n"
     ]
    }
   ],
   "source": [
    "print(car.info())\n",
    "print(\"\\n\\n\")\n",
    "print(\"Missing values: \", car.isnull().values.any())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "ad443670-8af5-427c-a58a-36da184355cc",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Helper Function\n",
    "def label_encoder(feature, label_to_int=None):\n",
    "    if not label_to_int:\n",
    "        unique_labels = pd.unique(feature)\n",
    "        label_to_int = {label: idx for idx, label in enumerate(unique_labels)}\n",
    "    print(label_to_int)\n",
    "    transformed_feature = np.array([label_to_int[label] for label in feature])\n",
    "    return transformed_feature"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "4d3bb9f1-29e5-4178-84af-7d1d8672cfdb",
   "metadata": {},
   "source": [
    "**Converting Categorical Features to Numerical**"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "f9a2baa4-41c9-444b-ad1c-01e2dce2455b",
   "metadata": {},
   "source": [
    "**class (Target Feature)**\n",
    "\n",
    "Categorical: Numerical<br>\n",
    "unacc: 0 <br>\n",
    "acc: 1 <br>\n",
    "good: 2 <br>\n",
    "vgood: 3"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "8e04a263-1ab6-4791-8d44-a81885117a83",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{'unacc': 0, 'acc': 1, 'good': 2, 'vgood': 3}\n"
     ]
    }
   ],
   "source": [
    "class_label_to_int = {\"unacc\": 0, \"acc\": 1, \"good\": 2, \"vgood\": 3}\n",
    "car['class'] = label_encoder(car['class'], label_to_int=class_label_to_int)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "8605f323-fdee-42d4-8949-47a93933fac7",
   "metadata": {},
   "source": [
    "**buying (attribute)**\n",
    "\n",
    "Categorical: Numerical <br>\n",
    "vhigh: 3 <br>\n",
    "high: 2 <br>\n",
    "med: 1 <br>\n",
    "low: 0"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "14d3c119-6cac-49dc-bdb7-eab700b08dce",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{'vhigh': 3, 'high': 2, 'med': 1, 'low': 0}\n"
     ]
    }
   ],
   "source": [
    "buying_label_to_int = {\"vhigh\": 3, \"high\": 2, \"med\": 1, \"low\": 0}\n",
    "car['buying'] = label_encoder(car['buying'], label_to_int=buying_label_to_int)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "28983e1e-8f72-46fe-a7d8-d359b718fe73",
   "metadata": {},
   "source": [
    "**maint (attribute)**\n",
    "\n",
    "Categorical: Numerical<br>\n",
    "vhigh: 3<br>\n",
    "high: 2<br>\n",
    "med: 1<br>\n",
    "low: 0"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "fb0e3bfc-17eb-44f8-a446-6db360afc050",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{'vhigh': 3, 'high': 2, 'med': 1, 'low': 0}\n"
     ]
    }
   ],
   "source": [
    "maint_label_to_int = {\"vhigh\": 3, \"high\": 2, \"med\": 1, \"low\": 0}\n",
    "car['maint'] = label_encoder(car['maint'], label_to_int=maint_label_to_int)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "d4eaf437-e6e4-41cf-af83-376e549afcf2",
   "metadata": {},
   "source": [
    "**door (attribute)**\n",
    "\n",
    "Categorical: Numerical<br>\n",
    "2: 2<br>\n",
    "3: 3<br>\n",
    "4: 4<br>\n",
    "5more: 5"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "64db38b9-d89b-4518-a632-523a384d1251",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{'2': 2, '3': 3, '4': 4, '5more': 5}\n"
     ]
    }
   ],
   "source": [
    "door_label_to_int = {\"2\": 2, \"3\": 3, \"4\": 4, \"5more\": 5}\n",
    "car['doors'] = label_encoder(car['doors'], label_to_int=door_label_to_int) "
   ]
  },
  {
   "cell_type": "markdown",
   "id": "da9f2d62-e3ed-433e-b485-5ce5c9e2486c",
   "metadata": {},
   "source": [
    "**persons (attribute)**\n",
    "\n",
    "Categorical: Numerical<br>\n",
    "2: 2<br>\n",
    "4: 4<br>\n",
    "more: 5<br>"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "f90c8d85-826c-456b-8fb7-a221fe87e8bb",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{'2': 2, '4': 4, 'more': 5}\n"
     ]
    }
   ],
   "source": [
    "persons_label_to_int = {\"2\":2, \"4\":4, \"more\":5}\n",
    "car[\"persons\"] = label_encoder(car[\"persons\"], label_to_int=persons_label_to_int)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "8ffb99c4-8077-4778-844a-a0662918404c",
   "metadata": {},
   "source": [
    "**lug_boot (attribute)**\n",
    "\n",
    "Categorical: Numerical<br>\n",
    "small: 0<br>\n",
    "med: 1<br>\n",
    "big: 2<br>"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "65edd551-5663-4381-ab03-1d28007e5dc3",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{'small': 0, 'med': 1, 'big': 2}\n"
     ]
    }
   ],
   "source": [
    "lug_boot_label_to_int = {\"small\":0, \"med\":1, \"big\":2}\n",
    "car[\"lug_boot\"] = label_encoder(car[\"lug_boot\"], label_to_int=lug_boot_label_to_int)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "7b90c075-6ab9-4939-ad0f-30cb57827a47",
   "metadata": {},
   "source": [
    "**safety (attribute)**\n",
    "\n",
    "Categorical: Numerical<br>\n",
    "low: 0<br>\n",
    "med: 1<br>\n",
    "high: 2<br>"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "4b79e370-f56d-40a3-99b5-69446ec48c1f",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{'low': 0, 'med': 1, 'high': 2}\n"
     ]
    }
   ],
   "source": [
    "safety_label_to_int = {\"low\": 0, \"med\": 1, \"high\": 2}\n",
    "car[\"safety\"] = label_encoder(car[\"safety\"], label_to_int=safety_label_to_int)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "d921143a-172f-4f29-80c6-5a877643d067",
   "metadata": {},
   "source": [
    "**Variance Check**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "948672e3-370b-466e-97ac-be927c47d05f",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "buying      1.251\n",
       "maint       1.251\n",
       "doors       1.251\n",
       "persons     1.556\n",
       "lug_boot    0.667\n",
       "safety      0.667\n",
       "class       0.549\n",
       "dtype: float64"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "car.var().round(3)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "039d6a5a-4cb2-43ea-b8c5-0c2488444861",
   "metadata": {},
   "source": [
    "Very different variance levels"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "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>buying</th>\n",
       "      <th>maint</th>\n",
       "      <th>doors</th>\n",
       "      <th>persons</th>\n",
       "      <th>lug_boot</th>\n",
       "      <th>safety</th>\n",
       "      <th>class</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>3</td>\n",
       "      <td>3</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>3</td>\n",
       "      <td>3</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>3</td>\n",
       "      <td>3</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>3</td>\n",
       "      <td>3</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>3</td>\n",
       "      <td>3</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   buying  maint  doors  persons  lug_boot  safety  class\n",
       "0       3      3      2        2         0       0      0\n",
       "1       3      3      2        2         0       1      0\n",
       "2       3      3      2        2         0       2      0\n",
       "3       3      3      2        2         1       0      0\n",
       "4       3      3      2        2         1       1      0"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "car.head()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "06776d06-aac3-4cd8-b1e8-b8498381d713",
   "metadata": {},
   "source": [
    "**Checking the distribution of target values**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "339d9bbe-8754-4572-87e1-3365bed7af5e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "class\n",
       "0    0.700\n",
       "1    0.222\n",
       "2    0.040\n",
       "3    0.038\n",
       "Name: proportion, dtype: float64"
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "car[\"class\"].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; 82%-18%\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": 15,
   "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(car.drop(columns=\"class\"), car[\"class\"], test_size=0.18, random_state=400, stratify=car[\"class\"])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "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": 17,
   "id": "f79613d4",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "class\n",
      "0    0.700\n",
      "1    0.222\n",
      "2    0.040\n",
      "3    0.037\n",
      "Name: proportion, dtype: float64\n",
      "class\n",
      "0    0.699\n",
      "1    0.224\n",
      "2    0.038\n",
      "3    0.038\n",
      "Name: proportion, dtype: float64\n",
      "class\n",
      "0    0.705\n",
      "1    0.218\n",
      "2    0.038\n",
      "3    0.038\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": 18,
   "id": "9bf865bb-067e-40f8-bfb8-03afba7c71a1",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "buying      1.265\n",
       "maint       1.248\n",
       "doors       1.243\n",
       "persons     1.543\n",
       "lug_boot    0.671\n",
       "safety      0.661\n",
       "dtype: float64"
      ]
     },
     "execution_count": 18,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "X_train.var().round(3)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "0a7a2750-30fc-45f5-97d9-9bd0863cab60",
   "metadata": {},
   "source": [
    "**Standardization** - No need. The label encoded values all lie in the range of 0-5. Also not a huge difference variance"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "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": 20,
   "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": 21,
   "id": "d53928be",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "buying      1.265\n",
       "maint       1.248\n",
       "doors       1.243\n",
       "persons     1.543\n",
       "lug_boot    0.671\n",
       "safety      0.661\n",
       "dtype: float64"
      ]
     },
     "execution_count": 21,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "X_train.var().round(3)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "97fe3ae9-5bdc-488c-9339-af497d6999ee",
   "metadata": {},
   "source": [
    "From here Onwards `X_train` is going to be `X_train_scaled_df`."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "61841898",
   "metadata": {},
   "outputs": [],
   "source": [
    "X_train_scaled_df = X_train\n",
    "X_test_scaled_df = X_test_verb\n",
    "X_test_gen_scaled_df = X_test_gen\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": 23,
   "id": "89b2a7e3-1405-4e9d-97c6-0e04001d6968",
   "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=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/_sag.py:349: ConvergenceWarning: The max_iter was reached which means the coef_ did not converge\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/_sag.py:349: ConvergenceWarning: The max_iter was reached which means the coef_ did not converge\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/_sag.py:349: ConvergenceWarning: The max_iter was reached which means the coef_ did not converge\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/_sag.py:349: ConvergenceWarning: The max_iter was reached which means the coef_ did not converge\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/_sag.py:349: ConvergenceWarning: The max_iter was reached which means the coef_ did not converge\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/_sag.py:349: ConvergenceWarning: The max_iter was reached which means the coef_ did not converge\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/_sag.py:349: ConvergenceWarning: The max_iter was reached which means the coef_ did not converge\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/_sag.py:349: ConvergenceWarning: The max_iter was reached which means the coef_ did not converge\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/_sag.py:349: ConvergenceWarning: The max_iter was reached which means the coef_ did not converge\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/_sag.py:349: ConvergenceWarning: The max_iter was reached which means the coef_ did not converge\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/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/_sag.py:349: ConvergenceWarning: The max_iter was reached which means the coef_ did not converge\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/_sag.py:349: ConvergenceWarning: The max_iter was reached which means the coef_ did not converge\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/_sag.py:349: ConvergenceWarning: The max_iter was reached which means the coef_ did not converge\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/_sag.py:349: ConvergenceWarning: The max_iter was reached which means the coef_ did not converge\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/_sag.py:349: ConvergenceWarning: The max_iter was reached which means the coef_ did not converge\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/_sag.py:349: ConvergenceWarning: The max_iter was reached which means the coef_ did not converge\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/_sag.py:349: ConvergenceWarning: The max_iter was reached which means the coef_ did not converge\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/_sag.py:349: ConvergenceWarning: The max_iter was reached which means the coef_ did not converge\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/_sag.py:349: ConvergenceWarning: The max_iter was reached which means the coef_ did not converge\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/_sag.py:349: ConvergenceWarning: The max_iter was reached which means the coef_ did not converge\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=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",
      "120 fits failed out of a total of 200.\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",
      "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 elasticnet penalty.\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "50 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 1466, in wrapper\n",
      "    estimator._validate_params()\n",
      "  File \"/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/base.py\", line 666, in _validate_params\n",
      "    validate_parameter_constraints(\n",
      "  File \"/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/utils/_param_validation.py\", line 95, in validate_parameter_constraints\n",
      "    raise InvalidParameterError(\n",
      "sklearn.utils._param_validation.InvalidParameterError: The 'penalty' parameter of LogisticRegression must be a str among {'l1', 'l2', 'elasticnet'} or None. Got 'none' instead.\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "20 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",
      "20 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",
      "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",
      "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 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        nan        nan        nan        nan        nan\n",
      " 0.81849466        nan 0.8050894  0.69986515        nan 0.84533513\n",
      "        nan        nan 0.84604435 0.69986515 0.74366197        nan\n",
      " 0.75702228        nan]\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(11.682671286687027), 'class_weight': None, 'l1_ratio': np.float64(0.008584156320560643), 'max_iter': 718, 'penalty': 'l2', 'solver': 'saga', 'tol': np.float64(3.899475548867021e-06)}\n",
      "Best score:  0.8460443512136651\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_sag.py:349: ConvergenceWarning: The max_iter was reached which means the coef_ did not converge\n",
      "  warnings.warn(\n"
     ]
    }
   ],
   "source": [
    "from sklearn.linear_model import LogisticRegression\n",
    "\n",
    "param_dist = {\n",
    "    'C': loguniform(1e-4, 1e4),\n",
    "    'penalty': ['l1', 'l2', 'elasticnet', 'none'],\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=10, 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": 24,
   "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:469: ConvergenceWarning: lbfgs failed to converge (status=1):\n",
      "STOP: TOTAL NO. of ITERATIONS REACHED LIMIT.\n",
      "\n",
      "Increase the number of iterations (max_iter) or scale the data as shown in:\n",
      "    https://scikit-learn.org/stable/modules/preprocessing.html\n",
      "Please also refer to the documentation for alternative solver options:\n",
      "    https://scikit-learn.org/stable/modules/linear_model.html#logistic-regression\n",
      "  n_iter_i = _check_optimize_result(\n"
     ]
    }
   ],
   "source": [
    "# Train the base model\n",
    "def train_base_model(X_train, y_train):\n",
    "    model = LogisticRegression(C=0.2, max_iter=10, 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": 25,
   "id": "97d229ee-5cb6-46d4-8ab8-742e47dcf1d0",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.8205128205128205\n"
     ]
    }
   ],
   "source": [
    "print(accuracy_score(y_test, base_pred))"
   ]
  },
  {
   "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": 26,
   "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_\n",
    "    intercept = modified_model.intercept_\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_ = modified_coef\n",
    "    modified_model.intercept_ = 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": 46,
   "id": "efe7242e-ecc0-4520-9b64-280823bc4364",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Modification Factor: 0.1 Noise: [[ 0.11080715 -0.03222778  0.22887439 -0.18454491 -0.15340805  0.10899448]\n",
      " [ 0.12094714 -0.02926353 -0.09630636  0.02023765  0.16234354 -0.23111366]\n",
      " [ 0.10366632  0.23406019 -0.02230727 -0.06536506  0.08148753 -0.04307922]\n",
      " [-0.00125621  0.13021517 -0.00906202  0.14110323  0.04291008 -0.03789852]]\n",
      "Modification Factor: 0.15 Noise: [[-0.13727545 -0.01796059  0.17631381  0.06998616  0.01211552  0.10263912]\n",
      " [-0.05940997 -0.05474557 -0.03762306 -0.01580992  0.04370281  0.25185992]\n",
      " [ 0.06066135  0.13575536 -0.04674335  0.01806367  0.13607301  0.11218857]\n",
      " [-0.07190651 -0.03768539  0.09026022 -0.17311521  0.01058959 -0.02649049]]\n",
      "Modification Factor: 0.2 Noise: [[-0.35441709  0.12231621 -0.13090208 -0.09896912 -0.0369192  -0.06795451]\n",
      " [ 0.2945715  -0.03380182 -0.05298912 -0.31283459 -0.06891524 -0.50993837]\n",
      " [ 0.30846416 -0.18584641 -0.00134224  0.12841399  0.09746084  0.25902374]\n",
      " [-0.30534287  0.17807346  0.26501942 -0.35525384 -0.04122093 -0.05110933]]\n",
      "Modification Factor: 0.25 Noise: [[-0.1897558  -0.25670809 -0.51750515 -0.05761685  0.25287013  0.31130262]\n",
      " [-0.44148224  0.00924058 -0.06938217  0.10947578  0.03253233  0.030752  ]\n",
      " [-0.17057627 -0.19329722  0.34495295  0.00219882  0.04394752  0.02771537]\n",
      " [ 0.1221652   0.0963545   0.1659819   0.40707824  0.02717337  0.18347406]]\n",
      "Modification Factor: 0.3 Noise: [[ 0.15625708  0.43226894 -0.25900816  0.53083561  0.33135093  0.11792951]\n",
      " [ 0.5632451   0.25803269  0.28874394  0.16530939 -0.38731528  0.26415088]\n",
      " [-0.04600961  0.05996919  0.53374772  0.13714497  0.49305175 -0.19536669]\n",
      " [ 0.10158475  0.4707064   0.29265189  0.02293801 -0.57877358  0.41855522]]\n",
      "Modification Factor: 0.35 Noise: [[-0.06764006 -0.09136009  0.19927477  0.05574303 -0.15143692 -0.25397291]\n",
      " [ 0.31751418 -0.1372936   0.02786345  0.09934679 -0.63255292  0.24992639]\n",
      " [ 0.13480291 -0.01053283 -0.62050224  0.14699062 -0.20581968 -0.18363789]\n",
      " [-0.37175266 -0.3154081  -0.7110784   0.03946822 -0.12766805 -0.20323664]]\n",
      "Modification Factor: 0.4 Noise: [[-0.7925045  -0.08917935 -0.33263863 -0.36401285 -0.74110709  0.17447611]\n",
      " [ 0.48972787  0.58725161  0.41459194  0.08070572  0.6105536  -0.02402236]\n",
      " [-1.13761622  0.44638198 -0.08837277  0.23527213  0.63280694  0.14158483]\n",
      " [ 0.21789096  0.07837938  0.08670517 -0.05319206 -0.38965166 -0.20997161]]\n",
      "Modification Factor: 0.45 Noise: [[ 0.85401195 -0.04273036 -0.05983822  0.36957865  0.08699391 -0.39036109]\n",
      " [-0.95170252  0.38881309 -0.12516513  0.4492154  -0.98668945 -0.98845552]\n",
      " [ 0.52805603 -0.88572684 -0.15984319  0.30396251  0.5327988  -0.74316002]\n",
      " [-0.59398618  0.91228598 -0.36553574  0.05945719  0.12713102  0.44164068]]\n",
      "Modification Factor: 0.5 Noise: [[ 0.10519997 -0.26010343 -0.48202528 -0.04449894  0.16644988  0.45870683]\n",
      " [-0.88181528  0.39838161 -0.01609303  0.82394305 -0.33217278 -0.04912624]\n",
      " [-0.19622827 -0.20451704  0.02414199 -0.13927114 -0.36041334  0.46555608]\n",
      " [ 0.25924261  0.1937431  -0.25083209  0.17578876 -0.48442625 -0.07532823]]\n",
      "Modification Factor: 0.55 Noise: [[-0.186983   -0.93113025 -0.24529765  0.42080934 -0.56304064 -0.15332403]\n",
      " [-0.67127859 -0.63832245  0.29866119  0.68026359  0.27975545  0.87997297]\n",
      " [-0.28277234 -1.26416418  0.3605093   0.39972172 -1.34088336  0.43047087]\n",
      " [-0.29257379  0.33202053 -0.82089165 -0.46720912 -0.06817115 -0.20095632]]\n",
      "Modification Factor: 0.6 Noise: [[ 0.67408226 -0.03633497  0.28979285  0.01146301 -0.80326141 -0.2870182 ]\n",
      " [-0.0294319  -0.84690023  1.54281227 -0.21052614 -0.27635407  0.26103435]\n",
      " [ 0.06061091  0.21011415 -0.10259547 -0.53565712 -1.07188117  0.06736322]\n",
      " [ 0.12567252  0.66485498  0.09687389 -0.1352848   0.80365572  0.20627169]]\n",
      "Modification Factor: 0.65 Noise: [[-0.40747767 -0.02172686 -0.30530259 -1.31065461  0.81983434  0.49503085]\n",
      " [ 0.51337439  0.36578627  0.51730104  0.16818049 -0.04834735 -0.0389109 ]\n",
      " [-0.64272419 -1.09578496 -1.12015726 -0.54509146  0.53247581 -0.05939627]\n",
      " [ 0.3325491   0.0077453   0.6438638  -0.17793904  0.76106648 -0.6169173 ]]\n",
      "Modification Factor: 0.7 Noise: [[-0.85366402  0.69917922  1.03259536  0.395923    0.20689792 -0.40965611]\n",
      " [ 0.68591139  2.3723649  -0.77525526  0.68446257  0.20101578 -0.95673759]\n",
      " [-0.34487959 -0.35958289  0.78983003  0.30345764 -1.07020247 -1.36017223]\n",
      " [-0.55261408 -0.28906802 -0.45706895 -0.95240065  0.23741514  1.29947535]]\n",
      "Modification Factor: 0.75 Noise: [[ 0.66501506 -0.79803961 -0.23192226  0.47981127 -0.32719373 -0.28847097]\n",
      " [ 0.06661714 -0.49142777  0.30080411 -1.38534894 -0.40359697 -0.20038601]\n",
      " [-0.91529822 -0.12044928 -0.71017877 -2.08003728  0.33295478 -0.21110617]\n",
      " [-0.48872237  0.06627093  0.16890877 -0.12403209 -0.79464911 -0.06502259]]\n"
     ]
    }
   ],
   "source": [
    "# np.random.seed(124)\n",
    "# np.random.seed(125)\n",
    "# np.random.seed(21)\n",
    "# np.random.seed(100)\n",
    "np.random.seed(199)\n",
    "\n",
    "# Create variations of the model\n",
    "variations = []\n",
    "modification_factors = [0.1, 0.15, 0.2, 0.25, 0.3, 0.35, 0.4, 0.45, 0.5, 0.55, 0.6, 0.65, 0.7, 0.75]\n",
    "# modification_factors = [0.8, 0.75, 0.7, 0.65, 0.6, 0.55, 0.5, 0.45, 0.4, 0.35, 0.3, 0.25, 0.2, 0.15, 0.1, 0.05, 0]\n",
    "# modification_factors = [1.1, 1.05, 1, 0.1, 0.2, 0.3, 0.4, 0.45, 0.5, 0.55, 0.6]\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": 47,
   "id": "58645e40-aebe-495e-b8df-f367c6777448",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "With Model: Modified (factor=0.1), Diff: 0.07692307692307693\n",
      "With Model: Modified (factor=0.15), Diff: 0.10256410256410256\n",
      "With Model: Modified (factor=0.2), Diff: 0.15384615384615385\n",
      "With Model: Modified (factor=0.25), Diff: 0.16666666666666666\n",
      "With Model: Modified (factor=0.3), Diff: 0.15384615384615385\n",
      "With Model: Modified (factor=0.35), Diff: 0.2564102564102564\n",
      "With Model: Modified (factor=0.4), Diff: 0.46153846153846156\n",
      "With Model: Modified (factor=0.45), Diff: 0.23076923076923078\n",
      "Best Model till now is Modified (factor=0.45)\n",
      "With Model: Modified (factor=0.5), Diff: 0.07692307692307693\n",
      "With Model: Modified (factor=0.55), Diff: 0.40384615384615385\n",
      "With Model: Modified (factor=0.6), Diff: 0.20512820512820512\n",
      "With Model: Modified (factor=0.65), Diff: 0.1794871794871795\n",
      "With Model: Modified (factor=0.7), Diff: 0.42948717948717946\n",
      "With Model: Modified (factor=0.75), Diff: 0.16666666666666666\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": 29,
   "id": "e23fad61-1e9e-44bf-9f12-2c4668d58030",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "With Models: Modified (factor=0.1) vs Modified (factor=0.15), Diff: 0.16025641025641027\n",
      "With Models: Modified (factor=0.1) vs Modified (factor=0.2), Diff: 0.0641025641025641\n",
      "With Models: Modified (factor=0.1) vs Modified (factor=0.25), Diff: 0.22435897435897437\n",
      "With Models: Modified (factor=0.1) vs Modified (factor=0.3), Diff: 0.3717948717948718\n",
      "With Models: Modified (factor=0.1) vs Modified (factor=0.35), Diff: 0.15384615384615385\n",
      "With Models: Modified (factor=0.1) vs Modified (factor=0.4), Diff: 0.34615384615384615\n",
      "With Models: Modified (factor=0.1) vs Modified (factor=0.45), Diff: 0.26282051282051283\n",
      "With Models: Modified (factor=0.1) vs Modified (factor=0.5), Diff: 0.1987179487179487\n",
      "With Models: Modified (factor=0.1) vs Modified (factor=0.55), Diff: 0.28205128205128205\n",
      "With Models: Modified (factor=0.1) vs Modified (factor=0.6), Diff: 0.16666666666666666\n",
      "With Models: Modified (factor=0.1) vs Modified (factor=0.65), Diff: 0.28846153846153844\n",
      "With Models: Modified (factor=0.1) vs Modified (factor=0.7), Diff: 0.5\n",
      "With Models: Modified (factor=0.1) vs Modified (factor=0.75), Diff: 0.391025641025641\n",
      "With Models: Modified (factor=0.15) vs Modified (factor=0.2), Diff: 0.1346153846153846\n",
      "With Models: Modified (factor=0.15) vs Modified (factor=0.25), Diff: 0.358974358974359\n",
      "With Models: Modified (factor=0.15) vs Modified (factor=0.3), Diff: 0.23717948717948717\n",
      "With Models: Modified (factor=0.15) vs Modified (factor=0.35), Diff: 0.28205128205128205\n",
      "With Models: Modified (factor=0.15) vs Modified (factor=0.4), Diff: 0.3782051282051282\n",
      "With Models: Modified (factor=0.15) vs Modified (factor=0.45), Diff: 0.3974358974358974\n",
      "With Models: Modified (factor=0.15) vs Modified (factor=0.5), Diff: 0.16666666666666666\n",
      "With Models: Modified (factor=0.15) vs Modified (factor=0.55), Diff: 0.17307692307692307\n",
      "With Models: Modified (factor=0.15) vs Modified (factor=0.6), Diff: 0.2948717948717949\n",
      "With Models: Modified (factor=0.15) vs Modified (factor=0.65), Diff: 0.3333333333333333\n",
      "With Models: Modified (factor=0.15) vs Modified (factor=0.7), Diff: 0.36538461538461536\n",
      "With Models: Modified (factor=0.15) vs Modified (factor=0.75), Diff: 0.2948717948717949\n",
      "With Models: Modified (factor=0.2) vs Modified (factor=0.25), Diff: 0.25\n",
      "With Models: Modified (factor=0.2) vs Modified (factor=0.3), Diff: 0.358974358974359\n",
      "With Models: Modified (factor=0.2) vs Modified (factor=0.35), Diff: 0.1987179487179487\n",
      "With Models: Modified (factor=0.2) vs Modified (factor=0.4), Diff: 0.34615384615384615\n",
      "With Models: Modified (factor=0.2) vs Modified (factor=0.45), Diff: 0.28846153846153844\n",
      "With Models: Modified (factor=0.2) vs Modified (factor=0.5), Diff: 0.1858974358974359\n",
      "With Models: Modified (factor=0.2) vs Modified (factor=0.55), Diff: 0.26282051282051283\n",
      "With Models: Modified (factor=0.2) vs Modified (factor=0.6), Diff: 0.21794871794871795\n",
      "With Models: Modified (factor=0.2) vs Modified (factor=0.65), Diff: 0.3141025641025641\n",
      "With Models: Modified (factor=0.2) vs Modified (factor=0.7), Diff: 0.4807692307692308\n",
      "With Models: Modified (factor=0.2) vs Modified (factor=0.75), Diff: 0.34615384615384615\n",
      "With Models: Modified (factor=0.25) vs Modified (factor=0.3), Diff: 0.5897435897435898\n",
      "With Models: Modified (factor=0.25) vs Modified (factor=0.35), Diff: 0.1346153846153846\n",
      "With Models: Modified (factor=0.25) vs Modified (factor=0.4), Diff: 0.34615384615384615\n",
      "With Models: Modified (factor=0.25) vs Modified (factor=0.45), Diff: 0.038461538461538464\n",
      "With Models: Modified (factor=0.25) vs Modified (factor=0.5), Diff: 0.27564102564102566\n",
      "With Models: Modified (factor=0.25) vs Modified (factor=0.55), Diff: 0.4807692307692308\n",
      "With Models: Modified (factor=0.25) vs Modified (factor=0.6), Diff: 0.14102564102564102\n",
      "With Models: Modified (factor=0.25) vs Modified (factor=0.65), Diff: 0.4358974358974359\n",
      "With Models: Modified (factor=0.25) vs Modified (factor=0.7), Diff: 0.7051282051282052\n",
      "With Models: Modified (factor=0.25) vs Modified (factor=0.75), Diff: 0.5384615384615384\n",
      "With Models: Modified (factor=0.3) vs Modified (factor=0.35), Diff: 0.5128205128205128\n",
      "With Models: Modified (factor=0.3) vs Modified (factor=0.4), Diff: 0.33974358974358976\n",
      "With Models: Modified (factor=0.3) vs Modified (factor=0.45), Diff: 0.6282051282051282\n",
      "With Models: Modified (factor=0.3) vs Modified (factor=0.5), Diff: 0.38461538461538464\n",
      "With Models: Modified (factor=0.3) vs Modified (factor=0.55), Diff: 0.2564102564102564\n",
      "With Models: Modified (factor=0.3) vs Modified (factor=0.6), Diff: 0.5192307692307693\n",
      "With Models: Modified (factor=0.3) vs Modified (factor=0.65), Diff: 0.3525641025641026\n",
      "With Models: Modified (factor=0.3) vs Modified (factor=0.7), Diff: 0.2692307692307692\n",
      "With Models: Modified (factor=0.3) vs Modified (factor=0.75), Diff: 0.38461538461538464\n",
      "With Models: Modified (factor=0.35) vs Modified (factor=0.4), Diff: 0.40384615384615385\n",
      "With Models: Modified (factor=0.35) vs Modified (factor=0.45), Diff: 0.17307692307692307\n",
      "With Models: Modified (factor=0.35) vs Modified (factor=0.5), Diff: 0.1987179487179487\n",
      "With Models: Modified (factor=0.35) vs Modified (factor=0.55), Diff: 0.3974358974358974\n",
      "With Models: Modified (factor=0.35) vs Modified (factor=0.6), Diff: 0.10256410256410256\n",
      "With Models: Modified (factor=0.35) vs Modified (factor=0.65), Diff: 0.40384615384615385\n",
      "With Models: Modified (factor=0.35) vs Modified (factor=0.7), Diff: 0.6217948717948718\n",
      "With Models: Modified (factor=0.35) vs Modified (factor=0.75), Diff: 0.4935897435897436\n",
      "With Models: Modified (factor=0.4) vs Modified (factor=0.45), Diff: 0.3717948717948718\n",
      "With Models: Modified (factor=0.4) vs Modified (factor=0.5), Diff: 0.4935897435897436\n",
      "With Models: Modified (factor=0.4) vs Modified (factor=0.55), Diff: 0.5256410256410257\n",
      "With Models: Modified (factor=0.4) vs Modified (factor=0.6), Diff: 0.3782051282051282\n",
      "With Models: Modified (factor=0.4) vs Modified (factor=0.65), Diff: 0.38461538461538464\n",
      "With Models: Modified (factor=0.4) vs Modified (factor=0.7), Diff: 0.5897435897435898\n",
      "With Models: Modified (factor=0.4) vs Modified (factor=0.75), Diff: 0.6153846153846154\n",
      "With Models: Modified (factor=0.45) vs Modified (factor=0.5), Diff: 0.3141025641025641\n",
      "With Models: Modified (factor=0.45) vs Modified (factor=0.55), Diff: 0.5064102564102564\n",
      "With Models: Modified (factor=0.45) vs Modified (factor=0.6), Diff: 0.1794871794871795\n",
      "With Models: Modified (factor=0.45) vs Modified (factor=0.65), Diff: 0.44871794871794873\n",
      "With Models: Modified (factor=0.45) vs Modified (factor=0.7), Diff: 0.7371794871794872\n",
      "With Models: Modified (factor=0.45) vs Modified (factor=0.75), Diff: 0.5448717948717948\n",
      "With Models: Modified (factor=0.5) vs Modified (factor=0.55), Diff: 0.24358974358974358\n",
      "Best Model Pair till now is Modified (factor=0.5) vs Modified (factor=0.55)\n",
      "With Models: Modified (factor=0.5) vs Modified (factor=0.6), Diff: 0.23717948717948717\n",
      "With Models: Modified (factor=0.5) vs Modified (factor=0.65), Diff: 0.3333333333333333\n",
      "With Models: Modified (factor=0.5) vs Modified (factor=0.7), Diff: 0.46153846153846156\n",
      "With Models: Modified (factor=0.5) vs Modified (factor=0.75), Diff: 0.34615384615384615\n",
      "With Models: Modified (factor=0.55) vs Modified (factor=0.6), Diff: 0.40384615384615385\n",
      "With Models: Modified (factor=0.55) vs Modified (factor=0.65), Diff: 0.3782051282051282\n",
      "With Models: Modified (factor=0.55) vs Modified (factor=0.7), Diff: 0.3141025641025641\n",
      "With Models: Modified (factor=0.55) vs Modified (factor=0.75), Diff: 0.21794871794871795\n",
      "With Models: Modified (factor=0.6) vs Modified (factor=0.65), Diff: 0.391025641025641\n",
      "With Models: Modified (factor=0.6) vs Modified (factor=0.7), Diff: 0.6282051282051282\n",
      "With Models: Modified (factor=0.6) vs Modified (factor=0.75), Diff: 0.5192307692307693\n",
      "With Models: Modified (factor=0.65) vs Modified (factor=0.7), Diff: 0.5128205128205128\n",
      "With Models: Modified (factor=0.65) vs Modified (factor=0.75), Diff: 0.5\n",
      "With Models: Modified (factor=0.7) vs Modified (factor=0.75), Diff: 0.34615384615384615\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.25):\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": 48,
   "id": "534dbb87-dd80-412a-92e0-92979cb7eb94",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Get the model pair\n",
    "# (model1_name, model1), (model2_name, model2) = best_pair\n",
    "(model2_name, model2), (model1_name, model1) = best_pair"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "9ea03138-8060-44ec-80ba-72d49272ec80",
   "metadata": {},
   "source": [
    "**Evaluate Both Models**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "id": "6e595955-68c6-41b3-8b0e-051de7cf86ba",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model 1: Modified (factor=0.45)\n",
      "Model 1 accuracy: 0.7115384615384616\n",
      "\n",
      "Model 2: Base Model\n",
      "Model 2 accuracy: 0.8205128205128205\n",
      "\n",
      "Accuracy difference: 0.10897435897435892\n",
      "\n",
      "Percentage of different outputs: 23.08%\n",
      "\n",
      "\n",
      "\n",
      "[[ 2.61648256e+00  1.15987013e+00  4.42203437e-01 -8.85320942e-01\n",
      "  -2.63445685e-01 -9.33163631e-01]\n",
      " [ 2.86759521e-02  6.56468245e-01  7.17200469e-03  2.32881840e-01\n",
      "  -1.80422637e-03  4.75779659e-03]\n",
      " [-1.57610326e+00 -1.21758441e-01 -1.71297641e-01  3.94856011e-01\n",
      "  -1.48469859e-01  7.34214707e-02]\n",
      " [-3.95273525e-01 -1.18336773e+00 -1.74261104e-01  1.93786334e-01\n",
      "   5.35130532e-01  1.20044034e+00]]\n",
      "[[ 1.41125442  1.21164412  0.47034824 -0.64641848 -0.24236169 -1.53068253]\n",
      " [ 0.59373594  0.47268293  0.00819812  0.16069512 -0.13554862  0.41212748]\n",
      " [-1.03144337 -1.06550343 -0.2038877   0.3028124  -0.09686194  0.28586465]\n",
      " [-0.97354698 -0.61882362 -0.27465866  0.18291096  0.47477225  0.83269039]]\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": 50,
   "id": "9297eecf-1718-46bb-be3a-98b8f08a5afe",
   "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 prediction\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=3)\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(list(class_label_to_int.values()))\n",
    "    cbar.set_ticklabels(list(class_label_to_int.keys()))\n",
    "\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e25664a2-96be-41f8-8156-f6ed213336fc",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "id": "6d4d70a4-794b-4bc0-8659-d244baa22e7c",
   "metadata": {},
   "source": [
    "**Model 1 Decision Boundary**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "id": "de4db779-ea88-4543-944d-46c15b3e31de",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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9OOPP6pWrVqSpD///FO1atXS2bNn1atXL5UrV05//PGH5syZo/Pnz6eZqU9JSVFMTIySk5PVv39/hYWF6Y8//tCCBQt09uxZhYaGphnnsWPHVLduXZ0/f14DBgxQgQIF9PHHH+uf//yn5syZozZt2niUf+ONN+RwOPTss88qPj5eb731ljp27Kj169d7dV/i4+N18uRJmaap48eP691339W5c+c8Mvumaeqf//ynVq5cqe7duysqKkpLlizRc889pz/++EPjxo3z6lxpeeyxx1SqVCmNGjVKmzdv1pQpU1S4cGG9+eab7jI9evTQ9OnT9fjjj6tu3bpasWKFmjdvnqquDRs2aM2aNWrfvr3Cw8N14MABTZw4UQ0aNNDOnTuVK1cuj/LX/ntp0KCBSpQooRkzZqS6zzNmzFCZMmUUHR2d4WsFfJIJZIJp06aZkswNGzZct0zr1q3NnDlzmvv27XPv+/PPP83g4GDzgQcecO/r37+/aRiGuWXLFve+U6dOmfnz5zclmfv373fvr1+/vlm/fn3351atWpkVK1a8YayjR49OVc9VJUuWNDt37uz+PGzYMFOS+dVXX6Uq63K5bniekiVLmg899JB54sQJ88SJE+a2bdvMJ554wpRk9u3b113uxx9/NCWZM2bM8Dh+8eLFHvvj4uJMf39/s3Xr1h7lRowYYUryiPvq38d9991nXr582b0/MTHRzJs3r9mzZ0+POuLi4szQ0FD3/jNnzpiSzNGjR1/3+ubOnXvTv3PTNE1J5vDhw92fvX0Orl5DkyZNPO71008/bfr5+Zlnz5694XmHDx9uSjJPnDiR5vdXr7FNmzamaV75+yxbtqwZExPjcb7z58+bpUqVMh988EH3vk6dOpkOhyPNa7967MqVK01J5sqVK03TNM0tW7aYkswvvvjihnFf+wwOGjTIlGT++OOP7n2JiYlmqVKlzIiICNPpdHqcr3z58mZycrK77DvvvGNKMrdt23bD816939duAQEBZmxsrEfZefPmmZLMV1991WP/I488YhqGYe7du9c0TdPcv3+/KcmcNm1aqvNd+1xc/fvq1q2bR7k2bdqYBQoUcH/eunWrKcns06ePR7nHH388VZ3nz59Pdd61a9eaksxPPvkk1bVf++/FNE1z6NChZkBAgMfzdvz4cdPf39/jXAC8Q9c8bOF0OrV06VK1bt1apUuXdu8vWrSoHn/8cf30009KSEiQJC1evFjR0dGKiopyl8ufP786dux40/PkzZtXR44c0YYNGyyJ+8svv1TVqlVTZUOkK12LN7N06VIVKlRIhQoVUuXKlfXpp5+qa9euGj16tLvMF198odDQUD344IM6efKke6tevbry5MmjlStXSpKWL1+uy5cvq0+fPh7n6N+//3XP37NnT/n5+bk/L1u2TGfPnlWHDh08zuXn56fatWu7zxUUFKScOXNq1apVqYYHXHV1oteCBQt06dKlm94LKX3PwVW9evXyuNf333+/nE6nDh486NU5rydPnjySpMTEREnS1q1btWfPHj3++OM6deqU+94kJSWpcePG+uGHH+RyueRyuTRv3jy1bNnSYyzlVdd7Lq5mPJcsWZKqq/lGFi5cqFq1aum+++7ziL1Xr146cOCAdu7c6VG+a9euHhnZ+++/X9KV7n1vvP/++1q2bJmWLVum6dOnq2HDhurRo4dHpnvhwoXy8/PTgAEDPI595plnZJrmLc2yf/LJJz0+33///Tp16pT7uVi4cKEkpTr3oEGDUtUVFBTk/vOlS5d06tQp3X333cqbN682b96cqvy1/14kqVOnTkpOTtacOXPc+z777DNdvnzZI0sMwDs0RGGLEydO6Pz584qMjEz1Xfny5eVyuXT48GFJV8Z13X333anKpbXvWv/+97+VJ08e1apVS2XLllXfvn3THN/nrX379qlSpUoZPr527dpatmyZFi9erLffflt58+bVmTNnPBoKe/bsUXx8vAoXLuxutF7dzp07p+PHj0uSu+F17X3Inz9/qq7+q0qVKuXxec+ePZKkRo0apTrX0qVL3ecKCAjQm2++qUWLFqlIkSJ64IEH9NZbbykuLs5dV/369fXwww9r5MiRKliwoFq1anXTZZHS8xxcddddd3l8vnqt12sge+vcuXOSpODgYEl/3ZvOnTunujdTpkxRcnKy4uPjdeLECSUkJKT7uShVqpQGDx6sKVOmqGDBgoqJidH777/vMT40LQcPHrzu/br6/d/d6v2qVauWmjRpoiZNmqhjx4769ttvVaFCBfXr1889/vXgwYMqVqyY+97dLKb0uFn8Bw8elMPhUJkyZTzKpXWPLly4oGHDhrnHsRYsWFCFChXS2bNn07zv1/57kaRy5cqpZs2amjFjhnvfjBkzVKdOHa9+JgHwxBhR3NHKly+v3bt3a8GCBVq8eLG+/PJLTZgwQcOGDdPIkSOzPJ6CBQuqSZMmkqSYmBiVK1dOLVq00DvvvKPBgwdLujIBqXDhwh6/6P7ueuNXvfH3jNDVc0lXxomGhYWlKv/3CSmDBg1Sy5YtNW/ePC1ZskQvvfSSRo0apRUrVqhatWoyDENz5szRunXr9M0337iXRRozZozWrVvnzjjeqmszVFeZf5sUkxHbt2+X9FfD/uq9GT16tEc2/u/y5Mmj06dPZ/icY8aMUZcuXfT1119r6dKlGjBggEaNGqV169Z5TCa7FVbfL4fDoYYNG+qdd97Rnj17VLFiRa+PvV522Ol0XvcYK+Pv37+/pk2bpkGDBik6OlqhoaEyDEPt27d3/33/3bX/Xq7q1KmTBg4cqCNHjig5OVnr1q3Te++9l+54ANAQhU0KFSqkXLlyaffu3am++7//+z85HA73eo4lS5ZMc5avtzN/c+fOrXbt2qldu3ZKSUlR27Zt9dprr2no0KEKDAz0qkv9qjJlyrgbLFZo3ry56tevr9dff129e/dW7ty5VaZMGX333XeqV6/edX8RSlfui3TlPvw9c3Pq1Cmvs11Xs0iFCxd2N5BvVv6ZZ57RM888oz179igqKkpjxozR9OnT3WXq1KmjOnXq6LXXXtPMmTPVsWNHzZ49Wz169EhVX3qeg8z26aefSrryHwTpr3sTEhJyw3tTqFAhhYSEZPi5qFy5sipXrqwXX3xRa9asUb169TRp0iS9+uqraZYvWbLkde/X1e8z2+XLlyX9lUUuWbKkvvvuOyUmJnpkRa+N6Wo289qXR9xKxrRkyZJyuVzat2+fRxY0rXs0Z84cde7cWWPGjHHvu3jxYrpfZtG+fXsNHjxYs2bN0oULF5QjRw61a9cuw9cA+DK65mELPz8/PfTQQ/r66689lk45duyYZs6cqfvuu08hISGSrjQM1q5dq61bt7rLnT59+roZw787deqUx+ecOXOqQoUKMk3TPY7x6tqA3vwyevjhh/XLL7+kuXxLRjNM//73v3Xq1Cl9+OGHkq7MEnY6nXrllVdSlb18+bI7zsaNG8vf318TJ070KJOezExMTIxCQkL0+uuvpzmu8+qySOfPn081E79MmTIKDg52d72fOXMm1T24mkm8Xvd8ep6DzDRz5kxNmTJF0dHRaty4sSSpevXqKlOmjN5++213g+vvrt4bh8Oh1q1b65tvvknzTWLXey4SEhLcDbqrKleuLIfDccPhDM2aNdPPP//ssUxQUlKSJk+erIiICFWoUOHmF3wLLl26pKVLlypnzpzurvdmzZrJ6XSmevbGjRsnwzDUtGlTSVca9QULFtQPP/zgUW7ChAkZjudq3f/973899o8fPz5VWT8/v1R/H+++++4NM7JpKViwoJo2barp06drxowZ+sc//pHuFTMAXEFGFJlq6tSpWrx4car9AwcO1Kuvvqply5bpvvvuU58+feTv768PPvhAycnJeuutt9xlhwwZounTp+vBBx9U//793cs33XXXXTp9+vQNM5oPPfSQwsLCVK9ePRUpUkS7du3Se++9p+bNm7szN9WrV5ckvfDCC2rfvr1y5Mihli1bprl49XPPPac5c+bo0UcfVbdu3VS9enWdPn1a8+fP16RJk1S1atV036OmTZuqUqVKGjt2rPr27av69eurd+/eGjVqlLZu3aqHHnpIOXLk0J49e/TFF1/onXfe0SOPPKIiRYpo4MCBGjNmjP75z3/qH//4h3755RctWrRIBQsW9CrTGxISookTJ+qJJ57Qvffeq/bt26tQoUI6dOiQvv32W9WrV0/vvfeefvvtNzVu3FiPPfaYKlSoIH9/f82dO1fHjh1T+/btJUkff/yxJkyYoDZt2qhMmTJKTEzUhx9+qJCQEDVr1uy6MXj7HFhlzpw5ypMnj1JSUtxvVlq9erWqVq2qL774wl3O4XBoypQpatq0qSpWrKiuXbuqePHi+uOPP7Ry5UqFhITom2++kSS9/vrrWrp0qerXr69evXqpfPnyOnr0qL744gv99NNPqd7YJV1ZGqpfv3569NFHdc899+jy5cv69NNP5efnp4cffvi68T///POaNWuWmjZtqgEDBih//vz6+OOPtX//fn355ZeWv4Vp0aJF7szm8ePHNXPmTO3Zs0fPP/+8+z8JLVu2VMOGDfXCCy/owIEDqlq1qpYuXaqvv/5agwYN8hi/2aNHD73xxhvq0aOHatSooR9++EG//fZbhuOLiopShw4dNGHCBMXHx6tu3bpavnx5mj0mLVq00KeffqrQ0FBVqFBBa9eu1XfffacCBQqk+7ydOnXSI488Iklp/qcRgJdsm6+PO9r1ln65uh0+fNg0TdPcvHmzGRMTY+bJk8fMlSuX2bBhQ3PNmjWp6tuyZYt5//33mwEBAWZ4eLg5atQo87///a8pyYyLi3OXu3b5pg8++MB84IEHzAIFCpgBAQFmmTJlzOeee86Mj4/3qP+VV14xixcvbjocDo+lnK5dOsc0rywd1a9fP7N48eJmzpw5zfDwcLNz587myZMnb3hPSpYsaTZv3jzN72JjY1MtazN58mSzevXqZlBQkBkcHGxWrlzZHDJkiPnnn3+6y1y+fNl86aWXzLCwMDMoKMhs1KiRuWvXLrNAgQLmk08+merv43pLK61cudKMiYkxQ0NDzcDAQLNMmTJmly5dzI0bN5qmaZonT540+/bta5YrV87MnTu3GRoaatauXdv8/PPP3XVs3rzZ7NChg3nXXXeZAQEBZuHChc0WLVq467hK1yypc/XYmz0H17uGa5dFup6rywFd3QIDA83w8HCzRYsW5tSpU82LFy+medyWLVvMtm3bup+hkiVLmo899pi5fPlyj3IHDx40O3XqZBYqVMgMCAgwS5cubfbt29e9dNK1cf7+++9mt27dzDJlypiBgYFm/vz5zYYNG5rfffedR71pPYP79u0zH3nkETNv3rxmYGCgWatWLXPBggVp3pdrl4e60RJKf5fWv+HAwEAzKirKnDhxYqrlyhITE82nn37aLFasmJkjRw6zbNmy5ujRo1OVO3/+vNm9e3czNDTUDA4ONh977DHz+PHj112+6drltq7G9ffl1i5cuGAOGDDALFCggJk7d26zZcuW5uHDh1PVeebMGbNr165mwYIFzTx58pgxMTHm//3f/6W6x94sP5ecnGzmy5fPDA0NNS9cuHDDewng+gzTvMUR/oBNBg0apA8++EDnzp277oQGX3T27Fnly5dPr776ql544QW7wwHuSJcvX1axYsXUsmVLffTRR3aHA2RbjBFFtnDhwgWPz6dOndKnn36q++67z6cbodfeF+mvsXHXvuoUgHXmzZunEydOqFOnTnaHAmRrZESRLURFRalBgwYqX768jh07po8++kh//vmnli9frgceeMDu8GwTGxur2NhYNWvWTHny5NFPP/2kWbNm6aGHHtKSJUvsDg+446xfv16//vqrXnnlFRUsWDDNhfABeI/JSsgWmjVrpjlz5mjy5MkyDEP33nuvPvroI59uhEpSlSpV5O/vr7feeksJCQnuCUzXW/oHwK2ZOHGipk+frqioKMXGxtodDnBb6dKli86ePat58+Z5fQwZUQAAANyyjDREGSMKAAAAW9AQBQAAyCYmT56sYsWKpXotbatWrdStWzdJV9ZnLly4sIKDg9WjRw89//zzHq8qdrlcevnllxUeHq6AgABFRUWlWvN727ZtatSokYKCglSgQAH16tXL4+UeTqdTgwcPVt68eVWgQAENGTIkQy928bmueZfLpT///FPBwcHperUjAACwj2maSkxMVLFixSx/cYM3Ll68qJSUlEyp2zTNVG2SgIAABQQEpCp75swZhYWFaeHChe43wZ0+fVpFixbVwoULFRcXpx49emjChAmqV6+eZs+erTFjxqhUqVLuNxSOGzdOI0aM0AcffKBq1app6tSpGjdunHbs2KGyZcsqKSlJZcuWVXR0tEaOHKnjx4+rR48eeuCBB9xjo9966y298cYbmjJlisqXL68xY8bo888/V6NGjdLVNe9zC9pfXeSYjY2NjY2NLfttV1+IkpUuXLhghmXiNeXJkyfVvmtf/PF3rVq1Mrt16+b+/MEHH5jFihUznU6nWbt2bbNv374e5evVq2dWrVrV/blYsWLma6+95lGmZs2aZp8+fUzTvPJClXz58pnnzp1zf//tt9+aDofD/RKZokWLmm+99Zb7+0uXLpnh4eFmq1at0nVvfW7W/NXXOh4+fDhL3mENAABuXUJCgkqUKOH+PZ6VUlJSFCfpsCSrWw4JkkqcO5eqXZJWNvSqjh07qmfPnpowYYICAgI0Y8YMtW/fXg6HQ7t371afPn08yteqVUsrVqy4cr6EBP3555+qV6+eR5l69erpl19+kSTt2rVLVatW9XjVdb169eRyubR7924FBgbq6NGjql27tvt7f39/1ahRI93d8z7XEL2a+g4JCaEhCgBANmPnsLoQh6EQq89vmpLLTFe7pGXLljJNU99++61q1qypH3/8UePGjbM2rizCZCUAAABv+BmZs6VTYGCg2rZtqxkzZmjWrFmKjIzUvffeK0mKjIzUhg0bPMr//XNISIiKFSum1atXe5RZvXq1KlSoIEkqX768fvnlFyUlJXl873A4FBkZqdDQUBUtWlTr1693f3/58mVt2rQp3dficxlRAACA7K5jx45q0aKFduzYoX/961/u/f3791fPnj1Vo0YN1a1bV5999pl+/fVXlS5d2l3mueee0/Dhw1WmTBlFRUVp2rRp2rp1q2bMmOGue/jw4ercubNGjBihEydOqH///nriiSdUpEgRSdLAgQP1xhtvqGzZsipXrpzGjh2rs2fPpvs6aIgCAAB4w88hZUbX/CXXzctdo1GjRsqfP792796txx9/3L2/Y8eO+v333/Xss8/q4sWLeuyxx9SlSxf9/PPP7jIDBgxQfHy8nnnmGR0/flwVKlTQ/PnzVbZsWUlSrly5tGTJEg0cOFA1a9ZUrly59PDDD2vs2LHuOp555hkdPXpUnTt3lsPhULdu3dSmTRvFx8en6zp8bvmmhIQEhYaGKj4+njGiAABkE3b+/nafO9Df8jGiCaap0IuXM/W6HnzwQYWFhenTTz/NlPpvBRlRAAAAb/gbmZARtba68+fPa9KkSYqJiZGfn59mzZql7777TsuWLbP2RBahIQoAAHCHMAxDCxcu1GuvvaaLFy8qMjJSX375pZo0aWJ3aGmiIQoAAOCNzBojaqGgoCB99913ltaZmVi+CQAAALYgIwoAAOANh3Fls1L6J8zfUWiIAgAAeMPPYX1D1PCpxYtSoWseAAAAtiAjCgAA4A0yopYjIwoAAABb0BC1UPfu3fX+++/bHQbuMMuXL9fMmTPtDgN3mI0bN6pXr176888/7Q4Fd5BLly5p0aJFOnTokN2hZA4/I3M2H2ZrQ3TixImqUqWKQkJCFBISoujoaC1atOiGx3zxxRcqV66cAgMDVblyZS1cuDCLor0+wzDkMHJo6tSp6tevvwzDoapVq9odFrK5Dh06yDAcatLkQXXs2FEOI4fCwsLsDgvZ3KJFi2QYhmrVrKMPP/xQJYqXlGEYSkxMtDs0ZHOlSpVSYM5catasmSJKlpLD4dC3335rd1i4zdnaEA0PD9cbb7yhTZs2aePGjWrUqJFatWqlHTt2pFl+zZo16tChg7p3764tW7aodevWat26tbZv357Fkf/FMAxJhu5SXbXRJ3pQbymXCmrbrzv18ssv2xYXsrcJEybo89lzFKyiitFYtdI0FVN1HTt2XHfffbfd4SEba9asuRzyV7Se1iP6TFXVSZKy/N3duLOULl1aBw4cUBnFqK1mqKFeVk4zWP9s0Vrx8fF2h2cdP0fmbD7MME2Ll/S/Rfnz59fo0aPVvXv3VN+1a9dOSUlJWrBggXtfnTp1FBUVpUmTJnlVf0JCgkJDQxUfH2/JD16H4a8wRamn1sshP0nSCe3S+6ooydRtdnuRTTgcDhmmn/prj/IpQpJ0WSmapKo6qd9kmk57A0S2VKpUKR04cEAtNEk11Nu9f4me1TqN1yuvjtQLL7xgY4TIji5duqTAnLlURg/pcS2QoStdzQf0g2JVXxUqVLhugik9rP79naFzlwhViMWTlRJcpkIPx9tyXbeD26YZ7nQ6NXv2bCUlJSk6OjrNMmvXrk31rtSYmBitXbv2uvUmJycrISHBY7OWqcrq4G6ESlIhlVdhVbL4PPAlpmkqXNHuRqgk+SunKqqdx7MGpMeBAwckSZXUwWN/ZXWQKadef/11G6JCdrdu3Tq5dFmV1MHdCJWkCD2g3CqsvXv32hidxRgjajnbl2/atm2boqOjdfHiReXJk0dz585VhQoV0iwbFxenIkWKeOwrUqSI4uLirlv/qFGjNHLkSEtj/jtDfjqtfR77LitZCTqcaeeEbzijfXLJ6dHwPKM76Ac6spzD4ZDL5dIZ7VNRVXPvv/ozjDHIyIjy5cvLkENnrvldeEFndEFnlDsg0KbIMoGfYX1XutO3X61ke0Y0MjJSW7du1fr16/XUU0+pc+fO2rlzp2X1Dx06VPHx8e7t8GFrG4guXdJmTdEuzZUpU8lK1GIN0kWdVXBwsKXngu+45557lKg/tUxDlKLzcsmlbZqlbZot07hsd3jIptavXy+H/LVAT+qsrsxqPqbtWqYhMuSvffv23aQGILWCBQvKMKQ1elu/a4VMmTqv0/pGvWXKqTFjxtgdIm5jtmdEc+bM6Z58Ub16dW3YsEHvvPOOPvjgg1Rlw8LCdOzYMY99x44du+H/4gMCAhQQEGBt0H/z3nvvqX+/AfpMbRWovLqkC3IqRZIyYRgAfMXu3bvlcDi01hyrDZogPwUoWfGSDO2y8D9q8C01atRQYK6c+vP8Jo1XhHKrkJJ0XA75K7Ick+CQcYuXLNY/HmqmT9RYQSqgZMXLlEuly5RSz5497Q7POpnSle7bXfO2Z0Sv5XK5lJycnOZ30dHRWr58uce+ZcuWXXdMaVbo27evTp85JcMwdFFn5VSySpWKYJISbpnL5VLbtm3lNJKVYiTorrvu0oUL51WuXDm7Q0M2lpSUpBdf+o8kU0k6Lkn6fM5s7dq1y97AkK09+OCDSkyKV1RUlJw5E5UnJJemxU69s8aHIlPYOmt+6NChatq0qe666y4lJiZq5syZevPNN7VkyRI9+OCD6tSpk4oXL65Ro0ZJurJ8U/369fXGG2+oefPmmj17tl5//XVt3rxZlSp5NznIzll3AAAgY26LWfPlCyrE4jGiCU6XQned9Nl2ia1d88ePH1enTp109OhRhYaGqkqVKu5GqCQdOnRIDsdff+F169bVzJkz9eKLL+o///mPypYtq3nz5nndCAUAAMDt47ZbRzSzkREFACD7uS0yopUKZ05GdPtxn22X3HZjRAEAAOAbbJ81DwAAkC0wa95yNEQBAAC8wbvhLcfdBAAAgC3IiAIAAHjDkQld86Zvd82TEQUAAIAtyIgCAAB4IzPGiPrUIpqpkREFAACALciIAgAAeCMzlm9ijCgAAACQ9ciIAgAAeIMxopajIQoAAOANuuYtR9c8AAAAbEFGFAAAwBt0zVuOjCgAAABsQUYUAADAGw7D+oyoy7dTomREAQAAYAsyogAAAN7IjFnzLmbNAwAAAFmOjCgAAIA3MmPWvI+PEaUhCgAA4A265i1H1zwAAABsQUYUAADAG3TNW46MKAAAAGxBRhQAAMAbjBG1HBlRAAAA2IKMKAAAgDccmTBG1MkYUQAAACDLkREFAADwRmaMEbW6vmyGhigAAIA3MmP5Jj+65gEAAIAsR0YUAADAG3TNW46MKAAAAGxBRhQAAMAbjBG1HBlRAAAA2IKMKAAAgDf8jEzIiLqsrS+bISMKAAAAW5ARBQAA8IbDuLJZXacPoyEKAADgjcx417zDtzunffvqAQAAYBsyogAAAN5gQXvLkREFAACALciIAgAAeCNTFrT37Zygb189AAAAbENGFAAAwBuMEbUcGVEAAADYgowoAACANxwO69f9ZB1RAAAAIOuREQUAAPAGY0QtR0MUAADAG7zi03K+ffUAAACwDRlRAAAAb9A1bzkyogAAALAFGVEAAABvsHyT5Xz76gEAAGAbMqIAAADeYIyo5ciIAgAAwBZkRAEAALzhZ1i/jqiPZ0RpiAIAAHjDYVzZrK7Th9naNT9q1CjVrFlTwcHBKly4sFq3bq3du3ff8JjY2FgZhuGxBQYGZlHEAAAAsIqtGdHvv/9effv2Vc2aNXX58mX95z//0UMPPaSdO3cqd+7c1z0uJCTEo8FqGL79vwkAAJAF/DLhFZ9W15fN2NoQXbx4scfn2NhYFS5cWJs2bdIDDzxw3eMMw1BYWFhmhwcAAIBMdFs1w+Pj4yVJ+fPnv2G5c+fOqWTJkipRooRatWqlHTt2XLdscnKyEhISPDYAAIB0M4y/xolatfl4r+5t0xB1uVwaNGiQ6tWrp0qVKl23XGRkpKZOnaqvv/5a06dPl8vlUt26dXXkyJE0y48aNUqhoaHurUSJEpl1CQAAAEgHwzRN0+4gJOmpp57SokWL9NNPPyk8PNzr4y5duqTy5curQ4cOeuWVV1J9n5ycrOTkZPfnhIQElShRQvHx8QoJCbEkdgAAkLkSEhIUGhpqy+9v97nHNFNIUA5r675wSaHPLPTZdsltsXxTv379tGDBAv3www/paoRKUo4cOVStWjXt3bs3ze8DAgIUEBBgRZgAAACwkK1d86Zpql+/fpo7d65WrFihUqVKpbsOp9Opbdu2qWjRopkQIQAAwP9YPT40M9YlzWZszYj27dtXM2fO1Ndff63g4GDFxcVJkkJDQxUUFCRJ6tSpk4oXL65Ro0ZJkl5++WXVqVNHd999t86ePavRo0fr4MGD6tGjh23XAQAAfADLN1nO1oboxIkTJUkNGjTw2D9t2jR16dJFknTo0CE5HH/9JZ05c0Y9e/ZUXFyc8uXLp+rVq2vNmjWqUKFCVoUNAAAAC9jaEPVmntSqVas8Po8bN07jxo3LpIgAAACug1d8Ws6388EAAACwzW0xax4AAOC2xxhRy/n21QMAAMA2ZEQBAAC8wRhRy5ERBQAAgC3IiAIAAHjDkQljRB2+nROkIQoAAOANuuYt59vNcAAAANiGjCgAAIA3HA7ru9J9vGvet68eAAAAtiEjCgAA4A0/SX4Wj+n0s7a67IaMKAAAAGxBRhQAAMAbjBG1nG9fPQAAAGxDRhQAAMAbrCNqORqiAAAA3vAzMmGykm83ROmaBwAAgC3IiAIAAHiDyUqW8+2rBwAAgG3IiAIAAHjBZRhyWTy5yGUwRhQAAADIcmREAQAAvOByOOSyeEyn1fVlN7599QAAALANGVEAAAAvuByZMEaUBe0BAABwM04/h5x+1nYmW11fduPbVw8AAADbkBEFAADwAl3z1iMjCgAAAFuQEQUAAPCC6XDItHi5Javry258++oBAABgGzKiAAAAXmCMqPXIiAIAAMAWZEQBAAC8QEbUejREAQAAvHClIWr1u+Z9uyFK1zwAAABsQUYUAADAC6Zhfde8aZARBQAAALIcGVEAAAAvOA2HnIa1OTyr68tufPvqAQAAYBsyogAAAF5g+SbrkREFAACALciIAgAAeIGMqPVoiAIAAHjBdDhkWrygvdX1ZTe+ffUAAACwDRlRAAAAL9A1bz0yogAAALAFGVEAAAAvuBwOuSwe02l1fdmNb189AAAAbENGFAAAwAsuw5DLsHiMqMX1ZTdkRAEAAGALMqIAAABeYNa89ciIAgAA4KYiIiI0fvx4S+skIwoAAOAFMxNmzfv6m5VoiAIAAHjBKUNOiycXOUXXPAAAALKJxMREdezYUblz51bRokU1btw4NWjQQIMGDZIknTlzRp06dVK+fPmUK1cuNW3aVHv27PGo48svv1TFihUVEBCgiIgIjRkzxuP748ePq2XLlgoKClKpUqU0Y8aMTLkWGqIAAABeuDJZyWHxdiUjmpCQ4LElJydfN47Bgwdr9erVmj9/vpYtW6Yff/xRmzdvdn/fpUsXbdy4UfPnz9fatWtlmqaaNWumS5cuSZI2bdqkxx57TO3bt9e2bds0YsQIvfTSS4qNjfWo4/Dhw1q5cqXmzJmjCRMm6Pjx45bfU7rmAQAAbFaiRAmPz8OHD9eIESNSlUtMTNTHH3+smTNnqnHjxpKkadOmqVixYpKkPXv2aP78+Vq9erXq1q0rSZoxY4ZKlCihefPm6dFHH9XYsWPVuHFjvfTSS5Kke+65Rzt37tTo0aPVpUsX/fbbb1q0aJF+/vln1axZU5L00UcfqXz58pZfNw1RAAAAL5iGIdPiMaJX6zt8+LBCQkLc+wMCAtIs//vvv+vSpUuqVauWe19oaKgiIyMlSbt27ZK/v79q167t/r5AgQKKjIzUrl273GVatWrlUW+9evU0fvx4OZ1Odx3Vq1d3f1+uXDnlzZv31i42DXTNW2jDhg06cOCA3WHgDjN79uxUY3eAW3XkyBF99NFHSkhIsDsU3EESEhLUvXt3zZ8/3+5Qsp2QkBCP7XoN0TuNrQ3RUaNGqWbNmgoODlbhwoXVunVr7d69+6bHffHFFypXrpwCAwNVuXJlLVy4MAuivb4mTZrI4Z9DtWrVUqnSpeXvn0OzZ8+2NSZkf/Xq1ZPhcKjD44/r2WefleHvr6CgILvDQja3c+dOGYahu0pEqEePHsoXWkD+/v43HI8GeMMwDOULLaCpU6eqdas2MgxDnTt3tjssS11d0N7qLT1Kly6tHDlyaMOGDe598fHx+u233yRJ5cuX1+XLl7V+/Xr396dOndLu3btVoUIFd5nVq1d71Lt69Wrdc8898vPzU7ly5XT58mVt2rTJ/f3u3bt19uzZ9N6ym7K1Ifr999+rb9++WrdunZYtW6ZLly7poYceUlJS0nWPWbNmjTp06KDu3btry5Ytat26tVq3bq3t27dnYeR/adWqlZavWKGge+9VsbffVuF//1sKDVWHfz3hVaMaSMt//vMfrVm/Xv6FCqnICy+o2JtvKqhSZV1MTla+fPnsDg/ZWMWKleSQv6L1tB7RZ6qqTnI6ncqVK5fdoSEbM/7XvVxGMWqrGWqolxWgEE3/ZKZ27txpc3R3luDgYHXu3FnPPfecVq5cqR07dqh79+5yOBwyDENly5ZVq1at1LNnT/3000/65Zdf9K9//UvFixd3d8c/88wzWr58uV555RX99ttv+vjjj/Xee+/p2WeflSRFRkbqH//4h3r37q3169dr06ZN6tGjR6YkQwzTNE3La82gEydOqHDhwvr+++/1wAMPpFmmXbt2SkpK0oIFC9z76tSpo6ioKE2aNOmm50hISFBoaKji4+M9xmJklMM/hwLKl1epr76U4ecnSUreu1f7/vEPlSldWnv37r3lc8D3GIYh+fnp7hUrlDM8XJJkpqRoX/PmStl/QKbLaXOEyI7atWunzz//XC00STXU271/iZ7VOo3XNwu+VvPmzW2MENlRQkKC8oUWUBk9pMe1QMb/1sU8oB8Uq/qSJCuaGlb//s7IuX/c/qLyBAdaWve5xIu6v9Kr6bquxMREPfnkk5o3b55CQkI0ZMgQzZ49W40aNdKoUaN05swZDRw4UPPnz1dKSooeeOABvfvuuypbtqy7ji+//FLDhg3Tnj17VLRoUfXv39/dEJWkuLg49ejRQ999952KFCmiV199VS+99JIGDRrkXibKCrfVZKX4+HhJUv78+a9bZu3atRo8eLDHvpiYGM2bNy/N8snJyR5dTlaPhzJNl0JbtnA3QiUp4O67FVD2Hh3a/7ul54JvyVXtXncjVJKMnDkV0qKFTk6YYGNUyM6u/ge+kjp47K+sDlqrMfrPf/5DQxTp9tprr8mly6qkDu5GqCRF6AHlVmElyfolf+xyu7xrPjg42GNdz6SkJI0cOVK9evWSJOXLl0+ffPLJDet4+OGH9fDDD1/3+7CwMI+knyQ98cQT6Y71Zm6byUoul0uDBg1SvXr1VKlSpeuWi4uLU5EiRTz2FSlSRHFxcWmWHzVqlEJDQ93btcsj3DLDoZRDhzx2uZKTdSnuqM8MNEbmSDl0SKbTM/N56cBBH38HB25FaGioJOmM9nnsP/2/z1fHjwHp0aZNGxlypHquLuiMLuiMTVHd2bZs2aJZs2Zp37592rx5szp27ChJqWbCZwe3TUO0b9++2r59u+WTfIYOHar4+Hj3dvjwYUvrD8mdS2c++0wJS5bINE05z53TsVdflSshQU8//bSl54LvyJ8/vy4fP6Zjb74p14ULMl0uxc+fr/gF38i8fNnu8JBN/fzzz3LIXwv0pM7qyn+gj2m7lmmIDPlr1qxZNkeI7KhOnToy5dIava3ftUKmTJ3XaX2j3jLl1H333Wd3iJZxGUambBnx9ttvq2rVqmrSpImSkpL0448/qmDBghZfcea7Lbrm+/XrpwULFuiHH35Q+N+6ItMSFhamY8eOeew7duyYwsLC0iwfEBCQqZnJX375RWXuLqsjffrIERIi8+JFmZcuKSIiQi+//HKmnRd3tlOnTskwDJ3+6COd+XS6jICcciUmSoahdevW2R0esqnw8HBVqlJB237dpPGKUG4VUpKOyyF/derc0e7wkI099dRT+mDih/pEjRWkAkpWvEy5ZMqlH3/80e7w7jjVqlXzmNGendmaETVNU/369dPcuXO1YsUKlSpV6qbHREdHa/ny5R77li1bpujo6MwK84YiIiKUfPGC2rRpo2DDUKG8eTXlww+1f/9+W+LBncM0TdWsWVNmSrJciYkKDg7WucREj0WKgfT65Zdf9OVXXyggIKeSdFx58uTRpi0bPF7tB6TXhAkTdPDwfhmGoQs6JZcuq3GTRpZMUrqduBwOOS3eXI7bpnPaFrZmRPv27auZM2fq66+/VnBwsHucZ2hoqHuJgE6dOql48eIaNWqUJGngwIGqX7++xowZo+bNm2v27NnauHGjJk+ebNt1+Pv766uvvrLt/Lhz/fzzz3aHgDtQmzZtdPHiRbvDwB0mPDxcLpfL7jCQzdjaDJ84caLi4+PVoEEDFS1a1L199tln7jKHDh3S0aNH3Z/r1q2rmTNnavLkyapatarmzJmjefPm3XCCEwAAwK26ncaI3ilszYh6k7JftWpVqn2PPvqoHn300UyICAAAAFnltpisBAAAcLvLjAwmGVEAAADclOlwyLR4cpHV9WU3vn31AAAAsA0ZUQAAAC/QNW89MqIAAACwBRlRAAAAL5ARtR4ZUQAAANiCjCgAAIAXXMqEjKjIiAIAAABZjowoAACAF1yGQy7D2hye1fVlNzREAQAAvOAyrJ9c5PLtnnm65gEAAGAPMqIAAABecDkMOR0WZ0Qtri+7ISMKAAAAW5ARBQAA8AKTlazn21cPAAAA25ARBQAA8IJpGDItnjVvdX3ZDRlRAAAA2IKMKAAAgBdcMix/Jaevv+KThigAAIAXXEYmvGuernkAAAAg65ERBQAA8ALLN1nPt68eAAAAtiEjCgAA4AXGiFqPjCgAAABsQUYUAADAC07DkNPiDKbV9WU3ZEQBAABgCzKiAAAAXmCMqPVoiAIAAHjBJYdcFncmW11fduPbVw8AAADbkBEFAADwhmHItLor3ce75smIAgAAwBZkRAEAALzAZCXrkREFAACALciIAgAAeMElQy5ZnBG1uL7showoAAAAbEFGFAAAwAtXxohavI6oj48RpSEKAADgBbrmrUfXPAAAAGxBRhQAAMALLN9kPTKiAAAAsAUZUQAAAC84Zchp8ZhOq+vLbsiIAgAAwBZkRAEAALzAGFHrkREFAACALciIAgAAeMGUIdPiMZ1W15fdZCgjWrp0aZ06dSrV/rNnz6p06dK3HBQAAMDtxjQcclm8mRa/qSm7ydDVHzhwQE6nM9X+5ORk/fHHH7ccFAAAAO586eqanz9/vvvPS5YsUWhoqPuz0+nU8uXLFRERYVlwAAAAtwte8Wm9dDVEW7duLUkyDEOdO3f2+C5HjhyKiIjQmDFjLAsOAAAAd650NURdLpckqVSpUtqwYYMKFiyYKUEBAADcbsiIWi9Ds+b3799vdRwAAADwMRlevmn58uVavny5jh8/7s6UXjV16tRbDgwAAOB2QkbUehlqiI4cOVIvv/yyatSooaJFi8rw8bcCAAAAIP0y1BCdNGmSYmNj9cQTT1gdDwAAwG3JaRhyWpx8s7q+7CZD64impKSobt26VscCAAAAH5KhhmiPHj00c+ZMq2MBAAC4bV0dI2r15ssy1DV/8eJFTZ48Wd99952qVKmiHDlyeHw/duxYS4IDAAC4XbjkkCtjObwb1unLMtQQ/fXXXxUVFSVJ2r59u8d3TFwCAACANzLUEF25cqUlJ//hhx80evRobdq0SUePHtXcuXPdb29Ky6pVq9SwYcNU+48ePaqwsDBLYgIAAEiLKUOmxV3pVteX3diaD05KSlLVqlX1/vvvp+u43bt36+jRo+6tcOHCmRQhAAAAMovXGdG2bdsqNjZWISEhatu27Q3LfvXVV17V2bRpUzVt2tTbENwKFy6svHnzpvs4AACAjGJBe+t53RANDQ11j/8MDQ3NtIC8ERUVpeTkZFWqVEkjRoxQvXr1rls2OTlZycnJ7s8JCQlZESIAAABuwuuG6LRp09L8c1YqWrSoJk2apBo1aig5OVlTpkxRgwYNtH79et17771pHjNq1CiNHDkyiyMFAAB3GjMTMqK+PkY0w++at0NkZKQiIyPdn+vWrat9+/Zp3Lhx+vTTT9M8ZujQoRo8eLD7c0JCgkqUKJHpsQIAAODGMtwQnTNnjj7//HMdOnRIKSkpHt9t3rz5lgPzVq1atfTTTz9d9/uAgAAFBARkWTwAAODOxBhR62Vo1vx///tfde3aVUWKFNGWLVtUq1YtFShQQL///nuGJh/diq1bt6po0aJZek4AAOB7nJKcMizefFuGMqITJkzQ5MmT1aFDB8XGxmrIkCEqXbq0hg0bptOnT3tdz7lz57R371735/3792vr1q3Knz+/7rrrLg0dOlR//PGHPvnkE0nS+PHjVapUKVWsWFEXL17UlClTtGLFCi1dujQjlwEAAAAbZagheujQIdWtW1eSFBQUpMTEREnSE088oTp16ui9997zqp6NGzd6LFB/dSxn586dFRsbq6NHj+rQoUPu71NSUvTMM8/ojz/+UK5cuVSlShV99913aS5yDwAAYCUWtLdehhqiYWFhOn36tEqWLKm77rpL69atU9WqVbV//36Zpul1PQ0aNLhh+djYWI/PQ4YM0ZAhQzISMgAAAG4zGRoj2qhRI82fP1+S1LVrVz399NN68MEH1a5dO7Vp08bSAAEAAG4HVycrWb35sgxlRCdPniyXyyVJ6tu3rwoWLKjVq1frn//8p5588klLAwQAAMCdKUMNUYfDoZSUFG3evFnHjx9XUFCQmjRpIklavHixWrZsaWmQAAAAdnOahpymtRlMq+vLbjLUEF28eLGeeOIJnTp1KtV3hmHI6fT1xQgAAABwMxkaI9q/f3899thjOnr0qFwul8dGIxQAANyJGCNqvQxlRI8dO6bBgwerSJEiVscDAABwW2L5JutlKCP6yCOPaNWqVRaHAgAAAF+SoYzoe++9p0cffVQ//vijKleurBw5cnh8P2DAAEuCAwAAuF245JArYzm8G9bpyzLUEJ01a5aWLl2qwMBArVq1SobxV1rZMAwaogAAALipDDVEX3jhBY0cOVLPP/+8HA7fbskDAADfYJqGXBYvt2T6+PJNGWpFpqSkqF27djRCAQAAkGEZakl27txZn332mdWxAAAA3LacMjJl82UZ6pp3Op166623tGTJElWpUiXVZKWxY8daEhwAAADuXBlqiG7btk3VqlWTJG3fvt3ju79PXAIAALhTmKZh+ZhOXx8jmqGG6MqVK62OAwAA4LaWGW9C8vU3KzHbCAAAALbIUEYUAADA1zhNQ06Lu9Ktri+7ISMKAAAAW5ARBQAA8AJjRK1HRhQAAAC2ICMKAADgBZZvsh4ZUQAAANiCjCgAAIAXGCNqPRqiAAAAXnCZhlwWd6VbXV92Q9c8AAAAbEFGFAAAwAuuTFjQnowoAAAAYAMyogAAAF4wJZkWTy4yLa0t+yEjCgAAAFuQEQUAAPACs+atR0YUAAAAtiAjCgAA4AWnachhcQbT6ln42Q0NUQAAAC+4zCub1XX6MrrmAQAAYAsyogAAAF4wTUOmxV3pVteX3ZARBQAAgC3IiAIAAHiB5ZusR0YUAAAAtiAjCgAA4AWXDLksfsWn1fVlN2REAQAAYAsyogAAAF5gQXvr0RAFAADwAss3WY+ueQAAANiCjCgAAIAXTJchl8vijKjF9WU3ZEQBAABgCzKiAAAAXnCahgwmK1mKjCgAAABsQUYUAADAC7zi03pkRAEAAGALMqIAAABeMJUJ64j6+Cs+aYgCAAB4ga5569E1DwAAAFuQEQUAAPCCy7yyWV2nLyMjCgAAAFuQEQUAAPCC02XIsPiVnE5e8QkAAABkPTKiAAAAXjDNTFi+iVnzAAAAQNajIWqh2NhY/fTTT3aHgTvMTz/9pLlz59odBu4wW7du1YABAxQXF2d3KLiDXLx4URMmTNDWrVvtDiVTXF1H1OrNl9naEP3hhx/UsmVLFStWTIZhaN68eTc9ZtWqVbr33nsVEBCgu+++W7GxsZke583kz59f/oahrl276oH775dhGBowYIDdYSGb69WrlwzDofvvf0Bt27aVn5FDpUqVsjssZHPfffedDMPQvdVq6N1331XxoiVkGIbOnTtnd2jI5oKCgpQ7KFh9+/bVvdWqyzAM/fe//7U7LEu5XIacFm8uJivZJykpSVWrVtX777/vVfn9+/erefPmatiwobZu3apBgwapR48eWrJkSSZHen1hYWE6e+aM6kn6RNJbkgpJmvjuu1q0aJFtcSF7i42N1UcfTlOwiipGY9VK01RU1XXgwEFVqVLF7vCQjT344ENyyF/RelqP6DNVVSdJUnBwsM2RITvLlSuXLl68qDKKUVvNUEO9rACF6OmBz5B1xw0ZpmneFkupGoahuXPnqnXr1tct8+9//1vffvuttm/f7t7Xvn17nT17VosXL/bqPAkJCQoNDVV8fLxCQkJuNWz5G4aiJK2X5Pe/fbskVZTk5++vS5cu3fI54Hv8/f1lOg311x7lU4Qk6bJSNElVdVK/yTSd9gaIbCkyMlK//fabWmiSaqi3e/8SPat1Gq+3Rr+hZ5991sYIkR1dvHhRuYOCVUYP6XEtkPG/d6cf0A+KVX2FhIQoPj7+ls9j9e/vjJy76s7N8gvOY2ndzsRz+qXCvbZc1+0gW40RXbt2rZo0aeKxLyYmRmvXrr3uMcnJyUpISPDYrGRK6qC/GqGSVF5XGqKXL1+29FzwHU6nU+GKdjdCJclfOVVR7eTweNoA7/3222+SpErq4LG/sjrIlFMvv/yyHWEhm/vqq6/k0mVVUgd3I1SSIvSAcquw5b93cWfJVg3RuLg4FSlSxGNfkSJFlJCQoAsXLqR5zKhRoxQaGureSpQoYWlMDkn7rtmXLOmIpWeBLzqjfXLJec2+vTZFgzuBn9+V/8Scuean1un/fS5evHiWx4Tsr27dujLkSPVcXdAZXdAZGcadMwbSdGXO5suyVUM0I4YOHar4+Hj3dvjwYUvrvyxpiqS5upIdTZQ0SNJZSffff7+l54LviIqKUqL+1DINUYrOyyWXtmmWtmm2DD8f/6mFDNu4caMc8tcCPamzOiRJOqbtWqYhMuSvXbt22RwhsqOIiAiZcmmN3tbvWiFTps7rtL5Rb5lyatCgQXaHiNtYtlrQPiwsTMeOHfPYd+zYMYWEhCgoKCjNYwICAhQQEJBpMf3444+qf//9aispr6QLklJ0JfPwww8/ZNp5cWfbsmWL/P39tdY5Vhs0QX4KULLiJRnavXuP3eEhm4qKilLu4CD9mbhJ4xWh3CqkJB2XQ/6qXKWC3eEhG5s8ebKe7NVHn6ixglRAyYqXKZeCcgVq7NixdodnGZcpGRYvt+S6LWbq2CdbZUSjo6O1fPlyj33Lli1TdHS0TRFJ9913n5IuXLgye15SimGoU+fOjA/FLbt8+bI6d+4slyNFlxyJKleunC5evKAyZcrYHRqysYSEBL3y6khJppJ0XJI09+sv9csvv9gbGLK1nj176tSZE8qXL58u6JRMw6nnh/5bSUlJdoeG25yts+bPnTunvXuvjHmrVq2axo4dq4YNGyp//vy66667NHToUP3xxx/65JNPJF1ZvqlSpUrq27evunXrphUrVmjAgAH69ttvFRMT49U57Zx1BwAAMuZ2mDVf4Zct8rN4qTNnYqJ2Vq3ms+0SWzOiGzduVLVq1VStWjVJ0uDBg1WtWjUNGzZMknT06FEdOnTIXb5UqVL69ttvtWzZMlWtWlVjxozRlClTvG6EAgAAZHeLFy/Wfffdp7x586pAgQJq0aKF9u37a7LYkSNH1KFDB+XPn1+5c+dWjRo1tH79evf333zzjWrWrKnAwEAVLFhQbdq0seMyJNk8RrRBgwa6UUI2rbcmNWjQQFu2bMnEqAAAAFJzmoZk8RhR5//qu3aZqxvNcUlKStLgwYNVpUoVnTt3TsOGDVObNm20detWnT9/XvXr11fx4sU1f/58hYWFafPmzXK5rkx0/fbbb9WmTRu98MIL+uSTT5SSkqKFCxdaek3pcdssaJ9V6JoHACD7uR265u/Z/EumdM3/dm/VVPuHDx+uESNGeFXHyZMnVahQIW3btk1r1qzRs88+qwMHDih//vypytatW1elS5fW9OnTbzV0S2SrWfMAAAB3osOHD3s0sG+04s+ePXs0bNgwrV+/XidPnnRnOw8dOqStW7eqWrVqaTZCJWnr1q3q2bOntcHfAhqiAAAAXnBJMizuR766MnRISIjXmd6WLVuqZMmS+vDDD1WsWDG5XC5VqlRJKSkp113O8qqbfZ/VstXyTQAAAL7s1KlT2r17t1588UU1btxY5cuX15kzZ9zfV6lSRVu3btXp06fTPL5KlSqplsK0Ew1RAAAAL7hchpwWby5X+iY/5cuXTwUKFNDkyZO1d+9erVixQoMHD3Z/36FDB4WFhal169ZavXq1fv/9d3355Zdau3atpCtjT2fNmqXhw4dr165d2rZtm958801L71N60BAFAADIJhwOh2bPnq1NmzapUqVKevrppzV69Gj39zlz5tTSpUtVuHBhNWvWTJUrV9Ybb7whPz8/SVdWH/riiy80f/58RUVFqVGjRvr555/tuhxmzQMAgNvf7TBrPuLnbXLksXbWvOtcog7Uquyz7RIyogAAALAFs+YBAAC8YJqGTIsXtLe6vuyGhigAAIAXXC79td6SlXX6MLrmAQAAYAsyogAAAF5wuQwpncsteVWnDyMjCgAAAFuQEQUAAPCC02XIJCNqKTKiAAAAsAUZUQAAAC8wRtR6ZEQBAABgCzKiAAAAXjBdVzar6/RlNEQBAAC84MyENyu5fPzNSnTNAwAAwBZkRAEAALxgmoblk4t8/V3zZEQBAABgCzKiAAAAXnC5JIPJSpYiIwoAAABbkBEFAADwgpkJC9pb/crQ7IaMKAAAAGxBRhQAAMALLpchg4yopWiIAgAAeMHJZCXL0TUPAAAAW5ARBQAA8AJd89YjIwoAAABbkBEFAADwguk0JKfFGVGL68tuyIgCAADAFmREAQAAvMCseeuREQUAAIAtyIgCAAB4gVnz1qMhCgAA4AXTzISudNPi+rIZuuYBAABgCzKiAAAA3qBr3nJkRAEAAGALMqIAAABe8HNKhuUL2ktOS2vMXsiIAgAAwBZkRAEAALzgyKQF7cmIAgAAAFmMjCgAAIAXHMyatxwNUQAAAC8YziubpXy5X150zQMAAMAmZEQBAAC84EfXvOXIiAIAAMAWZEQBAAC8kFnLN/kyMqIAAACwBRlRAAAALzhchvWv+GSMKAAAAJD1yIgCAAB4wciEWfPy8YwoDVEAAAAvOJxXNiu5WNAeAAAAyHpkRAEAALzgcBly0DVvKTKiAAAAsAUZUQAAAC9kxhhRMUbUfu+//74iIiIUGBio2rVr6+eff75u2djYWBmG4bEFBgZmYbQAAACwgu0Z0c8++0yDBw/WpEmTVLt2bY0fP14xMTHavXu3ChcunOYxISEh2r17t/uzYfj2+AoAAJD5MmP5JsuXg8pmbM+Ijh07Vj179lTXrl1VoUIFTZo0Sbly5dLUqVOve4xhGAoLC3NvRYoUycKIAQAAYAVbG6IpKSnatGmTmjRp4t7ncDjUpEkTrV279rrHnTt3TiVLllSJEiXUqlUr7dix47plk5OTlZCQ4LEBAACkl58zczZfZmtD9OTJk3I6nakymkWKFFFcXFyax0RGRmrq1Kn6+uuvNX36dLlcLtWtW1dHjhxJs/yoUaMUGhrq3kqUKGH5dQAAgDufw5QcLos30+6rspftXfPpFR0drU6dOikqKkr169fXV199pUKFCumDDz5Is/zQoUMVHx/v3g4fPpzFEQMAACAttk5WKliwoPz8/HTs2DGP/ceOHVNYWJhXdeTIkUPVqlXT3r170/w+ICBAAQEBtxwrAADwbQ6nIYfT4slFVteXzdiaEc2ZM6eqV6+u5cuXu/e5XC4tX75c0dHRXtXhdDq1bds2FS1aNLPCBAAAQCawffmmwYMHq3PnzqpRo4Zq1aql8ePHKykpSV27dpUkderUScWLF9eoUaMkSS+//LLq1Kmju+++W2fPntXo0aN18OBB9ejRw87LAAAAdzjDdWWzuk5fZntDtF27djpx4oSGDRumuLg4RUVFafHixe4JTIcOHZLD8Vfi9syZM+rZs6fi4uKUL18+Va9eXWvWrFGFChXsugQAAABkgGGapk/N10pISFBoaKji4+MVEhJidzgAAMALdv7+vnru0iOPyhFo7bldFxP0+/CiPtsuyXaz5gEAAHBnsL1rHgAAIDswnJLD4gXoTRa0BwAAALIeGVEAAAAvOFyGHC5r1/00La4vu6EhCgAA4AXDeWWzuk5fRtc8AAAAbEFGFAAAwAt+LkN+Vr+S08e75smIAgAAwBZkRAEAALzgYPkmy5ERBQAAgC3IiAIAAHjB4bqyWcm0uL7showoAAAAbEFGFAAAwAuG05Bh8ax5q+vLbmiIAgAAeMHPeWWzFJOVAAAAgKxHRhQAAMALLN9kPTKiAAAAsAUZUQAAAC8YLkMOiycXuXjFJwAAAJD1yIgCAAB4wXBd2ayu05eREQUAAIAtyIgCAAB4ITPWEfX1WfM0RAEAALzgcFo/Wcnq+rIbuuYBAABgCzKiAAAAXsiMBe2tri+7ISMKAAAAW5ARBQAA8AIZUeuREQUAAIAtyIgCAAB4gVnz1iMjCgAAAFuQEQUAAPCCw5UJY0R9/BWfNEQBAAC84HBKDov7kpmsBAAAANiAjCgAAIAXjEzIiBpkRAEAAICsR0YUAADACw6nIYeD5ZusREYUAAAAtiAjCgAA4AVmzVuPjCgAAABsQUYUAADAC2RErUdDFAAAwAu8Wcl6dM0DAADAFmREAQAAvOBwGnIYLN9kJTKiAAAAsAUZUQAAAC84nJLF69n7/GQlMqIAAACwBRlRAAAAL5ARtR4ZUQAAANiCjCgAAIAXyIhaj4YoAACAF4xMaIgaPt4QpWseAAAAtiAjCgAA4AWHy7B8AXqHiwXtAQAAgCxHRhQAAMALDqf1GTxfn6xERhQAAAC2ICMKAADgBTKi1iMjCgAAAFuQEQUAAPACGVHrkRG10NixY7Vo0SK7w8AdZsqUKRo2bJjdYeAOExcXp88++0znzp2zOxTcQRISEtS9e3fNnz/f7lAyhcOZOZsvuy0aou+//74iIiIUGBio2rVr6+eff75h+S+++ELlypVTYGCgKleurIULF2ZRpGkLCgpSDsPQM888o+bNmslhGOrQoYOtMSH7q1SpkgzDoZ49e+mVV16Rn5FD/v50YuDW7N27V35+fipWNFzt27dXaHA+BQYGKiUlxe7QkM0ZhqF8oQU0depUtW7VRoZhqHPnznaHhduc7Q3Rzz77TIMHD9bw4cO1efNmVa1aVTExMTp+/Hia5desWaMOHTqoe/fu2rJli1q3bq3WrVtr+/btWRz5FcHBwUq+eFF1JX0i6S1JBSXNmT1bs2fPtiUmZH99+vTRrh27FayiitFYtdI0FVV1OZ0u5cqVy+7wkI3dU/YeyeVQtJ7WI/pMVdVJycnJyp07t92hIRszjCuLspdRjNpqhhrqZQUoRNM/mamdO3faHJ11yIhazzBN07QzgNq1a6tmzZp67733JEkul0slSpRQ//799fzzz6cq365dOyUlJWnBggXufXXq1FFUVJQmTZp00/MlJCQoNDRU8fHxCgkJueX4/Q1D1SStk+T3v327JFWUJMOQy+W65XPA9xiGIYf81V97lE8RkqTLStEkVdVJ7ZZp8lwh/Xr16qUPP/xQLTRJNdTbvX+JntU6jdd3y5eqUaNGNkaI7CghIUH5QguojB7S41ogQ1capQf0g2JVX5JkRVPD6t/fGTl3tzJnldPP2nOnOBM0dV9eW67rdmBrRjQlJUWbNm1SkyZN3PscDoeaNGmitWvXpnnM2rVrPcpLUkxMzHXLJycnKyEhwWOzkimpvf5qhEpSeUmVZM0/PPiucEW7G6GS5K+cqqh2cjDHEBk0Z84cSVIleQ4dqqwOMuVkLDIy5LXXXpNLl1VJHdyNUEmK0APKrcI2RmY9h1NyXLZ48/GMqK0N0ZMnT8rpdKpIkSIe+4sUKaK4uLg0j4mLi0tX+VGjRik0NNS9lShRwprg/8dP0r5r9iVLOmzpWeCLzmifXHJes2+vTdHgTpA/f35JV56tvzv9v8+VKlXK8piQ/bVp00aGHKmeqws6ows6Y1NUyC5sHyOa2YYOHar4+Hj3dviwtU3ES5KmSJqrK9nRREmDJJ2VVKFCBUvPBd+RO3duJepPLdMQpei8XHJpm2Zpm2bLpUt2h4ds6qeffpJD/lqg3jqrQ5KkY9quZRoiQ35eDW8CrlWnTh2ZcmmN3tbvWiFTps7rtL5Rb5ly6r777rM7RMs4nEambL7M1j6+ggULys/PT8eOHfPYf+zYMYWFhaV5TFhYWLrKBwQEKCAgwJqA07Bw4UK1aNZMbSXllXRB0tW5pzt27Mi08+LOdu7cORmGobUaqw2aID8FKFnxkgytWrXK7vCQTYWFhSm6Xm2tWb1O4xWh3CqkJB2/Mh55QF+7w0M29tRTT+mDiR/qEzVWkAooWfEy5ZIpl3788Ue7w8NtzNaMaM6cOVW9enUtX77cvc/lcmn58uWKjo5O85jo6GiP8pK0bNmy65bPbE2bNlViUpKCg4N1Vle65Zs2a8b4UNwy0zRVrlw5XdZFJSteAQEBSkiIV/369e0ODdnYTz/9pEWLv1WePLl1wXFSBQoU0LYdv+idd96xOzRkYxMmTNDBw/tlGIYu6JRcuqzGTRrdcb8LjUyYMW/4+BhR22c9DB48WJ07d1aNGjVUq1YtjR8/XklJSerataskqVOnTipevLhGjRolSRo4cKDq16+vMWPGqHnz5po9e7Y2btyoyZMn23YNuXLlsnwSFCBJu3btsjsE3IFiYmKUmJhodxi4w4SHh9/xK8U4nJLD4ra1486+ZTdle0O0Xbt2OnHihIYNG6a4uDhFRUVp8eLF7glJhw4dksPxV+K2bt26mjlzpl588UX95z//UdmyZTVv3jwG2QMAAGQztq8jmtXsXIcMAABkzO2wjmjfgvEKcFh77mRXgt4/6bvtkjt+1jwAAABuT7Z3zQMAAGQHjBG1HhlRAAAA2IKMKAAAgBccrkzIiPrUTJ3UyIgCAADAFmREAQAAvOBwSg6L38hJRhQAAACwARlRAAAALzgukxG1Gg1RAAAAL9A1bz265gEAAGALMqIAAABeICNqPTKiAAAAsAUNUQAAAC8Yrv9lRS3cjHS+4jMiIkLjx4/32BcVFaURI0ZcidEwNGXKFLVp00a5cuVS2bJlNX/+fHdZp9Op7t27q1SpUgoKClJkZKTeeeedVOeZOnWqKlasqICAABUtWlT9+vVzf3f27Fn17t1bRYoUUWBgoCpVqqQFCxak70L+x+e65k3zSg48ISHB5kgAAIC3rv7evvp73A7Jsr7tcLXOa9slAQEBCggIyFCdI0eO1FtvvaXRo0fr3XffVceOHXXw4EHlz59fLpdL4eHh+uKLL1SgQAGtWbNGvXr1UtGiRfXYY49JkiZOnKjBgwfrjTfeUNOmTRUfH6/Vq1dLklwul5o2barExERNnz5dZcqU0c6dO+Xn55exG2D6mMOHD5uS2NjY2NjY2LLhdvjw4SxvO1y4cMEMCwvLtGvKkydPqn3Dhw9PM5aSJUua48aN89hXtWpVd3lJ5osvvuj+7ty5c6Ykc9GiRde9vr59+5oPP/yw+3OxYsXMF154Ic2yS5YsMR0Oh7l7927vbt5N+FxGtFixYjp8+LCCg4NlGNaOOE5ISFCJEiV0+PBhhYSEWFr3nYZ75T3ulfe4V97jXqUP98t7mXWvTNNUYmKiihUrZlmd3goMDNT+/fuVkpKSKfWbppmqTZLRbKgkValSxf3n3LlzKyQkRMePH3fve//99zV16lQdOnRIFy5cUEpKiqKioiRJx48f159//qnGjRunWffWrVsVHh6ue+65J8Px/Z3PNUQdDofCw8Mz9RwhISH8oPIS98p73Cvvca+8x71KH+6X9zLjXoWGhlpaX3oEBgYqMDDQtvNf5XA4Ug1PuHTpksfnHDlyeHw2DEMu15XBqLNnz9azzz6rMWPGKDo6WsHBwRo9erTWr18vSQoKCrrh+W/2fXoxWQkAACCbKFSokI4ePer+nJCQoP3793t9/OrVq1W3bl316dNH1apV09133619+/a5vw8ODlZERISWL1+e5vFVqlTRkSNH9Ntvv2X8Iv6GhigAAEA20ahRI3366af68ccftW3bNnXu3DldE4XKli2rjRs3asmSJfrtt9/00ksvacOGDR5lRowYoTFjxui///2v9uzZo82bN+vdd9+VJNWvX18PPPCAHn74YS1btkz79+/XokWLtHjx4gxdDw1RCwUEBGj48OG3NK7DV3CvvMe98h73ynvcq/ThfnmPe5W5hg4dqvr166tFixZq3ry5WrdurTJlynh9fO/evdW2bVu1a9dOtWvX1qlTp9SnTx+PMp07d9b48eM1YcIEVaxYUS1atNCePXvc33/55ZeqWbOmOnTooAoVKmjIkCFyOp0Zuh7DvHagAQAAAJAFyIgCAADAFjREAQAAYAsaogAAALAFDVEAAADYgoZoOr3//vuKiIhQYGCgateurZ9//vmG5b/44guVK1dOgYGBqly5shYuXJhFkdovPfcqNjZWhmF4bLfDwsFZ4YcfflDLli1VrFgxGYahefPm3fSYVatW6d5771VAQIDuvvtuxcbGZnqct4P03qtVq1aleq4Mw1BcXFzWBGyTUaNGqWbNmgoODlbhwoXVunVr7d69+6bH+erPq4zcL1/9mTVx4kRVqVLFvVh9dHS0Fi1adMNjfPW5gndoiKbDZ599psGDB2v48OHavHmzqlatqpiYGI/XZv3dmjVr1KFDB3Xv3l1btmxR69at1bp1a23fvj2LI8966b1X0pW3cBw9etS9HTx4MAsjtk9SUpKqVq2q999/36vy+/fvV/PmzdWwYUNt3bpVgwYNUo8ePbRkyZJMjtR+6b1XV+3evdvj2SpcuHAmRXh7+P7779W3b1+tW7dOy5Yt06VLl/TQQw8pKSnpusf48s+rjNwvyTd/ZoWHh+uNN97Qpk2btHHjRjVq1EitWrXSjh070izvy88VvGTJG+t9RK1atcy+ffu6PzudTrNYsWLmqFGj0iz/2GOPmc2bN/fYV7t2bbN3796ZGuftIL33atq0aWZoaGgWRXf7kmTOnTv3hmWGDBliVqxY0WNfu3btzJiYmEyM7Pbjzb1auXKlKck8c+ZMlsR0uzp+/Lgpyfz++++vW8aXf15dy5v7xc+sv+TLl8+cMmVKmt/xXOFmyIh6KSUlRZs2bVKTJk3c+xwOh5o0aaK1a9emeczatWs9yktSTEzMdcvfKTJyryTp3LlzKlmypEqUKHHD/2H7Ol99rm5FVFSUihYtqgcffFCrV6+2O5wsFx8fL0nKnz//dcvwXP3Fm/sl8TPL6XRq9uzZSkpKUnR0dJpleK5wMzREvXTy5Ek5nU4VKVLEY3+RIkWuO94sLi4uXeXvFBm5V5GRkZo6daq+/vprTZ8+XS6XS3Xr1tWRI0eyIuRs5XrPVUJCgi5cuGBTVLenokWLatKkSfryyy/15ZdfqkSJEmrQoIE2b95sd2hZxuVyadCgQapXr54qVap03XK++vPqWt7eL1/+mbVt2zblyZNHAQEBevLJJzV37lxVqFAhzbI8V7gZf7sDACQpOjra43/UdevWVfny5fXBBx/olVdesTEyZGeRkZGKjIx0f65bt6727duncePG6dNPP7UxsqzTt29fbd++XT/99JPdoWQL3t4vX/6ZFRkZqa1btyo+Pl5z5sxR586d9f3331+3MQrcCBlRLxUsWFB+fn46duyYx/5jx44pLCwszWPCwsLSVf5OkZF7da0cOXKoWrVq2rt3b2aEmK1d77kKCQlRUFCQTVFlH7Vq1fKZ56pfv35asGCBVq5cqfDw8BuW9dWfV3+Xnvt1LV/6mZUzZ07dfffdql69ukaNGqWqVavqnXfeSbMszxVuhoaol3LmzKnq1atr+fLl7n0ul0vLly+/7tiY6Ohoj/KStGzZsuuWv1Nk5F5dy+l0atu2bSpatGhmhZlt+epzZZWtW7fe8c+VaZrq16+f5s6dqxUrVqhUqVI3PcaXn6uM3K9r+fLPLJfLpeTk5DS/8+XnCl6ye7ZUdjJ79mwzICDAjI2NNXfu3Gn26tXLzJs3rxkXF2eapmk+8cQT5vPPP+8uv3r1atPf3998++23zV27dpnDhw83c+TIYW7bts2uS8gy6b1XI0eONJcsWWLu27fP3LRpk9m+fXszMDDQ3LFjh12XkGUSExPNLVu2mFu2bDElmWPHjjW3bNliHjx40DRN03z++efNJ554wl3+999/N3PlymU+99xz5q5du8z333/f9PPzMxcvXmzXJWSZ9N6rcePGmfPmzTP37Nljbtu2zRw4cKDpcDjM7777zq5LyBJPPfWUGRoaaq5atco8evSoezt//ry7DD+v/pKR++WrP7Oef/558/vvvzf3799v/vrrr+bzzz9vGoZhLl261DRNniukHw3RdHr33XfNu+66y8yZM6dZq1Ytc926de7v6tevb3bu3Nmj/Oeff27ec889Zs6cOc2KFSua3377bRZHbJ/03KtBgwa5yxYpUsRs1qyZuXnzZhuiznpXlxi6drt6fzp37mzWr18/1TFRUVFmzpw5zdKlS5vTpk3L8rjtkN579eabb5plypQxAwMDzfz585sNGjQwV6xYYU/wWSiteyTJ4znh59VfMnK/fPVnVrdu3cySJUuaOXPmNAsVKmQ2btzY3Qg1TZ4rpJ9hmqaZdflXAAAA4ArGiAIAAMAWNEQBAABgCxqiAAAAsAUNUQAAANiChigAAABsQUMUAAAAtqAhCgAAAFvQEAUAAIAtaIgCsEWDBg00aNCgTD1HRESExo8fn6nnAABknL/dAQBAZtmwYYNy585tdxgAgOugIQrgjlWoUCG7QwAA3ABd8wBsc/nyZfXr10+hoaEqWLCgXnrpJZmmKUkyDEPz5s3zKJ83b17FxsZKkho1aqR+/fp5fH/ixAnlzJlTy5cvl5S6a94wDE2ZMkVt2rRRrly5VLZsWc2fP9+jjvnz56ts2bIKDAxUw4YN9fHHH8swDJ09e9bSawcA0BAFYKOPP/5Y/v7++vnnn/XOO+9o7NixmjJlilfH9ujRQzNnzlRycrJ73/Tp01W8eHE1atTouseNHDlSjz32mH799Vc1a9ZMHTt21OnTpyVJ+/fv1yOPPKLWrVvrl19+Ue/evfXCCy/c2kUCAK6LhigA25QoUULjxo1TZGSkOnbsqP79+2vcuHFeHdu2bVtJ0tdff+3eFxsbqy5dusgwjOse16VLF3Xo0EF33323Xn/9dZ07d04///yzJOmDDz5QZGSkRo8ercjISLVv315dunTJ+AUCAG6IhigA29SpU8ej0RgdHa09e/bI6XTe9NjAwEA98cQTmjp1qiRp8+bN2r59+00bjlWqVHH/OXfu3AoJCdHx48clSbt371bNmjU9yteqVcvbywEApBOTlQDclgzDcI8XverSpUsen3v06KGoqCgdOXJE06ZNU6NGjVSyZMkb1psjR45U53G5XNYEDQBIFzKiAGyzfv16j8/r1q1T2bJl5efnp0KFCuno0aPu7/bs2aPz5897lK9cubJq1KihDz/8UDNnzlS3bt1uKZ7IyEht3LjRY9+GDRtuqU4AwPXREAVgm0OHDmnw4MHavXu3Zs2apXfffVcDBw6UdGVW/HvvvactW7Zo48aNevLJJ1NlM6UrWdE33nhDpmmqTZs2txRP79699X//93/697//rd9++02ff/65e5b+jcadAgAyhoYoANt06tRJFy5cUK1atdS3b18NHDhQvXr1kiSNGTNGJUqU0P3336/HH39czz77rHLlypWqjg4dOsjf318dOnRQYGDgLcVTqlQpzZkzR1999ZWqVKmiiRMnumfNBwQE3FLdAIDUDPPaQVgAkI0cOHBAZcqU0YYNG3TvvfdaXv9rr72mSZMm6fDhw5bXDQC+jslKALKlS5cu6dSpU3rxxRdVp04dyxqhEyZMUM2aNVWgQAGtXr1ao0ePTrVwPgDAGjREAWRLq1evVsOGDXXPPfdozpw5ltW7Z88evfrqqzp9+rTuuusuPfPMMxo6dKhl9QMA/kLXPAAAAGzBZCUAAADYgoYoAAAAbEFDFAAAALagIQoAAABb0BAFAACALWiIAgAAwBY0RAEAAGALGqIAAACwxf8DVsgLtwyzGIcAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 800x600 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_decision_boundary(X_test_scaled_df, y_pred_1, \"buying\", \"maint\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "599fcca1-20b3-4b16-89c4-4fba23c314ce",
   "metadata": {},
   "source": [
    "**Model 2 Decision Boundary**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 52,
   "id": "bff87fe6-d656-416c-88a7-47fd6d503a63",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAqIAAAIjCAYAAADY7XmOAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/TGe4hAAAACXBIWXMAAA9hAAAPYQGoP6dpAABi70lEQVR4nO3dd3gU5drH8d9sAkmAJHQCBAkghk6QGlC65tAOxQLIK72oVLEcOSrFhooUj1JEhKg0FQURqVIsNKkKyEFAmkroJCFAArvz/sHJ6pIAmzDJEPb7ua65Lnb2mWfuGYbk4X7KGKZpmgIAAACymcPuAAAAAOCbaIgCAADAFjREAQAAYAsaogAAALAFDVEAAADYgoYoAAAAbEFDFAAAALagIQoAAABb0BAFAACALWiI4rbSuHFjNW7c2LL6IiIi1L17d8vqg2QYhkaOHGl3GNluzZo1MgxDa9asydBxPIOZ56vPGpCT0BBFloiNjZVhGNq8ebPdodzQunXrNHLkSJ09ezZLzxMRESHDMNxb3rx5VadOHX300UdZel5cMXLkSI/7nydPHt1xxx1q06aNZsyYoeTkZLtDvKWk/hv++1a0aFE1adJES5YssTs8ALcJf7sDAKy0fPnyDB+zbt06jRo1St27d1f+/Pk9vtuzZ48cDuv+vxYVFaWnnnpKknT06FFNmzZN3bp1U3Jysvr06WPZeW5lFy5ckL+/fT96Jk+erHz58ik5OVl//PGHli1bpp49e2rChAlatGiRSpUqlSXnbdiwoS5cuKDcuXNn6Dirn8GMeumll1SmTBmZpqljx44pNjZWLVu21FdffaXWrVvbFheA2wMNUdxWMvpL/kYCAgIsra9kyZL6v//7P/fn7t27q2zZsho/fny2N0STkpKUN2/ebD2nJAUGBmb7Of/uwQcfVOHChd2fhw8frlmzZqlr16566KGHtGHDhiw5r8PhyNS1W/0MZlSLFi1Uq1Yt9+devXqpWLFimjNnjk81RO369wLc7uiah622bdumFi1aKCQkRPny5VOzZs3SbQj8/PPPatSokYKCghQeHq5XXnlFM2bMkGEYOnjwoLtcemNE33nnHVWuXFl58uRRgQIFVKtWLc2ePVvSle7aZ555RpJUpkwZdxdkap3pjc87e/asnnzySUVERCggIEDh4eHq2rWrTp48meHrL1KkiCpUqKD9+/d77He5XJowYYIqV66swMBAFStWTP369dOZM2fSlBs5cqRKlCihPHnyqEmTJvrll1/SxJ3azfrtt9/qiSeeUNGiRRUeHu7+fsmSJbr33nuVN29eBQcHq1WrVtq1a5fHueLi4tSjRw+Fh4crICBAxYsXV9u2bT3u/+bNmxUTE6PChQsrKChIZcqUUc+ePT3qSW/cnjfPQeo1rF27VkOHDlWRIkWUN29etW/fXidOnPD2lqerS5cu6t27tzZu3KgVK1Z4fLdx40b94x//UGhoqPLkyaNGjRpp7dq1aer4448/1KtXL5UoUUIBAQEqU6aMHn/8caWkpEhKf4zo3r179cADDygsLEyBgYEKDw9Xp06dFB8f7y6T3jP422+/6aGHHlLBggWVJ08e1atXT19//bVHmdTzffrpp3r11VcVHh6uwMBANWvWTPv27cv0vcqfP7+CgoLSZLWTkpL01FNPqVSpUgoICFBkZKTeeustmabpLnPw4EEZhqHY2Ng09V79XKQOpdi3b5+7tyI0NFQ9evTQ+fPnPY5NTk7Wk08+qSJFiig4OFj//Oc/9fvvv6c5x6FDh/TEE08oMjJSQUFBKlSokB566CGPZ1i69r+X1atXyzAMzZ8/P03ds2fPlmEYWr9+vRd3EUAqMqKwza5du3TvvfcqJCREzz77rHLlyqX33ntPjRs31rfffqu6detKuvILvkmTJjIMQ8OGDVPevHk1bdo0rzJF77//vgYNGqQHH3xQgwcP1sWLF/Xzzz9r48aNeuSRR9ShQwf9+uuvmjNnjsaPH+/OlBUpUiTd+s6dO6d7771Xu3fvVs+ePXX33Xfr5MmTWrhwoX7//XePTJs3Ll++rN9//10FChTw2N+vXz/FxsaqR48eGjRokA4cOKB3331X27Zt09q1a5UrVy5J0rBhw/Tmm2+qTZs2iomJ0U8//aSYmBhdvHgx3fM98cQTKlKkiIYPH66kpCRJ0scff6xu3bopJiZGb7zxhs6fP6/Jkyfrnnvu0bZt2xQRESFJeuCBB7Rr1y4NHDhQEREROn78uFasWKHDhw+7P99///0qUqSInnvuOeXPn18HDx7UF198cd174O1zkGrgwIEqUKCARowYoYMHD2rChAkaMGCAPvnkkwzd+6s9+uijmjp1qpYvX6777rtPkrRq1Sq1aNFCNWvW1IgRI+RwODRjxgw1bdpU33//verUqSNJ+vPPP1WnTh2dPXtWffv2VYUKFfTHH39o3rx5On/+fLqZ+pSUFMXExCg5OVkDBw5UWFiY/vjjDy1atEhnz55VaGhounEeO3ZM9evX1/nz5zVo0CAVKlRIH374of75z39q3rx5at++vUf5119/XQ6HQ08//bTi4+P15ptvqkuXLtq4caNX9yU+Pl4nT56UaZo6fvy43nnnHZ07d84js2+apv75z39q9erV6tWrl6KiorRs2TI988wz+uOPPzR+/HivzpWehx9+WGXKlNHo0aO1detWTZs2TUWLFtUbb7zhLtO7d2/NnDlTjzzyiOrXr69Vq1apVatWaeratGmT1q1bp06dOik8PFwHDx7U5MmT1bhxY/3yyy/KkyePR/mr/700btxYpUqV0qxZs9Lc51mzZqlcuXKKjo7O9LUCPskEssCMGTNMSeamTZuuWaZdu3Zm7ty5zf3797v3/fnnn2ZwcLDZsGFD976BAweahmGY27Ztc+87deqUWbBgQVOSeeDAAff+Ro0amY0aNXJ/btu2rVm5cuXrxjpmzJg09aQqXbq02a1bN/fn4cOHm5LML774Ik1Zl8t13fOULl3avP/++80TJ06YJ06cMHfs2GE++uijpiSzf//+7nLff/+9KcmcNWuWx/FLly712B8XF2f6+/ub7dq18yg3cuRIU5JH3Kl/H/fcc495+fJl9/7ExEQzf/78Zp8+fTzqiIuLM0NDQ937z5w5Y0oyx4wZc83rmz9//g3/zk3TNCWZI0aMcH/29jlIvYbmzZt73Osnn3zS9PPzM8+ePXvd844YMcKUZJ44cSLd71OvsX379qZpXvn7LF++vBkTE+NxvvPnz5tlypQx77vvPve+rl27mg6HI91rTz129erVpiRz9erVpmma5rZt20xJ5meffXbduK9+BocMGWJKMr///nv3vsTERLNMmTJmRESE6XQ6Pc5XsWJFMzk52V327bffNiWZO3bsuO55U+/31VtAQIAZGxvrUXbBggWmJPOVV17x2P/ggw+ahmGY+/btM03TNA8cOGBKMmfMmJHmfFc/F6l/Xz179vQo1759e7NQoULuz9u3bzclmU888YRHuUceeSRNnefPn09z3vXr15uSzI8++ijNtV/978U0TXPYsGFmQECAx/N2/Phx09/f3+NcALxD1zxs4XQ6tXz5crVr105ly5Z17y9evLgeeeQR/fDDD0pISJAkLV26VNHR0YqKinKXK1iwoLp06XLD8+TPn1+///67Nm3aZEncn3/+uapXr54mGyJd6Vq8keXLl6tIkSIqUqSIqlatqo8//lg9evTQmDFj3GU+++wzhYaG6r777tPJkyfdW82aNZUvXz6tXr1akrRy5UpdvnxZTzzxhMc5Bg4ceM3z9+nTR35+fu7PK1as0NmzZ9W5c2ePc/n5+alu3brucwUFBSl37txas2ZNmuEBqVInei1atEiXLl264b2QMvYcpOrbt6/Hvb733nvldDp16NAhr855Lfny5ZMkJSYmSpK2b9+uvXv36pFHHtGpU6fc9yYpKUnNmjXTd999J5fLJZfLpQULFqhNmzYeYylTXeu5SM14Llu2LE1X8/UsXrxYderU0T333OMRe9++fXXw4EH98ssvHuV79OjhkZG99957JV3p3vfGxIkTtWLFCq1YsUIzZ85UkyZN1Lt3b49M9+LFi+Xn56dBgwZ5HPvUU0/JNM2bmmX/2GOPeXy+9957derUKfdzsXjxYklKc+4hQ4akqSsoKMj950uXLunUqVO68847lT9/fm3dujVN+av/vUhS165dlZycrHnz5rn3ffLJJ7p8+bJHlhiAd2iIwhYnTpzQ+fPnFRkZmea7ihUryuVy6ciRI5KujOu6884705RLb9/V/vWvfylfvnyqU6eOypcvr/79+6c7vs9b+/fvV5UqVTJ9fN26dbVixQotXbpUb731lvLnz68zZ854NBT27t2r+Ph4FS1a1N1oTd3OnTun48ePS5K74XX1fShYsGCarv5UZcqU8fi8d+9eSVLTpk3TnGv58uXucwUEBOiNN97QkiVLVKxYMTVs2FBvvvmm4uLi3HU1atRIDzzwgEaNGqXChQurbdu2N1wWKSPPQao77rjD43PqtV6rgeytc+fOSZKCg4Ml/XVvunXrlubeTJs2TcnJyYqPj9eJEyeUkJCQ4eeiTJkyGjp0qKZNm6bChQsrJiZGEydO9Bgfmp5Dhw5d836lfv93N3u/6tSpo+bNm6t58+bq0qWLvv76a1WqVEkDBgxwj389dOiQSpQo4b53N4opI24U/6FDh+RwOFSuXDmPcundowsXLmj48OHucayFCxdWkSJFdPbs2XTv+9X/XiSpQoUKql27tmbNmuXeN2vWLNWrV8+rn0kAPDFGFLe1ihUras+ePVq0aJGWLl2qzz//XJMmTdLw4cM1atSobI+ncOHCat68uSQpJiZGFSpUUOvWrfX2229r6NChkq5MQCpatKjHL7q/u9b4VW/8PSOUei7pyjjRsLCwNOX/PiFlyJAhatOmjRYsWKBly5bpxRdf1OjRo7Vq1SrVqFFDhmFo3rx52rBhg7766iv3skhjx47Vhg0b3BnHm3V1hiqV+bdJMZmxc+dOSX817FPvzZgxYzyy8X+XL18+nT59OtPnHDt2rLp3764vv/xSy5cv16BBgzR69Ght2LDBYzLZzbD6fjkcDjVp0kRvv/229u7dq8qVK3t97LWyw06n85rHWBn/wIEDNWPGDA0ZMkTR0dEKDQ2VYRjq1KmT++/7767+95Kqa9euGjx4sH7//XclJydrw4YNevfddzMcDwAaorBJkSJFlCdPHu3ZsyfNd//973/lcDjc6zmWLl063Vm+3s78zZs3rzp27KiOHTsqJSVFHTp00Kuvvqphw4YpMDDQqy71VOXKlXM3WKzQqlUrNWrUSK+99pr69eunvHnzqly5cvrmm2/UoEGDa/4ilK7cF+nKffh75ubUqVNeZ7tSs0hFixZ1N5BvVP6pp57SU089pb179yoqKkpjx47VzJkz3WXq1aunevXq6dVXX9Xs2bPVpUsXzZ07V717905TX0aeg6z28ccfS7ryHwTpr3sTEhJy3XtTpEgRhYSEZPq5qFq1qqpWraoXXnhB69atU4MGDTRlyhS98sor6ZYvXbr0Ne9X6vdZ7fLly5L+yiKXLl1a33zzjRITEz2yolfHlJrNvPrlETeTMS1durRcLpf279/vkQVN7x7NmzdP3bp109ixY937Ll68mOGXWXTq1ElDhw7VnDlzdOHCBeXKlUsdO3bM9DUAvoyuedjCz89P999/v7788kuPpVOOHTum2bNn65577lFISIikKw2D9evXa/v27e5yp0+fvmbG8O9OnTrl8Tl37tyqVKmSTNN0j2NMXRvQm19GDzzwgH766ad0l2/JbIbpX//6l06dOqX3339f0pVZwk6nUy+//HKaspcvX3bH2axZM/n7+2vy5MkeZTKSmYmJiVFISIhee+21dMd1pi6LdP78+TQz8cuVK6fg4GB31/uZM2fS3IPUTOK1uucz8hxkpdmzZ2vatGmKjo5Ws2bNJEk1a9ZUuXLl9NZbb7kbXH+Xem8cDofatWunr776Kt03iV3ruUhISHA36FJVrVpVDofjusMZWrZsqR9//NFjmaCkpCRNnTpVERERqlSp0o0v+CZcunRJy5cvV+7cud1d7y1btpTT6Uzz7I0fP16GYahFixaSrjTqCxcurO+++86j3KRJkzIdT2rd//nPfzz2T5gwIU1ZPz+/NH8f77zzznUzsukpXLiwWrRooZkzZ2rWrFn6xz/+keEVMwBcQUYUWWr69OlaunRpmv2DBw/WK6+8ohUrVuiee+7RE088IX9/f7333ntKTk7Wm2++6S777LPPaubMmbrvvvs0cOBA9/JNd9xxh06fPn3djOb999+vsLAwNWjQQMWKFdPu3bv17rvvqlWrVu7MTc2aNSVJzz//vDp16qRcuXKpTZs26S5e/cwzz2jevHl66KGH1LNnT9WsWVOnT5/WwoULNWXKFFWvXj3D96hFixaqUqWKxo0bp/79+6tRo0bq16+fRo8ere3bt+v+++9Xrly5tHfvXn322Wd6++239eCDD6pYsWIaPHiwxo4dq3/+85/6xz/+oZ9++klLlixR4cKFvcr0hoSEaPLkyXr00Ud19913q1OnTipSpIgOHz6sr7/+Wg0aNNC7776rX3/9Vc2aNdPDDz+sSpUqyd/fX/Pnz9exY8fUqVMnSdKHH36oSZMmqX379ipXrpwSExP1/vvvKyQkRC1btrxmDN4+B1aZN2+e8uXLp5SUFPebldauXavq1avrs88+c5dzOByaNm2aWrRoocqVK6tHjx4qWbKk/vjjD61evVohISH66quvJEmvvfaali9frkaNGqlv376qWLGijh49qs8++0w//PBDmjd2SVeWhhowYIAeeugh3XXXXbp8+bI+/vhj+fn56YEHHrhm/M8995zmzJmjFi1aaNCgQSpYsKA+/PBDHThwQJ9//rnlb2FasmSJO7N5/PhxzZ49W3v37tVzzz3n/k9CmzZt1KRJEz3//PM6ePCgqlevruXLl+vLL7/UkCFDPMZv9u7dW6+//rp69+6tWrVq6bvvvtOvv/6a6fiioqLUuXNnTZo0SfHx8apfv75WrlyZbo9J69at9fHHHys0NFSVKlXS+vXr9c0336hQoUIZPm/Xrl314IMPSlK6/2kE4CXb5uvjtnatpV9StyNHjpimaZpbt241Y2JizHz58pl5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gD766KPr1vHAAw/ogQceuOb3YWFhHkk/SXr00UczHOuN3DKTlVwul4YMGaIGDRqoSpUq1ywXFxenYsWKeewrVqyY4uLi0i0/evRohYaGurerl0e4WYb8dFr7PfZdVrISdMRnBhoja6QcPizT6Zn5vHTwkI+/gwM3IzQ0VJJ05qqfWak/w1LHjwEZ0b59exlypHmuLuiMLuiMTVHd3rZt26Y5c+Zo//792rp1q7p06SJJaWbC5wS3TEO0f//+2rlzp+WTfIYNG6b4+Hj3duTIEUvrzxcSpK2apt2aL1OmkpWopRqiizqrJ5980tJzwXcULFhQl48f07E33pDrwgWZLpfiFy5U/KKvZF6+bHd4yKF+/PFHOeSvReqnszosSTqmnVqhZ2XIX3PmzLE5QuRE9erVkymX1ukt/aZVMmXqvE7rK/WTS07dc889dodoGZdhZMmWGW+99ZaqV6+u5s2bKykpSd9//70KFy5s8RVnvVuia37AgAFatGiRvvvuO4X/rSsyPWFhYTp27JjHvmPHjiksLCzd8gEBAVmamfzpp59Urmx5fWJ2UKDy65IuyKkURURE6KWXXsqy8+L2durUKRmGodMffKAzH8+UEZBbrsREyTC0YcMGu8NDDhUeHq4q1Sppx89bNUERyqsiStJxOeSvrt262B0ecrDHH39cUyZP1UdqpiAVUrLi5ZJLkkvff/+93eHddmrUqOExoz0nszUjapqmBgwYoPnz52vVqlUqU6bMDY+Jjo7WypUrPfatWLFC0dHRWRXmdUVERCg55YLat2+vgFBThYqGatq093XgwAFb4sHtwzRN1a5dW2ZKslyJiQoODta5xESPRYqBjPrpp5/0+RefKSAgt5J0XPny5dOWbZs8Xu0HZNSkSZN0+MhBGYahCzolly6refOmlkxSupW4HA45Ld5cjlumc9oWtmZE+/fvr9mzZ+vLL79UcHCwe5xnaGioe4mArl27qmTJkho9erQkafDgwWrUqJHGjh2rVq1aae7cudq8ebOmTp1q23X4+/vriy++sO38uH39+OOPdoeA21D79u118eJFu8PAbSY8PFwul8vuMJDD2NoMnzx5suLj49W4cWMVL17cvX3yySfuMocPH9bRo0fdn+vXr6/Zs2dr6tSpql69uubNm6cFCxZcd4ITAADAzbqVxojeLmzNiHqTsl+zZk2afQ89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uXPnVLp0aZUqVUpt27bVrl27rlk2OTlZCQkJHhsAAEBG+TmzZvNltjZET548KafTmSajWaxYMcXFxaV7TGRkpKZPn64vv/xSM2fOlMvlUv369fX777+nW3706NEKDQ11b6VKlbL8OgAAwO3PYUoOl8WbafdV2cv2rvmMio6OVteuXRUVFaVGjRrpiy++UJEiRfTee++lW37YsGGKj493b0eOHMnmiAEAAJAeWycrFS5cWH5+fjp27JjH/mPHjiksLMyrOnLlyqUaNWpo37596X4fEBCggICAm44VAAD4NofTkMNp8eQiq+vLYWzNiObOnVs1a9bUypUr3ftcLpdWrlyp6Ohor+pwOp3asWOHihcvnlVhAgAAIAvYvnzT0KFD1a1bN9WqVUt16tTRhAkTlJSUpB49ekiSunbtqpIlS2r06NGSpJdeekn16tXTnXfeqbNnz2rMmDE6dOiQevfubedlAACA25zhurJZXacvs70h2rFjR504cULDhw9XXFycoqKitHTpUvcEpsOHD8vh+Ctxe+bMGfXp00dxcXEqUKCAatasqXXr1qlSpUp2XQIAAAAywTBN06fmayUkJCg0NFTx8fEKCQmxOxwAAOAFO39/p5677KijcgRae27XxQT9NqK4z7ZLctyseQAAANwebO+aBwAAyAkMp+SweAF6kwXtAQAAgOxHRhQAAMALDpchh8vadT9Ni+vLaWiIAgAAeMFwXtmsrtOX0TUPAAAAW5ARBQAA8IKfy5Cf1a/k9PGueTKiAAAAsAUZUQAAAC84WL7JcmREAQAAYAsyogAAAF5wuK5sVjItri+nISMKAAAAW5ARBQAA8ILhNGRYPGve6vpyGhqiAAAAXvBzXtksxWQlAAAAIPuREQUAAPACyzdZj4woAAAAbEFGFAAAwAuGy5DD4slFLl7xCQAAAGQ/MqIAAABeMFxXNqvr9GVkRAEAAGALMqIAAABeyIp1RH191jwNUQAAAC84nNZPVrK6vpyGrnkAAADYgowoAACAF7JiQXur68tpyIgCAADAFmREAQAAvEBG1HpkRAEAAGALMqIAAABeYNa89ciIAgAAwBZkRAEAALzgcGXBGFEff8UnDVEAAAAvOJySw+K+ZCYrAQAAADYgIwoAAOAFIwsyogYZUQAAACD7kREFAADwgsNpyOFg+SYrkREFAACALciIAgAAeIFZ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S5Zo6dKlmboeGqIWCggI0IgRI25qXIev4F55j3vlPe6V97hXGcP98h73KmsNGzZMjRo1UuvWrdWqVSu1a9dO5cqV8/r4fv36qUOHDurYsaPq1q2rU6dO6YknnvAo061bN02YMEGTJk1S5cqV1bp1a+3du9f9/eeff67atWurc+fOqlSpkp599lk5nc5MXY9hXj3QAAAAAMgGZEQBAABgCxqiAAAAsAUNUQAAANiChigAAABsQUM0gyZOnKiIiAgFBgaqbt26+vHHH69b/rPPPlOFChUUGBioqlWravHixdkUqf0ycq9iY2NlGIbHdissHJwdvvvuO7Vp00YlSpSQYRhasGDBDY9Zs2aN7r77bgUEBOjOO+9UbGxslsd5K8jovVqzZk2a58owDMXFxWVPwDYZPXq0ateureDgYBUtWlTt2rXTnj17bnicr/68ysz98tWfWZMnT1a1atXci9VHR0dryZIl1z3GV58reIeGaAZ88sknGjp0qEaMGKGtW7eqevXqiomJ8Xht1t+tW7dOnTt3Vq9evbRt2za1a9dO7dq1086dO7M58uyX0XslXXkLx9GjR93boUOHsjFi+yQlJal69eqaOHGiV+UPHDigVq1aqUmTJtq+fbuGDBmi3r17a9myZVkcqf0yeq9S7dmzx+PZKlq0aBZFeGv49ttv1b9/f23YsEErVqzQpUuXdP/99yspKemax/jyz6vM3C/JN39mhYeH6/XXX9eWLVu0efNmNW3aVG3bttWuXbvSLe/LzxW8ZMkb631EnTp1zP79+7s/O51Os0SJEubo0aPTLf/www+brVq18thXt25ds1+/flka560go/dqxowZZmhoaDZFd+uSZM6fP/+6ZZ599lmzcuXKHvs6duxoxsTEZGFktx5v7tXq1atNSeaZM2eyJaZb1fHjx01J5rfffnvNMr788+pq3twvfmb9pUCBAua0adPS/Y7nCjdCRtRLKSkp2rJli5o3b+7e53A41Lx5c61fvz7dY9avX+9RXpJiYmKuWf52kZl7JUnnzp1T6dKlVapUqev+D9vX+epzdTOioqJUvHhx3XfffVq7dq3d4WS7+Ph4SVLBggWvWYbn6i/e3C+Jn1lOp1Nz585VUlKSoqOj0y3Dc4UboSHqpZMnT8rpdKpYsWIe+4sVK3bN8WZxcXEZKn+7yMy9ioyM1PTp0/Xll19q5syZcrlcql+/vn7//ffsCDlHudZzlZCQoAsXLtgU1a2pePHimjJlij7//HN9/vnnKlWqlBo3bqytW7faHVq2cblcGjJkiBo0aKAqVapcs5yv/ry6mrf3y5d/Zu3YsUP58uVTQECAHnvsMc2fP1+VKlVKtyzPFW7E3+4AAEmKjo72+B91/fr1VbFiRb333nt6+eWXbYwMOVlkZKQiIyPdn+vXr6/9+/dr/Pjx+vjjj22MLPv0799fO3fu1A8//GB3KDmCt/fLl39mRUZGavv27YqPj9e8efPUrVs3ffvtt9dsjALXQ0bUS4ULF5afn5+OHTvmsf/YsWMKCwtL95iwsLAMlb9dZOZeXS1XrlyqUaOG9u3blxUh5mjXeq5CQkIUFBRkU1Q5R506dXzmuRowYIAWLVqk1atXKzw8/LplffXn1d9l5H5dzZd+ZuXOnVt33nmnatasqdGjR6t69ep6++230y3Lc4UboSHqpdy5c6tmzZpauXKle5/L5dLKlSuvOTYmOjrao7wkrVix4prlbxeZuVdXczqd2rFjh4oXL55VYeZYvvpcWWX79u23/XNlmqYGDBig+fPna9WqVSpTpswNj/Hl5yoz9+tqvvwzy+VyKTk5Od3vfPm5gpfsni2Vk8ydO9cMCAgwY2NjzV9++cXs27evmT9/fjMuLs40TdN89NFHzeeee85dfu3ataa/v7/51ltvmbt37zZHjBhh5sqVy9yxY4ddl5BtMnqvRo0aZS5btszcv3+/uWXLFrNTp05mYGCguWvXLrsuIdskJiaa27ZtM7dt22ZKMseNG2du27bNPHTokGmapvncc8+Zjz76qLv8b7/9ZubJk8d85plnzN27d5sTJ040/fz8zKVLl9p1Cdkmo/dq/Pjx5oIFC8y9e/eaO3bsMAcPHmw6HA7zm2++sesSssXjjz9uhoaGmmvWrDGPHj3q3s6fP+8uw8+rv2Tmfvnqz6znnnvO/Pbbb80DBw6YP//8s/ncc8+ZhmGYy5cvN02T5woZR0M0g9555x3zjjvuMHPnzm3WqVPH3LBhg/u7Ro0amd26dfMo/+mnn5p33XWXmTt3brNy5crm119/nc0R2ycj92rIkCHussWKFTNbtmxpbt261Yaos1/qEkNXb6n3p1u3bmajRo3SHBMVFWXmzp3bLFu2rDljxoxsj9sOGb1Xb7zxhlmuXDkzMDDQLFiwoNm4cWNz1apV9gSfjdK7R5I8nhN+Xv0lM/fLV39m9ezZ0yxdurSZO3dus0iRImazZs3cjVDT5LlCxhmmaZrZl38FAAAArmCMKAAAAGxBQxQAAAC2oCEKAAAAW9AQBQAAgC1oiAIAAMAWNEQBAABgCxqiAAAAsAUNUQAAANiChigAWzRu3FhDhgzJ0nNERERowoQJWXoOAEDm+dsdAABklU2bNilv3rx2hwEAuAYaogBuW0WKFLE7BADAddA1D8A2ly9f1oABAxQaGqrChQvrxRdflGmakiTDMLRgwQKP8vnz51dsbKwkqWnTphowYIDH9ydOnFDu3Lm1cuVKSWm75g3D0LRp09S+fXvlyZNH5cuX18KFCz3qWLhwocqXL6/AwEA1adJEH374oQzD0NmzZy29dgAADVEANvrwww/l7++vH3/8UW+//bbGjRunadOmeXVs7969NXv2bCUnJ7v3zZw5UyVLllTTpk2vedyoUaP08MMP6+eff1bLli3VpUsXnT59WpJ04MABPfjgg2rXrp1++ukn9evXT88///zNXSQA4JpoiAKwTalSpTR+/HhFRkaqS5cuGjhwoMaPH+/VsR06dJAkffnll+59sbGx6t69uwzDuOZx3bt3V+fOnXXnnXfqtdde07lz5/Tjjz9Kkt577z1FRkZqzJgxioyMVKdOndS9e/fMXyAA4LpoiAKwTb169TwajdHR0dq7d6+cTucNjw0MDNSjjz6q6dOnS5K2bt2qnTt33rDhWK1aNfef8+bNq5CQEB0/flyStGfPHtWuXdujfJ06dby9HABABjFZCcAtyTAM93jRVJcuXfL43Lt3b0VFRen333/XjBkz1LRpU5UuXfq69ebKlSvNeVwulzVBAwAyhIwoANts3LjR4/OGDRtUvnx5+fn5qUiRIjp69Kj7u7179+r8+fMe5atWrapatWrp/fff1+zZs9WzZ8+biicyMlKbN2/22Ldp06abqhMAcG00RAHY5vDhwxo6dKj27NmjOXPm6J133tHgwYMlXZkV/+6772rbtm3avHmzHnvssTTZTOlKVvT111+XaZpq3779TcXTr18//fe//9W//vUv/frrr/r000/ds/SvN+4UAJA5NEQB2KZr1666cOGC6tSpo/79+2vw4MHq27evJGns2LEqVaqU7r33Xj3yyCN6+umnlSdPnjR1dO7cWf7+/urcubMCAwNvKp4yZcpo3rx5+uKLL1StWjVNnjzZPWs+ICDgpuoGAKRlmFcPwgKAHOTgwYMqV66cNm3apLvvvtvy+l999VVNmTJFR44csbxuAPB1TFYCkCNdunRJp06d0gsvvKB69epZ1gidNGmSateurUKFCmnt2rUaM2ZMmoXzAQDWoCEKIEdau3atmjRporvuukvz5s2zrN69e/fqlVde0enTp3XHHXfoqaee0rBhwyyrHwDwF7rmAQAAYAsmKwEAAMAWNEQBAABgCxqiAAAAsAUNUQAAANiChigAAABsQUMUAAAAtqAhCgAAAFvQEAUAAIAt/h8rFg2kDAc1EgAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 800x600 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_decision_boundary(X_test_scaled_df, y_pred_2, \"buying\", \"maint\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c3249b8a-a969-4b3c-a2a4-77e0e6f99f42",
   "metadata": {},
   "outputs": [],
   "source": [
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b20f6fdd-cb92-43b7-b1bf-b32f34fea7ad",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "id": "43a1d4fa-fb39-46e7-8c14-645e213aa7f3",
   "metadata": {},
   "source": [
    "#### Sample Data Creation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 69,
   "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/car/level_3.py\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 70,
   "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": 71,
   "id": "d2ba908c-9ccc-43ed-aebc-34c5e3eeac92",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Number of samples in verb_data: 156\n"
     ]
    }
   ],
   "source": [
    "verb_data = []\n",
    "for idx in range(len(X_test_scaled_df)):\n",
    "    data_point = {\n",
    "        \"input\": 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": 72,
   "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": 73,
   "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": 74,
   "id": "5b11b0a3-deea-4f17-99f7-c992d2b470df",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Number of samples in gen_data: 156\n"
     ]
    }
   ],
   "source": [
    "gen_data = []\n",
    "for idx in range(len(X_test_gen_scaled_df)):\n",
    "    data_point = {\n",
    "        \"input\": 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": 75,
   "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": 76,
   "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": 77,
   "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": "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": 78,
   "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": "8d820805-edbf-4f58-b167-8ff9a934f819",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4027f14b-ec81-4e90-8980-1e0d97eeb569",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 79,
   "id": "79bf04b1-a373-41f9-aa12-e69df36ffef5",
   "metadata": {},
   "outputs": [],
   "source": [
    "def prediction_zero(data):\n",
    "    prediction0_1 = [i for i in range(len(data)) if data[i][\"output\"][\"model1\"] == 3]\n",
    "    prediction0_2 = [i for i in range(len(data)) if data[i][\"output\"][\"model2\"] == 3]\n",
    "    return prediction0_1, prediction0_2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 80,
   "id": "5fc61a82-569c-4f68-859b-20e9c8b5c3b0",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model 1: 17\n",
      "Model 2: 9\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": 81,
   "id": "a2357944-fbcf-4247-b017-fb79bcef2736",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model 1: 12\n",
      "Model 2: 5\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": null,
   "id": "dfccbc3c-5151-447a-9ec4-f75fa090fd86",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 82,
   "id": "127ea668-1a92-4dbd-9822-9708845a4d14",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "mismatches = [i for i in gen_data if i[\"output\"][\"model1\"] != i[\"output\"][\"model2\"]]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 83,
   "id": "cff62f25-61e0-4114-9e6a-ddf5374598a9",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "33"
      ]
     },
     "execution_count": 83,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(mismatches)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 84,
   "id": "5f9f5303-eb90-4f44-b76d-fe9167e68440",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[{'input': [2, 3, 3, 5, 0, 2], 'output': {'model1': 0, 'model2': 1}},\n",
       " {'input': [0, 1, 5, 4, 0, 2], 'output': {'model1': 3, 'model2': 1}},\n",
       " {'input': [2, 3, 2, 5, 1, 2], 'output': {'model1': 0, 'model2': 1}},\n",
       " {'input': [1, 0, 5, 5, 1, 1], 'output': {'model1': 3, 'model2': 1}},\n",
       " {'input': [0, 2, 4, 5, 0, 0], 'output': {'model1': 1, 'model2': 0}},\n",
       " {'input': [3, 0, 5, 5, 1, 2], 'output': {'model1': 0, 'model2': 1}},\n",
       " {'input': [1, 3, 2, 5, 0, 2], 'output': {'model1': 0, 'model2': 1}},\n",
       " {'input': [2, 0, 4, 5, 0, 2], 'output': {'model1': 0, 'model2': 1}},\n",
       " {'input': [3, 0, 4, 5, 2, 2], 'output': {'model1': 0, 'model2': 1}},\n",
       " {'input': [3, 0, 3, 5, 2, 2], 'output': {'model1': 0, 'model2': 1}},\n",
       " {'input': [1, 1, 3, 4, 2, 2], 'output': {'model1': 3, 'model2': 1}},\n",
       " {'input': [2, 0, 2, 5, 0, 2], 'output': {'model1': 3, 'model2': 1}},\n",
       " {'input': [2, 0, 4, 5, 2, 1], 'output': {'model1': 0, 'model2': 1}},\n",
       " {'input': [0, 2, 3, 4, 2, 1], 'output': {'model1': 1, 'model2': 0}},\n",
       " {'input': [1, 3, 5, 5, 2, 2], 'output': {'model1': 0, 'model2': 1}},\n",
       " {'input': [1, 1, 2, 4, 2, 2], 'output': {'model1': 3, 'model2': 1}},\n",
       " {'input': [2, 0, 3, 4, 1, 2], 'output': {'model1': 0, 'model2': 1}},\n",
       " {'input': [2, 0, 5, 5, 1, 2], 'output': {'model1': 0, 'model2': 1}},\n",
       " {'input': [0, 3, 5, 5, 2, 1], 'output': {'model1': 1, 'model2': 0}},\n",
       " {'input': [2, 1, 3, 5, 1, 2], 'output': {'model1': 0, 'model2': 1}},\n",
       " {'input': [0, 0, 5, 4, 0, 1], 'output': {'model1': 3, 'model2': 2}},\n",
       " {'input': [0, 1, 2, 5, 2, 0], 'output': {'model1': 2, 'model2': 3}},\n",
       " {'input': [1, 0, 5, 4, 1, 2], 'output': {'model1': 3, 'model2': 1}},\n",
       " {'input': [0, 0, 4, 4, 1, 0], 'output': {'model1': 2, 'model2': 0}},\n",
       " {'input': [3, 0, 4, 5, 1, 2], 'output': {'model1': 0, 'model2': 1}},\n",
       " {'input': [3, 1, 2, 4, 1, 2], 'output': {'model1': 0, 'model2': 1}},\n",
       " {'input': [2, 1, 5, 5, 1, 2], 'output': {'model1': 0, 'model2': 1}},\n",
       " {'input': [3, 1, 3, 4, 2, 2], 'output': {'model1': 0, 'model2': 1}},\n",
       " {'input': [1, 2, 2, 4, 1, 2], 'output': {'model1': 0, 'model2': 1}},\n",
       " {'input': [1, 0, 4, 5, 1, 2], 'output': {'model1': 3, 'model2': 1}},\n",
       " {'input': [1, 1, 2, 2, 0, 2], 'output': {'model1': 0, 'model2': 1}},\n",
       " {'input': [1, 1, 4, 5, 1, 1], 'output': {'model1': 0, 'model2': 1}},\n",
       " {'input': [0, 2, 5, 5, 2, 0], 'output': {'model1': 1, 'model2': 0}}]"
      ]
     },
     "execution_count": 84,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "mismatches"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7ca6685d-655c-41db-9dd0-aa0a32e6d77d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "be62be11-0ea9-44b9-bf5d-60c16a96c81f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cef65393-950e-4678-99ca-21cb4d14afd6",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4b830818-14c4-48fb-af2e-94071dc0f99f",
   "metadata": {},
   "outputs": [],
   "source": [
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6d6d3058-a39e-473e-ad51-c41ab838728f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fc19a7c9-5bec-405f-b630-e809c61a218f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a1b898da-8584-403b-9372-7d1b087f99b3",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "36e98d95-620d-41de-8ab1-a8dcc4ad19da",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5cac5c04-19ec-4885-a0b9-6a02999dbe04",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4ad79814-97c6-4a55-b858-05b03157fabc",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c0ba358f-d8d1-4775-ac1f-97ebc8bd379e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bbdc1b12-c3c1-44b3-a8e4-fab4f22d5f34",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "681edae6-2d69-41ce-9346-fa6a3d02558e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "58ad5698-f890-4730-b102-d6f2f3cff13c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ee2290fd-3110-4d95-b78c-b76667e2b42c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5985f374-cba9-42f2-8edf-a73d4ccf985e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ad066228-903d-4769-b4d8-931ddf9f64d6",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c7606768-f2c8-477e-9efc-6ded4766163e",
   "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
}
