{
 "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": [
    "# Third Party Imports\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "from sklearn.metrics import accuracy_score\n",
    "from sklearn.model_selection import train_test_split, RandomizedSearchCV\n",
    "from sklearn.neighbors import KNeighborsClassifier\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": "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": 5,
     "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": 6,
   "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": 6,
     "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": 7,
   "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.4, random_state=400, stratify=blood[\"Blood Donated\"])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "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": 9,
   "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": 10,
   "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": 10,
     "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": 11,
   "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": 12,
   "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": 13,
   "id": "d53928be",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Recency (months)         1.00224\n",
       "Frequency (times)        1.00224\n",
       "Monetary (c.c. blood)    1.00224\n",
       "Time (months)            1.00224\n",
       "dtype: float64"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "X_train_scaled_df.var().round(5)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "d4ad7b6d-4c4a-47bb-998d-f1b1c7b27c46",
   "metadata": {},
   "source": [
    "Let's expand the dataset. This will preserve the relationship between the data points but since the data is scaled, it'll be easier for the LLM to interpret"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "92893c0c-a9aa-4620-bd7a-fdf3e007561b",
   "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": 15,
   "id": "61360c87-a38f-4ec7-a771-5fe734bb6f79",
   "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": 15,
     "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": 16,
   "id": "61841898",
   "metadata": {},
   "outputs": [],
   "source": [
    "X_test_scaled_df = X_test_verb_scaled_df\n",
    "y_test = y_test_verb"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "517b1967-ddbb-4326-96cf-cbcf8275462a",
   "metadata": {},
   "outputs": [],
   "source": [
    "#### Helper Functions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "ffb370a1-50a9-404f-9b85-4f8feeb4bd0f",
   "metadata": {},
   "outputs": [],
   "source": [
    "def nearest_neighbours_plot(knn, X_train, y_train, X_test, y_pred, test_index):\n",
    "    # Select a test instance and print the prediction\n",
    "    test_instance = X_test.iloc[test_index]\n",
    "    \n",
    "    # Find the nearest neighbors\n",
    "    distances, indices = knn.kneighbors([test_instance])\n",
    "    \n",
    "    # Indices 0 and 1 correspond to Recency and Frequency\n",
    "    feature_index_1 = 0\n",
    "    feature_index_2 = 1\n",
    "\n",
    "    # Plot the training data\n",
    "    plt.figure(figsize=(10, 6))\n",
    "    plt.scatter(X_train.iloc[:, feature_index_1], X_train.iloc[:, feature_index_2], c=y_train, cmap='viridis', edgecolor='k')\n",
    "    \n",
    "    # Plot the test instance\n",
    "    plt.scatter(test_instance[feature_index_1], test_instance[feature_index_2], c='r', s=100, marker='*', label='Test Instance')\n",
    "    \n",
    "    # Plot the nearest neighbors\n",
    "    nearest_neighbors = X_train.iloc[indices[0]]\n",
    "    plt.scatter(nearest_neighbors.iloc[:, feature_index_1], nearest_neighbors.iloc[:, feature_index_2], c='g', s=100, label=f'k Nearest Neighbors')\n",
    "    \n",
    "    # Add labels and title\n",
    "    plt.xlabel(X_train.columns[0])\n",
    "    plt.ylabel(X_train.columns[1])\n",
    "    plt.title('Nearest Neighbors Plot')\n",
    "    plt.legend()\n",
    "    \n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "8b4f0cd4-3251-4f7a-99d4-d12f4c7bc310",
   "metadata": {},
   "source": [
    "#### Model Variations"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "a4d58829-270b-4e57-a66c-e5af096007e4",
   "metadata": {},
   "source": [
    "**Best Parameter**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "fa0140dc-832a-4916-8844-2fc4a16d5dc1",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/shravan/NLE3/Explainable-AI/venv/lib/python3.12/site-packages/numpy/ma/core.py:2881: RuntimeWarning: invalid value encountered in cast\n",
      "  _data = np.array(data, dtype=dtype, copy=copy,\n"
     ]
    }
   ],
   "source": [
    "np.random.seed(123)\n",
    "    \n",
    "param_distributions = {\n",
    "    'n_neighbors': range(1, 10),\n",
    "    'weights': ['uniform', 'distance'],\n",
    "    'algorithm': ['auto', 'brute'],\n",
    "    'leaf_size': range(1, 51),\n",
    "    'p': [1, 2, 3, 4, np.inf],\n",
    "    'metric': ['minkowski', 'cosine']\n",
    "}\n",
    "\n",
    "knn = KNeighborsClassifier()\n",
    "random_search = RandomizedSearchCV(\n",
    "    estimator=knn,\n",
    "    param_distributions=param_distributions,\n",
    "    n_iter=10,\n",
    "    cv=5,\n",
    "    n_jobs=-1,\n",
    "    scoring='accuracy',\n",
    "    random_state=21\n",
    ")\n",
    "\n",
    "random_search.fit(X_train_scaled_df, y_train)\n",
    "best_params = random_search.best_params_"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "6958dd86-d485-4998-b663-9fc11fbdba67",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'weights': 'uniform',\n",
       " 'p': 1,\n",
       " 'n_neighbors': 8,\n",
       " 'metric': 'minkowski',\n",
       " 'leaf_size': 20,\n",
       " 'algorithm': 'brute'}"
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "best_params"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "30088431-0576-483c-adef-d0e5900e78de",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.7733333333333333"
      ]
     },
     "execution_count": 21,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Train the base model\n",
    "def train_base_model(X_train, y_train):\n",
    "    best_knn = KNeighborsClassifier(**best_params)\n",
    "    # best_knn = KNeighborsClassifier(metric=\"cosine\", n_neighbors=3, p=np.inf)\n",
    "    best_knn.fit(X_train, y_train)\n",
    "    return best_knn\n",
    "\n",
    "base_model = train_base_model(X_train_scaled_df, y_train)\n",
    "base_pred = base_model.predict(X_test_scaled_df)\n",
    "accuracy_score(y_test, base_pred)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "0ca95e36-e07e-4695-a25c-11affdbe8d24",
   "metadata": {},
   "outputs": [],
   "source": [
    "def generate_random_params():\n",
    "    metric = np.random.choice(['minkowski', 'cosine'])\n",
    "    \n",
    "    if metric == 'minkowski':\n",
    "        p_choices = [1, 2, 3, 4, np.inf]\n",
    "        p = np.random.choice(p_choices)\n",
    "        params = {\n",
    "            'n_neighbors': np.random.randint(1, 20),\n",
    "            'weights': np.random.choice(['uniform', 'distance']),\n",
    "            'algorithm': np.random.choice(['auto', 'ball_tree', 'kd_tree', 'brute']),\n",
    "            'leaf_size': np.random.randint(10, 51),\n",
    "            'metric': 'minkowski',\n",
    "            'p': p\n",
    "        }\n",
    "    else:  # cosine similarity\n",
    "        params = {\n",
    "            'n_neighbors': np.random.randint(1, 20),\n",
    "            'weights': np.random.choice(['uniform', 'distance']),\n",
    "            'algorithm': 'brute',\n",
    "            'metric': 'cosine'\n",
    "        }\n",
    "    \n",
    "    return params\n",
    "\n",
    "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"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "6f5b47dd-fd38-4f95-9846-fee1c83e7eac",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Comparison with Base Model\n",
    "def generate_models_with_diff(base_model, X_train, y_train, X_test, max_attempts=10):\n",
    "    best_diff = 0\n",
    "    best_pair = None\n",
    "    all_models = []\n",
    "    \n",
    "    for i in range(max_attempts):\n",
    "        random_params = generate_random_params()\n",
    "        new_model = KNeighborsClassifier(**random_params)\n",
    "        new_model.fit(X_train, y_train)\n",
    "        all_models.append(new_model)\n",
    "        \n",
    "        diff = compare_models(base_model, new_model, X_test)\n",
    "        print(f\"Attempt Number {i}. Diff - {diff}\")\n",
    "        \n",
    "        if diff > best_diff and (0.25 <= diff and diff <= 0.30):\n",
    "            best_diff = diff\n",
    "            best_pair = (base_model, new_model)\n",
    "            print(f\"Best diff till now {best_diff}.\")\n",
    "    return best_pair, best_diff, all_models"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "a9c4fc5e-a3c3-4e02-90d5-20d759c5ac89",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Attempt Number 0. Diff - 0.11333333333333333\n",
      "Attempt Number 1. Diff - 0.06666666666666667\n",
      "Attempt Number 2. Diff - 0.013333333333333334\n",
      "Attempt Number 3. Diff - 0.18\n",
      "Attempt Number 4. Diff - 0.09333333333333334\n",
      "Attempt Number 5. Diff - 0.16666666666666666\n",
      "Attempt Number 6. Diff - 0.16666666666666666\n",
      "Attempt Number 7. Diff - 0.06\n",
      "Attempt Number 8. Diff - 0.04666666666666667\n",
      "Attempt Number 9. Diff - 0.02\n",
      "Attempt Number 10. Diff - 0.11333333333333333\n",
      "Attempt Number 11. Diff - 0.07333333333333333\n",
      "Attempt Number 12. Diff - 0.006666666666666667\n",
      "Attempt Number 13. Diff - 0.07333333333333333\n",
      "Attempt Number 14. Diff - 0.09333333333333334\n",
      "Attempt Number 15. Diff - 0.18\n",
      "Attempt Number 16. Diff - 0.04666666666666667\n",
      "Attempt Number 17. Diff - 0.02\n",
      "Attempt Number 18. Diff - 0.09333333333333334\n",
      "Attempt Number 19. Diff - 0.07333333333333333\n",
      "Attempt Number 20. Diff - 0.03333333333333333\n",
      "Attempt Number 21. Diff - 0.24\n",
      "Attempt Number 22. Diff - 0.16\n",
      "Attempt Number 23. Diff - 0.09333333333333334\n",
      "Attempt Number 24. Diff - 0.04666666666666667\n",
      "Attempt Number 25. Diff - 0.11333333333333333\n",
      "Attempt Number 26. Diff - 0.04666666666666667\n",
      "Attempt Number 27. Diff - 0.05333333333333334\n",
      "Attempt Number 28. Diff - 0.06\n",
      "Attempt Number 29. Diff - 0.02\n",
      "Attempt Number 30. Diff - 0.013333333333333334\n",
      "Attempt Number 31. Diff - 0.04666666666666667\n",
      "Attempt Number 32. Diff - 0.11333333333333333\n",
      "Attempt Number 33. Diff - 0.02666666666666667\n",
      "Attempt Number 34. Diff - 0.13333333333333333\n",
      "Attempt Number 35. Diff - 0.09333333333333334\n",
      "Attempt Number 36. Diff - 0.16666666666666666\n",
      "Attempt Number 37. Diff - 0.06\n",
      "Attempt Number 38. Diff - 0.03333333333333333\n",
      "Attempt Number 39. Diff - 0.09333333333333334\n",
      "Attempt Number 40. Diff - 0.03333333333333333\n",
      "Attempt Number 41. Diff - 0.06\n",
      "Attempt Number 42. Diff - 0.05333333333333334\n",
      "Attempt Number 43. Diff - 0.09333333333333334\n",
      "Attempt Number 44. Diff - 0.03333333333333333\n",
      "Attempt Number 45. Diff - 0.09333333333333334\n",
      "Attempt Number 46. Diff - 0.02666666666666667\n",
      "Attempt Number 47. Diff - 0.11333333333333333\n",
      "Attempt Number 48. Diff - 0.03333333333333333\n",
      "Attempt Number 49. Diff - 0.11333333333333333\n"
     ]
    }
   ],
   "source": [
    "# np.random.seed(128)\n",
    "# np.random.seed(236)\n",
    "np.random.seed(264)\n",
    "# np.random.seed(130)\n",
    "# np.random.seed(123)\n",
    "# np.random.seed(12)\n",
    "\n",
    "max_attempts = 50\n",
    "best_pair, best_diff, all_knns = generate_models_with_diff(base_model, X_train_scaled_df, y_train, X_test_scaled_df, max_attempts)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "b4de7a2f-1b92-4635-9456-fd625595c80b",
   "metadata": {},
   "outputs": [],
   "source": [
    "def find_best_model_pair(all_models, X_test):\n",
    "    best_pair = None\n",
    "    best_diff = 0\n",
    "    n = len(all_models)\n",
    "    \n",
    "    for i in range(n):\n",
    "        print(f\"ith value is - {i}\")\n",
    "        for j in range(i+1, n):\n",
    "            \n",
    "            model_i = all_models[i]\n",
    "            model_j = all_models[j]\n",
    "            \n",
    "            diff = compare_models(model_i, model_j, X_test)\n",
    "            print(f\"Comparing Model {i} and Model {j}. Diff: {diff:.4f}\")\n",
    "            \n",
    "            if diff > best_diff and (0.25 <= diff and diff <= 0.30):\n",
    "                best_diff = diff\n",
    "                best_pair = (model_i, model_j)\n",
    "                print(\"************************************\")\n",
    "                print(f\"New best pair found: Models {i} and {j} with diff {diff:.4f}\")\n",
    "                print(\"************************************\")\n",
    "               \n",
    "    return best_pair, best_diff"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6e2ccfa6-1437-4cc7-bb4a-570272043034",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "ith value is - 0\n",
      "Comparing Model 0 and Model 1. Diff: 0.1133\n",
      "Comparing Model 0 and Model 2. Diff: 0.1133\n",
      "Comparing Model 0 and Model 3. Diff: 0.1067\n",
      "Comparing Model 0 and Model 4. Diff: 0.1400\n",
      "Comparing Model 0 and Model 5. Diff: 0.2400\n",
      "Comparing Model 0 and Model 6. Diff: 0.2400\n",
      "Comparing Model 0 and Model 7. Diff: 0.1067\n",
      "Comparing Model 0 and Model 8. Diff: 0.0800\n",
      "Comparing Model 0 and Model 9. Diff: 0.0933\n",
      "Comparing Model 0 and Model 10. Diff: 0.1867\n",
      "Comparing Model 0 and Model 11. Diff: 0.1200\n",
      "Comparing Model 0 and Model 12. Diff: 0.1067\n",
      "Comparing Model 0 and Model 13. Diff: 0.1200\n",
      "Comparing Model 0 and Model 14. Diff: 0.1400\n",
      "Comparing Model 0 and Model 15. Diff: 0.1067\n",
      "Comparing Model 0 and Model 16. Diff: 0.0800\n",
      "Comparing Model 0 and Model 17. Diff: 0.1067\n",
      "Comparing Model 0 and Model 18. Diff: 0.1400\n",
      "Comparing Model 0 and Model 19. Diff: 0.1200\n",
      "Comparing Model 0 and Model 20. Diff: 0.1200\n",
      "Comparing Model 0 and Model 21. Diff: 0.1800\n",
      "Comparing Model 0 and Model 22. Diff: 0.1133\n",
      "Comparing Model 0 and Model 23. Diff: 0.1400\n",
      "Comparing Model 0 and Model 24. Diff: 0.1200\n",
      "Comparing Model 0 and Model 25. Diff: 0.1600\n",
      "Comparing Model 0 and Model 26. Diff: 0.0800\n",
      "Comparing Model 0 and Model 27. Diff: 0.0733\n",
      "Comparing Model 0 and Model 28. Diff: 0.1067\n",
      "Comparing Model 0 and Model 29. Diff: 0.1067\n",
      "Comparing Model 0 and Model 30. Diff: 0.1133\n",
      "Comparing Model 0 and Model 31. Diff: 0.0800\n",
      "Comparing Model 0 and Model 32. Diff: 0.1333\n",
      "Comparing Model 0 and Model 33. Diff: 0.1133\n",
      "Comparing Model 0 and Model 34. Diff: 0.0333\n",
      "Comparing Model 0 and Model 35. Diff: 0.1400\n",
      "Comparing Model 0 and Model 36. Diff: 0.2400\n",
      "Comparing Model 0 and Model 37. Diff: 0.1067\n",
      "Comparing Model 0 and Model 38. Diff: 0.1200\n",
      "Comparing Model 0 and Model 39. Diff: 0.1400\n",
      "Comparing Model 0 and Model 40. Diff: 0.1200\n",
      "Comparing Model 0 and Model 41. Diff: 0.0933\n",
      "Comparing Model 0 and Model 42. Diff: 0.1400\n",
      "Comparing Model 0 and Model 43. Diff: 0.1400\n",
      "Comparing Model 0 and Model 44. Diff: 0.1200\n",
      "Comparing Model 0 and Model 45. Diff: 0.1400\n",
      "Comparing Model 0 and Model 46. Diff: 0.1133\n",
      "Comparing Model 0 and Model 47. Diff: 0.1600\n",
      "Comparing Model 0 and Model 48. Diff: 0.1200\n",
      "Comparing Model 0 and Model 49. Diff: 0.1867\n",
      "ith value is - 1\n",
      "Comparing Model 1 and Model 2. Diff: 0.0800\n",
      "Comparing Model 1 and Model 3. Diff: 0.1667\n",
      "Comparing Model 1 and Model 4. Diff: 0.0933\n",
      "Comparing Model 1 and Model 5. Diff: 0.1933\n",
      "Comparing Model 1 and Model 6. Diff: 0.1933\n",
      "Comparing Model 1 and Model 7. Diff: 0.0867\n",
      "Comparing Model 1 and Model 8. Diff: 0.0867\n",
      "Comparing Model 1 and Model 9. Diff: 0.0733\n",
      "Comparing Model 1 and Model 10. Diff: 0.1400\n",
      "Comparing Model 1 and Model 11. Diff: 0.1000\n",
      "Comparing Model 1 and Model 12. Diff: 0.0733\n",
      "Comparing Model 1 and Model 13. Diff: 0.1000\n",
      "Comparing Model 1 and Model 14. Diff: 0.0933\n",
      "Comparing Model 1 and Model 15. Diff: 0.1667\n",
      "Comparing Model 1 and Model 16. Diff: 0.0867\n",
      "Comparing Model 1 and Model 17. Diff: 0.0733\n",
      "Comparing Model 1 and Model 18. Diff: 0.0933\n",
      "Comparing Model 1 and Model 19. Diff: 0.1000\n",
      "Comparing Model 1 and Model 20. Diff: 0.0867\n",
      "Comparing Model 1 and Model 21. Diff: 0.2267\n",
      "Comparing Model 1 and Model 22. Diff: 0.1600\n",
      "Comparing Model 1 and Model 23. Diff: 0.0933\n",
      "Comparing Model 1 and Model 24. Diff: 0.0733\n",
      "Comparing Model 1 and Model 25. Diff: 0.1133\n",
      "Comparing Model 1 and Model 26. Diff: 0.0733\n",
      "Comparing Model 1 and Model 27. Diff: 0.0533\n",
      "Comparing Model 1 and Model 28. Diff: 0.0867\n",
      "Comparing Model 1 and Model 29. Diff: 0.0733\n",
      "Comparing Model 1 and Model 30. Diff: 0.0800\n",
      "Comparing Model 1 and Model 31. Diff: 0.0600\n",
      "Comparing Model 1 and Model 32. Diff: 0.0733\n",
      "Comparing Model 1 and Model 33. Diff: 0.0800\n",
      "Comparing Model 1 and Model 34. Diff: 0.0933\n",
      "Comparing Model 1 and Model 35. Diff: 0.0933\n",
      "Comparing Model 1 and Model 36. Diff: 0.1933\n",
      "Comparing Model 1 and Model 37. Diff: 0.0867\n",
      "Comparing Model 1 and Model 38. Diff: 0.0867\n",
      "Comparing Model 1 and Model 39. Diff: 0.1067\n",
      "Comparing Model 1 and Model 40. Diff: 0.0867\n",
      "Comparing Model 1 and Model 41. Diff: 0.0600\n",
      "Comparing Model 1 and Model 42. Diff: 0.1067\n",
      "Comparing Model 1 and Model 43. Diff: 0.1067\n",
      "Comparing Model 1 and Model 44. Diff: 0.0867\n",
      "Comparing Model 1 and Model 45. Diff: 0.0933\n",
      "Comparing Model 1 and Model 46. Diff: 0.0800\n",
      "Comparing Model 1 and Model 47. Diff: 0.1133\n",
      "Comparing Model 1 and Model 48. Diff: 0.0867\n",
      "Comparing Model 1 and Model 49. Diff: 0.1400\n",
      "ith value is - 2\n",
      "Comparing Model 2 and Model 3. Diff: 0.1933\n",
      "Comparing Model 2 and Model 4. Diff: 0.1067\n",
      "Comparing Model 2 and Model 5. Diff: 0.1800\n",
      "Comparing Model 2 and Model 6. Diff: 0.1800\n",
      "Comparing Model 2 and Model 7. Diff: 0.0733\n",
      "Comparing Model 2 and Model 8. Diff: 0.0467\n",
      "Comparing Model 2 and Model 9. Diff: 0.0200\n",
      "Comparing Model 2 and Model 10. Diff: 0.1267\n",
      "Comparing Model 2 and Model 11. Diff: 0.0867\n",
      "Comparing Model 2 and Model 12. Diff: 0.0067\n",
      "Comparing Model 2 and Model 13. Diff: 0.0867\n",
      "Comparing Model 2 and Model 14. Diff: 0.1067\n",
      "Comparing Model 2 and Model 15. Diff: 0.1933\n",
      "Comparing Model 2 and Model 16. Diff: 0.0467\n",
      "Comparing Model 2 and Model 17. Diff: 0.0200\n",
      "Comparing Model 2 and Model 18. Diff: 0.1067\n",
      "Comparing Model 2 and Model 19. Diff: 0.0867\n",
      "Comparing Model 2 and Model 20. Diff: 0.0333\n",
      "Comparing Model 2 and Model 21. Diff: 0.2533\n",
      "************************************\n",
      "New best pair found: Models 2 and 21 with diff 0.2533\n",
      "************************************\n",
      "Comparing Model 2 and Model 22. Diff: 0.1733\n",
      "Comparing Model 2 and Model 23. Diff: 0.1067\n",
      "Comparing Model 2 and Model 24. Diff: 0.0600\n",
      "Comparing Model 2 and Model 25. Diff: 0.1267\n",
      "Comparing Model 2 and Model 26. Diff: 0.0467\n",
      "Comparing Model 2 and Model 27. Diff: 0.0533\n",
      "Comparing Model 2 and Model 28. Diff: 0.0733\n",
      "Comparing Model 2 and Model 29. Diff: 0.0200\n",
      "Comparing Model 2 and Model 30. Diff: 0.0133\n",
      "Comparing Model 2 and Model 31. Diff: 0.0600\n",
      "Comparing Model 2 and Model 32. Diff: 0.1267\n",
      "Comparing Model 2 and Model 33. Diff: 0.0267\n",
      "Comparing Model 2 and Model 34. Diff: 0.1467\n",
      "Comparing Model 2 and Model 35. Diff: 0.1067\n",
      "Comparing Model 2 and Model 36. Diff: 0.1800\n",
      "Comparing Model 2 and Model 37. Diff: 0.0733\n",
      "Comparing Model 2 and Model 38. Diff: 0.0333\n",
      "Comparing Model 2 and Model 39. Diff: 0.1067\n",
      "Comparing Model 2 and Model 40. Diff: 0.0333\n",
      "Comparing Model 2 and Model 41. Diff: 0.0733\n",
      "Comparing Model 2 and Model 42. Diff: 0.0667\n",
      "Comparing Model 2 and Model 43. Diff: 0.1067\n",
      "Comparing Model 2 and Model 44. Diff: 0.0200\n",
      "Comparing Model 2 and Model 45. Diff: 0.1067\n",
      "Comparing Model 2 and Model 46. Diff: 0.0267\n",
      "Comparing Model 2 and Model 47. Diff: 0.1267\n",
      "Comparing Model 2 and Model 48. Diff: 0.0333\n",
      "Comparing Model 2 and Model 49. Diff: 0.1267\n",
      "ith value is - 3\n",
      "Comparing Model 3 and Model 4. Diff: 0.1267\n",
      "Comparing Model 3 and Model 5. Diff: 0.2000\n",
      "Comparing Model 3 and Model 6. Diff: 0.2000\n",
      "Comparing Model 3 and Model 7. Diff: 0.1733\n",
      "Comparing Model 3 and Model 8. Diff: 0.1733\n",
      "Comparing Model 3 and Model 9. Diff: 0.1867\n",
      "Comparing Model 3 and Model 10. Diff: 0.1333\n",
      "Comparing Model 3 and Model 11. Diff: 0.1733\n",
      "Comparing Model 3 and Model 12. Diff: 0.1867\n",
      "Comparing Model 3 and Model 13. Diff: 0.1733\n",
      "Comparing Model 3 and Model 14. Diff: 0.1267\n",
      "Comparing Model 3 and Model 15. Diff: 0.0133\n",
      "Comparing Model 3 and Model 16. Diff: 0.1733\n",
      "Comparing Model 3 and Model 17. Diff: 0.1867\n",
      "Comparing Model 3 and Model 18. Diff: 0.1400\n",
      "Comparing Model 3 and Model 19. Diff: 0.1733\n",
      "Comparing Model 3 and Model 20. Diff: 0.2133\n",
      "Comparing Model 3 and Model 21. Diff: 0.1133\n",
      "Comparing Model 3 and Model 22. Diff: 0.0467\n",
      "Comparing Model 3 and Model 23. Diff: 0.1400\n",
      "Comparing Model 3 and Model 24. Diff: 0.1600\n",
      "Comparing Model 3 and Model 25. Diff: 0.1333\n",
      "Comparing Model 3 and Model 26. Diff: 0.1600\n",
      "Comparing Model 3 and Model 27. Diff: 0.1800\n",
      "Comparing Model 3 and Model 28. Diff: 0.1733\n",
      "Comparing Model 3 and Model 29. Diff: 0.2000\n",
      "Comparing Model 3 and Model 30. Diff: 0.1933\n",
      "Comparing Model 3 and Model 31. Diff: 0.1467\n",
      "Comparing Model 3 and Model 32. Diff: 0.1200\n",
      "Comparing Model 3 and Model 33. Diff: 0.2067\n",
      "Comparing Model 3 and Model 34. Diff: 0.0733\n",
      "Comparing Model 3 and Model 35. Diff: 0.1267\n",
      "Comparing Model 3 and Model 36. Diff: 0.2000\n",
      "Comparing Model 3 and Model 37. Diff: 0.1733\n",
      "Comparing Model 3 and Model 38. Diff: 0.2133\n",
      "Comparing Model 3 and Model 39. Diff: 0.1667\n",
      "Comparing Model 3 and Model 40. Diff: 0.2133\n",
      "Comparing Model 3 and Model 41. Diff: 0.1333\n",
      "Comparing Model 3 and Model 42. Diff: 0.1933\n",
      "Comparing Model 3 and Model 43. Diff: 0.1667\n",
      "Comparing Model 3 and Model 44. Diff: 0.2133\n",
      "Comparing Model 3 and Model 45. Diff: 0.1400\n",
      "Comparing Model 3 and Model 46. Diff: 0.2067\n",
      "Comparing Model 3 and Model 47. Diff: 0.1333\n",
      "Comparing Model 3 and Model 48. Diff: 0.2000\n",
      "Comparing Model 3 and Model 49. Diff: 0.1333\n",
      "ith value is - 4\n",
      "Comparing Model 4 and Model 5. Diff: 0.1533\n",
      "Comparing Model 4 and Model 6. Diff: 0.1533\n",
      "Comparing Model 4 and Model 7. Diff: 0.0867\n",
      "Comparing Model 4 and Model 8. Diff: 0.0867\n",
      "Comparing Model 4 and Model 9. Diff: 0.0867\n",
      "Comparing Model 4 and Model 10. Diff: 0.0600\n",
      "Comparing Model 4 and Model 11. Diff: 0.0867\n",
      "Comparing Model 4 and Model 12. Diff: 0.1000\n",
      "Comparing Model 4 and Model 13. Diff: 0.0867\n",
      "Comparing Model 4 and Model 14. Diff: 0.0000\n",
      "Comparing Model 4 and Model 15. Diff: 0.1267\n",
      "Comparing Model 4 and Model 16. Diff: 0.0867\n",
      "Comparing Model 4 and Model 17. Diff: 0.1000\n",
      "Comparing Model 4 and Model 18. Diff: 0.0800\n",
      "Comparing Model 4 and Model 19. Diff: 0.0867\n",
      "Comparing Model 4 and Model 20. Diff: 0.1133\n",
      "Comparing Model 4 and Model 21. Diff: 0.2133\n",
      "Comparing Model 4 and Model 22. Diff: 0.1467\n",
      "Comparing Model 4 and Model 23. Diff: 0.0800\n",
      "Comparing Model 4 and Model 24. Diff: 0.0467\n",
      "Comparing Model 4 and Model 25. Diff: 0.0733\n",
      "Comparing Model 4 and Model 26. Diff: 0.0733\n",
      "Comparing Model 4 and Model 27. Diff: 0.0933\n",
      "Comparing Model 4 and Model 28. Diff: 0.0867\n",
      "Comparing Model 4 and Model 29. Diff: 0.1000\n",
      "Comparing Model 4 and Model 30. Diff: 0.1067\n",
      "Comparing Model 4 and Model 31. Diff: 0.0733\n",
      "Comparing Model 4 and Model 32. Diff: 0.1000\n",
      "Comparing Model 4 and Model 33. Diff: 0.1067\n",
      "Comparing Model 4 and Model 34. Diff: 0.1333\n",
      "Comparing Model 4 and Model 35. Diff: 0.0000\n",
      "Comparing Model 4 and Model 36. Diff: 0.1533\n",
      "Comparing Model 4 and Model 37. Diff: 0.0867\n",
      "Comparing Model 4 and Model 38. Diff: 0.1133\n",
      "Comparing Model 4 and Model 39. Diff: 0.0800\n",
      "Comparing Model 4 and Model 40. Diff: 0.1133\n",
      "Comparing Model 4 and Model 41. Diff: 0.0867\n",
      "Comparing Model 4 and Model 42. Diff: 0.0933\n",
      "Comparing Model 4 and Model 43. Diff: 0.0800\n",
      "Comparing Model 4 and Model 44. Diff: 0.1133\n",
      "Comparing Model 4 and Model 45. Diff: 0.0800\n",
      "Comparing Model 4 and Model 46. Diff: 0.1067\n",
      "Comparing Model 4 and Model 47. Diff: 0.0733\n",
      "Comparing Model 4 and Model 48. Diff: 0.1000\n",
      "Comparing Model 4 and Model 49. Diff: 0.0600\n",
      "ith value is - 5\n",
      "Comparing Model 5 and Model 6. Diff: 0.0000\n",
      "Comparing Model 5 and Model 7. Diff: 0.1467\n",
      "Comparing Model 5 and Model 8. Diff: 0.1733\n",
      "Comparing Model 5 and Model 9. Diff: 0.1733\n",
      "Comparing Model 5 and Model 10. Diff: 0.1333\n",
      "Comparing Model 5 and Model 11. Diff: 0.1333\n",
      "Comparing Model 5 and Model 12. Diff: 0.1733\n",
      "Comparing Model 5 and Model 13. Diff: 0.1333\n",
      "Comparing Model 5 and Model 14. Diff: 0.1533\n",
      "Comparing Model 5 and Model 15. Diff: 0.1867\n",
      "Comparing Model 5 and Model 16. Diff: 0.1733\n",
      "Comparing Model 5 and Model 17. Diff: 0.1867\n",
      "Comparing Model 5 and Model 18. Diff: 0.1133\n",
      "Comparing Model 5 and Model 19. Diff: 0.1333\n",
      "Comparing Model 5 and Model 20. Diff: 0.2000\n",
      "Comparing Model 5 and Model 21. Diff: 0.1400\n",
      "Comparing Model 5 and Model 22. Diff: 0.1800\n",
      "Comparing Model 5 and Model 23. Diff: 0.1133\n",
      "Comparing Model 5 and Model 24. Diff: 0.1867\n",
      "Comparing Model 5 and Model 25. Diff: 0.0800\n",
      "Comparing Model 5 and Model 26. Diff: 0.1600\n",
      "Comparing Model 5 and Model 27. Diff: 0.2067\n",
      "Comparing Model 5 and Model 28. Diff: 0.1467\n",
      "Comparing Model 5 and Model 29. Diff: 0.1867\n",
      "Comparing Model 5 and Model 30. Diff: 0.1800\n",
      "Comparing Model 5 and Model 31. Diff: 0.1600\n",
      "Comparing Model 5 and Model 32. Diff: 0.1600\n",
      "Comparing Model 5 and Model 33. Diff: 0.1933\n",
      "Comparing Model 5 and Model 34. Diff: 0.2200\n",
      "Comparing Model 5 and Model 35. Diff: 0.1533\n",
      "Comparing Model 5 and Model 36. Diff: 0.0000\n",
      "Comparing Model 5 and Model 37. Diff: 0.1467\n",
      "Comparing Model 5 and Model 38. Diff: 0.2000\n",
      "Comparing Model 5 and Model 39. Diff: 0.1133\n",
      "Comparing Model 5 and Model 40. Diff: 0.2000\n",
      "Comparing Model 5 and Model 41. Diff: 0.1600\n",
      "Comparing Model 5 and Model 42. Diff: 0.1533\n",
      "Comparing Model 5 and Model 43. Diff: 0.1000\n",
      "Comparing Model 5 and Model 44. Diff: 0.2000\n",
      "Comparing Model 5 and Model 45. Diff: 0.1133\n",
      "Comparing Model 5 and Model 46. Diff: 0.1800\n",
      "Comparing Model 5 and Model 47. Diff: 0.0800\n",
      "Comparing Model 5 and Model 48. Diff: 0.1867\n",
      "Comparing Model 5 and Model 49. Diff: 0.1333\n",
      "ith value is - 6\n",
      "Comparing Model 6 and Model 7. Diff: 0.1467\n",
      "Comparing Model 6 and Model 8. Diff: 0.1733\n",
      "Comparing Model 6 and Model 9. Diff: 0.1733\n",
      "Comparing Model 6 and Model 10. Diff: 0.1333\n",
      "Comparing Model 6 and Model 11. Diff: 0.1333\n",
      "Comparing Model 6 and Model 12. Diff: 0.1733\n",
      "Comparing Model 6 and Model 13. Diff: 0.1333\n",
      "Comparing Model 6 and Model 14. Diff: 0.1533\n",
      "Comparing Model 6 and Model 15. Diff: 0.1867\n",
      "Comparing Model 6 and Model 16. Diff: 0.1733\n",
      "Comparing Model 6 and Model 17. Diff: 0.1867\n",
      "Comparing Model 6 and Model 18. Diff: 0.1133\n",
      "Comparing Model 6 and Model 19. Diff: 0.1333\n",
      "Comparing Model 6 and Model 20. Diff: 0.2000\n",
      "Comparing Model 6 and Model 21. Diff: 0.1400\n",
      "Comparing Model 6 and Model 22. Diff: 0.1800\n",
      "Comparing Model 6 and Model 23. Diff: 0.1133\n",
      "Comparing Model 6 and Model 24. Diff: 0.1867\n",
      "Comparing Model 6 and Model 25. Diff: 0.0800\n",
      "Comparing Model 6 and Model 26. Diff: 0.1600\n",
      "Comparing Model 6 and Model 27. Diff: 0.2067\n",
      "Comparing Model 6 and Model 28. Diff: 0.1467\n",
      "Comparing Model 6 and Model 29. Diff: 0.1867\n",
      "Comparing Model 6 and Model 30. Diff: 0.1800\n",
      "Comparing Model 6 and Model 31. Diff: 0.1600\n",
      "Comparing Model 6 and Model 32. Diff: 0.1600\n",
      "Comparing Model 6 and Model 33. Diff: 0.1933\n",
      "Comparing Model 6 and Model 34. Diff: 0.2200\n",
      "Comparing Model 6 and Model 35. Diff: 0.1533\n",
      "Comparing Model 6 and Model 36. Diff: 0.0000\n",
      "Comparing Model 6 and Model 37. Diff: 0.1467\n",
      "Comparing Model 6 and Model 38. Diff: 0.2000\n",
      "Comparing Model 6 and Model 39. Diff: 0.1133\n",
      "Comparing Model 6 and Model 40. Diff: 0.2000\n",
      "Comparing Model 6 and Model 41. Diff: 0.1600\n",
      "Comparing Model 6 and Model 42. Diff: 0.1533\n",
      "Comparing Model 6 and Model 43. Diff: 0.1000\n",
      "Comparing Model 6 and Model 44. Diff: 0.2000\n",
      "Comparing Model 6 and Model 45. Diff: 0.1133\n",
      "Comparing Model 6 and Model 46. Diff: 0.1800\n",
      "Comparing Model 6 and Model 47. Diff: 0.0800\n",
      "Comparing Model 6 and Model 48. Diff: 0.1867\n",
      "Comparing Model 6 and Model 49. Diff: 0.1333\n",
      "ith value is - 7\n",
      "Comparing Model 7 and Model 8. Diff: 0.0267\n",
      "Comparing Model 7 and Model 9. Diff: 0.0533\n",
      "Comparing Model 7 and Model 10. Diff: 0.1067\n",
      "Comparing Model 7 and Model 11. Diff: 0.0133\n",
      "Comparing Model 7 and Model 12. Diff: 0.0667\n",
      "Comparing Model 7 and Model 13. Diff: 0.0133\n",
      "Comparing Model 7 and Model 14. Diff: 0.0867\n",
      "Comparing Model 7 and Model 15. Diff: 0.1733\n",
      "Comparing Model 7 and Model 16. Diff: 0.0267\n",
      "Comparing Model 7 and Model 17. Diff: 0.0667\n",
      "Comparing Model 7 and Model 18. Diff: 0.0467\n",
      "Comparing Model 7 and Model 19. Diff: 0.0133\n",
      "Comparing Model 7 and Model 20. Diff: 0.0800\n",
      "Comparing Model 7 and Model 21. Diff: 0.2467\n",
      "Comparing Model 7 and Model 22. Diff: 0.1533\n",
      "Comparing Model 7 and Model 23. Diff: 0.0467\n",
      "Comparing Model 7 and Model 24. Diff: 0.0667\n",
      "Comparing Model 7 and Model 25. Diff: 0.0667\n",
      "Comparing Model 7 and Model 26. Diff: 0.0400\n",
      "Comparing Model 7 and Model 27. Diff: 0.0733\n",
      "Comparing Model 7 and Model 28. Diff: 0.0000\n",
      "Comparing Model 7 and Model 29. Diff: 0.0667\n",
      "Comparing Model 7 and Model 30. Diff: 0.0733\n",
      "Comparing Model 7 and Model 31. Diff: 0.0400\n",
      "Comparing Model 7 and Model 32. Diff: 0.0933\n",
      "Comparing Model 7 and Model 33. Diff: 0.0600\n",
      "Comparing Model 7 and Model 34. Diff: 0.1133\n",
      "Comparing Model 7 and Model 35. Diff: 0.0867\n",
      "Comparing Model 7 and Model 36. Diff: 0.1467\n",
      "Comparing Model 7 and Model 37. Diff: 0.0000\n",
      "Comparing Model 7 and Model 38. Diff: 0.0667\n",
      "Comparing Model 7 and Model 39. Diff: 0.0333\n",
      "Comparing Model 7 and Model 40. Diff: 0.0800\n",
      "Comparing Model 7 and Model 41. Diff: 0.0533\n",
      "Comparing Model 7 and Model 42. Diff: 0.0733\n",
      "Comparing Model 7 and Model 43. Diff: 0.0467\n",
      "Comparing Model 7 and Model 44. Diff: 0.0667\n",
      "Comparing Model 7 and Model 45. Diff: 0.0467\n",
      "Comparing Model 7 and Model 46. Diff: 0.0600\n",
      "Comparing Model 7 and Model 47. Diff: 0.0667\n",
      "Comparing Model 7 and Model 48. Diff: 0.0667\n",
      "Comparing Model 7 and Model 49. Diff: 0.1067\n",
      "ith value is - 8\n",
      "Comparing Model 8 and Model 9. Diff: 0.0267\n",
      "Comparing Model 8 and Model 10. Diff: 0.1200\n",
      "Comparing Model 8 and Model 11. Diff: 0.0400\n",
      "Comparing Model 8 and Model 12. Diff: 0.0400\n",
      "Comparing Model 8 and Model 13. Diff: 0.0400\n",
      "Comparing Model 8 and Model 14. Diff: 0.0867\n",
      "Comparing Model 8 and Model 15. Diff: 0.1733\n",
      "Comparing Model 8 and Model 16. Diff: 0.0000\n",
      "Comparing Model 8 and Model 17. Diff: 0.0400\n",
      "Comparing Model 8 and Model 18. Diff: 0.0733\n",
      "Comparing Model 8 and Model 19. Diff: 0.0400\n",
      "Comparing Model 8 and Model 20. Diff: 0.0533\n",
      "Comparing Model 8 and Model 21. Diff: 0.2467\n",
      "Comparing Model 8 and Model 22. Diff: 0.1533\n",
      "Comparing Model 8 and Model 23. Diff: 0.0733\n",
      "Comparing Model 8 and Model 24. Diff: 0.0533\n",
      "Comparing Model 8 and Model 25. Diff: 0.0933\n",
      "Comparing Model 8 and Model 26. Diff: 0.0133\n",
      "Comparing Model 8 and Model 27. Diff: 0.0467\n",
      "Comparing Model 8 and Model 28. Diff: 0.0267\n",
      "Comparing Model 8 and Model 29. Diff: 0.0400\n",
      "Comparing Model 8 and Model 30. Diff: 0.0467\n",
      "Comparing Model 8 and Model 31. Diff: 0.0267\n",
      "Comparing Model 8 and Model 32. Diff: 0.0933\n",
      "Comparing Model 8 and Model 33. Diff: 0.0333\n",
      "Comparing Model 8 and Model 34. Diff: 0.1133\n",
      "Comparing Model 8 and Model 35. Diff: 0.0867\n",
      "Comparing Model 8 and Model 36. Diff: 0.1733\n",
      "Comparing Model 8 and Model 37. Diff: 0.0267\n",
      "Comparing Model 8 and Model 38. Diff: 0.0400\n",
      "Comparing Model 8 and Model 39. Diff: 0.0600\n",
      "Comparing Model 8 and Model 40. Diff: 0.0533\n",
      "Comparing Model 8 and Model 41. Diff: 0.0400\n",
      "Comparing Model 8 and Model 42. Diff: 0.0733\n",
      "Comparing Model 8 and Model 43. Diff: 0.0733\n",
      "Comparing Model 8 and Model 44. Diff: 0.0400\n",
      "Comparing Model 8 and Model 45. Diff: 0.0733\n",
      "Comparing Model 8 and Model 46. Diff: 0.0333\n",
      "Comparing Model 8 and Model 47. Diff: 0.0933\n",
      "Comparing Model 8 and Model 48. Diff: 0.0400\n",
      "Comparing Model 8 and Model 49. Diff: 0.1200\n",
      "ith value is - 9\n",
      "Comparing Model 9 and Model 10. Diff: 0.1200\n",
      "Comparing Model 9 and Model 11. Diff: 0.0667\n",
      "Comparing Model 9 and Model 12. Diff: 0.0133\n",
      "Comparing Model 9 and Model 13. Diff: 0.0667\n",
      "Comparing Model 9 and Model 14. Diff: 0.0867\n",
      "Comparing Model 9 and Model 15. Diff: 0.1867\n",
      "Comparing Model 9 and Model 16. Diff: 0.0267\n",
      "Comparing Model 9 and Model 17. Diff: 0.0267\n",
      "Comparing Model 9 and Model 18. Diff: 0.0867\n",
      "Comparing Model 9 and Model 19. Diff: 0.0667\n",
      "Comparing Model 9 and Model 20. Diff: 0.0267\n",
      "Comparing Model 9 and Model 21. Diff: 0.2600\n",
      "************************************\n",
      "New best pair found: Models 9 and 21 with diff 0.2600\n",
      "************************************\n",
      "Comparing Model 9 and Model 22. Diff: 0.1800\n",
      "Comparing Model 9 and Model 23. Diff: 0.0867\n",
      "Comparing Model 9 and Model 24. Diff: 0.0533\n",
      "Comparing Model 9 and Model 25. Diff: 0.1067\n",
      "Comparing Model 9 and Model 26. Diff: 0.0267\n",
      "Comparing Model 9 and Model 27. Diff: 0.0333\n",
      "Comparing Model 9 and Model 28. Diff: 0.0533\n",
      "Comparing Model 9 and Model 29. Diff: 0.0133\n",
      "Comparing Model 9 and Model 30. Diff: 0.0200\n",
      "Comparing Model 9 and Model 31. Diff: 0.0400\n",
      "Comparing Model 9 and Model 32. Diff: 0.1067\n",
      "Comparing Model 9 and Model 33. Diff: 0.0200\n",
      "Comparing Model 9 and Model 34. Diff: 0.1267\n",
      "Comparing Model 9 and Model 35. Diff: 0.0867\n",
      "Comparing Model 9 and Model 36. Diff: 0.1733\n",
      "Comparing Model 9 and Model 37. Diff: 0.0533\n",
      "Comparing Model 9 and Model 38. Diff: 0.0267\n",
      "Comparing Model 9 and Model 39. Diff: 0.0867\n",
      "Comparing Model 9 and Model 40. Diff: 0.0267\n",
      "Comparing Model 9 and Model 41. Diff: 0.0533\n",
      "Comparing Model 9 and Model 42. Diff: 0.0733\n",
      "Comparing Model 9 and Model 43. Diff: 0.0867\n",
      "Comparing Model 9 and Model 44. Diff: 0.0267\n",
      "Comparing Model 9 and Model 45. Diff: 0.0867\n",
      "Comparing Model 9 and Model 46. Diff: 0.0200\n",
      "Comparing Model 9 and Model 47. Diff: 0.1067\n",
      "Comparing Model 9 and Model 48. Diff: 0.0267\n",
      "Comparing Model 9 and Model 49. Diff: 0.1200\n",
      "ith value is - 10\n",
      "Comparing Model 10 and Model 11. Diff: 0.0933\n",
      "Comparing Model 10 and Model 12. Diff: 0.1200\n",
      "Comparing Model 10 and Model 13. Diff: 0.0933\n",
      "Comparing Model 10 and Model 14. Diff: 0.0600\n",
      "Comparing Model 10 and Model 15. Diff: 0.1467\n",
      "Comparing Model 10 and Model 16. Diff: 0.1200\n",
      "Comparing Model 10 and Model 17. Diff: 0.1200\n",
      "Comparing Model 10 and Model 18. Diff: 0.0733\n",
      "Comparing Model 10 and Model 19. Diff: 0.0933\n",
      "Comparing Model 10 and Model 20. Diff: 0.1467\n",
      "Comparing Model 10 and Model 21. Diff: 0.2200\n",
      "Comparing Model 10 and Model 22. Diff: 0.1533\n",
      "Comparing Model 10 and Model 23. Diff: 0.0733\n",
      "Comparing Model 10 and Model 24. Diff: 0.0933\n",
      "Comparing Model 10 and Model 25. Diff: 0.0800\n",
      "Comparing Model 10 and Model 26. Diff: 0.1067\n",
      "Comparing Model 10 and Model 27. Diff: 0.1400\n",
      "Comparing Model 10 and Model 28. Diff: 0.1067\n",
      "Comparing Model 10 and Model 29. Diff: 0.1333\n",
      "Comparing Model 10 and Model 30. Diff: 0.1267\n",
      "Comparing Model 10 and Model 31. Diff: 0.1067\n",
      "Comparing Model 10 and Model 32. Diff: 0.1067\n",
      "Comparing Model 10 and Model 33. Diff: 0.1400\n",
      "Comparing Model 10 and Model 34. Diff: 0.1667\n",
      "Comparing Model 10 and Model 35. Diff: 0.0600\n",
      "Comparing Model 10 and Model 36. Diff: 0.1333\n",
      "Comparing Model 10 and Model 37. Diff: 0.1067\n",
      "Comparing Model 10 and Model 38. Diff: 0.1467\n",
      "Comparing Model 10 and Model 39. Diff: 0.0733\n",
      "Comparing Model 10 and Model 40. Diff: 0.1467\n",
      "Comparing Model 10 and Model 41. Diff: 0.1067\n",
      "Comparing Model 10 and Model 42. Diff: 0.1133\n",
      "Comparing Model 10 and Model 43. Diff: 0.0733\n",
      "Comparing Model 10 and Model 44. Diff: 0.1467\n",
      "Comparing Model 10 and Model 45. Diff: 0.0733\n",
      "Comparing Model 10 and Model 46. Diff: 0.1267\n",
      "Comparing Model 10 and Model 47. Diff: 0.0800\n",
      "Comparing Model 10 and Model 48. Diff: 0.1333\n",
      "Comparing Model 10 and Model 49. Diff: 0.0000\n",
      "ith value is - 11\n",
      "Comparing Model 11 and Model 12. Diff: 0.0800\n",
      "Comparing Model 11 and Model 13. Diff: 0.0000\n",
      "Comparing Model 11 and Model 14. Diff: 0.0867\n",
      "Comparing Model 11 and Model 15. Diff: 0.1733\n",
      "Comparing Model 11 and Model 16. Diff: 0.0400\n",
      "Comparing Model 11 and Model 17. Diff: 0.0800\n",
      "Comparing Model 11 and Model 18. Diff: 0.0467\n",
      "Comparing Model 11 and Model 19. Diff: 0.0000\n",
      "Comparing Model 11 and Model 20. Diff: 0.0933\n",
      "Comparing Model 11 and Model 21. Diff: 0.2467\n",
      "Comparing Model 11 and Model 22. Diff: 0.1533\n",
      "Comparing Model 11 and Model 23. Diff: 0.0467\n",
      "Comparing Model 11 and Model 24. Diff: 0.0800\n",
      "Comparing Model 11 and Model 25. Diff: 0.0667\n",
      "Comparing Model 11 and Model 26. Diff: 0.0533\n",
      "Comparing Model 11 and Model 27. Diff: 0.0867\n",
      "Comparing Model 11 and Model 28. Diff: 0.0133\n",
      "Comparing Model 11 and Model 29. Diff: 0.0800\n",
      "Comparing Model 11 and Model 30. Diff: 0.0867\n",
      "Comparing Model 11 and Model 31. Diff: 0.0533\n",
      "Comparing Model 11 and Model 32. Diff: 0.1067\n",
      "Comparing Model 11 and Model 33. Diff: 0.0733\n",
      "Comparing Model 11 and Model 34. Diff: 0.1267\n",
      "Comparing Model 11 and Model 35. Diff: 0.0867\n",
      "Comparing Model 11 and Model 36. Diff: 0.1333\n",
      "Comparing Model 11 and Model 37. Diff: 0.0133\n",
      "Comparing Model 11 and Model 38. Diff: 0.0800\n",
      "Comparing Model 11 and Model 39. Diff: 0.0200\n",
      "Comparing Model 11 and Model 40. Diff: 0.0933\n",
      "Comparing Model 11 and Model 41. Diff: 0.0667\n",
      "Comparing Model 11 and Model 42. Diff: 0.0733\n",
      "Comparing Model 11 and Model 43. Diff: 0.0333\n",
      "Comparing Model 11 and Model 44. Diff: 0.0800\n",
      "Comparing Model 11 and Model 45. Diff: 0.0467\n",
      "Comparing Model 11 and Model 46. Diff: 0.0600\n",
      "Comparing Model 11 and Model 47. Diff: 0.0667\n",
      "Comparing Model 11 and Model 48. Diff: 0.0667\n",
      "Comparing Model 11 and Model 49. Diff: 0.0933\n",
      "ith value is - 12\n",
      "Comparing Model 12 and Model 13. Diff: 0.0800\n",
      "Comparing Model 12 and Model 14. Diff: 0.1000\n",
      "Comparing Model 12 and Model 15. Diff: 0.1867\n",
      "Comparing Model 12 and Model 16. Diff: 0.0400\n",
      "Comparing Model 12 and Model 17. Diff: 0.0133\n",
      "Comparing Model 12 and Model 18. Diff: 0.1000\n",
      "Comparing Model 12 and Model 19. Diff: 0.0800\n",
      "Comparing Model 12 and Model 20. Diff: 0.0267\n",
      "Comparing Model 12 and Model 21. Diff: 0.2467\n",
      "Comparing Model 12 and Model 22. Diff: 0.1667\n",
      "Comparing Model 12 and Model 23. Diff: 0.1000\n",
      "Comparing Model 12 and Model 24. Diff: 0.0533\n",
      "Comparing Model 12 and Model 25. Diff: 0.1200\n",
      "Comparing Model 12 and Model 26. Diff: 0.0400\n",
      "Comparing Model 12 and Model 27. Diff: 0.0467\n",
      "Comparing Model 12 and Model 28. Diff: 0.0667\n",
      "Comparing Model 12 and Model 29. Diff: 0.0133\n",
      "Comparing Model 12 and Model 30. Diff: 0.0067\n",
      "Comparing Model 12 and Model 31. Diff: 0.0533\n",
      "Comparing Model 12 and Model 32. Diff: 0.1200\n",
      "Comparing Model 12 and Model 33. Diff: 0.0200\n",
      "Comparing Model 12 and Model 34. Diff: 0.1400\n",
      "Comparing Model 12 and Model 35. Diff: 0.1000\n",
      "Comparing Model 12 and Model 36. Diff: 0.1733\n",
      "Comparing Model 12 and Model 37. Diff: 0.0667\n",
      "Comparing Model 12 and Model 38. Diff: 0.0267\n",
      "Comparing Model 12 and Model 39. Diff: 0.1000\n",
      "Comparing Model 12 and Model 40. Diff: 0.0267\n",
      "Comparing Model 12 and Model 41. Diff: 0.0667\n",
      "Comparing Model 12 and Model 42. Diff: 0.0600\n",
      "Comparing Model 12 and Model 43. Diff: 0.1000\n",
      "Comparing Model 12 and Model 44. Diff: 0.0267\n",
      "Comparing Model 12 and Model 45. Diff: 0.1000\n",
      "Comparing Model 12 and Model 46. Diff: 0.0200\n",
      "Comparing Model 12 and Model 47. Diff: 0.1200\n",
      "Comparing Model 12 and Model 48. Diff: 0.0267\n",
      "Comparing Model 12 and Model 49. Diff: 0.1200\n",
      "ith value is - 13\n",
      "Comparing Model 13 and Model 14. Diff: 0.0867\n",
      "Comparing Model 13 and Model 15. Diff: 0.1733\n",
      "Comparing Model 13 and Model 16. Diff: 0.0400\n",
      "Comparing Model 13 and Model 17. Diff: 0.0800\n",
      "Comparing Model 13 and Model 18. Diff: 0.0467\n",
      "Comparing Model 13 and Model 19. Diff: 0.0000\n",
      "Comparing Model 13 and Model 20. Diff: 0.0933\n",
      "Comparing Model 13 and Model 21. Diff: 0.2467\n",
      "Comparing Model 13 and Model 22. Diff: 0.1533\n",
      "Comparing Model 13 and Model 23. Diff: 0.0467\n",
      "Comparing Model 13 and Model 24. Diff: 0.0800\n",
      "Comparing Model 13 and Model 25. Diff: 0.0667\n",
      "Comparing Model 13 and Model 26. Diff: 0.0533\n",
      "Comparing Model 13 and Model 27. Diff: 0.0867\n",
      "Comparing Model 13 and Model 28. Diff: 0.0133\n",
      "Comparing Model 13 and Model 29. Diff: 0.0800\n",
      "Comparing Model 13 and Model 30. Diff: 0.0867\n",
      "Comparing Model 13 and Model 31. Diff: 0.0533\n",
      "Comparing Model 13 and Model 32. Diff: 0.1067\n",
      "Comparing Model 13 and Model 33. Diff: 0.0733\n",
      "Comparing Model 13 and Model 34. Diff: 0.1267\n",
      "Comparing Model 13 and Model 35. Diff: 0.0867\n",
      "Comparing Model 13 and Model 36. Diff: 0.1333\n",
      "Comparing Model 13 and Model 37. Diff: 0.0133\n",
      "Comparing Model 13 and Model 38. Diff: 0.0800\n",
      "Comparing Model 13 and Model 39. Diff: 0.0200\n",
      "Comparing Model 13 and Model 40. Diff: 0.0933\n",
      "Comparing Model 13 and Model 41. Diff: 0.0667\n",
      "Comparing Model 13 and Model 42. Diff: 0.0733\n",
      "Comparing Model 13 and Model 43. Diff: 0.0333\n",
      "Comparing Model 13 and Model 44. Diff: 0.0800\n",
      "Comparing Model 13 and Model 45. Diff: 0.0467\n",
      "Comparing Model 13 and Model 46. Diff: 0.0600\n",
      "Comparing Model 13 and Model 47. Diff: 0.0667\n",
      "Comparing Model 13 and Model 48. Diff: 0.0667\n",
      "Comparing Model 13 and Model 49. Diff: 0.0933\n",
      "ith value is - 14\n",
      "Comparing Model 14 and Model 15. Diff: 0.1267\n",
      "Comparing Model 14 and Model 16. Diff: 0.0867\n",
      "Comparing Model 14 and Model 17. Diff: 0.1000\n",
      "Comparing Model 14 and Model 18. Diff: 0.0800\n",
      "Comparing Model 14 and Model 19. Diff: 0.0867\n",
      "Comparing Model 14 and Model 20. Diff: 0.1133\n",
      "Comparing Model 14 and Model 21. Diff: 0.2133\n",
      "Comparing Model 14 and Model 22. Diff: 0.1467\n",
      "Comparing Model 14 and Model 23. Diff: 0.0800\n",
      "Comparing Model 14 and Model 24. Diff: 0.0467\n",
      "Comparing Model 14 and Model 25. Diff: 0.0733\n",
      "Comparing Model 14 and Model 26. Diff: 0.0733\n",
      "Comparing Model 14 and Model 27. Diff: 0.0933\n",
      "Comparing Model 14 and Model 28. Diff: 0.0867\n",
      "Comparing Model 14 and Model 29. Diff: 0.1000\n",
      "Comparing Model 14 and Model 30. Diff: 0.1067\n",
      "Comparing Model 14 and Model 31. Diff: 0.0733\n",
      "Comparing Model 14 and Model 32. Diff: 0.1000\n",
      "Comparing Model 14 and Model 33. Diff: 0.1067\n",
      "Comparing Model 14 and Model 34. Diff: 0.1333\n",
      "Comparing Model 14 and Model 35. Diff: 0.0000\n",
      "Comparing Model 14 and Model 36. Diff: 0.1533\n",
      "Comparing Model 14 and Model 37. Diff: 0.0867\n",
      "Comparing Model 14 and Model 38. Diff: 0.1133\n",
      "Comparing Model 14 and Model 39. Diff: 0.0800\n",
      "Comparing Model 14 and Model 40. Diff: 0.1133\n",
      "Comparing Model 14 and Model 41. Diff: 0.0867\n",
      "Comparing Model 14 and Model 42. Diff: 0.0933\n",
      "Comparing Model 14 and Model 43. Diff: 0.0800\n",
      "Comparing Model 14 and Model 44. Diff: 0.1133\n",
      "Comparing Model 14 and Model 45. Diff: 0.0800\n",
      "Comparing Model 14 and Model 46. Diff: 0.1067\n",
      "Comparing Model 14 and Model 47. Diff: 0.0733\n",
      "Comparing Model 14 and Model 48. Diff: 0.1000\n",
      "Comparing Model 14 and Model 49. Diff: 0.0600\n",
      "ith value is - 15\n",
      "Comparing Model 15 and Model 16. Diff: 0.1733\n",
      "Comparing Model 15 and Model 17. Diff: 0.1867\n",
      "Comparing Model 15 and Model 18. Diff: 0.1533\n",
      "Comparing Model 15 and Model 19. Diff: 0.1733\n",
      "Comparing Model 15 and Model 20. Diff: 0.2133\n",
      "Comparing Model 15 and Model 21. Diff: 0.1000\n",
      "Comparing Model 15 and Model 22. Diff: 0.0333\n",
      "Comparing Model 15 and Model 23. Diff: 0.1533\n",
      "Comparing Model 15 and Model 24. Diff: 0.1600\n",
      "Comparing Model 15 and Model 25. Diff: 0.1200\n",
      "Comparing Model 15 and Model 26. Diff: 0.1600\n",
      "Comparing Model 15 and Model 27. Diff: 0.1800\n",
      "Comparing Model 15 and Model 28. Diff: 0.1733\n",
      "Comparing Model 15 and Model 29. Diff: 0.2000\n",
      "Comparing Model 15 and Model 30. Diff: 0.1933\n",
      "Comparing Model 15 and Model 31. Diff: 0.1467\n",
      "Comparing Model 15 and Model 32. Diff: 0.1333\n",
      "Comparing Model 15 and Model 33. Diff: 0.2067\n",
      "Comparing Model 15 and Model 34. Diff: 0.0867\n",
      "Comparing Model 15 and Model 35. Diff: 0.1267\n",
      "Comparing Model 15 and Model 36. Diff: 0.1867\n",
      "Comparing Model 15 and Model 37. Diff: 0.1733\n",
      "Comparing Model 15 and Model 38. Diff: 0.2133\n",
      "Comparing Model 15 and Model 39. Diff: 0.1667\n",
      "Comparing Model 15 and Model 40. Diff: 0.2133\n",
      "Comparing Model 15 and Model 41. Diff: 0.1333\n",
      "Comparing Model 15 and Model 42. Diff: 0.1800\n",
      "Comparing Model 15 and Model 43. Diff: 0.1533\n",
      "Comparing Model 15 and Model 44. Diff: 0.2133\n",
      "Comparing Model 15 and Model 45. Diff: 0.1533\n",
      "Comparing Model 15 and Model 46. Diff: 0.2067\n",
      "Comparing Model 15 and Model 47. Diff: 0.1200\n",
      "Comparing Model 15 and Model 48. Diff: 0.2000\n",
      "Comparing Model 15 and Model 49. Diff: 0.1467\n",
      "ith value is - 16\n",
      "Comparing Model 16 and Model 17. Diff: 0.0400\n",
      "Comparing Model 16 and Model 18. Diff: 0.0733\n",
      "Comparing Model 16 and Model 19. Diff: 0.0400\n",
      "Comparing Model 16 and Model 20. Diff: 0.0533\n",
      "Comparing Model 16 and Model 21. Diff: 0.2467\n",
      "Comparing Model 16 and Model 22. Diff: 0.1533\n",
      "Comparing Model 16 and Model 23. Diff: 0.0733\n",
      "Comparing Model 16 and Model 24. Diff: 0.0533\n",
      "Comparing Model 16 and Model 25. Diff: 0.0933\n",
      "Comparing Model 16 and Model 26. Diff: 0.0133\n",
      "Comparing Model 16 and Model 27. Diff: 0.0467\n",
      "Comparing Model 16 and Model 28. Diff: 0.0267\n",
      "Comparing Model 16 and Model 29. Diff: 0.0400\n",
      "Comparing Model 16 and Model 30. Diff: 0.0467\n",
      "Comparing Model 16 and Model 31. Diff: 0.0267\n",
      "Comparing Model 16 and Model 32. Diff: 0.0933\n",
      "Comparing Model 16 and Model 33. Diff: 0.0333\n",
      "Comparing Model 16 and Model 34. Diff: 0.1133\n",
      "Comparing Model 16 and Model 35. Diff: 0.0867\n",
      "Comparing Model 16 and Model 36. Diff: 0.1733\n",
      "Comparing Model 16 and Model 37. Diff: 0.0267\n",
      "Comparing Model 16 and Model 38. Diff: 0.0400\n",
      "Comparing Model 16 and Model 39. Diff: 0.0600\n",
      "Comparing Model 16 and Model 40. Diff: 0.0533\n",
      "Comparing Model 16 and Model 41. Diff: 0.0400\n",
      "Comparing Model 16 and Model 42. Diff: 0.0733\n",
      "Comparing Model 16 and Model 43. Diff: 0.0733\n",
      "Comparing Model 16 and Model 44. Diff: 0.0400\n",
      "Comparing Model 16 and Model 45. Diff: 0.0733\n",
      "Comparing Model 16 and Model 46. Diff: 0.0333\n",
      "Comparing Model 16 and Model 47. Diff: 0.0933\n",
      "Comparing Model 16 and Model 48. Diff: 0.0400\n",
      "Comparing Model 16 and Model 49. Diff: 0.1200\n",
      "ith value is - 17\n",
      "Comparing Model 17 and Model 18. Diff: 0.1000\n",
      "Comparing Model 17 and Model 19. Diff: 0.0800\n",
      "Comparing Model 17 and Model 20. Diff: 0.0267\n",
      "Comparing Model 17 and Model 21. Diff: 0.2467\n",
      "Comparing Model 17 and Model 22. Diff: 0.1667\n",
      "Comparing Model 17 and Model 23. Diff: 0.1000\n",
      "Comparing Model 17 and Model 24. Diff: 0.0533\n",
      "Comparing Model 17 and Model 25. Diff: 0.1200\n",
      "Comparing Model 17 and Model 26. Diff: 0.0400\n",
      "Comparing Model 17 and Model 27. Diff: 0.0467\n",
      "Comparing Model 17 and Model 28. Diff: 0.0667\n",
      "Comparing Model 17 and Model 29. Diff: 0.0267\n",
      "Comparing Model 17 and Model 30. Diff: 0.0067\n",
      "Comparing Model 17 and Model 31. Diff: 0.0533\n",
      "Comparing Model 17 and Model 32. Diff: 0.1200\n",
      "Comparing Model 17 and Model 33. Diff: 0.0333\n",
      "Comparing Model 17 and Model 34. Diff: 0.1400\n",
      "Comparing Model 17 and Model 35. Diff: 0.1000\n",
      "Comparing Model 17 and Model 36. Diff: 0.1867\n",
      "Comparing Model 17 and Model 37. Diff: 0.0667\n",
      "Comparing Model 17 and Model 38. Diff: 0.0400\n",
      "Comparing Model 17 and Model 39. Diff: 0.1000\n",
      "Comparing Model 17 and Model 40. Diff: 0.0400\n",
      "Comparing Model 17 and Model 41. Diff: 0.0667\n",
      "Comparing Model 17 and Model 42. Diff: 0.0600\n",
      "Comparing Model 17 and Model 43. Diff: 0.1000\n",
      "Comparing Model 17 and Model 44. Diff: 0.0400\n",
      "Comparing Model 17 and Model 45. Diff: 0.1000\n",
      "Comparing Model 17 and Model 46. Diff: 0.0333\n",
      "Comparing Model 17 and Model 47. Diff: 0.1200\n",
      "Comparing Model 17 and Model 48. Diff: 0.0400\n",
      "Comparing Model 17 and Model 49. Diff: 0.1200\n",
      "ith value is - 18\n",
      "Comparing Model 18 and Model 19. Diff: 0.0467\n",
      "Comparing Model 18 and Model 20. Diff: 0.1133\n",
      "Comparing Model 18 and Model 21. Diff: 0.2267\n",
      "Comparing Model 18 and Model 22. Diff: 0.1467\n",
      "Comparing Model 18 and Model 23. Diff: 0.0000\n",
      "Comparing Model 18 and Model 24. Diff: 0.0867\n",
      "Comparing Model 18 and Model 25. Diff: 0.0333\n",
      "Comparing Model 18 and Model 26. Diff: 0.0600\n",
      "Comparing Model 18 and Model 27. Diff: 0.1067\n",
      "Comparing Model 18 and Model 28. Diff: 0.0467\n",
      "Comparing Model 18 and Model 29. Diff: 0.1000\n",
      "Comparing Model 18 and Model 30. Diff: 0.1067\n",
      "Comparing Model 18 and Model 31. Diff: 0.0600\n",
      "Comparing Model 18 and Model 32. Diff: 0.0867\n",
      "Comparing Model 18 and Model 33. Diff: 0.1067\n",
      "Comparing Model 18 and Model 34. Diff: 0.1067\n",
      "Comparing Model 18 and Model 35. Diff: 0.0800\n",
      "Comparing Model 18 and Model 36. Diff: 0.1133\n",
      "Comparing Model 18 and Model 37. Diff: 0.0467\n",
      "Comparing Model 18 and Model 38. Diff: 0.1133\n",
      "Comparing Model 18 and Model 39. Diff: 0.0267\n",
      "Comparing Model 18 and Model 40. Diff: 0.1133\n",
      "Comparing Model 18 and Model 41. Diff: 0.0600\n",
      "Comparing Model 18 and Model 42. Diff: 0.0933\n",
      "Comparing Model 18 and Model 43. Diff: 0.0267\n",
      "Comparing Model 18 and Model 44. Diff: 0.1133\n",
      "Comparing Model 18 and Model 45. Diff: 0.0000\n",
      "Comparing Model 18 and Model 46. Diff: 0.1067\n",
      "Comparing Model 18 and Model 47. Diff: 0.0333\n",
      "Comparing Model 18 and Model 48. Diff: 0.1133\n",
      "Comparing Model 18 and Model 49. Diff: 0.0733\n",
      "ith value is - 19\n",
      "Comparing Model 19 and Model 20. Diff: 0.0933\n",
      "Comparing Model 19 and Model 21. Diff: 0.2467\n",
      "Comparing Model 19 and Model 22. Diff: 0.1533\n",
      "Comparing Model 19 and Model 23. Diff: 0.0467\n",
      "Comparing Model 19 and Model 24. Diff: 0.0800\n",
      "Comparing Model 19 and Model 25. Diff: 0.0667\n",
      "Comparing Model 19 and Model 26. Diff: 0.0533\n",
      "Comparing Model 19 and Model 27. Diff: 0.0867\n",
      "Comparing Model 19 and Model 28. Diff: 0.0133\n",
      "Comparing Model 19 and Model 29. Diff: 0.0800\n",
      "Comparing Model 19 and Model 30. Diff: 0.0867\n",
      "Comparing Model 19 and Model 31. Diff: 0.0533\n",
      "Comparing Model 19 and Model 32. Diff: 0.1067\n",
      "Comparing Model 19 and Model 33. Diff: 0.0733\n",
      "Comparing Model 19 and Model 34. Diff: 0.1267\n",
      "Comparing Model 19 and Model 35. Diff: 0.0867\n",
      "Comparing Model 19 and Model 36. Diff: 0.1333\n",
      "Comparing Model 19 and Model 37. Diff: 0.0133\n",
      "Comparing Model 19 and Model 38. Diff: 0.0800\n",
      "Comparing Model 19 and Model 39. Diff: 0.0200\n",
      "Comparing Model 19 and Model 40. Diff: 0.0933\n",
      "Comparing Model 19 and Model 41. Diff: 0.0667\n",
      "Comparing Model 19 and Model 42. Diff: 0.0733\n",
      "Comparing Model 19 and Model 43. Diff: 0.0333\n",
      "Comparing Model 19 and Model 44. Diff: 0.0800\n",
      "Comparing Model 19 and Model 45. Diff: 0.0467\n",
      "Comparing Model 19 and Model 46. Diff: 0.0600\n",
      "Comparing Model 19 and Model 47. Diff: 0.0667\n",
      "Comparing Model 19 and Model 48. Diff: 0.0667\n",
      "Comparing Model 19 and Model 49. Diff: 0.0933\n",
      "ith value is - 20\n",
      "Comparing Model 20 and Model 21. Diff: 0.2733\n",
      "************************************\n",
      "New best pair found: Models 20 and 21 with diff 0.2733\n",
      "************************************\n",
      "Comparing Model 20 and Model 22. Diff: 0.1933\n",
      "Comparing Model 20 and Model 23. Diff: 0.1133\n",
      "Comparing Model 20 and Model 24. Diff: 0.0667\n",
      "Comparing Model 20 and Model 25. Diff: 0.1333\n",
      "Comparing Model 20 and Model 26. Diff: 0.0533\n",
      "Comparing Model 20 and Model 27. Diff: 0.0467\n",
      "Comparing Model 20 and Model 28. Diff: 0.0800\n",
      "Comparing Model 20 and Model 29. Diff: 0.0133\n",
      "Comparing Model 20 and Model 30. Diff: 0.0200\n",
      "Comparing Model 20 and Model 31. Diff: 0.0667\n",
      "Comparing Model 20 and Model 32. Diff: 0.1333\n",
      "Comparing Model 20 and Model 33. Diff: 0.0200\n",
      "Comparing Model 20 and Model 34. Diff: 0.1533\n",
      "Comparing Model 20 and Model 35. Diff: 0.1133\n",
      "Comparing Model 20 and Model 36. Diff: 0.2000\n",
      "Comparing Model 20 and Model 37. Diff: 0.0800\n",
      "Comparing Model 20 and Model 38. Diff: 0.0267\n",
      "Comparing Model 20 and Model 39. Diff: 0.1133\n",
      "Comparing Model 20 and Model 40. Diff: 0.0267\n",
      "Comparing Model 20 and Model 41. Diff: 0.0800\n",
      "Comparing Model 20 and Model 42. Diff: 0.0867\n",
      "Comparing Model 20 and Model 43. Diff: 0.1133\n",
      "Comparing Model 20 and Model 44. Diff: 0.0267\n",
      "Comparing Model 20 and Model 45. Diff: 0.1133\n",
      "Comparing Model 20 and Model 46. Diff: 0.0333\n",
      "Comparing Model 20 and Model 47. Diff: 0.1333\n",
      "Comparing Model 20 and Model 48. Diff: 0.0400\n",
      "Comparing Model 20 and Model 49. Diff: 0.1467\n",
      "ith value is - 21\n",
      "Comparing Model 21 and Model 22. Diff: 0.1067\n",
      "Comparing Model 21 and Model 23. Diff: 0.2267\n",
      "Comparing Model 21 and Model 24. Diff: 0.2333\n",
      "Comparing Model 21 and Model 25. Diff: 0.1933\n",
      "Comparing Model 21 and Model 26. Diff: 0.2333\n",
      "Comparing Model 21 and Model 27. Diff: 0.2533\n",
      "Comparing Model 21 and Model 28. Diff: 0.2467\n",
      "Comparing Model 21 and Model 29. Diff: 0.2600\n",
      "Comparing Model 21 and Model 30. Diff: 0.2533\n",
      "Comparing Model 21 and Model 31. Diff: 0.2200\n",
      "Comparing Model 21 and Model 32. Diff: 0.2067\n",
      "Comparing Model 21 and Model 33. Diff: 0.2667\n",
      "Comparing Model 21 and Model 34. Diff: 0.1600\n",
      "Comparing Model 21 and Model 35. Diff: 0.2133\n",
      "Comparing Model 21 and Model 36. Diff: 0.1400\n",
      "Comparing Model 21 and Model 37. Diff: 0.2467\n",
      "Comparing Model 21 and Model 38. Diff: 0.2733\n",
      "Comparing Model 21 and Model 39. Diff: 0.2400\n",
      "Comparing Model 21 and Model 40. Diff: 0.2733\n",
      "Comparing Model 21 and Model 41. Diff: 0.2067\n",
      "Comparing Model 21 and Model 42. Diff: 0.2533\n",
      "Comparing Model 21 and Model 43. Diff: 0.2267\n",
      "Comparing Model 21 and Model 44. Diff: 0.2733\n",
      "Comparing Model 21 and Model 45. Diff: 0.2267\n",
      "Comparing Model 21 and Model 46. Diff: 0.2667\n",
      "Comparing Model 21 and Model 47. Diff: 0.1933\n",
      "Comparing Model 21 and Model 48. Diff: 0.2733\n",
      "Comparing Model 21 and Model 49. Diff: 0.2200\n",
      "ith value is - 22\n",
      "Comparing Model 22 and Model 23. Diff: 0.1467\n",
      "Comparing Model 22 and Model 24. Diff: 0.1533\n",
      "Comparing Model 22 and Model 25. Diff: 0.1133\n",
      "Comparing Model 22 and Model 26. Diff: 0.1533\n",
      "Comparing Model 22 and Model 27. Diff: 0.1867\n",
      "Comparing Model 22 and Model 28. Diff: 0.1533\n",
      "Comparing Model 22 and Model 29. Diff: 0.1800\n",
      "Comparing Model 22 and Model 30. Diff: 0.1733\n",
      "Comparing Model 22 and Model 31. Diff: 0.1400\n",
      "Comparing Model 22 and Model 32. Diff: 0.1267\n",
      "Comparing Model 22 and Model 33. Diff: 0.1733\n",
      "Comparing Model 22 and Model 34. Diff: 0.0933\n",
      "Comparing Model 22 and Model 35. Diff: 0.1467\n",
      "Comparing Model 22 and Model 36. Diff: 0.1800\n",
      "Comparing Model 22 and Model 37. Diff: 0.1533\n",
      "Comparing Model 22 and Model 38. Diff: 0.1800\n",
      "Comparing Model 22 and Model 39. Diff: 0.1467\n",
      "Comparing Model 22 and Model 40. Diff: 0.1933\n",
      "Comparing Model 22 and Model 41. Diff: 0.1267\n",
      "Comparing Model 22 and Model 42. Diff: 0.1600\n",
      "Comparing Model 22 and Model 43. Diff: 0.1467\n",
      "Comparing Model 22 and Model 44. Diff: 0.1800\n",
      "Comparing Model 22 and Model 45. Diff: 0.1467\n",
      "Comparing Model 22 and Model 46. Diff: 0.1733\n",
      "Comparing Model 22 and Model 47. Diff: 0.1133\n",
      "Comparing Model 22 and Model 48. Diff: 0.1667\n",
      "Comparing Model 22 and Model 49. Diff: 0.1533\n",
      "ith value is - 23\n",
      "Comparing Model 23 and Model 24. Diff: 0.0867\n",
      "Comparing Model 23 and Model 25. Diff: 0.0333\n",
      "Comparing Model 23 and Model 26. Diff: 0.0600\n",
      "Comparing Model 23 and Model 27. Diff: 0.1067\n",
      "Comparing Model 23 and Model 28. Diff: 0.0467\n",
      "Comparing Model 23 and Model 29. Diff: 0.1000\n",
      "Comparing Model 23 and Model 30. Diff: 0.1067\n",
      "Comparing Model 23 and Model 31. Diff: 0.0600\n",
      "Comparing Model 23 and Model 32. Diff: 0.0867\n",
      "Comparing Model 23 and Model 33. Diff: 0.1067\n",
      "Comparing Model 23 and Model 34. Diff: 0.1067\n",
      "Comparing Model 23 and Model 35. Diff: 0.0800\n",
      "Comparing Model 23 and Model 36. Diff: 0.1133\n",
      "Comparing Model 23 and Model 37. Diff: 0.0467\n",
      "Comparing Model 23 and Model 38. Diff: 0.1133\n",
      "Comparing Model 23 and Model 39. Diff: 0.0267\n",
      "Comparing Model 23 and Model 40. Diff: 0.1133\n",
      "Comparing Model 23 and Model 41. Diff: 0.0600\n",
      "Comparing Model 23 and Model 42. Diff: 0.0933\n",
      "Comparing Model 23 and Model 43. Diff: 0.0267\n",
      "Comparing Model 23 and Model 44. Diff: 0.1133\n",
      "Comparing Model 23 and Model 45. Diff: 0.0000\n",
      "Comparing Model 23 and Model 46. Diff: 0.1067\n",
      "Comparing Model 23 and Model 47. Diff: 0.0333\n",
      "Comparing Model 23 and Model 48. Diff: 0.1133\n",
      "Comparing Model 23 and Model 49. Diff: 0.0733\n",
      "ith value is - 24\n",
      "Comparing Model 24 and Model 25. Diff: 0.1067\n",
      "Comparing Model 24 and Model 26. Diff: 0.0400\n",
      "Comparing Model 24 and Model 27. Diff: 0.0733\n",
      "Comparing Model 24 and Model 28. Diff: 0.0667\n",
      "Comparing Model 24 and Model 29. Diff: 0.0533\n",
      "Comparing Model 24 and Model 30. Diff: 0.0600\n",
      "Comparing Model 24 and Model 31. Diff: 0.0400\n",
      "Comparing Model 24 and Model 32. Diff: 0.1067\n",
      "Comparing Model 24 and Model 33. Diff: 0.0600\n",
      "Comparing Model 24 and Model 34. Diff: 0.1267\n",
      "Comparing Model 24 and Model 35. Diff: 0.0467\n",
      "Comparing Model 24 and Model 36. Diff: 0.1867\n",
      "Comparing Model 24 and Model 37. Diff: 0.0667\n",
      "Comparing Model 24 and Model 38. Diff: 0.0667\n",
      "Comparing Model 24 and Model 39. Diff: 0.0867\n",
      "Comparing Model 24 and Model 40. Diff: 0.0667\n",
      "Comparing Model 24 and Model 41. Diff: 0.0533\n",
      "Comparing Model 24 and Model 42. Diff: 0.0600\n",
      "Comparing Model 24 and Model 43. Diff: 0.0867\n",
      "Comparing Model 24 and Model 44. Diff: 0.0667\n",
      "Comparing Model 24 and Model 45. Diff: 0.0867\n",
      "Comparing Model 24 and Model 46. Diff: 0.0600\n",
      "Comparing Model 24 and Model 47. Diff: 0.1067\n",
      "Comparing Model 24 and Model 48. Diff: 0.0533\n",
      "Comparing Model 24 and Model 49. Diff: 0.0933\n",
      "ith value is - 25\n",
      "Comparing Model 25 and Model 26. Diff: 0.0800\n",
      "Comparing Model 25 and Model 27. Diff: 0.1267\n",
      "Comparing Model 25 and Model 28. Diff: 0.0667\n",
      "Comparing Model 25 and Model 29. Diff: 0.1200\n",
      "Comparing Model 25 and Model 30. Diff: 0.1267\n",
      "Comparing Model 25 and Model 31. Diff: 0.0800\n",
      "Comparing Model 25 and Model 32. Diff: 0.0800\n",
      "Comparing Model 25 and Model 33. Diff: 0.1267\n",
      "Comparing Model 25 and Model 34. Diff: 0.1400\n",
      "Comparing Model 25 and Model 35. Diff: 0.0733\n",
      "Comparing Model 25 and Model 36. Diff: 0.0800\n",
      "Comparing Model 25 and Model 37. Diff: 0.0667\n",
      "Comparing Model 25 and Model 38. Diff: 0.1333\n",
      "Comparing Model 25 and Model 39. Diff: 0.0467\n",
      "Comparing Model 25 and Model 40. Diff: 0.1333\n",
      "Comparing Model 25 and Model 41. Diff: 0.0800\n",
      "Comparing Model 25 and Model 42. Diff: 0.1000\n",
      "Comparing Model 25 and Model 43. Diff: 0.0333\n",
      "Comparing Model 25 and Model 44. Diff: 0.1333\n",
      "Comparing Model 25 and Model 45. Diff: 0.0333\n",
      "Comparing Model 25 and Model 46. Diff: 0.1267\n",
      "Comparing Model 25 and Model 47. Diff: 0.0000\n",
      "Comparing Model 25 and Model 48. Diff: 0.1333\n",
      "Comparing Model 25 and Model 49. Diff: 0.0800\n",
      "ith value is - 26\n",
      "Comparing Model 26 and Model 27. Diff: 0.0467\n",
      "Comparing Model 26 and Model 28. Diff: 0.0400\n",
      "Comparing Model 26 and Model 29. Diff: 0.0400\n",
      "Comparing Model 26 and Model 30. Diff: 0.0467\n",
      "Comparing Model 26 and Model 31. Diff: 0.0133\n",
      "Comparing Model 26 and Model 32. Diff: 0.0800\n",
      "Comparing Model 26 and Model 33. Diff: 0.0467\n",
      "Comparing Model 26 and Model 34. Diff: 0.1000\n",
      "Comparing Model 26 and Model 35. Diff: 0.0733\n",
      "Comparing Model 26 and Model 36. Diff: 0.1600\n",
      "Comparing Model 26 and Model 37. Diff: 0.0400\n",
      "Comparing Model 26 and Model 38. Diff: 0.0533\n",
      "Comparing Model 26 and Model 39. Diff: 0.0600\n",
      "Comparing Model 26 and Model 40. Diff: 0.0533\n",
      "Comparing Model 26 and Model 41. Diff: 0.0267\n",
      "Comparing Model 26 and Model 42. Diff: 0.0733\n",
      "Comparing Model 26 and Model 43. Diff: 0.0600\n",
      "Comparing Model 26 and Model 44. Diff: 0.0533\n",
      "Comparing Model 26 and Model 45. Diff: 0.0600\n",
      "Comparing Model 26 and Model 46. Diff: 0.0467\n",
      "Comparing Model 26 and Model 47. Diff: 0.0800\n",
      "Comparing Model 26 and Model 48. Diff: 0.0533\n",
      "Comparing Model 26 and Model 49. Diff: 0.1067\n",
      "ith value is - 27\n",
      "Comparing Model 27 and Model 28. Diff: 0.0733\n",
      "Comparing Model 27 and Model 29. Diff: 0.0333\n",
      "Comparing Model 27 and Model 30. Diff: 0.0533\n",
      "Comparing Model 27 and Model 31. Diff: 0.0467\n",
      "Comparing Model 27 and Model 32. Diff: 0.1000\n",
      "Comparing Model 27 and Model 33. Diff: 0.0400\n",
      "Comparing Model 27 and Model 34. Diff: 0.1067\n",
      "Comparing Model 27 and Model 35. Diff: 0.0933\n",
      "Comparing Model 27 and Model 36. Diff: 0.2067\n",
      "Comparing Model 27 and Model 37. Diff: 0.0733\n",
      "Comparing Model 27 and Model 38. Diff: 0.0467\n",
      "Comparing Model 27 and Model 39. Diff: 0.1067\n",
      "Comparing Model 27 and Model 40. Diff: 0.0467\n",
      "Comparing Model 27 and Model 41. Diff: 0.0600\n",
      "Comparing Model 27 and Model 42. Diff: 0.0933\n",
      "Comparing Model 27 and Model 43. Diff: 0.1067\n",
      "Comparing Model 27 and Model 44. Diff: 0.0467\n",
      "Comparing Model 27 and Model 45. Diff: 0.1067\n",
      "Comparing Model 27 and Model 46. Diff: 0.0533\n",
      "Comparing Model 27 and Model 47. Diff: 0.1267\n",
      "Comparing Model 27 and Model 48. Diff: 0.0600\n",
      "Comparing Model 27 and Model 49. Diff: 0.1400\n",
      "ith value is - 28\n",
      "Comparing Model 28 and Model 29. Diff: 0.0667\n",
      "Comparing Model 28 and Model 30. Diff: 0.0733\n",
      "Comparing Model 28 and Model 31. Diff: 0.0400\n",
      "Comparing Model 28 and Model 32. Diff: 0.0933\n",
      "Comparing Model 28 and Model 33. Diff: 0.0600\n",
      "Comparing Model 28 and Model 34. Diff: 0.1133\n",
      "Comparing Model 28 and Model 35. Diff: 0.0867\n",
      "Comparing Model 28 and Model 36. Diff: 0.1467\n",
      "Comparing Model 28 and Model 37. Diff: 0.0000\n",
      "Comparing Model 28 and Model 38. Diff: 0.0667\n",
      "Comparing Model 28 and Model 39. Diff: 0.0333\n",
      "Comparing Model 28 and Model 40. Diff: 0.0800\n",
      "Comparing Model 28 and Model 41. Diff: 0.0533\n",
      "Comparing Model 28 and Model 42. Diff: 0.0733\n",
      "Comparing Model 28 and Model 43. Diff: 0.0467\n",
      "Comparing Model 28 and Model 44. Diff: 0.0667\n",
      "Comparing Model 28 and Model 45. Diff: 0.0467\n",
      "Comparing Model 28 and Model 46. Diff: 0.0600\n",
      "Comparing Model 28 and Model 47. Diff: 0.0667\n",
      "Comparing Model 28 and Model 48. Diff: 0.0667\n",
      "Comparing Model 28 and Model 49. Diff: 0.1067\n",
      "ith value is - 29\n",
      "Comparing Model 29 and Model 30. Diff: 0.0200\n",
      "Comparing Model 29 and Model 31. Diff: 0.0533\n",
      "Comparing Model 29 and Model 32. Diff: 0.1200\n",
      "Comparing Model 29 and Model 33. Diff: 0.0067\n",
      "Comparing Model 29 and Model 34. Diff: 0.1400\n",
      "Comparing Model 29 and Model 35. Diff: 0.1000\n",
      "Comparing Model 29 and Model 36. Diff: 0.1867\n",
      "Comparing Model 29 and Model 37. Diff: 0.0667\n",
      "Comparing Model 29 and Model 38. Diff: 0.0133\n",
      "Comparing Model 29 and Model 39. Diff: 0.1000\n",
      "Comparing Model 29 and Model 40. Diff: 0.0133\n",
      "Comparing Model 29 and Model 41. Diff: 0.0667\n",
      "Comparing Model 29 and Model 42. Diff: 0.0733\n",
      "Comparing Model 29 and Model 43. Diff: 0.1000\n",
      "Comparing Model 29 and Model 44. Diff: 0.0133\n",
      "Comparing Model 29 and Model 45. Diff: 0.1000\n",
      "Comparing Model 29 and Model 46. Diff: 0.0200\n",
      "Comparing Model 29 and Model 47. Diff: 0.1200\n",
      "Comparing Model 29 and Model 48. Diff: 0.0267\n",
      "Comparing Model 29 and Model 49. Diff: 0.1333\n",
      "ith value is - 30\n",
      "Comparing Model 30 and Model 31. Diff: 0.0600\n",
      "Comparing Model 30 and Model 32. Diff: 0.1267\n",
      "Comparing Model 30 and Model 33. Diff: 0.0267\n",
      "Comparing Model 30 and Model 34. Diff: 0.1467\n",
      "Comparing Model 30 and Model 35. Diff: 0.1067\n",
      "Comparing Model 30 and Model 36. Diff: 0.1800\n",
      "Comparing Model 30 and Model 37. Diff: 0.0733\n",
      "Comparing Model 30 and Model 38. Diff: 0.0333\n",
      "Comparing Model 30 and Model 39. Diff: 0.1067\n",
      "Comparing Model 30 and Model 40. Diff: 0.0333\n",
      "Comparing Model 30 and Model 41. Diff: 0.0733\n",
      "Comparing Model 30 and Model 42. Diff: 0.0667\n",
      "Comparing Model 30 and Model 43. Diff: 0.1067\n",
      "Comparing Model 30 and Model 44. Diff: 0.0333\n",
      "Comparing Model 30 and Model 45. Diff: 0.1067\n",
      "Comparing Model 30 and Model 46. Diff: 0.0267\n",
      "Comparing Model 30 and Model 47. Diff: 0.1267\n",
      "Comparing Model 30 and Model 48. Diff: 0.0333\n",
      "Comparing Model 30 and Model 49. Diff: 0.1267\n",
      "ith value is - 31\n",
      "Comparing Model 31 and Model 32. Diff: 0.0667\n",
      "Comparing Model 31 and Model 33. Diff: 0.0600\n",
      "Comparing Model 31 and Model 34. Diff: 0.0867\n",
      "Comparing Model 31 and Model 35. Diff: 0.0733\n",
      "Comparing Model 31 and Model 36. Diff: 0.1600\n",
      "Comparing Model 31 and Model 37. Diff: 0.0400\n",
      "Comparing Model 31 and Model 38. Diff: 0.0667\n",
      "Comparing Model 31 and Model 39. Diff: 0.0600\n",
      "Comparing Model 31 and Model 40. Diff: 0.0667\n",
      "Comparing Model 31 and Model 41. Diff: 0.0133\n",
      "Comparing Model 31 and Model 42. Diff: 0.0733\n",
      "Comparing Model 31 and Model 43. Diff: 0.0600\n",
      "Comparing Model 31 and Model 44. Diff: 0.0667\n",
      "Comparing Model 31 and Model 45. Diff: 0.0600\n",
      "Comparing Model 31 and Model 46. Diff: 0.0600\n",
      "Comparing Model 31 and Model 47. Diff: 0.0800\n",
      "Comparing Model 31 and Model 48. Diff: 0.0667\n",
      "Comparing Model 31 and Model 49. Diff: 0.1067\n",
      "ith value is - 32\n",
      "Comparing Model 32 and Model 33. Diff: 0.1267\n",
      "Comparing Model 32 and Model 34. Diff: 0.1000\n",
      "Comparing Model 32 and Model 35. Diff: 0.1000\n",
      "Comparing Model 32 and Model 36. Diff: 0.1600\n",
      "Comparing Model 32 and Model 37. Diff: 0.0933\n",
      "Comparing Model 32 and Model 38. Diff: 0.1333\n",
      "Comparing Model 32 and Model 39. Diff: 0.1133\n",
      "Comparing Model 32 and Model 40. Diff: 0.1333\n",
      "Comparing Model 32 and Model 41. Diff: 0.0533\n",
      "Comparing Model 32 and Model 42. Diff: 0.1400\n",
      "Comparing Model 32 and Model 43. Diff: 0.1133\n",
      "Comparing Model 32 and Model 44. Diff: 0.1333\n",
      "Comparing Model 32 and Model 45. Diff: 0.0867\n",
      "Comparing Model 32 and Model 46. Diff: 0.1267\n",
      "Comparing Model 32 and Model 47. Diff: 0.0800\n",
      "Comparing Model 32 and Model 48. Diff: 0.1333\n",
      "Comparing Model 32 and Model 49. Diff: 0.1067\n",
      "ith value is - 33\n",
      "Comparing Model 33 and Model 34. Diff: 0.1467\n",
      "Comparing Model 33 and Model 35. Diff: 0.1067\n",
      "Comparing Model 33 and Model 36. Diff: 0.1933\n",
      "Comparing Model 33 and Model 37. Diff: 0.0600\n",
      "Comparing Model 33 and Model 38. Diff: 0.0067\n",
      "Comparing Model 33 and Model 39. Diff: 0.0933\n",
      "Comparing Model 33 and Model 40. Diff: 0.0200\n",
      "Comparing Model 33 and Model 41. Diff: 0.0733\n",
      "Comparing Model 33 and Model 42. Diff: 0.0800\n",
      "Comparing Model 33 and Model 43. Diff: 0.1067\n",
      "Comparing Model 33 and Model 44. Diff: 0.0067\n",
      "Comparing Model 33 and Model 45. Diff: 0.1067\n",
      "Comparing Model 33 and Model 46. Diff: 0.0133\n",
      "Comparing Model 33 and Model 47. Diff: 0.1267\n",
      "Comparing Model 33 and Model 48. Diff: 0.0200\n",
      "Comparing Model 33 and Model 49. Diff: 0.1400\n",
      "ith value is - 34\n",
      "Comparing Model 34 and Model 35. Diff: 0.1333\n",
      "Comparing Model 34 and Model 36. Diff: 0.2200\n",
      "Comparing Model 34 and Model 37. Diff: 0.1133\n",
      "Comparing Model 34 and Model 38. Diff: 0.1533\n",
      "Comparing Model 34 and Model 39. Diff: 0.1333\n",
      "Comparing Model 34 and Model 40. Diff: 0.1533\n",
      "Comparing Model 34 and Model 41. Diff: 0.0867\n",
      "Comparing Model 34 and Model 42. Diff: 0.1600\n",
      "Comparing Model 34 and Model 43. Diff: 0.1333\n",
      "Comparing Model 34 and Model 44. Diff: 0.1533\n",
      "Comparing Model 34 and Model 45. Diff: 0.1067\n",
      "Comparing Model 34 and Model 46. Diff: 0.1467\n",
      "Comparing Model 34 and Model 47. Diff: 0.1400\n",
      "Comparing Model 34 and Model 48. Diff: 0.1533\n",
      "Comparing Model 34 and Model 49. Diff: 0.1667\n",
      "ith value is - 35\n",
      "Comparing Model 35 and Model 36. Diff: 0.1533\n",
      "Comparing Model 35 and Model 37. Diff: 0.0867\n",
      "Comparing Model 35 and Model 38. Diff: 0.1133\n",
      "Comparing Model 35 and Model 39. Diff: 0.0800\n",
      "Comparing Model 35 and Model 40. Diff: 0.1133\n",
      "Comparing Model 35 and Model 41. Diff: 0.0867\n",
      "Comparing Model 35 and Model 42. Diff: 0.0933\n",
      "Comparing Model 35 and Model 43. Diff: 0.0800\n",
      "Comparing Model 35 and Model 44. Diff: 0.1133\n",
      "Comparing Model 35 and Model 45. Diff: 0.0800\n",
      "Comparing Model 35 and Model 46. Diff: 0.1067\n",
      "Comparing Model 35 and Model 47. Diff: 0.0733\n",
      "Comparing Model 35 and Model 48. Diff: 0.1000\n",
      "Comparing Model 35 and Model 49. Diff: 0.0600\n",
      "ith value is - 36\n",
      "Comparing Model 36 and Model 37. Diff: 0.1467\n",
      "Comparing Model 36 and Model 38. Diff: 0.2000\n",
      "Comparing Model 36 and Model 39. Diff: 0.1133\n",
      "Comparing Model 36 and Model 40. Diff: 0.2000\n",
      "Comparing Model 36 and Model 41. Diff: 0.1600\n",
      "Comparing Model 36 and Model 42. Diff: 0.1533\n",
      "Comparing Model 36 and Model 43. Diff: 0.1000\n",
      "Comparing Model 36 and Model 44. Diff: 0.2000\n",
      "Comparing Model 36 and Model 45. Diff: 0.1133\n",
      "Comparing Model 36 and Model 46. Diff: 0.1800\n",
      "Comparing Model 36 and Model 47. Diff: 0.0800\n",
      "Comparing Model 36 and Model 48. Diff: 0.1867\n",
      "Comparing Model 36 and Model 49. Diff: 0.1333\n",
      "ith value is - 37\n",
      "Comparing Model 37 and Model 38. Diff: 0.0667\n",
      "Comparing Model 37 and Model 39. Diff: 0.0333\n",
      "Comparing Model 37 and Model 40. Diff: 0.0800\n",
      "Comparing Model 37 and Model 41. Diff: 0.0533\n",
      "Comparing Model 37 and Model 42. Diff: 0.0733\n",
      "Comparing Model 37 and Model 43. Diff: 0.0467\n",
      "Comparing Model 37 and Model 44. Diff: 0.0667\n",
      "Comparing Model 37 and Model 45. Diff: 0.0467\n",
      "Comparing Model 37 and Model 46. Diff: 0.0600\n",
      "Comparing Model 37 and Model 47. Diff: 0.0667\n",
      "Comparing Model 37 and Model 48. Diff: 0.0667\n",
      "Comparing Model 37 and Model 49. Diff: 0.1067\n",
      "ith value is - 38\n",
      "Comparing Model 38 and Model 39. Diff: 0.1000\n",
      "Comparing Model 38 and Model 40. Diff: 0.0267\n",
      "Comparing Model 38 and Model 41. Diff: 0.0800\n",
      "Comparing Model 38 and Model 42. Diff: 0.0867\n",
      "Comparing Model 38 and Model 43. Diff: 0.1133\n",
      "Comparing Model 38 and Model 44. Diff: 0.0133\n",
      "Comparing Model 38 and Model 45. Diff: 0.1133\n",
      "Comparing Model 38 and Model 46. Diff: 0.0200\n",
      "Comparing Model 38 and Model 47. Diff: 0.1333\n",
      "Comparing Model 38 and Model 48. Diff: 0.0267\n",
      "Comparing Model 38 and Model 49. Diff: 0.1467\n",
      "ith value is - 39\n",
      "Comparing Model 39 and Model 40. Diff: 0.1133\n",
      "Comparing Model 39 and Model 41. Diff: 0.0733\n",
      "Comparing Model 39 and Model 42. Diff: 0.0800\n",
      "Comparing Model 39 and Model 43. Diff: 0.0133\n",
      "Comparing Model 39 and Model 44. Diff: 0.1000\n",
      "Comparing Model 39 and Model 45. Diff: 0.0267\n",
      "Comparing Model 39 and Model 46. Diff: 0.0800\n",
      "Comparing Model 39 and Model 47. Diff: 0.0467\n",
      "Comparing Model 39 and Model 48. Diff: 0.0867\n",
      "Comparing Model 39 and Model 49. Diff: 0.0733\n",
      "ith value is - 40\n",
      "Comparing Model 40 and Model 41. Diff: 0.0800\n",
      "Comparing Model 40 and Model 42. Diff: 0.0867\n",
      "Comparing Model 40 and Model 43. Diff: 0.1133\n",
      "Comparing Model 40 and Model 44. Diff: 0.0267\n",
      "Comparing Model 40 and Model 45. Diff: 0.1133\n",
      "Comparing Model 40 and Model 46. Diff: 0.0333\n",
      "Comparing Model 40 and Model 47. Diff: 0.1333\n",
      "Comparing Model 40 and Model 48. Diff: 0.0400\n",
      "Comparing Model 40 and Model 49. Diff: 0.1467\n",
      "ith value is - 41\n",
      "Comparing Model 41 and Model 42. Diff: 0.0867\n",
      "Comparing Model 41 and Model 43. Diff: 0.0733\n",
      "Comparing Model 41 and Model 44. Diff: 0.0800\n",
      "Comparing Model 41 and Model 45. Diff: 0.0600\n",
      "Comparing Model 41 and Model 46. Diff: 0.0733\n",
      "Comparing Model 41 and Model 47. Diff: 0.0800\n",
      "Comparing Model 41 and Model 48. Diff: 0.0800\n",
      "Comparing Model 41 and Model 49. Diff: 0.1067\n",
      "ith value is - 42\n",
      "Comparing Model 42 and Model 43. Diff: 0.0667\n",
      "Comparing Model 42 and Model 44. Diff: 0.0867\n"
     ]
    }
   ],
   "source": [
    "best_pair, best_diff = find_best_model_pair(all_knns, X_test_scaled_df)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b00b7592-1329-4ef7-83a3-aaa8658d506b",
   "metadata": {},
   "outputs": [],
   "source": [
    "model1, model2 = best_pair"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9077d3ed-bc11-4ff7-bdb9-82439a985c16",
   "metadata": {},
   "outputs": [],
   "source": [
    "model2, model1 = best_pair"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a7aa62ed-2203-49ab-b6f0-87f6ab2049aa",
   "metadata": {},
   "outputs": [],
   "source": [
    "# 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": "dba9bf5b-0b57-4456-ac25-bcccafe00d22",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "id": "9ea03138-8060-44ec-80ba-72d49272ec80",
   "metadata": {},
   "source": [
    "**Evaluate Both Models**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6e595955-68c6-41b3-8b0e-051de7cf86ba",
   "metadata": {},
   "outputs": [],
   "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\")\n",
    "print(\"Model 1 accuracy:\", accuracy1)\n",
    "print(f\"\\nModel 2:\")\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.get_params())\n",
    "print(model2.get_params())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "170339e7-d051-4934-9bbf-30ae482fd8cf",
   "metadata": {},
   "outputs": [],
   "source": [
    "nearest_neighbours_plot(model1, X_train_scaled_df, y_train, X_test_scaled_df, y_pred_1, 23)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "938c2dc6-cc5a-4492-ae6b-e8e5f2dfb2bf",
   "metadata": {},
   "outputs": [],
   "source": [
    "nearest_neighbours_plot(model2, X_train_scaled_df, y_train, X_test_scaled_df, y_pred_2, 23)"
   ]
  },
  {
   "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": null,
   "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('KNN 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": null,
   "id": "de4db779-ea88-4543-944d-46c15b3e31de",
   "metadata": {},
   "outputs": [],
   "source": [
    "plot_decision_boundary(X_test_scaled_df, y_pred_1, \"Recency (months)\", \"Frequency (times)\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "599fcca1-20b3-4b16-89c4-4fba23c314ce",
   "metadata": {},
   "source": [
    "**Model 2 Decision Boundary**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bff87fe6-d656-416c-88a7-47fd6d503a63",
   "metadata": {},
   "outputs": [],
   "source": [
    "plot_decision_boundary(X_test_scaled_df, y_pred_2, \"Recency (months)\", \"Frequency (times)\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6f04be47-b214-4aa2-a035-57987b4684ae",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "id": "868a325f-d81b-48b4-85a8-5c7f7fc7c201",
   "metadata": {},
   "source": [
    "**Preparing Detailed Data For Ablation Study**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6cbdfedb",
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_knn_details(knn_model, X_train, y_train, X_test, for_gen=False):\n",
    "    if not hasattr(knn_model, 'classes_'):\n",
    "        raise ValueError(\"The KNN model is not fitted. Please fit the model before using this function.\")\n",
    "    \n",
    "    # Get the number of neighbors (k) from the model\n",
    "    k = knn_model.n_neighbors\n",
    "    \n",
    "    result = []\n",
    "    \n",
    "    # Loop through each row in the testing dataset\n",
    "    for _, test_row in X_test.iterrows():\n",
    "        distances, indices = knn_model.kneighbors([test_row], n_neighbors=k)\n",
    "        predicted_output = knn_model.predict([test_row])[0]\n",
    "        \n",
    "        nearest_neighbors = []\n",
    "        for distance, index in zip(distances[0], indices[0]):\n",
    "            neighbor_details = {\n",
    "                \"feature_values\": X_train.iloc[index].tolist(),\n",
    "                \"assigned_class\": int(y_train.iloc[index]),\n",
    "                \"distance\": float(distance)\n",
    "            }\n",
    "            nearest_neighbors.append(neighbor_details)\n",
    "        \n",
    "        # Add k random data points if for_gen is True\n",
    "        if for_gen:\n",
    "            random_indices = np.random.choice(len(X_train), k, replace=False)\n",
    "            for index in random_indices:\n",
    "                random_point_details = {\n",
    "                    \"feature_values\": X_train.iloc[index].tolist(),\n",
    "                    \"assigned_class\": int(y_train.iloc[index]),\n",
    "                    \"distance\": None  # Random data points don't have a distance\n",
    "                }\n",
    "                nearest_neighbors.append(random_point_details)\n",
    "        \n",
    "        # Add the details to the result dictionary\n",
    "        result.append({\n",
    "            \"input\": test_row.tolist(),\n",
    "            \"output\": int(predicted_output),\n",
    "            \"nearest_neighbors\": nearest_neighbors\n",
    "        })\n",
    "        \n",
    "    return result"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b8dc1f25-f56a-47df-9d75-e364be498870",
   "metadata": {},
   "outputs": [],
   "source": [
    "model1_details_verb = get_knn_details(model1, X_train_scaled_df, y_train, X_test_scaled_df)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "15784e34-dd83-42e1-b7ae-7f0c61de0a13",
   "metadata": {},
   "outputs": [],
   "source": [
    "model2_details_verb = get_knn_details(model2, X_train_scaled_df, y_train, X_test_scaled_df)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ffff2030-daf8-439c-8c2f-d759d7d1e9d6",
   "metadata": {},
   "outputs": [],
   "source": [
    "model1_details_gen = get_knn_details(model1, X_train_scaled_df, y_train, X_test_gen_scaled_df, for_gen=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "49d011df-c937-4922-ba06-e6c35182442c",
   "metadata": {},
   "outputs": [],
   "source": [
    "model2_details_gen = get_knn_details(model2, X_train_scaled_df, y_train, X_test_gen_scaled_df, for_gen=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "134416e9-8e03-4c14-bfc5-d08ec5a45df4",
   "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": "5971118d-84e4-4688-890b-9f570e4666b4",
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_combined_details(model1_details, model2_details):\n",
    "    combined_details = []\n",
    "    for m1, m2 in zip(model1_details, model2_details):\n",
    "        if m1['input'] == m2['input']:\n",
    "            rounded_input = round_values(m1['input'])\n",
    "            rounded_nn1 = round_values(m1['nearest_neighbors'])\n",
    "            rounded_nn2 = round_values(m2['nearest_neighbors'])\n",
    "\n",
    "            combined_entry = {\n",
    "                \"input\": rounded_input,\n",
    "                \"model1\": {\n",
    "                    \"output\": m1['output'],\n",
    "                    \"nearest_neighbors\": rounded_nn1\n",
    "                },\n",
    "                \"model2\": {\n",
    "                    \"output\": m2['output'],\n",
    "                    \"nearest_neighbors\": rounded_nn2\n",
    "                }\n",
    "            }\n",
    "\n",
    "            combined_details.append(combined_entry)\n",
    "    return combined_details"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a6c2fd97-2cfe-4ae8-a098-07065adb8303",
   "metadata": {},
   "outputs": [],
   "source": [
    "combined_details_verb = get_combined_details(model1_details_verb, model2_details_verb)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b4535fa8-bbbf-48a6-a1f7-fe16d04f0e86",
   "metadata": {},
   "outputs": [],
   "source": [
    "combined_details_gen = get_combined_details(model1_details_gen, model2_details_gen)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "457066ab",
   "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_1.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)}\")\n",
    "np.where(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": [
    "verb_data_second = [{\"input\": i['input'], \"output\": {\"model1\": i[\"model1\"][\"output\"], \"model2\": i[\"model2\"][\"output\"]}} for i in combined_details_verb]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ba2e31c9-b037-4a66-8d9f-b17fd97e02cf",
   "metadata": {},
   "outputs": [],
   "source": [
    "verb_data == verb_data_second"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8444496e-6189-430b-bd90-5ff71426534c",
   "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": "ca8a8550-1c56-4a9b-b73a-0d24e3c318fd",
   "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": "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": [
    "def write_structures(structure_text, file_name, varname):\n",
    "    datastr = f\"\\n{varname} = {structure_text}\"\n",
    "    \n",
    "    # write this string to the file\n",
    "    with open(file_name, 'a') as file:\n",
    "        file.write(datastr)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1ffcfa7d-c895-42f0-bee6-dec69c44e339",
   "metadata": {},
   "outputs": [],
   "source": [
    "STRUCTURES_FILE_NAME = \"./../structures/blood/level_1.py\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "59b12448-1adf-43a5-bdad-c3b85be3fcc1",
   "metadata": {},
   "outputs": [],
   "source": [
    "write_structures(combined_details_verb, STRUCTURES_FILE_NAME, \"combined_details_verb\")\n",
    "write_structures(combined_details_gen, STRUCTURES_FILE_NAME, \"combined_details_gen\")"
   ]
  },
  {
   "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": "432aac87-4b82-4366-8b72-6b1c2951d782",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "79f05dff-21c8-4b96-93ed-534230524c65",
   "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": null,
   "id": "473a513b-6dea-497a-b710-5345bfb2a264",
   "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": "9e6a9ebd-fc67-4823-9f8c-b9e79ec94b4d",
   "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": "067d9623-2ef6-4253-a6a8-515e2ec355a2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "11eaf5cb-3c36-4760-9e38-21725f728e67",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d9d4cd0b-c7dc-4063-a4bd-c37338661d12",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Function to round data and analyze variance\n",
    "def analyze_precision(df, column, decimal_places):\n",
    "    results = []\n",
    "    for decimals in decimal_places:\n",
    "        df_rounded = df.copy()\n",
    "        df_rounded[column] = df_rounded[column].round(decimals)\n",
    "        variance = df_rounded[column].var()\n",
    "        results.append((decimals, variance))\n",
    "    return pd.DataFrame(results, columns=['Decimals', 'Variance'])\n",
    "\n",
    "# Analyze precision from 0 to 5 decimal places\n",
    "precision_analysis_1 = analyze_precision(X_train_scaled_df, 'Recency (months)', range(7))\n",
    "precision_analysis_2 = analyze_precision(X_train_scaled_df, 'Frequency (times)', range(7))\n",
    "precision_analysis_3 = analyze_precision(X_train_scaled_df, 'Monetary (c.c. blood)', range(7))\n",
    "precision_analysis_4 = analyze_precision(X_train_scaled_df, 'Time (months)', range(7))\n",
    "\n",
    "print(precision_analysis_1)\n",
    "print(precision_analysis_2)\n",
    "print(precision_analysis_3)\n",
    "print(precision_analysis_4)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "898835e4-cd64-4c6b-854d-16acb0ffd8b7",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9806ca77",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1af5df0f-de07-4c56-89c0-dcdbb5b578cb",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ed9c4c85-ad54-4717-b43f-a99bf0fb4e73",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0fb156d4-9804-454a-a9d9-8c4d8a11ef13",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3d0d8f47-a535-4bf5-a695-094a683eea07",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ad3021a0-8b61-43d7-a609-5ad8e3bd92ea",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "367c80af-5835-471c-8a34-215670a67db2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "96019376-c72e-4796-ac5c-6c5cee450b82",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "94ed0313-9bd5-4776-9027-d4fc7df3791b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d3738abe-306e-43b3-b0c5-ac0f66ba6071",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1948628d-62a8-44b9-b2c7-50b97f810d32",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ca213365-6813-46ab-b214-2c26b075a15c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7427ca6e-acbd-46f8-9506-00849ca4d2ec",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "851e14da-a79b-4e84-84d5-07203d9a9b96",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "017c6184-b781-4dd2-8d63-5a0e0b3a30b0",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "39223733-e5f8-4010-b78f-3c606123015a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "51e52657-1843-423e-8dbe-838b73092b21",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2271873b-e486-4bef-a93c-cff2b35f0fbc",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "72b68c4c-a260-4061-b955-f481176792a4",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ead40791-4fef-42d9-b745-656e63cceb61",
   "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
}
