首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Idris总体检查

Idris总体检查
EN

Stack Overflow用户
提问于 2022-08-29 02:04:56
回答 1查看 63关注 0票数 3

我正在使用Idris2编译以下简单程序。

代码语言:javascript
复制
import Data.Fin

%default total

negate : {k:_} -> Fin k -> Fin k
subt : {k:_} -> Fin k -> Fin k -> Fin k
add : {k:_} -> Fin k -> Fin k -> Fin k

mult : {k:_} -> Fin k -> Fin k -> Fin k
mult FZ b = FZ
mult (FS a) b = add b $ mult (weaken a) b

但是,编译器产生一个错误:

代码语言:javascript
复制
Error: mult is not total, possibly not terminating due to recursive
path Main.mult -> Main.mult -> Main.mult

对输入a的递归调用不是比(FS a)小吗?为什么整个检查失败了?

谢谢!

EN

回答 1

Stack Overflow用户

发布于 2022-09-08 14:38:19

我不知道为什么编译器没有意识到weaken aFS a小,尽管我怀疑问题是weaken

您可以通过断言weaken aFS a小来绕过它。

代码语言:javascript
复制
module Misc

import Data.Fin

%default total

add : Fin k -> Fin k -> Fin k
add a b = ?add_rhs

mult : Fin k -> Fin k -> Fin k
mult FZ _ = FZ
mult a@(FS a') b = add b $ mult (assert_smaller a (weaken a')) b

请注意,在通常对整数进行加法和乘法的定义下,结果可能大于k。我假设您的add实现会处理这个问题。

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

https://stackoverflow.com/questions/73523536

复制
相关文章

相似问题

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