一种基于交换环的命题逻辑代数推理算法

一种基于交换环的命题逻辑代数推理算法

老实说,我一直觉得类似深度学习的纯数值方法(那些个Neural-Symbolic其实也是意识流的掩耳盗铃,完全没有理论基础,全靠"艺术创作")实在难以胜任逻辑推理,一个可行的、有希望实现计算地进行逻辑推理的方案就是借助构造一种抽象代数结构(最后借助代数结构间的同态性来实现);


构造一种Logic-Ring的意义(Motivation)

最终目的是更好地进行逻辑推理,详细地讲:

  • 环代数的结构比逻辑代数更佳;
  • 环代数有许多优良的性质(域/理想/复形…);
  • 可以引入多项式环或者其它更多种类的、能做到和逻辑环同构的环用作Representation来进而实现推理(比如矩阵环/集合环…);

谓词逻辑命题环

  • L\mathcal{L}是一个谓词逻辑命题的集合,则有运算(,)(\lor,\land)L\mathcal{L}中封闭;
  • 令蕴含运算\rightarrowL\mathcal{L}上的一个二元关系,易证\rightarrowL\mathcal{L}上满足"自反性"、“反对称性”、“传递性”(因此是一个偏序关系);
  • 我们将\lor看作加法、将\land看作乘法,\rightarrow看作偏序;

现在我们可以将谓词命题逻辑看做一个环结构(L,,,)(\mathcal{L},\lor,\land,\rightarrow);

如何推理:引入其它的环

构造逻辑环仅仅完成了对命题的表征,而最终的目的是推理,因此我们必须有赋值:

  • 在谓词逻辑环(L,,,)(\mathcal{L},\lor,\land,\rightarrow)表征命题;
  • 在多项式环(R[x1xn],+,×,<)(\mathbb{R}[x_1 \cdots x_n],+,\times,<)推理命题;
  • 在集合环(E,,,)(\mathcal{E},\cup ,\cap,\subset)判定命题;
环之间的单同态

因此我们可以构造L,R[x1xn],E\mathcal{L},\mathbb{R}[x_1 \cdots x_n],\mathcal{E}之间的单同态来实现谓词逻辑命题的Computation:

一种基于交换环的命题逻辑代数推理算法

在这个图中有Ψ=Φφ\Psi = \Phi \circ \varphi;更进一步,我们甚至可以引入谓词逻辑环的理想和商环(参见我6月底写的上一篇文档:<<基于多项式环的谓词逻辑命题推理算法>>);

一个漏洞

至此,这一切似乎已经很完美了,但是我发现这个逻辑环并不能满足环的定义,试着带入环的定义:

  • 在谓词逻辑环L\mathcal{L}中有一元素FF满足:对p(x)L\forall p(x) \in \mathcal{L}有:p(x)F=Fp(x)=p(x)p(x) \lor F =F \lor p(x) = p(x)(也就是说永假符号FF其实是加法零元);

  • 在谓词逻辑环L\mathcal{L}中有一元素TT满足:对p(x),q(y)L\forall p(x),q(y) \in \mathcal{L}有:p(x)q(y)=q(y)p(x)=Tp(x) \lor q(y) =q(y) \lor p(x) = T(根据排中律:q(y)=¬p(x)q(y) = \lnot p(x);也就是说永真符号TT其实是加法零元);

  • 在谓词逻辑环L\mathcal{L}中有一元素TT满足:对p(x)L\forall p(x) \in \mathcal{L}有:p(x)T=Tp(x)=p(x)p(x) \land T =T \land p(x) = p(x)(也就是说永真符号TT其实是乘法幺元);

那么问题来了:到底T,FT,F哪个是乘法幺元/加法零元,进而乘法逆元/加法逆元又是什么(最终我们会发现怎么都不能满足);

一种可以表征命题逻辑代数的交换环

现在我们换一种思路,我们已经知道谓词逻辑代数(L,,,)(\mathcal{L},\lor,\land,\rightarrow)根本不是环,那我们尝试去定义一种"取巧"的泛代数结构S\mathcal{S},使其能够和谓词逻辑代数L\mathcal{L}和环代数R\mathcal{R}都能存在同态关系,定义如下:

  • S={si}S=\{s_i\}是一个有限集合,p=isi,q=jsjSp=\prod_{i}s_i,q=\prod_{j}s_j \in \mathcal{S}是这些元素的组合,r=kskS\ominus r=\ominus \prod_{k}s_k \in \mathcal{S}rSr \in \mathcal{S}的加法逆元,,S\empty,S分别是空组合和全组合;

  • 乘法pq=ksk,skpqp \otimes q = \prod_{k}s_k,s_k \in p \cap q;

  • 加法pq=ksk,skpqp \oplus q = \prod_{k}s_k,s_k \in p \cup q;

  • 加法rr=r \oplus \ominus r = \empty;

  • 乘法pS=pp \otimes S = p(因此SS是乘法幺元);

  • 加法p=pp \oplus \empty = p(因此SS是加法零元);

  • 乘法pq{sisip}{sjsjq}p | q \Leftrightarrow \{s_i |s_i\in p \} \subset \{s_j |s_j\in q \}(因此|是偏序关系);

验证

我们现在来验证以上代数结构即可以表征命题逻辑代数、又符合环的定义;

对逻辑代数同态性的验证

考虑谓词逻辑代数(L,,,)(\mathcal{L},\lor,\land,\rightarrow)的蕴含公理集、等价公理集;验证如下(视\oplus\lor,\otimes\land,|\rightarrow):

  • 分配律I :p(qr)=(pq)(pr)p \otimes (q \oplus r) = (p \otimes q) \oplus (p \otimes r);

  • 分配律II:p(qr)=(pq)(pr)p \oplus (q \otimes r) = (p \oplus q) \otimes (p \oplus r);

  • ppqp | p \oplus q(命题逻辑的ppqp \rightarrow p \lor q);

  • pqpp \otimes q | p(命题逻辑的pqpp \land q \rightarrow p);

  • pS=Sp \oplus S = S(命题逻辑的pSSp \lor S \rightarrow S);

  • pS=pp \otimes S = p(命题逻辑的pSpp \land S \rightarrow p);

容易验证其它的定理比如De Morgan律也满足;

对环代数同态性的验证

我们再证明泛代数(S,,)(\mathcal{S},\oplus,\otimes)是一个环;验证如下:

  • 加法交换律:pq=qp,p,qSp \oplus q = q \oplus p,\forall p,q \in \mathcal{S};

  • 加法结合律:p(qr)=(pq)rp \oplus (q \oplus r) = (p \oplus q) \oplus r;

  • 加法零元律:p=p=p\empty \oplus p = p \oplus \empty = p;

  • 加法逆元律:pp=pp=p \oplus \ominus p = \ominus p \oplus p = \empty;

  • 乘法结合律:p(qr)=(pq)rp \otimes (q \otimes r) = (p \otimes q) \otimes r;

  • 乘法分配律:p(qr)=(pq)(pr)p \otimes (q \oplus r) = (p \otimes q) \oplus (p \otimes r);

并且易知乘法也满足交换律,因此泛代数(S,,)(\mathcal{S},\oplus,\otimes)是一个交换环;

一些注解

我们已经证明泛代数(S,,)(\mathcal{S},\oplus,\otimes)是一个环且可以保持和命题逻辑代数的同态;以下是一些额外的说明:

  • SS的内涵:SS中的那些元素siSs_i \in S可以视作"原子命题",它们如同整数域中的素数一样,不可再分割;

  • r\ominus r的内涵:r\ominus r的逻辑意义可以认为是"排除了这些可能",比如:
    "you kill him""I kill him""I kill him"="you kill him""\text{you kill him}" \oplus "\text{I kill him}" \oplus \ominus "\text{I kill him}"="\text{you kill him}"

  • ¬\lnot的体现:我们有¬p\lnot pSpS \oplus \ominus p,但是我必须指出"构造性二难"pq¬pqp \rightarrow q \Leftrightarrow \lnot p \lor q并不能体现;

  • 乘法逆元:我们并没有找到乘法逆元;满足pq=Sp \otimes q = S的元素qq找不到(因此SS不是域);

我的几个感想

以下是几个随想:

  • 天然性:其实格代数才是表征命题逻辑运算的天然方式,很明显它和环代数是矛盾的;

  • 他人的相关工作:模糊逻辑推理被从Zadeh到王国俊等研究者做得美观但不足够深刻;

  • 接下来:我仍然在努力建立多项式结构与逻辑代数的联系以期望比较严肃地模糊推理;