{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "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",
       "      <th>2</th>\n",
       "      <th>3</th>\n",
       "      <th>4</th>\n",
       "      <th>5</th>\n",
       "      <th>6</th>\n",
       "      <th>7</th>\n",
       "      <th>8</th>\n",
       "      <th>9</th>\n",
       "      <th>...</th>\n",
       "      <th>21</th>\n",
       "      <th>22</th>\n",
       "      <th>23</th>\n",
       "      <th>24</th>\n",
       "      <th>25</th>\n",
       "      <th>26</th>\n",
       "      <th>27</th>\n",
       "      <th>28</th>\n",
       "      <th>29</th>\n",
       "      <th>30</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.00</td>\n",
       "      <td>1.00</td>\n",
       "      <td>2.00</td>\n",
       "      <td>3.0</td>\n",
       "      <td>4.0000</td>\n",
       "      <td>5.0000</td>\n",
       "      <td>6.0000</td>\n",
       "      <td>7.0000</td>\n",
       "      <td>8.0000</td>\n",
       "      <td>9.0000</td>\n",
       "      <td>...</td>\n",
       "      <td>21.00</td>\n",
       "      <td>22.00</td>\n",
       "      <td>23.0</td>\n",
       "      <td>24.0000</td>\n",
       "      <td>25.0000</td>\n",
       "      <td>26.0000</td>\n",
       "      <td>27.0000</td>\n",
       "      <td>28.0000</td>\n",
       "      <td>29.0000</td>\n",
       "      <td>label</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>17.99</td>\n",
       "      <td>10.38</td>\n",
       "      <td>122.80</td>\n",
       "      <td>1001.0</td>\n",
       "      <td>0.1184</td>\n",
       "      <td>0.2776</td>\n",
       "      <td>0.3001</td>\n",
       "      <td>0.1471</td>\n",
       "      <td>0.2419</td>\n",
       "      <td>0.0787</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.1189</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>20.57</td>\n",
       "      <td>17.77</td>\n",
       "      <td>132.90</td>\n",
       "      <td>1326.0</td>\n",
       "      <td>0.0847</td>\n",
       "      <td>0.0786</td>\n",
       "      <td>0.0869</td>\n",
       "      <td>0.0702</td>\n",
       "      <td>0.1812</td>\n",
       "      <td>0.0567</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.0890</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>19.69</td>\n",
       "      <td>21.25</td>\n",
       "      <td>130.00</td>\n",
       "      <td>1203.0</td>\n",
       "      <td>0.1096</td>\n",
       "      <td>0.1599</td>\n",
       "      <td>0.1974</td>\n",
       "      <td>0.1279</td>\n",
       "      <td>0.2069</td>\n",
       "      <td>0.0600</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.0876</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>11.42</td>\n",
       "      <td>20.38</td>\n",
       "      <td>77.58</td>\n",
       "      <td>386.1</td>\n",
       "      <td>0.1425</td>\n",
       "      <td>0.2839</td>\n",
       "      <td>0.2414</td>\n",
       "      <td>0.1052</td>\n",
       "      <td>0.2597</td>\n",
       "      <td>0.0974</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.1730</td>\n",
       "      <td>0</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>565</th>\n",
       "      <td>21.56</td>\n",
       "      <td>22.39</td>\n",
       "      <td>142.00</td>\n",
       "      <td>1479.0</td>\n",
       "      <td>0.1110</td>\n",
       "      <td>0.1159</td>\n",
       "      <td>0.2439</td>\n",
       "      <td>0.1389</td>\n",
       "      <td>0.1726</td>\n",
       "      <td>0.0562</td>\n",
       "      <td>...</td>\n",
       "      <td>26.40</td>\n",
       "      <td>166.10</td>\n",
       "      <td>2027.0</td>\n",
       "      <td>0.1410</td>\n",
       "      <td>0.2113</td>\n",
       "      <td>0.4107</td>\n",
       "      <td>0.2216</td>\n",
       "      <td>0.2060</td>\n",
       "      <td>0.0712</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>566</th>\n",
       "      <td>20.13</td>\n",
       "      <td>28.25</td>\n",
       "      <td>131.20</td>\n",
       "      <td>1261.0</td>\n",
       "      <td>0.0978</td>\n",
       "      <td>0.1034</td>\n",
       "      <td>0.1440</td>\n",
       "      <td>0.0979</td>\n",
       "      <td>0.1752</td>\n",
       "      <td>0.0553</td>\n",
       "      <td>...</td>\n",
       "      <td>38.25</td>\n",
       "      <td>155.00</td>\n",
       "      <td>1731.0</td>\n",
       "      <td>0.1166</td>\n",
       "      <td>0.1922</td>\n",
       "      <td>0.3215</td>\n",
       "      <td>0.1628</td>\n",
       "      <td>0.2572</td>\n",
       "      <td>0.0664</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>567</th>\n",
       "      <td>16.60</td>\n",
       "      <td>28.08</td>\n",
       "      <td>108.30</td>\n",
       "      <td>858.1</td>\n",
       "      <td>0.0846</td>\n",
       "      <td>0.1023</td>\n",
       "      <td>0.0925</td>\n",
       "      <td>0.0530</td>\n",
       "      <td>0.1590</td>\n",
       "      <td>0.0565</td>\n",
       "      <td>...</td>\n",
       "      <td>34.12</td>\n",
       "      <td>126.70</td>\n",
       "      <td>1124.0</td>\n",
       "      <td>0.1139</td>\n",
       "      <td>0.3094</td>\n",
       "      <td>0.3403</td>\n",
       "      <td>0.1418</td>\n",
       "      <td>0.2218</td>\n",
       "      <td>0.0782</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>568</th>\n",
       "      <td>20.60</td>\n",
       "      <td>29.33</td>\n",
       "      <td>140.10</td>\n",
       "      <td>1265.0</td>\n",
       "      <td>0.1178</td>\n",
       "      <td>0.2770</td>\n",
       "      <td>0.3514</td>\n",
       "      <td>0.1520</td>\n",
       "      <td>0.2397</td>\n",
       "      <td>0.0702</td>\n",
       "      <td>...</td>\n",
       "      <td>39.42</td>\n",
       "      <td>184.60</td>\n",
       "      <td>1821.0</td>\n",
       "      <td>0.1650</td>\n",
       "      <td>0.8681</td>\n",
       "      <td>0.9387</td>\n",
       "      <td>0.2650</td>\n",
       "      <td>0.4087</td>\n",
       "      <td>0.1240</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>569</th>\n",
       "      <td>7.76</td>\n",
       "      <td>24.54</td>\n",
       "      <td>47.92</td>\n",
       "      <td>181.0</td>\n",
       "      <td>0.0526</td>\n",
       "      <td>0.0436</td>\n",
       "      <td>0.0000</td>\n",
       "      <td>0.0000</td>\n",
       "      <td>0.1587</td>\n",
       "      <td>0.0588</td>\n",
       "      <td>...</td>\n",
       "      <td>30.37</td>\n",
       "      <td>59.16</td>\n",
       "      <td>268.6</td>\n",
       "      <td>0.0900</td>\n",
       "      <td>0.0644</td>\n",
       "      <td>0.0000</td>\n",
       "      <td>0.0000</td>\n",
       "      <td>0.2871</td>\n",
       "      <td>0.0704</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>570 rows × 31 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "        0      1       2       3       4       5       6       7       8   \\\n",
       "0     0.00   1.00    2.00     3.0  4.0000  5.0000  6.0000  7.0000  8.0000   \n",
       "1    17.99  10.38  122.80  1001.0  0.1184  0.2776  0.3001  0.1471  0.2419   \n",
       "2    20.57  17.77  132.90  1326.0  0.0847  0.0786  0.0869  0.0702  0.1812   \n",
       "3    19.69  21.25  130.00  1203.0  0.1096  0.1599  0.1974  0.1279  0.2069   \n",
       "4    11.42  20.38   77.58   386.1  0.1425  0.2839  0.2414  0.1052  0.2597   \n",
       "..     ...    ...     ...     ...     ...     ...     ...     ...     ...   \n",
       "565  21.56  22.39  142.00  1479.0  0.1110  0.1159  0.2439  0.1389  0.1726   \n",
       "566  20.13  28.25  131.20  1261.0  0.0978  0.1034  0.1440  0.0979  0.1752   \n",
       "567  16.60  28.08  108.30   858.1  0.0846  0.1023  0.0925  0.0530  0.1590   \n",
       "568  20.60  29.33  140.10  1265.0  0.1178  0.2770  0.3514  0.1520  0.2397   \n",
       "569   7.76  24.54   47.92   181.0  0.0526  0.0436  0.0000  0.0000  0.1587   \n",
       "\n",
       "         9   ...     21      22      23       24       25       26       27  \\\n",
       "0    9.0000  ...  21.00   22.00    23.0  24.0000  25.0000  26.0000  27.0000   \n",
       "1    0.0787  ...  17.33  184.60  2019.0   0.1622   0.6656   0.7119   0.2654   \n",
       "2    0.0567  ...  23.41  158.80  1956.0   0.1238   0.1866   0.2416   0.1860   \n",
       "3    0.0600  ...  25.53  152.50  1709.0   0.1444   0.4245   0.4504   0.2430   \n",
       "4    0.0974  ...  26.50   98.87   567.7   0.2098   0.8663   0.6869   0.2575   \n",
       "..      ...  ...    ...     ...     ...      ...      ...      ...      ...   \n",
       "565  0.0562  ...  26.40  166.10  2027.0   0.1410   0.2113   0.4107   0.2216   \n",
       "566  0.0553  ...  38.25  155.00  1731.0   0.1166   0.1922   0.3215   0.1628   \n",
       "567  0.0565  ...  34.12  126.70  1124.0   0.1139   0.3094   0.3403   0.1418   \n",
       "568  0.0702  ...  39.42  184.60  1821.0   0.1650   0.8681   0.9387   0.2650   \n",
       "569  0.0588  ...  30.37   59.16   268.6   0.0900   0.0644   0.0000   0.0000   \n",
       "\n",
       "          28       29     30  \n",
       "0    28.0000  29.0000  label  \n",
       "1     0.4601   0.1189      0  \n",
       "2     0.2750   0.0890      0  \n",
       "3     0.3613   0.0876      0  \n",
       "4     0.6638   0.1730      0  \n",
       "..       ...      ...    ...  \n",
       "565   0.2060   0.0712      0  \n",
       "566   0.2572   0.0664      0  \n",
       "567   0.2218   0.0782      0  \n",
       "568   0.4087   0.1240      0  \n",
       "569   0.2871   0.0704      1  \n",
       "\n",
       "[570 rows x 31 columns]"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "data = pd.read_csv('./breastcancer.csv', sep=',', header=None)\n",
    "data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "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",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1050</th>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1051</th>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1052</th>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1053</th>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1054</th>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>1055 rows × 1 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "      0\n",
       "0     1\n",
       "1     1\n",
       "2     1\n",
       "3     1\n",
       "4     1\n",
       "...  ..\n",
       "1050  2\n",
       "1051  2\n",
       "1052  2\n",
       "1053  2\n",
       "1054  2\n",
       "\n",
       "[1055 rows x 1 columns]"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "label = pd.read_csv('./biodeg_label.csv', sep=',', header=None)\n",
    "label"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "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",
       "      <th>2</th>\n",
       "      <th>3</th>\n",
       "      <th>4</th>\n",
       "      <th>5</th>\n",
       "      <th>6</th>\n",
       "      <th>7</th>\n",
       "      <th>8</th>\n",
       "      <th>9</th>\n",
       "      <th>...</th>\n",
       "      <th>33</th>\n",
       "      <th>34</th>\n",
       "      <th>35</th>\n",
       "      <th>36</th>\n",
       "      <th>37</th>\n",
       "      <th>38</th>\n",
       "      <th>39</th>\n",
       "      <th>40</th>\n",
       "      <th>41</th>\n",
       "      <th>label</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>3.919</td>\n",
       "      <td>2.6909</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>31.4</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>...</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>2.949</td>\n",
       "      <td>1.591</td>\n",
       "      <td>0</td>\n",
       "      <td>7.253</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>4.170</td>\n",
       "      <td>2.1144</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>30.8</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>...</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>3.315</td>\n",
       "      <td>1.967</td>\n",
       "      <td>0</td>\n",
       "      <td>7.257</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>3.932</td>\n",
       "      <td>3.2512</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>26.7</td>\n",
       "      <td>2</td>\n",
       "      <td>4</td>\n",
       "      <td>...</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>3.076</td>\n",
       "      <td>2.417</td>\n",
       "      <td>0</td>\n",
       "      <td>7.601</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>3.000</td>\n",
       "      <td>2.7098</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>20.0</td>\n",
       "      <td>0</td>\n",
       "      <td>2</td>\n",
       "      <td>...</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>3.046</td>\n",
       "      <td>5.000</td>\n",
       "      <td>0</td>\n",
       "      <td>6.690</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>4.236</td>\n",
       "      <td>3.3944</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>29.4</td>\n",
       "      <td>2</td>\n",
       "      <td>4</td>\n",
       "      <td>...</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>3.351</td>\n",
       "      <td>2.405</td>\n",
       "      <td>0</td>\n",
       "      <td>8.003</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>1</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>1050</th>\n",
       "      <td>5.431</td>\n",
       "      <td>2.8955</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>32.1</td>\n",
       "      <td>4</td>\n",
       "      <td>1</td>\n",
       "      <td>...</td>\n",
       "      <td>6</td>\n",
       "      <td>1</td>\n",
       "      <td>3.573</td>\n",
       "      <td>2.242</td>\n",
       "      <td>1</td>\n",
       "      <td>8.088</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1051</th>\n",
       "      <td>5.287</td>\n",
       "      <td>3.3732</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>9</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>35.3</td>\n",
       "      <td>0</td>\n",
       "      <td>9</td>\n",
       "      <td>...</td>\n",
       "      <td>3</td>\n",
       "      <td>0</td>\n",
       "      <td>3.787</td>\n",
       "      <td>3.083</td>\n",
       "      <td>3</td>\n",
       "      <td>9.278</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1052</th>\n",
       "      <td>4.869</td>\n",
       "      <td>1.7670</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>9</td>\n",
       "      <td>0</td>\n",
       "      <td>5</td>\n",
       "      <td>44.4</td>\n",
       "      <td>0</td>\n",
       "      <td>4</td>\n",
       "      <td>...</td>\n",
       "      <td>13</td>\n",
       "      <td>0</td>\n",
       "      <td>3.848</td>\n",
       "      <td>2.576</td>\n",
       "      <td>5</td>\n",
       "      <td>9.537</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1053</th>\n",
       "      <td>5.158</td>\n",
       "      <td>1.6914</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>36</td>\n",
       "      <td>0</td>\n",
       "      <td>9</td>\n",
       "      <td>56.1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>...</td>\n",
       "      <td>16</td>\n",
       "      <td>0</td>\n",
       "      <td>5.808</td>\n",
       "      <td>2.055</td>\n",
       "      <td>8</td>\n",
       "      <td>11.055</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1054</th>\n",
       "      <td>5.076</td>\n",
       "      <td>2.6588</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>4</td>\n",
       "      <td>54.5</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>...</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>4.009</td>\n",
       "      <td>2.206</td>\n",
       "      <td>0</td>\n",
       "      <td>9.130</td>\n",
       "      <td>0</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>1055 rows × 43 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "          0       1  2  3   4  5  6     7  8  9  ...  33  34     35     36  \\\n",
       "0     3.919  2.6909  0  0   0  0  0  31.4  2  0  ...   0   0  2.949  1.591   \n",
       "1     4.170  2.1144  0  0   0  0  0  30.8  1  1  ...   0   0  3.315  1.967   \n",
       "2     3.932  3.2512  0  0   0  0  0  26.7  2  4  ...   0   1  3.076  2.417   \n",
       "3     3.000  2.7098  0  0   0  0  0  20.0  0  2  ...   0   1  3.046  5.000   \n",
       "4     4.236  3.3944  0  0   0  0  0  29.4  2  4  ...   0   0  3.351  2.405   \n",
       "...     ...     ... .. ..  .. .. ..   ... .. ..  ...  ..  ..    ...    ...   \n",
       "1050  5.431  2.8955  0  0   0  2  0  32.1  4  1  ...   6   1  3.573  2.242   \n",
       "1051  5.287  3.3732  0  0   9  0  0  35.3  0  9  ...   3   0  3.787  3.083   \n",
       "1052  4.869  1.7670  0  1   9  0  5  44.4  0  4  ...  13   0  3.848  2.576   \n",
       "1053  5.158  1.6914  2  0  36  0  9  56.1  0  0  ...  16   0  5.808  2.055   \n",
       "1054  5.076  2.6588  2  0   0  0  4  54.5  0  0  ...   0   0  4.009  2.206   \n",
       "\n",
       "      37      38  39  40  41  label  \n",
       "0      0   7.253   0   0   1      1  \n",
       "1      0   7.257   0   0   1      1  \n",
       "2      0   7.601   0   0   1      1  \n",
       "3      0   6.690   0   0   1      1  \n",
       "4      0   8.003   0   0   1      1  \n",
       "...   ..     ...  ..  ..  ..    ...  \n",
       "1050   1   8.088   0   0   2      2  \n",
       "1051   3   9.278   0   0   2      2  \n",
       "1052   5   9.537   1   0   2      2  \n",
       "1053   8  11.055   0   1   2      2  \n",
       "1054   0   9.130   0   2   2      2  \n",
       "\n",
       "[1055 rows x 43 columns]"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "data['label'] = label\n",
    "data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "data.to_csv('./biodeg.csv', sep=',', index=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0    2\n",
       "dtype: int64"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "label.max()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.collections.PathCollection at 0x7f126500cf40>"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "r = data[data['color']==0]\n",
    "b = data[data['color'] == 1]\n",
    "plt.scatter(r['x'], r['y'])\n",
    "plt.scatter(b['x'], b['y'])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "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>607.796021</td>\n",
       "      <td>225.123001</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>337.240997</td>\n",
       "      <td>355.937012</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>174.166000</td>\n",
       "      <td>156.988007</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>88.382004</td>\n",
       "      <td>391.389008</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>499.385986</td>\n",
       "      <td>126.143997</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9995</th>\n",
       "      <td>313.623993</td>\n",
       "      <td>412.970001</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9996</th>\n",
       "      <td>142.145996</td>\n",
       "      <td>332.209015</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9997</th>\n",
       "      <td>84.971001</td>\n",
       "      <td>293.795013</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9998</th>\n",
       "      <td>445.592010</td>\n",
       "      <td>359.608002</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9999</th>\n",
       "      <td>573.750000</td>\n",
       "      <td>458.924011</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>10000 rows × 2 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "               0           1\n",
       "0     607.796021  225.123001\n",
       "1     337.240997  355.937012\n",
       "2     174.166000  156.988007\n",
       "3      88.382004  391.389008\n",
       "4     499.385986  126.143997\n",
       "...          ...         ...\n",
       "9995  313.623993  412.970001\n",
       "9996  142.145996  332.209015\n",
       "9997   84.971001  293.795013\n",
       "9998  445.592010  359.608002\n",
       "9999  573.750000  458.924011\n",
       "\n",
       "[10000 rows x 2 columns]"
      ]
     },
     "execution_count": 50,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "data = pd.read_csv('./cluto-t7-10k_data.csv', sep=',', header=None)\n",
    "data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "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",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>5</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>8</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>6</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9995</th>\n",
       "      <td>6</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9996</th>\n",
       "      <td>4</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9997</th>\n",
       "      <td>6</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9998</th>\n",
       "      <td>6</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9999</th>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>10000 rows × 1 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "      0\n",
       "0     1\n",
       "1     5\n",
       "2     8\n",
       "3     6\n",
       "4     2\n",
       "...  ..\n",
       "9995  6\n",
       "9996  4\n",
       "9997  6\n",
       "9998  6\n",
       "9999  1\n",
       "\n",
       "[10000 rows x 1 columns]"
      ]
     },
     "execution_count": 51,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "label = pd.read_csv('cluto-t7-10k_label.csv', header=None)\n",
    "label"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 52,
   "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",
       "      <th>color</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>607.796021</td>\n",
       "      <td>225.123001</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>337.240997</td>\n",
       "      <td>355.937012</td>\n",
       "      <td>5</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>174.166000</td>\n",
       "      <td>156.988007</td>\n",
       "      <td>8</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>88.382004</td>\n",
       "      <td>391.389008</td>\n",
       "      <td>6</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>499.385986</td>\n",
       "      <td>126.143997</td>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9995</th>\n",
       "      <td>313.623993</td>\n",
       "      <td>412.970001</td>\n",
       "      <td>6</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9996</th>\n",
       "      <td>142.145996</td>\n",
       "      <td>332.209015</td>\n",
       "      <td>4</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9997</th>\n",
       "      <td>84.971001</td>\n",
       "      <td>293.795013</td>\n",
       "      <td>6</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9998</th>\n",
       "      <td>445.592010</td>\n",
       "      <td>359.608002</td>\n",
       "      <td>6</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9999</th>\n",
       "      <td>573.750000</td>\n",
       "      <td>458.924011</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>10000 rows × 3 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "               0           1  color\n",
       "0     607.796021  225.123001      1\n",
       "1     337.240997  355.937012      5\n",
       "2     174.166000  156.988007      8\n",
       "3      88.382004  391.389008      6\n",
       "4     499.385986  126.143997      2\n",
       "...          ...         ...    ...\n",
       "9995  313.623993  412.970001      6\n",
       "9996  142.145996  332.209015      4\n",
       "9997   84.971001  293.795013      6\n",
       "9998  445.592010  359.608002      6\n",
       "9999  573.750000  458.924011      1\n",
       "\n",
       "[10000 rows x 3 columns]"
      ]
     },
     "execution_count": 52,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "data['color'] = label\n",
    "data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 53,
   "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>x</th>\n",
       "      <th>y</th>\n",
       "      <th>color</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>607.796021</td>\n",
       "      <td>225.123001</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>337.240997</td>\n",
       "      <td>355.937012</td>\n",
       "      <td>5</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>174.166000</td>\n",
       "      <td>156.988007</td>\n",
       "      <td>8</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>88.382004</td>\n",
       "      <td>391.389008</td>\n",
       "      <td>6</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>499.385986</td>\n",
       "      <td>126.143997</td>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9995</th>\n",
       "      <td>313.623993</td>\n",
       "      <td>412.970001</td>\n",
       "      <td>6</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9996</th>\n",
       "      <td>142.145996</td>\n",
       "      <td>332.209015</td>\n",
       "      <td>4</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9997</th>\n",
       "      <td>84.971001</td>\n",
       "      <td>293.795013</td>\n",
       "      <td>6</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9998</th>\n",
       "      <td>445.592010</td>\n",
       "      <td>359.608002</td>\n",
       "      <td>6</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9999</th>\n",
       "      <td>573.750000</td>\n",
       "      <td>458.924011</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>10000 rows × 3 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "               x           y  color\n",
       "0     607.796021  225.123001      1\n",
       "1     337.240997  355.937012      5\n",
       "2     174.166000  156.988007      8\n",
       "3      88.382004  391.389008      6\n",
       "4     499.385986  126.143997      2\n",
       "...          ...         ...    ...\n",
       "9995  313.623993  412.970001      6\n",
       "9996  142.145996  332.209015      4\n",
       "9997   84.971001  293.795013      6\n",
       "9998  445.592010  359.608002      6\n",
       "9999  573.750000  458.924011      1\n",
       "\n",
       "[10000 rows x 3 columns]"
      ]
     },
     "execution_count": 53,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "data.columns = ['x', 'y' , 'color']\n",
    "data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "metadata": {},
   "outputs": [],
   "source": [
    "data.to_csv('cluto.csv', sep=',', index=None)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 55,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "8"
      ]
     },
     "execution_count": 55,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "label[0].max(0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 56,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(1061, 1)\n",
      "(2230, 1)\n",
      "(611, 1)\n",
      "(625, 1)\n",
      "(346, 1)\n",
      "(335, 1)\n",
      "(2758, 1)\n",
      "(994, 1)\n",
      "(1040, 1)\n"
     ]
    }
   ],
   "source": [
    "for i in range(label[0].max(0) + 1):\n",
    "    print(label[label[0] == i].shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 59,
   "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",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "Empty DataFrame\n",
       "Columns: []\n",
       "Index: []"
      ]
     },
     "execution_count": 59,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "new_data = pd.DataFrame()\n",
    "new_data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "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>x</th>\n",
       "      <th>y</th>\n",
       "      <th>color</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>325.111</td>\n",
       "      <td>316.065</td>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>15</th>\n",
       "      <td>345.291</td>\n",
       "      <td>376.266</td>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>103</th>\n",
       "      <td>312.980</td>\n",
       "      <td>349.579</td>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>106</th>\n",
       "      <td>319.294</td>\n",
       "      <td>329.545</td>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>137</th>\n",
       "      <td>366.213</td>\n",
       "      <td>324.547</td>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2974</th>\n",
       "      <td>303.768</td>\n",
       "      <td>337.460</td>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2982</th>\n",
       "      <td>347.617</td>\n",
       "      <td>370.365</td>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2990</th>\n",
       "      <td>323.167</td>\n",
       "      <td>328.544</td>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2991</th>\n",
       "      <td>321.703</td>\n",
       "      <td>372.978</td>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3024</th>\n",
       "      <td>367.370</td>\n",
       "      <td>322.193</td>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>110 rows × 3 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "            x        y  color\n",
       "2     325.111  316.065      2\n",
       "15    345.291  376.266      2\n",
       "103   312.980  349.579      2\n",
       "106   319.294  329.545      2\n",
       "137   366.213  324.547      2\n",
       "...       ...      ...    ...\n",
       "2974  303.768  337.460      2\n",
       "2982  347.617  370.365      2\n",
       "2990  323.167  328.544      2\n",
       "2991  321.703  372.978      2\n",
       "3024  367.370  322.193      2\n",
       "\n",
       "[110 rows x 3 columns]"
      ]
     },
     "execution_count": 40,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "data[data['color'] == 2]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 60,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(1061, 1)\n",
      "(2230, 1)\n",
      "(611, 1)\n",
      "(625, 1)\n",
      "(346, 1)\n",
      "(335, 1)\n",
      "(2758, 1)\n",
      "(994, 1)\n",
      "(1040, 1)\n"
     ]
    }
   ],
   "source": [
    "for i in range(0, label[0].max(0) + 1):\n",
    "    print(label[label[0] == i].shape)\n",
    "    new_data = pd.concat([new_data, data[data['color'] == i].sample(300)])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 61,
   "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>x</th>\n",
       "      <th>y</th>\n",
       "      <th>color</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>5450</th>\n",
       "      <td>627.323975</td>\n",
       "      <td>341.602997</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9943</th>\n",
       "      <td>489.079010</td>\n",
       "      <td>96.985001</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4936</th>\n",
       "      <td>216.684006</td>\n",
       "      <td>347.716003</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6682</th>\n",
       "      <td>31.476999</td>\n",
       "      <td>439.335999</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6347</th>\n",
       "      <td>337.158997</td>\n",
       "      <td>66.889999</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7303</th>\n",
       "      <td>168.033997</td>\n",
       "      <td>142.725006</td>\n",
       "      <td>8</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9318</th>\n",
       "      <td>18.066999</td>\n",
       "      <td>173.054993</td>\n",
       "      <td>8</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6700</th>\n",
       "      <td>200.697998</td>\n",
       "      <td>139.845993</td>\n",
       "      <td>8</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5014</th>\n",
       "      <td>223.914001</td>\n",
       "      <td>143.268997</td>\n",
       "      <td>8</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8798</th>\n",
       "      <td>49.653000</td>\n",
       "      <td>147.764999</td>\n",
       "      <td>8</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>2700 rows × 3 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "               x           y  color\n",
       "5450  627.323975  341.602997      0\n",
       "9943  489.079010   96.985001      0\n",
       "4936  216.684006  347.716003      0\n",
       "6682   31.476999  439.335999      0\n",
       "6347  337.158997   66.889999      0\n",
       "...          ...         ...    ...\n",
       "7303  168.033997  142.725006      8\n",
       "9318   18.066999  173.054993      8\n",
       "6700  200.697998  139.845993      8\n",
       "5014  223.914001  143.268997      8\n",
       "8798   49.653000  147.764999      8\n",
       "\n",
       "[2700 rows x 3 columns]"
      ]
     },
     "execution_count": 61,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "new_data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 64,
   "metadata": {},
   "outputs": [],
   "source": [
    "new_data.to_csv('balanced_cluto.csv', sep=',', index=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 63,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(300, 3)\n",
      "(300, 3)\n",
      "(300, 3)\n",
      "(300, 3)\n",
      "(300, 3)\n",
      "(300, 3)\n",
      "(300, 3)\n",
      "(300, 3)\n",
      "(300, 3)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_148898/2789652804.py:2: UserWarning: Boolean Series key will be reindexed to match DataFrame index.\n",
      "  print(new_data[label[0] == i].shape)\n",
      "/tmp/ipykernel_148898/2789652804.py:2: UserWarning: Boolean Series key will be reindexed to match DataFrame index.\n",
      "  print(new_data[label[0] == i].shape)\n",
      "/tmp/ipykernel_148898/2789652804.py:2: UserWarning: Boolean Series key will be reindexed to match DataFrame index.\n",
      "  print(new_data[label[0] == i].shape)\n",
      "/tmp/ipykernel_148898/2789652804.py:2: UserWarning: Boolean Series key will be reindexed to match DataFrame index.\n",
      "  print(new_data[label[0] == i].shape)\n",
      "/tmp/ipykernel_148898/2789652804.py:2: UserWarning: Boolean Series key will be reindexed to match DataFrame index.\n",
      "  print(new_data[label[0] == i].shape)\n",
      "/tmp/ipykernel_148898/2789652804.py:2: UserWarning: Boolean Series key will be reindexed to match DataFrame index.\n",
      "  print(new_data[label[0] == i].shape)\n",
      "/tmp/ipykernel_148898/2789652804.py:2: UserWarning: Boolean Series key will be reindexed to match DataFrame index.\n",
      "  print(new_data[label[0] == i].shape)\n",
      "/tmp/ipykernel_148898/2789652804.py:2: UserWarning: Boolean Series key will be reindexed to match DataFrame index.\n",
      "  print(new_data[label[0] == i].shape)\n",
      "/tmp/ipykernel_148898/2789652804.py:2: UserWarning: Boolean Series key will be reindexed to match DataFrame index.\n",
      "  print(new_data[label[0] == i].shape)\n"
     ]
    }
   ],
   "source": [
    "for i in range(0, label[0].max(0) + 1):\n",
    "    print(new_data[label[0] == i].shape)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "ph",
   "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.10.13"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
