【发布时间】:2016-01-28 21:27:56
【问题描述】:
Scala 中的错误消息could not find implicit value 周围还有很多其他问题。答案非常具体,不适用于这个具体问题。
在 Scala Breeze 中,我尝试将 argmax 应用于 SparseVector[Int]。根据文档(和直觉),这很容易与
argmax(SparseVector.zeros[Int](5))
导入breeze.linalg._后。
我的实际测试代码如下所示:
import breeze.linalg.{Vector, argmax, sum}
val counts: Map[Int, Vector[Int]] = ...
counts
.filter(e => sum(e._2) > 10)
.take(100)
.map(e => (e._1, argmax(e._2)))
.foreach(println)
但是,编译器会抛出以下错误消息:
Error:(41, 37) could not find implicit value for parameter impl: breeze.linalg.argmax.Impl[breeze.linalg.Vector[Int],VR]
.map(e => (e._1, argmax(e._2)))
^
一些或多或少令人惊讶的观察结果:
-
sum(e._2)似乎编译得很好。 - 在内部使用
DenseVector而不是SparseVector不会改变任何内容
我该如何解决这个问题或至少缩小根本原因。
【问题讨论】:
标签: scala scala-breeze