我想从边缘的CSV文件计算PageRank
,格式如下:
12,13,1.0
12,14,1.0
12,15,1.0
12,16,1.0
12,17,1.0
...
我的代码:
var filename = "<filename>.csv"
val graph = Graph.fromCsvReader[Long,Double,Double](
env = env,
pathEdges = filename,
readVertices = false,
hasEdgeValues = true,
vertexValueInitializer = new MapFunction[Long, Double] {
def map(id: Long): Double = 0.0 } )
val ranks = new PageRank[Long](0.85, 20).run(graph)
我从Flink Scala Shell中收到以下错误:
error: type mismatch;
found : org.apache.flink.graph.scala.Graph[Long,_23,_24] where type _24 >: Double with _22, type _23 >: Double with _21
required: org.apache.flink.graph.Graph[Long,Double,Double]
val ranks = new PageRank[Long](0.85, 20).run(graph)
^
我做错了什么?
(每个顶点的初始值是0.0,每个边的正确值是1.0吗?)
答案 0 :(得分:2)
问题在于您将Scala org.apache.flink.graph.scala.Graph
提供给期望Java PageRank.run
的{{1}}。
要为Scala org.apache.flink.graph.Graph
对象运行GraphAlgorithm
,您必须使用Graph
调用Scala run
的{{1}}方法。
Graph
对于GraphAlgorithm
算法,重要的是要注意算法需要类型为graph.run(new PageRank[Long](0.85, 20))
的实例。由于Java的PageRank
类型与Scala的Graph[K, java.lang.Double, java.lang.Double]
类型不同(在类型检查方面),因此必须考虑到这一点。
对于示例代码,这意味着
Double