Java 使用Weka查找实例分配给的群集
我使用一个带有AddCluster过滤器的EM clusterer,以便查看在培训后将哪些实例分配给不同的集群。下面是我正在使用的代码。我不能确定我是否正确应用了过滤器,但一旦我有了新实例,我仍然不知道如何从它们那里获取集群信息。我肯定这只是一个简单的电话,但我只是没有找到它。提前谢谢Java 使用Weka查找实例分配给的群集,java,weka,Java,Weka,我使用一个带有AddCluster过滤器的EM clusterer,以便查看在培训后将哪些实例分配给不同的集群。下面是我正在使用的代码。我不能确定我是否正确应用了过滤器,但一旦我有了新实例,我仍然不知道如何从它们那里获取集群信息。我肯定这只是一个简单的电话,但我只是没有找到它。提前谢谢 public Cluster() { clusterer = new EM(); filter = new AddCluster(); try { cluster
public Cluster()
{
clusterer = new EM();
filter = new AddCluster();
try
{
clusterer.setMaxIterations(100);
clusterer.setNumClusters(20);
filter.setClusterer(clusterer);
}
catch (Exception e)
{
e.printStackTrace();
}
}
public void buildCluster(String fileName)
{
try
{
DataSource source = new DataSource(fileName);
inst = source.getDataSet();
filter.setInputFormat(inst);
inst = AddCluster.useFilter(inst, filter);
}
catch (Exception e)
{
e.printStackTrace();
}
}
我认为你应该上字典课。下面是我的示例代码: 您还可以通过调用字典的键从字典中检索数据
Enumeration clusteredInst = data_to_use.enumerateInstances();<br>
Dictionary<Integer, ArrayList<Instance>> clusteredSamples = new ashtable<>();
while (clusteredInst.hasMoreElements()) {<br>
Instance ins = (Instance) clusteredInst.nextElement();<br>
int clusterNumb = em.clusterInstance(ins);<br>
ArrayList<Instance> cls = null;<br>
cls = clusteredSamples.get(clusterNumb);<br>
if (cls != null) {<br>
cls.add(ins);<br>
} else {<br>
cls = new ArrayList<>();<br>
cls.add(ins);<br>
//you add elements to dictionary using put method<br>
//put(key, value)<br>
clusteredSamples.put(clusterNumb, cls);<br>
}
}