{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "initial_id",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-05-22T07:41:03.562265Z",
     "start_time": "2024-05-22T07:41:03.559003Z"
    }
   },
   "outputs": [],
   "source": [
    "# Standard Imports\n",
    "import copy\n",
    "\n",
    "# Third Party Imports\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "from sklearn.linear_model import LogisticRegression\n",
    "from sklearn.metrics import accuracy_score\n",
    "from sklearn.model_selection import train_test_split\n",
    "from sklearn.preprocessing import StandardScaler"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "644fbcb1-a948-4036-8fec-6f18369ec046",
   "metadata": {},
   "source": [
    "#### Data Preparation"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "bc9ca94d-fd7a-46c5-932d-01ca644994c9",
   "metadata": {},
   "source": [
    "**Reading the Blood 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>Recency (months)</th>\n",
       "      <th>Frequency (times)</th>\n",
       "      <th>Monetary (c.c. blood)</th>\n",
       "      <th>Time (months)</th>\n",
       "      <th>Blood Donated</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>2</td>\n",
       "      <td>50</td>\n",
       "      <td>12500</td>\n",
       "      <td>98</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0</td>\n",
       "      <td>13</td>\n",
       "      <td>3250</td>\n",
       "      <td>28</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>1</td>\n",
       "      <td>16</td>\n",
       "      <td>4000</td>\n",
       "      <td>35</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>2</td>\n",
       "      <td>20</td>\n",
       "      <td>5000</td>\n",
       "      <td>45</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>1</td>\n",
       "      <td>24</td>\n",
       "      <td>6000</td>\n",
       "      <td>77</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   Recency (months)  Frequency (times)  Monetary (c.c. blood)  Time (months)  \\\n",
       "0                 2                 50                  12500             98   \n",
       "1                 0                 13                   3250             28   \n",
       "2                 1                 16                   4000             35   \n",
       "3                 2                 20                   5000             45   \n",
       "4                 1                 24                   6000             77   \n",
       "\n",
       "   Blood Donated  \n",
       "0              1  \n",
       "1              1  \n",
       "2              1  \n",
       "3              1  \n",
       "4              0  "
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Reading the Blood Dataset\n",
    "blood = pd.read_csv(\"./../../../datasets/blood/blood.data\")\n",
    "blood.head()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "317ecda9-87df-40b3-918d-19b7ccd05777",
   "metadata": {},
   "source": [
    "**Print Info and Missing Values**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "1b167864-ced8-46fd-89d8-74266115ab90",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "<class 'pandas.core.frame.DataFrame'>\n",
      "RangeIndex: 748 entries, 0 to 747\n",
      "Data columns (total 5 columns):\n",
      " #   Column                 Non-Null Count  Dtype\n",
      "---  ------                 --------------  -----\n",
      " 0   Recency (months)       748 non-null    int64\n",
      " 1   Frequency (times)      748 non-null    int64\n",
      " 2   Monetary (c.c. blood)  748 non-null    int64\n",
      " 3   Time (months)          748 non-null    int64\n",
      " 4   Blood Donated          748 non-null    int64\n",
      "dtypes: int64(5)\n",
      "memory usage: 29.3 KB\n",
      "None\n",
      "\n",
      "\n",
      "\n",
      "Missing values:  False\n"
     ]
    }
   ],
   "source": [
    "print(blood.info())\n",
    "print(\"\\n\\n\")\n",
    "print(\"Missing values: \", blood.isnull().values.any())"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "d921143a-172f-4f29-80c6-5a877643d067",
   "metadata": {},
   "source": [
    "**Variance Check**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "948672e3-370b-466e-97ac-be927c47d05f",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Recency (months)              65.535\n",
       "Frequency (times)             34.098\n",
       "Monetary (c.c. blood)    2131094.230\n",
       "Time (months)                594.224\n",
       "Blood Donated                  0.182\n",
       "dtype: float64"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "blood.var().round(3)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "0aac7df9-f6fe-43ef-96a9-b10fa43a1ebf",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Log Transformation of Monetary (c.c. blood) to reduce the variance and range\n",
    "# blood['Monetary (c.c. blood)'] = blood['Monetary (c.c. blood)'] / 100\n",
    "# blood.var().round(3)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "a9aaeed7-a7e6-4fac-83fb-213f6b0c3774",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>Recency (months)</th>\n",
       "      <th>Frequency (times)</th>\n",
       "      <th>Monetary (c.c. blood)</th>\n",
       "      <th>Time (months)</th>\n",
       "      <th>Blood Donated</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>2</td>\n",
       "      <td>50</td>\n",
       "      <td>12500</td>\n",
       "      <td>98</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0</td>\n",
       "      <td>13</td>\n",
       "      <td>3250</td>\n",
       "      <td>28</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>1</td>\n",
       "      <td>16</td>\n",
       "      <td>4000</td>\n",
       "      <td>35</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>2</td>\n",
       "      <td>20</td>\n",
       "      <td>5000</td>\n",
       "      <td>45</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>1</td>\n",
       "      <td>24</td>\n",
       "      <td>6000</td>\n",
       "      <td>77</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   Recency (months)  Frequency (times)  Monetary (c.c. blood)  Time (months)  \\\n",
       "0                 2                 50                  12500             98   \n",
       "1                 0                 13                   3250             28   \n",
       "2                 1                 16                   4000             35   \n",
       "3                 2                 20                   5000             45   \n",
       "4                 1                 24                   6000             77   \n",
       "\n",
       "   Blood Donated  \n",
       "0              1  \n",
       "1              1  \n",
       "2              1  \n",
       "3              1  \n",
       "4              0  "
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "blood.head()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "06776d06-aac3-4cd8-b1e8-b8498381d713",
   "metadata": {},
   "source": [
    "**Checking the distribution of target values**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "339d9bbe-8754-4572-87e1-3365bed7af5e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Blood Donated\n",
       "0    0.762\n",
       "1    0.238\n",
       "Name: proportion, dtype: float64"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "blood[\"Blood Donated\"].value_counts(normalize=True).round(3)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "0ce86e3c-d237-459e-805b-83a02b971354",
   "metadata": {},
   "source": [
    "**Train-Test Split**"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "852899ac-5378-4914-a9e7-c206ded4d0de",
   "metadata": {},
   "source": [
    "Train - Test Split &nbsp;&nbsp;&nbsp;&nbsp; 60%-40%\n",
    "\n",
    "The Test-Set is Further split into Verb And Gen split\n",
    "\n",
    "Verb - Gen Split   &nbsp;&nbsp;&nbsp;&nbsp; 50%-50%"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "bf7ff54f-f3f4-40e6-8bc4-424d99ae8af8",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Train Test Split Stratified on Target Feature\n",
    "X_train, X_test, y_train, y_test = train_test_split(blood.drop(columns=\"Blood Donated\"), blood[\"Blood Donated\"], test_size=0.40, random_state=400, stratify=blood[\"Blood Donated\"])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "5cc4deea-e333-4ce0-890d-ad1078aac260",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Train Test Split on the Test set to get Verb and Gen Sets. Stratified on the Target Feature\n",
    "X_test_verb, X_test_gen, y_test_verb, y_test_gen = train_test_split(X_test, y_test, test_size=0.5, random_state=400, stratify=y_test)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "bda17883-3302-4fc9-8b3b-46c6c669a070",
   "metadata": {},
   "source": [
    "**Checking the distribution target values after the split**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "f79613d4",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Blood Donated\n",
      "0    0.761\n",
      "1    0.239\n",
      "Name: proportion, dtype: float64\n",
      "Blood Donated\n",
      "0    0.76\n",
      "1    0.24\n",
      "Name: proportion, dtype: float64\n",
      "Blood Donated\n",
      "0    0.767\n",
      "1    0.233\n",
      "Name: proportion, dtype: float64\n"
     ]
    }
   ],
   "source": [
    "print(y_train.value_counts(normalize=True).round(3))\n",
    "print(y_test_verb.value_counts(normalize=True).round(3))\n",
    "print(y_test_gen.value_counts(normalize=True).round(3))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ccf6c676-335d-4133-afa2-5161bd932f2a",
   "metadata": {},
   "source": [
    "**Variance Check**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "9bf865bb-067e-40f8-bfb8-03afba7c71a1",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Recency (months)              71.826\n",
       "Frequency (times)             38.962\n",
       "Monetary (c.c. blood)    2435111.807\n",
       "Time (months)                569.385\n",
       "dtype: float64"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "X_train.var().round(3)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "0a7a2750-30fc-45f5-97d9-9bd0863cab60",
   "metadata": {},
   "source": [
    "**Standardization**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "ebbccb2f-d31e-451c-83a4-ba3b35025796",
   "metadata": {},
   "outputs": [],
   "source": [
    "scaler = StandardScaler()\n",
    "X_train_scaled = scaler.fit_transform(X_train)\n",
    "X_test_gen_scaled = scaler.transform(X_test_gen)\n",
    "X_test_verb_scaled = scaler.transform(X_test_verb)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "99cb1c0e-8239-4489-a757-51307bfe7e8a",
   "metadata": {},
   "source": [
    "**Converting them back to dataframes**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "563a7aff-a958-42bf-a740-bfe04b397aee",
   "metadata": {},
   "outputs": [],
   "source": [
    "X_train_scaled_df = pd.DataFrame(X_train_scaled, columns=X_train.columns)\n",
    "X_test_gen_scaled_df = pd.DataFrame(X_test_gen_scaled, columns=X_test.columns)\n",
    "X_test_verb_scaled_df = pd.DataFrame(X_test_verb_scaled, columns=X_test.columns)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "d53928be",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Recency (months)         1.002\n",
       "Frequency (times)        1.002\n",
       "Monetary (c.c. blood)    1.002\n",
       "Time (months)            1.002\n",
       "dtype: float64"
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "X_train_scaled_df.var().round(3)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "97fe3ae9-5bdc-488c-9339-af497d6999ee",
   "metadata": {},
   "source": [
    "From here Onwards `X_test_verb_scaled_df` is going to be `X_test_scaled_df`. `X_test_gen_scaled_df` is not going to be used at all in the code"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "13015d0d-47a8-4148-9f3c-074d1eec82b6",
   "metadata": {},
   "outputs": [],
   "source": [
    "expansion_factor = 100\n",
    "X_train_scaled_df = X_train_scaled_df * expansion_factor\n",
    "X_test_verb_scaled_df = X_test_verb_scaled_df * expansion_factor\n",
    "X_test_gen_scaled_df = X_test_gen_scaled_df * expansion_factor"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "9090224d-4b22-423c-932d-990204d4c703",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Recency (months)         10022.37136\n",
       "Frequency (times)        10022.37136\n",
       "Monetary (c.c. blood)    10022.37136\n",
       "Time (months)            10022.37136\n",
       "dtype: float64"
      ]
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "X_train_scaled_df.var().round(5)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "61841898",
   "metadata": {},
   "outputs": [],
   "source": [
    "X_test_scaled_df = X_test_verb_scaled_df\n",
    "y_test = y_test_verb"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c89636ce-0600-405c-ad76-9f9edb475f76",
   "metadata": {},
   "source": [
    "#### Model Variations"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "98c6a1a3",
   "metadata": {},
   "source": [
    "**Base Model**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "1384fb24-8c96-4831-870f-5085890016c7",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_sag.py:349: ConvergenceWarning: The max_iter was reached which means the coef_ did not converge\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_sag.py:349: ConvergenceWarning: The max_iter was reached which means the coef_ did not converge\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_sag.py:349: ConvergenceWarning: The max_iter was reached which means the coef_ did not converge\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_sag.py:349: ConvergenceWarning: The max_iter was reached which means the coef_ did not converge\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_sag.py:349: ConvergenceWarning: The max_iter was reached which means the coef_ did not converge\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_sag.py:349: ConvergenceWarning: The max_iter was reached which means the coef_ did not converge\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_sag.py:349: ConvergenceWarning: The max_iter was reached which means the coef_ did not converge\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_sag.py:349: ConvergenceWarning: The max_iter was reached which means the coef_ did not converge\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_sag.py:349: ConvergenceWarning: The max_iter was reached which means the coef_ did not converge\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_sag.py:349: ConvergenceWarning: The max_iter was reached which means the coef_ did not converge\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_sag.py:349: ConvergenceWarning: The max_iter was reached which means the coef_ did not converge\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_sag.py:349: ConvergenceWarning: The max_iter was reached which means the coef_ did not converge\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_sag.py:349: ConvergenceWarning: The max_iter was reached which means the coef_ did not converge\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_sag.py:349: ConvergenceWarning: The max_iter was reached which means the coef_ did not converge\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_sag.py:349: ConvergenceWarning: The max_iter was reached which means the coef_ did not converge\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Best parameters found:  {'C': np.float64(22.64641798242547), 'class_weight': None, 'l1_ratio': np.float64(0.9353361101344497), 'max_iter': 673, 'penalty': 'l1', 'solver': 'liblinear', 'tol': np.float64(2.0361425074347295e-06)}\n",
      "Best score:  0.7924094881398253\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/model_selection/_validation.py:540: FitFailedWarning: \n",
      "125 fits failed out of a total of 250.\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",
      "20 fits failed with the following error:\n",
      "Traceback (most recent call last):\n",
      "  File \"/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/model_selection/_validation.py\", line 888, in _fit_and_score\n",
      "    estimator.fit(X_train, y_train, **fit_params)\n",
      "  File \"/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/base.py\", line 1473, in wrapper\n",
      "    return fit_method(estimator, *args, **kwargs)\n",
      "           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n",
      "  File \"/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py\", line 1194, in fit\n",
      "    solver = _check_solver(self.solver, self.penalty, self.dual)\n",
      "             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n",
      "  File \"/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py\", line 67, in _check_solver\n",
      "    raise ValueError(\n",
      "ValueError: Solver newton-cg supports only 'l2' or None penalties, got elasticnet penalty.\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "25 fits failed with the following error:\n",
      "Traceback (most recent call last):\n",
      "  File \"/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/model_selection/_validation.py\", line 888, in _fit_and_score\n",
      "    estimator.fit(X_train, y_train, **fit_params)\n",
      "  File \"/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/base.py\", line 1473, in wrapper\n",
      "    return fit_method(estimator, *args, **kwargs)\n",
      "           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n",
      "  File \"/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py\", line 1194, in fit\n",
      "    solver = _check_solver(self.solver, self.penalty, self.dual)\n",
      "             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n",
      "  File \"/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py\", line 67, in _check_solver\n",
      "    raise ValueError(\n",
      "ValueError: Solver lbfgs supports only 'l2' or None penalties, got elasticnet penalty.\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "40 fits failed with the following error:\n",
      "Traceback (most recent call last):\n",
      "  File \"/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/model_selection/_validation.py\", line 888, in _fit_and_score\n",
      "    estimator.fit(X_train, y_train, **fit_params)\n",
      "  File \"/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/base.py\", line 1473, in wrapper\n",
      "    return fit_method(estimator, *args, **kwargs)\n",
      "           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n",
      "  File \"/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py\", line 1194, in fit\n",
      "    solver = _check_solver(self.solver, self.penalty, self.dual)\n",
      "             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n",
      "  File \"/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py\", line 67, in _check_solver\n",
      "    raise ValueError(\n",
      "ValueError: Solver lbfgs supports only 'l2' or None penalties, got l1 penalty.\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "5 fits failed with the following error:\n",
      "Traceback (most recent call last):\n",
      "  File \"/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/model_selection/_validation.py\", line 888, in _fit_and_score\n",
      "    estimator.fit(X_train, y_train, **fit_params)\n",
      "  File \"/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/base.py\", line 1473, in wrapper\n",
      "    return fit_method(estimator, *args, **kwargs)\n",
      "           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n",
      "  File \"/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py\", line 1194, in fit\n",
      "    solver = _check_solver(self.solver, self.penalty, self.dual)\n",
      "             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n",
      "  File \"/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py\", line 75, in _check_solver\n",
      "    raise ValueError(\n",
      "ValueError: Only 'saga' solver supports elasticnet penalty, got solver=liblinear.\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "15 fits failed with the following error:\n",
      "Traceback (most recent call last):\n",
      "  File \"/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/model_selection/_validation.py\", line 888, in _fit_and_score\n",
      "    estimator.fit(X_train, y_train, **fit_params)\n",
      "  File \"/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/base.py\", line 1473, in wrapper\n",
      "    return fit_method(estimator, *args, **kwargs)\n",
      "           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n",
      "  File \"/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py\", line 1194, in fit\n",
      "    solver = _check_solver(self.solver, self.penalty, self.dual)\n",
      "             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n",
      "  File \"/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py\", line 67, in _check_solver\n",
      "    raise ValueError(\n",
      "ValueError: Solver sag supports only 'l2' or None penalties, got l1 penalty.\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "10 fits failed with the following error:\n",
      "Traceback (most recent call last):\n",
      "  File \"/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/model_selection/_validation.py\", line 888, in _fit_and_score\n",
      "    estimator.fit(X_train, y_train, **fit_params)\n",
      "  File \"/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/base.py\", line 1473, in wrapper\n",
      "    return fit_method(estimator, *args, **kwargs)\n",
      "           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n",
      "  File \"/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py\", line 1194, in fit\n",
      "    solver = _check_solver(self.solver, self.penalty, self.dual)\n",
      "             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n",
      "  File \"/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py\", line 67, in _check_solver\n",
      "    raise ValueError(\n",
      "ValueError: Solver newton-cg supports only 'l2' or None penalties, got l1 penalty.\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "10 fits failed with the following error:\n",
      "Traceback (most recent call last):\n",
      "  File \"/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/model_selection/_validation.py\", line 888, in _fit_and_score\n",
      "    estimator.fit(X_train, y_train, **fit_params)\n",
      "  File \"/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/base.py\", line 1473, in wrapper\n",
      "    return fit_method(estimator, *args, **kwargs)\n",
      "           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n",
      "  File \"/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py\", line 1194, in fit\n",
      "    solver = _check_solver(self.solver, self.penalty, self.dual)\n",
      "             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n",
      "  File \"/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py\", line 67, in _check_solver\n",
      "    raise ValueError(\n",
      "ValueError: Solver sag supports only 'l2' or None penalties, got elasticnet penalty.\n",
      "\n",
      "  warnings.warn(some_fits_failed_message, FitFailedWarning)\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/model_selection/_search.py:1102: UserWarning: One or more of the test scores are non-finite: [       nan        nan 0.64514357 0.63625468 0.63625468 0.64734082\n",
      " 0.64734082        nan 0.79240949        nan        nan 0.79240949\n",
      "        nan        nan        nan 0.68299625 0.64292135        nan\n",
      " 0.69642946 0.64958801        nan        nan        nan        nan\n",
      " 0.79240949 0.64736579 0.6384769  0.64514357        nan        nan\n",
      " 0.6451186  0.64734082        nan 0.79240949 0.69418227        nan\n",
      " 0.63845194        nan        nan        nan        nan 0.6451186\n",
      " 0.63622971 0.64734082 0.79240949        nan 0.79240949        nan\n",
      "        nan        nan]\n",
      "  warnings.warn(\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n"
     ]
    }
   ],
   "source": [
    "from sklearn.model_selection import RandomizedSearchCV\n",
    "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'],\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=50, cv=5, 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": 19,
   "id": "9c1d7336",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l1)\n",
      "  warnings.warn(\n"
     ]
    }
   ],
   "source": [
    "# Train the base model\n",
    "def train_base_model(X_train, y_train):\n",
    "    # model = LogisticRegression(C=0.1, random_state=400)\n",
    "    model = LogisticRegression(**best_params)\n",
    "    model.fit(X_train, y_train)\n",
    "    return model\n",
    "\n",
    "base_model = train_base_model(X_train_scaled_df, y_train)\n",
    "base_pred = base_model.predict(X_test_scaled_df)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "5f4bde23-82a5-4aa6-8e66-a21cb7dbb11b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.76\n"
     ]
    }
   ],
   "source": [
    "print(accuracy_score(y_test, base_pred))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "592177b8-82c2-4fa2-9882-d7ce7ae9a40e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'C': np.float64(22.64641798242547),\n",
       " 'class_weight': None,\n",
       " 'l1_ratio': np.float64(0.9353361101344497),\n",
       " 'max_iter': 673,\n",
       " 'penalty': 'l1',\n",
       " 'solver': 'liblinear',\n",
       " 'tol': np.float64(2.0361425074347295e-06)}"
      ]
     },
     "execution_count": 21,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "best_params"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "087401a5-0018-4860-a224-9966a4e1b198",
   "metadata": {},
   "source": [
    "**Functions to copy and modify coefficients of a model**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "9296776c",
   "metadata": {},
   "outputs": [],
   "source": [
    "# This function works for binary classification only\n",
    "def modify_coefficients(model, modification_factor=0.2):\n",
    "    modified_model = copy.deepcopy(model)\n",
    "    \n",
    "    # Get the coefficients and intercept\n",
    "    coef = modified_model.coef_[0]\n",
    "    intercept = modified_model.intercept_[0]\n",
    "    \n",
    "    # Modify coefficients\n",
    "    noise = np.random.normal(0, modification_factor, size=coef.shape)\n",
    "    modified_coef = coef * (1 + noise) # This helps scale the noise to the coefficients\n",
    "\n",
    "    # Print Modifications and Noise\n",
    "    print(f\"Modification Factor: {modification_factor}\", f\"Noise: {noise}\")\n",
    "    \n",
    "    # Modify intercept\n",
    "    modified_intercept = intercept * (1 + np.random.normal(0, modification_factor))\n",
    "    \n",
    "    # Set the modified coefficients and intercept\n",
    "    modified_model.coef_[0] = modified_coef\n",
    "    modified_model.intercept_[0] = modified_intercept\n",
    "    \n",
    "    return modified_model\n",
    "    \n",
    "# Function to compute the differences\n",
    "def compute_difference(pred1, pred2):\n",
    "    return np.mean(pred1 != pred2)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "fb632903-7860-4b55-9fb8-b8a185e0ac82",
   "metadata": {},
   "source": [
    "**Generate and Compare Model Variations**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "b20a39dd-a769-4559-87f8-6d7bf72cfa35",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Modification Factor: 0.1 Noise: [-0.00519642 -0.01111961  0.10417968 -0.12567393]\n",
      "Modification Factor: 0.2 Noise: [-0.34221075 -0.04117288 -0.04691426  0.22562881]\n",
      "Modification Factor: 0.3 Noise: [-0.18396009  0.41210655  0.48329759 -0.20676848]\n",
      "Modification Factor: 0.4 Noise: [-0.17924624  0.06493699  0.10289165 -0.51018234]\n",
      "Modification Factor: 0.5 Noise: [-0.53092831 -0.4946842  -0.22886161 -0.99209081]\n",
      "Modification Factor: 0.6 Noise: [ 0.13908178  0.38649556  0.51127362 -0.27841123]\n",
      "Modification Factor: 0.7 Noise: [ 1.09751752  0.82498934 -0.96876981 -1.22313366]\n",
      "Modification Factor: 0.8 Noise: [ 0.99558624 -0.01906908  0.76205417  0.19597115]\n",
      "Modification Factor: 0.9 Noise: [ 0.26701308  0.19867805 -0.38097075  1.6610536 ]\n",
      "Modification Factor: 1.0 Noise: [-0.55791623 -0.28522504 -1.04126664  0.48036943]\n",
      "Modification Factor: 1.1 Noise: [-0.36659306  0.82203934  0.61625259  0.63107983]\n",
      "Modification Factor: 1.2 Noise: [ 0.9175801  -0.16126198  1.58956521 -0.33171317]\n",
      "Modification Factor: 1.3 Noise: [ 0.53971044  0.97198609 -0.51028953 -0.52822129]\n",
      "Modification Factor: 1.4 Noise: [ 1.40126305 -0.6267554  -0.16251763  1.63662046]\n",
      "Modification Factor: 1.5 Noise: [-0.38680085  0.42756872 -2.10688553 -2.26362353]\n",
      "Modification Factor: 1.6 Noise: [4.40800528 3.21726849 4.03183738 0.91270012]\n",
      "Modification Factor: 1.7 Noise: [ 1.81597936 -2.03072373 -4.86146958  0.72115194]\n"
     ]
    }
   ],
   "source": [
    "# Generate Model Variations\n",
    "np.random.seed(21)\n",
    "# np.random.seed(125)\n",
    "# np.random.seed(120)\n",
    "# np.random.seed(100)\n",
    "\n",
    "# Create variations of the model\n",
    "variations = []\n",
    "modification_factors = [0.1, 0.2, 0.3, 0.4, 0.5, 0.6, 0.7, 0.8, 0.9, 1.0, 1.1, 1.2, 1.3, 1.4, 1.5, 1.6, 1.7]\n",
    "# modification_factors = [0.1, 0.3, 0.5, 0.7, 0.9, 1, 1.1, 1.3, 1.4]\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": 26,
   "id": "366a89cf-f11e-463c-ba84-3bbfcabbe0ad",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "With Model: Modified (factor=0.1), Diff: 0.013333333333333334\n",
      "With Model: Modified (factor=0.2), Diff: 0.03333333333333333\n",
      "With Model: Modified (factor=0.3), Diff: 0.02\n",
      "With Model: Modified (factor=0.4), Diff: 0.02\n",
      "With Model: Modified (factor=0.5), Diff: 0.17333333333333334\n",
      "Best Model till now is Modified (factor=0.5)\n",
      "With Model: Modified (factor=0.6), Diff: 0.02\n",
      "With Model: Modified (factor=0.7), Diff: 0.13333333333333333\n",
      "With Model: Modified (factor=0.8), Diff: 0.19333333333333333\n",
      "Best Model till now is Modified (factor=0.8)\n",
      "With Model: Modified (factor=0.9), Diff: 0.04\n",
      "With Model: Modified (factor=1.0), Diff: 0.6466666666666666\n",
      "With Model: Modified (factor=1.1), Diff: 0.5333333333333333\n",
      "With Model: Modified (factor=1.2), Diff: 0.04666666666666667\n",
      "With Model: Modified (factor=1.3), Diff: 0.31333333333333335\n",
      "With Model: Modified (factor=1.4), Diff: 0.3\n",
      "With Model: Modified (factor=1.5), Diff: 0.07333333333333333\n",
      "With Model: Modified (factor=1.6), Diff: 0.52\n",
      "With Model: Modified (factor=1.7), Diff: 0.25333333333333335\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.15 and diff <= 0.20):\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": 28,
   "id": "34016cf3-d5b9-46b2-8fee-29d49da5dccc",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "With Models: Modified (factor=0.1) vs Modified (factor=0.2), Diff: 0.02\n",
      "With Models: Modified (factor=0.1) vs Modified (factor=0.3), Diff: 0.006666666666666667\n",
      "With Models: Modified (factor=0.1) vs Modified (factor=0.4), Diff: 0.006666666666666667\n",
      "With Models: Modified (factor=0.1) vs Modified (factor=0.5), Diff: 0.18666666666666668\n",
      "With Models: Modified (factor=0.1) vs Modified (factor=0.6), Diff: 0.006666666666666667\n",
      "With Models: Modified (factor=0.1) vs Modified (factor=0.7), Diff: 0.14666666666666667\n",
      "With Models: Modified (factor=0.1) vs Modified (factor=0.8), Diff: 0.20666666666666667\n",
      "With Models: Modified (factor=0.1) vs Modified (factor=0.9), Diff: 0.02666666666666667\n",
      "With Models: Modified (factor=0.1) vs Modified (factor=1.0), Diff: 0.66\n",
      "With Models: Modified (factor=0.1) vs Modified (factor=1.1), Diff: 0.5466666666666666\n",
      "With Models: Modified (factor=0.1) vs Modified (factor=1.2), Diff: 0.03333333333333333\n",
      "With Models: Modified (factor=0.1) vs Modified (factor=1.3), Diff: 0.32666666666666666\n",
      "With Models: Modified (factor=0.1) vs Modified (factor=1.4), Diff: 0.3\n",
      "With Models: Modified (factor=0.1) vs Modified (factor=1.5), Diff: 0.06\n",
      "With Models: Modified (factor=0.1) vs Modified (factor=1.6), Diff: 0.5333333333333333\n",
      "With Models: Modified (factor=0.1) vs Modified (factor=1.7), Diff: 0.24\n",
      "With Models: Modified (factor=0.2) vs Modified (factor=0.3), Diff: 0.02666666666666667\n",
      "With Models: Modified (factor=0.2) vs Modified (factor=0.4), Diff: 0.02666666666666667\n",
      "With Models: Modified (factor=0.2) vs Modified (factor=0.5), Diff: 0.20666666666666667\n",
      "With Models: Modified (factor=0.2) vs Modified (factor=0.6), Diff: 0.02666666666666667\n",
      "With Models: Modified (factor=0.2) vs Modified (factor=0.7), Diff: 0.16666666666666666\n",
      "With Models: Modified (factor=0.2) vs Modified (factor=0.8), Diff: 0.22666666666666666\n",
      "With Models: Modified (factor=0.2) vs Modified (factor=0.9), Diff: 0.006666666666666667\n",
      "With Models: Modified (factor=0.2) vs Modified (factor=1.0), Diff: 0.68\n",
      "With Models: Modified (factor=0.2) vs Modified (factor=1.1), Diff: 0.5666666666666667\n",
      "With Models: Modified (factor=0.2) vs Modified (factor=1.2), Diff: 0.013333333333333334\n",
      "With Models: Modified (factor=0.2) vs Modified (factor=1.3), Diff: 0.3466666666666667\n",
      "With Models: Modified (factor=0.2) vs Modified (factor=1.4), Diff: 0.29333333333333333\n",
      "With Models: Modified (factor=0.2) vs Modified (factor=1.5), Diff: 0.04\n",
      "With Models: Modified (factor=0.2) vs Modified (factor=1.6), Diff: 0.5533333333333333\n",
      "With Models: Modified (factor=0.2) vs Modified (factor=1.7), Diff: 0.22\n",
      "With Models: Modified (factor=0.3) vs Modified (factor=0.4), Diff: 0.0\n",
      "With Models: Modified (factor=0.3) vs Modified (factor=0.5), Diff: 0.18\n",
      "With Models: Modified (factor=0.3) vs Modified (factor=0.6), Diff: 0.0\n",
      "With Models: Modified (factor=0.3) vs Modified (factor=0.7), Diff: 0.14\n",
      "With Models: Modified (factor=0.3) vs Modified (factor=0.8), Diff: 0.2\n",
      "With Models: Modified (factor=0.3) vs Modified (factor=0.9), Diff: 0.03333333333333333\n",
      "With Models: Modified (factor=0.3) vs Modified (factor=1.0), Diff: 0.6533333333333333\n",
      "With Models: Modified (factor=0.3) vs Modified (factor=1.1), Diff: 0.54\n",
      "With Models: Modified (factor=0.3) vs Modified (factor=1.2), Diff: 0.04\n",
      "With Models: Modified (factor=0.3) vs Modified (factor=1.3), Diff: 0.32\n",
      "With Models: Modified (factor=0.3) vs Modified (factor=1.4), Diff: 0.30666666666666664\n",
      "With Models: Modified (factor=0.3) vs Modified (factor=1.5), Diff: 0.06666666666666667\n",
      "With Models: Modified (factor=0.3) vs Modified (factor=1.6), Diff: 0.5266666666666666\n",
      "With Models: Modified (factor=0.3) vs Modified (factor=1.7), Diff: 0.24666666666666667\n",
      "With Models: Modified (factor=0.4) vs Modified (factor=0.5), Diff: 0.18\n",
      "With Models: Modified (factor=0.4) vs Modified (factor=0.6), Diff: 0.0\n",
      "With Models: Modified (factor=0.4) vs Modified (factor=0.7), Diff: 0.14\n",
      "With Models: Modified (factor=0.4) vs Modified (factor=0.8), Diff: 0.2\n",
      "With Models: Modified (factor=0.4) vs Modified (factor=0.9), Diff: 0.03333333333333333\n",
      "With Models: Modified (factor=0.4) vs Modified (factor=1.0), Diff: 0.6533333333333333\n",
      "With Models: Modified (factor=0.4) vs Modified (factor=1.1), Diff: 0.54\n",
      "With Models: Modified (factor=0.4) vs Modified (factor=1.2), Diff: 0.04\n",
      "With Models: Modified (factor=0.4) vs Modified (factor=1.3), Diff: 0.32\n",
      "With Models: Modified (factor=0.4) vs Modified (factor=1.4), Diff: 0.30666666666666664\n",
      "With Models: Modified (factor=0.4) vs Modified (factor=1.5), Diff: 0.06666666666666667\n",
      "With Models: Modified (factor=0.4) vs Modified (factor=1.6), Diff: 0.5266666666666666\n",
      "With Models: Modified (factor=0.4) vs Modified (factor=1.7), Diff: 0.24666666666666667\n",
      "With Models: Modified (factor=0.5) vs Modified (factor=0.6), Diff: 0.18\n",
      "With Models: Modified (factor=0.5) vs Modified (factor=0.7), Diff: 0.04\n",
      "With Models: Modified (factor=0.5) vs Modified (factor=0.8), Diff: 0.24666666666666667\n",
      "With Models: Modified (factor=0.5) vs Modified (factor=0.9), Diff: 0.21333333333333335\n",
      "With Models: Modified (factor=0.5) vs Modified (factor=1.0), Diff: 0.62\n",
      "With Models: Modified (factor=0.5) vs Modified (factor=1.1), Diff: 0.41333333333333333\n",
      "With Models: Modified (factor=0.5) vs Modified (factor=1.2), Diff: 0.22\n",
      "With Models: Modified (factor=0.5) vs Modified (factor=1.3), Diff: 0.15333333333333332\n",
      "With Models: Modified (factor=0.5) vs Modified (factor=1.4), Diff: 0.43333333333333335\n",
      "With Models: Modified (factor=0.5) vs Modified (factor=1.5), Diff: 0.19333333333333333\n",
      "With Models: Modified (factor=0.5) vs Modified (factor=1.6), Diff: 0.3466666666666667\n",
      "With Models: Modified (factor=0.5) vs Modified (factor=1.7), Diff: 0.4266666666666667\n",
      "With Models: Modified (factor=0.6) vs Modified (factor=0.7), Diff: 0.14\n",
      "With Models: Modified (factor=0.6) vs Modified (factor=0.8), Diff: 0.2\n",
      "With Models: Modified (factor=0.6) vs Modified (factor=0.9), Diff: 0.03333333333333333\n",
      "With Models: Modified (factor=0.6) vs Modified (factor=1.0), Diff: 0.6533333333333333\n",
      "With Models: Modified (factor=0.6) vs Modified (factor=1.1), Diff: 0.54\n",
      "With Models: Modified (factor=0.6) vs Modified (factor=1.2), Diff: 0.04\n",
      "With Models: Modified (factor=0.6) vs Modified (factor=1.3), Diff: 0.32\n",
      "With Models: Modified (factor=0.6) vs Modified (factor=1.4), Diff: 0.30666666666666664\n",
      "With Models: Modified (factor=0.6) vs Modified (factor=1.5), Diff: 0.06666666666666667\n",
      "With Models: Modified (factor=0.6) vs Modified (factor=1.6), Diff: 0.5266666666666666\n",
      "With Models: Modified (factor=0.6) vs Modified (factor=1.7), Diff: 0.24666666666666667\n",
      "With Models: Modified (factor=0.7) vs Modified (factor=0.8), Diff: 0.22\n",
      "With Models: Modified (factor=0.7) vs Modified (factor=0.9), Diff: 0.17333333333333334\n",
      "With Models: Modified (factor=0.7) vs Modified (factor=1.0), Diff: 0.6333333333333333\n",
      "With Models: Modified (factor=0.7) vs Modified (factor=1.1), Diff: 0.4533333333333333\n",
      "With Models: Modified (factor=0.7) vs Modified (factor=1.2), Diff: 0.18\n",
      "With Models: Modified (factor=0.7) vs Modified (factor=1.3), Diff: 0.18\n",
      "With Models: Modified (factor=0.7) vs Modified (factor=1.4), Diff: 0.4066666666666667\n",
      "With Models: Modified (factor=0.7) vs Modified (factor=1.5), Diff: 0.15333333333333332\n",
      "With Models: Modified (factor=0.7) vs Modified (factor=1.6), Diff: 0.38666666666666666\n",
      "With Models: Modified (factor=0.7) vs Modified (factor=1.7), Diff: 0.38666666666666666\n",
      "With Models: Modified (factor=0.8) vs Modified (factor=0.9), Diff: 0.23333333333333334\n",
      "With Models: Modified (factor=0.8) vs Modified (factor=1.0), Diff: 0.4533333333333333\n",
      "With Models: Modified (factor=0.8) vs Modified (factor=1.1), Diff: 0.34\n",
      "With Models: Modified (factor=0.8) vs Modified (factor=1.2), Diff: 0.24\n",
      "With Models: Modified (factor=0.8) vs Modified (factor=1.3), Diff: 0.24\n",
      "With Models: Modified (factor=0.8) vs Modified (factor=1.4), Diff: 0.18666666666666668\n",
      "With Models: Modified (factor=0.8) vs Modified (factor=1.5), Diff: 0.26666666666666666\n",
      "With Models: Modified (factor=0.8) vs Modified (factor=1.6), Diff: 0.32666666666666666\n",
      "With Models: Modified (factor=0.8) vs Modified (factor=1.7), Diff: 0.23333333333333334\n",
      "With Models: Modified (factor=0.9) vs Modified (factor=1.0), Diff: 0.6866666666666666\n",
      "With Models: Modified (factor=0.9) vs Modified (factor=1.1), Diff: 0.5733333333333334\n",
      "With Models: Modified (factor=0.9) vs Modified (factor=1.2), Diff: 0.006666666666666667\n",
      "With Models: Modified (factor=0.9) vs Modified (factor=1.3), Diff: 0.35333333333333333\n",
      "With Models: Modified (factor=0.9) vs Modified (factor=1.4), Diff: 0.2866666666666667\n",
      "With Models: Modified (factor=0.9) vs Modified (factor=1.5), Diff: 0.03333333333333333\n",
      "With Models: Modified (factor=0.9) vs Modified (factor=1.6), Diff: 0.56\n",
      "With Models: Modified (factor=0.9) vs Modified (factor=1.7), Diff: 0.21333333333333335\n",
      "With Models: Modified (factor=1.0) vs Modified (factor=1.1), Diff: 0.20666666666666667\n",
      "With Models: Modified (factor=1.0) vs Modified (factor=1.2), Diff: 0.6933333333333334\n",
      "With Models: Modified (factor=1.0) vs Modified (factor=1.3), Diff: 0.4666666666666667\n",
      "With Models: Modified (factor=1.0) vs Modified (factor=1.4), Diff: 0.41333333333333333\n",
      "With Models: Modified (factor=1.0) vs Modified (factor=1.5), Diff: 0.72\n",
      "With Models: Modified (factor=1.0) vs Modified (factor=1.6), Diff: 0.2733333333333333\n",
      "With Models: Modified (factor=1.0) vs Modified (factor=1.7), Diff: 0.5\n",
      "With Models: Modified (factor=1.1) vs Modified (factor=1.2), Diff: 0.58\n",
      "With Models: Modified (factor=1.1) vs Modified (factor=1.3), Diff: 0.2733333333333333\n",
      "With Models: Modified (factor=1.1) vs Modified (factor=1.4), Diff: 0.3\n",
      "With Models: Modified (factor=1.1) vs Modified (factor=1.5), Diff: 0.5533333333333333\n",
      "With Models: Modified (factor=1.1) vs Modified (factor=1.6), Diff: 0.09333333333333334\n",
      "With Models: Modified (factor=1.1) vs Modified (factor=1.7), Diff: 0.38666666666666666\n",
      "With Models: Modified (factor=1.2) vs Modified (factor=1.3), Diff: 0.36\n",
      "With Models: Modified (factor=1.2) vs Modified (factor=1.4), Diff: 0.29333333333333333\n",
      "With Models: Modified (factor=1.2) vs Modified (factor=1.5), Diff: 0.02666666666666667\n",
      "With Models: Modified (factor=1.2) vs Modified (factor=1.6), Diff: 0.5666666666666667\n",
      "With Models: Modified (factor=1.2) vs Modified (factor=1.7), Diff: 0.20666666666666667\n",
      "With Models: Modified (factor=1.3) vs Modified (factor=1.4), Diff: 0.4\n",
      "With Models: Modified (factor=1.3) vs Modified (factor=1.5), Diff: 0.3333333333333333\n",
      "With Models: Modified (factor=1.3) vs Modified (factor=1.6), Diff: 0.20666666666666667\n",
      "With Models: Modified (factor=1.3) vs Modified (factor=1.7), Diff: 0.46\n",
      "With Models: Modified (factor=1.4) vs Modified (factor=1.5), Diff: 0.32\n",
      "With Models: Modified (factor=1.4) vs Modified (factor=1.6), Diff: 0.2866666666666667\n",
      "With Models: Modified (factor=1.4) vs Modified (factor=1.7), Diff: 0.08666666666666667\n",
      "With Models: Modified (factor=1.5) vs Modified (factor=1.6), Diff: 0.54\n",
      "With Models: Modified (factor=1.5) vs Modified (factor=1.7), Diff: 0.23333333333333334\n",
      "With Models: Modified (factor=1.6) vs Modified (factor=1.7), Diff: 0.37333333333333335\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.15 and diff <= 0.20):\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": 29,
   "id": "84e9b87d-af8e-4cd9-b0df-14dd242c6958",
   "metadata": {},
   "outputs": [],
   "source": [
    "(model1_name, model1), (model2_name, model2) = best_pair"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "604a50ca-5b68-4263-9d01-961facc8345c",
   "metadata": {},
   "outputs": [],
   "source": [
    "(model2_name, model2), (model1_name, model1) = best_pair"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "9ea03138-8060-44ec-80ba-72d49272ec80",
   "metadata": {},
   "source": [
    "**Evaluate Both Models**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "6e595955-68c6-41b3-8b0e-051de7cf86ba",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model 1: Modified (factor=0.8)\n",
      "Model 1 accuracy: 0.7\n",
      "\n",
      "Model 2: Base Model\n",
      "Model 2 accuracy: 0.76\n",
      "\n",
      "Accuracy difference: 0.06000000000000005\n",
      "\n",
      "Percentage of different outputs: 19.33%\n",
      "\n",
      "\n",
      "\n",
      "[[-0.02311257  0.00672713  0.00788529 -0.00745692]]\n",
      "[[-0.01158185  0.0068579   0.00447506 -0.00623503]]\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": 32,
   "id": "80b922f5-4307-452f-90d2-397fc5e969ad",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Function to plot decision boundary\n",
    "def plot_decision_boundary(X_test, y_pred, feature_1, feature_2):\n",
    "    # Create a scatter plot of the predictions\n",
    "    plt.figure(figsize=(8, 6))\n",
    "    plt.scatter(X_test[feature_1], X_test[feature_2], c=y_pred, cmap='rainbow', edgecolor='black', s=20, vmin=0, vmax=1)\n",
    "    \n",
    "    # Add labels and title\n",
    "    plt.xlabel(feature_1)\n",
    "    plt.ylabel(feature_2)\n",
    "    plt.title('Logistic Regression Decision Boundary')\n",
    "    \n",
    "    # Add a colorbar to indicate the predicted classes\n",
    "    cbar = plt.colorbar()\n",
    "    cbar.set_ticks([0, 1])\n",
    "    cbar.set_ticklabels([\"No\", \"Yes\"])\n",
    "\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "6d4d70a4-794b-4bc0-8659-d244baa22e7c",
   "metadata": {},
   "source": [
    "**Model 1 Decision Boundary**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "id": "de4db779-ea88-4543-944d-46c15b3e31de",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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jw/i4uLk9VlZWUhISEBQUBAAICgoCBkZGTh27JjcZ+fOndBoNGjevLkRjoKIiIislsIAl9YVvLyud+PHj8fLL7+MuXPn4s0338Thw4fx9ddf4+uvvwYASJKEcePG4eOPP0bNmjXh7++PDz/8EL6+vujevTuAospop06d8Pbbb2PlypUoKCjA6NGj0bdv31LvXCciIiIi/TCbpPOll17Cpk2bMG3aNHz00Ufw9/fH559/jgEDBsh9pkyZggcPHmDEiBHIyMhAq1atEB0dDXt7e7nPmjVrMHr0aHTo0AEKhQK9evXCkiVLTHFIREREZE0MMabTLCa+LGI283Q+L0w5zxcRERE9m+dins7mleBqo+d5Ogs1cEu4bhZ5idlUOomIiIjMmiGmOBLmM6bTbG4kIiIiIiLzxUonERERkTFY+ZhOJp1ERERExsDL60REREREhsVKJxEREZExWPnldVY6iYiIiMjgWOkkIiIiMgaFpP9Kp8Z8Sp2sdBIRERGRwbHSSURERGQMhrh7XcO714mIiIiIZKx0EhERERmDIe5eN6MxnUw6iYiIiIyBl9eJiIiIiAyLlU4iIiIiY7Dyy+usdBIRERGRwbHSSURERGQMHNNJRERERGRYrHQSERERGYPCAGM61RzTSUREREQkY6WTiIiIyBgMMaZT39szICadRERERMZgiCmTlLy8TkREREQkY6WTiIiIyBis/PI6K51EREREZHCsdBIREREZA8d0EhEREREZFiudRERERMaglAxQ6dTod3sGxEonERERERkcK51ERERExqCQipq+t2kmmHQSERERGYMhnr2uMJ+L1uYTKRERERGZLVY6iYiIiIyBk8MTERERERkWK51ERERExmCQyeHNp35oPpESERERkdlipZOIiIjIGDimk4iIiIjIsFjpJCIiIjIGhUL/82pynk4iIiIiov/HSicRERGRMVj5mE4mnURERETGwMdgEhEREREZFiudRERERMZg5ZfXWekkIiIiIoNjpZOIiIjIGDhlEhERERGRYbHSSURERGQMHNNJRERERGRYZpN0zpo1C5IkabXatWvL63NzcxEeHo4KFSrA2dkZvXr1QmpqqtY2kpKSEBoaCkdHR3h5eWHy5MkoLCw09qEQERGRNVJKRfN06rWZT6XTrC6v161bFzt27JBf29j8f/jjx4/HH3/8gfXr18PNzQ2jR49Gz549ceDAAQCAWq1GaGgofHx8cPDgQdy6dQuDBg2Cra0t5s6da/RjISIiIiujkIqavrdpJswq6bSxsYGPj0+J5ZmZmfjuu++wdu1atG/fHgAQGRmJOnXq4NChQ2jRogViYmJw/vx57NixA97e3mjYsCHmzJmDqVOnYtasWbCzszP24RARERFZDbO5vA4Aly5dgq+vL6pVq4YBAwYgKSkJAHDs2DEUFBQgODhY7lu7dm1UqVIF8fHxAID4+HgEBgbC29tb7hMSEoKsrCycO3fusfvMy8tDVlaWViMiIiLSmd4vrRvgsZoGZDaRNm/eHFFRUYiOjsaKFStw5coVtG7dGvfv30dKSgrs7Ozg7u6u9R5vb2+kpKQAAFJSUrQSzuL1xeseJyIiAm5ubnKrXLmyfg+MiIiIyAqYzeX1zp07y/+vX78+mjdvDj8/P/zyyy9wcHAw2H6nTZuGCRMmyK+zsrKYeBIREZHuJAOM6ZTMZ0yn2VQ6H+Xu7o5atWrhr7/+go+PD/Lz85GRkaHVJzU1VR4D6uPjU+Ju9uLXpY0TLaZSqeDq6qrViIiIiEg3Zpt0Zmdn4/Lly6hYsSKaNGkCW1tbxMXFyesTExORlJSEoKAgAEBQUBDOnDmDtLQ0uU9sbCxcXV0REBBg9PiJiIjIylj5mE6zubw+adIkdO3aFX5+frh58yZmzpwJpVKJfv36wc3NDcOGDcOECRNQvnx5uLq64r333kNQUBBatGgBAOjYsSMCAgIwcOBALFiwACkpKZg+fTrCw8OhUqlMfHREREREls1sks7r16+jX79+uHv3Ljw9PdGqVSscOnQInp6eAIDFixdDoVCgV69eyMvLQ0hICJYvXy6/X6lUYsuWLRg5ciSCgoLg5OSEsLAwfPTRR6Y6JCIiIrImVj5PpySEEKYOwpxkZWXBzc0NmZmZHN9JRERkJkz5+1ve95KucHWw1e+2cwrgNuZ3s8hLzGcgABERERGZLbO5vE5ERERk1qz88jornURERERkcKx0EhERERmDIaY4MqMpk8wnUiIiIiIyW6x0EhERERkDx3QSERERERkWK51ERERExqAwwJhOhfnUD5l0EhERERkDL68TERERERkWK51ERERExqBQ6P9yuBldXjefSImIiIjIbLHSSURERGQMSgBKPY/BVOp3c4bESicRERERGRwrnURERETGwDGdRERERESGxUonERERkTFY+TydTDqJiIiIjEEpGeBGIvNJOnl5nYiIiIgMjpVOIiIiImPgjURERERERIbFSicRERGREWgkCRo93/ijkTimk4iIiIhIxkonERERkRFoFApo9DwGU9/bMyTziZSIiIiIzBYrnURERERGoFEYYEwnJ4cnIiIion9SKxVQK/V7kVnf2zMk84mUiIiIiMwWK51ERERERmDtl9dZ6SQiIiIig2Olk4iIiMgIhEIBoecpjvS9PUMyn0iJiIiIyGyx0klERERkBBzTSURERERkYKx0EhERERmBtVc6mXQSERERGUFR0qnvZ6+bT9LJy+tEREREZHCsdBIREREZgZD0f3ldSKx0EhERERHJWOkkIiIiMgK1pIBa0m+9T9/bMyTziZSIiIiIzBYrnURERERGYO1TJrHSSUREREQGx0onERERkRFYe6WTSScRERGREQiFAkLPk8Pre3uGZD6REhEREZHZYqWTiIiIyAis/fI6K51EREREZHCsdBIREREZgUahgEbPYzD1vT1DMp9IiYiIiMhsmW3SOW/ePEiShHHjxsnLcnNzER4ejgoVKsDZ2Rm9evVCamqq1vuSkpIQGhoKR0dHeHl5YfLkySgsLDRy9ERERGRtNJJkkGYuzDLpPHLkCL766ivUr19fa/n48ePx+++/Y/369dizZw9u3ryJnj17yuvVajVCQ0ORn5+PgwcPYtWqVYiKisKMGTOMfQhEREREVsXsks7s7GwMGDAA33zzDcqVKycvz8zMxHfffYdFixahffv2aNKkCSIjI3Hw4EEcOnQIABATE4Pz589j9erVaNiwITp37ow5c+Zg2bJlyM/PN9UhERERkRUovntd381cmF3SGR4ejtDQUAQHB2stP3bsGAoKCrSW165dG1WqVEF8fDwAID4+HoGBgfD29pb7hISEICsrC+fOnSt1f3l5ecjKytJqRERERKQbs7p7fd26dTh+/DiOHDlSYl1KSgrs7Ozg7u6utdzb2xspKSlyn38mnMXri9eVJiIiArNnz9ZD9ERERGTNhAHuXucTiQwgOTkZY8eOxZo1a2Bvb2+0/U6bNg2ZmZlyS05ONtq+iYiIyHKoIUEt6bmBl9f17tixY0hLS0Pjxo1hY2MDGxsb7NmzB0uWLIGNjQ28vb2Rn5+PjIwMrfelpqbCx8cHAODj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giMiIiKyFGohQS30fPe6nrdnSDonnWPHjkVUVBRCQ0NRr149SJL5HCwRERERmYbOSee6devwyy+/oEuXLoaIh4iIiMgicUynjuzs7FCjRg1DxEJERERksax9yiSdJ4efOHEivvjiCwghDBEPEREREVkgnSud+/fvx65du7Bt2zbUrVsXtra2Wus3btyot+CIiIiILIUGCmh0r/c9dZvmQuek093dHT169DBELERERERkoXROOiMjIw0RBxEREZFFE0KCRs9THAkzmjLpmWqyhYWF2LFjB7766ivcv38fAHDz5k1kZ2frNTgiIiIisgw6VzqvXbuGTp06ISkpCXl5eXj11Vfh4uKC+fPnIy8vDytXrjREnERERERmTQ0Jaj3fba7v7RmSzpXOsWPHomnTprh37x4cHBzk5T169EBcXJxegyMiIiIiy6BzpXPfvn04ePAg7OzstJZXrVoVN27c0FtgRERERJZECEnvYzDNaUynzkmnRqOBWq0usfz69etwcXHRS1BERERElsban0ik8+X1jh074vPPP5dfS5KE7OxszJw5k4/GJCIiIqJS6VzpXLhwIUJCQhAQEIDc3Fz0798fly5dgoeHB3766SdDxEhERERk9tRCglrPl8P1vT1D0jnprFSpEk6dOoV169bh9OnTyM7OxrBhwzBgwACtG4uIiIiIiIrpnHQCgI2NDd566y19x0JERERksax9TKfOSecPP/zwxPWDBg165mCIiIiIyDLpnHSOHTtW63VBQQEePnwIOzs7ODo6MukkIiIiKoW1T5mk893r9+7d02rZ2dlITExEq1ateCMREREREZXqmZ69/qiaNWti3rx5JaqgRERERFSkeEynvpu5eKYbiUrdkI0Nbt68qa/NEREREVkUjZCg0fPlcH1vz5B0Tjp/++03rddCCNy6dQtffvklWrZsqbfAiIiIiMhy6Jx0du/eXeu1JEnw9PRE+/btsXDhQn3FRURERGRRNAaYHN6iK50ajcYQcRARERGRBdPbmE4iIiIiejwBQOj5xh+h160Zls5J54QJE8rcd9GiRbpunoiIiIgskM5J54kTJ3DixAkUFBTgxRdfBABcvHgRSqUSjRs3lvtJkvmMMSAiIiIyNGu/e13neTq7du2KNm3a4Pr16zh+/DiOHz+O5ORktGvXDq+99hp27dqFXbt2YefOnXoNNCIi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RERkOXx8fPDdd9/iu+++hRCC058REZHBMekksnJMOImIjEMjJEi8vE5EluD06dMYMngI6tdrhNAur+H33383dUhEREQAmHQSWYydO3fipabN8NuaXbA71xxnYu7i9ddfx5w5c0wdGhERARAawzRzwcvrRBZACIHwke/Bt7AF3hLbYQMVoAbiMB2zZ83G0KFD8cILL5g6TCIismKsdBJZgKtXr+LPi+fRQkwoSjj/pyWmQKPRYNu2bSaMjoiIAEAj/n/aJP01Ux9V2THpJLIAxTcDCai1lgtoIMC704mIyPSYdBJZAD8/PwTWbYB4xafIx0MAgIDAXsyBjdIGoaGhJo6QiIg0/5tXU9/NXHBMJ5EFkCQJK75ahleDO+LLwmrwKwzGbeVppKjP4LP5n8HHx8fUIRIRkZVj0klkIVq2bImTp05g6dKlOH70JOpUCcA773yO9u3bmzo0IiICoBYSoOd5NdVmNE8nk04iC1KrVi0sXbrU1GEQEVEphEaC0PPlcH1vz5A4ppPITNy5cwdXr141dRhERETPhEkn0XNu7dq1sLWxgZenJ/z9/WErSejdu7epwyIiIh1pUDxtkh6bqQ9KB0w6iZ5jp0+fRtiAASinViMCwNcAGgHY9OuvGDRokImjIyIiKjsmnUTPsa5du0ID4ACAqQDeBrAfQG0AP61ebcrQiIhIRxqNBLWemzlNmcSkk+g5duPGDTQFUPMfy+wA9AMAYUaPoSAiIqvHu9eJnmO2tra4plZDDUD5j+VXAJjP37ZERAQUVTqh58okK51EpBeDBw9GKoD3AeQAEAA2A/gBgHO5ciaMjIiISDdMOomeYytWrICXlxc+A+ABwBtADwCQJJw+fdqksRERkW6EkAzSzAWTTqLnXGpqKiIiImBfvjxynJ3x2muvISc/H5UqVTJ1aEREpAONxjDNXDDpJDID77//Pu7evYv79+/j999/h40Nh2MTEZF54W8uIiIiIiPgjURERERERAbGSicRERGREag1EgQrnUREREREhsNKJxEREZERcEwnEREREZGBsdJJREREZARCU9T0vU1zwaSTiIiIyAjUBniCkIZPJCIiIiIi+n+sdBIREREZgRCS3m/84bPXDWTv3r3o2rUrfH19IUkSNm/erLVeCIEZM2agYsWKcHBwQHBwMC5duqTVJz09HQMGDICrqyvc3d0xbNgw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BwkJCTh27BiGDx9eauV237596Nix4xPjJyJ6HCadRFbM1dUVrq6uj10/b9489OrVCwMHDkTjxo3x119/Yfv27ShXrlyZ9xESEoItW7YgJiYGL730Elq0aIHFixdrXe5euHAhYmNjUblyZbmStmjRIpQrVw4vv/wyunbtipCQEDRu3LjM++3Xrx9sbGzQr1+/J17GB4oS8CFDhpSYKujXX3/FSy+9hH79+iEgIABTpkyRK7IFBQVITEzUGuOoa//SdOjQATVr1kSbNm3Qp08fvP7665g1a9Zj+0dGRqJJkyZ47bXXEBQUBCEEtm7dKg95aNy4MX755ResW7cO9erVw4wZM/DRRx9pjXGNjIyEr68v2rZti549e2LEiBHw8vLS2k98fDwyMzPRu3fvJ8ZPRPQ4khBCmDoIIiJ9u3r1KqpXr44jR46UKVlNSUlB3bp1cfz48SeO/7RWffr0QYMGDfCf//zH1KEQkZlipZOILEpBQQFSUlIwffp0tGjRoszVUR8fH3z33Xcl7o6nokv+gYGBGD9+vKlDISIzxkonEVmU3bt3o127dqhVqxY2bNiAwMBAU4dERERg0klERERERsDL60RERERkcEw6iYiIiMjgmHQSERERkcEx6SQiIiIig2PSSUREREQGx6STiIiIiAyOSScRERERGRyTTiIiIiIyuP8DvLFyAFsf2mIAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 800x600 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_decision_boundary(X_test_scaled_df, y_pred_1, \"Monetary (c.c. blood)\", \"Frequency (times)\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "599fcca1-20b3-4b16-89c4-4fba23c314ce",
   "metadata": {},
   "source": [
    "**Model 2 Decision Boundary**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "id": "bff87fe6-d656-416c-88a7-47fd6d503a63",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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4uLk9VlZWUhISEBgYCAAIDAwEBkZGTh27JjcZ9euXdBoNGjZsmU5HAURERFZLIUBLq0reHld7yZMmICXXnoJ8+bNwxtvvIHDhw/jq6++wldffQUAkCQJ48ePx0cffYTatWvDz88PH3zwAby9vdGjRw8ARZXRzp0746233sKqVatQUFCAMWPGoF+/fqXeuU5ERERE+mEySeeLL76IzZs3Y/r06fjwww/h5+eHzz77DAMHDpT7TJ06FQ8ePMDIkSORkZGBNm3aIDo6Gra2tnKftWvXYsyYMejUqRMUCgV69+6NpUuXGuOQiIiIyJIYYkynSUx8WcRk5ul8Xhhzni8iIiJ6Ns/FPJ0tq8LZSs/zdBZq4JJw3STyEpOpdBIRERGZNENMcSRMZ0ynydxIRERERESmi5VOIiIiovJg4WM6mXQSERERlQdeXiciIiIiMixWOomIiIjKg4VfXmelk4iIiIgMjpVOIiIiovKgkPRf6dSYTqmTlU4iIiIiMjhWOomIiIjKgyHuXtfw7nUiIiIiIhkrnURERETlwRB3r5vQmE4mnURERETlgZfXiYiIiIgMi5VOIiIiovJg4ZfXWekkIiIiIoNjpZOIiIioPHBMJxERERGRYbHSSURERFQeFAYY06nmmE4iIiIiIhkrnURERETlwRBjOvW9PQNi0klERERUHgwxZZKSl9eJiIiIiGSsdBIRERGVBwu/vM5KJxEREREZHCudREREROWBYzqJiIiIiAyLlU4iIiKi8qCUDFDp1Oh3ewbESicRERERGRwrnURERETlQSEVNX1v00Qw6SQiIiIqD4Z49rrCdC5am06kRERERGSyWOkkIiIiKg+cHJ6IiIiIyLBY6SQiIiIqDwaZHN506oemEykRERERmSxWOomIiIjKA8d0EhEREREZFiudREREROVBodD/vJqcp5OIiIiI6P+x0klERERUHix8TCeTTiIiIqLywMdgEhEREREZFiudREREROXBwi+vs9JJRERERAbHSicRERFReeCUSUREREREhsVKJxEREVF54JhOIiIiIiLDMpmkc/bs2ZAkSavVrVtXXp+bm4vw8HBUqlQJjo6O6N27N1JTU7W2kZSUhNDQUNjb28PDwwNTpkxBYWFheR8KERERWSKlVDRPp16b6VQ6Teryev369bFz5075tZXV/4c/YcIE/P7779iwYQNc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LQ3Ozs56D5CIiIiITJ/OSefMmTMxefJkVK9eHS1atEBgYCCAoqpnkyZN9B4gERERkTnQKCSo9dw0CtMpdep8eb1Pnz5o06YNbt26hUaNGsnLO3XqhJ49e+o1OCIiIiIyD8/07HUvLy9kZ2cjNjYW7dq1g52dHV588UVIJjRBKREREVF5MsSNP6Z0I5HOkd69exedOnVCnTp10LVrV9y6dQsAMHz4cEyaNEnvARIRERGR6dM56ZwwYQKsra2RlJQkTxAPAH379kV0dLRegyMiIiIyF0KSDNJMhc6X12NiYrBjxw5UrVpVa3nt2rU5ZRIRERERlUrnpPPBgwdaFc5i6enpUKlUegmKiIiIyNxoIOn9sZVm/RjMtm3byo/BBABJkqDRaLBw4UJ06NBBr8ERERERmQuNJBmkmQqdK50LFy5Ep06dcPToUeTn52Pq1Kk4d+4c0tPTceDAAUPESEREREQmTueks0GDBrh48SK++OILODk5ITs7G7169UJ4eDgqV65siBiJiIiITJ6lT5n0TPN0uri44P3339d3LERERERkpp4p6czNzcXp06eRlpYGjUajte61117TS2BERERE5sQQYzDNekxndHQ0Bg8ejDt37pRYJ0kS1Gq1XgIjIiIiIvOh80CAd999F6+//jpu3boFjUaj1ZhwEhEREZVOLUkGaaZC56QzNTUVEydOhKenpyHiISIiIiIzpHPS2adPH+zZs8cAoRARERGZL87TqaMvvvgCr7/+Ovbv34+AgABYW1trrR87dqzegiMiIiIyFxoooNG93vfUbZoKnZPOH3/8ETExMbC1tcWePXsg/SPDliSJSScRERERlaBz0vn+++9jzpw5eO+996BQmE52TURERGRUkgSh78vhJnR5XeesMT8/H3379mXCSURERERlpnPmGBYWhp9++skQsRARERGZLd5IpCO1Wo2FCxdix44daNiwYYkbiRYvXqy34IiIiIjIPOicdJ45cwZNmjQBAJw9e1ZrnWRC2TYRERFRedJAggZ6fgymnrdnSDonnbt37zZEHERERERkxnROOomIiIhId0VjMPU8T6cJXWUuU9LZq1cvREVFwdnZGb169Xpi302bNuklMCIiIiJzwsvrZeDi4iKP13R2dubYTSIiIiLSSZmSzsjISPnfUVFRhorliVauXImVK1fi6tWrAID69etj5syZ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44svvsDkyZMBAC+88AI6d+6Mt99+GwkJCTh27BhGjBhRauV2//79CA4OfmL8RESPw6STyII5OzvD2dn5sevnz5+P3r17Y9CgQWjatCn++usv7NixAxUqVCjzPkJCQrB161bExMTgxRdfRKtWrbBkyRKty92LFi1CbGwsfHx85Era4sWLUaFCBbz00kvo1q0bQkJC0LRp0zLvt3///rCyskL//v2feBkfKErAhw4dWmKqoF9++QUvvvgi+vfvD39/f0ydOlWuyBYUFCAxMVFrjKOu/UvTqVMn1K5dG+3atUPfvn3x2muvYfbs2Y/tHxkZiWbNmuHVV19FYGAghBDYtm2bPOShadOm+Pnnn7F+/Xo0aNAAM2fOxIcffqg1xjUyMhLe3t5o3749evXqhZEjR8LDw0NrP/Hx8cjMzESfPn2eGD8R0eNIQghh7CCIiPTt6tWrqFmzJo4cOVKmZDUlJQX169fH8ePHnzj+01L17dsXjRo1wn/+8x9jh0JEJoqVTiIyKwUFBUhJScGMGTPQqlWrMldHvby88O2335a4O56KLvkHBARgwoQJxg6FiEwYK51EZFb27NmDDh06oE6dOti4cSMCAgKMHRIREYFJJxERERGVA15eJyIiIiKDY9JJRERERAbHpJOIiIiIDI5JJxEREREZHJNOIiIiIjI4Jp1EREREZHBMOomIiIjI4Jh0EhEREZHB/R9XzXsf9OJAeAAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 800x600 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_decision_boundary(X_test_scaled_df, y_pred_2, \"Monetary (c.c. blood)\", \"Frequency (times)\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "id": "c3249b8a-a969-4b3c-a2a4-77e0e6f99f42",
   "metadata": {},
   "outputs": [],
   "source": [
    "def round_values(data, precision=3):\n",
    "    if isinstance(data, list):\n",
    "        return [round_values(item, precision) for item in data]\n",
    "    elif isinstance(data, dict):\n",
    "        return {key: round_values(value, precision) for key, value in data.items()}\n",
    "    elif isinstance(data, (int, float)):\n",
    "        return round(data, precision)\n",
    "    return data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "277cf8a1-0910-4840-a36e-2cbb3cbcdbd5",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2efbe7b5-3156-42e3-8867-3435af12d92b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f19681ea-701d-47e6-b783-53de3937da76",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "182bc281-2188-4ef1-bfb1-de796f9b4e87",
   "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": null,
   "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/blood/level_2.py\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "166d67f7-55ae-4e56-8ee5-a45649a95bf0",
   "metadata": {},
   "outputs": [],
   "source": [
    "print(f\"Number of mismatched samples: {np.sum(y_pred_1 != y_pred_2)}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d2ba908c-9ccc-43ed-aebc-34c5e3eeac92",
   "metadata": {},
   "outputs": [],
   "source": [
    "verb_data = []\n",
    "for idx in range(len(X_test_scaled_df)):\n",
    "    data_point = {\n",
    "        \"input\": round_values(X_test_scaled_df.iloc[idx].to_list()),\n",
    "        \"output\": {\n",
    "            \"model1\": int(y_pred_1[idx]),\n",
    "            \"model2\": int(y_pred_2[idx])\n",
    "        }\n",
    "    }\n",
    "    verb_data.append(data_point)\n",
    "\n",
    "print(f\"Number of samples in verb_data: {len(verb_data)}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e4051e96-5b23-4745-9954-d55495df2008",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "97da7c78-ebf8-4ce7-913f-88dc065fcf6e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "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": "9dada228-0bb5-4ec6-b117-cf5ecd20d768",
   "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": null,
   "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": null,
   "id": "5b11b0a3-deea-4f17-99f7-c992d2b470df",
   "metadata": {},
   "outputs": [],
   "source": [
    "gen_data = []\n",
    "for idx in range(len(X_test_gen_scaled_df)):\n",
    "    data_point = {\n",
    "        \"input\": round_values(X_test_gen_scaled_df.iloc[idx].to_list()),\n",
    "        \"output\": {\n",
    "            \"model1\": int(y_gen_pred_1[idx]),\n",
    "            \"model2\": int(y_gen_pred_2[idx])\n",
    "        }\n",
    "    }\n",
    "    gen_data.append(data_point)\n",
    "\n",
    "print(f\"Number of samples in gen_data: {len(gen_data)}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "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": null,
   "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": null,
   "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": "1ffcfa7d-c895-42f0-bee6-dec69c44e339",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0acfe6a3-a651-4bcf-91a6-1cf038ff43a6",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f985bf05-ccf6-4ba9-a6ee-c4a5eb7dc8f0",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bfe59780-2e74-4418-9a06-cff330c76e6c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "59b12448-1adf-43a5-bdad-c3b85be3fcc1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3e988969-a87e-42f7-8a5e-d161adb0d32a",
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_accuracy(a, b):\n",
    "    correct = 0\n",
    "    total = len(a)\n",
    "    \n",
    "    for i in range(len(a)):\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": "ad485001-fb0e-4ad4-a968-40ce44e0a33c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "23cd5e81-71ca-405f-a26e-836a19e3fcab",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "39b0dff0-f837-4af3-a039-2a269a492db5",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "432aac87-4b82-4366-8b72-6b1c2951d782",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "79f05dff-21c8-4b96-93ed-534230524c65",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "473a513b-6dea-497a-b710-5345bfb2a264",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "36199077-e835-45d7-9b7b-0a6f6b2133cd",
   "metadata": {},
   "outputs": [],
   "source": [
    "def prediction_zero(data):\n",
    "    prediction0_1 = [i for i in range(len(data)) if data[i][\"output\"][\"model1\"] == 1]\n",
    "    prediction0_2 = [i for i in range(len(data)) if data[i][\"output\"][\"model2\"] == 1]\n",
    "    return prediction0_1, prediction0_2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "aae6cf11-dea7-4ad8-b018-1a76ff690285",
   "metadata": {},
   "outputs": [],
   "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": null,
   "id": "ba93234e-dd91-46b5-8002-081ba7d2810d",
   "metadata": {},
   "outputs": [],
   "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": "b8339c15-a764-4120-9954-cfc0c0cbfa9a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f92cc5ac-5539-4b9e-af70-c11a63106546",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1ad80f5c-c487-4851-af7f-c5b45eab517a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "067664f2-4f75-4821-b979-6aaeae3e2be8",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d41aae9d-7dcc-4893-adaf-4e9082bde5ad",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "88d04ab0-774f-4f2a-8b11-5a687fcc1ed2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "505413c4-859b-4b67-9423-427c46c0e217",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7a5c4bdc-444e-4511-88b4-7067f0adf595",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cab6a327-4ac2-4d0e-a191-682ebdc7d13f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "95c94e15-3b72-4b88-8fa7-7dd9e5993159",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "11becfd7-0870-4c55-8094-a2f023dc98e5",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d2ad600e-5826-41c9-8f92-f9a7e5cbaa99",
   "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
}
