兴奋地玩弄无形的自然数,我想知道获得例如 nats 乘积的整数值的最佳方法是什么。
摘自无形nat.scala
:
trait Prod[A <: Nat, B <: Nat] {
type Out <: Nat
}
trait ProdAux[A <: Nat, B <: Nat, C <: Nat]
object Prod {
implicit def prod[A <: Nat, B <: Nat, C <: Nat](implicit diff : ProdAux[A, B, C]) = new Prod[A, B] {
type Out = C
}
}
object ProdAux {
import Nat._0
implicit def prod1[B <: Nat] = new ProdAux[_0, B, _0] {}
implicit def prod2[A <: Nat, B <: Nat, C <: Nat, D <: Nat]
(implicit ev1 : ProdAux[A, B, C], ev2 : SumAux[B, C, D]) = new ProdAux[Succ[A], B, D] {}
}
到目前为止,我已经提出了简单的定义
def toInt[A <: Nat, B <: Nat, C <: Nat](p: Prod[A, B])
(implicit paux: ProdAux[A, B, C], iv: ToInt[C]): Int = iv()
事实上,这种方法需要对等价代码进行一些冗余的实现,例如求和、差异、阶乘等。所以我宁愿能够使用“默认”方法toInt[A <: Nat]
。
你会怎么做?是否可以使用内部类型(Prod#Out
,,Sum#Out
...)?