- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我仍然想知道相等类型的术语 eq
是什么意思在 COQ 中可以不同于 eq_refl
.
下面的术语是一个例子吗?
((fun x:nat => eq_refl x) 2).
eq_refl
,但它计算为
eq_refl
.
eq_refl
的术语的例子? ?
最佳答案
正如您所指出的,(fun x => eq_refl x) 2
实际上与 eq_refl 2
没有区别,因为两个表达式计算的结果相同。
回答你的第二个问题有点微妙,因为它可以有很多不同的解释。这是一种可能性(我认为这是您想到的一种):
Are there any type
T
and termsx y : T
, such that there is a proofe
of@eq T x y
in the empty context that does not compute to@eq_refl T z
(wherez : T
is the result of computingx
andy
)?
e
必须有范式
e'
,以及所有类型为
eq
的范式必须是
eq_refl
.
e
的要求在空上下文中键入,这不再成立。例如,考虑
forall n, n + 0 = n
的证明项.
Fixpoint plus_n_0 n : n + 0 = n :=
match n return n + 0 = n with
| 0 => eq_refl 0
| S n' => match plus_n_0 n' in _ = m return S (n' + 0) = S m with
| eq_refl => eq_refl (S (n' + 0))
end
end.
match
出示
S (n' + 0) = S n'
的证明不计算为
eq_refl
.这是因为
match
无法减少
plus_n_0 n'
术语,因为它是一个应用于变量的函数。但是,如果我们申请
plus_n_0
对于任何具体的自然数(例如,
1729
),结果证明将计算为
eq_refl 1729
(尝试一下!)。
eq_refl
时,我们不得不在 Coq 的逻辑之外进行推理,诉诸于我们不能将其表述为 Coq 命题的规范化论证:请注意,因为 Coq 标识了可转换性之前的术语,因此无法编写命题
P : nat -> Prop
使得
P n
成立当且仅当
n
是标准形式的 Coq 项。
forall T (x : T) (e : x = x), e = eq_refl x,
eq_refl
”。事实证明,这个语句独立于 Coq 的逻辑,这意味着它不能在 Coq 本身内被证明或反驳。
T
完全没问题。 , 一些术语
x : T
,以及一些证明
e
的
x = x
使得
e <> eq_refl x
.如果我们添加了这个公理,那么我之前给出的论证将不再适用,因为会有正常形式的等式证明在语法上与
eq_refl
不同。 (即,
e
)。
=
关联的项)。 Coq 中定义相等的项可以互换,而命题相等的项必须通过显式重写步骤(或使用
match
语句,如上所示)进行交换。
nat
的自反性替代证明:
Fixpoint eq_refl_nat (n : nat) : n = n :=
match n return n = n with
| 0 => eq_refl 0
| S n' => match eq_refl_nat n' in _ = m return S n' = S m with
| eq_refl => eq_refl (S n')
end
end.
eq_refl_nat
不等于
eq_refl
: 我们无法获得
eq_refl
来自
eq_refl_nat
只是通过简化。然而,两者在命题上是相等的:事实证明,对于
nat
,可以证明
forall n (e : n = n), e = eq_refl
. (正如我上面提到的,这不能针对任意 Coq 类型显示。)
关于equality - 不是 eq_refl 的 COQ 标识项,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35157052/
我正在尝试理解 Coq 定理: Theorem thm0 : UseCl Pos (PredVP (UsePN john_PN) walk_V) -> UseCl Pos
编辑 Require Import Bool List ZArith. Variable A: Type. Inductive error := | Todo. Induc
我试图在 Coq 中证明以下引理: Lemma not_eq_S2: forall m n, S m <> S n -> m <> n. 这似乎很容易,但我不知道如何完成证明。有人可以帮帮我吗? 谢谢
我想查看我的证明中使用的所有公理。 获取此类信息的最简单方法是什么? 我将使用哪些命令、脚本或工具? 我对所有公理或所有使用过的公理感兴趣。 最佳答案 你应该使用 Print Assumptions
我想以某种方式限制在归纳定义中允许什么样的输入构造函数。说我想说定义二进制数如下: Inductive bin : Type := | O : bin | D : bin -> bin |
Coq 标准库中是否有对自然数进行欧几里德除法的函数?我一直无法找到一个。如果没有,那么从数学上讲,是否有理由不应该有一个? 我想要这个的原因是因为我试图将一个列表分成两个较小的列表。我希望一个列表的
我在将参数传递给 coq 中的产品类型时遇到问题。我有一个看起来像这样的定义, Definition bar (a:Type) := a->Type. 我需要定义一个函数,它接收“a”和“ba
这是本在线类(class)中出现的证明https://softwarefoundations.cis.upenn.edu/plf-current/StlcProp.html#lab222 . Proo
在命题和谓词演算中证明了数十个引理后(有些比其他的更具挑战性,但通常仍然可以在 intro-apply-destruct 自动驾驶仪上证明)我从 ~forall 开始打了一个并立即被捕获。显然,我缺乏
我正在学习命题逻辑和推理规则。析取三段论规则指出,如果我们的前提中有(P 或 Q),并且也有(非 P);然后我们可以到达Q。 我一生都无法弄清楚如何在 Coq 中做到这一点。假设我有: H : A \
从 Coq 引用手册 (8.5p1) 来看,我的印象是 revert是 intro 的倒数,但 generalize 也是如此在某种程度上。例如,revert和 generalize dependen
假设我知道某些自然数是好的。我知道 1 很好,如果 n 很好,那么 3n 就是,如果 n 很好,那么 n+5 就是,这些只是构造好数字的方法。在我看来,这在 Coq 中的充分形式化是 Inductiv
通常在 Coq 中,我发现自己在做以下事情:我有证明目标,例如: some_constructor a c d = some_constructor b c d 而我真的只需要证明a = b因为无论如
我希望能够为不同的归纳定义定义相同的 Coq 符号,并根据参数的类型区分这些符号。 这是一个最小的例子: Inductive type : Type := | TBool : type. Induct
有没有办法对 Coq 的类型类使用递归?例如,在为列表定义显示时,如果您想调用 show递归列表函数,那么你将不得不使用这样的固定点: Require Import Strings.String. R
假设我有一个解决某种引理的奇特策略: Ltac solveFancy := some_preparation; repeat (first [important_step1 | importa
我是 Coq 的新手。我注意到可以使用在 Coq 中定义空集 Inductive Empty_set : Set :=. 是否也可以将函数从空集定义为另一个通用集/类型? 如果是这样怎么办? 最佳答案
有人能给我一个 Coq 中存在实例化和存在泛化的简单例子吗?当我想证明exists x, P ,其中 P是一些 Prop使用 x ,我经常想命名x (如 x0 或类似的),并操纵 P。这可以是 Coq
我见过很多在功能上相互重叠的 Coq 策略。 例如,当您在假设中有确切的结论时,您可以使用 assumption , apply , exact , trivial ,也许还有其他人。其他示例包括 d
我需要使用标准库中称为 Coq.Arith.PeanoNat ( https://coq.inria.fr/library/Coq.Arith.PeanoNat.html ) 的部分。 我尝试过导入整
我是一名优秀的程序员,十分优秀!