-
Notifications
You must be signed in to change notification settings - Fork 1
/
KMCluster.java
executable file
·98 lines (79 loc) · 2.23 KB
/
KMCluster.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
package wekatest;
import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.FileNotFoundException;
import java.io.FileReader;
import java.io.FileWriter;
import java.io.IOException;
import weka.clusterers.SimpleKMeans;
import weka.core.Instances;
import weka.core.converters.ConverterUtils.DataSource;
public class KMCluster {
private Instances insdata;
private String sourceFile;
private String targetFile;
private int numCluster;
private int[] assignment;
public KMCluster(String sourceFile,String targetFile,int numCluster){
this.sourceFile=sourceFile;
this.targetFile=targetFile;
this.numCluster=numCluster;
}
public void loadData() throws Exception{
DataSource dataSource=new DataSource(sourceFile);
insdata=dataSource.getDataSet();
}
public void cluster() throws Exception{
SimpleKMeans KM=new SimpleKMeans();
//set options
String[] options=new String[4];
options[0]="-N";
options[1]=Integer.toString(numCluster);
options[2]="-S";
options[3]="10";
KM.setOptions(options);
KM.buildClusterer(insdata);
//collect results
assignment=new int[insdata.numInstances()];
for(int j=0;j<insdata.numInstances();j++){
assignment[j]=KM.clusterInstance(insdata.instance(j));
}
}
public void writeResult() throws Exception{
FileReader fr=null;
BufferedReader br=null;
FileWriter fw=null;
BufferedWriter bw=null;
String line=null;
int j=0;
try{
fr=new FileReader(sourceFile);
br=new BufferedReader(fr);
fw=new FileWriter(targetFile);
bw=new BufferedWriter(fw);
line=br.readLine();
bw.write(line+",cluster\n");
while((line=br.readLine())!=null){
bw.write(line+","+assignment[j++]+"\n");
}
}finally{
if (br!=null){
br.close();}
if(bw!=null){
bw.close();}
}
}
public void process() throws Exception{
loadData();
cluster();
writeResult();
}
public static void main(String[] args) throws Exception{
// TODO Auto-generated method stub
int i;
for(i=0;i<100;i++){
KMCluster cluster1=new KMCluster("YOUR_INPUT_PATH"+i+".csv","YOUR_OUTPUT_PATH"+i+".csv",3);
cluster1.process();
}
}
}