{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "initial_id",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-05-22T07:41:03.562265Z",
     "start_time": "2024-05-22T07:41:03.559003Z"
    }
   },
   "outputs": [],
   "source": [
    "# Standard Imports\n",
    "import copy\n",
    "\n",
    "# Third Party Imports\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "from sklearn.linear_model import LogisticRegression\n",
    "from sklearn.metrics import accuracy_score\n",
    "from sklearn.model_selection import train_test_split, 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": "0aac7df9-f6fe-43ef-96a9-b10fa43a1ebf",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Log Transformation of Monetary (c.c. blood) to reduce the variance and range\n",
    "# blood['Monetary (c.c. blood)'] = blood['Monetary (c.c. blood)'] / 100\n",
    "# blood.var().round(3)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "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": 14,
     "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": 15,
   "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": 15,
     "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": 16,
   "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": 17,
   "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": 18,
   "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": 19,
   "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": 19,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "X_train.var().round(3)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "0a7a2750-30fc-45f5-97d9-9bd0863cab60",
   "metadata": {},
   "source": [
    "**Standardization** - Skipping this because the data is categorical anyway"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "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": 21,
   "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": 22,
   "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": 22,
     "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": 23,
   "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": 24,
   "id": "89b2a7e3-1405-4e9d-97c6-0e04001d6968",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/shravan/NLE3/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/NLE3/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/NLE3/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/NLE3/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/NLE3/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/NLE3/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/NLE3/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/NLE3/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/NLE3/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/NLE3/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/NLE3/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/NLE3/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/NLE3/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/NLE3/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/NLE3/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/NLE3/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/NLE3/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/NLE3/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/NLE3/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/NLE3/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/NLE3/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/NLE3/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/NLE3/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/NLE3/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/NLE3/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/NLE3/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/NLE3/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/NLE3/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/NLE3/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/NLE3/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/NLE3/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/NLE3/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/NLE3/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/NLE3/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/NLE3/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/NLE3/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/NLE3/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/NLE3/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/NLE3/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"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Best parameters found:  {'C': np.float64(0.8825700575384295), 'class_weight': 'balanced', 'l1_ratio': np.float64(0.19146757745157583), 'max_iter': 125, 'penalty': 'l1', 'solver': 'saga', 'tol': np.float64(4.245175201266573e-05)}\n",
      "Best score:  0.7951902906802517\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/shravan/NLE3/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/NLE3/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/NLE3/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/NLE3/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/NLE3/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/NLE3/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/NLE3/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/NLE3/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/NLE3/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/NLE3/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/NLE3/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/NLE3/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/model_selection/_validation.py:540: FitFailedWarning: \n",
      "30 fits failed out of a total of 70.\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/NLE3/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/NLE3/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/NLE3/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/NLE3/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",
      "--------------------------------------------------------------------------------\n",
      "20 fits failed with the following error:\n",
      "Traceback (most recent call last):\n",
      "  File \"/home/shravan/NLE3/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/NLE3/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/base.py\", line 1466, in wrapper\n",
      "    estimator._validate_params()\n",
      "  File \"/home/shravan/NLE3/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/base.py\", line 666, in _validate_params\n",
      "    validate_parameter_constraints(\n",
      "  File \"/home/shravan/NLE3/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', 'elasticnet', 'l2'} or None. Got 'none' instead.\n",
      "\n",
      "  warnings.warn(some_fits_failed_message, FitFailedWarning)\n",
      "/home/shravan/NLE3/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 0.69986515 0.77407851 0.79519029 0.69986515\n",
      "        nan]\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE3/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/NLE3/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",
    "from scipy.stats import loguniform, uniform\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=7, cv=10, random_state=400)\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": 25,
   "id": "9c1d7336",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/shravan/NLE3/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/NLE3/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": [
    "# Train the base model\n",
    "def train_base_model(X_train, y_train):\n",
    "    # model = LogisticRegression(C=0.1, max_iter=100, 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": 26,
   "id": "97d229ee-5cb6-46d4-8ab8-742e47dcf1d0",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.717948717948718\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": 27,
   "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": 40,
   "id": "efe7242e-ecc0-4520-9b64-280823bc4364",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Modification Factor: 0.1 Noise: [[-0.06988369  0.00106231 -0.09467864  0.032873    0.03150646 -0.04028224]\n",
      " [-0.26333037  0.02019705 -0.04073261  0.26869677 -0.08838987 -0.04036689]\n",
      " [ 0.01019237  0.11959814  0.11724114  0.01691044 -0.04913242 -0.08294031]\n",
      " [-0.01896405  0.04332583 -0.23685336 -0.03772465 -0.03266734  0.08956885]]\n",
      "Modification Factor: 0.15 Noise: [[-0.01497981  0.03869799 -0.03078066 -0.07485309  0.41672265  0.00930111]\n",
      " [-0.14460235  0.14022724 -0.19109696 -0.11779025 -0.06467498 -0.19128619]\n",
      " [-0.00684465 -0.07608375 -0.04218373 -0.00353335  0.11590071 -0.12851939]\n",
      " [ 0.09216858 -0.10066244 -0.11428612 -0.06758537 -0.16521176 -0.13197066]]\n",
      "Modification Factor: 0.2 Noise: [[ 0.07691208  0.09683763  0.06115704  0.25547428  0.00780421 -0.10974186]\n",
      " [-0.26251533 -0.23591903  0.23337045  0.07646576  0.00523038 -0.35540875]\n",
      " [-0.05270112  0.2466355   0.33028162 -0.01090106  0.02591979  0.30159082]\n",
      " [-0.2783345   0.17416922  0.03531392  0.03032246  0.43382342 -0.16201026]]\n",
      "Modification Factor: 0.25 Noise: [[-0.23547656 -0.38094397 -0.29814278  0.18645481  0.42301097  0.1113383 ]\n",
      " [ 0.23645885  0.43382001  0.34958464 -0.13780918 -0.3847614  -0.07853139]\n",
      " [ 0.34252898  0.02043001 -0.11699135  0.18058685 -0.11030306  0.2831506 ]\n",
      " [-0.13890591 -0.16471469  0.23883873 -0.44311    -0.12727494  0.09925709]]\n",
      "Modification Factor: 0.3 Noise: [[-0.27374372 -0.15700939  0.19417383 -0.21873127  0.13123624  0.25146548]\n",
      " [ 0.20126369  0.02260881 -0.22519157 -0.13749445 -0.18612484 -0.69083004]\n",
      " [-0.15571377 -0.00739794  0.84403027 -0.01925467  0.04666473  0.05034269]\n",
      " [-0.1728576   0.00867782 -0.16941705 -0.17459833 -0.18128243 -0.00602353]]\n",
      "Modification Factor: 0.35 Noise: [[-0.06611939 -0.06188352  0.37717618  0.04221204 -0.1057986   0.48315803]\n",
      " [-0.46432346 -0.98987304  0.30804003 -0.26151154 -0.0132091   0.21023864]\n",
      " [-0.34169145 -0.07470653  0.34487515 -0.34140621 -0.22635349  0.22310922]\n",
      " [ 0.05806079  0.48410006  0.54593943  0.27284007  0.40755207  0.30293811]]\n",
      "Modification Factor: 0.4 Noise: [[-0.06656824  0.26468126  0.062404    0.24314731  0.37656684 -0.00555492]\n",
      " [ 0.34215246 -0.08505697 -0.51357201  0.01158447  0.85548142  0.18457685]\n",
      " [-0.26300369 -0.58656893 -0.28827739  0.6370615   0.46507573 -0.21753755]\n",
      " [ 0.43079613 -0.69117229  0.04073752  0.05079123 -0.16206435  0.16075637]]\n",
      "Modification Factor: 0.45 Noise: [[-0.1347638  -0.05035262  0.40738596  0.314416    0.72715846 -0.91482284]\n",
      " [-0.45772999 -0.10169796 -0.29568209  0.08466837 -0.58763022  0.41960369]\n",
      " [-0.2725953   0.59650144  0.63327385  0.3555637  -0.8577355  -0.02184346]\n",
      " [ 0.16265865  0.06675001 -0.26825357 -1.19507766  0.40382131  0.34103101]]\n",
      "Modification Factor: 0.5 Noise: [[-0.25471757  0.51897412 -0.22308502  0.39081865  0.22253532 -0.28149354]\n",
      " [ 0.49895068 -0.05872675  0.98620341  0.17217507 -0.04779688 -0.37431125]\n",
      " [ 0.51495552  0.46483737  0.67147021 -0.39575481  0.18752448  0.75875171]\n",
      " [-0.34846818  0.53160728 -0.60205896 -1.03203561 -0.10651468 -0.28127368]]\n",
      "Modification Factor: 0.55 Noise: [[ 0.25443451 -0.52029583 -0.017617   -0.43297716  0.31508468  0.20289938]\n",
      " [-0.85377375  0.02803141  0.22013014  0.23120838 -0.1650054   1.41882064]\n",
      " [-0.31026905  0.64413263  0.58295829  0.49183415  0.2946047   0.25209644]\n",
      " [ 1.16629957  0.03987516  0.83353385  0.39901133  0.15460565  0.05856872]]\n",
      "Modification Factor: 0.6 Noise: [[-0.16340646 -0.04175274 -0.42483407  0.09246278  0.64805576 -0.40607954]\n",
      " [-0.48193976  0.10170954  0.19883857 -1.3930289  -0.12299601  0.27586245]\n",
      " [ 0.3636701   0.86661874 -0.85736064 -0.35693397 -0.00484475  0.26228227]\n",
      " [ 0.79836134  0.72675512  0.08882608 -0.2866401   0.58067403  0.0213763 ]]\n",
      "Modification Factor: 0.65 Noise: [[-0.47414022  0.07031064 -0.03149768 -0.10428883  0.99191864  0.99333307]\n",
      " [-1.08724457 -0.24589485 -0.20401672 -0.28399495 -0.23546068 -0.91030348]\n",
      " [-0.33066786  0.00869871 -0.68486183 -0.5612478   1.50725028  0.39551424]\n",
      " [ 0.8524936   0.42215004  0.07024247  1.18230603 -0.13890418  0.17832545]]\n",
      "Modification Factor: 0.7 Noise: [[ 0.05172652  0.78349835  0.19309985 -0.5506189   0.3380072  -0.00951905]\n",
      " [-0.59114352  0.40541064 -0.37778376 -0.48956551 -0.07684534  1.44349311]\n",
      " [-0.18569872 -0.87540714 -0.27766402  0.22529878 -0.42381124 -0.09181629]\n",
      " [ 0.91527561  1.03280135 -0.32083594 -0.14244456 -0.45671753  0.34495046]]\n",
      "Modification Factor: 0.75 Noise: [[ 0.11478371  0.86910346  0.55566145  0.178635    1.50585403  0.15961906]\n",
      " [ 1.02154755  1.06276972  0.10779687 -0.57896384  0.07815046 -0.37512872]\n",
      " [-0.3255585  -0.12806761  0.67004816 -0.10842627 -1.10975392 -1.17707181]\n",
      " [ 0.11241106 -0.68161653  0.67047123  1.24505874  0.84116472 -0.22989415]]\n"
     ]
    }
   ],
   "source": [
    "np.random.seed(124)\n",
    "np.random.seed(125)\n",
    "# np.random.seed(400)\n",
    "# np.random.seed(150)\n",
    "# np.random.seed(200)\n",
    "# np.random.seed(250)\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": 39,
   "id": "58645e40-aebe-495e-b8df-f367c6777448",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "With Model: Modified (factor=0.1), Diff: 0.14102564102564102\n",
      "With Model: Modified (factor=0.15), Diff: 0.1346153846153846\n",
      "With Model: Modified (factor=0.2), Diff: 0.26282051282051283\n",
      "Best Model till now is Modified (factor=0.2)\n",
      "With Model: Modified (factor=0.25), Diff: 0.5064102564102564\n",
      "With Model: Modified (factor=0.3), Diff: 0.3717948717948718\n",
      "With Model: Modified (factor=0.35), Diff: 0.47435897435897434\n",
      "With Model: Modified (factor=0.4), Diff: 0.47435897435897434\n",
      "With Model: Modified (factor=0.45), Diff: 0.4358974358974359\n",
      "With Model: Modified (factor=0.5), Diff: 0.3717948717948718\n",
      "With Model: Modified (factor=0.55), Diff: 0.5256410256410257\n",
      "With Model: Modified (factor=0.6), Diff: 0.32051282051282054\n",
      "With Model: Modified (factor=0.65), Diff: 0.3333333333333333\n",
      "With Model: Modified (factor=0.7), Diff: 0.42948717948717946\n",
      "With Model: Modified (factor=0.75), Diff: 0.7692307692307693\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.25 and diff <= 0.3:\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": 41,
   "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.2564102564102564\n",
      "Best Model Pair till now is Modified (factor=0.1) vs Modified (factor=0.2)\n",
      "With Models: Modified (factor=0.1) vs Modified (factor=0.25), Diff: 0.6217948717948718\n",
      "With Models: Modified (factor=0.1) vs Modified (factor=0.3), Diff: 0.48717948717948717\n",
      "With Models: Modified (factor=0.1) vs Modified (factor=0.35), Diff: 0.358974358974359\n",
      "With Models: Modified (factor=0.1) vs Modified (factor=0.4), Diff: 0.48717948717948717\n",
      "With Models: Modified (factor=0.1) vs Modified (factor=0.45), Diff: 0.4230769230769231\n",
      "With Models: Modified (factor=0.1) vs Modified (factor=0.5), Diff: 0.44871794871794873\n",
      "With Models: Modified (factor=0.1) vs Modified (factor=0.55), Diff: 0.47435897435897434\n",
      "With Models: Modified (factor=0.1) vs Modified (factor=0.6), Diff: 0.4166666666666667\n",
      "With Models: Modified (factor=0.1) vs Modified (factor=0.65), Diff: 0.27564102564102566\n",
      "With Models: Modified (factor=0.1) vs Modified (factor=0.7), Diff: 0.3525641025641026\n",
      "With Models: Modified (factor=0.1) vs Modified (factor=0.75), Diff: 0.7628205128205128\n",
      "With Models: Modified (factor=0.15) vs Modified (factor=0.2), Diff: 0.22435897435897437\n",
      "With Models: Modified (factor=0.15) vs Modified (factor=0.25), Diff: 0.47435897435897434\n",
      "With Models: Modified (factor=0.15) vs Modified (factor=0.3), Diff: 0.3782051282051282\n",
      "With Models: Modified (factor=0.15) vs Modified (factor=0.35), Diff: 0.5064102564102564\n",
      "With Models: Modified (factor=0.15) vs Modified (factor=0.4), Diff: 0.5641025641025641\n",
      "With Models: Modified (factor=0.15) vs Modified (factor=0.45), Diff: 0.42948717948717946\n",
      "With Models: Modified (factor=0.15) vs Modified (factor=0.5), Diff: 0.391025641025641\n",
      "With Models: Modified (factor=0.15) vs Modified (factor=0.55), Diff: 0.4935897435897436\n",
      "With Models: Modified (factor=0.15) vs Modified (factor=0.6), Diff: 0.33974358974358976\n",
      "With Models: Modified (factor=0.15) vs Modified (factor=0.65), Diff: 0.34615384615384615\n",
      "With Models: Modified (factor=0.15) vs Modified (factor=0.7), Diff: 0.46153846153846156\n",
      "With Models: Modified (factor=0.15) vs Modified (factor=0.75), Diff: 0.8525641025641025\n",
      "With Models: Modified (factor=0.2) vs Modified (factor=0.25), Diff: 0.6858974358974359\n",
      "With Models: Modified (factor=0.2) vs Modified (factor=0.3), Diff: 0.5897435897435898\n",
      "With Models: Modified (factor=0.2) vs Modified (factor=0.35), Diff: 0.42948717948717946\n",
      "With Models: Modified (factor=0.2) vs Modified (factor=0.4), Diff: 0.6923076923076923\n",
      "With Models: Modified (factor=0.2) vs Modified (factor=0.45), Diff: 0.26282051282051283\n",
      "Best Model Pair till now is Modified (factor=0.2) vs Modified (factor=0.45)\n",
      "With Models: Modified (factor=0.2) vs Modified (factor=0.5), Diff: 0.33974358974358976\n",
      "With Models: Modified (factor=0.2) vs Modified (factor=0.55), Diff: 0.28846153846153844\n",
      "With Models: Modified (factor=0.2) vs Modified (factor=0.6), Diff: 0.2948717948717949\n",
      "With Models: Modified (factor=0.2) vs Modified (factor=0.65), Diff: 0.5\n",
      "With Models: Modified (factor=0.2) vs Modified (factor=0.7), Diff: 0.2564102564102564\n",
      "With Models: Modified (factor=0.2) vs Modified (factor=0.75), Diff: 0.9423076923076923\n",
      "With Models: Modified (factor=0.25) vs Modified (factor=0.3), Diff: 0.14743589743589744\n",
      "With Models: Modified (factor=0.25) vs Modified (factor=0.35), Diff: 0.8589743589743589\n",
      "With Models: Modified (factor=0.25) vs Modified (factor=0.4), Diff: 0.4935897435897436\n",
      "With Models: Modified (factor=0.25) vs Modified (factor=0.45), Diff: 0.8461538461538461\n",
      "With Models: Modified (factor=0.25) vs Modified (factor=0.5), Diff: 0.6089743589743589\n",
      "With Models: Modified (factor=0.25) vs Modified (factor=0.55), Diff: 0.9166666666666666\n",
      "With Models: Modified (factor=0.25) vs Modified (factor=0.6), Diff: 0.5064102564102564\n",
      "With Models: Modified (factor=0.25) vs Modified (factor=0.65), Diff: 0.5064102564102564\n",
      "With Models: Modified (factor=0.25) vs Modified (factor=0.7), Diff: 0.9038461538461539\n",
      "With Models: Modified (factor=0.25) vs Modified (factor=0.75), Diff: 0.47435897435897434\n",
      "With Models: Modified (factor=0.3) vs Modified (factor=0.35), Diff: 0.75\n",
      "With Models: Modified (factor=0.3) vs Modified (factor=0.4), Diff: 0.3782051282051282\n",
      "With Models: Modified (factor=0.3) vs Modified (factor=0.45), Diff: 0.7564102564102564\n",
      "With Models: Modified (factor=0.3) vs Modified (factor=0.5), Diff: 0.5897435897435898\n",
      "With Models: Modified (factor=0.3) vs Modified (factor=0.55), Diff: 0.8589743589743589\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.391025641025641\n",
      "With Models: Modified (factor=0.3) vs Modified (factor=0.7), Diff: 0.7884615384615384\n",
      "With Models: Modified (factor=0.3) vs Modified (factor=0.75), Diff: 0.5128205128205128\n",
      "With Models: Modified (factor=0.35) vs Modified (factor=0.4), Diff: 0.5\n",
      "With Models: Modified (factor=0.35) vs Modified (factor=0.45), Diff: 0.48717948717948717\n",
      "With Models: Modified (factor=0.35) vs Modified (factor=0.5), Diff: 0.5384615384615384\n",
      "With Models: Modified (factor=0.35) vs Modified (factor=0.55), Diff: 0.5\n",
      "With Models: Modified (factor=0.35) vs Modified (factor=0.6), Diff: 0.6089743589743589\n",
      "With Models: Modified (factor=0.35) vs Modified (factor=0.65), Diff: 0.3974358974358974\n",
      "With Models: Modified (factor=0.35) vs Modified (factor=0.7), Diff: 0.391025641025641\n",
      "With Models: Modified (factor=0.35) vs Modified (factor=0.75), Diff: 0.6153846153846154\n",
      "With Models: Modified (factor=0.4) vs Modified (factor=0.45), Diff: 0.7435897435897436\n",
      "With Models: Modified (factor=0.4) vs Modified (factor=0.5), Diff: 0.6282051282051282\n",
      "With Models: Modified (factor=0.4) vs Modified (factor=0.55), Diff: 0.8333333333333334\n",
      "With Models: Modified (factor=0.4) vs Modified (factor=0.6), Diff: 0.6282051282051282\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.6923076923076923\n",
      "With Models: Modified (factor=0.4) vs Modified (factor=0.75), Diff: 0.3782051282051282\n",
      "With Models: Modified (factor=0.45) vs Modified (factor=0.5), Diff: 0.34615384615384615\n",
      "With Models: Modified (factor=0.45) vs Modified (factor=0.55), Diff: 0.1282051282051282\n",
      "With Models: Modified (factor=0.45) vs Modified (factor=0.6), Diff: 0.41025641025641024\n",
      "With Models: Modified (factor=0.45) vs Modified (factor=0.65), Diff: 0.6282051282051282\n",
      "With Models: Modified (factor=0.45) vs Modified (factor=0.7), Diff: 0.16666666666666666\n",
      "With Models: Modified (factor=0.45) vs Modified (factor=0.75), Diff: 0.9615384615384616\n",
      "With Models: Modified (factor=0.5) vs Modified (factor=0.55), Diff: 0.3141025641025641\n",
      "With Models: Modified (factor=0.5) vs Modified (factor=0.6), Diff: 0.358974358974359\n",
      "With Models: Modified (factor=0.5) vs Modified (factor=0.65), Diff: 0.5448717948717948\n",
      "With Models: Modified (factor=0.5) vs Modified (factor=0.7), Diff: 0.40384615384615385\n",
      "With Models: Modified (factor=0.5) vs Modified (factor=0.75), Diff: 0.8461538461538461\n",
      "With Models: Modified (factor=0.55) vs Modified (factor=0.6), Diff: 0.4551282051282051\n",
      "With Models: Modified (factor=0.55) vs Modified (factor=0.65), Diff: 0.6474358974358975\n",
      "With Models: Modified (factor=0.55) vs Modified (factor=0.7), Diff: 0.14743589743589744\n",
      "With Models: Modified (factor=0.55) vs Modified (factor=0.75), Diff: 1.0\n",
      "With Models: Modified (factor=0.6) vs Modified (factor=0.65), Diff: 0.5897435897435898\n",
      "With Models: Modified (factor=0.6) vs Modified (factor=0.7), Diff: 0.4551282051282051\n",
      "With Models: Modified (factor=0.6) vs Modified (factor=0.75), Diff: 0.8141025641025641\n",
      "With Models: Modified (factor=0.65) vs Modified (factor=0.7), Diff: 0.5384615384615384\n",
      "With Models: Modified (factor=0.65) vs Modified (factor=0.75), Diff: 0.6025641025641025\n",
      "With Models: Modified (factor=0.7) vs Modified (factor=0.75), Diff: 0.9166666666666666\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.25 and diff <= 0.27):\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": 42,
   "id": "29fd7798-dc06-449d-a1f5-22804fc6c057",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Get the model pair\n",
    "(model1_name, model1), (model2_name, model2) = best_pair"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "id": "534dbb87-dd80-412a-92e0-92979cb7eb94",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "np.float64(0.2948717948717949)"
      ]
     },
     "execution_count": 43,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "def compare_models(model1, model2, X):\n",
    "    pred1 = model1.predict(X)\n",
    "    pred2 = model2.predict(X)\n",
    "    diff_percentage = np.mean(pred1 != pred2)\n",
    "    return diff_percentage\n",
    "# let's check the difference on the generation data as well\n",
    "compare_models(model1, model2, X_test_gen_scaled_df)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "9ea03138-8060-44ec-80ba-72d49272ec80",
   "metadata": {},
   "source": [
    "**Evaluate Both Models**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "id": "6e595955-68c6-41b3-8b0e-051de7cf86ba",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model 1: Modified (factor=0.2)\n",
      "Model 1 accuracy: 0.8269230769230769\n",
      "\n",
      "Model 2: Modified (factor=0.45)\n",
      "Model 2 accuracy: 0.6730769230769231\n",
      "\n",
      "Accuracy difference: 0.15384615384615374\n",
      "\n",
      "Percentage of different outputs: 26.28%\n",
      "\n",
      "\n",
      "\n",
      "[[ 5.02034864  4.38185097 -0.50026463 -3.75497531 -1.58875543 -5.07136606]\n",
      " [ 2.85298473  2.7994044   0.0813289  -0.69699614 -0.95573318 -1.62981141]\n",
      " [-3.84058287 -5.61836531  0.31618916  1.24606767  0.77375323  0.13508092]\n",
      " [-3.23047832 -3.70068841  0.97861508  2.04540755  9.15771009 11.3497254 ]]\n",
      "[[ 4.03355805  3.79382798 -0.66348842 -3.93126303 -2.72278322 -0.48521272]\n",
      " [ 2.09779013  3.29115733  0.04644298 -0.70230721 -0.39206483 -3.58938519]\n",
      " [-2.94907774 -7.19514914  0.38820613  1.70774028  0.10729651  0.10151446]\n",
      " [-5.20454913 -3.36212986  0.69167243 -0.38727032  8.96608914 18.16291187]]\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": 45,
   "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": 46,
   "id": "de4db779-ea88-4543-944d-46c15b3e31de",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAqIAAAIjCAYAAADY7XmOAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8hTgPZAAAACXBIWXMAAA9hAAAPYQGoP6dpAABjG0lEQVR4nO3dd3gU5drH8d9sAkmAJHQCBAkghk6QGlCpmkM7FAsgR3pRuqgcOSrFhooUjwqICFGpioKIVCkWmlQF5KUJAkroJCFAArvz/sFhdUmATZhkCPv9XNdcFzv7zDP3DEPycD9lDNM0TQEAAABZzGF3AAAAAPBNNEQBAABgCxqiAAAAsAUNUQAAANiChigAAABsQUMUAAAAtqAhCgAAAFvQEAUAAIAtaIgCAADAFjREcUdp0KCBGjRoYFl9ERER6tKli2X1QTIMQyNGjLA7jCy3evVqGYah1atXp+s4nsGM89VnDchOaIgiU8TGxsowDG3atMnuUG5q7dq1GjFihM6ePZup54mIiJBhGO4td+7cqlWrlj755JNMPS+uGDFihMf9z5Url+666y61bNlS06ZNU3Jyst0h3lau/hv++1a4cGE1bNhQixcvtjs8AHcIf7sDAKy0bNmydB+zdu1ajRw5Ul26dFHevHk9vtu9e7ccDuv+vxYVFaVnnnlGknT06FFNmTJFnTt3VnJysnr27GnZeW5nFy5ckL+/fT96Jk6cqDx58ig5OVl//PGHli5dqm7dumn8+PFauHChSpQokSnnfeCBB3ThwgXlzJkzXcdZ/Qym18svv6xSpUrJNE0dO3ZMsbGxatasmb7++mu1aNHCtrgA3BloiOKOkt5f8jcTEBBgaX3FixfXv/71L/fnLl26qHTp0ho3blyWN0STkpKUO3fuLD2nJAUGBmb5Of/ukUceUcGCBd2fhw0bphkzZqhTp0569NFHtX79+kw5r8PhyNC1W/0MplfTpk1Vo0YN9+fu3burSJEimjVrlk81RO369wLc6eiah622bt2qpk2bKiQkRHny5FHjxo3TbAj88ssvql+/voKCghQeHq5XX31V06ZNk2EYOnjwoLtcWmNE3333XVWsWFG5cuVSvnz5VKNGDc2cOVPSle7a5557TpJUqlQpdxfk1TrTGp939uxZPf3004qIiFBAQIDCw8PVqVMnnTx5Mt3XX6hQIZUrV0779+/32O9yuTR+/HhVrFhRgYGBKlKkiHr37q0zZ86kKjdixAgVK1ZMuXLlUsOGDfXrr7+mivtqN+t3332nPn36qHDhwgoPD3d/v3jxYt1///3KnTu3goOD1bx5c+3cudPjXHFxceratavCw8MVEBCgokWLqlWrVh73f9OmTYqJiVHBggUVFBSkUqVKqVu3bh71pDVuz5vn4Oo1rFmzRoMHD1ahQoWUO3dutWnTRidOnPD2lqepY8eO6tGjhzZs2KDly5d7fLdhwwb94x//UGhoqHLlyqX69etrzZo1qer4448/1L17dxUrVkwBAQEqVaqUnnrqKaWkpEhKe4zo3r179fDDDyssLEyBgYEKDw9X+/btFR8f7y6T1jP422+/6dFHH1X+/PmVK1cu1alTR998841Hmavn++yzz/Taa68pPDxcgYGBaty4sfbt25fhe5U3b14FBQWlymonJSXpmWeeUYkSJRQQEKDIyEi9/fbbMk3TXebgwYMyDEOxsbGp6r32ubg6lGLfvn3u3orQ0FB17dpV58+f9zg2OTlZTz/9tAoVKqTg4GD985//1JEjR1Kd4/fff1efPn0UGRmpoKAgFShQQI8++qjHMyxd/9/LqlWrZBiG5s2bl6rumTNnyjAMrVu3zou7COAqMqKwzc6dO3X//fcrJCREQ4YMUY4cOfTBBx+oQYMG+u6771S7dm1JV37BN2zYUIZhaOjQocqdO7emTJniVaboww8/1IABA/TII49o4MCBunjxon755Rdt2LBBjz/+uNq2bas9e/Zo1qxZGjdunDtTVqhQoTTrO3funO6//37t2rVL3bp107333quTJ09qwYIFOnLkiEemzRuXL1/WkSNHlC9fPo/9vXv3VmxsrLp27aoBAwbowIEDeu+997R161atWbNGOXLkkCQNHTpUb731llq2bKmYmBj9/PPPiomJ0cWLF9M8X58+fVSoUCENGzZMSUlJkqRPP/1UnTt3VkxMjN58802dP39eEydO1H333aetW7cqIiJCkvTwww9r586d6t+/vyIiInT8+HEtX75chw4dcn9+6KGHVKhQIT3//PPKmzevDh48qC+//PKG98Db5+Cq/v37K1++fBo+fLgOHjyo8ePHq1+/fpozZ0667v21nnjiCU2ePFnLli3Tgw8+KElauXKlmjZtqurVq2v48OFyOByaNm2aGjVqpB9++EG1atWSJP3555+qVauWzp49q169eqlcuXL6448/NHfuXJ0/fz7NTH1KSopiYmKUnJys/v37KywsTH/88YcWLlyos2fPKjQ0NM04jx07prp16+r8+fMaMGCAChQooI8//lj//Oc/NXfuXLVp08aj/BtvvCGHw6Fnn31W8fHxeuutt9SxY0dt2LDBq/sSHx+vkydPyjRNHT9+XO+++67OnTvnkdk3TVP//Oc/tWrVKnXv3l1RUVFaunSpnnvuOf3xxx8aN26cV+dKy2OPPaZSpUpp1KhR2rJli6ZMmaLChQvrzTffdJfp0aOHpk+frscff1x169bVypUr1bx581R1bdy4UWvXrlX79u0VHh6ugwcPauLEiWrQoIF+/fVX5cqVy6P8tf9eGjRooBIlSmjGjBmp7vOMGTNUpkwZRUdHZ/haAZ9kAplg2rRppiRz48aN1y3TunVrM2fOnOb+/fvd+/78808zODjYfOCBB9z7+vfvbxqGYW7dutW979SpU2b+/PlNSeaBAwfc++vXr2/Wr1/f/blVq1ZmxYoVbxjr6NGjU9VzVcmSJc3OnTu7Pw8bNsyUZH755Zepyrpcrhuep2TJkuZDDz1knjhxwjxx4oS5fft284knnjAlmX379nWX++GHH0xJ5owZMzyOX7Jkicf+uLg409/f32zdurVHuREjRpiSPOK++vdx3333mZcvX3bvT0xMNPPmzWv27NnTo464uDgzNDTUvf/MmTOmJHP06NHXvb558+bd9O/cNE1Tkjl8+HD3Z2+fg6vX0KRJE497/fTTT5t+fn7m2bNnb3je4cOHm5LMEydOpPn91Wts06aNaZpX/j7Lli1rxsTEeJzv/PnzZqlSpcwHH3zQva9Tp06mw+FI89qvHrtq1SpTkrlq1SrTNE1z69atpiTz888/v2Hc1z6DgwYNMiWZP/zwg3tfYmKiWapUKTMiIsJ0Op0e5ytfvryZnJzsLvvOO++Ykszt27ff8LxX7/e1W0BAgBkbG+tRdv78+aYk89VXX/XY/8gjj5iGYZj79u0zTdM0Dxw4YEoyp02blup81z4XV/++unXr5lGuTZs2ZoECBdyft23bZkoy+/Tp41Hu8ccfT1Xn+fPnU5133bp1piTzk08+SXXt1/57MU3THDp0qBkQEODxvB0/ftz09/f3OBcA79A1D1s4nU4tW7ZMrVu3VunSpd37ixYtqscff1w//vijEhISJElLlixRdHS0oqKi3OXy58+vjh073vQ8efPm1ZEjR7Rx40ZL4v7iiy9UtWrVVNkQ6UrX4s0sW7ZMhQoVUqFChVS5cmV9+umn6tq1q0aPHu0u8/nnnys0NFQPPvigTp486d6qV6+uPHnyaNWqVZKkFStW6PLly+rTp4/HOfr373/d8/fs2VN+fn7uz8uXL9fZs2fVoUMHj3P5+fmpdu3a7nMFBQUpZ86cWr16darhAVddnei1cOFCXbp06ab3Qkrfc3BVr169PO71/fffL6fTqd9//92rc15Pnjx5JEmJiYmSpG3btmnv3r16/PHHderUKfe9SUpKUuPGjfX999/L5XLJ5XJp/vz5atmypcdYyquu91xczXguXbo0VVfzjSxatEi1atXSfffd5xF7r169dPDgQf36668e5bt27eqRkb3//vslXene98b777+v5cuXa/ny5Zo+fboaNmyoHj16eGS6Fy1aJD8/Pw0YMMDj2GeeeUamad7SLPsnn3zS4/P999+vU6dOuZ+LRYsWSVKqcw8aNChVXUFBQe4/X7p0SadOndLdd9+tvHnzasuWLanKX/vvRZI6deqk5ORkzZ07171vzpw5unz5skeWGIB3aIjCFidOnND58+cVGRmZ6rvy5cvL5XLp8OHDkq6M67r77rtTlUtr37X+/e9/K0+ePKpVq5bKli2rvn37pjm+z1v79+9XpUqVMnx87dq1tXz5ci1ZskRvv/228ubNqzNnzng0FPbu3av4+HgVLlzY3Wi9up07d07Hjx+XJHfD69r7kD9//lRd/VeVKlXK4/PevXslSY0aNUp1rmXLlrnPFRAQoDfffFOLFy9WkSJF9MADD+itt95SXFycu6769evr4Ycf1siRI1WwYEG1atXqpssipec5uOquu+7y+Hz1Wq/XQPbWuXPnJEnBwcGS/ro3nTt3TnVvpkyZouTkZMXHx+vEiRNKSEhI93NRqlQpDR48WFOmTFHBggUVExOj999/32N8aFp+//33696vq9//3a3er1q1aqlJkyZq0qSJOnbsqG+++UYVKlRQv3793ONff//9dxUrVsx9724WU3rcLP7ff/9dDodDZcqU8SiX1j26cOGChg0b5h7HWrBgQRUqVEhnz55N875f++9FksqVK6eaNWtqxowZ7n0zZsxQnTp1vPqZBMATY0RxRytfvrx2796thQsXasmSJfriiy80YcIEDRs2TCNHjszyeAoWLKgmTZpIkmJiYlSuXDm1aNFC77zzjgYPHizpygSkwoULe/yi+7vrjV/1xt8zQlfPJV0ZJxoWFpaq/N8npAwaNEgtW7bU/PnztXTpUr300ksaNWqUVq5cqWrVqskwDM2dO1fr16/X119/7V4WacyYMVq/fr0743irrs1QXWX+bVJMRuzYsUPSXw37q/dm9OjRHtn4v8uTJ49Onz6d4XOOGTNGXbp00VdffaVly5ZpwIABGjVqlNavX+8xmexWWH2/HA6HGjZsqHfeeUd79+5VxYoVvT72etlhp9N53WOsjL9///6aNm2aBg0apOjoaIWGhsowDLVv39799/131/57uapTp04aOHCgjhw5ouTkZK1fv17vvfdeuuMBQEMUNilUqJBy5cql3bt3p/ru//7v/+RwONzrOZYsWTLNWb7ezvzNnTu32rVrp3bt2iklJUVt27bVa6+9pqFDhyowMNCrLvWrypQp426wWKF58+aqX7++Xn/9dfXu3Vu5c+dWmTJl9O2336pevXrX/UUoXbkv0pX78PfMzalTp7zOdl3NIhUuXNjdQL5Z+WeeeUbPPPOM9u7dq6ioKI0ZM0bTp093l6lTp47q1Kmj1157TTNnzlTHjh01e/Zs9ejRI1V96XkOMtunn34q6cp/EKS/7k1ISMgN702hQoUUEhKS4eeicuXKqly5sl588UWtXbtW9erV06RJk/Tqq6+mWb5kyZLXvV9Xv89sly9flvRXFrlkyZL69ttvlZiY6JEVvTamq9nMa18ecSsZ05IlS8rlcmn//v0eWdC07tHcuXPVuXNnjRkzxr3v4sWL6X6ZRfv27TV48GDNmjVLFy5cUI4cOdSuXbsMXwPgy+iahy38/Pz00EMP6auvvvJYOuXYsWOaOXOm7rvvPoWEhEi60jBYt26dtm3b5i53+vTp62YM/+7UqVMen3PmzKkKFSrINE33OMarawN688vo4Ycf1s8//5zm8i0ZzTD9+9//1qlTp/Thhx9KujJL2Ol06pVXXklV9vLly+44GzduLH9/f02cONGjTHoyMzExMQoJCdHrr7+e5rjOq8sinT9/PtVM/DJlyig4ONjd9X7mzJlU9+BqJvF63fPpeQ4y08yZMzVlyhRFR0ercePGkqTq1aurTJkyevvtt90Nrr+7em8cDodat26tr7/+Os03iV3vuUhISHA36K6qXLmyHA7HDYczNGvWTD/99JPHMkFJSUmaPHmyIiIiVKFChZtf8C24dOmSli1bppw5c7q73ps1ayan05nq2Rs3bpwMw1DTpk0lXWnUFyxYUN9//71HuQkTJmQ4nqt1//e///XYP378+FRl/fz8Uv19vPvuuzfMyKalYMGCatq0qaZPn64ZM2boH//4R7pXzABwBRlRZKqpU6dqyZIlqfYPHDhQr776qpYvX6777rtPffr0kb+/vz744AMlJyfrrbfecpcdMmSIpk+frgcffFD9+/d3L99011136fTp0zfMaD700EMKCwtTvXr1VKRIEe3atUvvvfeemjdv7s7cVK9eXZL0wgsvqH379sqRI4datmyZ5uLVzz33nObOnatHH31U3bp1U/Xq1XX69GktWLBAkyZNUtWqVdN9j5o2bapKlSpp7Nix6tu3r+rXr6/evXtr1KhR2rZtmx566CHlyJFDe/fu1eeff6533nlHjzzyiIoUKaKBAwdqzJgx+uc//6l//OMf+vnnn7V48WIVLFjQq0xvSEiIJk6cqCeeeEL33nuv2rdvr0KFCunQoUP65ptvVK9ePb333nvas2ePGjdurMcee0wVKlSQv7+/5s2bp2PHjql9+/aSpI8//lgTJkxQmzZtVKZMGSUmJurDDz9USEiImjVrdt0YvH0OrDJ37lzlyZNHKSkp7jcrrVmzRlWrVtXnn3/uLudwODRlyhQ1bdpUFStWVNeuXVW8eHH98ccfWrVqlUJCQvT1119Lkl5//XUtW7ZM9evXV69evVS+fHkdPXpUn3/+uX788cdUb+ySriwN1a9fPz366KO65557dPnyZX366afy8/PTww8/fN34n3/+ec2aNUtNmzbVgAEDlD9/fn388cc6cOCAvvjiC8vfwrR48WJ3ZvP48eOaOXOm9u7dq+eff979n4SWLVuqYcOGeuGFF3Tw4EFVrVpVy5Yt01dffaVBgwZ5jN/s0aOH3njjDfXo0UM1atTQ999/rz179mQ4vqioKHXo0EETJkxQfHy86tatqxUrVqTZY9KiRQt9+umnCg0NVYUKFbRu3Tp9++23KlCgQLrP26lTJz3yyCOSlOZ/GgF4ybb5+rijXW/pl6vb4cOHTdM0zS1btpgxMTFmnjx5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iHrp5MmTcjqdKlKkiMf+IkWKXHe8WVxcXLrK3ykycq8iIyM1depUffXVV5o+fbpcLpfq1q2rI0eOZEXI2cr1nquEhARduHDBpqhuT0WLFtWkSZP0xRdf6IsvvlCJEiXUoEEDbdmyxe7QsozL5dKgQYNUr149VapU6brlfPXn1bW8vV++/DNr+/btypMnjwICAvTkk09q3rx5qlChQpplea5wM/52BwBIUnR0tMf/qOvWravy5cvrgw8+0CuvvGJjZMjOIiMjFRkZ6f5ct25d7d+/X+PGjdOnn35qY2RZp2/fvtqxY4d+/PFHu0PJFry9X778MysyMlLbtm1TfHy85s6dq86dO+u77767bmMUuBEyol4qWLCg/Pz8dOzYMY/9x44dU1hYWJrHhIWFpav8nSIj9+paOXLkULVq1bRv377MCDFbu95zFRISoqCgIJuiyj5q1arlM89Vv379tHDhQq1atUrh4eE3LOurP6/+Lj3361q+9DMrZ86cuvvuu1W9enWNGjVKVatW1TvvvJNmWZ4r3AwNUS/lzJlT1atX14oVK9z7XC6XVqxYcd2xMdHR0R7lJWn58uXXLX+nyMi9upbT6dT27dtVtGjRzAoz2/LV58oq27Ztu+OfK9M01a9fP82bN08rV65UqVKlbnqMLz9XGblf1/Lln1kul0vJyclpfufLzxW8ZPdsqexk9uzZZkBAgBkbG2v++uuvZq9evcy8efOacXFxpmma5hNPPGE+//zz7vJr1qwx/f39zbffftvctWuXOXz4cDNHjhzm9u3b7bqELJPeezVy5Ehz6dKl5v79+83Nmzeb7du3NwMDA82dO3fadQlZJjEx0dy6dau5detWU5I5duxYc+vWrebvv/9umqZpPv/88+YTTzzhLv/bb7+ZuXLlMp977jlz165d5vvvv2/6+fmZS5YssesSskx679W4cePM+fPnm3v37jW3b99uDhw40HQ4HOa3335r1yVkiaeeesoMDQ01V69ebR49etS9nT9/3l2Gn1d/ycj98tWfWc8//7z53XffmQcOHDB/+eUX8/nnnzcNwzCXLVtmmibPFdKPhmg6vfvuu+Zdd91l5syZ06xVq5a5fv1693f169c3O3fu7FH+s88+M++55x4zZ86cZsWKFc1vvvkmiyO2T3ru1aBBg9xlixQpYjZr1szcsmWLDVFnvatLDF27Xb0/nTt3NuvXr5/qmKioKDNnzpxm6dKlzWnTpmV53HZI77168803zTJlypiBgYFm/vz5zQYNGpgrV660J/gslNY9kuTxnPDz6i8ZuV+++jOrW7duZsmSJc2cOXOahQoVMhs3buxuhJomzxXSzzBN08y6/CsAAABwBWNEAQAAYAsaogAAALAFDVEAAADYgoYoAAAAbEFDFAAAALagIQoAAABb0BAFAACALWiIAgAAwBY0RAHYokGDBho0aFCmniMiIkLjx4/P1HMAADLO3+4AACCzbNy4Ublz57Y7DADAddAQBXDHKlSokN0hAABugK55ALa5fPmy+vXrp9DQUBUsWFAvvfSSTNOUJBmGofnz53uUz5s3r2JjYyVJjRo1Ur9+/Ty+P3HihHLmzKkVK1ZISt01bxiGpkyZojZt2ihXrlwqW7asFixY4FHHggULVLZsWQUGBqphw4b6+OOPZRiGzp49a+m1AwBoiAKw0ccffyx/f3/99NNPeueddzR27FhNmTLFq2N79OihmTNnKjk52b1v+vTpKl68uBo1anTd40aOHKnHHntMv/zyi5o1a6aOHTvq9OnTkqQDBw7okUceUevWrfXzzz+rd+/eeuGFF27tIgEA10VDFIBtSpQooXHjxikyMlIdO3ZU//79NW7cOK+Obdu2rSTpq6++cu+LjY1Vly5dZBjGdY/r0qWLOnTooLvvvluvv/66zp07p59++kmS9MEHHygyMlKjR49WZGSk2rdvry5dumT8AgEAN0RDFIBt6tSp49FojI6O1t69e+V0Om96bGBgoJ544glNnTpVkrRlyxbt2LHjpg3HKlWquP+cO3duhYSE6Pjx45Kk3bt3q2bNmh7la9Wq5e3lAADSiclKAG5LhmG4x4tedenSJY/PPXr0UFRUlI4cOaJp06apUaNGKlmy5A3rzZEjR6rzuFwua4IGAKQLGVEAttmwYYPH5/Xr16ts2bLy8/NToUKFdPToUfd3e/fu1fnz5z3KV65cWTVq1NCHH36omTNnqlu3brcUT2RkpDZt2uSxb+PGjbdUJwDg+miIArDNoUOHNHjwYO3evVuzZs3Su+++q4EDB0q6Miv+vffe09atW7Vp0yY9+eSTqbKZ0pWs6BtvvCHTNNWmTZtbiqd37976v//7P/373//Wnj179Nlnn7ln6d9o3CkAIGNoiAKwTadOnXThwgXVqlVLffv21cCBA9WrVy9J0pgxY1SiRAndf//9evzxx/Xss88qV65cqero0KGD/P391aFDBwUGBt5SPKVKldLcuXP15ZdfqkqVKpo4caJ71nxAQMAt1Q0ASM0wrx2EBQDZyMGDB1WmTBlt3LhR9957r+X1v/baa5o0aZIOHz5sed0A4OuYrAQgW7p06ZJOnTqlF198UXXq1LGsETphwgTVrFlTBQoU0Jo1azR69OhUC+cDAKxBQxRAtrRmzRo1bNhQ99xzj+bOnWtZvXv37tWrr76q06dP66677tIzzzyjoUOHWlY/AOAvdM0DAADAFkxWAgAAgC1oiAIAAMAWNEQBAABgCxqiAAAAsAUNUQAAANiChigAAABsQUMUAAAAtqAhCgAAAFv8P3/OLG9K64TBAAAAAElFTkSuQmCC",
      "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": 47,
   "id": "bff87fe6-d656-416c-88a7-47fd6d503a63",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAqIAAAIjCAYAAADY7XmOAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8hTgPZAAAACXBIWXMAAA9hAAAPYQGoP6dpAABjJklEQVR4nO3dd3wUdf7H8fdsAgklCZ0AQQKIoROkBpSuOUCOYgHkpBePLionp1JsqEjxlCJyEJUqKIhIlWKhSVXajyYIKKGTQIAEduf3B5fVJQE2YZIh7Ov5eMzjwc5+5zufGYbky+dbxjBN0xQAAACQyRx2BwAAAADfREMUAAAAtqAhCgAAAFvQEAUAAIAtaIgCAADAFjREAQAAYAsaogAAALAFDVEAAADYgoYoAAAAbEFDFPeUBg0aqEGDBpbVFx4ers6dO1tWHyTDMDR8+HC7w8h0a9askWEYWrNmTZqO4xlMP1991oCshIYoMkRMTIwMw9DmzZvtDuW21q1bp+HDh+v8+fMZep7w8HAZhuHecuXKpZo1a+rTTz/N0PPiuuHDh3vc/5w5c+q+++5TixYtNG3aNCUmJtod4l0l+d/wX7dChQqpYcOGWrJkid3hAbhH+NsdAGCl5cuXp/mYdevWacSIEercubPy5Mnj8d3evXvlcFj3/7XIyEg9//zzkqTjx49rypQp6tSpkxITE9WjRw/LznM3u3z5svz97fvRM3HiROXOnVuJiYn6/ffftWzZMnXt2lXjxo3TokWLVLx48Qw5b7169XT58mVlz549TcdZ/Qym1WuvvaaSJUvKNE2dOHFCMTExatasmb7++ms99thjtsUF4N5AQxT3lLT+kr+dgIAAS+srVqyY/vGPf7g/d+7cWaVKldLYsWMzvSGakJCgXLlyZeo5JSkwMDDTz/lXTzzxhAoUKOD+PHToUM2YMUMdO3bUk08+qQ0bNmTIeR0OR7qu3epnMK2aNm2q6tWruz9369ZNhQsX1qxZs3yqIWrXvxfgXkfXPGy1bds2NW3aVMHBwcqdO7caN26cakPgl19+Uf369ZUjRw6FhYXpjTfe0LRp02QYhg4fPuwul9oY0Q8++EAVKlRQzpw5lTdvXlWvXl0zZ86UdL279sUXX5QklSxZ0t0FmVxnauPzzp8/r+eee07h4eEKCAhQWFiYOnbsqNOnT6f5+gsWLKiyZcvq4MGDHvtdLpfGjRunChUqKDAwUIULF1avXr107ty5FOWGDx+uokWLKmfOnGrYsKF2796dIu7kbtbvvvtOvXv3VqFChRQWFub+fsmSJXr44YeVK1cuBQUFqXnz5tq1a5fHuWJjY9WlSxeFhYUpICBARYoUUcuWLT3u/+bNmxUdHa0CBQooR44cKlmypLp27epRT2rj9rx5DpKvYe3atRo0aJAKFiyoXLlyqXXr1jp16pS3tzxVHTp0UPfu3bVx40atWLHC47uNGzfqb3/7m0JCQpQzZ07Vr19fa9euTVHH77//rm7duqlo0aIKCAhQyZIl9c9//lNJSUmSUh8jun//fj3++OMKDQ1VYGCgwsLC1K5dO8XFxbnLpPYM/vrrr3ryySeVL18+5cyZU7Vr19Y333zjUSb5fJ9//rnefPNNhYWFKTAwUI0bN9aBAwfSfa/y5MmjHDlypMhqJyQk6Pnnn1fx4sUVEBCgiIgIvffeezJN013m8OHDMgxDMTExKeq98blIHkpx4MABd29FSEiIunTpokuXLnkcm5iYqOeee04FCxZUUFCQ/v73v+vYsWMpzvHbb7+pd+/eioiIUI4cOZQ/f349+eSTHs+wdPN/L6tXr5ZhGJo/f36KumfOnCnDMLR+/Xov7iKAZGREYZtdu3bp4YcfVnBwsAYPHqxs2bLpo48+UoMGDfTdd9+pVq1akq7/gm/YsKEMw9CQIUOUK1cuTZkyxatM0ccff6z+/fvriSee0IABA3TlyhX98ssv2rhxo55++mm1adNG+/bt06xZszR27Fh3pqxgwYKp1nfx4kU9/PDD2rNnj7p27aoHH3xQp0+f1sKFC3Xs2DGPTJs3rl27pmPHjilv3rwe+3v16qWYmBh16dJF/fv316FDh/Thhx9q27ZtWrt2rbJlyyZJGjJkiN599121aNFC0dHR+vnnnxUdHa0rV66ker7evXurYMGCGjp0qBISEiRJn332mTp16qTo6Gi98847unTpkiZOnKiHHnpI27ZtU3h4uCTp8ccf165du9SvXz+Fh4fr5MmTWrFihY4cOeL+/Oijj6pgwYJ66aWXlCdPHh0+fFhffvnlLe+Bt89Bsn79+ilv3rwaNmyYDh8+rHHjxqlv376aM2dOmu79jZ555hlNnjxZy5cv1yOPPCJJWrVqlZo2bapq1app2LBhcjgcmjZtmho1aqQffvhBNWvWlCT98ccfqlmzps6fP6+ePXuqbNmy+v333zVv3jxdunQp1Ux9UlKSoqOjlZiYqH79+ik0NFS///67Fi1apPPnzyskJCTVOE+cOKE6dero0qVL6t+/v/Lnz69PPvlEf//73zVv3jy1bt3ao/zbb78th8OhF154QXFxcXr33XfVoUMHbdy40av7EhcXp9OnT8s0TZ08eVIffPCBLl686JHZN01Tf//737V69Wp169ZNkZGRWrZsmV588UX9/vvvGjt2rFfnSs1TTz2lkiVLauTIkdq6daumTJmiQoUK6Z133nGX6d69u6ZPn66nn35aderU0apVq9S8efMUdW3atEnr1q1Tu3btFBYWpsOHD2vixIlq0KCBdu/erZw5c3qUv/HfS4MGDVS8eHHNmDEjxX2eMWOGSpcuraioqHRfK+CTTCADTJs2zZRkbtq06aZlWrVqZWbPnt08ePCge98ff/xhBgUFmfXq1XPv69evn2kYhrlt2zb3vjNnzpj58uUzJZmHDh1y769fv75Zv3599+eWLVuaFSpUuGWso0aNSlFPshIlSpidOnVyfx46dKgpyfzyyy9TlHW5XLc8T4kSJcxHH33UPHXqlHnq1Clzx44d5jPPPGNKMvv06eMu98MPP5iSzBkzZngcv3TpUo/9sbGxpr+/v9mqVSuPcsOHDzclecSd/Pfx0EMPmdeuXXPvv3DhgpknTx6zR48eHnXExsaaISEh7v3nzp0zJZmjRo266fXNnz//tn/npmmaksxhw4a5P3v7HCRfQ5MmTTzu9XPPPWf6+fmZ58+fv+V5hw0bZkoyT506ler3ydfYunVr0zSv/32WKVPGjI6O9jjfpUuXzJIlS5qPPPKIe1/Hjh1Nh8OR6rUnH7t69WpTkrl69WrTNE1z27ZtpiRz7ty5t4z7xmdw4MCBpiTzhx9+cO+7cOGCWbJkSTM8PNx0Op0e5ytXrpyZmJjoLvv++++bkswdO3bc8rzJ9/vGLSAgwIyJifEou2DBAlOS+cYbb3jsf+KJJ0zDMMwDBw6Ypmmahw4dMiWZ06ZNS3G+G5+L5L+vrl27epRr3bq1mT9/fvfn7du3m5LM3r17e5R7+umnU9R56dKlFOddv369Kcn89NNPU1z7jf9eTNM0hwwZYgYEBHg8bydPnjT9/f09zgXAO3TNwxZOp1PLly9Xq1atVKpUKff+IkWK6Omnn9aPP/6o+Ph4SdLSpUsVFRWlyMhId7l8+fKpQ4cOtz1Pnjx5dOzYMW3atMmSuL/44gtVqVIlRTZEut61eDvLly9XwYIFVbBgQVWqVEmfffaZunTpolGjRrnLzJ07VyEhIXrkkUd0+vRp91atWjXlzp1bq1evliStXLlS165dU+/evT3O0a9fv5uev0ePHvLz83N/XrFihc6fP6/27dt7nMvPz0+1atVynytHjhzKnj271qxZk2J4QLLkiV6LFi3S1atXb3svpLQ9B8l69uzpca8ffvhhOZ1O/fbbb16d82Zy584tSbpw4YIkafv27dq/f7+efvppnTlzxn1vEhIS1LhxY33//fdyuVxyuVxasGCBWrRo4TGWMtnNnovkjOeyZctSdDXfyuLFi1WzZk099NBDHrH37NlThw8f1u7duz3Kd+nSxSMj+/DDD0u63r3vjfHjx2vFihVasWKFpk+froYNG6p79+4eme7FixfLz89P/fv39zj2+eefl2madzTL/tlnn/X4/PDDD+vMmTPu52Lx4sWSlOLcAwcOTFFXjhw53H++evWqzpw5o/vvv1958uTR1q1bU5S/8d+LJHXs2FGJiYmaN2+ee9+cOXN07do1jywxAO/QEIUtTp06pUuXLikiIiLFd+XKlZPL5dLRo0clXR/Xdf/996col9q+G/3rX/9S7ty5VbNmTZUpU0Z9+vRJdXyftw4ePKiKFSum+/hatWppxYoVWrp0qd577z3lyZNH586d82go7N+/X3FxcSpUqJC70Zq8Xbx4USdPnpQkd8PrxvuQL1++FF39yUqWLOnxef/+/ZKkRo0apTjX8uXL3ecKCAjQO++8oyVLlqhw4cKqV6+e3n33XcXGxrrrql+/vh5//HGNGDFCBQoUUMuWLW+7LFJanoNk9913n8fn5Gu9WQPZWxcvXpQkBQUFSfrz3nTq1CnFvZkyZYoSExMVFxenU6dOKT4+Ps3PRcmSJTVo0CBNmTJFBQoUUHR0tMaPH+8xPjQ1v/32203vV/L3f3Wn96tmzZpq0qSJmjRpog4dOuibb75R+fLl1bdvX/f4199++01FixZ137vbxZQWt4v/t99+k8PhUOnSpT3KpXaPLl++rKFDh7rHsRYoUEAFCxbU+fPnU73vN/57kaSyZcuqRo0amjFjhnvfjBkzVLt2ba9+JgHwxBhR3NPKlSunvXv3atGiRVq6dKm++OILTZgwQUOHDtWIESMyPZ4CBQqoSZMmkqTo6GiVLVtWjz32mN5//30NGjRI0vUJSIUKFfL4RfdXNxu/6o2/ZoSSzyVdHycaGhqaovxfJ6QMHDhQLVq00IIFC7Rs2TK9+uqrGjlypFatWqWqVavKMAzNmzdPGzZs0Ndff+1eFmn06NHasGGDO+N4p27MUCUz/zIpJj127twp6c+GffK9GTVqlEc2/q9y586ts2fPpvuco0ePVufOnfXVV19p+fLl6t+/v0aOHKkNGzZ4TCa7E1bfL4fDoYYNG+r999/X/v37VaFCBa+PvVl22Ol03vQYK+Pv16+fpk2bpoEDByoqKkohISEyDEPt2rVz/33/1Y3/XpJ17NhRAwYM0LFjx5SYmKgNGzboww8/THM8AGiIwiYFCxZUzpw5tXfv3hTf/d///Z8cDod7PccSJUqkOsvX25m/uXLlUtu2bdW2bVslJSWpTZs2evPNNzVkyBAFBgZ61aWerHTp0u4GixWaN2+u+vXr66233lKvXr2UK1culS5dWt9++63q1q1701+E0vX7Il2/D3/N3Jw5c8brbFdyFqlQoULuBvLtyj///PN6/vnntX//fkVGRmr06NGaPn26u0zt2rVVu3Ztvfnmm5o5c6Y6dOig2bNnq3v37inqS8tzkNE+++wzSdf/gyD9eW+Cg4NveW8KFiyo4ODgdD8XlSpVUqVKlfTKK69o3bp1qlu3riZNmqQ33ngj1fIlSpS46f1K/j6jXbt2TdKfWeQSJUro22+/1YULFzyyojfGlJzNvPHlEXeSMS1RooRcLpcOHjzokQVN7R7NmzdPnTp10ujRo937rly5kuaXWbRr106DBg3SrFmzdPnyZWXLlk1t27ZN9zUAvoyuedjCz89Pjz76qL766iuPpVNOnDihmTNn6qGHHlJwcLCk6w2D9evXa/v27e5yZ8+evWnG8K/OnDnj8Tl79uwqX768TNN0j2NMXhvQm19Gjz/+uH7++edUl29Jb4bpX//6l86cOaOPP/5Y0vVZwk6nU6+//nqKsteuXXPH2bhxY/n7+2vixIkeZdKSmYmOjlZwcLDeeuutVMd1Ji+LdOnSpRQz8UuXLq2goCB31/u5c+dS3IPkTOLNuufT8hxkpJkzZ2rKlCmKiopS48aNJUnVqlVT6dKl9d5777kbXH+VfG8cDodatWqlr7/+OtU3id3suYiPj3c36JJVqlRJDofjlsMZmjVrpp9++sljmaCEhARNnjxZ4eHhKl++/O0v+A5cvXpVy5cvV/bs2d1d782aNZPT6Uzx7I0dO1aGYahp06aSrjfqCxQooO+//96j3IQJE9IdT3Ld//nPfzz2jxs3LkVZPz+/FH8fH3zwwS0zsqkpUKCAmjZtqunTp2vGjBn629/+luYVMwBcR0YUGWrq1KlaunRpiv0DBgzQG2+8oRUrVuihhx5S79695e/vr48++kiJiYl699133WUHDx6s6dOn65FHHlG/fv3cyzfdd999Onv27C0zmo8++qhCQ0NVt25dFS5cWHv27NGHH36o5s2buzM31apVkyS9/PLLateunbJly6YWLVqkunj1iy++qHnz5unJJ59U165dVa1aNZ09e1YLFy7UpEmTVKVKlTTfo6ZNm6pixYoaM2aM+vTpo/r166tXr14aOXKktm/frkcffVTZsmXT/v37NXfuXL3//vt64oknVLhwYQ0YMECjR4/W3//+d/3tb3/Tzz//rCVLlqhAgQJeZXqDg4M1ceJEPfPMM3rwwQfVrl07FSxYUEeOHNE333yjunXr6sMPP9S+ffvUuHFjPfXUUypfvrz8/f01f/58nThxQu3atZMkffLJJ5owYYJat26t0qVL68KFC/r4448VHBysZs2a3TQGb58Dq8ybN0+5c+dWUlKS+81Ka9euVZUqVTR37lx3OYfDoSlTpqhp06aqUKGCunTpomLFiun333/X6tWrFRwcrK+//lqS9NZbb2n58uWqX7++evbsqXLlyun48eOaO3eufvzxxxRv7JKuLw3Vt29fPfnkk3rggQd07do1ffbZZ/Lz89Pjjz9+0/hfeuklzZo1S02bNlX//v2VL18+ffLJJzp06JC++OILy9/CtGTJEndm8+TJk5o5c6b279+vl156yf2fhBYtWqhhw4Z6+eWXdfjwYVWpUkXLly/XV199pYEDB3qM3+zevbvefvttde/eXdWrV9f333+vffv2pTu+yMhItW/fXhMmTFBcXJzq1KmjlStXptpj8thjj+mzzz5TSEiIypcvr/Xr1+vbb79V/vz503zejh076oknnpCkVP/TCMBLts3Xxz3tZku/JG9Hjx41TdM0t27dakZHR5u5c+c2c+bM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8mvq1Klq1bK1DMNQp06d7A7LUskL2lu9pUWpUqWULVs2bdq0yb0vLi5O+/btkySVK1dO165d08aNG93fnzlzRnv37lX58uXdZdauXetR79q1a/XAAw/Iz89PZcuW1bVr17Rlyxb393v37tX58+fTestuy9aG6Hfffac+ffpow4YNWrFiha5evapHH31UCQkJNz1m3bp1at++vbp166Zt27apVatWatWqlXbu3JmJkf+pZcuWWrlqlXI8+KCKvveeCv3rX1JIiNr/4xmvGtVAav79739rw7qfFKQiitYYtdQ0FVE1XbmSqLx589odHrKwChUqyiF/Rek5PaE5qqKOcjqdypkzp92hIQsz/te9XFrRaqMZaqjXFKBgTf90pnbv3m1zdPeWoKAgderUSS+++KJWr16tXbt2qVu3bnI4HDIMQ2XKlFHLli3Vo0cP/fjjj/r555/1j3/8Q8WKFXN3xz///PNauXKlXn/9de3bt0+ffPKJPvzwQ73wwguSpIiICP3tb39Tr169tHHjRm3ZskXdu3fPkGSIYZqmaXmt6XTq1CkVKlRI3333nerVq5dqmbZt2yohIUGLFi1y76tdu7YiIyM1adKk254jPj5eISEhiouL8xiLkV4O/2wKKFdOJb/8QoafnyQp8cABHfzb31S6VCkdOHDgjs8B32MYhhzyVz/tV16FS5KuKUmTVEWntU+m6bQ3QGRJbdu21eeff67HNEnV1cu9f5le0AaN09eLvlLz5s1tjBBZUXx8vPKG5FdpPaqntUjG/9bFPKzvFaP6kiQrmhpW//5Oz7l/2PmKcgcFWlr3xQtX9HDFN9J0XRcuXNCzzz6rBQsWKDg4WIMHD9bs2bPVqFEjjRw5UufOndOAAQO0cOFCJSUlqV69evrggw9UpkwZdx1ffPGFhg4dqv3796tIkSLq16+fuyEqSbGxserevbu+/fZbFS5cWG+88YZeffVVDRw40L1MlBXuqslKcXFxkqR8+fLdtMz69es1aNAgj33R0dFasGBBquUTExM9upysHg9lmi6FtHjM3QiVpID771dAmQd05NCvlp4LviVMUe5GqCT5K7sqqK1+0Fv2BYUsLfk/8BXV3mN/JbXXeo3Wv//9bxqiSLM333xTLl1TRbV3N0IlKVz1lEuFlCDrl/yxy93yrvmgoCCPdT0TEhI0YsQI9ezZU5KUN29e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hp0X97Zt27bJ399f651jtEkT5KcAJSpOkqG9e/fbHR6yqMjISAXlzKkLO3dpf7168suXT84zZyQ/f1WuWMHu8JCFTZ48Wc/27K1P1Vg5lF+JipMpl3LkDNSYMWPsDs8yLlMyLF5uyXVXzNSxT5bKiEZFRWnlypUe+1asWKGoqCibIpIeeughXbqcoNDQUF3RebmMJHXq1JHxobhj165dU6dOneRyJOmq44LKli2rK1cuq3Tp0naHhiwsPj5eb7w2QjLN641QSV99+YV+/vlnmyNDVtajRw+dOXdKefPm1WWdkWk49dKQfykhIcHu0HCXs3XW/MWLF3XgwPUxb1WrVtWYMWPUsGFD5cuXT/fdd5+GDBmi33//XZ9++qmk68s3VaxYUX369FHXrl21atUq9e/fX998842io6O9Oqeds+4AAED63A2z5sv/vE1+Fi915rxwQburVPXZdomtGdHNmzeratWqqlq1qiRp0KBBqlq1qoYOHSpJOn78uI78ZVB9yZIl9c0332jFihWqUqWKRo8erSlTpnjdCAUAAMjqli5dqoceekh58uRR/vz59dhjj+ngwT8nix07dkzt27dXvnz5lCtXLlWvXl0bN250f//111+rRo0aCgwMVIECBdS6dWs7LkOSzWNEGzRooFslZFN7a1KDBg20bdu2DIwKAAAgJadpSBaPEXX+r74bl7m61RyXhIQEDRo0SJUrV9bFixc1dOhQtW7dWtu3b9elS5dUv359FStWTAsXLlRoaKi2bt0ql+v6RNdvvvlGrVu31ssvv6xPP/1USUlJWrx4saXXlBZ3zYL2mYWueQAAsp67oWv+ga0/Z0jX/L4Hq6TYP2zYMA0fPtyrOk6fPq2CBQtqx44dWrdunV544QUdPnxY+fLlS1G2Tp06KlWqlKZPn36noVsiS82aBwAAuBcdPXrUo4F9qxV/9u/fr6FDh2rjxo06ffq0O9t55MgRbd++XVWrVk21ESpJ27dvV48ePawN/g7QEAUAAPCCS5JhcT9y8srQwcHBXmd6W7RooRIlSujjjz9W0aJF5XK5VLFiRSUlJd10Octkt/s+s2Wp5ZsAAAB82ZkzZ7R371698soraty4scqVK6dz5865v69cubK2b9+us2fPpnp85cqVUyyFaScaogAAAF5wuQw5Ld5crrRNfsqbN6/y58+vyZMn68CBA1q1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",
      "text/plain": [
       "<Figure size 800x600 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_decision_boundary(X_test_scaled_df, y_pred_2, \"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": 48,
   "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_1.py\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "id": "166d67f7-55ae-4e56-8ee5-a45649a95bf0",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Number of mismatched samples: 41\n"
     ]
    }
   ],
   "source": [
    "print(f\"Number of mismatched samples: {np.sum(y_pred_1 != y_pred_2)}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "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": 51,
   "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": 52,
   "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": 53,
   "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": 54,
   "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": 55,
   "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": 56,
   "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": 57,
   "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": "a481cf65-1ded-461a-aff4-a5baa1ca72b8",
   "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": null,
   "id": "3fe5baf7-8002-4e95-8c24-7843def2210e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 70,
   "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\"] == 0]\n",
    "    prediction0_2 = [i for i in range(len(data)) if data[i][\"output\"][\"model2\"] == 0]\n",
    "    return prediction0_1, prediction0_2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 71,
   "id": "5fc61a82-569c-4f68-859b-20e9c8b5c3b0",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model 1: 107\n",
      "Model 2: 132\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": 72,
   "id": "a2357944-fbcf-4247-b017-fb79bcef2736",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model 1: 105\n",
      "Model 2: 133\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": 73,
   "id": "127ea668-1a92-4dbd-9822-9708845a4d14",
   "metadata": {},
   "outputs": [],
   "source": [
    "verb_data2 = [{'input': [2, 0, 4, 2, 2, 1], 'output': {'model1': 0, 'model2': 0}}, {'input': [1, 0, 5, 4, 2, 1], 'output': {'model1': 2, 'model2': 2}}, {'input': [3, 0, 5, 2, 0, 0], 'output': {'model1': 0, 'model2': 0}}, {'input': [2, 3, 4, 4, 1, 2], 'output': {'model1': 0, 'model2': 0}}, {'input': [3, 2, 4, 2, 1, 0], 'output': {'model1': 0, 'model2': 0}}, {'input': [2, 1, 3, 5, 1, 1], 'output': {'model1': 1, 'model2': 0}}, {'input': [0, 3, 5, 5, 1, 2], 'output': {'model1': 1, 'model2': 0}}, {'input': [1, 2, 5, 2, 0, 0], 'output': {'model1': 0, 'model2': 0}}, {'input': [3, 2, 2, 5, 1, 1], 'output': {'model1': 0, 'model2': 0}}, {'input': [0, 0, 4, 4, 0, 0], 'output': {'model1': 2, 'model2': 2}}, {'input': [3, 2, 2, 2, 2, 1], 'output': {'model1': 0, 'model2': 0}}, {'input': [1, 2, 3, 5, 1, 2], 'output': {'model1': 1, 'model2': 0}}, {'input': [3, 0, 2, 4, 2, 0], 'output': {'model1': 0, 'model2': 0}}, {'input': [3, 3, 2, 2, 0, 0], 'output': {'model1': 0, 'model2': 0}}, {'input': [0, 3, 3, 5, 1, 2], 'output': {'model1': 1, 'model2': 0}}, {'input': [3, 0, 4, 5, 1, 0], 'output': {'model1': 0, 'model2': 0}}, {'input': [1, 1, 4, 4, 0, 2], 'output': {'model1': 1, 'model2': 0}}, {'input': [0, 3, 2, 5, 1, 0], 'output': {'model1': 0, 'model2': 1}}, {'input': [3, 2, 4, 2, 2, 2], 'output': {'model1': 0, 'model2': 0}}, {'input': [3, 2, 2, 2, 1, 0], 'output': {'model1': 0, 'model2': 0}}, {'input': [1, 3, 4, 2, 0, 2], 'output': {'model1': 0, 'model2': 0}}, {'input': [1, 0, 3, 2, 2, 0], 'output': {'model1': 0, 'model2': 0}}, {'input': [3, 2, 3, 4, 2, 1], 'output': {'model1': 0, 'model2': 0}}, {'input': [1, 0, 2, 4, 2, 1], 'output': {'model1': 2, 'model2': 2}}, {'input': [1, 3, 3, 2, 2, 1], 'output': {'model1': 0, 'model2': 0}}, {'input': [3, 0, 5, 5, 2, 1], 'output': {'model1': 1, 'model2': 0}}, {'input': [3, 3, 3, 2, 0, 2], 'output': {'model1': 0, 'model2': 0}}, {'input': [3, 0, 2, 4, 2, 1], 'output': {'model1': 0, 'model2': 0}}, {'input': [3, 0, 5, 4, 1, 0], 'output': {'model1': 0, 'model2': 0}}, {'input': [3, 1, 2, 4, 0, 0], 'output': {'model1': 0, 'model2': 0}}, {'input': [2, 2, 2, 4, 0, 2], 'output': {'model1': 0, 'model2': 0}}, {'input': [2, 1, 3, 2, 0, 2], 'output': {'model1': 0, 'model2': 0}}, {'input': [1, 0, 5, 2, 1, 2], 'output': {'model1': 0, 'model2': 0}}, {'input': [0, 1, 2, 4, 0, 0], 'output': {'model1': 0, 'model2': 0}}, {'input': [3, 2, 3, 4, 0, 2], 'output': {'model1': 0, 'model2': 0}}, {'input': [1, 3, 4, 5, 2, 2], 'output': {'model1': 1, 'model2': 0}}, {'input': [3, 2, 2, 4, 2, 2], 'output': {'model1': 0, 'model2': 0}}, {'input': [1, 2, 5, 2, 1, 0], 'output': {'model1': 0, 'model2': 0}}, {'input': [2, 0, 4, 5, 2, 2], 'output': {'model1': 3, 'model2': 2}}, {'input': [3, 1, 5, 5, 0, 1], 'output': {'model1': 0, 'model2': 0}}, {'input': [3, 2, 2, 5, 0, 2], 'output': {'model1': 0, 'model2': 0}}, {'input': [3, 0, 3, 2, 1, 0], 'output': {'model1': 0, 'model2': 0}}, {'input': [3, 1, 4, 4, 2, 2], 'output': {'model1': 0, 'model2': 0}}, {'input': [1, 0, 3, 2, 1, 0], 'output': {'model1': 0, 'model2': 0}}, {'input': [3, 2, 3, 2, 1, 2], 'output': {'model1': 0, 'model2': 0}}, {'input': [3, 3, 3, 2, 1, 0], 'output': {'model1': 0, 'model2': 0}}, {'input': [2, 0, 2, 5, 2, 2], 'output': {'model1': 3, 'model2': 2}}, {'input': [1, 1, 5, 2, 1, 2], 'output': {'model1': 0, 'model2': 0}}, {'input': [0, 3, 4, 2, 1, 2], 'output': {'model1': 0, 'model2': 0}}, {'input': [2, 1, 5, 4, 0, 0], 'output': {'model1': 0, 'model2': 0}}, {'input': [2, 1, 2, 4, 2, 1], 'output': {'model1': 0, 'model2': 0}}, {'input': [1, 0, 2, 5, 2, 0], 'output': {'model1': 2, 'model2': 2}}, {'input': [3, 0, 2, 5, 2, 2], 'output': {'model1': 1, 'model2': 0}}, {'input': [3, 1, 4, 4, 1, 2], 'output': {'model1': 0, 'model2': 0}}, {'input': [1, 2, 4, 4, 2, 2], 'output': {'model1': 1, 'model2': 0}}, {'input': [2, 3, 2, 2, 1, 0], 'output': {'model1': 0, 'model2': 0}}, {'input': [2, 3, 5, 5, 1, 0], 'output': {'model1': 0, 'model2': 0}}, {'input': [0, 0, 3, 2, 1, 2], 'output': {'model1': 2, 'model2': 0}}, {'input': [3, 3, 5, 4, 0, 1], 'output': {'model1': 0, 'model2': 0}}, {'input': [3, 1, 5, 4, 0, 1], 'output': {'model1': 0, 'model2': 0}}, {'input': [1, 0, 5, 4, 2, 0], 'output': {'model1': 2, 'model2': 2}}, {'input': [0, 3, 3, 2, 2, 2], 'output': {'model1': 0, 'model2': 0}}, {'input': [3, 2, 3, 2, 0, 1], 'output': {'model1': 0, 'model2': 0}}, {'input': [1, 1, 5, 4, 1, 2], 'output': {'model1': 1, 'model2': 0}}, {'input': [1, 2, 5, 4, 1, 0], 'output': {'model1': 0, 'model2': 0}}, {'input': [0, 1, 3, 5, 0, 1], 'output': {'model1': 1, 'model2': 0}}, {'input': [3, 1, 5, 2, 0, 2], 'output': {'model1': 0, 'model2': 0}}, {'input': [2, 2, 4, 5, 0, 1], 'output': {'model1': 0, 'model2': 0}}, {'input': [1, 3, 5, 2, 0, 1], 'output': {'model1': 0, 'model2': 0}}, {'input': [0, 1, 4, 4, 1, 2], 'output': {'model1': 2, 'model2': 0}}, {'input': [0, 3, 5, 4, 1, 2], 'output': {'model1': 1, 'model2': 0}}, {'input': [2, 3, 2, 5, 0, 0], 'output': {'model1': 0, 'model2': 0}}, {'input': [3, 2, 3, 2, 0, 0], 'output': {'model1': 0, 'model2': 0}}, {'input': [1, 0, 4, 5, 0, 2], 'output': {'model1': 2, 'model2': 2}}, {'input': [0, 3, 2, 5, 1, 1], 'output': {'model1': 1, 'model2': 0}}, {'input': [2, 3, 2, 4, 1, 0], 'output': {'model1': 0, 'model2': 0}}, {'input': [3, 1, 3, 2, 0, 0], 'output': {'model1': 0, 'model2': 0}}, {'input': [0, 1, 4, 2, 2, 1], 'output': {'model1': 0, 'model2': 0}}, {'input': [0, 0, 5, 2, 1, 1], 'output': {'model1': 2, 'model2': 0}}, {'input': [1, 3, 2, 5, 2, 2], 'output': {'model1': 1, 'model2': 0}}, {'input': [2, 3, 2, 4, 0, 2], 'output': {'model1': 0, 'model2': 0}}, {'input': [0, 0, 3, 5, 0, 1], 'output': {'model1': 2, 'model2': 2}}, {'input': [3, 0, 2, 4, 1, 2], 'output': {'model1': 0, 'model2': 0}}, {'input': [2, 2, 3, 5, 1, 1], 'output': {'model1': 0, 'model2': 0}}, {'input': [1, 0, 5, 2, 1, 0], 'output': {'model1': 0, 'model2': 0}}, {'input': [1, 2, 2, 5, 2, 2], 'output': {'model1': 1, 'model2': 0}}, {'input': [1, 2, 2, 5, 0, 1], 'output': {'model1': 0, 'model2': 0}}, {'input': [0, 3, 4, 5, 2, 2], 'output': {'model1': 1, 'model2': 0}}, {'input': [2, 1, 4, 5, 1, 2], 'output': {'model1': 1, 'model2': 0}}, {'input': [2, 0, 2, 2, 2, 1], 'output': {'model1': 0, 'model2': 0}}, {'input': [0, 0, 2, 4, 0, 2], 'output': {'model1': 2, 'model2': 2}}, {'input': [2, 1, 4, 4, 1, 0], 'output': {'model1': 0, 'model2': 0}}, {'input': [0, 0, 5, 2, 2, 0], 'output': {'model1': 0, 'model2': 2}}, {'input': [2, 2, 4, 4, 1, 0], 'output': {'model1': 0, 'model2': 0}}, {'input': [2, 3, 3, 2, 1, 1], 'output': {'model1': 0, 'model2': 0}}, {'input': [0, 2, 2, 4, 2, 2], 'output': {'model1': 1, 'model2': 0}}, {'input': [2, 2, 2, 2, 2, 0], 'output': {'model1': 0, 'model2': 0}}, {'input': [3, 1, 3, 5, 2, 0], 'output': {'model1': 0, 'model2': 0}}, {'input': [2, 3, 4, 4, 0, 1], 'output': {'model1': 0, 'model2': 0}}, {'input': [0, 0, 3, 2, 2, 1], 'output': {'model1': 2, 'model2': 0}}, {'input': [1, 2, 5, 4, 0, 0], 'output': {'model1': 0, 'model2': 0}}, {'input': [2, 1, 5, 5, 1, 0], 'output': {'model1': 0, 'model2': 1}}, {'input': [2, 0, 5, 2, 2, 1], 'output': {'model1': 0, 'model2': 0}}, {'input': [0, 2, 3, 2, 2, 1], 'output': {'model1': 0, 'model2': 0}}, {'input': [1, 0, 3, 4, 1, 0], 'output': {'model1': 0, 'model2': 0}}, {'input': [1, 0, 4, 5, 0, 1], 'output': {'model1': 2, 'model2': 2}}, {'input': [3, 0, 5, 5, 1, 0], 'output': {'model1': 0, 'model2': 0}}, {'input': [0, 3, 4, 4, 1, 0], 'output': {'model1': 0, 'model2': 0}}, {'input': [2, 1, 2, 5, 2, 2], 'output': {'model1': 1, 'model2': 0}}, {'input': [0, 0, 5, 5, 1, 2], 'output': {'model1': 2, 'model2': 2}}, {'input': [1, 3, 5, 2, 2, 2], 'output': {'model1': 0, 'model2': 0}}, {'input': [3, 0, 2, 5, 1, 0], 'output': {'model1': 0, 'model2': 0}}, {'input': [1, 0, 4, 5, 1, 0], 'output': {'model1': 2, 'model2': 2}}, {'input': [1, 1, 5, 5, 0, 1], 'output': {'model1': 1, 'model2': 0}}, {'input': [1, 2, 4, 5, 0, 1], 'output': {'model1': 1, 'model2': 0}}, {'input': [2, 0, 2, 2, 1, 0], 'output': {'model1': 0, 'model2': 0}}, {'input': [0, 0, 4, 4, 2, 2], 'output': {'model1': 2, 'model2': 2}}, {'input': [2, 1, 2, 2, 0, 0], 'output': {'model1': 0, 'model2': 0}}, {'input': [0, 3, 2, 2, 0, 1], 'output': {'model1': 0, 'model2': 0}}, {'input': [1, 0, 5, 2, 0, 1], 'output': {'model1': 0, 'model2': 0}}, {'input': [3, 0, 4, 4, 0, 1], 'output': {'model1': 0, 'model2': 0}}, {'input': [0, 2, 3, 2, 1, 2], 'output': {'model1': 0, 'model2': 0}}, {'input': [2, 2, 3, 2, 0, 1], 'output': {'model1': 0, 'model2': 0}}, {'input': [1, 1, 5, 2, 0, 1], 'output': {'model1': 0, 'model2': 0}}, {'input': [0, 1, 2, 4, 2, 0], 'output': {'model1': 0, 'model2': 1}}, {'input': [3, 0, 4, 5, 0, 2], 'output': {'model1': 1, 'model2': 0}}, {'input': [2, 3, 3, 5, 1, 2], 'output': {'model1': 1, 'model2': 0}}, {'input': [0, 3, 3, 2, 1, 2], 'output': {'model1': 0, 'model2': 0}}, {'input': [2, 3, 4, 4, 0, 2], 'output': {'model1': 0, 'model2': 0}}, {'input': [2, 3, 4, 4, 1, 1], 'output': {'model1': 0, 'model2': 0}}, {'input': [1, 2, 5, 4, 0, 1], 'output': {'model1': 0, 'model2': 0}}, {'input': [2, 3, 3, 4, 0, 0], 'output': {'model1': 0, 'model2': 0}}, {'input': [1, 2, 2, 5, 1, 2], 'output': {'model1': 1, 'model2': 0}}, {'input': [2, 1, 4, 4, 0, 2], 'output': {'model1': 1, 'model2': 0}}, {'input': [0, 1, 3, 2, 0, 2], 'output': {'model1': 0, 'model2': 0}}, {'input': [1, 3, 2, 5, 2, 0], 'output': {'model1': 0, 'model2': 1}}, {'input': [3, 2, 5, 2, 2, 0], 'output': {'model1': 0, 'model2': 0}}, {'input': [2, 1, 4, 4, 1, 2], 'output': {'model1': 1, 'model2': 0}}, {'input': [0, 0, 2, 5, 1, 2], 'output': {'model1': 2, 'model2': 2}}, {'input': [0, 2, 5, 5, 1, 1], 'output': {'model1': 1, 'model2': 1}}, {'input': [3, 0, 3, 4, 0, 1], 'output': {'model1': 0, 'model2': 0}}, {'input': [0, 3, 2, 5, 0, 0], 'output': {'model1': 0, 'model2': 0}}, {'input': [3, 3, 2, 2, 1, 0], 'output': {'model1': 0, 'model2': 0}}, {'input': [0, 3, 4, 4, 2, 2], 'output': {'model1': 1, 'model2': 0}}, {'input': [1, 1, 3, 5, 1, 0], 'output': {'model1': 0, 'model2': 1}}, {'input': [1, 1, 2, 2, 2, 2], 'output': {'model1': 0, 'model2': 0}}, {'input': [0, 1, 5, 4, 2, 1], 'output': {'model1': 2, 'model2': 2}}, {'input': [3, 2, 5, 4, 0, 0], 'output': {'model1': 0, 'model2': 0}}, {'input': [0, 3, 2, 2, 0, 2], 'output': {'model1': 0, 'model2': 0}}, {'input': [2, 2, 4, 2, 2, 1], 'output': {'model1': 0, 'model2': 0}}, {'input': [1, 3, 3, 4, 2, 1], 'output': {'model1': 0, 'model2': 0}}, {'input': [2, 1, 3, 5, 2, 0], 'output': {'model1': 0, 'model2': 1}}, {'input': [2, 3, 4, 4, 0, 0], 'output': {'model1': 0, 'model2': 0}}, {'input': [0, 1, 3, 4, 2, 2], 'output': {'model1': 3, 'model2': 0}}, {'input': [0, 3, 2, 4, 1, 1], 'output': {'model1': 0, 'model2': 0}}, {'input': [0, 3, 4, 2, 1, 1], 'output': {'model1': 0, 'model2': 0}}]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 74,
   "id": "cef65393-950e-4678-99ca-21cb4d14afd6",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "True"
      ]
     },
     "execution_count": 74,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4b830818-14c4-48fb-af2e-94071dc0f99f",
   "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
}
