{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import pandas as pd\n",
    "\n",
    "\n",
    "import coresets\n",
    "import coresets.utils.plotting as plotting\n",
    "\n",
    "import coresets.utils\n",
    "import coresets.utils.datagen\n",
    "import coresets.algorithms\n",
    "\n",
    "from sklearn.preprocessing import StandardScaler\n",
    "\n",
    "from K_Means_Algorithm_Uniform import cost\n",
    "from K_Means_Algorithm_Uniform import k_means_algorithm_uniform\n",
    "from K_Means_Sklearn_Uniform import k_means_generate_uniform"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "df = pd.read_csv('Exasens.csv')\n",
    "raw_data = df[df.columns[2:6]].values\n",
    "\n",
    "scaler = StandardScaler()\n",
    "X = scaler.fit_transform(raw_data)\n",
    "\n",
    "X = X[~np.isnan(X).any(axis=1)]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "157.0784452875977\n",
      "156.59742840373363\n",
      "157.59049360690736\n",
      "157.61170191628986\n",
      "160.66486466684867\n"
     ]
    }
   ],
   "source": [
    "k = 4\n",
    "\n",
    "lloyd_cost = [[0]*5 for _ in range(7)]\n",
    "\n",
    "for i in range(5):\n",
    "    lloyd_cost[k-4][i] = k_means_generate_uniform(X, k, max_iter=3, random_seed=38+i)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "27.747941712133013\n",
      "29.02593271821955\n",
      "27.940700851357303\n",
      "25.79247350431695\n",
      "27.703622382018914\n"
     ]
    }
   ],
   "source": [
    "k = 4\n",
    "\n",
    "our_cost = [[0]*5 for _ in range(7)]\n",
    "for i in range(5):\n",
    "    our_cost[k-4][i], _, _ = k_means_algorithm_uniform(X, k = k, net_distance=0.0001, n_iter=3, attempt=100, random_seed=38+i)\n",
    "    print(our_cost[k-4][i])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "152.8137890094397\n",
      "152.1627997385146\n",
      "149.24456542463753\n",
      "21.48689530227822\n",
      "154.7503128956088\n"
     ]
    }
   ],
   "source": [
    "k = 5\n",
    "\n",
    "for i in range(5):\n",
    "    lloyd_cost[k-4][i] = k_means_generate_uniform(X, k, max_iter=3, random_seed=38+i)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "20.2255677116353\n",
      "21.779530646266696\n",
      "22.855171206608315\n",
      "21.27841574466594\n",
      "23.659246145917983\n"
     ]
    }
   ],
   "source": [
    "k = 5\n",
    "\n",
    "for i in range(5):\n",
    "    our_cost[k-4][i], _, _ = k_means_algorithm_uniform(X, k = k, net_distance=0.0001, n_iter=3, attempt=100, random_seed=38+i)\n",
    "    print(our_cost[k-4][i])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "148.19680061009916\n",
      "147.1474588944842\n",
      "146.18556304348598\n",
      "20.983791580488848\n",
      "152.02333868605007\n"
     ]
    }
   ],
   "source": [
    "k = 6\n",
    "\n",
    "for i in range(5):\n",
    "    lloyd_cost[k-4][i] = k_means_generate_uniform(X, k, max_iter=3,random_seed=38+i)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "16.755495576446446\n",
      "18.21668585970518\n",
      "16.387824353312404\n",
      "16.655901471230234\n",
      "17.33166003273581\n"
     ]
    }
   ],
   "source": [
    "k = 6\n",
    "\n",
    "for i in range(5):\n",
    "    our_cost[k-4][i], _, _ = k_means_algorithm_uniform(X, k = k, net_distance=0.0001, n_iter=3, attempt=100,random_seed=38+i)\n",
    "    print(our_cost[k-4][i])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "147.6218130792996\n",
      "146.1139446078546\n",
      "145.4308645193264\n",
      "19.394987188968837\n",
      "149.82344884696045\n"
     ]
    }
   ],
   "source": [
    "k = 7\n",
    "\n",
    "for i in range(5):\n",
    "    lloyd_cost[k-4][i] = k_means_generate_uniform(X, k, max_iter=3,random_seed=38+i)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "12.54162294307942\n",
      "11.807104678777458\n",
      "11.980030672751012\n",
      "11.990313739882799\n",
      "12.865625482676197\n"
     ]
    }
   ],
   "source": [
    "k = 7\n",
    "\n",
    "for i in range(5):\n",
    "    our_cost[k-4][i], _, _ = k_means_algorithm_uniform(X, k = k, net_distance=0.0001, n_iter=3, attempt=100,random_seed=38+i)\n",
    "    print(our_cost[k-4][i])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "10.935342347457308\n",
      "145.70544095120215\n",
      "144.48884258771386\n",
      "16.606403691527984\n",
      "13.136978115118126\n"
     ]
    }
   ],
   "source": [
    "k = 8\n",
    "\n",
    "for i in range(5):\n",
    "    lloyd_cost[k-4][i] = k_means_generate_uniform(X, k, max_iter=3,random_seed=38+i)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "10.901068339491362\n",
      "10.688502898182023\n",
      "8.962870849654493\n",
      "10.485110662459102\n",
      "10.063769874031662\n"
     ]
    }
   ],
   "source": [
    "k = 8\n",
    "\n",
    "for i in range(5):\n",
    "    our_cost[k-4][i], _, _ = k_means_algorithm_uniform(X, k = k, net_distance=0.0001, n_iter=3, attempt=100,random_seed=38+i)\n",
    "    print(our_cost[k-4][i])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "10.040055524899273\n",
      "143.8325000566292\n",
      "144.22405942783416\n",
      "16.28600767602209\n",
      "11.95968538525494\n"
     ]
    }
   ],
   "source": [
    "k = 9\n",
    "\n",
    "for i in range(5):\n",
    "    lloyd_cost[k-4][i] = k_means_generate_uniform(X, k, max_iter=3,random_seed=38+i)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "7.4911253663274495\n",
      "8.455608882652168\n",
      "12.484884279236224\n",
      "7.1499490028544175\n",
      "7.84951723953399\n"
     ]
    }
   ],
   "source": [
    "k = 9\n",
    "\n",
    "for i in range(5):\n",
    "    our_cost[k-4][i], _, _ = k_means_algorithm_uniform(X, k = k, net_distance=0.0001, n_iter=3, attempt=100,random_seed=38+i)\n",
    "    print(our_cost[k-4][i])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "10.860548764258082\n",
      "142.84079819694688\n",
      "142.7437596441491\n",
      "10.998433600043066\n",
      "11.621362799279215\n"
     ]
    }
   ],
   "source": [
    "k = 10\n",
    "\n",
    "for i in range(5):\n",
    "    lloyd_cost[k-4][i] = k_means_generate_uniform(X, k, max_iter=3,random_seed=38+i)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "6.4672050572658994\n",
      "7.122262786366405\n",
      "7.8559739696392645\n",
      "6.3057221872735525\n",
      "7.647795278154406\n"
     ]
    }
   ],
   "source": [
    "k = 10\n",
    "\n",
    "for i in range(5):\n",
    "    our_cost[k-4][i], _, _ = k_means_algorithm_uniform(X, k = k, net_distance=0.0001, n_iter=3, attempt=100,random_seed=38+i)\n",
    "    print(our_cost[k-4][i])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Example data\n",
    "k_values = np.arange(4, 11)  # k ranges from 4 to 10"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Calculate statistics for both algorithms\n",
    "lloyd_avg = np.mean(lloyd_cost, axis=1)\n",
    "lloyd_min = np.min(lloyd_cost, axis=1)\n",
    "lloyd_max = np.max(lloyd_cost, axis=1)\n",
    "lloyd_median = np.median(lloyd_cost, axis=1)\n",
    "\n",
    "our_avg = np.mean(our_cost, axis=1)\n",
    "our_min = np.min(our_cost, axis=1)\n",
    "our_max = np.max(our_cost, axis=1)\n",
    "our_median = np.median(our_cost, axis=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Set the figure size\n",
    "figsize = (6, 4)  # Same size for both figures\n",
    "title_size = 14\n",
    "label_size = 12\n",
    "legend_size = 10\n",
    "\n",
    "# Lloyd heuristic lines (blue shades)\n",
    "plt.plot(k_values, lloyd_avg, label='Lloyd Avg', marker='o', linestyle='-', color='navy')\n",
    "plt.plot(k_values, lloyd_min, label='Lloyd Min', marker='x', linestyle='--', color='dodgerblue')\n",
    "# plt.plot(k_values, lloyd_max, label='Lloyd Max', marker='x', linestyle='-.', color='lightblue')\n",
    "plt.plot(k_values, lloyd_median, label='Lloyd Median', marker='^', linestyle=':', color='deepskyblue')\n",
    "\n",
    "# Our algorithm lines (maroon shades)\n",
    "plt.plot(k_values, our_avg, label='Our Avg', marker='o', linestyle='-', color='maroon')\n",
    "plt.plot(k_values, our_min, label='Our Min', marker='x', linestyle='--', color='firebrick')\n",
    "# plt.plot(k_values, our_max, label='Our Max', marker='x', linestyle='-.', color='indianred')\n",
    "plt.plot(k_values, our_median, label='Our Median', marker='^', linestyle=':', color='lightcoral')\n",
    "\n",
    "# Adding titles and labels\n",
    "# plt.title('Comparison of Total Cost for KMedoids and Our Algorithm')\n",
    "plt.xlabel('k', fontsize=label_size)\n",
    "plt.ylabel('Total Cost', fontsize=label_size)\n",
    "plt.legend(fontsize=legend_size)\n",
    "\n",
    "# Set legend to be displayed in the upper-right corner\n",
    "plt.legend(loc='upper right')\n",
    "plt.tight_layout(pad=1.0)\n",
    "\n",
    "# Show grid and plot\n",
    "plt.grid(True)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "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>k</th>\n",
       "      <th>Lloyd Avg</th>\n",
       "      <th>Our Avg</th>\n",
       "      <th>Lloyd Min</th>\n",
       "      <th>Our Min</th>\n",
       "      <th>Lloyd Max</th>\n",
       "      <th>Our Max</th>\n",
       "      <th>Lloyd Median</th>\n",
       "      <th>Our Median</th>\n",
       "      <th>Avg Improvement (%)</th>\n",
       "      <th>Min Improvement (%)</th>\n",
       "      <th>Max Improvement (%)</th>\n",
       "      <th>Median Improvement (%)</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>4</td>\n",
       "      <td>157.908587</td>\n",
       "      <td>27.642134</td>\n",
       "      <td>156.597428</td>\n",
       "      <td>25.792474</td>\n",
       "      <td>160.664865</td>\n",
       "      <td>29.025933</td>\n",
       "      <td>157.590494</td>\n",
       "      <td>27.747942</td>\n",
       "      <td>82.494850</td>\n",
       "      <td>83.529440</td>\n",
       "      <td>81.933864</td>\n",
       "      <td>82.392376</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>5</td>\n",
       "      <td>126.091672</td>\n",
       "      <td>21.959586</td>\n",
       "      <td>21.486895</td>\n",
       "      <td>20.225568</td>\n",
       "      <td>154.750313</td>\n",
       "      <td>23.659246</td>\n",
       "      <td>152.162800</td>\n",
       "      <td>21.779531</td>\n",
       "      <td>82.584428</td>\n",
       "      <td>5.870218</td>\n",
       "      <td>84.711342</td>\n",
       "      <td>85.686692</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>6</td>\n",
       "      <td>122.907391</td>\n",
       "      <td>17.069513</td>\n",
       "      <td>20.983792</td>\n",
       "      <td>16.387824</td>\n",
       "      <td>152.023339</td>\n",
       "      <td>18.216686</td>\n",
       "      <td>147.147459</td>\n",
       "      <td>16.755496</td>\n",
       "      <td>86.111890</td>\n",
       "      <td>21.902463</td>\n",
       "      <td>88.017178</td>\n",
       "      <td>88.613126</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>7</td>\n",
       "      <td>121.677012</td>\n",
       "      <td>12.236940</td>\n",
       "      <td>19.394987</td>\n",
       "      <td>11.807105</td>\n",
       "      <td>149.823449</td>\n",
       "      <td>12.865625</td>\n",
       "      <td>146.113945</td>\n",
       "      <td>11.990314</td>\n",
       "      <td>89.943097</td>\n",
       "      <td>39.122906</td>\n",
       "      <td>91.412809</td>\n",
       "      <td>91.793861</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>8</td>\n",
       "      <td>66.174602</td>\n",
       "      <td>10.220265</td>\n",
       "      <td>10.935342</td>\n",
       "      <td>8.962871</td>\n",
       "      <td>145.705441</td>\n",
       "      <td>10.901068</td>\n",
       "      <td>16.606404</td>\n",
       "      <td>10.485111</td>\n",
       "      <td>84.555609</td>\n",
       "      <td>18.037583</td>\n",
       "      <td>92.518421</td>\n",
       "      <td>36.861040</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>9</td>\n",
       "      <td>65.268462</td>\n",
       "      <td>8.686217</td>\n",
       "      <td>10.040056</td>\n",
       "      <td>7.149949</td>\n",
       "      <td>144.224059</td>\n",
       "      <td>12.484884</td>\n",
       "      <td>16.286008</td>\n",
       "      <td>7.849517</td>\n",
       "      <td>86.691556</td>\n",
       "      <td>28.785762</td>\n",
       "      <td>91.343411</td>\n",
       "      <td>51.802078</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>10</td>\n",
       "      <td>63.812981</td>\n",
       "      <td>7.079792</td>\n",
       "      <td>10.860549</td>\n",
       "      <td>6.305722</td>\n",
       "      <td>142.840798</td>\n",
       "      <td>7.855974</td>\n",
       "      <td>11.621363</td>\n",
       "      <td>7.122263</td>\n",
       "      <td>88.905405</td>\n",
       "      <td>41.939194</td>\n",
       "      <td>94.500189</td>\n",
       "      <td>38.714048</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "    k   Lloyd Avg    Our Avg   Lloyd Min    Our Min   Lloyd Max    Our Max  \\\n",
       "0   4  157.908587  27.642134  156.597428  25.792474  160.664865  29.025933   \n",
       "1   5  126.091672  21.959586   21.486895  20.225568  154.750313  23.659246   \n",
       "2   6  122.907391  17.069513   20.983792  16.387824  152.023339  18.216686   \n",
       "3   7  121.677012  12.236940   19.394987  11.807105  149.823449  12.865625   \n",
       "4   8   66.174602  10.220265   10.935342   8.962871  145.705441  10.901068   \n",
       "5   9   65.268462   8.686217   10.040056   7.149949  144.224059  12.484884   \n",
       "6  10   63.812981   7.079792   10.860549   6.305722  142.840798   7.855974   \n",
       "\n",
       "   Lloyd Median  Our Median  Avg Improvement (%)  Min Improvement (%)  \\\n",
       "0    157.590494   27.747942            82.494850            83.529440   \n",
       "1    152.162800   21.779531            82.584428             5.870218   \n",
       "2    147.147459   16.755496            86.111890            21.902463   \n",
       "3    146.113945   11.990314            89.943097            39.122906   \n",
       "4     16.606404   10.485111            84.555609            18.037583   \n",
       "5     16.286008    7.849517            86.691556            28.785762   \n",
       "6     11.621363    7.122263            88.905405            41.939194   \n",
       "\n",
       "   Max Improvement (%)  Median Improvement (%)  \n",
       "0            81.933864               82.392376  \n",
       "1            84.711342               85.686692  \n",
       "2            88.017178               88.613126  \n",
       "3            91.412809               91.793861  \n",
       "4            92.518421               36.861040  \n",
       "5            91.343411               51.802078  \n",
       "6            94.500189               38.714048  "
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Calculate improvement rates for each statistic\n",
    "improvement_avg = ((lloyd_avg - our_avg) / lloyd_avg) * 100\n",
    "improvement_min = ((lloyd_min - our_min) / lloyd_min) * 100\n",
    "improvement_max = ((lloyd_max - our_max) / lloyd_max) * 100\n",
    "improvement_median = ((lloyd_median - our_median) / lloyd_median) * 100\n",
    "\n",
    "# Create a DataFrame to show the improvement rates\n",
    "improvement_df = pd.DataFrame({\n",
    "    'k': k_values,\n",
    "    'Lloyd Avg': lloyd_avg,\n",
    "    'Our Avg': our_avg,\n",
    "    'Lloyd Min': lloyd_min,\n",
    "    'Our Min': our_min,\n",
    "    'Lloyd Max': lloyd_max,\n",
    "    'Our Max': our_max,\n",
    "    'Lloyd Median': lloyd_median,\n",
    "    'Our Median': our_median,\n",
    "    'Avg Improvement (%)': improvement_avg,\n",
    "    'Min Improvement (%)': improvement_min,\n",
    "    'Max Improvement (%)': improvement_max,\n",
    "    'Median Improvement (%)': improvement_median\n",
    "})\n",
    "\n",
    "# Display the DataFrame\n",
    "improvement_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [],
   "source": [
    "k = 10\n",
    "\n",
    "example_cost, example_centers, example_labels = k_means_algorithm_uniform(X, k = k, net_distance=0.0001, n_iter=3, attempt=100)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [],
   "source": [
    "def compute_kmeans_cost_and_percentage(X, example_centers):\n",
    "    # Step 1: Assign each point to the nearest center\n",
    "    n_clusters = len(example_centers)\n",
    "    clusters = {i: [] for i in range(n_clusters)}  # Initialize a dictionary to store clusters\n",
    "    \n",
    "    for point in X:\n",
    "        # Find the nearest center for each point\n",
    "        distances = [np.linalg.norm(point - center) for center in example_centers]\n",
    "        nearest_center = np.argmin(distances)\n",
    "        clusters[nearest_center].append(point)\n",
    "\n",
    "    # Step 2: Compute the total cost for each cluster\n",
    "    costs = []\n",
    "    for i in range(n_clusters):\n",
    "        cluster_points = np.array(clusters[i])\n",
    "        if len(cluster_points) == 0:\n",
    "            costs.append((i, 0))  # If no points in the cluster, cost is 0\n",
    "        else:\n",
    "            cost = np.sum([np.linalg.norm(point - example_centers[i])**2 for point in cluster_points])\n",
    "            costs.append((i, cost))  # Append the cluster index and its cost\n",
    "    \n",
    "    # Step 3: Sort the costs from biggest to smallest\n",
    "    sorted_costs = sorted(costs, key=lambda x: x[1], reverse=True)\n",
    "    \n",
    "    # Step 4: Compute the total cost\n",
    "    total_cost = sum([cost for _, cost in sorted_costs])\n",
    "    \n",
    "    # Step 5: Print the costs and the percentage contribution\n",
    "    print(f\"Total Cost: {total_cost}\")\n",
    "    print(\"K-Means Cost for each cluster (sorted from biggest to smallest):\")\n",
    "    for idx, (cluster_index, cost) in enumerate(sorted_costs, 1):\n",
    "        percentage = (cost / total_cost) * 100 if total_cost > 0 else 0\n",
    "        print(f\"Cluster {idx}: Cost = {cost}, Contribution = {percentage:.2f}%\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total Cost: 9.243241922376507\n",
      "K-Means Cost for each cluster (sorted from biggest to smallest):\n",
      "Cluster 1: Cost = 2.0561417173576992, Contribution = 22.24%\n",
      "Cluster 2: Cost = 2.0100809324358195, Contribution = 21.75%\n",
      "Cluster 3: Cost = 1.4206923005445253, Contribution = 15.37%\n",
      "Cluster 4: Cost = 1.3790024339843971, Contribution = 14.92%\n",
      "Cluster 5: Cost = 0.9269843503394583, Contribution = 10.03%\n",
      "Cluster 6: Cost = 0.5822803631784611, Contribution = 6.30%\n",
      "Cluster 7: Cost = 0.541282181560064, Contribution = 5.86%\n",
      "Cluster 8: Cost = 0.3267776429760853, Contribution = 3.54%\n",
      "Cluster 9: Cost = 0.0, Contribution = 0.00%\n",
      "Cluster 10: Cost = 0.0, Contribution = 0.00%\n"
     ]
    }
   ],
   "source": [
    "compute_kmeans_cost_and_percentage(X, example_centers)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "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.9.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
