using Accord.MachineLearning;
using System.Collections.Generic;
using System.ComponentModel;
using System.Threading.Tasks;
using System.Windows.Forms;
namespace MachineLearning
public partial class Form1 : Form
private string filePath = @"C:\Users\Duy Nguyen\Downloads\DTB_IT.xlsx";
private void button1_Click(object sender, EventArgs e)
FileStream stream = File.Open(filePath, FileMode.Open, FileAccess.Read);
IExcelDataReader excelReader;
if (Path.GetExtension(filePath).ToUpper() == ".XLS")
excelReader = ExcelReaderFactory.CreateBinaryReader(stream);
excelReader = ExcelReaderFactory.CreateOpenXmlReader(stream);
DataSet result = excelReader.AsDataSet(new ExcelDataSetConfiguration()
UseColumnDataType = true,
FilterSheet = (tableReader, sheetIndex) => true,
ConfigureDataTable = (tableReader) => new ExcelDataTableConfiguration()
EmptyColumnNamePrefix = "Column",
DataTable dt = result.Tables[0];
List<double[]> data = new List<double[]>();
foreach (DataRow dtRow in dt.Rows)
List<double> row = new List<double>();
for(int i = 4; i <= 12; i++)
double val = Double.Parse(dtRow[i].ToString());
double[][] input = data.ToArray();
KMeans kmeans = new KMeans(k: 2);
var clusters = kmeans.Learn(input);
int[] labels = clusters.Decide(input);
dt.Columns.Add("Cluster", typeof(System.Int32));
foreach (DataRow dtRow in dt.Rows)
int index = dt.Rows.IndexOf(dtRow);
dtRow["Cluster"] = labels[index];
dataGridView1.DataSource = dt;
DataTable dt_lb1 = dt.AsEnumerable().Where(row => row.Field<Int32>("Cluster") == 0).CopyToDataTable();
DataTable dt_lb2 = dt.AsEnumerable().Where(row => row.Field<Int32>("Cluster") == 1).CopyToDataTable();
dataGridView2.DataSource = dt_lb1;
dataGridView3.DataSource = dt_lb2;