0

我正在将 JUNG 库用于其“PageRankWithPriors 类”。我使用了一个非常小的图表(只有 3 个节点)来测试这个类。当没有任何具有自边缘的节点时,输出是可以的,但是如果图中包含具有自边缘的节点,则输出变得不正确(节点的最终排名不是概率值的形式,它们的总和是不等于 1)。输出是:

0.2997601918465228

0.1247002398081535

0.1918465227817746

我使用了“setHyperedgesAreSelfLoops(true)”,但输出仍然不正确:

320751.99531359226

609574.2619040733

2554381.251484884

为什么“PersonalizedPageRank 类”不能正常工作?它里面有错误还是我做错了什么?

我的代码是:

public static void main(String[] args) throws FileNotFoundException, IOException 
{           
   weigth[0][1]=0.2;
   weigth[0][2]=0.8;
   weigth[1][0]=1;
   weigth[2][1]= 0.5;
   weigth[2][2]= 0.5;       

   prior[0]=1;
   prior[1]=0;
   prior[2]=0;

   Graph<Integer, String> g = new DirectedSparseGraph<Integer, String> ();

   g.addVertex(new Integer(0));
   g.addVertex(new Integer(1));
   g.addVertex(new Integer(2));

   g.addEdge("0->1", 0, 1, EdgeType.DIRECTED);
   g.addEdge("0->2", 0, 2, EdgeType.DIRECTED);
   g.addEdge("1->0", 1, 0, EdgeType.DIRECTED);
   g.addEdge("2->1", 2, 1, EdgeType.DIRECTED);
   g.addEdge("2->2", 2, 2, EdgeType.DIRECTED);


   Transformer<String, Double> edge_weigths = 
           new Transformer<String, Double>()
           {
        @Override
                public Double transform(String e) 
                {
                    String[] split = e.split("->");           
                    return weigth[Integer.parseInt(split[0])][Integer.parseInt(split[1])];
                }           
           };

   Transformer<Integer, Double> vertex_prior = 
           new Transformer<Integer, Double>()
           {            
        @Override
                public Double transform(Integer v) 
                {                        
                    return prior[v];            
                }           
           }


   PageRankWithPriors prp = new PageRankWithPriors(g, edge_weigths, vertex_prior, 0.2);        
   prp.setHyperedgesAreSelfLoops(true);   
   prp.evaluate();

   System.out.println(prp.getVertexScore(0));
   System.out.println(prp.getVertexScore(1));
   System.out.println(prp.getVertexScore(2));   


}

非常感谢您的帮助。

4

1 回答 1

0

(1)我不确定你为什么打电话setHyperEdgesAreSelfLoops(),因为你没有使用超图。深入研究一下,结果数字看起来很奇怪,因为当调用该方法时,我们并没有防范图不是超图的可能性。哎呀。同时,如果您的图不是超图,请不要调用它。:)

(2) 我认为这可能是问题所在:

g.addVertex((Integer)0);

我相信将 0 (或任何其他整数)转换为 Integer 与new Integer(0)or不同Integer.valueOf(0)。您所做的实际上是将数字 0 转换为 Integer 引用。所以我敢打赌,如果你问你的图它有多少个顶点,它会报告“6”而不是“3”。

好消息是它addEdge()会根据需要自动将顶点参数添加到图形中,因此您可以完全删除addVertex()调用。

于 2013-10-15T03:59:57.647 回答