力迫法

· · 个人记录

当我们谈论集合论时我们脑海中总是浮现出那种经典、"正常"、"标准"的集合论的形象。但事实上符合我们熟悉那几条集合论公理的对象并不是唯一的:是否承认不可构造集、是否承认无穷集都属于可选的内容。我们所想象的那个"标准"形象只是集合论的一个模型

哥德尔完备性定理告诉我们,一个理论一致当且仅当存在一个满足它的模型。理论的一致只关乎形式推理,属于句法 (syntax);而它在模型中能否被满足则属于语义 (semantics)。由此,句法上的研究,例如考虑一个定理是否与集合论公理独立,可以通过句法上,也即对于模型的研究完成。

力迫法的含义就在于人工构造一个模型强制使它满足我们的目标理论,进而证明目标理论一致。这些模型和我们想象的"标准"模型的区别在于它们多承认了一些集合(即所谓力迫扩张)。

可能你不明白承认某些集合与否和理论是否被满足有什么关系。假如我们根本不承认无穷集,那么所有的基数统统不存在;假如我们承认很多奇怪的无穷集,那么基数就会相对更加密集,连续统可能等于 \aleph_2,\aleph_3 甚至更多。

接下来我们具体介绍力迫法的细节。

布尔代数

这部分实际上是我们曾经谈论过的理论结构的细化。

布尔代数也可以称为有补分配格。我们快速过一下。

(一个非常简单的布尔代数。)

取一个一阶逻辑语言 \mathfrak L 和其上的任意理论 T,我们记 T\vdash\varphi 表示理论 T 下能够形式化推理出命题 \varphi。我们以 T\vdash \varphi\leftrightarrow\psi 为命题划分等价类,以 T\vdash \varphi\rightarrow\psi 建立偏序,可以证明我们得到的偏序集是一个布尔代数,我们称它是被 T确定的布尔代数。显然 \mathfrak L 中的逻辑算符都有布尔代数中的对应。

我们自然需要一个把 T 上的命题映射到其确定的布尔代数 B 上的等价类的函数,记作 \varphi\mapsto[[\varphi]]

集合论宇宙的布尔代数扩张

现在我们来考虑我们的 ZFC 集合宇宙 V,让我们为每一个集合 x 分配一个特征函数 f_xx 包含于其定义域,值域为 \{0,1\}f_x(y)=[y\in x]。那么 x 自然可以被 f_x 所描述。V 当然是良基的,所以我们可以直接归纳(递归?)重新把 V 描述一遍:从 V_{\beta<\alpha}^{(2)} 归纳到 V_{\alpha}^{(2)}。这样得到的宇宙记为 V^{(2)}​。

x\in V^{(2)}\leftrightarrow \text{range}(x)\subseteq 2\land \text{domain}(x)\subseteq V^{(2)}

这看起来没什么用(事实上可以证明 V^{(2)}V 同构)。但是,如果我们把值域从 \{0,1\}(最简单的布尔代数)替换为任意布尔代数 B(其实也没有那么任意,应当至少还属于集合),得到的新宇宙 V^{(B)} 就有很多说法了,我们称它为 VB 扩张。似乎在这个宇宙中"集合"间的从属关系不总是 0,1 而可能取 B 中的任意值。不过这也不一定就是说 u\in v 的布尔值是 f_v(u)……往下看就知道了。

为了谈论 V^{(B)} 上的命题,我们在 \mathfrak L 中加入 V^{(B)} 中所有集合的(形式化)名称,得到的新语言称为 \mathfrak L^{(B)}。我们将把 \mathfrak L,\mathfrak L^{(B)} 上的命题区别开来,分别称为命题B-命题

显然对于所有 B-命题 我们都可以依如下法得到其布尔值 \varphi\mapsto [[\varphi]]^B由于 Tarski's undefinability theorem,这并不是一个实际上的映射。读者应该从元数学的角度来理解它。):

比较棘手的是原子 B-命题 u\in v,u=v。我们仍希望外延公理在 V^{(B)} 上成立,那么这两者只好这样互相递归定义:

良基性再次救命。

如果 [[\sigma]]^B=1,那么我们称 B-命题 \sigma,记 V^{(B)}\vDash \sigma

可以想象到(也相对比较好证明),考虑 B 的一个子代数 B'(子集且是布尔代数),我们可以得到 V^{(B')}V^{(B)} 的一个子模型V^{(B)} 不会做出与 V^{(B')} 不同的判断。具体来说:

2 总是任何布尔代数的子代数,而我们已经知道 V^{(2)}V 是同构的,所以 V 总是所有 V^{(B)} 的子模型。这很有用。事实上,ZFC 公理的 B-版本在 V^{(B)} 中也为真,包括 AC。下面我们记 V 中元素的 V^{(2)} 版本为 \hat x,具体来说

\hat x=\hat y\mapsto 1,y\in x

但是 某 些 东 西 的 B-版本就不是这样了。V 中的序数(\forall y\in x[y\subseteq x])都是 V^{(B)}​​ 中的序数,但反之不然。基数也是。(不然就没意思了。)

(其实,如果 B 比较简单,更具体地说满足 countable chain condition:每条反链的长度都可数,那么上述性质是双向成立的。)

此外,为了埋下伏笔,有一个关键的关于 V^{(B)} 中的可构造集的性质需要我们证明:

定理.

$$ [[L(u)]]=\bigvee_{x\in L}[[u=\hat x]] $$ **证明.** $$ [[L(u)]]=[[\exists\alpha(u\in L_\alpha)]]=\bigvee_{\alpha\in\text{ORD}}[[u\in L_{\hat\alpha}]] $$ 后一个等号很不显然,这涉及到 $V^{(B)}$ 中的序数的奇妙性质:$[[\text{Ord}(u)]]=\bigvee_{\alpha\in\text{ORD}}[[u=\hat\alpha]]$。即,$V^{(B)}$ 中的序数都是正版序数 $\hat\alpha$ 们的"混合"。这里我们不给出证明。 命题 $x=L_{\alpha}$ 由于是一个关于 $x$ 和 $\alpha$ 的 $\Sigma_1$ 公式,结构相对简单,可以比较容易地证明它可以推出它的 $B$-版本,即 $$ x=L_{\alpha}\rightarrow[[\hat x=L_{\hat \alpha}]]=1 $$ 即 $$ [[\widehat{L_{\alpha}}=L_{\hat\alpha}]]=1 $$ 故原式等于 $$ =\bigvee_{\alpha\in\text{ORD}}[[u\in \widehat{L_{\alpha}}]]\\=\bigvee_{\alpha\in\text{ORD}}\bigvee_{x\in L_{\alpha}}[[u=\hat x]]\\=\bigvee_{x\in L}[[u=\hat x]] $$

力迫偏序

现在我们来讲一个看似无关的主题:一种偏序关系,称为力迫偏序

事情其实是这样的。我们想加进模型的集合其实是力迫偏序里的一个 generic filter(一般译为脱殊滤),力迫偏序和这个 generic filter 编码了一些关于我们目标命题的信息。但问题就出在这里,它们的定义关涉了太多语义上的内容导致这个 generic filter 干脆可被证明不存在。但是如果我们给这个力迫偏序制造一个对应的布尔代数 B,我们就可以把语义上的

p\Vdash\varphi

转化为纯句法的

p\le[[\varphi]]^B

从而避免这一问题。

接下来我们介绍力迫偏序的含义和由它构造 B 的方法。

P 是一个偏序集。含义上,P 代表了一系列条件,p\le q 代表 pq 的细化(p 强于 q)。

p,q 相容,记为 \text{Comp}(p,q),当且仅当 \exists r,r\le p,r\le q

满足以下条件的 P 被称为是细化的

\forall p,q\in P,q\not\le p\rightarrow \exists q'\le q,\neg\text{Comp}(q',p)

即,若 q 不是 p 的细化,那么必定存在一个它的细化与 p 不相容。

O_p\le p 的所有元素。把 O_p 们视为拓扑基底,就得到一个 P 上的拓扑;称一个拓扑上等于其闭包的内部的集合为正则开集。记 \text{RO}(P) 是这一拓扑中的所有正则开集。

可以证明,任取一个拓扑,其正则开集(在 \subseteq 下)必定构成一个布尔代数。这里 \text{RO}(P) 就是我们所意欲的 B

下面给出一些 PB 的关系。

现在令 p 是一个 e(P)(那个稠密子集)中的元素(接下来我们可能不区分 e(P)P),令 \sigma 是一个 B-命题。定义:

p\Vdash\sigma\leftrightarrow p\le[[\sigma]]^B

如果我们把 P 看作条件不断细化的分化树,p\Vdash \sigma 就表明在 p 处我们将被接受 \sigma

\omega 的不可构造子集的存在性相容于 ZFC

P 为所有 \omega有限子集到 2 的映射。P 上有自然的偏序:pq 的细化当且仅当 qp 的一部分。p​ 也就被理解为为自然数取值。

e(p) 为:所有 \omega2 的映射中是 p 的"细化"的。以 e(p) 们为基底构造一个拓扑(2^{\omega}),其中的正则开集作为 B。可以证明,尽管 B 不是由之前的方法直接构造,但如今得到的 B=\text{RO}(2^\omega) 既然是 P 的一个布尔补完,而布尔补完又是唯一(精确到同构)的,所以就没有问题。

大功业如今就在眼前。

定理.

Pxx 的幂集。

证明.

定义

u=\hat n\mapsto \{f\in 2^{\omega}|f(n)=1\}

显然

[[u\in P\hat\omega]]^B=[[u\subseteq\hat \omega]]^B=\bigwedge_{n\in \omega}u(\hat n)\Rightarrow [[\hat n\in \hat\omega]]^B=1

这很自然。

但是我们竟然要证明:u 不属于 \widehat{(P\omega)}

假设不然,那么必定存在 p\in P,x\in P\omega,使得 e(p)\Vdash u=\hat x​。(因为 e(P) 稠密)

那么总可以取 n\notin\text{dom}(p)(因为 p 有限),构造一个细化 p'=p\cup(n\mapsto 0/1)。如果 n\in x,我们就令 p'(n)0;如果 n\notin x,我们就令 p'(n)1​​。

我们有

e(p')\Vdash\hat n\in u\leftrightarrow e(p')\subseteq u(\hat n)\leftrightarrow p'(n)=1

这样在 e(p')\hat n\in u\hat n\in x 总是只有一个成立。e(p')\Vdash u\neq x,但 p' 又是 p 的一个细化,矛盾。

通俗地说,由于 P 中有着无限细分的路径稠密地包围了 B 中的 0(你可以试试想象康托集;事实上康托集就是 \text{RO}(2^{\omega})),一旦声称 u=\hat x 就总会落到其中一点,u 的性质又保证在极远处 \hat n\in u​ 仍在不停震荡,从而生出一条岔路将其否定。

也算是某种对角线论证吧……但是更为诡异。

接下来进入更诡异的第二部分。仍关注那个 u。根据之前证过的那个定理,

[[L(u)]]^B=\bigvee_{x\in L}[[u=\hat x]]^B

我们把 L 分成 L\cap P\omegaL-P\omega 两部分。前者已经完蛋了。而对于后者(x\notin P\omega

[[u=\hat x]]^B=[[u=\hat x]]^B\land[[u\in P\hat \omega]]^B\le [[\hat x\in P\hat \omega]]^B=[[\hat x\subseteq \hat \omega]]^B

这是不可能的,因为我们已经知道 x\notin P\omega

最后再来总结一下:回顾 e(p)\Vdash\hat n\in u\leftrightarrow p(n)=1 这一性质,我们可以把 u 看作是一个新加入的"待被我们给出的条件决定形态"的集合,它的外延"悬而未决"同时又有前述的震荡性质,但又在 V^{(B)} 里"实际存在",这样一个很神经的模型却又是一个合理的模型,最终导致了一系列……悲剧的发生。

连续统假设之独立性

刚好前述的 B 可以接着用。我们现在来证明(广义)连续统假设与 ZFC 相容。

定理.

假设广义连续统假设(GCH)成立,如果 B 满足 countable chain condition,且 |B|=2^{\aleph_0}(显然前述的 B 满足这两条),则

V^{(B)}\vDash\text{GCH}

V^{(B)}\vDash\forall \alpha[|P\aleph_\alpha|\le \aleph_{\alpha+1}]

证明.

幂集在 V,V^{(B)} 是一致的。记 P^{(B)}(u)=x\mapsto[[x\subseteq u]],x\in B^{\text{dom}(u)},可以证明

V^{(B)}\vDash P^{(B)}(u)=Pu

现在令 u=\widehat{\aleph_{\alpha}}​。

由于 GCH,|\text{dom}(P^{(B)}(u))|=|B^{\text{dom}(u)}|=(2^{\aleph_0})^{\aleph_{\alpha}}=\aleph_{\alpha+1}。而 |P^{(B)}(u)|\le |\text{dom}(P^{(B)}(u))|,即

V^{(B)}\vDash|P^{(B)}(u)|\le\aleph_{\alpha+1}

由于 B​ 满足 ccc,基数性质也反向成立,综合即得到之前的结论。

可见连续统假设的成立与否被 P^{(B)} 的情况控制;如果 |B| 足够大,Pu 的基数就会和 P^{(B)}(u) 一起爆炸。

B=\text{RO}(2^{\omega\times\omega_{\alpha}}),可以(通过一些恶心的基数不等式,还得考虑基数和它们的 B-版本的关系,细节不表)证明

V^{(B)}\vDash 2^{\aleph_0}=\aleph_{\hat\alpha}

因此连续统可以等于 \aleph_2,\aleph_{\omega} 甚至 \aleph_{\omega_1}(蛤???这也太 broken 了)等等等等。