Coq是一种形式化的证明管理系统,半交互式定理证明器和函数式编程语言。 Coq用于软件验证,编程语言的形式化,数学定理的形式化,教学等。由于Coq的交互性,如果认为合适,我们建议将问题链接到https://x80.org/collacoq/上的可执行示例。
我正在尝试证明以下引理。 感应布尔:类型:= |真的 |错误的。 引理 andb_true_iff : forall b1 b2 : bool, b1 && b2 = true <-> b1 = true // b2 = true。 证明。
我正在尝试证明对立性。我的证明如下。这不起作用。 定理反证:forall (P Q : Prop), (P -> Q) -> (~Q -> ~P)。 证明。 介绍。 摧毁H...
我已经有了一个定理 定理 plus_id_example : forall n m:nat, n = 米 -> n + n = m + m。 我想证明它的“逆形式”。所以我有 定理 plus_n_n_injective :对于所有 n ...
如何申请(S n' <=? m) = true to S n' <= m?
试图完成 Coq 证明,但我最终陷入了最后一个目标。我把目标变成了S n' <= m and have a hypothesis (S n' <=? m) = true, but am unable to unify these. I tr...
我有两个函数 build_goal_aux 和 last 定义如下: 定点 build_goal_aux (acc:list nat)(n:nat) : list nat := 匹配 n 与 | O => ACC | S n' => build_goal_aux (n::acc) n' ...
引理 x: forall P Q: Set -> Prop, forall f:设置->设置, 对于所有 x,(P x -> Q (f x)) -> (存在x,P x)->(存在x,Q x)。 我尝试去做...
软件基础(lf):证明leb_plus_exists和plus_leb_exists
我一直在学习《软件基础》第一卷,但我无法通过 Logic.v 中的一对可选问题。有人知道该怎么做吗? 定理 leb_plus_exists :对于所有 n m, n &l...
我注意到,在 Coq 的有理数定义中,零的倒数被定义为零。 (通常,除以零是没有明确定义/合法/允许的。) 需要导入 QArith。 引理 inv_zero_is_zer...
Coq/Ltac:是否可以设计一种策略,在决策程序证明目标时证明目标已被证明,而无需证明项?
我正在设计一种 Coq 策略,它调用一个决策过程,该过程回答是/否,而不给出证明术语。当我回答“是”时,我想说 Ltac 目标已得到证明。 有没有办法...
我正在尝试在 Coq 中实现一个索引函数。我写了这段代码: 表示法 grid := (list nat)。 定点index_aux (n : nat) (g : grid) (i : nat) : 选项 nat := 将 g 与 | [] =>...
引理 x: forall P Q: Set -> Prop, forall f:设置->设置, 对于所有 x,(P x -> Q (f x)) -> (存在x,P x)->(存在x,Q x)。 我尝试去做...
为什么 coq 无法识别 `None = Some v` 是 false?
我有一个功能: 定点评估 (fuel : nat) (env : 环境) (e : exp) := 匹配燃料 | 0 => 无 | S 燃料' => (...) 结尾 我现在正在证明这种函数的属性......
使用以下 Coq 代码: 搜索“prod_uncurry_subdef”。 需要导入算术。 搜索“prod_uncurry_subdef”。 打印出以下内容: prod_uncurry_subdef: forall [A B C : T...
我想在 Coq 中定义一个小记录,其中也包含某些条件。此外,我想要一个定义来以简单的方式创建记录。这是我的方法: 需要导入算术。 (* 德菲...
如何在 coq 中证明 b = c if (andb b c = orb b c) ?
我是coq新手,我正在努力证明这一点...... 定理 andb_eq_orb : forall (b c : bool), (andb b c = orb b c) -> (b = c)。 这是我的证明,但当我达到目标时我陷入困境(错误=...
如何证明 (X × Y = ∅) <-> (X = ∅) ∨ (Y = ∅)
我希望使用 Coq 和 mathcomp.classical_sets 证明下面的引理。 设 A × B - 某些集合的乘积,即 {(z1, z2) | z1 Î A /\ z2 Î B} 那么 (A × B = ∅) <-> (A = ∅) ∨ (B = ∅) 我的证明是
我正在使用 Iris for Coq,但我遇到了一些问题。 在这里,我想从 hd' 获取 snd 值 l'。然后我可以使用 IH 与 Hl 和 Hphi 来完成目标。有谁知道如何替换 hd' in...
需要帮助证明 (X × Y = ∅) <-> (X = ∅) ∨ (Y = ∅)
请帮助我使用 Coq 和 mathcomp.classical_sets 证明下面的引理。 设 A × B - 某些集合的乘积,即 {(z1, z2) | z1 Î A /\ z2 Î B} 那么 (A × B = ∅) <-> (A = ∅) ∨ (B = ∅) 我的证明