{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "initial_id",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-05-22T07:41:03.562265Z",
     "start_time": "2024-05-22T07:41:03.559003Z"
    }
   },
   "outputs": [],
   "source": [
    "# Standard Imports\n",
    "import copy\n",
    "\n",
    "# Third Party Imports\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "from sklearn.linear_model import LogisticRegression\n",
    "from sklearn.metrics import accuracy_score\n",
    "from sklearn.model_selection import train_test_split\n",
    "from sklearn.preprocessing import StandardScaler"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "644fbcb1-a948-4036-8fec-6f18369ec046",
   "metadata": {},
   "source": [
    "#### Data Preparation"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "bc9ca94d-fd7a-46c5-932d-01ca644994c9",
   "metadata": {},
   "source": [
    "**Reading the Diabetes Transfusion Dataset**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "77cb6a91a07ed68d",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-05-22T07:41:03.731947Z",
     "start_time": "2024-05-22T07:41:03.723709Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>Pregnancies</th>\n",
       "      <th>Glucose</th>\n",
       "      <th>BloodPressure</th>\n",
       "      <th>SkinThickness</th>\n",
       "      <th>Insulin</th>\n",
       "      <th>BMI</th>\n",
       "      <th>DiabetesPedigreeFunction</th>\n",
       "      <th>Age</th>\n",
       "      <th>Outcome</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>6</td>\n",
       "      <td>148</td>\n",
       "      <td>72</td>\n",
       "      <td>35</td>\n",
       "      <td>0</td>\n",
       "      <td>33.6</td>\n",
       "      <td>0.627</td>\n",
       "      <td>50</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1</td>\n",
       "      <td>85</td>\n",
       "      <td>66</td>\n",
       "      <td>29</td>\n",
       "      <td>0</td>\n",
       "      <td>26.6</td>\n",
       "      <td>0.351</td>\n",
       "      <td>31</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>8</td>\n",
       "      <td>183</td>\n",
       "      <td>64</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>23.3</td>\n",
       "      <td>0.672</td>\n",
       "      <td>32</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>1</td>\n",
       "      <td>89</td>\n",
       "      <td>66</td>\n",
       "      <td>23</td>\n",
       "      <td>94</td>\n",
       "      <td>28.1</td>\n",
       "      <td>0.167</td>\n",
       "      <td>21</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0</td>\n",
       "      <td>137</td>\n",
       "      <td>40</td>\n",
       "      <td>35</td>\n",
       "      <td>168</td>\n",
       "      <td>43.1</td>\n",
       "      <td>2.288</td>\n",
       "      <td>33</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   Pregnancies  Glucose  BloodPressure  SkinThickness  Insulin   BMI  \\\n",
       "0            6      148             72             35        0  33.6   \n",
       "1            1       85             66             29        0  26.6   \n",
       "2            8      183             64              0        0  23.3   \n",
       "3            1       89             66             23       94  28.1   \n",
       "4            0      137             40             35      168  43.1   \n",
       "\n",
       "   DiabetesPedigreeFunction  Age  Outcome  \n",
       "0                     0.627   50        1  \n",
       "1                     0.351   31        0  \n",
       "2                     0.672   32        1  \n",
       "3                     0.167   21        0  \n",
       "4                     2.288   33        1  "
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Reading the Blood Dataset\n",
    "diabetes = pd.read_csv(\"./../../../datasets/diabetes/diabetes.csv\")\n",
    "diabetes.head()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "317ecda9-87df-40b3-918d-19b7ccd05777",
   "metadata": {},
   "source": [
    "**Print Info and Missing Values**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "1b167864-ced8-46fd-89d8-74266115ab90",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "<class 'pandas.core.frame.DataFrame'>\n",
      "RangeIndex: 768 entries, 0 to 767\n",
      "Data columns (total 9 columns):\n",
      " #   Column                    Non-Null Count  Dtype  \n",
      "---  ------                    --------------  -----  \n",
      " 0   Pregnancies               768 non-null    int64  \n",
      " 1   Glucose                   768 non-null    int64  \n",
      " 2   BloodPressure             768 non-null    int64  \n",
      " 3   SkinThickness             768 non-null    int64  \n",
      " 4   Insulin                   768 non-null    int64  \n",
      " 5   BMI                       768 non-null    float64\n",
      " 6   DiabetesPedigreeFunction  768 non-null    float64\n",
      " 7   Age                       768 non-null    int64  \n",
      " 8   Outcome                   768 non-null    int64  \n",
      "dtypes: float64(2), int64(7)\n",
      "memory usage: 54.1 KB\n",
      "None\n",
      "\n",
      "\n",
      "\n",
      "Missing values:  False\n"
     ]
    }
   ],
   "source": [
    "print(diabetes.info())\n",
    "print(\"\\n\\n\")\n",
    "print(\"Missing values: \", diabetes.isnull().values.any())"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "d921143a-172f-4f29-80c6-5a877643d067",
   "metadata": {},
   "source": [
    "**Variance Check**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "948672e3-370b-466e-97ac-be927c47d05f",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Pregnancies                    11.354\n",
       "Glucose                      1022.248\n",
       "BloodPressure                 374.647\n",
       "SkinThickness                 254.473\n",
       "Insulin                     13281.180\n",
       "BMI                            62.160\n",
       "DiabetesPedigreeFunction        0.110\n",
       "Age                           138.303\n",
       "Outcome                         0.227\n",
       "dtype: float64"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "diabetes.var().round(3)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "039d6a5a-4cb2-43ea-b8c5-0c2488444861",
   "metadata": {},
   "source": [
    "Very different variance levels"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "0aac7df9-f6fe-43ef-96a9-b10fa43a1ebf",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Log Transformation of Monetary (c.c. blood) to reduce the variance and range\n",
    "# blood['Monetary (c.c. blood)'] = blood['Monetary (c.c. blood)'] / 100\n",
    "# blood.var().round(3)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "a9aaeed7-a7e6-4fac-83fb-213f6b0c3774",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>Pregnancies</th>\n",
       "      <th>Glucose</th>\n",
       "      <th>BloodPressure</th>\n",
       "      <th>SkinThickness</th>\n",
       "      <th>Insulin</th>\n",
       "      <th>BMI</th>\n",
       "      <th>DiabetesPedigreeFunction</th>\n",
       "      <th>Age</th>\n",
       "      <th>Outcome</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>6</td>\n",
       "      <td>148</td>\n",
       "      <td>72</td>\n",
       "      <td>35</td>\n",
       "      <td>0</td>\n",
       "      <td>33.6</td>\n",
       "      <td>0.627</td>\n",
       "      <td>50</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1</td>\n",
       "      <td>85</td>\n",
       "      <td>66</td>\n",
       "      <td>29</td>\n",
       "      <td>0</td>\n",
       "      <td>26.6</td>\n",
       "      <td>0.351</td>\n",
       "      <td>31</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>8</td>\n",
       "      <td>183</td>\n",
       "      <td>64</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>23.3</td>\n",
       "      <td>0.672</td>\n",
       "      <td>32</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>1</td>\n",
       "      <td>89</td>\n",
       "      <td>66</td>\n",
       "      <td>23</td>\n",
       "      <td>94</td>\n",
       "      <td>28.1</td>\n",
       "      <td>0.167</td>\n",
       "      <td>21</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0</td>\n",
       "      <td>137</td>\n",
       "      <td>40</td>\n",
       "      <td>35</td>\n",
       "      <td>168</td>\n",
       "      <td>43.1</td>\n",
       "      <td>2.288</td>\n",
       "      <td>33</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   Pregnancies  Glucose  BloodPressure  SkinThickness  Insulin   BMI  \\\n",
       "0            6      148             72             35        0  33.6   \n",
       "1            1       85             66             29        0  26.6   \n",
       "2            8      183             64              0        0  23.3   \n",
       "3            1       89             66             23       94  28.1   \n",
       "4            0      137             40             35      168  43.1   \n",
       "\n",
       "   DiabetesPedigreeFunction  Age  Outcome  \n",
       "0                     0.627   50        1  \n",
       "1                     0.351   31        0  \n",
       "2                     0.672   32        1  \n",
       "3                     0.167   21        0  \n",
       "4                     2.288   33        1  "
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "diabetes.head()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "06776d06-aac3-4cd8-b1e8-b8498381d713",
   "metadata": {},
   "source": [
    "**Checking the distribution of target values**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "339d9bbe-8754-4572-87e1-3365bed7af5e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Outcome\n",
       "0    0.651\n",
       "1    0.349\n",
       "Name: proportion, dtype: float64"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "diabetes[\"Outcome\"].value_counts(normalize=True).round(3)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "0ce86e3c-d237-459e-805b-83a02b971354",
   "metadata": {},
   "source": [
    "**Train-Test Split**"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "852899ac-5378-4914-a9e7-c206ded4d0de",
   "metadata": {},
   "source": [
    "Train - Test Split &nbsp;&nbsp;&nbsp;&nbsp; 60%-40%\n",
    "\n",
    "The Test-Set is Further split into Verb And Gen split\n",
    "\n",
    "Verb - Gen Split   &nbsp;&nbsp;&nbsp;&nbsp; 50%-50%"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "bf7ff54f-f3f4-40e6-8bc4-424d99ae8af8",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Train Test Split Stratified on Target Feature\n",
    "X_train, X_test, y_train, y_test = train_test_split(diabetes.drop(columns=\"Outcome\"), diabetes[\"Outcome\"], test_size=0.40, random_state=400, stratify=diabetes[\"Outcome\"])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "5cc4deea-e333-4ce0-890d-ad1078aac260",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Train Test Split on the Test set to get Verb and Gen Sets. Stratified on the Target Feature\n",
    "X_test_verb, X_test_gen, y_test_verb, y_test_gen = train_test_split(X_test, y_test, test_size=0.5, random_state=400, stratify=y_test)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "bda17883-3302-4fc9-8b3b-46c6c669a070",
   "metadata": {},
   "source": [
    "**Checking the distribution target values after the split**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "f79613d4",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Outcome\n",
      "0    0.65\n",
      "1    0.35\n",
      "Name: proportion, dtype: float64\n",
      "Outcome\n",
      "0    0.649\n",
      "1    0.351\n",
      "Name: proportion, dtype: float64\n",
      "Outcome\n",
      "0    0.656\n",
      "1    0.344\n",
      "Name: proportion, dtype: float64\n"
     ]
    }
   ],
   "source": [
    "print(y_train.value_counts(normalize=True).round(3))\n",
    "print(y_test_verb.value_counts(normalize=True).round(3))\n",
    "print(y_test_gen.value_counts(normalize=True).round(3))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ccf6c676-335d-4133-afa2-5161bd932f2a",
   "metadata": {},
   "source": [
    "**Variance Check**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "9bf865bb-067e-40f8-bfb8-03afba7c71a1",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Pregnancies                    10.487\n",
       "Glucose                      1113.213\n",
       "BloodPressure                 327.460\n",
       "SkinThickness                 261.244\n",
       "Insulin                     13817.680\n",
       "BMI                            65.503\n",
       "DiabetesPedigreeFunction        0.109\n",
       "Age                           131.501\n",
       "dtype: float64"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "X_train.var().round(3)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "0a7a2750-30fc-45f5-97d9-9bd0863cab60",
   "metadata": {},
   "source": [
    "**Standardization** - Skipping this because the resulting dataset has very high precision float values (that may not be good for the LLM)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "ebbccb2f-d31e-451c-83a4-ba3b35025796",
   "metadata": {},
   "outputs": [],
   "source": [
    "scaler = StandardScaler()\n",
    "X_train_scaled = scaler.fit_transform(X_train)\n",
    "X_test_gen_scaled = scaler.transform(X_test_gen)\n",
    "X_test_verb_scaled = scaler.transform(X_test_verb)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "99cb1c0e-8239-4489-a757-51307bfe7e8a",
   "metadata": {},
   "source": [
    "**Converting them back to dataframes** - No need for this now as there's no standardization"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "563a7aff-a958-42bf-a740-bfe04b397aee",
   "metadata": {},
   "outputs": [],
   "source": [
    "X_train_scaled_df = pd.DataFrame(X_train_scaled, columns=X_train.columns)\n",
    "X_test_gen_scaled_df = pd.DataFrame(X_test_gen_scaled, columns=X_test.columns)\n",
    "X_test_verb_scaled_df = pd.DataFrame(X_test_verb_scaled, columns=X_test.columns)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "d53928be",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Pregnancies                    10.487\n",
       "Glucose                      1113.213\n",
       "BloodPressure                 327.460\n",
       "SkinThickness                 261.244\n",
       "Insulin                     13817.680\n",
       "BMI                            65.503\n",
       "DiabetesPedigreeFunction        0.109\n",
       "Age                           131.501\n",
       "dtype: float64"
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "X_train.var().round(3)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "34fa98be-c686-4fcf-8a49-367a1ceb78c1",
   "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": "817ffe14-5450-433d-b7e0-43b2ff1892da",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Pregnancies                 10021.78649\n",
       "Glucose                     10021.78649\n",
       "BloodPressure               10021.78649\n",
       "SkinThickness               10021.78649\n",
       "Insulin                     10021.78649\n",
       "BMI                         10021.78649\n",
       "DiabetesPedigreeFunction    10021.78649\n",
       "Age                         10021.78649\n",
       "dtype: float64"
      ]
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "X_train_scaled_df.var().round(5)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "97fe3ae9-5bdc-488c-9339-af497d6999ee",
   "metadata": {},
   "source": [
    "From here Onwards `X_test_verb_scaled_df` is going to be `X_test_scaled_df`. `X_test_gen_scaled_df` is not going to be used at all in the code"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "61841898",
   "metadata": {},
   "outputs": [],
   "source": [
    "X_test_scaled_df = X_test_verb_scaled_df\n",
    "y_test = y_test_verb"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c89636ce-0600-405c-ad76-9f9edb475f76",
   "metadata": {},
   "source": [
    "#### Model Variations"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "98c6a1a3",
   "metadata": {},
   "source": [
    "**Base Model**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "d0698840-a387-47f3-8b76-37a875fdcbdc",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Best parameters found:  {'C': np.float64(0.026995939285135797), 'class_weight': 'balanced', 'l1_ratio': np.float64(0.17144366073468476), 'max_iter': 989, 'penalty': 'l2', 'solver': 'newton-cg', 'tol': np.float64(0.08029607484234605)}\n",
      "Best score:  0.7369565217391305\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/model_selection/_validation.py:540: FitFailedWarning: \n",
      "5 fits failed out of a total of 10.\n",
      "The score on these train-test partitions for these parameters will be set to nan.\n",
      "If these failures are not expected, you can try to debug them by setting error_score='raise'.\n",
      "\n",
      "Below are more details about the failures:\n",
      "--------------------------------------------------------------------------------\n",
      "5 fits failed with the following error:\n",
      "Traceback (most recent call last):\n",
      "  File \"/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/model_selection/_validation.py\", line 888, in _fit_and_score\n",
      "    estimator.fit(X_train, y_train, **fit_params)\n",
      "  File \"/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/base.py\", line 1473, in wrapper\n",
      "    return fit_method(estimator, *args, **kwargs)\n",
      "           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n",
      "  File \"/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py\", line 1194, in fit\n",
      "    solver = _check_solver(self.solver, self.penalty, self.dual)\n",
      "             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n",
      "  File \"/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py\", line 67, in _check_solver\n",
      "    raise ValueError(\n",
      "ValueError: Solver lbfgs supports only 'l2' or None penalties, got elasticnet penalty.\n",
      "\n",
      "  warnings.warn(some_fits_failed_message, FitFailedWarning)\n",
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/model_selection/_search.py:1102: UserWarning: One or more of the test scores are non-finite: [       nan 0.73695652]\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"
     ]
    }
   ],
   "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=2, cv=5, random_state=40)\n",
    "\n",
    "# Fit the model\n",
    "random_search.fit(X_train_scaled_df, y_train)\n",
    "\n",
    "# Print the best parameters and the best score\n",
    "print(\"Best parameters found: \", random_search.best_params_)\n",
    "print(\"Best score: \", random_search.best_score_)\n",
    "best_params = random_search.best_params_\n",
    "best_score = random_search.best_score_"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "9c1d7336",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/shravan/NLE/Explainable-AI/venv/lib/python3.12/site-packages/sklearn/linear_model/_logistic.py:1197: UserWarning: l1_ratio parameter is only used when penalty is 'elasticnet'. Got (penalty=l2)\n",
      "  warnings.warn(\n"
     ]
    }
   ],
   "source": [
    "# Train the base model\n",
    "def train_base_model(X_train, y_train):\n",
    "    # model = LogisticRegression(C=0.001, max_iter=1000, random_state=400)\n",
    "    model = LogisticRegression(**best_params)\n",
    "    model.fit(X_train, y_train)\n",
    "    return model\n",
    "\n",
    "base_model = train_base_model(X_train_scaled_df, y_train)\n",
    "base_pred = base_model.predict(X_test_scaled_df)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "1f78d8c6-c30d-4de5-9132-a264c4918529",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.7272727272727273\n"
     ]
    }
   ],
   "source": [
    "print(accuracy_score(y_test, base_pred))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "7d95c6fa-d11c-4c8f-8cd6-ada24341837b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'C': np.float64(0.026995939285135797),\n",
       " 'class_weight': 'balanced',\n",
       " 'l1_ratio': np.float64(0.17144366073468476),\n",
       " 'max_iter': 989,\n",
       " 'penalty': 'l2',\n",
       " 'solver': 'newton-cg',\n",
       " 'tol': np.float64(0.08029607484234605)}"
      ]
     },
     "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": 29,
   "id": "12b3bcfa-de89-4d7d-b9b7-900996ed35e2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Modification Factor: 0.1 Noise: [0.23120746 0.01367893 0.01681843 0.01877392 0.0708152  0.15730281\n",
      " 0.03120646 0.10725715]\n",
      "Modification Factor: 0.2 Noise: [-0.05023919  0.19405968 -0.48878962  0.1473495   0.07332387 -0.12741361\n",
      "  0.15991099  0.16700835]\n",
      "Modification Factor: 0.3 Noise: [-0.23781827  0.12460169 -0.24345228  0.04417464 -0.09401802  0.15723156\n",
      " -0.09482801 -0.0301062 ]\n",
      "Modification Factor: 0.4 Noise: [ 0.30315914  0.3337394   0.24968512  0.13531834 -0.58988168 -0.15858368\n",
      "  0.08537093  0.27880665]\n",
      "Modification Factor: 0.5 Noise: [ 0.44980713 -0.49272677 -0.07918427  0.87131681 -0.30552395 -0.20156211\n",
      "  0.09886243  0.10889031]\n",
      "Modification Factor: 0.6 Noise: [-0.52426178 -0.82065592 -0.59960313 -0.49499915 -0.47083419 -0.33920954\n",
      "  0.54114384 -0.32045717]\n",
      "Modification Factor: 0.7 Noise: [ 0.63235198 -0.81242595 -0.93520508  0.59975408  0.14773135  0.22445533\n",
      "  0.17917048  0.17317474]\n",
      "Modification Factor: 0.8 Noise: [ 0.49801403  0.03595181 -0.99319623 -0.34113495 -0.40668871 -0.27029886\n",
      " -0.95370724  0.04523634]\n",
      "Modification Factor: 0.9 Noise: [ 0.20130284 -1.80580379  1.21875762  0.04786792 -2.38120852  0.2630488\n",
      "  3.15355227  0.35148189]\n",
      "Modification Factor: 1.0 Noise: [-0.48808737 -0.49448579  0.90705094 -0.69022153  1.1518222  -0.1405199\n",
      " -1.53464209  0.3418852 ]\n",
      "Modification Factor: 1.1 Noise: [ 0.98784461  0.23689827  0.63185401 -0.21745278 -1.47169457 -0.45674233\n",
      "  2.42361525 -1.03099269]\n",
      "Modification Factor: 1.2 Noise: [ 1.29828193 -0.9939732  -0.16763681 -0.78777021  1.54792433  0.54149564\n",
      " -0.02110287 -2.03572735]\n",
      "Modification Factor: 1.3 Noise: [ 0.87023512 -1.69773289 -0.4535102   1.46315006 -0.98933797 -1.11845865\n",
      "  0.36381881  0.54440364]\n",
      "Modification Factor: 1.4 Noise: [ 1.646555    0.21203798  0.17628832 -1.51357874 -0.01446807 -3.09171449\n",
      "  0.76364219 -2.09945027]\n",
      "Modification Factor: 1.5 Noise: [ 2.57879313 -0.38065278 -1.44937933  1.48253788  0.4774083   3.40427555\n",
      "  0.7806548   0.24288713]\n",
      "Modification Factor: 1.6 Noise: [-0.66723537  0.95829295 -1.04173829  0.23002437 -0.61441944 -1.15301923\n",
      " -1.5943642   0.82013099]\n",
      "Modification Factor: 1.7 Noise: [ 1.47150467  1.92820018 -2.35522589  0.53255047  0.53705579  0.53602505\n",
      "  1.88146416 -3.11447078]\n"
     ]
    }
   ],
   "source": [
    "# np.random.seed(21)\n",
    "# np.random.seed(125)\n",
    "# np.random.seed(100)\n",
    "np.random.seed(154)\n",
    "# np.random.seed(40)\n",
    "\n",
    "# Create variations of the model\n",
    "variations = []\n",
    "# modification_factors = [0.1, 0.3, 0.5, 0.7, 0.9, 1.1, 1.3, 1.5]\n",
    "# modification_factors = [0.1, 4, 1.3, 1.2, 1.1, 1.0, 0.9, 0.8, 0.7, 0.6, 0.5, 0.4, 0.3, 0.2, 0.1]\n",
    "modification_factors = [0.1, 0.2, 0.3, 0.4, 0.5, 0.6, 0.7, 0.8, 0.9, 1.0, 1.1, 1.2, 1.3, 1.4, 1.5, 1.6, 1.7]\n",
    "\n",
    "for factor in modification_factors:\n",
    "    modified_model = modify_coefficients(base_model, factor)\n",
    "    variations.append((f\"Modified (factor={factor})\", modified_model))\n",
    "\n",
    "# Find the pair of models with the highest difference\n",
    "best_diff = 0\n",
    "best_pair = None"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "cdc0b596-9624-4775-a67d-e27d545d5187",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "With Model: Modified (factor=0.1), Diff: 0.006493506493506494\n",
      "With Model: Modified (factor=0.2), Diff: 0.045454545454545456\n",
      "With Model: Modified (factor=0.3), Diff: 0.045454545454545456\n",
      "With Model: Modified (factor=0.4), Diff: 0.07142857142857142\n",
      "With Model: Modified (factor=0.5), Diff: 0.07142857142857142\n",
      "With Model: Modified (factor=0.6), Diff: 0.13636363636363635\n",
      "With Model: Modified (factor=0.7), Diff: 0.14285714285714285\n",
      "With Model: Modified (factor=0.8), Diff: 0.09090909090909091\n",
      "With Model: Modified (factor=0.9), Diff: 0.37012987012987014\n",
      "With Model: Modified (factor=1.0), Diff: 0.13636363636363635\n",
      "With Model: Modified (factor=1.1), Diff: 0.14285714285714285\n",
      "With Model: Modified (factor=1.2), Diff: 0.2922077922077922\n",
      "Best Model till now is Modified (factor=1.2)\n",
      "With Model: Modified (factor=1.3), Diff: 0.44805194805194803\n",
      "With Model: Modified (factor=1.4), Diff: 0.4155844155844156\n",
      "With Model: Modified (factor=1.5), Diff: 0.14935064935064934\n",
      "With Model: Modified (factor=1.6), Diff: 0.18181818181818182\n",
      "With Model: Modified (factor=1.7), Diff: 0.12987012987012986\n"
     ]
    }
   ],
   "source": [
    "# Comparison with the base model\n",
    "for name, model in variations:\n",
    "    modified_pred = model.predict(X_test_scaled_df)\n",
    "    diff = compute_difference(base_pred, modified_pred)\n",
    "    print(f\"With Model: {name}, Diff: {diff}\") \n",
    "    if diff > best_diff and (diff >= 0.25 and diff <= 0.30):\n",
    "        print(\"Best Model till now is\", name)\n",
    "        best_diff = diff\n",
    "        best_pair = ((\"Base Model\", base_model), (name, model))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "1c0ac2be-b6b4-4eda-aeda-84c752debaae",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "With Models: Modified (factor=0.1) vs Modified (factor=0.2), Diff: 0.01948051948051948\n",
      "With Models: Modified (factor=0.1) vs Modified (factor=0.3), Diff: 0.05194805194805195\n",
      "With Models: Modified (factor=0.1) vs Modified (factor=0.4), Diff: 0.09090909090909091\n",
      "With Models: Modified (factor=0.1) vs Modified (factor=0.5), Diff: 0.14935064935064934\n",
      "With Models: Modified (factor=0.1) vs Modified (factor=0.6), Diff: 0.12987012987012986\n",
      "With Models: Modified (factor=0.1) vs Modified (factor=0.7), Diff: 0.11038961038961038\n",
      "With Models: Modified (factor=0.1) vs Modified (factor=0.8), Diff: 0.43506493506493504\n",
      "With Models: Modified (factor=0.1) vs Modified (factor=0.9), Diff: 0.3181818181818182\n",
      "With Models: Modified (factor=0.1) vs Modified (factor=1.0), Diff: 0.461038961038961\n",
      "With Models: Modified (factor=0.1) vs Modified (factor=1.1), Diff: 0.12987012987012986\n",
      "With Models: Modified (factor=0.1) vs Modified (factor=1.2), Diff: 0.6623376623376623\n",
      "With Models: Modified (factor=0.1) vs Modified (factor=1.3), Diff: 0.487012987012987\n",
      "With Models: Modified (factor=0.1) vs Modified (factor=1.4), Diff: 0.7337662337662337\n",
      "With Models: Modified (factor=0.1) vs Modified (factor=1.5), Diff: 0.2597402597402597\n",
      "Best Model Pair till now is Modified (factor=0.1) vs Modified (factor=1.5)\n",
      "With Models: Modified (factor=0.1) vs Modified (factor=1.6), Diff: 0.6883116883116883\n",
      "With Models: Modified (factor=0.1) vs Modified (factor=1.7), Diff: 0.22727272727272727\n",
      "With Models: Modified (factor=0.2) vs Modified (factor=0.3), Diff: 0.045454545454545456\n",
      "With Models: Modified (factor=0.2) vs Modified (factor=0.4), Diff: 0.08441558441558442\n",
      "With Models: Modified (factor=0.2) vs Modified (factor=0.5), Diff: 0.14285714285714285\n",
      "With Models: Modified (factor=0.2) vs Modified (factor=0.6), Diff: 0.13636363636363635\n",
      "With Models: Modified (factor=0.2) vs Modified (factor=0.7), Diff: 0.11688311688311688\n",
      "With Models: Modified (factor=0.2) vs Modified (factor=0.8), Diff: 0.42857142857142855\n",
      "With Models: Modified (factor=0.2) vs Modified (factor=0.9), Diff: 0.3246753246753247\n",
      "With Models: Modified (factor=0.2) vs Modified (factor=1.0), Diff: 0.44155844155844154\n",
      "With Models: Modified (factor=0.2) vs Modified (factor=1.1), Diff: 0.14935064935064934\n",
      "With Models: Modified (factor=0.2) vs Modified (factor=1.2), Diff: 0.6428571428571429\n",
      "With Models: Modified (factor=0.2) vs Modified (factor=1.3), Diff: 0.4805194805194805\n",
      "With Models: Modified (factor=0.2) vs Modified (factor=1.4), Diff: 0.7272727272727273\n",
      "With Models: Modified (factor=0.2) vs Modified (factor=1.5), Diff: 0.2532467532467532\n",
      "With Models: Modified (factor=0.2) vs Modified (factor=1.6), Diff: 0.6818181818181818\n",
      "With Models: Modified (factor=0.2) vs Modified (factor=1.7), Diff: 0.22077922077922077\n",
      "With Models: Modified (factor=0.3) vs Modified (factor=0.4), Diff: 0.05194805194805195\n",
      "With Models: Modified (factor=0.3) vs Modified (factor=0.5), Diff: 0.11038961038961038\n",
      "With Models: Modified (factor=0.3) vs Modified (factor=0.6), Diff: 0.12987012987012986\n",
      "With Models: Modified (factor=0.3) vs Modified (factor=0.7), Diff: 0.09740259740259741\n",
      "With Models: Modified (factor=0.3) vs Modified (factor=0.8), Diff: 0.474025974025974\n",
      "With Models: Modified (factor=0.3) vs Modified (factor=0.9), Diff: 0.2792207792207792\n",
      "Best Model Pair till now is Modified (factor=0.3) vs Modified (factor=0.9)\n",
      "With Models: Modified (factor=0.3) vs Modified (factor=1.0), Diff: 0.43506493506493504\n",
      "With Models: Modified (factor=0.3) vs Modified (factor=1.1), Diff: 0.16883116883116883\n",
      "With Models: Modified (factor=0.3) vs Modified (factor=1.2), Diff: 0.6753246753246753\n",
      "With Models: Modified (factor=0.3) vs Modified (factor=1.3), Diff: 0.44805194805194803\n",
      "With Models: Modified (factor=0.3) vs Modified (factor=1.4), Diff: 0.6948051948051948\n",
      "With Models: Modified (factor=0.3) vs Modified (factor=1.5), Diff: 0.2077922077922078\n",
      "With Models: Modified (factor=0.3) vs Modified (factor=1.6), Diff: 0.6493506493506493\n",
      "With Models: Modified (factor=0.3) vs Modified (factor=1.7), Diff: 0.18831168831168832\n",
      "With Models: Modified (factor=0.4) vs Modified (factor=0.5), Diff: 0.08441558441558442\n",
      "With Models: Modified (factor=0.4) vs Modified (factor=0.6), Diff: 0.18181818181818182\n",
      "With Models: Modified (factor=0.4) vs Modified (factor=0.7), Diff: 0.09740259740259741\n",
      "With Models: Modified (factor=0.4) vs Modified (factor=0.8), Diff: 0.5\n",
      "With Models: Modified (factor=0.4) vs Modified (factor=0.9), Diff: 0.2792207792207792\n",
      "With Models: Modified (factor=0.4) vs Modified (factor=1.0), Diff: 0.43506493506493504\n",
      "With Models: Modified (factor=0.4) vs Modified (factor=1.1), Diff: 0.2077922077922078\n",
      "With Models: Modified (factor=0.4) vs Modified (factor=1.2), Diff: 0.7012987012987013\n",
      "With Models: Modified (factor=0.4) vs Modified (factor=1.3), Diff: 0.3961038961038961\n",
      "With Models: Modified (factor=0.4) vs Modified (factor=1.4), Diff: 0.6688311688311688\n",
      "With Models: Modified (factor=0.4) vs Modified (factor=1.5), Diff: 0.16883116883116883\n",
      "With Models: Modified (factor=0.4) vs Modified (factor=1.6), Diff: 0.6233766233766234\n",
      "With Models: Modified (factor=0.4) vs Modified (factor=1.7), Diff: 0.14935064935064934\n",
      "With Models: Modified (factor=0.5) vs Modified (factor=0.6), Diff: 0.21428571428571427\n",
      "With Models: Modified (factor=0.5) vs Modified (factor=0.7), Diff: 0.18181818181818182\n",
      "With Models: Modified (factor=0.5) vs Modified (factor=0.8), Diff: 0.45454545454545453\n",
      "With Models: Modified (factor=0.5) vs Modified (factor=0.9), Diff: 0.24675324675324675\n",
      "With Models: Modified (factor=0.5) vs Modified (factor=1.0), Diff: 0.35064935064935066\n",
      "With Models: Modified (factor=0.5) vs Modified (factor=1.1), Diff: 0.2792207792207792\n",
      "With Models: Modified (factor=0.5) vs Modified (factor=1.2), Diff: 0.6558441558441559\n",
      "With Models: Modified (factor=0.5) vs Modified (factor=1.3), Diff: 0.33766233766233766\n",
      "With Models: Modified (factor=0.5) vs Modified (factor=1.4), Diff: 0.5844155844155844\n",
      "With Models: Modified (factor=0.5) vs Modified (factor=1.5), Diff: 0.18831168831168832\n",
      "With Models: Modified (factor=0.5) vs Modified (factor=1.6), Diff: 0.538961038961039\n",
      "With Models: Modified (factor=0.5) vs Modified (factor=1.7), Diff: 0.09090909090909091\n",
      "With Models: Modified (factor=0.6) vs Modified (factor=0.7), Diff: 0.17532467532467533\n",
      "With Models: Modified (factor=0.6) vs Modified (factor=0.8), Diff: 0.5\n",
      "With Models: Modified (factor=0.6) vs Modified (factor=0.9), Diff: 0.2532467532467532\n",
      "With Models: Modified (factor=0.6) vs Modified (factor=1.0), Diff: 0.461038961038961\n",
      "With Models: Modified (factor=0.6) vs Modified (factor=1.1), Diff: 0.12987012987012986\n",
      "With Models: Modified (factor=0.6) vs Modified (factor=1.2), Diff: 0.6103896103896104\n",
      "With Models: Modified (factor=0.6) vs Modified (factor=1.3), Diff: 0.474025974025974\n",
      "With Models: Modified (factor=0.6) vs Modified (factor=1.4), Diff: 0.7207792207792207\n",
      "With Models: Modified (factor=0.6) vs Modified (factor=1.5), Diff: 0.2727272727272727\n",
      "With Models: Modified (factor=0.6) vs Modified (factor=1.6), Diff: 0.6753246753246753\n",
      "With Models: Modified (factor=0.6) vs Modified (factor=1.7), Diff: 0.2792207792207792\n",
      "With Models: Modified (factor=0.7) vs Modified (factor=0.8), Diff: 0.5194805194805194\n",
      "With Models: Modified (factor=0.7) vs Modified (factor=0.9), Diff: 0.3116883116883117\n",
      "With Models: Modified (factor=0.7) vs Modified (factor=1.0), Diff: 0.5194805194805194\n",
      "With Models: Modified (factor=0.7) vs Modified (factor=1.1), Diff: 0.14935064935064934\n",
      "With Models: Modified (factor=0.7) vs Modified (factor=1.2), Diff: 0.7467532467532467\n",
      "With Models: Modified (factor=0.7) vs Modified (factor=1.3), Diff: 0.44155844155844154\n",
      "With Models: Modified (factor=0.7) vs Modified (factor=1.4), Diff: 0.7402597402597403\n",
      "With Models: Modified (factor=0.7) vs Modified (factor=1.5), Diff: 0.21428571428571427\n",
      "With Models: Modified (factor=0.7) vs Modified (factor=1.6), Diff: 0.6948051948051948\n",
      "With Models: Modified (factor=0.7) vs Modified (factor=1.7), Diff: 0.22077922077922077\n",
      "With Models: Modified (factor=0.8) vs Modified (factor=0.9), Diff: 0.5974025974025974\n",
      "With Models: Modified (factor=0.8) vs Modified (factor=1.0), Diff: 0.2857142857142857\n",
      "Best Model Pair till now is Modified (factor=0.8) vs Modified (factor=1.0)\n",
      "With Models: Modified (factor=0.8) vs Modified (factor=1.1), Diff: 0.44805194805194803\n",
      "With Models: Modified (factor=0.8) vs Modified (factor=1.2), Diff: 0.33116883116883117\n",
      "With Models: Modified (factor=0.8) vs Modified (factor=1.3), Diff: 0.6753246753246753\n",
      "With Models: Modified (factor=0.8) vs Modified (factor=1.4), Diff: 0.5454545454545454\n",
      "With Models: Modified (factor=0.8) vs Modified (factor=1.5), Diff: 0.6428571428571429\n",
      "With Models: Modified (factor=0.8) vs Modified (factor=1.6), Diff: 0.5909090909090909\n",
      "With Models: Modified (factor=0.8) vs Modified (factor=1.7), Diff: 0.5194805194805194\n",
      "With Models: Modified (factor=0.9) vs Modified (factor=1.0), Diff: 0.38961038961038963\n",
      "With Models: Modified (factor=0.9) vs Modified (factor=1.1), Diff: 0.35714285714285715\n",
      "With Models: Modified (factor=0.9) vs Modified (factor=1.2), Diff: 0.7337662337662337\n",
      "With Models: Modified (factor=0.9) vs Modified (factor=1.3), Diff: 0.2727272727272727\n",
      "With Models: Modified (factor=0.9) vs Modified (factor=1.4), Diff: 0.5324675324675324\n",
      "With Models: Modified (factor=0.9) vs Modified (factor=1.5), Diff: 0.14935064935064934\n",
      "With Models: Modified (factor=0.9) vs Modified (factor=1.6), Diff: 0.525974025974026\n",
      "With Models: Modified (factor=0.9) vs Modified (factor=1.7), Diff: 0.2077922077922078\n",
      "With Models: Modified (factor=1.0) vs Modified (factor=1.1), Diff: 0.577922077922078\n",
      "With Models: Modified (factor=1.0) vs Modified (factor=1.2), Diff: 0.38311688311688313\n",
      "With Models: Modified (factor=1.0) vs Modified (factor=1.3), Diff: 0.44155844155844154\n",
      "With Models: Modified (factor=1.0) vs Modified (factor=1.4), Diff: 0.36363636363636365\n",
      "With Models: Modified (factor=1.0) vs Modified (factor=1.5), Diff: 0.474025974025974\n",
      "With Models: Modified (factor=1.0) vs Modified (factor=1.6), Diff: 0.35714285714285715\n",
      "With Models: Modified (factor=1.0) vs Modified (factor=1.7), Diff: 0.33766233766233766\n",
      "With Models: Modified (factor=1.1) vs Modified (factor=1.2), Diff: 0.6623376623376623\n",
      "With Models: Modified (factor=1.1) vs Modified (factor=1.3), Diff: 0.564935064935065\n",
      "With Models: Modified (factor=1.1) vs Modified (factor=1.4), Diff: 0.8506493506493507\n",
      "With Models: Modified (factor=1.1) vs Modified (factor=1.5), Diff: 0.3246753246753247\n",
      "With Models: Modified (factor=1.1) vs Modified (factor=1.6), Diff: 0.8051948051948052\n",
      "With Models: Modified (factor=1.1) vs Modified (factor=1.7), Diff: 0.35714285714285715\n",
      "With Models: Modified (factor=1.2) vs Modified (factor=1.3), Diff: 0.6818181818181818\n",
      "With Models: Modified (factor=1.2) vs Modified (factor=1.4), Diff: 0.38311688311688313\n",
      "With Models: Modified (factor=1.2) vs Modified (factor=1.5), Diff: 0.7922077922077922\n",
      "With Models: Modified (factor=1.2) vs Modified (factor=1.6), Diff: 0.36363636363636365\n",
      "With Models: Modified (factor=1.2) vs Modified (factor=1.7), Diff: 0.6818181818181818\n",
      "With Models: Modified (factor=1.3) vs Modified (factor=1.4), Diff: 0.36363636363636365\n",
      "With Models: Modified (factor=1.3) vs Modified (factor=1.5), Diff: 0.2662337662337662\n",
      "With Models: Modified (factor=1.3) vs Modified (factor=1.6), Diff: 0.37012987012987014\n",
      "With Models: Modified (factor=1.3) vs Modified (factor=1.7), Diff: 0.2727272727272727\n",
      "With Models: Modified (factor=1.4) vs Modified (factor=1.5), Diff: 0.577922077922078\n",
      "With Models: Modified (factor=1.4) vs Modified (factor=1.6), Diff: 0.08441558441558442\n",
      "With Models: Modified (factor=1.4) vs Modified (factor=1.7), Diff: 0.5324675324675324\n",
      "With Models: Modified (factor=1.5) vs Modified (factor=1.6), Diff: 0.5454545454545454\n",
      "With Models: Modified (factor=1.5) vs Modified (factor=1.7), Diff: 0.16233766233766234\n",
      "With Models: Modified (factor=1.6) vs Modified (factor=1.7), Diff: 0.5\n"
     ]
    }
   ],
   "source": [
    "# Comparing variations with each other\n",
    "for i in range(len(variations)):\n",
    "    for j in range(i + 1, len(variations)):\n",
    "        name1, model1 = variations[i]\n",
    "        name2, model2 = variations[j]\n",
    "        pred1 = model1.predict(X_test_scaled_df)\n",
    "        pred2 = model2.predict(X_test_scaled_df)\n",
    "        diff = compute_difference(pred1, pred2)\n",
    "        print(f\"With Models: {name1} vs {name2}, Diff: {diff}\")\n",
    "        if diff > best_diff and (diff >= 0.25 and diff <= 0.30):\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": 31,
   "id": "666bc111-27bc-42a4-a4de-ee2504fb8e4e",
   "metadata": {},
   "outputs": [],
   "source": [
    "(model1_name, model1), (model2_name, model2) = best_pair"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "378e0cc3-ddf1-477a-8854-3239c10f51a8",
   "metadata": {},
   "outputs": [],
   "source": [
    "(model2_name, model2), (model1_name, model1) = best_pair"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "id": "36a64e0c-4794-4fcf-8fae-ac3637815aae",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "np.float64(0.3116883116883117)"
      ]
     },
     "execution_count": 32,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "def compare_models(model1, model2, X):\n",
    "    pred1 = model1.predict(X)\n",
    "    pred2 = model2.predict(X)\n",
    "    diff_percentage = np.mean(pred1 != pred2)\n",
    "    return diff_percentage\n",
    "# let's check the difference on the generation data as well\n",
    "compare_models(model1, model2, X_test_gen_scaled_df)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "edf89eda-b43a-4b78-9512-024bf9631d3b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "beea7442-3c60-49c1-a0a5-916121125835",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "id": "9ea03138-8060-44ec-80ba-72d49272ec80",
   "metadata": {},
   "source": [
    "**Evaluate Both Models**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "id": "6e595955-68c6-41b3-8b0e-051de7cf86ba",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model 1: Base Model\n",
      "Model 1 accuracy: 0.7272727272727273\n",
      "\n",
      "Model 2: Modified (factor=1.2)\n",
      "Model 2 accuracy: 0.6168831168831169\n",
      "\n",
      "Accuracy difference: 0.11038961038961037\n",
      "\n",
      "Percentage of different outputs: 29.22%\n",
      "\n",
      "\n",
      "\n",
      "[[ 0.00308535  0.01105438 -0.00196662  0.00043325 -0.00104711  0.0073767\n",
      "   0.00236713  0.00258348]]\n",
      "[[ 7.09101298e-03  6.66226016e-05 -1.63693929e-03  9.19481157e-05\n",
      "  -2.66795427e-03  1.13711492e-02  2.31717442e-03 -2.67578424e-03]]\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": 35,
   "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": 36,
   "id": "de4db779-ea88-4543-944d-46c15b3e31de",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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sHLlSnr37k2lSpXInj07b731ln26JIDq1avz9ddf88Ybb/Daa6/xyCOPsHDhQsqUKePW8xERERFJb0zGjaxN7kl8fDwhISHExcURHBzs6XBERETkHnjy7/eNz86y+gCmjJmc2rdx5RIX6hb3irzEK26vi4iIiIh384rb6yIiIiLezmYDkwYSiYiIiIi4jiqdIiIiIm5g2Ezg5MncDS+aHF6VThERERFxOVU6RURERNzAZjNhSseVTiWdIiIiIm5g1UAiERERERHXUqVTRERExA3S++11VTpFRERExOVU6RQRERFxA8NqAquTK51O7s+VVOkUEREREZdTpVNERETEDTR6XURERETExVTplIeK1WplzZo1HD16lJIlS/L4449jMnnP8yoiIiK3k95HryvplIfGkSNHaNSwCQcP77e3PfZoFRYvXUTOnDk9GJmIiMiDMwwX3A43nNyfC+n2ujwUDMOg2TPPcf6olS5E8RZW2rOSgztO0KF9J0+HJyIiIg9ISac8FKKioti9dyeNrf8jH9UwY6YI9alrHcPKyOUcPXrU0yGKiIg8mL9vrztzw4turyvplIdCTEwMAGFUdGjPxaMAnDx50u0xiYiIiPMo6ZSHQrly5QA4yGKH9oMsxtfHl+LFi3siLBEREaexWMFiNTl58/RZ3TsNJJKHQsmSJXmmSVOWLevFFetZ8lKN31nFz+aRdO3aldDQUE+HKCIiIg9ASac8NL76Zja9e/fhm6+HkJySTIB/Bnq91JOxY8d4OjQREZEHZnbR5PDeUuxU0ikPjaCgIGbNmsm4cR9x8uRJChQoQHBwsKfDEhERESdQ0ikPnaxZs5I1a1ZPhyEiIuJUZk0OLyIiIiKuZrJe35zKW+6to9HrIiIiIuIGqnSKiIiIuIElnd9eV6VTRERERFxOlU4RERERN3DVlEneQpVOEREREXE5VTpFRERE3MBsM2Gy6plOERERERGXUaVTRERExA1MLhi9jhdVOpV0ioiIiLiB2Xp9cyabJocXEREREfmHKp0iIiIibmC2mTCn49vrqnSKiIiIiMup0ikiIiLiBq54phM90ykiIiIi8g9VOkVERETcwBVTJjl9CiYXUqVTRERERFxOlU4RERERN7C44JlOkxc906mkU0RERMQNzAaYbU7u1HByfy6k2+siIiIi4nKqdIqIiIi4gdlqwmx18sAf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rHPnzkaBAgUMPz8/IzQ01Khbt6494TQMXXu5PZNhGIbby6siIiIikq7omU4RERERcTklnSIiIiLicko6RURERMTllHSKiIiIiMsp6RQRERERl1PSKSIiIiIup6RTRERERFxOSaeIiIiIuJySThERERFxOSWdIpLmderUCZPJZN+yZctGw4YN2blzp32fG+/98ssvDscmJiaSLVs2TCYT69atc9h/4cKFbjoDERHvp6RTRNKFhg0bcvr0aU6fPs3q1avx8fGhSZMmDvvky5ePGTNmOLQtWLCAoKAgd4YqIpImKekUkXTB39+fsLAwwsLCqFChAkOGDCEmJoZz587Z9+nYsSNz5swhISHB3jZ9+nQ6duzoiZBFRNIUJZ0iku5cvnyZ2bNnU7RoUbJly2Zvr1SpEgULFmT+/PkAnDhxgg0bNtC+fXtPhSoikmYo6RSRdGHx4sUEBQURFBREpkyZWLRoEXPnzsVsdvwa7Ny5M9OnTwdg5syZNGrUiNDQUE+ELCKSpijpFJF0oXbt2mzfvp3t27fz66+/EhERwVNPPcXx48cd9mvXrh1RUVH8/vvvzJw5k86dO3soYhGRtEVJp4ikCxkzZqRo0aIULVqUypUr8/nnn3PlyhU+++wzh/2yZctGkyZN6NKlC9euXeOpp57yUMQiImmLkk4RSZdMJhNms9lh0NANnTt3Zt26dXTo0AGLxeKB6ERE0h4fTwcgIuIOiYmJxMbGAnDhwgUmTpzI5cuXefrpp2/at2HDhpw7d47g4GB3hykikmYp6RSRdGH58uXkypULgEyZMlGiRAnmzZtHrVq1btrXZDKRPXt2N0coIpK2mQzDMDwdhIiIiIikbXqmU0RERERcTkmniIiIiLickk4RERERcTklnSIiIiLicko6RURERMTllHSKiIiIiMsp6RQRERERl1PSKSIiIiIup6RTRERERFxOSaeIiIiIuJySThERERFxuf8H9gGgrRpM64wAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 800x600 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_decision_boundary(X_test_scaled_df, y_pred_1, \"BMI\", \"Glucose\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "599fcca1-20b3-4b16-89c4-4fba23c314ce",
   "metadata": {},
   "source": [
    "**Model 2 Decision Boundary**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "id": "bff87fe6-d656-416c-88a7-47fd6d503a63",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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X7/efus7KCiIlStXcuTIESpVqsSAAQN4++236dGjh72d6tWr8+233/Lll19SoUIFvv/+exYuXEjZsmXddWoiIiKSQZhszlk8hceO0+kuGqdTRETE8zwM43RW7n4WLx/HHjv5WjybJwd7RF7i1mc6RURERDIKZ4yraaj3uoiIiIjcyGx1fEciR7fnTB7xTKeIiIiIeDZVOkVERERcwBmDuXvS4PCqdIqIiIiI06nSKSIiIuICqnSKiIiIiDiZKp0iIiIiLqDe6yIiIiIiTqZKp4iIiIgLmG1OeKbTg6bBVNIpIiIi4gJmK5gdfI9ZHYlERERERG6gSqeIiIiIC5icUOk0qdIpIiIiIvIvVTpFREREXMBsNWE2a8gkERERERGnUaVTRERExAXUe11ERERExMlU6RQRERFxgYxe6VTSKSIiIuICGX1GIt1eFxERERGnU6VTRERExAXMVhNmk4ZMEhERERFxGlU6RURERFzAbAUHjw3vUR2JVOkUEREREadTpVNERETEBVTpFBERERFxMlU6RURERFwgo1c6lXSKiIiIuIDJCUmnyYOSTt1eFxERERGnU6VTRERExAXMNpPDB3M32zQ4vIiIiIiInSqdIiIiIi5gtjq+2udJHYlU6RQRERERp1OlU0RERMQFVOkUEREREXEyVTpFREREXCCjVzqVdIrcxGazERcXR5YsWfDy0j8RERFxjIyedOr2usg/DMNg7Nix5M9bkOzZs5MzRy5ef/11rl275u7QREREPJ7KOCL/eOeddxg6dCiP0oUahHMyfjNjPviImON/MnPW1+4OT0REPJwqnSLCxYsXGT1qDNV5lSZMoSytqM8YGtg+ZdY3Mzl48KC7QxQREfFoSjpFgD179nA54RJlaZtqfcrrqKgod4QlIiLpiNkK5mQHL6p0iniWHDlyAHCO1BXN8xwCIDg42OUxiYiIpCd6plMEKFq0KDWq12Rt1BCCraXJTVkucJyl5t7ky12A2rVruztEERHxcGarCbNhcmybNse250xKOkX+MXPWDOrUqsfEY+XI6p2P+ORTZA3MxrKFSzV0koiIyAPSb1KRfxQuXJg9+3axYMECdu/eTWhoKK1atSJLlizuDk1ERNIBkxXMhoPbtDm2PWdS0ilyA19fX9q0aePuMEREJB0yOyHpNHtQ0qmORCIiIiLidKp0ioiIiLiAKp0iIiIiIk6mSqeIiIiIC6jSKSIiIiLiZKp0ioiIiLiA2eaESqeD23MmVTpFRERExOlU6RQRERFxAbMVzA6etVKVThERERGRG6jSKSIiIuIC5uSMXelU0ikiIiLiArq9LiIiIiLiZEo6RURERFzAbHXOcj86d+6MyWRi1KhRqdYvXLgQk8nBZdibKOkUERERyUD8/Pz44IMPOH/+vEuPq6RTRERExAVMNsdXOU1pmAazbt26hISEMHLkyDtuM3/+fMqUKYOvry+FChXio48+eoAzv04die6TYVx/Yjc+Pt7NkYiIiMi9Svm9nfJ73B0ScXzukNLmzXmJr68vvr6+t93HYrHw/vvv065dO/7v//6P/Pnzp3o/OjqaVq1aMWzYMFq3bs2mTZvo3bs3OXLkoHPnzmkP1pD7EhMTYwBatGjRokWLFg9cYmJiXJ47JCQkGCEhIU47p4CAgFvWDR069LaxdOrUyWjSpIlhGIZRrVo1o0uXLoZhGMaCBQsMuJ4WtmvXzqhXr16q/QYOHGiULl36ga6DKp33KW/evMTExJAlSxanP3CbHsTHx1OgQAFiYmIIDAx0dzgZkj4D99L1dy9df/d6mK6/YRhcvHiRvHnzuvzYfn5+HDlyhGvXrjmlfcMwbslJ7lTlvNEHH3xA7dq1efXVV1Ot37NnD02aNEm1rkaNGnzyySdYrVYsFkua4lTSeZ/MZvMtZWj5b4GBgW7/wsno9Bm4l66/e+n6u9fDcv2DgoLcdmw/Pz/8/PzcdvzbefLJJwkPD2fIkCEPdtv8HinpFBEREcmgRo0aRcWKFSlRooR9XalSpdi4cWOq7TZu3Ejx4sXTXOUEJZ0iIiIiGVa5cuV4/vnn+fTTT+3rBgwYQOXKlXnnnXdo3bo1kZGRTJgwgc8///yBjqUhk8SpfH19GTp06D09WyLOoc/AvXT93UvX3710/T3DiBEjsNn+HXvpscceY+7cucyePZuyZcvy9ttvM2LEiAe+BW8yDDeOHSAiIiIiGYIqnSIiIiLidEo6RURERMTplHSKiIiIiNMp6RQRERERp1PSKQ7z3nvvUb16dfz9/cmaNetttzl+/DiNGjXC39+fXLlyMXDgQJKTk1Nts27dOh577DF8fX0pVqwY06dPd37w6dRnn31GoUKF8PPzo2rVqvz222/uDild2LBhA//73//ImzcvJpOJhQsXpnrfMAzefvtt8uTJQ6ZMmahbty4HDhxItc25c+d4/vnnCQwMJGvWrHTt2pVLly658Cw818iRI6lcuTJZsmQhV65cNG3alH379qXa5urVq/Tp04ccOXIQEBBA8+bNOX36dKpt7uX7SG41ceJEypcvbx/wPSwsjGXLltnf17WXO1HSKQ5z7do1WrZsSa9evW77vtVqpVGjRly7do1NmzYxY8YMpk+fzttvv23f5siRIzRq1IhatWqxbds2+vfvT7du3VixYoWrTiPdmDNnDq+88gpDhw7l999/p0KFCoSHh3PmzBl3h+bxLl++TIUKFfjss89u+/7o0aP59NNPmTRpElFRUWTOnJnw8HCuXr1q3+b5559n165dREREsHjxYjZs2ECPHj1cdQoebf369fTp04dff/2ViIgIkpKSqF+/PpcvX7Zv8/LLL/PTTz8xb9481q9fz8mTJ2nWrJn9/Xv5PpLby58/P6NGjSI6OpotW7ZQu3ZtmjRpwq5duwBde7mLB5q5XeQ2pk2bZgQFBd2yfunSpYbZbDZiY2Pt6yZOnGgEBgYaiYmJhmEYxmuvvWaUKVMm1X6tW7c2wsPDnRpzelSlShWjT58+9tdWq9XImzevMXLkSDdGlf4AxoIFC+yvbTabERISYowZM8a+7sKFC4avr6/x3XffGYZhGLt37zYAY/PmzfZtli1bZphMJuPEiRMuiz29OHPmjAEY69evNwzj+vX29vY25s2bZ99mz549BmBERkYahnFv30dy77Jly2Z89dVXuvZyV6p0istERkZSrlw5cufObV8XHh5OfHy8/S/kyMhI6tatm2q/8PBwIiMjXRqrp7t27RrR0dGprqXZbKZu3bq6lk525MgRYmNjU137oKAgqlatar/2kZGRZM2alccff9y+Td26dTGbzURFRbk8Zk8XFxcHQPbs2QGIjo4mKSkp1WdQsmRJChYsmOoz+K/vI/lvVquV2bNnc/nyZcLCwnTt5a6UdIrLxMbGpvqSAeyvY2Nj77pNfHw8CQkJrgk0Hfjrr7+wWq23vZYp11qcI+X63u3ax8bGkitXrlTve3l5kT17dn0+98lms9G/f39q1KhB2bJlgevX18fH55Zny2/+DP7r+0ju7I8//iAgIABfX1969uzJggULKF26tK693JWSTrmrwYMHYzKZ7rrs3bvX3WGKSAbVp08fdu7cyezZs90dSoZSokQJtm3bRlRUFL169aJTp07s3r3b3WHJQ87L3QHIw23AgAH/OddqkSJF7qmtkJCQW3pPp/RoDAkJsf/35l6Op0+fJjAwkEyZMt1j1JIzZ04sFsttr2XKtRbnSLm+p0+fJk+ePPb1p0+fpmLFivZtbu7QlZyczLlz5/T53Ie+ffvaO2Hlz5/fvj4kJIRr165x4cKFVBW3G3/+7+X7SO7Mx8eHYsWKAVCpUiU2b97MuHHjaN26ta693JEqnXJXwcHBlCxZ8q6Lj4/PPbUVFhbGH3/8keqXbUREBIGBgZQuXdq+zerVq1PtFxERQVhYmONOKgPw8fGhUqVKqa6lzWZj9erVupZOVrhwYUJCQlJd+/j4eKKiouzXPiwsjAsXLhAdHW3fZs2aNdhsNqpWrerymD2NYRj07duXBQsWsGbNGgoXLpzq/UqVKuHt7Z3qM9i3bx/Hjx9P9Rn81/eR3DubzUZiYqKuvdydu3sySfpx7NgxY+vWrcbw4cONgIAAY+vWrcbWrVuNixcvGoZhGMnJyUbZsmWN+vXrG9u2bTOWL19uBAcHG0OGDLG3cfjwYcPf398YOHCgsWfPHuOzzz4zLBaLsXz5cnedlseaPXu24evra0yfPt3YvXu30aNHDyNr1qypeoxK2ly8eNH+8w0YH3/8sbF161bj2LFjhmEYxqhRo4ysWbMaP/74o7Fjxw6jSZMmRuHChY2EhAR7Gw0aNDAeffRRIyoqyvjll1+MRx55xGjbtq27Tsmj9OrVywgKCjLWrVtnnDp1yr5cuXLFvk3Pnj2NggULGmvWrDG2bNlihIWFGWFhYfb37+X7SG5v8ODBxvr1640jR44YO3bsMAYPHmyYTCZj5cqVhmHo2sudKekUh+nUqZMB3LKsXbvWvs3Ro0eNZ555xsiUKZORM2dOY8CAAUZSUlKqdtauXWtUrFjR8PHxMYoUKWJMmzbNtSeSjowfP94oWLCg4ePjY1SpUsX49ddf3R1SurB27drb/qx36tTJMIzrwya99dZbRu7cuQ1fX1+jTp06xr59+1K18ffffxtt27Y1AgICjMDAQOOFF16w/4Emd3e7aw+k+q5ISEgwevfubWTLls3w9/c3nnvuOePUqVOp2rmX7yO5VZcuXYzQ0FDDx8fHCA4ONurUqWNPOA1D117uzGQYhuHy8qqIiIiIZCh6plNEREREnE5Jp4iIiIg4nZJOEREREXE6JZ0iIiIi4nRKOkVERETE6ZR0ioiIiIjTKekUEREREadT0ikiIiIiTqekU0REREScTkmniKR7nTt3xmQy2ZccOXLQoEEDduzYYd8m5b1ff/011b6JiYnkyJEDk8nEunXrUm2/cOFCF52BiIjnU9IpIhlCgwYNOHXqFKdOnWL16tV4eXnRuHHjVNsUKFCAadOmpVq3YMECAgICXBmqiEi6pKRTRDIEX19fQkJCCAkJoWLFigwePJiYmBjOnj1r36ZTp07Mnj2bhIQE+7qpU6fSqVMnd4QsIpKuKOkUkQzn0qVLzJo1i2LFipEjRw77+kqVKlGoUCHmz58PwPHjx9mwYQMdOnRwV6giIumGkk4RyRAWL15MQEAAAQEBZMmShUWLFjFnzhzM5tRfg126dGHq1KkATJ8+nYYNGxIcHOyOkEVE0hUlnSKSIdSqVYtt27axbds2fvvtN8LDw3nmmWc4duxYqu3at29PZGQkhw8fZvr06XTp0sVNEYuIpC9KOkUkQ8icOTPFihWjWLFiVK5cma+++orLly8zefLkVNvlyJGDxo0b07VrV65evcozzzzjpohFRNIXJZ0ikiGZTCbMZnOqTkMpunTpwrp16+jYsSMWi8UN0YmIpD9e7g5ARMQVEhMTiY2NBeD8+fNMmDCBS5cu8b///e+WbRs0aMDZs2cJDAx0dZgiIumWkk4RyRCWL19Onjx5AMiSJQslS5Zk3rx5PP3007dsazKZyJkzp4sjFBFJ30yGYRjuDkJERERE0jc90ykiIiIiTqekU0REREScTkmniIiIiDidkk4RERERcTolnSIiIiLidEo6RURERMTplHSKiIiIiNMp6RQRERERp1PSKSIiIiJOp6RTRERERJxOSaeIiIiION3/AzMf/KhQg6F5AAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 800x600 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_decision_boundary(X_test_scaled_df, y_pred_2, \"BMI\", \"Glucose\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "id": "fe0e45a8-4007-4158-bb18-d85481ccdaf2",
   "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": "1e288b7d-4d22-4e5d-bff1-8216f4151845",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "646b1a97-0946-4c43-bb35-a9d8af1bf40f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e7c3b385-b836-4a47-b65c-6c9340d8ee9a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9eae56be-c4b1-40fc-b2bc-334670d6b69c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c3249b8a-a969-4b3c-a2a4-77e0e6f99f42",
   "metadata": {},
   "outputs": [],
   "source": [
    "    "
   ]
  },
  {
   "cell_type": "markdown",
   "id": "43a1d4fa-fb39-46e7-8c14-645e213aa7f3",
   "metadata": {},
   "source": [
    "#### Sample Data Creation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "id": "a4c67e91-d622-4a73-bedd-f3535c46c5a1",
   "metadata": {},
   "outputs": [],
   "source": [
    "def write_data(data, file_name, varname):\n",
    "    datastr = f\"\\n{varname} = {data}\"\n",
    "    \n",
    "    # Write this string to the file\n",
    "    with open(file_name, 'a') as file:\n",
    "        file.write(datastr)\n",
    "\n",
    "# This stays constant for this iPython file\n",
    "FILE_NAME = \"./../samples/diabetes/level_1.py\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "id": "166d67f7-55ae-4e56-8ee5-a45649a95bf0",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Number of mismatched samples: 45\n"
     ]
    }
   ],
   "source": [
    "print(f\"Number of mismatched samples: {np.sum(y_pred_1 != y_pred_2)}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "id": "d2ba908c-9ccc-43ed-aebc-34c5e3eeac92",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Number of samples in verb_data: 154\n"
     ]
    }
   ],
   "source": [
    "verb_data = []\n",
    "for idx in range(len(X_test_scaled_df)):\n",
    "    data_point = {\n",
    "        \"input\": round_values(X_test_scaled_df.iloc[idx].to_list()),\n",
    "        \"output\": {\n",
    "            \"model1\": int(y_pred_1[idx]),\n",
    "            \"model2\": int(y_pred_2[idx])\n",
    "        }\n",
    "    }\n",
    "    verb_data.append(data_point)\n",
    "\n",
    "print(f\"Number of samples in verb_data: {len(verb_data)}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "91fdcfc7-e87f-4bbd-8da2-80ee816a0380",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "97da7c78-ebf8-4ce7-913f-88dc065fcf6e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "id": "8b0374cf-250d-4b9c-ad17-b30db0b6d8bf",
   "metadata": {},
   "outputs": [],
   "source": [
    "varname = \"verb_data\"\n",
    "data = verb_data\n",
    "write_data(data, FILE_NAME, varname)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "53874348-fd8d-402c-86a5-8c1372bc8706",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d415f065-bda1-47a2-963a-d610530a5332",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f094023f-354c-465c-af91-64085494585d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "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": 44,
   "id": "5b11b0a3-deea-4f17-99f7-c992d2b470df",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Number of samples in gen_data: 154\n"
     ]
    }
   ],
   "source": [
    "gen_data = []\n",
    "for idx in range(len(X_test_gen_scaled_df)):\n",
    "    data_point = {\n",
    "        \"input\": round_values(X_test_gen_scaled_df.iloc[idx].to_list()),\n",
    "        \"output\": {\n",
    "            \"model1\": int(y_gen_pred_1[idx]),\n",
    "            \"model2\": int(y_gen_pred_2[idx])\n",
    "        }\n",
    "    }\n",
    "    gen_data.append(data_point)\n",
    "\n",
    "print(f\"Number of samples in gen_data: {len(gen_data)}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "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": 46,
   "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": 47,
   "id": "ca15745c-cc52-4855-a227-06aef729d537",
   "metadata": {},
   "outputs": [],
   "source": [
    "varname = \"gen_data_pruned\"\n",
    "data = prune_data(gen_data)\n",
    "write_data(data, FILE_NAME, varname)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "39486abe-a340-480f-a7e4-8449c05d372d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0acfe6a3-a651-4bcf-91a6-1cf038ff43a6",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f985bf05-ccf6-4ba9-a6ee-c4a5eb7dc8f0",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bfe59780-2e74-4418-9a06-cff330c76e6c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "59b12448-1adf-43a5-bdad-c3b85be3fcc1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "id": "3e988969-a87e-42f7-8a5e-d161adb0d32a",
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_accuracy(a, b):\n",
    "    correct = 0\n",
    "    total = 93\n",
    "    \n",
    "    for i in range(len(b)):\n",
    "        if(a[i]['input'] == b[i]['input']):\n",
    "            if(a[i]['output']['model2'] == b[i]['output']['model2']):\n",
    "                correct += 1\n",
    "        else:\n",
    "            print(\"Mismatch\")\n",
    "            print(a[i])\n",
    "            print(b[i])\n",
    "            print(\"\\n\\n\\n\")\n",
    "    \n",
    "    print(correct)\n",
    "    print(correct/total)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6e2e5462-92f8-43f3-9f15-c39d7a3c2916",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ee838346-dd7c-4f4b-bb37-5ed87af56ce3",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d9d1faa7-f554-4b39-a9a5-a00ea353ce79",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 52,
   "id": "01bd30d5-ac2e-45a5-9e89-3250d2eacf9a",
   "metadata": {},
   "outputs": [],
   "source": [
    "def prediction_zero(data):\n",
    "    prediction0_1 = [i for i in range(len(data)) if data[i][\"output\"][\"model1\"] == 0]\n",
    "    prediction0_2 = [i for i in range(len(data)) if data[i][\"output\"][\"model2\"] == 0]\n",
    "    return prediction0_1, prediction0_2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 53,
   "id": "ae70c842-45ed-46b6-981c-eb8d7ee9cbdd",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model 1: 78\n",
      "Model 2: 73\n"
     ]
    }
   ],
   "source": [
    "print(f\"Model 1: {len(prediction_zero(verb_data)[0])}\")\n",
    "print(f\"Model 2: {len(prediction_zero(verb_data)[1])}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "id": "e3eb3fd8-3cc7-4adf-a3ad-0130ff33a6f0",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model 1: 91\n",
      "Model 2: 73\n"
     ]
    }
   ],
   "source": [
    "print(f\"Model 1: {len(prediction_zero(gen_data)[0])}\")\n",
    "print(f\"Model 2: {len(prediction_zero(gen_data)[1])}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "86e06dda-b35d-49b8-999f-97b80d243978",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9c599d47-8876-4ef7-9e86-f6d78b2756d9",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "05375133-7679-48d7-a37c-752780695a42",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "909c9d41-6c05-46e9-805f-3be9b415cb1b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8027d70a-6300-432e-a81b-25fe78072e5d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ca325a2f-366a-4da8-9f10-df508d2db26a",
   "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
}
