gpt4 book ai didi

辅 enzyme Q "convoy pattern"

转载 作者:行者123 更新时间:2023-12-01 12:34:17 26 4
gpt4 key购买 nike

我正在尝试使用“车队模式”来保留 3 个变量(两个参数和返回值)之间的依赖关系:

Require Import Vector.

(* "sparse" vector type *)
Notation svector A n := (Vector.t (option A) n).

Fixpoint svector_is_dense {A} {n} (v:svector A n) : Prop :=
match v with
| Vector.nil => True
| Vector.cons (None) _ _ => False
| Vector.cons (Some _) _ xs => svector_is_dense xs
end.

Lemma svector_tl_dense {A} {n} {v: svector A (S n)}:
svector_is_dense v -> svector_is_dense (Vector.tl v).
Admitted.

Lemma svector_hd {A} {n} (v:svector A (S n)): svector_is_dense v -> A.
Admitted.

Fixpoint vector_from_svector {A} {n} {v:svector A n} (D:svector_is_dense v): Vector.t A n :=
match n return (svector A n) -> (svector_is_dense v) -> (Vector.t A n) with
| O => fun _ _ => @Vector.nil A
| (S p) => fun v0 D0 => Vector.cons
(svector_hd v0 D0)
(vector_from_svector (Vector.tl v) (svector_tl_dense D))
end v D.

问题出现在最后一个定义中。有什么建议为什么它不起作用吗?

最佳答案

你几乎是对的。问题出在您的 return 子句中,该子句是非依赖的。你需要的是

match n return forall (w: svector A n), (svector_is_dense w) -> (Vector.t A n) with

因此 D0 不是您的情况下的 svector_is_dense v 类型,而是 svector_is_dense v0

顺便说一下,在第二个构造函数中,我猜你指的是 Vector.tl v0svector_tl_dense D0。这是我写的完整术语(不要介意 cons 中的附加 _,我没有激活 implicits):

Fixpoint vector_from_svector {A} {n} {v:svector A n} (D:svector_is_dense v): Vector.t A n :=
match n return forall (w:svector A n), (svector_is_dense w) -> (Vector.t A n) with
| O => fun _ _ => @Vector.nil A
| (S p) => fun v0 D0 => Vector.cons _
(svector_hd v0 D0) _
(vector_from_svector (svector_tl_dense D0))
end v D.

关于辅 enzyme Q "convoy pattern",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31041297/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com