Scala 如何使用泛型扩展抽象类?

Scala 如何使用泛型扩展抽象类?,scala,generics,abstract,Scala,Generics,Abstract,我是斯卡拉的新手。我想做的是创建一个名为EnhancedFirstOrderMinimizer的抽象类,它扩展了另一个名为FirstOrderMinimizer的抽象类。但是,IDE告诉我“类型不匹配,预期:无,实际:DF” 这是FirstOrderMinimizer: abstract class FirstOrderMinimizer[T, DF <: StochasticDiffFunction[T]] (maxIter: Int = -1, tolerance: Doubl

我是斯卡拉的新手。我想做的是创建一个名为
EnhancedFirstOrderMinimizer
的抽象类,它扩展了另一个名为
FirstOrderMinimizer
的抽象类。但是,IDE告诉我“
类型不匹配,预期:无,实际:DF

这是FirstOrderMinimizer:

abstract class FirstOrderMinimizer[T, DF <: StochasticDiffFunction[T]]
    (maxIter: Int = -1, tolerance: Double = 1E-6, improvementTol: Double = 1E-3,
     val minImprovementWindow: Int = 10,
     val numberOfImprovementFailures: Int = 1)
    (implicit space: NormedModule[T, Double])
    extends Minimizer[T, DF] with SerializableLogging {

protected def initialHistory(f: DF, init: T): History
  ...
  type History
  protected def initialHistory(f: DF, init: T): History
  protected def adjustFunction(f: DF): DF = f
  protected def adjust(newX: T, newGrad: T, newVal: Double): (Double, T) =
    (newVal, newGrad)
  protected def chooseDescentDirection(state: State, f: DF): T
  protected def determineStepSize(state: State, f: DF, direction: T): Double
  protected def takeStep(state: State, dir: T, stepSize:Double): T
  protected def updateHistory(newX: T, newGrad: T, newVal: Double,
                              f: DF, oldState: State): History

  def iterations(f: DF, init: T): Iterator[State] = {
    val adjustedFun = adjustFunction(f)
    infiniteIterations(f, initialState(adjustedFun, init))
      .takeUpToWhere(_.converged) 
  }
  ...
}

你能帮我查一下吗?

编译器告诉你,
f
无限运算的第一个参数的错误类型。我们可能需要查看
无限运算
的声明位置,以准确了解发生了什么

但是我认为扩展问题的快速答案是
extends FirstOrderMinimizer
应该更改为
extends FirstOrderMinimizer[T,DF]

EnhancedFirstOrderMinimizer[T, DF<:StochasticDiffFunction[T]]
    (maxIter: Int = -1, tolerance: Double=1E-6, improvementTol: Double=1E-3)
    extends FirstOrderMinimizer {

  override def iterations(f: DF, init: T): Iterator[State] = {
    val adjustedFun = adjustFunction(f)

    // f: Type mismatch, expected: nothing, actual: DF
    infiniteIterations(f, initialState(adjustedFun, init))
      .takeUpToWhere(_.converged)
  }
}