Java 使用Weka查找实例分配给的群集

Java 使用Weka查找实例分配给的群集,java,weka,Java,Weka,我使用一个带有AddCluster过滤器的EM clusterer,以便查看在培训后将哪些实例分配给不同的集群。下面是我正在使用的代码。我不能确定我是否正确应用了过滤器,但一旦我有了新实例,我仍然不知道如何从它们那里获取集群信息。我肯定这只是一个简单的电话,但我只是没有找到它。提前谢谢 public Cluster() { clusterer = new EM(); filter = new AddCluster(); try { cluster

我使用一个带有AddCluster过滤器的EM clusterer,以便查看在培训后将哪些实例分配给不同的集群。下面是我正在使用的代码。我不能确定我是否正确应用了过滤器,但一旦我有了新实例,我仍然不知道如何从它们那里获取集群信息。我肯定这只是一个简单的电话,但我只是没有找到它。提前谢谢

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> 
            }
        }