{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "%matplotlib inline"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "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>radius_mean</th>\n",
       "      <th>texture_mean</th>\n",
       "      <th>perimeter_mean</th>\n",
       "      <th>area_mean</th>\n",
       "      <th>smoothness_mean</th>\n",
       "      <th>compactness_mean</th>\n",
       "      <th>concavity_mean</th>\n",
       "      <th>concave points_mean</th>\n",
       "      <th>symmetry_mean</th>\n",
       "      <th>fractal_dimension_mean</th>\n",
       "      <th>...</th>\n",
       "      <th>texture_worst</th>\n",
       "      <th>perimeter_worst</th>\n",
       "      <th>area_worst</th>\n",
       "      <th>smoothness_worst</th>\n",
       "      <th>compactness_worst</th>\n",
       "      <th>concavity_worst</th>\n",
       "      <th>concave points_worst</th>\n",
       "      <th>symmetry_worst</th>\n",
       "      <th>fractal_dimension_worst</th>\n",
       "      <th>diagnosis</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>17.99</td>\n",
       "      <td>10.38</td>\n",
       "      <td>122.80</td>\n",
       "      <td>1001.0</td>\n",
       "      <td>0.11840</td>\n",
       "      <td>0.27760</td>\n",
       "      <td>0.30010</td>\n",
       "      <td>0.14710</td>\n",
       "      <td>0.2419</td>\n",
       "      <td>0.07871</td>\n",
       "      <td>...</td>\n",
       "      <td>17.33</td>\n",
       "      <td>184.60</td>\n",
       "      <td>2019.0</td>\n",
       "      <td>0.16220</td>\n",
       "      <td>0.66560</td>\n",
       "      <td>0.7119</td>\n",
       "      <td>0.2654</td>\n",
       "      <td>0.4601</td>\n",
       "      <td>0.11890</td>\n",
       "      <td>M</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>20.57</td>\n",
       "      <td>17.77</td>\n",
       "      <td>132.90</td>\n",
       "      <td>1326.0</td>\n",
       "      <td>0.08474</td>\n",
       "      <td>0.07864</td>\n",
       "      <td>0.08690</td>\n",
       "      <td>0.07017</td>\n",
       "      <td>0.1812</td>\n",
       "      <td>0.05667</td>\n",
       "      <td>...</td>\n",
       "      <td>23.41</td>\n",
       "      <td>158.80</td>\n",
       "      <td>1956.0</td>\n",
       "      <td>0.12380</td>\n",
       "      <td>0.18660</td>\n",
       "      <td>0.2416</td>\n",
       "      <td>0.1860</td>\n",
       "      <td>0.2750</td>\n",
       "      <td>0.08902</td>\n",
       "      <td>M</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>19.69</td>\n",
       "      <td>21.25</td>\n",
       "      <td>130.00</td>\n",
       "      <td>1203.0</td>\n",
       "      <td>0.10960</td>\n",
       "      <td>0.15990</td>\n",
       "      <td>0.19740</td>\n",
       "      <td>0.12790</td>\n",
       "      <td>0.2069</td>\n",
       "      <td>0.05999</td>\n",
       "      <td>...</td>\n",
       "      <td>25.53</td>\n",
       "      <td>152.50</td>\n",
       "      <td>1709.0</td>\n",
       "      <td>0.14440</td>\n",
       "      <td>0.42450</td>\n",
       "      <td>0.4504</td>\n",
       "      <td>0.2430</td>\n",
       "      <td>0.3613</td>\n",
       "      <td>0.08758</td>\n",
       "      <td>M</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>11.42</td>\n",
       "      <td>20.38</td>\n",
       "      <td>77.58</td>\n",
       "      <td>386.1</td>\n",
       "      <td>0.14250</td>\n",
       "      <td>0.28390</td>\n",
       "      <td>0.24140</td>\n",
       "      <td>0.10520</td>\n",
       "      <td>0.2597</td>\n",
       "      <td>0.09744</td>\n",
       "      <td>...</td>\n",
       "      <td>26.50</td>\n",
       "      <td>98.87</td>\n",
       "      <td>567.7</td>\n",
       "      <td>0.20980</td>\n",
       "      <td>0.86630</td>\n",
       "      <td>0.6869</td>\n",
       "      <td>0.2575</td>\n",
       "      <td>0.6638</td>\n",
       "      <td>0.17300</td>\n",
       "      <td>M</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>20.29</td>\n",
       "      <td>14.34</td>\n",
       "      <td>135.10</td>\n",
       "      <td>1297.0</td>\n",
       "      <td>0.10030</td>\n",
       "      <td>0.13280</td>\n",
       "      <td>0.19800</td>\n",
       "      <td>0.10430</td>\n",
       "      <td>0.1809</td>\n",
       "      <td>0.05883</td>\n",
       "      <td>...</td>\n",
       "      <td>16.67</td>\n",
       "      <td>152.20</td>\n",
       "      <td>1575.0</td>\n",
       "      <td>0.13740</td>\n",
       "      <td>0.20500</td>\n",
       "      <td>0.4000</td>\n",
       "      <td>0.1625</td>\n",
       "      <td>0.2364</td>\n",
       "      <td>0.07678</td>\n",
       "      <td>M</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>564</th>\n",
       "      <td>21.56</td>\n",
       "      <td>22.39</td>\n",
       "      <td>142.00</td>\n",
       "      <td>1479.0</td>\n",
       "      <td>0.11100</td>\n",
       "      <td>0.11590</td>\n",
       "      <td>0.24390</td>\n",
       "      <td>0.13890</td>\n",
       "      <td>0.1726</td>\n",
       "      <td>0.05623</td>\n",
       "      <td>...</td>\n",
       "      <td>26.40</td>\n",
       "      <td>166.10</td>\n",
       "      <td>2027.0</td>\n",
       "      <td>0.14100</td>\n",
       "      <td>0.21130</td>\n",
       "      <td>0.4107</td>\n",
       "      <td>0.2216</td>\n",
       "      <td>0.2060</td>\n",
       "      <td>0.07115</td>\n",
       "      <td>M</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>565</th>\n",
       "      <td>20.13</td>\n",
       "      <td>28.25</td>\n",
       "      <td>131.20</td>\n",
       "      <td>1261.0</td>\n",
       "      <td>0.09780</td>\n",
       "      <td>0.10340</td>\n",
       "      <td>0.14400</td>\n",
       "      <td>0.09791</td>\n",
       "      <td>0.1752</td>\n",
       "      <td>0.05533</td>\n",
       "      <td>...</td>\n",
       "      <td>38.25</td>\n",
       "      <td>155.00</td>\n",
       "      <td>1731.0</td>\n",
       "      <td>0.11660</td>\n",
       "      <td>0.19220</td>\n",
       "      <td>0.3215</td>\n",
       "      <td>0.1628</td>\n",
       "      <td>0.2572</td>\n",
       "      <td>0.06637</td>\n",
       "      <td>M</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>566</th>\n",
       "      <td>16.60</td>\n",
       "      <td>28.08</td>\n",
       "      <td>108.30</td>\n",
       "      <td>858.1</td>\n",
       "      <td>0.08455</td>\n",
       "      <td>0.10230</td>\n",
       "      <td>0.09251</td>\n",
       "      <td>0.05302</td>\n",
       "      <td>0.1590</td>\n",
       "      <td>0.05648</td>\n",
       "      <td>...</td>\n",
       "      <td>34.12</td>\n",
       "      <td>126.70</td>\n",
       "      <td>1124.0</td>\n",
       "      <td>0.11390</td>\n",
       "      <td>0.30940</td>\n",
       "      <td>0.3403</td>\n",
       "      <td>0.1418</td>\n",
       "      <td>0.2218</td>\n",
       "      <td>0.07820</td>\n",
       "      <td>M</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>567</th>\n",
       "      <td>20.60</td>\n",
       "      <td>29.33</td>\n",
       "      <td>140.10</td>\n",
       "      <td>1265.0</td>\n",
       "      <td>0.11780</td>\n",
       "      <td>0.27700</td>\n",
       "      <td>0.35140</td>\n",
       "      <td>0.15200</td>\n",
       "      <td>0.2397</td>\n",
       "      <td>0.07016</td>\n",
       "      <td>...</td>\n",
       "      <td>39.42</td>\n",
       "      <td>184.60</td>\n",
       "      <td>1821.0</td>\n",
       "      <td>0.16500</td>\n",
       "      <td>0.86810</td>\n",
       "      <td>0.9387</td>\n",
       "      <td>0.2650</td>\n",
       "      <td>0.4087</td>\n",
       "      <td>0.12400</td>\n",
       "      <td>M</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>568</th>\n",
       "      <td>7.76</td>\n",
       "      <td>24.54</td>\n",
       "      <td>47.92</td>\n",
       "      <td>181.0</td>\n",
       "      <td>0.05263</td>\n",
       "      <td>0.04362</td>\n",
       "      <td>0.00000</td>\n",
       "      <td>0.00000</td>\n",
       "      <td>0.1587</td>\n",
       "      <td>0.05884</td>\n",
       "      <td>...</td>\n",
       "      <td>30.37</td>\n",
       "      <td>59.16</td>\n",
       "      <td>268.6</td>\n",
       "      <td>0.08996</td>\n",
       "      <td>0.06444</td>\n",
       "      <td>0.0000</td>\n",
       "      <td>0.0000</td>\n",
       "      <td>0.2871</td>\n",
       "      <td>0.07039</td>\n",
       "      <td>B</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>569 rows × 31 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "     radius_mean  texture_mean  perimeter_mean  area_mean  smoothness_mean  \\\n",
       "0          17.99         10.38          122.80     1001.0          0.11840   \n",
       "1          20.57         17.77          132.90     1326.0          0.08474   \n",
       "2          19.69         21.25          130.00     1203.0          0.10960   \n",
       "3          11.42         20.38           77.58      386.1          0.14250   \n",
       "4          20.29         14.34          135.10     1297.0          0.10030   \n",
       "..           ...           ...             ...        ...              ...   \n",
       "564        21.56         22.39          142.00     1479.0          0.11100   \n",
       "565        20.13         28.25          131.20     1261.0          0.09780   \n",
       "566        16.60         28.08          108.30      858.1          0.08455   \n",
       "567        20.60         29.33          140.10     1265.0          0.11780   \n",
       "568         7.76         24.54           47.92      181.0          0.05263   \n",
       "\n",
       "     compactness_mean  concavity_mean  concave points_mean  symmetry_mean  \\\n",
       "0             0.27760         0.30010              0.14710         0.2419   \n",
       "1             0.07864         0.08690              0.07017         0.1812   \n",
       "2             0.15990         0.19740              0.12790         0.2069   \n",
       "3             0.28390         0.24140              0.10520         0.2597   \n",
       "4             0.13280         0.19800              0.10430         0.1809   \n",
       "..                ...             ...                  ...            ...   \n",
       "564           0.11590         0.24390              0.13890         0.1726   \n",
       "565           0.10340         0.14400              0.09791         0.1752   \n",
       "566           0.10230         0.09251              0.05302         0.1590   \n",
       "567           0.27700         0.35140              0.15200         0.2397   \n",
       "568           0.04362         0.00000              0.00000         0.1587   \n",
       "\n",
       "     fractal_dimension_mean  ...  texture_worst  perimeter_worst  area_worst  \\\n",
       "0                   0.07871  ...          17.33           184.60      2019.0   \n",
       "1                   0.05667  ...          23.41           158.80      1956.0   \n",
       "2                   0.05999  ...          25.53           152.50      1709.0   \n",
       "3                   0.09744  ...          26.50            98.87       567.7   \n",
       "4                   0.05883  ...          16.67           152.20      1575.0   \n",
       "..                      ...  ...            ...              ...         ...   \n",
       "564                 0.05623  ...          26.40           166.10      2027.0   \n",
       "565                 0.05533  ...          38.25           155.00      1731.0   \n",
       "566                 0.05648  ...          34.12           126.70      1124.0   \n",
       "567                 0.07016  ...          39.42           184.60      1821.0   \n",
       "568                 0.05884  ...          30.37            59.16       268.6   \n",
       "\n",
       "     smoothness_worst  compactness_worst  concavity_worst  \\\n",
       "0             0.16220            0.66560           0.7119   \n",
       "1             0.12380            0.18660           0.2416   \n",
       "2             0.14440            0.42450           0.4504   \n",
       "3             0.20980            0.86630           0.6869   \n",
       "4             0.13740            0.20500           0.4000   \n",
       "..                ...                ...              ...   \n",
       "564           0.14100            0.21130           0.4107   \n",
       "565           0.11660            0.19220           0.3215   \n",
       "566           0.11390            0.30940           0.3403   \n",
       "567           0.16500            0.86810           0.9387   \n",
       "568           0.08996            0.06444           0.0000   \n",
       "\n",
       "     concave points_worst  symmetry_worst  fractal_dimension_worst  diagnosis  \n",
       "0                  0.2654          0.4601                  0.11890          M  \n",
       "1                  0.1860          0.2750                  0.08902          M  \n",
       "2                  0.2430          0.3613                  0.08758          M  \n",
       "3                  0.2575          0.6638                  0.17300          M  \n",
       "4                  0.1625          0.2364                  0.07678          M  \n",
       "..                    ...             ...                      ...        ...  \n",
       "564                0.2216          0.2060                  0.07115          M  \n",
       "565                0.1628          0.2572                  0.06637          M  \n",
       "566                0.1418          0.2218                  0.07820          M  \n",
       "567                0.2650          0.4087                  0.12400          M  \n",
       "568                0.0000          0.2871                  0.07039          B  \n",
       "\n",
       "[569 rows x 31 columns]"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "iris = pd.read_csv(\"Breast Cancer Original.csv\",encoding=\"ISO-8859-1\")\n",
    "iris"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "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>radius_mean</th>\n",
       "      <th>texture_mean</th>\n",
       "      <th>perimeter_mean</th>\n",
       "      <th>area_mean</th>\n",
       "      <th>smoothness_mean</th>\n",
       "      <th>compactness_mean</th>\n",
       "      <th>concavity_mean</th>\n",
       "      <th>concave points_mean</th>\n",
       "      <th>symmetry_mean</th>\n",
       "      <th>fractal_dimension_mean</th>\n",
       "      <th>...</th>\n",
       "      <th>texture_worst</th>\n",
       "      <th>perimeter_worst</th>\n",
       "      <th>area_worst</th>\n",
       "      <th>smoothness_worst</th>\n",
       "      <th>compactness_worst</th>\n",
       "      <th>concavity_worst</th>\n",
       "      <th>concave points_worst</th>\n",
       "      <th>symmetry_worst</th>\n",
       "      <th>fractal_dimension_worst</th>\n",
       "      <th>diagnosis</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>17.99</td>\n",
       "      <td>10.38</td>\n",
       "      <td>122.80</td>\n",
       "      <td>1001.0</td>\n",
       "      <td>0.11840</td>\n",
       "      <td>0.27760</td>\n",
       "      <td>0.3001</td>\n",
       "      <td>0.14710</td>\n",
       "      <td>0.2419</td>\n",
       "      <td>0.07871</td>\n",
       "      <td>...</td>\n",
       "      <td>17.33</td>\n",
       "      <td>184.60</td>\n",
       "      <td>2019.0</td>\n",
       "      <td>0.1622</td>\n",
       "      <td>0.6656</td>\n",
       "      <td>0.7119</td>\n",
       "      <td>0.2654</td>\n",
       "      <td>0.4601</td>\n",
       "      <td>0.11890</td>\n",
       "      <td>M</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>20.57</td>\n",
       "      <td>17.77</td>\n",
       "      <td>132.90</td>\n",
       "      <td>1326.0</td>\n",
       "      <td>0.08474</td>\n",
       "      <td>0.07864</td>\n",
       "      <td>0.0869</td>\n",
       "      <td>0.07017</td>\n",
       "      <td>0.1812</td>\n",
       "      <td>0.05667</td>\n",
       "      <td>...</td>\n",
       "      <td>23.41</td>\n",
       "      <td>158.80</td>\n",
       "      <td>1956.0</td>\n",
       "      <td>0.1238</td>\n",
       "      <td>0.1866</td>\n",
       "      <td>0.2416</td>\n",
       "      <td>0.1860</td>\n",
       "      <td>0.2750</td>\n",
       "      <td>0.08902</td>\n",
       "      <td>M</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>19.69</td>\n",
       "      <td>21.25</td>\n",
       "      <td>130.00</td>\n",
       "      <td>1203.0</td>\n",
       "      <td>0.10960</td>\n",
       "      <td>0.15990</td>\n",
       "      <td>0.1974</td>\n",
       "      <td>0.12790</td>\n",
       "      <td>0.2069</td>\n",
       "      <td>0.05999</td>\n",
       "      <td>...</td>\n",
       "      <td>25.53</td>\n",
       "      <td>152.50</td>\n",
       "      <td>1709.0</td>\n",
       "      <td>0.1444</td>\n",
       "      <td>0.4245</td>\n",
       "      <td>0.4504</td>\n",
       "      <td>0.2430</td>\n",
       "      <td>0.3613</td>\n",
       "      <td>0.08758</td>\n",
       "      <td>M</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>11.42</td>\n",
       "      <td>20.38</td>\n",
       "      <td>77.58</td>\n",
       "      <td>386.1</td>\n",
       "      <td>0.14250</td>\n",
       "      <td>0.28390</td>\n",
       "      <td>0.2414</td>\n",
       "      <td>0.10520</td>\n",
       "      <td>0.2597</td>\n",
       "      <td>0.09744</td>\n",
       "      <td>...</td>\n",
       "      <td>26.50</td>\n",
       "      <td>98.87</td>\n",
       "      <td>567.7</td>\n",
       "      <td>0.2098</td>\n",
       "      <td>0.8663</td>\n",
       "      <td>0.6869</td>\n",
       "      <td>0.2575</td>\n",
       "      <td>0.6638</td>\n",
       "      <td>0.17300</td>\n",
       "      <td>M</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>20.29</td>\n",
       "      <td>14.34</td>\n",
       "      <td>135.10</td>\n",
       "      <td>1297.0</td>\n",
       "      <td>0.10030</td>\n",
       "      <td>0.13280</td>\n",
       "      <td>0.1980</td>\n",
       "      <td>0.10430</td>\n",
       "      <td>0.1809</td>\n",
       "      <td>0.05883</td>\n",
       "      <td>...</td>\n",
       "      <td>16.67</td>\n",
       "      <td>152.20</td>\n",
       "      <td>1575.0</td>\n",
       "      <td>0.1374</td>\n",
       "      <td>0.2050</td>\n",
       "      <td>0.4000</td>\n",
       "      <td>0.1625</td>\n",
       "      <td>0.2364</td>\n",
       "      <td>0.07678</td>\n",
       "      <td>M</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>5 rows × 31 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "   radius_mean  texture_mean  perimeter_mean  area_mean  smoothness_mean  \\\n",
       "0        17.99         10.38          122.80     1001.0          0.11840   \n",
       "1        20.57         17.77          132.90     1326.0          0.08474   \n",
       "2        19.69         21.25          130.00     1203.0          0.10960   \n",
       "3        11.42         20.38           77.58      386.1          0.14250   \n",
       "4        20.29         14.34          135.10     1297.0          0.10030   \n",
       "\n",
       "   compactness_mean  concavity_mean  concave points_mean  symmetry_mean  \\\n",
       "0           0.27760          0.3001              0.14710         0.2419   \n",
       "1           0.07864          0.0869              0.07017         0.1812   \n",
       "2           0.15990          0.1974              0.12790         0.2069   \n",
       "3           0.28390          0.2414              0.10520         0.2597   \n",
       "4           0.13280          0.1980              0.10430         0.1809   \n",
       "\n",
       "   fractal_dimension_mean  ...  texture_worst  perimeter_worst  area_worst  \\\n",
       "0                 0.07871  ...          17.33           184.60      2019.0   \n",
       "1                 0.05667  ...          23.41           158.80      1956.0   \n",
       "2                 0.05999  ...          25.53           152.50      1709.0   \n",
       "3                 0.09744  ...          26.50            98.87       567.7   \n",
       "4                 0.05883  ...          16.67           152.20      1575.0   \n",
       "\n",
       "   smoothness_worst  compactness_worst  concavity_worst  concave points_worst  \\\n",
       "0            0.1622             0.6656           0.7119                0.2654   \n",
       "1            0.1238             0.1866           0.2416                0.1860   \n",
       "2            0.1444             0.4245           0.4504                0.2430   \n",
       "3            0.2098             0.8663           0.6869                0.2575   \n",
       "4            0.1374             0.2050           0.4000                0.1625   \n",
       "\n",
       "   symmetry_worst  fractal_dimension_worst  diagnosis  \n",
       "0          0.4601                  0.11890          M  \n",
       "1          0.2750                  0.08902          M  \n",
       "2          0.3613                  0.08758          M  \n",
       "3          0.6638                  0.17300          M  \n",
       "4          0.2364                  0.07678          M  \n",
       "\n",
       "[5 rows x 31 columns]"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "iris.head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "def class_value(diagnosis): \n",
    "    if diagnosis == 'M': \n",
    "        return 1\n",
    "    else: \n",
    "        return 0\n",
    "  \n",
    "iris['diagnosis'] = iris['diagnosis'].apply(class_value) "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "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>radius_mean</th>\n",
       "      <th>texture_mean</th>\n",
       "      <th>perimeter_mean</th>\n",
       "      <th>area_mean</th>\n",
       "      <th>smoothness_mean</th>\n",
       "      <th>compactness_mean</th>\n",
       "      <th>concavity_mean</th>\n",
       "      <th>concave points_mean</th>\n",
       "      <th>symmetry_mean</th>\n",
       "      <th>fractal_dimension_mean</th>\n",
       "      <th>...</th>\n",
       "      <th>radius_worst</th>\n",
       "      <th>texture_worst</th>\n",
       "      <th>perimeter_worst</th>\n",
       "      <th>area_worst</th>\n",
       "      <th>smoothness_worst</th>\n",
       "      <th>compactness_worst</th>\n",
       "      <th>concavity_worst</th>\n",
       "      <th>concave points_worst</th>\n",
       "      <th>symmetry_worst</th>\n",
       "      <th>fractal_dimension_worst</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>17.99</td>\n",
       "      <td>10.38</td>\n",
       "      <td>122.80</td>\n",
       "      <td>1001.0</td>\n",
       "      <td>0.11840</td>\n",
       "      <td>0.27760</td>\n",
       "      <td>0.30010</td>\n",
       "      <td>0.14710</td>\n",
       "      <td>0.2419</td>\n",
       "      <td>0.07871</td>\n",
       "      <td>...</td>\n",
       "      <td>25.380</td>\n",
       "      <td>17.33</td>\n",
       "      <td>184.60</td>\n",
       "      <td>2019.0</td>\n",
       "      <td>0.16220</td>\n",
       "      <td>0.66560</td>\n",
       "      <td>0.7119</td>\n",
       "      <td>0.2654</td>\n",
       "      <td>0.4601</td>\n",
       "      <td>0.11890</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>20.57</td>\n",
       "      <td>17.77</td>\n",
       "      <td>132.90</td>\n",
       "      <td>1326.0</td>\n",
       "      <td>0.08474</td>\n",
       "      <td>0.07864</td>\n",
       "      <td>0.08690</td>\n",
       "      <td>0.07017</td>\n",
       "      <td>0.1812</td>\n",
       "      <td>0.05667</td>\n",
       "      <td>...</td>\n",
       "      <td>24.990</td>\n",
       "      <td>23.41</td>\n",
       "      <td>158.80</td>\n",
       "      <td>1956.0</td>\n",
       "      <td>0.12380</td>\n",
       "      <td>0.18660</td>\n",
       "      <td>0.2416</td>\n",
       "      <td>0.1860</td>\n",
       "      <td>0.2750</td>\n",
       "      <td>0.08902</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>19.69</td>\n",
       "      <td>21.25</td>\n",
       "      <td>130.00</td>\n",
       "      <td>1203.0</td>\n",
       "      <td>0.10960</td>\n",
       "      <td>0.15990</td>\n",
       "      <td>0.19740</td>\n",
       "      <td>0.12790</td>\n",
       "      <td>0.2069</td>\n",
       "      <td>0.05999</td>\n",
       "      <td>...</td>\n",
       "      <td>23.570</td>\n",
       "      <td>25.53</td>\n",
       "      <td>152.50</td>\n",
       "      <td>1709.0</td>\n",
       "      <td>0.14440</td>\n",
       "      <td>0.42450</td>\n",
       "      <td>0.4504</td>\n",
       "      <td>0.2430</td>\n",
       "      <td>0.3613</td>\n",
       "      <td>0.08758</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>11.42</td>\n",
       "      <td>20.38</td>\n",
       "      <td>77.58</td>\n",
       "      <td>386.1</td>\n",
       "      <td>0.14250</td>\n",
       "      <td>0.28390</td>\n",
       "      <td>0.24140</td>\n",
       "      <td>0.10520</td>\n",
       "      <td>0.2597</td>\n",
       "      <td>0.09744</td>\n",
       "      <td>...</td>\n",
       "      <td>14.910</td>\n",
       "      <td>26.50</td>\n",
       "      <td>98.87</td>\n",
       "      <td>567.7</td>\n",
       "      <td>0.20980</td>\n",
       "      <td>0.86630</td>\n",
       "      <td>0.6869</td>\n",
       "      <td>0.2575</td>\n",
       "      <td>0.6638</td>\n",
       "      <td>0.17300</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>20.29</td>\n",
       "      <td>14.34</td>\n",
       "      <td>135.10</td>\n",
       "      <td>1297.0</td>\n",
       "      <td>0.10030</td>\n",
       "      <td>0.13280</td>\n",
       "      <td>0.19800</td>\n",
       "      <td>0.10430</td>\n",
       "      <td>0.1809</td>\n",
       "      <td>0.05883</td>\n",
       "      <td>...</td>\n",
       "      <td>22.540</td>\n",
       "      <td>16.67</td>\n",
       "      <td>152.20</td>\n",
       "      <td>1575.0</td>\n",
       "      <td>0.13740</td>\n",
       "      <td>0.20500</td>\n",
       "      <td>0.4000</td>\n",
       "      <td>0.1625</td>\n",
       "      <td>0.2364</td>\n",
       "      <td>0.07678</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>564</th>\n",
       "      <td>21.56</td>\n",
       "      <td>22.39</td>\n",
       "      <td>142.00</td>\n",
       "      <td>1479.0</td>\n",
       "      <td>0.11100</td>\n",
       "      <td>0.11590</td>\n",
       "      <td>0.24390</td>\n",
       "      <td>0.13890</td>\n",
       "      <td>0.1726</td>\n",
       "      <td>0.05623</td>\n",
       "      <td>...</td>\n",
       "      <td>25.450</td>\n",
       "      <td>26.40</td>\n",
       "      <td>166.10</td>\n",
       "      <td>2027.0</td>\n",
       "      <td>0.14100</td>\n",
       "      <td>0.21130</td>\n",
       "      <td>0.4107</td>\n",
       "      <td>0.2216</td>\n",
       "      <td>0.2060</td>\n",
       "      <td>0.07115</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>565</th>\n",
       "      <td>20.13</td>\n",
       "      <td>28.25</td>\n",
       "      <td>131.20</td>\n",
       "      <td>1261.0</td>\n",
       "      <td>0.09780</td>\n",
       "      <td>0.10340</td>\n",
       "      <td>0.14400</td>\n",
       "      <td>0.09791</td>\n",
       "      <td>0.1752</td>\n",
       "      <td>0.05533</td>\n",
       "      <td>...</td>\n",
       "      <td>23.690</td>\n",
       "      <td>38.25</td>\n",
       "      <td>155.00</td>\n",
       "      <td>1731.0</td>\n",
       "      <td>0.11660</td>\n",
       "      <td>0.19220</td>\n",
       "      <td>0.3215</td>\n",
       "      <td>0.1628</td>\n",
       "      <td>0.2572</td>\n",
       "      <td>0.06637</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>566</th>\n",
       "      <td>16.60</td>\n",
       "      <td>28.08</td>\n",
       "      <td>108.30</td>\n",
       "      <td>858.1</td>\n",
       "      <td>0.08455</td>\n",
       "      <td>0.10230</td>\n",
       "      <td>0.09251</td>\n",
       "      <td>0.05302</td>\n",
       "      <td>0.1590</td>\n",
       "      <td>0.05648</td>\n",
       "      <td>...</td>\n",
       "      <td>18.980</td>\n",
       "      <td>34.12</td>\n",
       "      <td>126.70</td>\n",
       "      <td>1124.0</td>\n",
       "      <td>0.11390</td>\n",
       "      <td>0.30940</td>\n",
       "      <td>0.3403</td>\n",
       "      <td>0.1418</td>\n",
       "      <td>0.2218</td>\n",
       "      <td>0.07820</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>567</th>\n",
       "      <td>20.60</td>\n",
       "      <td>29.33</td>\n",
       "      <td>140.10</td>\n",
       "      <td>1265.0</td>\n",
       "      <td>0.11780</td>\n",
       "      <td>0.27700</td>\n",
       "      <td>0.35140</td>\n",
       "      <td>0.15200</td>\n",
       "      <td>0.2397</td>\n",
       "      <td>0.07016</td>\n",
       "      <td>...</td>\n",
       "      <td>25.740</td>\n",
       "      <td>39.42</td>\n",
       "      <td>184.60</td>\n",
       "      <td>1821.0</td>\n",
       "      <td>0.16500</td>\n",
       "      <td>0.86810</td>\n",
       "      <td>0.9387</td>\n",
       "      <td>0.2650</td>\n",
       "      <td>0.4087</td>\n",
       "      <td>0.12400</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>568</th>\n",
       "      <td>7.76</td>\n",
       "      <td>24.54</td>\n",
       "      <td>47.92</td>\n",
       "      <td>181.0</td>\n",
       "      <td>0.05263</td>\n",
       "      <td>0.04362</td>\n",
       "      <td>0.00000</td>\n",
       "      <td>0.00000</td>\n",
       "      <td>0.1587</td>\n",
       "      <td>0.05884</td>\n",
       "      <td>...</td>\n",
       "      <td>9.456</td>\n",
       "      <td>30.37</td>\n",
       "      <td>59.16</td>\n",
       "      <td>268.6</td>\n",
       "      <td>0.08996</td>\n",
       "      <td>0.06444</td>\n",
       "      <td>0.0000</td>\n",
       "      <td>0.0000</td>\n",
       "      <td>0.2871</td>\n",
       "      <td>0.07039</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>569 rows × 30 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "     radius_mean  texture_mean  perimeter_mean  area_mean  smoothness_mean  \\\n",
       "0          17.99         10.38          122.80     1001.0          0.11840   \n",
       "1          20.57         17.77          132.90     1326.0          0.08474   \n",
       "2          19.69         21.25          130.00     1203.0          0.10960   \n",
       "3          11.42         20.38           77.58      386.1          0.14250   \n",
       "4          20.29         14.34          135.10     1297.0          0.10030   \n",
       "..           ...           ...             ...        ...              ...   \n",
       "564        21.56         22.39          142.00     1479.0          0.11100   \n",
       "565        20.13         28.25          131.20     1261.0          0.09780   \n",
       "566        16.60         28.08          108.30      858.1          0.08455   \n",
       "567        20.60         29.33          140.10     1265.0          0.11780   \n",
       "568         7.76         24.54           47.92      181.0          0.05263   \n",
       "\n",
       "     compactness_mean  concavity_mean  concave points_mean  symmetry_mean  \\\n",
       "0             0.27760         0.30010              0.14710         0.2419   \n",
       "1             0.07864         0.08690              0.07017         0.1812   \n",
       "2             0.15990         0.19740              0.12790         0.2069   \n",
       "3             0.28390         0.24140              0.10520         0.2597   \n",
       "4             0.13280         0.19800              0.10430         0.1809   \n",
       "..                ...             ...                  ...            ...   \n",
       "564           0.11590         0.24390              0.13890         0.1726   \n",
       "565           0.10340         0.14400              0.09791         0.1752   \n",
       "566           0.10230         0.09251              0.05302         0.1590   \n",
       "567           0.27700         0.35140              0.15200         0.2397   \n",
       "568           0.04362         0.00000              0.00000         0.1587   \n",
       "\n",
       "     fractal_dimension_mean  ...  radius_worst  texture_worst  \\\n",
       "0                   0.07871  ...        25.380          17.33   \n",
       "1                   0.05667  ...        24.990          23.41   \n",
       "2                   0.05999  ...        23.570          25.53   \n",
       "3                   0.09744  ...        14.910          26.50   \n",
       "4                   0.05883  ...        22.540          16.67   \n",
       "..                      ...  ...           ...            ...   \n",
       "564                 0.05623  ...        25.450          26.40   \n",
       "565                 0.05533  ...        23.690          38.25   \n",
       "566                 0.05648  ...        18.980          34.12   \n",
       "567                 0.07016  ...        25.740          39.42   \n",
       "568                 0.05884  ...         9.456          30.37   \n",
       "\n",
       "     perimeter_worst  area_worst  smoothness_worst  compactness_worst  \\\n",
       "0             184.60      2019.0           0.16220            0.66560   \n",
       "1             158.80      1956.0           0.12380            0.18660   \n",
       "2             152.50      1709.0           0.14440            0.42450   \n",
       "3              98.87       567.7           0.20980            0.86630   \n",
       "4             152.20      1575.0           0.13740            0.20500   \n",
       "..               ...         ...               ...                ...   \n",
       "564           166.10      2027.0           0.14100            0.21130   \n",
       "565           155.00      1731.0           0.11660            0.19220   \n",
       "566           126.70      1124.0           0.11390            0.30940   \n",
       "567           184.60      1821.0           0.16500            0.86810   \n",
       "568            59.16       268.6           0.08996            0.06444   \n",
       "\n",
       "     concavity_worst  concave points_worst  symmetry_worst  \\\n",
       "0             0.7119                0.2654          0.4601   \n",
       "1             0.2416                0.1860          0.2750   \n",
       "2             0.4504                0.2430          0.3613   \n",
       "3             0.6869                0.2575          0.6638   \n",
       "4             0.4000                0.1625          0.2364   \n",
       "..               ...                   ...             ...   \n",
       "564           0.4107                0.2216          0.2060   \n",
       "565           0.3215                0.1628          0.2572   \n",
       "566           0.3403                0.1418          0.2218   \n",
       "567           0.9387                0.2650          0.4087   \n",
       "568           0.0000                0.0000          0.2871   \n",
       "\n",
       "     fractal_dimension_worst  \n",
       "0                    0.11890  \n",
       "1                    0.08902  \n",
       "2                    0.08758  \n",
       "3                    0.17300  \n",
       "4                    0.07678  \n",
       "..                       ...  \n",
       "564                  0.07115  \n",
       "565                  0.06637  \n",
       "566                  0.07820  \n",
       "567                  0.12400  \n",
       "568                  0.07039  \n",
       "\n",
       "[569 rows x 30 columns]"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "#creating the data file with the labels removed\n",
    "irisdata = iris.loc[:, iris.columns != 'diagnosis']\n",
    "irisdata"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[1.799e+01, 1.038e+01, 1.228e+02, ..., 2.654e-01, 4.601e-01,\n",
       "        1.189e-01],\n",
       "       [2.057e+01, 1.777e+01, 1.329e+02, ..., 1.860e-01, 2.750e-01,\n",
       "        8.902e-02],\n",
       "       [1.969e+01, 2.125e+01, 1.300e+02, ..., 2.430e-01, 3.613e-01,\n",
       "        8.758e-02],\n",
       "       ...,\n",
       "       [1.660e+01, 2.808e+01, 1.083e+02, ..., 1.418e-01, 2.218e-01,\n",
       "        7.820e-02],\n",
       "       [2.060e+01, 2.933e+01, 1.401e+02, ..., 2.650e-01, 4.087e-01,\n",
       "        1.240e-01],\n",
       "       [7.760e+00, 2.454e+01, 4.792e+01, ..., 0.000e+00, 2.871e-01,\n",
       "        7.039e-02]])"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "rawdata=irisdata.to_numpy()\n",
    "rawdata"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0,\n",
       "       1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, 1, 1, 1,\n",
       "       1, 1, 0, 1, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 0, 1, 1,\n",
       "       0, 0, 0, 0, 1, 0, 1, 1, 0, 1, 0, 1, 1, 0, 0, 0, 1, 1, 0, 1, 1, 1,\n",
       "       0, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0,\n",
       "       0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 1, 0, 0, 0, 1, 1, 0, 1, 0, 1,\n",
       "       1, 0, 1, 1, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0,\n",
       "       0, 0, 1, 0, 0, 0, 0, 1, 1, 0, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0,\n",
       "       0, 1, 0, 0, 1, 1, 1, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 0, 1, 1,\n",
       "       1, 1, 0, 1, 1, 1, 0, 1, 0, 1, 0, 0, 1, 0, 1, 1, 1, 1, 0, 0, 1, 1,\n",
       "       0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 0, 0, 1, 1, 0, 1, 0, 0,\n",
       "       0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,\n",
       "       1, 1, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 0, 1, 1, 0, 0,\n",
       "       0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0,\n",
       "       0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 1, 1,\n",
       "       1, 0, 0, 0, 0, 1, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1,\n",
       "       1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 1, 0, 1, 1,\n",
       "       0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 0, 0,\n",
       "       0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 1,\n",
       "       0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 1, 0, 1, 0, 0, 0, 0,\n",
       "       0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1,\n",
       "       0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0,\n",
       "       0, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 0, 1, 0, 1, 0, 0,\n",
       "       0, 0, 0, 1, 0, 0, 1, 0, 1, 0, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0,\n",
       "       0, 0, 0, 0, 0, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,\n",
       "       0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0],\n",
       "      dtype=int64)"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "iris_y=iris[\"diagnosis\"]\n",
    "iris_ylabel=iris_y.to_numpy()\n",
    "iris_ylabel"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "from sklearn.model_selection import train_test_split"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Separating the independent variables from dependent variables\n",
    "#x=iris.iloc[:,:-1]\n",
    "#y=iris.iloc[:,30]\n",
    "x_train,x_test, y_train, y_test=train_test_split(iris.drop('diagnosis', axis=1),\n",
    "                iris['diagnosis'],\n",
    "                test_size=0.2,\n",
    "                random_state=42)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Shape of training set: (455, 30)\n",
      "Shape of test set: (114, 30)\n"
     ]
    }
   ],
   "source": [
    "print(\"Shape of training set:\", x_train.shape)\n",
    "print(\"Shape of test set:\", x_test.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "204    0\n",
       "70     1\n",
       "131    1\n",
       "431    0\n",
       "540    0\n",
       "      ..\n",
       "486    0\n",
       "75     1\n",
       "249    0\n",
       "238    0\n",
       "265    1\n",
       "Name: diagnosis, Length: 114, dtype: int64"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "y_test"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[9.029e+00, 1.733e+01, 5.879e+01, ..., 1.750e-01, 4.228e-01,\n",
       "        1.175e-01],\n",
       "       [2.109e+01, 2.657e+01, 1.427e+02, ..., 2.903e-01, 4.098e-01,\n",
       "        1.284e-01],\n",
       "       [9.173e+00, 1.386e+01, 5.920e+01, ..., 5.087e-02, 3.282e-01,\n",
       "        8.490e-02],\n",
       "       ...,\n",
       "       [1.429e+01, 1.682e+01, 9.030e+01, ..., 3.333e-02, 2.458e-01,\n",
       "        6.120e-02],\n",
       "       [1.398e+01, 1.962e+01, 9.112e+01, ..., 1.827e-01, 3.179e-01,\n",
       "        1.055e-01],\n",
       "       [1.218e+01, 2.052e+01, 7.722e+01, ..., 7.431e-02, 2.694e-01,\n",
       "        6.878e-02]])"
      ]
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "traindata=x_train.to_numpy()\n",
    "traindata"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 1, 1, 0, 0, 1, 1, 1, 0, 0, 0, 1,\n",
       "       0, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 1, 1, 0, 1, 0, 0, 0, 0, 1, 1, 0,\n",
       "       0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0,\n",
       "       0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0,\n",
       "       1, 0, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 1, 1,\n",
       "       0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0,\n",
       "       1, 0, 1, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 0, 0, 1, 0, 0, 0,\n",
       "       0, 1, 0, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0,\n",
       "       0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 1, 0, 0, 1, 0, 1, 1, 1, 0, 0, 0, 1,\n",
       "       0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 1, 1, 0, 0, 1, 0, 1, 1, 0,\n",
       "       1, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0,\n",
       "       0, 0, 0, 1, 1, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 1, 1, 0, 1, 0, 1,\n",
       "       0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 1,\n",
       "       1, 1, 0, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0,\n",
       "       0, 1, 1, 0, 1, 0, 1, 1, 0, 0, 1, 0, 1, 1, 0, 1, 1, 0, 0, 1, 0, 1,\n",
       "       0, 0, 1, 0, 0, 1, 1, 1, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 1, 0, 1,\n",
       "       1, 1, 1, 0, 0, 1, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1,\n",
       "       1, 1, 1, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0,\n",
       "       0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 0, 0,\n",
       "       1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0,\n",
       "       0, 1, 1, 1, 0, 1, 1, 0, 1, 0, 0, 0, 0, 1, 0], dtype=int64)"
      ]
     },
     "execution_count": 17,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "trainlabel=y_train.to_numpy()\n",
    "trainlabel"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "455"
      ]
     },
     "execution_count": 18,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "x_train.shape[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Count of B: 286\n",
      "Count of M: 169\n"
     ]
    }
   ],
   "source": [
    "ClassB=[]\n",
    "ClassM=[]\n",
    "ClassB_label=[]\n",
    "ClassM_label=[]\n",
    "CountM=0\n",
    "CountB=0\n",
    "for a in range(x_train.shape[0]):\n",
    "    if(trainlabel[a]==0):\n",
    "        #print(\"B\")\n",
    "        #print(traindata[0])\n",
    "        ClassB.append(traindata[a])\n",
    "        ClassB_label.append(trainlabel[a])\n",
    "        CountB=CountB+1\n",
    "    else:\n",
    "        #print(\"M\")\n",
    "        ClassM.append(traindata[a])\n",
    "        ClassM_label.append(trainlabel[a])\n",
    "        CountM=CountM+1\n",
    "print(\"Count of B:\", CountB)\n",
    "print(\"Count of M:\", CountM)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array(['radius_mean', 'texture_mean', 'perimeter_mean', 'area_mean',\n",
       "       'smoothness_mean', 'compactness_mean', 'concavity_mean',\n",
       "       'concave points_mean', 'symmetry_mean', 'fractal_dimension_mean',\n",
       "       'radius_se', 'texture_se', 'perimeter_se', 'area_se',\n",
       "       'smoothness_se', 'compactness_se', 'concavity_se',\n",
       "       'concave points_se', 'symmetry_se', 'fractal_dimension_se',\n",
       "       'radius_worst', 'texture_worst', 'perimeter_worst', 'area_worst',\n",
       "       'smoothness_worst', 'compactness_worst', 'concavity_worst',\n",
       "       'concave points_worst', 'symmetry_worst',\n",
       "       'fractal_dimension_worst'], dtype=object)"
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "x_train.columns.values"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "204    0\n",
       "70     1\n",
       "131    1\n",
       "431    0\n",
       "540    0\n",
       "      ..\n",
       "486    0\n",
       "75     1\n",
       "249    0\n",
       "238    0\n",
       "265    1\n",
       "Name: diagnosis, Length: 114, dtype: int64"
      ]
     },
     "execution_count": 23,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "y_test"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[1.247e+01, 1.860e+01, 8.109e+01, ..., 1.015e-01, 3.014e-01,\n",
       "        8.750e-02],\n",
       "       [1.894e+01, 2.131e+01, 1.236e+02, ..., 1.789e-01, 2.551e-01,\n",
       "        6.589e-02],\n",
       "       [1.546e+01, 1.948e+01, 1.017e+02, ..., 1.514e-01, 2.837e-01,\n",
       "        8.019e-02],\n",
       "       ...,\n",
       "       [1.152e+01, 1.493e+01, 7.387e+01, ..., 9.608e-02, 2.664e-01,\n",
       "        7.809e-02],\n",
       "       [1.422e+01, 2.785e+01, 9.255e+01, ..., 8.219e-02, 1.890e-01,\n",
       "        7.796e-02],\n",
       "       [2.073e+01, 3.112e+01, 1.357e+02, ..., 1.659e-01, 2.868e-01,\n",
       "        8.218e-02]])"
      ]
     },
     "execution_count": 25,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "testdata=x_test.to_numpy()\n",
    "testdata"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "radius_mean                  18.940000\n",
       "texture_mean                 21.310000\n",
       "perimeter_mean              123.600000\n",
       "area_mean                  1130.000000\n",
       "smoothness_mean               0.090090\n",
       "compactness_mean              0.102900\n",
       "concavity_mean                0.108000\n",
       "concave points_mean           0.079510\n",
       "symmetry_mean                 0.158200\n",
       "fractal_dimension_mean        0.054610\n",
       "radius_se                     0.788800\n",
       "texture_se                    0.797500\n",
       "perimeter_se                  5.486000\n",
       "area_se                      96.050000\n",
       "smoothness_se                 0.004444\n",
       "compactness_se                0.016520\n",
       "concavity_se                  0.022690\n",
       "concave points_se             0.013700\n",
       "symmetry_se                   0.013860\n",
       "fractal_dimension_se          0.001698\n",
       "radius_worst                 24.860000\n",
       "texture_worst                26.580000\n",
       "perimeter_worst             165.900000\n",
       "area_worst                 1866.000000\n",
       "smoothness_worst              0.119300\n",
       "compactness_worst             0.233600\n",
       "concavity_worst               0.268700\n",
       "concave points_worst          0.178900\n",
       "symmetry_worst                0.255100\n",
       "fractal_dimension_worst       0.065890\n",
       "Name: 70, dtype: float64"
      ]
     },
     "execution_count": 26,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "x_test.iloc[1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([0, 1, 1, 0, 0, 1, 1, 1, 0, 0, 0, 1, 0, 1, 0, 1, 0, 0, 0, 1, 1, 0,\n",
       "       1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0,\n",
       "       0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0,\n",
       "       1, 1, 0, 0, 1, 1, 0, 1, 0, 0, 0, 1, 0, 0, 1, 0, 1, 1, 1, 1, 1, 1,\n",
       "       0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 0, 0, 1, 0, 0,\n",
       "       1, 0, 0, 1], dtype=int64)"
      ]
     },
     "execution_count": 27,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "testlabel=y_test.to_numpy()\n",
    "testlabel"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model Coefficients: [[-1.25331611e+00 -9.31837772e-02  1.44106190e-01  6.63399105e-04\n",
      "   2.56405200e-01  2.79869326e-01  6.74715553e-01  3.99430405e-01\n",
      "   3.43762786e-01  4.14958594e-02  9.71676672e-02 -1.60400066e+00\n",
      "   1.41590121e-02  6.79481179e-02  5.04695432e-02 -6.10008641e-02\n",
      "   7.38162751e-02  5.21197185e-02  5.20320385e-02 -1.66884827e-02\n",
      "   9.39684673e-02  2.83385734e-01 -1.91574109e-02  5.61291849e-03\n",
      "   4.67786245e-01  8.99706203e-01  1.72568330e+00  6.32677454e-01\n",
      "   1.19681735e+00  1.24953982e-01]]\n",
      "Intercept [-7.75940226]\n",
      "[[1.441e+01 1.973e+01 9.603e+01 ... 1.021e-01 2.272e-01 8.799e-02]\n",
      " [1.474e+01 2.542e+01 9.470e+01 ... 1.095e-01 2.722e-01 6.956e-02]\n",
      " [1.469e+01 1.398e+01 9.822e+01 ... 1.108e-01 2.827e-01 9.208e-02]\n",
      " ...\n",
      " [1.460e+01 2.329e+01 9.397e+01 ... 1.359e-01 2.477e-01 6.836e-02]\n",
      " [1.442e+01 1.977e+01 9.448e+01 ... 1.565e-01 2.718e-01 9.353e-02]\n",
      " [1.419e+01 2.381e+01 9.287e+01 ... 1.772e-01 4.724e-01 1.026e-01]]\n"
     ]
    }
   ],
   "source": [
    "import scipy\n",
    "import scipy.linalg\n",
    "from sklearn.svm import SVC\n",
    "\n",
    "model=SVC(kernel = \"linear\")\n",
    "model.fit(x_train, y_train)\n",
    "\n",
    "Theta_orig=model.coef_\n",
    "Intercept_orig=model.intercept_\n",
    "dfpred_orig=model.predict(x_test)\n",
    "\n",
    "print(\"Model Coefficients:\", Theta_orig)\n",
    "print(\"Intercept\", Intercept_orig)\n",
    "support_vectors_orig=model.support_vectors_\n",
    "print(support_vectors_orig)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "              precision    recall  f1-score   support\n",
      "\n",
      "           0      0.946     0.986     0.966        71\n",
      "           1      0.975     0.907     0.940        43\n",
      "\n",
      "    accuracy                          0.956       114\n",
      "   macro avg      0.960     0.946     0.953       114\n",
      "weighted avg      0.957     0.956     0.956       114\n",
      "\n"
     ]
    }
   ],
   "source": [
    "from sklearn.metrics import classification_report\n",
    "print(classification_report(y_test, dfpred_orig, digits=3))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Accuracy of SVM model is:  0.956140350877193\n",
      "The number of wrong classified sample : 5\n"
     ]
    }
   ],
   "source": [
    "from sklearn.metrics import accuracy_score\n",
    "svm_acc = accuracy_score((y_test), dfpred_orig)\n",
    "print(\"Accuracy of SVM model is: \", svm_acc)\n",
    "print('The number of wrong classified sample :', ((y_test) != dfpred_orig).sum())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "metadata": {},
   "outputs": [],
   "source": [
    "model_rbf=SVC(kernel = \"rbf\")\n",
    "model_rbf.fit(x_train, y_train)\n",
    "\n",
    "dfpred_rbf=model_rbf.predict(x_test)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "              precision    recall  f1-score   support\n",
      "\n",
      "           0      0.922     1.000     0.959        71\n",
      "           1      1.000     0.860     0.925        43\n",
      "\n",
      "    accuracy                          0.947       114\n",
      "   macro avg      0.961     0.930     0.942       114\n",
      "weighted avg      0.951     0.947     0.946       114\n",
      "\n"
     ]
    }
   ],
   "source": [
    "from sklearn.metrics import classification_report\n",
    "print(classification_report(y_test, dfpred_rbf, digits=3))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Accuracy of SVM model is:  0.9473684210526315\n",
      "The number of wrong classified sample : 6\n"
     ]
    }
   ],
   "source": [
    "from sklearn.metrics import accuracy_score\n",
    "svm_acc = accuracy_score((y_test), dfpred_rbf)\n",
    "print(\"Accuracy of SVM model is: \", svm_acc)\n",
    "print('The number of wrong classified sample :', ((y_test) != dfpred_rbf).sum())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "metadata": {},
   "outputs": [],
   "source": [
    "model_sigmoid=SVC(kernel = \"sigmoid\")\n",
    "model_sigmoid.fit(x_train, y_train)\n",
    "\n",
    "dfpred_sigmoid=model_sigmoid.predict(x_test)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "              precision    recall  f1-score   support\n",
      "\n",
      "           0      0.560     0.662     0.606        71\n",
      "           1      0.200     0.140     0.164        43\n",
      "\n",
      "    accuracy                          0.465       114\n",
      "   macro avg      0.380     0.401     0.385       114\n",
      "weighted avg      0.424     0.465     0.440       114\n",
      "\n"
     ]
    }
   ],
   "source": [
    "from sklearn.metrics import classification_report\n",
    "print(classification_report(y_test, dfpred_sigmoid, digits=3))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Accuracy of SVM model is:  0.4649122807017544\n",
      "The number of wrong classified sample : 61\n"
     ]
    }
   ],
   "source": [
    "from sklearn.metrics import accuracy_score\n",
    "svm_acc = accuracy_score((y_test), dfpred_sigmoid)\n",
    "print(\"Accuracy of SVM model is: \", svm_acc)\n",
    "print('The number of wrong classified sample :', ((y_test) != dfpred_sigmoid).sum())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "metadata": {},
   "outputs": [],
   "source": [
    "model_poly=SVC(kernel = \"poly\")\n",
    "model_poly.fit(x_train, y_train)\n",
    "\n",
    "dfpred_poly=model_poly.predict(x_test)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "              precision    recall  f1-score   support\n",
      "\n",
      "           0      0.922     1.000     0.959        71\n",
      "           1      1.000     0.860     0.925        43\n",
      "\n",
      "    accuracy                          0.947       114\n",
      "   macro avg      0.961     0.930     0.942       114\n",
      "weighted avg      0.951     0.947     0.946       114\n",
      "\n"
     ]
    }
   ],
   "source": [
    "from sklearn.metrics import classification_report\n",
    "print(classification_report(y_test, dfpred_poly, digits=3))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Accuracy of SVM model is:  0.9473684210526315\n",
      "The number of wrong classified sample : 6\n"
     ]
    }
   ],
   "source": [
    "from sklearn.metrics import accuracy_score\n",
    "svm_acc = accuracy_score((y_test), dfpred_poly)\n",
    "print(\"Accuracy of SVM model is: \", svm_acc)\n",
    "print('The number of wrong classified sample :', ((y_test) != dfpred_poly).sum())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Training data class B count: 286\n",
      "Training data class M count: 169\n",
      "Model Coefficients: [[-0.00444342  0.00150206  0.00142288  0.00987608  0.01035925 -0.01761552\n",
      "  -0.02222059 -0.00904124  0.007263   -0.00877202 -0.00151791 -0.00524111\n",
      "  -0.00012943  0.01756293 -0.00757828  0.0020328   0.0051842   0.01254015\n",
      "   0.00691232 -0.00418919 -0.01097074  0.00367162  0.00443928 -0.0020065\n",
      "  -0.01079598  0.00876844  0.01357408 -0.00176712 -0.00175069  0.00328569]]\n",
      "Intercept [0.03516048]\n",
      "(1, 30)\n"
     ]
    }
   ],
   "source": [
    "#Now calculating by first finding the coefficients of the decision boundary for training data in transformed space  \n",
    "import scipy\n",
    "import scipy.linalg\n",
    "from sklearn.svm import SVC\n",
    "predict=[]\n",
    "test_dataset=[]\n",
    "\n",
    "trainB=ClassB.copy()\n",
    "trainM=ClassM.copy()\n",
    "\n",
    "dataB=pd.DataFrame(trainB)\n",
    "dataM=pd.DataFrame(trainM)\n",
    "\n",
    "#Cholesky decomposition of covariance matrix of class B where L is lower trialgular Matrix and U is Upper Triangular\n",
    "CovMatrixB=dataB.cov()\n",
    "#CovMatrixB=np.identity(30)\n",
    "LB = scipy.linalg.cholesky(CovMatrixB, lower=True)\n",
    "dfLB=pd.DataFrame(LB)\n",
    "LB_upper = scipy.linalg.cholesky(CovMatrixB, lower=False)\n",
    "dfLB_upper=pd.DataFrame(LB_upper)\n",
    "LBinv=np.linalg.inv(LB)\n",
    "#LBinv=np.identity(30)\n",
    "trainBtranspose=np.transpose(trainB)\n",
    "prodB = np.matmul(LBinv, trainBtranspose)\n",
    "prodBtranspose=np.transpose(prodB)\n",
    "dfLBinv=pd.DataFrame(LBinv)\n",
    "\n",
    "#Cholesky decomposition of covariance matrix of class M where L is lower trialgular Matrix and U is Upper Triangular\n",
    "CovMatrixM=dataM.cov()\n",
    "#print(\"CovMatrixM\",CovMatrixM)\n",
    "#CovMatrixM=np.identity(30)\n",
    "LM = scipy.linalg.cholesky(CovMatrixM, lower=True)\n",
    "dfLM=pd.DataFrame(LM)\n",
    "\n",
    "LM_upper = scipy.linalg.cholesky(CovMatrixM, lower=False)\n",
    "dfLM_upper=pd.DataFrame(LM_upper)\n",
    "#LMinv=np.identity(30)\n",
    "trainMtranspose=np.transpose(trainM)\n",
    "prodM = np.matmul(LMinv, trainMtranspose)\n",
    "prodMtranspose=np.transpose(prodM)\n",
    "dfLMinv=pd.DataFrame(LMinv)\n",
    "\n",
    "tottrain=[]\n",
    "tottrainlabel=[]\n",
    "tottest=[]\n",
    "tottestlabel=[]\n",
    "tot=[]\n",
    "Test_countB=0\n",
    "Test_countM=0\n",
    "Train_countB=0\n",
    "Train_countM=0\n",
    "    \n",
    "for k in range(len(ClassB)):\n",
    "    tottrain.append(prodBtranspose[k])\n",
    "#        tottrainlabel[k]=[\"B\"]\n",
    "    Train_countB=Train_countB+1\n",
    "for k in range(len(ClassM)):\n",
    "    tottrain.append(prodMtranspose[k])\n",
    "#        tottrainlabel[k]=[\"M\"]\n",
    "    Train_countM=Train_countM+1\n",
    "\n",
    "    \n",
    "print(\"Training data class B count:\",Train_countB)\n",
    "print(\"Training data class M count:\",Train_countM)\n",
    "\n",
    "model=SVC(kernel = \"linear\")\n",
    "model.fit(tottrain, np.sort(trainlabel))\n",
    "\n",
    "Theta=model.coef_\n",
    "Intercept=model.intercept_\n",
    "#dfpred1=model.predict(tottest)\n",
    "\n",
    "print(\"Model Coefficients:\", Theta)\n",
    "print(\"Intercept\", Intercept)\n",
    "print(Theta.shape)\n",
    "\n",
    "#y_pred01=model.predict(prodtesttranspose11)\n",
    "#print(\"predicted y:\", y_pred01)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Margin of B is: [[175.8934257]]\n",
      "Margin of M is: [[230.59618844]]\n",
      "value of k is 0.8733709480913453\n",
      "Value of p is 0.06759422208274807\n"
     ]
    }
   ],
   "source": [
    "import math\n",
    "InvCovMatrixB=np.linalg.inv(CovMatrixB)\n",
    "MarginB=np.matmul(Theta,np.matmul(np.linalg.inv(CovMatrixB),np.transpose(Theta)))\n",
    "print(\"Margin of B is:\", MarginB)\n",
    "MarginM=np.matmul(Theta,np.matmul(np.linalg.inv(CovMatrixM),np.transpose(Theta)))\n",
    "print(\"Margin of M is:\", MarginM)\n",
    "k=math.sqrt(MarginB/MarginM)\n",
    "print(\"value of k is\", k)\n",
    "p=(1-k)/(1+k)\n",
    "print(\"Value of p is\", p)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Dim Class B: (286, 30)\n",
      "CountBStart 286\n",
      "CountMStart 169\n",
      "Dim of DFB: (286, 30)\n",
      "Dim of DFM: (169, 30)\n",
      "Training data class B count: 286\n",
      "Training data class M count: 169\n",
      "Training data array dimensions: (455, 30)\n",
      "Training label array dimensions: (455,)\n",
      "Model Coefficients: [[-0.00441915  0.00148683  0.00141083  0.0098455   0.0103631  -0.01757403\n",
      "  -0.02216989 -0.00901866  0.00722466 -0.00870728 -0.00150523 -0.00525416\n",
      "  -0.00012397  0.01754476 -0.00755163  0.00201897  0.00516501  0.01250055\n",
      "   0.00691436 -0.00420351 -0.01093044  0.00366246  0.00441863 -0.00199613\n",
      "  -0.01077654  0.00875534  0.01354002 -0.0017803  -0.00176786  0.0032769 ]]\n",
      "Intercept [0.03196374]\n",
      "(1, 30)\n",
      "Margin of B is: [[0.00569346]]\n",
      "Margin of M is: [[0.00431499]]\n",
      "value of k is [[1.31946136]]\n",
      "Value of p is [[-0.13773084]]\n",
      "Inter Count B 286\n",
      "Inter Count M 169\n",
      "Test Data array dimensions: (114, 30)\n",
      "CountBfinish 359\n",
      "CountMFinish 210\n",
      "CountBStart 359\n",
      "CountMStart 210\n",
      "Dim of DFB: (359, 30)\n",
      "Dim of DFM: (210, 30)\n",
      "Training data class B count: 286\n",
      "Training data class M count: 169\n",
      "Training data array dimensions: (455, 30)\n",
      "Training label array dimensions: (455,)\n",
      "Model Coefficients: [[-5.08460440e-03  1.15223976e-03  1.83150256e-03  8.46032854e-03\n",
      "   1.12497348e-02 -1.84037667e-02 -2.13018253e-02 -8.21491150e-03\n",
      "   2.98297857e-03 -9.85329827e-03 -2.57922522e-06 -8.95235905e-03\n",
      "   3.39255715e-04  1.83389068e-02 -7.51017688e-03  3.43405720e-03\n",
      "   8.49442245e-03  1.21303973e-02 -6.77755068e-04 -4.94644665e-03\n",
      "  -1.42287345e-02  8.64606803e-03  3.83328226e-03 -6.78304957e-03\n",
      "  -8.47356685e-03  1.32111955e-02  1.04460780e-02 -7.48556756e-03\n",
      "  -1.14247624e-03  6.53173917e-03]]\n",
      "Intercept [-0.00293302]\n",
      "(1, 30)\n",
      "Margin of B is: [[0.00509277]]\n",
      "Margin of M is: [[0.00360976]]\n",
      "value of k is [[1.4108311]]\n",
      "Value of p is [[-0.17041057]]\n",
      "Inter Count B 286\n",
      "Inter Count M 169\n",
      "Test Data array dimensions: (114, 30)\n",
      "CountBfinish 358\n",
      "CountMFinish 211\n",
      "CountBStart 358\n",
      "CountMStart 211\n",
      "Dim of DFB: (358, 30)\n",
      "Dim of DFM: (211, 30)\n",
      "Training data class B count: 286\n",
      "Training data class M count: 169\n",
      "Training data array dimensions: (455, 30)\n",
      "Training label array dimensions: (455,)\n",
      "Model Coefficients: [[-0.00473799  0.00126369  0.00168563  0.00878414  0.01116941 -0.01825931\n",
      "  -0.02131698 -0.00821115  0.0027958  -0.00996346 -0.00018632 -0.00922744\n",
      "   0.00022465  0.01834797 -0.00745921  0.0031225   0.00850876  0.01238919\n",
      "  -0.00060778 -0.00501286 -0.01435453  0.00818725  0.00447331 -0.0068424\n",
      "  -0.00812115  0.01323018  0.01054667 -0.00612035 -0.00169392  0.00699152]]\n",
      "Intercept [0.00100459]\n",
      "(1, 30)\n",
      "Margin of B is: [[0.00498977]]\n",
      "Margin of M is: [[0.00351497]]\n",
      "value of k is [[1.4195773]]\n",
      "Value of p is [[-0.17340934]]\n",
      "Inter Count B 286\n",
      "Inter Count M 169\n",
      "Test Data array dimensions: (114, 30)\n",
      "CountBfinish 358\n",
      "CountMFinish 211\n",
      "CountBStart 358\n",
      "CountMStart 211\n",
      "Dim of DFB: (358, 30)\n",
      "Dim of DFM: (211, 30)\n",
      "Training data class B count: 286\n",
      "Training data class M count: 169\n",
      "Training data array dimensions: (455, 30)\n",
      "Training label array dimensions: (455,)\n",
      "Model Coefficients: [[-0.00473799  0.00126369  0.00168563  0.00878414  0.01116941 -0.01825931\n",
      "  -0.02131698 -0.00821115  0.0027958  -0.00996346 -0.00018632 -0.00922744\n",
      "   0.00022465  0.01834797 -0.00745921  0.0031225   0.00850876  0.01238919\n",
      "  -0.00060778 -0.00501286 -0.01435453  0.00818725  0.00447331 -0.0068424\n",
      "  -0.00812115  0.01323018  0.01054667 -0.00612035 -0.00169392  0.00699152]]\n",
      "Intercept [0.00100459]\n",
      "(1, 30)\n",
      "Margin of B is: [[0.00498977]]\n",
      "Margin of M is: [[0.00351497]]\n",
      "value of k is [[1.4195773]]\n",
      "Value of p is [[-0.17340934]]\n",
      "Inter Count B 286\n",
      "Inter Count M 169\n",
      "Test Data array dimensions: (114, 30)\n",
      "CountBfinish 358\n",
      "CountMFinish 211\n",
      "CountBStart 358\n",
      "CountMStart 211\n",
      "Dim of DFB: (358, 30)\n",
      "Dim of DFM: (211, 30)\n",
      "Training data class B count: 286\n",
      "Training data class M count: 169\n",
      "Training data array dimensions: (455, 30)\n",
      "Training label array dimensions: (455,)\n",
      "Model Coefficients: [[-0.00473799  0.00126369  0.00168563  0.00878414  0.01116941 -0.01825931\n",
      "  -0.02131698 -0.00821115  0.0027958  -0.00996346 -0.00018632 -0.00922744\n",
      "   0.00022465  0.01834797 -0.00745921  0.0031225   0.00850876  0.01238919\n",
      "  -0.00060778 -0.00501286 -0.01435453  0.00818725  0.00447331 -0.0068424\n",
      "  -0.00812115  0.01323018  0.01054667 -0.00612035 -0.00169392  0.00699152]]\n",
      "Intercept [0.00100459]\n",
      "(1, 30)\n",
      "Margin of B is: [[0.00498977]]\n",
      "Margin of M is: [[0.00351497]]\n",
      "value of k is [[1.4195773]]\n",
      "Value of p is [[-0.17340934]]\n",
      "Inter Count B 286\n",
      "Inter Count M 169\n",
      "Test Data array dimensions: (114, 30)\n",
      "CountBfinish 358\n",
      "CountMFinish 211\n",
      "CountBStart 358\n",
      "CountMStart 211\n",
      "Dim of DFB: (358, 30)\n",
      "Dim of DFM: (211, 30)\n",
      "Training data class B count: 286\n",
      "Training data class M count: 169\n",
      "Training data array dimensions: (455, 30)\n",
      "Training label array dimensions: (455,)\n",
      "Model Coefficients: [[-0.00473799  0.00126369  0.00168563  0.00878414  0.01116941 -0.01825931\n",
      "  -0.02131698 -0.00821115  0.0027958  -0.00996346 -0.00018632 -0.00922744\n",
      "   0.00022465  0.01834797 -0.00745921  0.0031225   0.00850876  0.01238919\n",
      "  -0.00060778 -0.00501286 -0.01435453  0.00818725  0.00447331 -0.0068424\n",
      "  -0.00812115  0.01323018  0.01054667 -0.00612035 -0.00169392  0.00699152]]\n",
      "Intercept [0.00100459]\n",
      "(1, 30)\n",
      "Margin of B is: [[0.00498977]]\n",
      "Margin of M is: [[0.00351497]]\n",
      "value of k is [[1.4195773]]\n",
      "Value of p is [[-0.17340934]]\n",
      "Inter Count B 286\n",
      "Inter Count M 169\n",
      "Test Data array dimensions: (114, 30)\n",
      "CountBfinish 358\n",
      "CountMFinish 211\n",
      "CountBStart 358\n",
      "CountMStart 211\n",
      "Dim of DFB: (358, 30)\n",
      "Dim of DFM: (211, 30)\n",
      "Training data class B count: 286\n",
      "Training data class M count: 169\n",
      "Training data array dimensions: (455, 30)\n",
      "Training label array dimensions: (455,)\n",
      "Model Coefficients: [[-0.00473799  0.00126369  0.00168563  0.00878414  0.01116941 -0.01825931\n",
      "  -0.02131698 -0.00821115  0.0027958  -0.00996346 -0.00018632 -0.00922744\n",
      "   0.00022465  0.01834797 -0.00745921  0.0031225   0.00850876  0.01238919\n",
      "  -0.00060778 -0.00501286 -0.01435453  0.00818725  0.00447331 -0.0068424\n",
      "  -0.00812115  0.01323018  0.01054667 -0.00612035 -0.00169392  0.00699152]]\n",
      "Intercept [0.00100459]\n",
      "(1, 30)\n",
      "Margin of B is: [[0.00498977]]\n",
      "Margin of M is: [[0.00351497]]\n",
      "value of k is [[1.4195773]]\n",
      "Value of p is [[-0.17340934]]\n",
      "Inter Count B 286\n",
      "Inter Count M 169\n",
      "Test Data array dimensions: (114, 30)\n",
      "CountBfinish 358\n",
      "CountMFinish 211\n",
      "CountBStart 358\n",
      "CountMStart 211\n",
      "Dim of DFB: (358, 30)\n",
      "Dim of DFM: (211, 30)\n",
      "Training data class B count: 286\n",
      "Training data class M count: 169\n",
      "Training data array dimensions: (455, 30)\n",
      "Training label array dimensions: (455,)\n",
      "Model Coefficients: [[-0.00473799  0.00126369  0.00168563  0.00878414  0.01116941 -0.01825931\n",
      "  -0.02131698 -0.00821115  0.0027958  -0.00996346 -0.00018632 -0.00922744\n",
      "   0.00022465  0.01834797 -0.00745921  0.0031225   0.00850876  0.01238919\n",
      "  -0.00060778 -0.00501286 -0.01435453  0.00818725  0.00447331 -0.0068424\n",
      "  -0.00812115  0.01323018  0.01054667 -0.00612035 -0.00169392  0.00699152]]\n",
      "Intercept [0.00100459]\n",
      "(1, 30)\n",
      "Margin of B is: [[0.00498977]]\n",
      "Margin of M is: [[0.00351497]]\n",
      "value of k is [[1.4195773]]\n",
      "Value of p is [[-0.17340934]]\n",
      "Inter Count B 286\n",
      "Inter Count M 169\n",
      "Test Data array dimensions: (114, 30)\n",
      "CountBfinish 358\n",
      "CountMFinish 211\n",
      "CountBStart 358\n",
      "CountMStart 211\n",
      "Dim of DFB: (358, 30)\n",
      "Dim of DFM: (211, 30)\n",
      "Training data class B count: 286\n",
      "Training data class M count: 169\n",
      "Training data array dimensions: (455, 30)\n",
      "Training label array dimensions: (455,)\n",
      "Model Coefficients: [[-0.00473799  0.00126369  0.00168563  0.00878414  0.01116941 -0.01825931\n",
      "  -0.02131698 -0.00821115  0.0027958  -0.00996346 -0.00018632 -0.00922744\n",
      "   0.00022465  0.01834797 -0.00745921  0.0031225   0.00850876  0.01238919\n",
      "  -0.00060778 -0.00501286 -0.01435453  0.00818725  0.00447331 -0.0068424\n",
      "  -0.00812115  0.01323018  0.01054667 -0.00612035 -0.00169392  0.00699152]]\n",
      "Intercept [0.00100459]\n",
      "(1, 30)\n",
      "Margin of B is: [[0.00498977]]\n",
      "Margin of M is: [[0.00351497]]\n",
      "value of k is [[1.4195773]]\n",
      "Value of p is [[-0.17340934]]\n",
      "Inter Count B 286\n",
      "Inter Count M 169\n",
      "Test Data array dimensions: (114, 30)\n",
      "CountBfinish 358\n",
      "CountMFinish 211\n",
      "CountBStart 358\n",
      "CountMStart 211\n",
      "Dim of DFB: (358, 30)\n",
      "Dim of DFM: (211, 30)\n",
      "Training data class B count: 286\n",
      "Training data class M count: 169\n",
      "Training data array dimensions: (455, 30)\n",
      "Training label array dimensions: (455,)\n",
      "Model Coefficients: [[-0.00473799  0.00126369  0.00168563  0.00878414  0.01116941 -0.01825931\n",
      "  -0.02131698 -0.00821115  0.0027958  -0.00996346 -0.00018632 -0.00922744\n",
      "   0.00022465  0.01834797 -0.00745921  0.0031225   0.00850876  0.01238919\n",
      "  -0.00060778 -0.00501286 -0.01435453  0.00818725  0.00447331 -0.0068424\n",
      "  -0.00812115  0.01323018  0.01054667 -0.00612035 -0.00169392  0.00699152]]\n",
      "Intercept [0.00100459]\n",
      "(1, 30)\n",
      "Margin of B is: [[0.00498977]]\n",
      "Margin of M is: [[0.00351497]]\n",
      "value of k is [[1.4195773]]\n",
      "Value of p is [[-0.17340934]]\n",
      "Inter Count B 286\n",
      "Inter Count M 169\n",
      "Test Data array dimensions: (114, 30)\n",
      "CountBfinish 358\n",
      "CountMFinish 211\n"
     ]
    }
   ],
   "source": [
    "#Now calculating by calculating expected training W and then transforming all data\n",
    "#now transforming all data to Euclidean space  \n",
    "import scipy\n",
    "import scipy.linalg\n",
    "import math\n",
    "\n",
    "#GlobalClass0=Class0.copy()\n",
    "#GlobalClass1=Class1.copy()\n",
    "#Counter0=Count0\n",
    "#Counter1=Count1\n",
    "\n",
    "DummyB=ClassB.copy()\n",
    "print(\"Dim Class B:\", np.shape(ClassB))\n",
    "DummyM=ClassM.copy()\n",
    "DCountB=CountB\n",
    "DCountM=CountM\n",
    "\n",
    "for alpha in range(10):\n",
    "    dataB=pd.DataFrame(DummyB)\n",
    "    dataM=pd.DataFrame(DummyM)\n",
    "    print(\"CountBStart\", DCountB)\n",
    "    print(\"CountMStart\", DCountM)\n",
    "    print(\"Dim of DFB:\", dataB.shape)\n",
    "    print(\"Dim of DFM:\", dataM.shape)\n",
    "\n",
    "    #Cholesky decomposition of covariance matrix of class B where L is lower trialgular Matrix and U is Upper Triangular\n",
    "    CovMatrixB=dataB.cov()*((DCountB-1)/DCountB)\n",
    "    LB = scipy.linalg.cholesky(CovMatrixB, lower=True)\n",
    "    LBinv=np.linalg.inv(LB)\n",
    "    trainBtranspose=np.transpose(DummyB)\n",
    "    prodB = np.matmul(LBinv, trainBtranspose)\n",
    "    prodBtranspose=np.transpose(prodB)\n",
    "\n",
    "    #Cholesky decomposition of covariance matrix of class M where L is lower trialgular Matrix and U is Upper Triangular\n",
    "    CovMatrixM=dataM.cov()*((DCountM-1)/DCountM)\n",
    "    LM = scipy.linalg.cholesky(CovMatrixM, lower=True)\n",
    "    LMinv=np.linalg.inv(LM)\n",
    "    trainMtranspose=np.transpose(DummyM)\n",
    "    prodM = np.matmul(LMinv, trainMtranspose)\n",
    "    prodMtranspose=np.transpose(prodM)\n",
    "   \n",
    "    tottrain=[]\n",
    "    tottrainlabel=[]\n",
    "    tottest=[]\n",
    "    tottestlabel=[]\n",
    "    tot=[]\n",
    "    Test_countB=0\n",
    "    Test_countM=0\n",
    "    Train_countB=0\n",
    "    Train_countM=0\n",
    "    \n",
    "    for k in range(len(ClassB)):\n",
    "        tottrain.append(prodBtranspose[k])\n",
    "        tottrainlabel.append(0)\n",
    "        Train_countB=Train_countB+1\n",
    "    for k in range(len(ClassM)):\n",
    "        tottrain.append(prodMtranspose[k])\n",
    "        tottrainlabel.append(1)\n",
    "        Train_countM=Train_countM+1\n",
    "\n",
    "    \n",
    "    print(\"Training data class B count:\",Train_countB)\n",
    "    print(\"Training data class M count:\",Train_countM)\n",
    "    print(\"Training data array dimensions:\", np.shape(tottrain))\n",
    "    print(\"Training label array dimensions:\", np.shape(tottrainlabel))\n",
    "    \n",
    "\n",
    "    model1=SVC(kernel = \"linear\")\n",
    "    #model.fit(tottrain, np.sort(trainlabel))\n",
    "    model1.fit(tottrain, tottrainlabel)\n",
    "    \n",
    "    Theta=model1.coef_\n",
    "    Intercept=model1.intercept_\n",
    "    #dfpred1=model.predict(tottest)\n",
    "\n",
    "    print(\"Model Coefficients:\", Theta)\n",
    "    print(\"Intercept\", Intercept)\n",
    "    print(Theta.shape)\n",
    "    \n",
    "    #MarginB=np.matmul(Theta,np.matmul(np.linalg.inv(CovMatrixB),np.transpose(Theta)))\n",
    "    MarginB=(1/np.matmul(Theta,np.matmul(np.linalg.inv(CovMatrixB),np.transpose(Theta))))\n",
    "    #MarginB=np.matmul(Theta_orig,np.matmul(np.linalg.inv(CovMatrixB),np.transpose(Theta_orig)))\n",
    "    print(\"Margin of B is:\", MarginB)\n",
    "    #MarginM=np.matmul(Theta,np.matmul(np.linalg.inv(CovMatrixM),np.transpose(Theta)))\n",
    "    MarginM=(1/np.matmul(Theta,np.matmul(np.linalg.inv(CovMatrixM),np.transpose(Theta))))\n",
    "    #MarginM=np.matmul(Theta_orig,np.matmul(np.linalg.inv(CovMatrixM),np.transpose(Theta_orig)))\n",
    "    print(\"Margin of M is:\", MarginM)\n",
    "    k=(MarginB/MarginM)\n",
    "    print(\"value of k is\", k)\n",
    "    Margin_orig=(2/math.sqrt(np.matmul(Theta_orig, np.transpose(Theta_orig))))\n",
    "    Half_Margin_orig=(1/math.sqrt(np.matmul(Theta_orig, np.transpose(Theta_orig))))\n",
    "    #p=(k-1)*Half_Margin_orig\n",
    "    #p=Margin_orig*(1/(k+1))-Half_Margin_orig\n",
    "    p=(1-k)/(1+k)\n",
    "    #p=(-math.sqrt(k)+1)/(-math.sqrt(k)-1)\n",
    "    #p=(1-math.sqrt(k))/(1+math.sqrt(k))\n",
    "    #p=(-2*(1+k)-4*math.sqrt(k))/(2*(1-k))\n",
    "    #p=(-2*(1+k)+4*math.sqrt(1/k))/(2*(k-1))\n",
    "    print(\"Value of p is\", p)\n",
    "    \n",
    "    DummyB=ClassB.copy() \n",
    "    DummyM=ClassM.copy()\n",
    "    \n",
    "    DCountB=CountB\n",
    "    DCountM=CountM\n",
    "    print(\"Inter Count B\",DCountB)\n",
    "    print(\"Inter Count M\",DCountM)\n",
    "    print(\"Test Data array dimensions:\", np.shape(testdata))\n",
    "    \n",
    "\n",
    "    for k in range(len(testdata)): \n",
    "        testdatatranspose1=np.transpose(testdata[k])\n",
    "        slope=np.matmul(Theta_orig,testdatatranspose1)\n",
    "        equation=slope+Intercept_orig-p #Here it can be -p or +p: Check for both the instances\n",
    "        #print(\"Eq value:\", equation)\n",
    "    \n",
    "        if(equation<=0):\n",
    "            DummyB.append(testdata[k])\n",
    "            DCountB=DCountB+1\n",
    "            tottestlabel.append(0)\n",
    "        else:\n",
    "            DummyM.append(testdata[k])\n",
    "            DCountM=DCountM+1\n",
    "            tottestlabel.append(1)\n",
    "            \n",
    "    print(\"CountBfinish\",DCountB)\n",
    "    print(\"CountMFinish\",DCountM)\n",
    "    \n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "              precision    recall  f1-score   support\n",
      "\n",
      "           0      0.972     0.986     0.979        71\n",
      "           1      0.976     0.953     0.965        43\n",
      "\n",
      "    accuracy                          0.974       114\n",
      "   macro avg      0.974     0.970     0.972       114\n",
      "weighted avg      0.974     0.974     0.974       114\n",
      "\n"
     ]
    }
   ],
   "source": [
    "from sklearn.metrics import classification_report\n",
    "print(classification_report(y_test, tottestlabel, digits=3))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Accuracy of SVM model is:  0.9736842105263158\n",
      "The number of wrong classified sample : 3\n"
     ]
    }
   ],
   "source": [
    "from sklearn.metrics import accuracy_score\n",
    "svm_acc = accuracy_score(y_test, tottestlabel)\n",
    "print(\"Accuracy of SVM model is: \", svm_acc)\n",
    "print('The number of wrong classified sample :', (y_test != tottestlabel).sum())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Accuracy\t:  0.9737\n",
      "Precision\t:  0.9742\n",
      "Recall\t\t:  0.9697\n"
     ]
    }
   ],
   "source": [
    "from sklearn.metrics import accuracy_score\n",
    "from sklearn.metrics import precision_score\n",
    "from sklearn.metrics import recall_score\n",
    "from sklearn.metrics import confusion_matrix\n",
    "from sklearn.metrics import classification_report\n",
    "from sklearn.model_selection import GridSearchCV\n",
    "print('Accuracy\\t: ', round(accuracy_score(y_test, tottestlabel),4))\n",
    "print('Precision\\t: ', round(precision_score(y_test, tottestlabel, average='macro'),4)) \n",
    "print('Recall\\t\\t: ', round(recall_score(y_test, tottestlabel, average='macro'),4))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{0: 0, 1: 1}"
      ]
     },
     "execution_count": 47,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "from sklearn.preprocessing import LabelEncoder\n",
    "from sklearn.preprocessing import OrdinalEncoder\n",
    "from sklearn.preprocessing import OneHotEncoder\n",
    "\n",
    "le = LabelEncoder()\n",
    "le.fit(y_train)\n",
    "\n",
    "species_name = dict(zip([0,1], le.classes_))\n",
    "species_name"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "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>0</th>\n",
       "      <th>1</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>70</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>2</td>\n",
       "      <td>41</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "    0   1\n",
       "0  70   1\n",
       "1   2  41"
      ]
     },
     "execution_count": 48,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "cm = confusion_matrix(y_test, tottestlabel)\n",
    "df_cm = pd.DataFrame(cm)\n",
    "df_cm.rename(columns=species_name, index=species_name, inplace=True)\n",
    "df_cm"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 576x576 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(figsize=(8,8))\n",
    "sns.heatmap(df_cm, fmt='.0f',\n",
    "            cmap='YlGnBu', linewidth=1,\n",
    "            square=True, annot=True, annot_kws={'fontsize':16}, ax=ax)\n",
    "\n",
    "ax.set_xlabel('Prediction')\n",
    "ax.set_ylabel('Actual')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "from sklearn.decomposition import PCA\n",
    "from sklearn.preprocessing import StandardScaler\n",
    "\n",
    "# Assume X is your feature matrix\n",
    "# X = ... (your data)\n",
    "\n",
    "# Step 1: Standardize the data (mean 0, variance 1)\n",
    "scaler = StandardScaler()\n",
    "X_scaled = scaler.fit_transform(irisdata)\n",
    "\n",
    "# Step 2: Apply PCA for decorrelation and whitening\n",
    "# n_components can be set to the number of features or a smaller value for dimensionality reduction\n",
    "pca = PCA(whiten=True) # whiten=True performs whitening\n",
    "X_whitened = pca.fit_transform(X_scaled)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "SVM Accuracy with Whitened Data: 0.95\n"
     ]
    }
   ],
   "source": [
    "from sklearn.svm import SVC\n",
    "from sklearn.model_selection import train_test_split\n",
    "from sklearn.metrics import accuracy_score\n",
    "\n",
    "# Assume y is your target variable\n",
    "# y = ... (your labels)\n",
    "\n",
    "# Split data into training and testing sets\n",
    "X_train, X_test, Y_train, Y_test = train_test_split(X_whitened, iris_y, test_size=0.2, random_state=42)\n",
    "\n",
    "# Initialize and train the SVM classifier\n",
    "svm_classifier = SVC(kernel='linear', C=1.0, random_state=42) # You can choose different kernels and parameters\n",
    "svm_classifier.fit(X_train, Y_train)\n",
    "\n",
    "# Make predictions on the test set\n",
    "Y_pred = svm_classifier.predict(X_test)\n",
    "\n",
    "# Evaluate the model\n",
    "accuracy = accuracy_score(Y_test, Y_pred)\n",
    "print(f\"SVM Accuracy with Whitened Data: {accuracy:.2f}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 52,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "              precision    recall  f1-score   support\n",
      "\n",
      "           0      0.945     0.972     0.958        71\n",
      "           1      0.951     0.907     0.929        43\n",
      "\n",
      "    accuracy                          0.947       114\n",
      "   macro avg      0.948     0.939     0.943       114\n",
      "weighted avg      0.947     0.947     0.947       114\n",
      "\n"
     ]
    }
   ],
   "source": [
    "from sklearn.metrics import classification_report\n",
    "print(classification_report(Y_test, Y_pred, digits=3))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 53,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Accuracy of SVM model is:  0.9473684210526315\n",
      "The number of wrong classified sample : 6\n"
     ]
    }
   ],
   "source": [
    "from sklearn.metrics import accuracy_score\n",
    "svm_acc = accuracy_score(Y_test, Y_pred)\n",
    "print(\"Accuracy of SVM model is: \", svm_acc)\n",
    "print('The number of wrong classified sample :', (Y_test != Y_pred).sum())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "metadata": {},
   "outputs": [],
   "source": [
    "def zca_whitening(data, epsilon=1e-5):\n",
    "    sigma=np.cov(data, rowvar=False)\n",
    "    U,S,V=np.linalg.svd(sigma)\n",
    "    \n",
    "    zca_matrix=np.dot(U, np.dot(np.diag(1.0/np.sqrt(S+epsilon)),U.T))\n",
    "    whitened_data=np.dot(data, zca_matrix)\n",
    "    return whitened_data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 55,
   "metadata": {},
   "outputs": [],
   "source": [
    "X_whitened_zca = zca_whitening(irisdata)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 56,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "SVM Accuracy with Whitened Data: 0.94\n"
     ]
    }
   ],
   "source": [
    "from sklearn.svm import SVC\n",
    "from sklearn.model_selection import train_test_split\n",
    "from sklearn.metrics import accuracy_score\n",
    "\n",
    "# Assume y is your target variable\n",
    "# y = ... (your labels)\n",
    "\n",
    "# Split data into training and testing sets\n",
    "X_train_zca, X_test_zca, Y_train_zca, Y_test_zca = train_test_split(X_whitened_zca, iris_y, test_size=0.2, random_state=42)\n",
    "\n",
    "# Initialize and train the SVM classifier\n",
    "svm_classifier = SVC(kernel='linear', C=1.0, random_state=42) # You can choose different kernels and parameters\n",
    "svm_classifier.fit(X_train_zca, Y_train_zca)\n",
    "\n",
    "# Make predictions on the test set\n",
    "Y_pred_zca = svm_classifier.predict(X_test_zca)\n",
    "\n",
    "# Evaluate the model\n",
    "accuracy = accuracy_score(Y_test_zca, Y_pred_zca)\n",
    "print(f\"SVM Accuracy with Whitened Data: {accuracy:.2f}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 57,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "              precision    recall  f1-score   support\n",
      "\n",
      "           0      0.944     0.958     0.951        71\n",
      "           1      0.929     0.907     0.918        43\n",
      "\n",
      "    accuracy                          0.939       114\n",
      "   macro avg      0.937     0.932     0.934       114\n",
      "weighted avg      0.938     0.939     0.938       114\n",
      "\n"
     ]
    }
   ],
   "source": [
    "from sklearn.metrics import classification_report\n",
    "print(classification_report(Y_test_zca, Y_pred_zca, digits=3))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 58,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Accuracy of SVM model is:  0.9385964912280702\n",
      "The number of wrong classified sample : 7\n"
     ]
    }
   ],
   "source": [
    "from sklearn.metrics import accuracy_score\n",
    "svm_acc = accuracy_score(Y_test_zca, Y_pred_zca)\n",
    "print(\"Accuracy of SVM model is: \", svm_acc)\n",
    "print('The number of wrong classified sample :', (Y_test_zca != Y_pred_zca).sum())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 59,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([0, 1, 1, 0, 0, 1, 1, 1, 0, 0, 0, 1, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0,\n",
       "       1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0,\n",
       "       0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, 0,\n",
       "       1, 1, 0, 0, 1, 1, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 1, 1, 1, 1,\n",
       "       0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 0, 0, 1, 0, 0,\n",
       "       1, 0, 1, 1], dtype=int64)"
      ]
     },
     "execution_count": 59,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dfpred_orig"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 60,
   "metadata": {},
   "outputs": [],
   "source": [
    "test_df = pd.DataFrame({'True': y_test, 'Linear': dfpred_orig, 'RBF': dfpred_rbf, 'Sigmoid': dfpred_sigmoid, 'Polynomial': dfpred_poly, 'CSVM-Cholesky': tottestlabel, 'PCA Whitening':Y_pred, 'ZCA Whitening':Y_pred_zca})"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 61,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 504x360 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "from sklearn.metrics import roc_curve, auc\n",
    "plt.figure(figsize=(7, 5))\n",
    "\n",
    "for model in ['Linear', 'RBF', 'Sigmoid', 'Polynomial', 'CSVM-Cholesky', 'PCA Whitening', 'ZCA Whitening']:\n",
    "    fpr, tpr, _ = roc_curve(test_df['True'], test_df[model])\n",
    "    roc_auc = auc(fpr, tpr)\n",
    "    plt.plot(fpr, tpr, label=f'{model} (AUC = {roc_auc:.2f})')\n",
    "\n",
    "plt.plot([0, 1], [0, 1], 'r--', label='Random Guess')\n",
    "\n",
    "plt.xlabel('False Positive Rate')\n",
    "plt.ylabel('True Positive Rate')\n",
    "plt.title('ROC Curves for SVM Models')\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "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.8.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
