首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Prod在shapeless中的整数值

Prod在shapeless中的整数值
EN

Stack Overflow用户
提问于 2012-02-12 18:59:18
回答 1查看 317关注 0票数 3

在兴奋地玩着shapeless自然数时,我想知道获得例如nats乘积的整数值的最好方法是什么。

摘自shapeless nat.scala

代码语言:javascript
复制
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] {}
}

到目前为止,我已经给出了简单的定义

代码语言:javascript
复制
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#OutSum#Out等)?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2012-02-27 02:03:47

很抱歉我之前错过了这个问题(顺便说一句,shapeless mailing list是一个问这个问题的好地方)。

我认为您稍微误解了Prod类型类的作用:它的实例本身不是Nat,它们见证了三个Nat之间的关系,即(A * B) == C。因此,将Prod实例转换为Int并没有多大意义,或者更确切地说,如果是这样的话,结果值对应于ABC中的任何一个或所有这些值的三元组也同样有意义。

为了在方法定义中用作证明术语,您所显示的样式与预期的基本一致……有关示例,请参阅here。显然,这并不能很好地解决REPL上的问题。为了让它更流畅一点,你可以试着这样做,

代码语言:javascript
复制
def prod[A <: Nat, B <: Nat](implicit prod : Prod[A, B]) =
  new { def toInt(implicit ti : ToInt[prod.Out]) = ti() }

这允许REPL交互,例如,

代码语言:javascript
复制
scala> prod[_2, _3].toInt
res0: Int = 6

如果这仍然不是你想要的,那么请前往邮件列表,勾勒出你想要做的事情。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/9248271

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档