布尔逻辑

✍ dations ◷ 2025-11-03 14:44:58 #逻辑,代数逻辑,布尔代数,形式逻辑系统

布尔逻辑(英语:Boolean algebra)得名于乔治·布尔,他是爱尔兰科克的皇后学院的英国数学家,他在十九世纪中叶首次定义了逻辑的代数系统。现在,布尔逻辑在电子学、计算机硬件和软件中有很多应用。在1937年,克劳德·艾尔伍德·香农展示了布尔逻辑如何在电子学中使用。

使用集合代数作为介绍布尔逻辑的一种方式。还使用文氏图来展示各种布尔逻辑陈述所描述的集合联系。

设是一个集合:

设图像为集合A包含"全集"中所有偶数(二的倍数),集合B包含"全集"中所有三的倍数。则两个集合的交集(在集合A AND B中所有的元素)将是"全集"中所有六的倍数。

集合A的补集(所有不在集合A中的元素)是"全集"中所有的奇数。

尽管在任何布尔运算中都最多有两个集合参与,从这个运算所形成的新集合可以接着与其他集合联合起来实现另外的布尔运算。使用前面的例子,我们可以定义一个新集合C作为"全集"中所有五的倍数的集合。所以"集合A AND B AND C"将是"全集"中所有30的倍数。如果为了更方便,我们可以把集合AB当作集合A和B的交集,或者说"全集"中所有六的倍数的集合。那么我们可以称"集合AB AND C"是"全集"中所有30的倍数的集合。我们接着进一步的把这个结果叫做集合ABC。

尽管任何数目的逻辑AND(或任何数目的逻辑OR)可以被连接在一起而没有歧义,AND和OR和NOT的组合可以导致歧义的情况。在这种情况下,可以使用圆括号来分清运算的次序。永远是最内的括号内的运算先进行,随后是外层的括号以此类推,直到在所有的括号内运算都完成。接着进行括号外的运算。

为两个主要的二元运算的符号定义为 / {\displaystyle \land /\cap } (逻辑与/交集)和 / {\displaystyle \lor /\cup } (逻辑或/并集),把单一的一元运算的符号定义为 ¬ {\displaystyle \lnot } / ~(逻辑非/补集)。我们还使用值0(逻辑假/空集)和1(逻辑真/全集)。下列性质适用于布尔代数和布尔逻辑二者:

布尔逻辑只使用两个值0和1,这两个值的交集和并集可以使用真值表定义如下:

可以使用各种样式的基本算符来表达布尔逻辑。AND(与)、OR(或)、NOT(非)是最直觉的。数学家、工程师和程序员经常使用 +表示或, {\displaystyle \cdot } 表示与(因为在某些方面这些运算类似于在其他代数结构中的加法和乘法,并且这种记号使熟悉普通代数的人易于得到积之和范式)。非也表示为在要否定的表达式顶上的一个横线。

另一种记号使用"交"表示与使用"并"表示或。但是这会导致混淆,因为术语"并"也经常用于合并集合的另一个布尔运算,它包括了与和或二者。

同样适用于联立不等式:

在把英语句子转换成形式的布尔语句的时候要小心。很多英语词语不精确的意义可能导致多种逻辑结果,例如英语单词NOT(非):“所有闪光的东西不是金子。”可以解析为以下不同的逻辑表达:

作为英语单词的AND(与)和OR(或)在特定情况下是可以互换使用的:

还要注意在英语中单词OR(或)可以分别对应于逻辑表达中的或(OR)(此亦彼亦)和异或(XOR)(此即彼非),具体意思要依赖于上下文进行判断:

在规定计算机程序或者电子电路时,如何使用英语准确描述其功能逻辑是个关键问题。例如,对于功能“程序应校验申请者已经选择取了男性或女性单选框”,应当被当作一个异或(非此即彼)逻辑(即“程序应校验申请者已经选择取了男性或女性选项,并且此二选项互相排他”),则程序语句须特别限定“二者之间只有一个能被选择”来确保校验功能的实现;假如将其混为或逻辑(此亦彼亦),则该校验功能有可能被错误地实现,造成申请者同时选择两个选项、而校验依然通过。

在其他非技术语言的情况下,对于一段英语文字的解释可能包含更多的不确定性,可能需要深入探讨、以确保明晰该段文字背后所含的逻辑意义的多种可能性。

布尔逻辑还在电子工程中的电路设计中使用;这里的0和1表示在数字电路中某一个位的不同状态,典型的是高和低电压。使用包含变量的表达式描述电路,并且对于这些变量的所有的值两个这种表达式是等价的,当且仅当对应的电路有相同的输入-输出行为。进一步的说,每种可能的输入-输出行为都被建模为适合的布尔表达式。

基本的逻辑闸比如与闸、或闸、非闸可以单独使用,或者联合成与非闸、或非闸和异或闸来控制数字电子和电路。这些闸的串联或并联控制了运算的优先级。

关系数据库使用SQL语言,或者其他特定于数据库的语言,来进行查询,它可以包含布尔逻辑。对于这种应用,在表中每个记录都可以被当作"集合"的"元素"。例如,在SQL中,下列SELECT语句被用来从在数据库中的表格中检索数据:

在有多个运算出现的时候,可以使用圆括号来明确的指定布尔运算发生的次序:

在需要的时候可以使用嵌套的圆括号。

联合两个(或更多)表格的任何布尔运算在关系数据库术语中都被称为连接。

对于这种应用,在互联网上的每个web页面都被当作是"集合"的"元素"。各种在线搜索引擎使用各自不同的语法。下面描述Google使用的语法。

相关

  • 高果糖玉米糖浆高果糖浆(英语:High-fructose corn syrup、简称HFCS)亦称果葡糖浆、高果糖玉米糖浆或葡萄糖异构糖浆,是以酶法糖化淀粉所得到的糖化液经葡萄糖异构酶的异构作用,将一部分葡萄糖异
  • Cannizzaro反应坎尼扎罗反应(Cannizzaro反应),也译作康尼查罗反应、康尼扎罗反应、卡尼扎罗反应,是无α活泼氢的醛在强碱作用下发生分子间氧化还原反应,生成一分子羧酸和一分子醇的有机歧化反应
  • 原子能核结合能(英语:Nuclear binding energy),又称为原子能或核能,是由组成原子核的粒子之间发生的反应释放出的能量。原子能比化学反应中释放的热能要大将近5千万倍:铀核裂变的这种原
  • 柏林航空柏林航空(全称柏林航空服务两合公司,德语:Air Berlin PLC & Co. Luftverkehrs KG)是仅次于汉莎航空的德国第二大航空公司。 其总部设于柏林, 广泛经营从德国飞往地中海、加那利群
  • 左旋多巴L-多巴(英语:L-DOPA,全称3,4-二羟苯丙氨酸)是酪氨酸经酪氨酸羟化酶的作用下羟化产生的一种氧化产物,具有儿茶酚羟基,可进一步生成另外一些有生物活性的物质:L-多巴在酪氨酸酶的作用
  • Google Book SearchGoogle图书(英语:Google Books)是一个由Google研发的搜索工具,它可以自Google所扫描、经由光学字符识别(OCR)、存储的数字化数据库中搜索数据。此服务于2004年10月在法兰克福书展
  • 森鸥外森鸥外(1862年2月17日-1922年7月9日),石见国津和野(今岛根县津和野町)出生及出身,本名森林太郎,号鸥外,又别号观潮楼主人、鸥外渔史。日本明治至大正年间小说家、评论家、翻译家、医
  • 斯洛伐克南部地区德国与斯洛伐克傀儡政权胜利纳粹德国 斯洛伐克共和国斯洛伐克的捷克斯洛伐克第一军(捷克语:1. československá armáda na Slovensku)斯洛伐克民族起义(斯洛伐克语:Slovenské
  • 遗传工程学基因工程(英语:genetic engineering,又称为遗传工程、转基因、基因修饰)是一种使用生物技术直接操纵有机体基因组、用于改变细胞的遗传物质的技术。包括了同一物种和跨物种的基
  • 马达加斯加民主共和国马达加斯加民主共和国(马达加斯加语:Repoblika Demokratika Malagasy;法语:République démocratique de Madagascar)是一个存在于1975年-1992年的国家。该国由迪迪安·拉齐拉卡(1