ZFC in LEAN 之 前集的等价关系(Equivalence on Pre-set)详解

《前集等价关系》 一文中,已经简单地描述了,等价关系的要求,以及前集的等价关系(Equivalence on Pre-set)的定义。因为,这个前集的等价关系,是对后面的讲述起到关键作用,因此,这里展开说说。

前集(pre-set)定义

前集(Pre-set)在LEAN中,定义为,

前集的等价关系(Equivalence Relation)定义

其等价关系(Equivalence Relation),定义为,

这里的Prop,指的是命题宇宙,即包含所有命题。这里,是LEAN的类型系统中的类型宇宙特性,详细内容可查看LEAN类型理论的文章

那么,Equiv,可看作是一个函数, 如 Equiv x y,输入两个 前集(x y :PSet),输出一个命题(:Prop),如果,该输出的命题是有证明的(Inhabited),那么,前集 x y 相等。

即,该函数表达了,如果对于两前集(Pre-set),第一前集的任一元素都与第二前集中的一个元素相等,反之亦然,那么两前集(Pre-set)相等(equivalent)。

这里,根据 PSet 的定义,其索引函数是用于索引所有包含的元素(members),因此,在 Equiv 函数中,其输出的命题,就是 需要归纳式(Inductively)地证明两前集相等。因为,前集(Pre-set)的定义也是归纳式的(Inductive)。即,前集(Pre-set)的元素(members)也是前集(Pre-set)。

等价关系要求的定义

也就是说,当一个二元关系(Binary Relation)满足等价关系要求是,该二元关系成为等价关系。其定义如下:

可见,该 Equivalence 结构包括了,自反性,对称性,及 传递性,其类型是命题。也就是,Equivalence 包含了其三属性的命题。因此,要使一个二元关系 r,满足等价关系(Equivalence),需要满足其中的三个属性,即,自反性(refl),对称性(symm),及 传递性(trans)。

前集的等价关系(PSet.Equiv)的等价属性

那么,前集的等价关系(PSet.Equiv)是如何满足等价关系的要求(Equivalence)呢?有如下定义:

  1. 自反性(Reflexivity):
  1. 相等替换(substitution):

即,x = y, z = y,那么,x = z。

这里需要解析一下,

  1. 前三个 〈_, _〉,对应着 x y z,表示忽略 x y z,其类型为 PSet。

  2. αβ 表示 Equiv x y 输出命题的左边部分。从 Equiv 的定义来看,其输出是一个与(∧, and)的命题,有左右两命题组成。因此,αβ 表示左边的部分,即 前集 x 中任一元素,都存在前集y的一个元素与之相等。即,αβ 是 Equiv x y 左命题的证明。

  3. 同理第二点,βα 是 Equiv x y 右命题的证明;γβ 是 Equiv z y 左命题的证明; βγ 是 Equiv z y 右命题的证明。

  4. 此时,需要通过 αβ,βα,γβ,βγ,来构建 Equiv x z 左右命题的证明。

  5. Equiv x z 左命题是,前集 x 中任一元素,都存在前集z的一个元素与之相等。

那么,上面的 fun a 的 a 就是前集x的任一元素,αβ a 为与之对应前集 y的元素 b,其中,ab 是元素 b 存在的证明,即代表了 a = b,亦 ab: a = b。

那么,通过,βγ b,找到与之对应的前集 z 的元素 c,其中 bc 是元素 c 存在的证明,即代表了 b = c,亦 bc: b = c。

那么,元素 c 便是 Equiv x z 左命题的 前集 z 中,与 前集x 中任一元素 a 对应的与之相等的元素。

另外,要证明存在命题,除了需要找到对应的元素外,还需提供其相等的证明,即 Equiv.euc ab bc,亦 a = b ∧ b = c。

这里有意思的是,一开始定义Equiv.euc 时,是对于前集间的相等,到其定义体(Body)里,即,Equiv.euc ab bc,是对于其元素间的相等,因为元素也是前集,因此递归下去求证。

那么,〈c, Equiv.euc ab bc〉 就是 Equiv x z 左命题 的证明了。

  1. 同理第5点,〈a, Equiv.euc ba cb〉 为 Equiv x z 右命题 的证明。

  2. Equiv x z 左右命题都得以证明,因此,Equiv x z 也得以证明。

  3. 对称性(Symmetricity)

  1. 传递性(Transitivity)

这里的参数名用 h₁,h₂来表示,是一种惯例(Convention),h for hypothesis。

相关推荐
Smile灬凉城6667 分钟前
反序列化为啥可以利用加号绕过php正则匹配
开发语言·php
lsx20240619 分钟前
SQL MID()
开发语言
Dream_Snowar22 分钟前
速通Python 第四节——函数
开发语言·python·算法
西猫雷婶23 分钟前
python学opencv|读取图像(十四)BGR图像和HSV图像通道拆分
开发语言·python·opencv
鸿蒙自习室24 分钟前
鸿蒙UI开发——组件滤镜效果
开发语言·前端·javascript
言、雲31 分钟前
从tryLock()源码来出发,解析Redisson的重试机制和看门狗机制
java·开发语言·数据库
Altair澳汰尔35 分钟前
数据分析和AI丨知识图谱,AI革命中数据集成和模型构建的关键推动者
人工智能·算法·机器学习·数据分析·知识图谱
A懿轩A1 小时前
C/C++ 数据结构与算法【栈和队列】 栈+队列详细解析【日常学习,考研必备】带图+详细代码
c语言·数据结构·c++·学习·考研·算法·栈和队列
汪洪墩1 小时前
【Mars3d】设置backgroundImage、map.scene.skyBox、backgroundImage来回切换
开发语言·javascript·python·ecmascript·webgl·cesium
Python机器学习AI1 小时前
分类模型的预测概率解读:3D概率分布可视化的直观呈现
算法·机器学习·分类