我正在使用weka kmeans分类器,我已经建立了一个模型.现在我想要聚集每个质心的中心值.我在weka UI上得到它
Attribute Full Data 0 1
(48836) (39469) (9367)
============================================
tt 428.6238 514.1345 68.3143
Run Code Online (Sandbox Code Playgroud)
我如何使用weka java jar获取它?
我的weka集群训练集只有一个属性.
要获取属性名称,请执行以下操作:String attname = clusterCenters.get(0).attribute(0).name();
如何获得集群中心的价值?
当您调用该方法时getClusterCentroids(),SimpleKMeans您将获得一个Instances对象(在weka-3-6-8中).这是一组代表您的集群中心的实例(每个指定集群一个).
SimpleKMeans kmeans = ...
// your code
...
Instances instances = kmeans.getClusterCentroids();
Run Code Online (Sandbox Code Playgroud)
一旦我们拥有了一组实例(质心),我们可以猜测它的大小numInstances(),迭代它们instance(int index)并使用double value(int attIndex)这种方式得到它们的值:
for ( int i = 0; i < instances.numInstances(); i++ ) {
// for each cluster center
Instance inst = instances.instance( i );
// as you mentioned, you only had 1 attribute
// but you can iterate through the different attributes
double value = inst.value( 0 );
System.out.println( "Value for centroid " + i + ": " + value );
}
Run Code Online (Sandbox Code Playgroud)
这就是全部.我没有编译代码,但这就是我的方式.
| 归档时间: |
|
| 查看次数: |
4662 次 |
| 最近记录: |