CPU逻辑运算原理

上传人:奇异 文档编号:60433519 上传时间:2022-03-07 格式:DOCX 页数:12 大小:359.30KB
收藏 版权申诉 举报 下载
CPU逻辑运算原理_第1页
第1页 / 共12页
CPU逻辑运算原理_第2页
第2页 / 共12页
CPU逻辑运算原理_第3页
第3页 / 共12页
资源描述:

《CPU逻辑运算原理》由会员分享,可在线阅读,更多相关《CPU逻辑运算原理(12页珍藏版)》请在装配图网上搜索。

1、CPU逻辑运算原理第一季继电器先不要扯什么图灵,冯诺依曼这些先贤。因为他们都太遥远。计算机一切计算的源头其实是源自一个非常非常中二的东西:“继电器(Relay)”。继电器是什么鬼看下图,Steuwritruirikrfejh230V、LdHtstrurrikrtfis其实就是一个线圈利用电磁感应做成的电磁铁。原理和“电报机”一样,当开关闭合,黄色电路通电,线圈是金属棒变成磁铁,吸引中间的小开关(Anker),接通右边灰色的电路,点亮灯泡SchalTprspannungs- Anschlu&irD der queHe SteuerspannungArker23QV yLflsLsLrui i i

2、kiSLtfiiersluriikreN简单说就是你在家一按开关,隔壁老王家的灯亮了第二季“反相器”和“非门”为什么说继电器是个很中二的东西因为这不就是开关吗我按了它才亮,不按绝对不亮。但CPU真就是这货发展而来的。它的变种就开始好玩了。最简单的一个变种,就是“反继电器”,或者叫“反相器(Inverter)”。就是隔壁老王家的灯本来是亮着的,我手上的开关一按,灯就灭了。ASwitch A*Open = Lamp-ON - TSwitch A*CIosed Lamp -OFF = 0*“反相器到了现代计算机里,就叫做 “非门(NOT Gate ) ”。本来开关T1是接通的,Output是1 (5

3、V高位电平)。一旦闭合开关 T1 ,电路中断,输出变为 0 (1V低位电平)。*Vcc91n1oR2a OUTQ QT1Transrstoi Switch1 ,输出就是0。输入0,输出“非门”用卜面这个符号表示。简单说,就是输出永远和输入是反的,输入就是1。NOTgatetruthtab/eInput-OutputInputOutput01io第三季逻辑门家族和“非门”一样,我们能得到一堆其他特性的门。比如,“与门(ANDGate):就是两个开InputE 一OutputFig.3.1 AND Gate关串联。必须两个开关同时闭合,灯泡才能亮。BulbFig3.2Acircuitcontain

4、ingtwoswitchesinseries“或门(OR Gate ) ”,两个开关并联,只要其中一个开关闭合,灯泡就会亮Fig.3.4 A circuit containingFig 3 3:Grapical symbol OR Gat(switches in parallel长话短说,下图是所能得到的几个基本“逻辑门(LogicGates)LogicGatesWMJOR艮XNORA*.E*呷A川剧Aymlnil:口1zl-D-r-1ntthAHAAKHHAXHA14V0I00eQ01aoo001G400011C1g0119101aV110IG1QD10QJ1Cl0111001:tIJ1I1

5、t11o1111I1i虽然看上去比较复杂,但“逻辑门”在本质上和之前讲的“继电器”都是“控制电路”。或者说都是我手里握着控制老王家花式吊灯的各种开关。老王一定很郁闷。第四季逻辑逻辑门虽然被我说得很淳朴,就是控制隔壁老王家吊灯的开关。但其中却可能蕴含着人类大脑,甚至是这个世界终极奥义的一部分:逻辑(Logic)。这也是为什么它被叫做逻辑门。爱因斯坦曾说过:世界上最不可思议的事情,就是这个世界是可以被“理解”的。简直是细思极恐有木有!最简单的例子,亚里士多德给出的经典“Barbara”三段论:如果所有人(M)都是必死的(P),(大前提)并且所有希腊人(S)都是人(M),(小前提)那么所有希腊人(S

6、)都是必死的(P)。(结论)数学上,一个形式系统(Formalsystem)的野心就是想通过一组公理,和逻辑推理过程,来描述和证明我们的客观世界。说到这里我们计算机的祖师爷们就都出来了:莱布尼兹,康托尔,布尔,图灵,等等等等。着名的图灵机就是在这个议题的争论中无心插柳的副产品。这个主题无法展开。感兴趣推荐看这本书。这里只举一个最简单的“布尔代数(Booleanalgebra)”的例子:我喜欢(长头发)的(不是)(蛇精脸)的女生用布尔代数来表示就是:长头发AND(NOT蛇精脸)说到这里,是不是和前面说的逻辑门联系起来了第五季逻辑电路但是逻辑是逻辑,继电器是继电器,就算上面的花式继电器也是继电器。

7、把逻辑和继电器联系起来的是一位不得不提的大师,克劳德艾尔伍德香农(ClaudeElwoodShannon)和他的那篇史上最牛硕士论文:继电器与开关电路的符号分析。绝对最牛,没有之一!还是之前那个例子:我喜欢(长头发)的(不是)(蛇精脸)的女生如果:那我喜欢的女生就可以写成一个布尔函数:国把一个逻辑命题用符号写成一个公式有什么用呢那是因为这样就可以很方便地转换成一个“逻辑表决器”,如下图。国原理很简单,当A=1时,纵向的A总线为1。当A=0时,总线输出1。B也是如此。最后Isl1的输出线搭在A总线和总线上,用个与门连接。所以只有当A的输入为1,B的输入为0时,Out才为1,代表我能接受这个女孩。

8、不信大家可以人肉推演一下。理论上任何布尔函数,都能转换成上面这样的表决器。就好像电路有了人类逻辑思考的能力。第六季“图灵机”和“累加器”总算要说到计算机的祖师爷图灵(Turing)了。图灵机模型,相比上面说到的逻辑电路,要多一个“存储器”。因为根据图灵机模拟人类计算时大脑的工作状态的模型,人类的任何计算都可以抽象成一个机械化的过程。考虑5+7=12这个加法。5加7等于12,写下2,然后心中默记产生一个进位。最终写成125+712换成二进制,是一个道理,+0000011100001100其中每一位的加法还是能分解成两个动作:1 .同一位的两个数字相加2 .如果当前位结果大于1,则向前进一位第一个

9、动作可能的结果(真值表)有:这个真值表和一个简单的“异或门”是一致的。第二步进位,只有1+1才需要进位1,所以真值表如下:这和“与门”的真值表是一致的所以把一个“异或门”和一个“与门”组合到一起,就构成了一个“一位半加器”P oo SUMO CARRY OUT但事实上一位半加器只适用于末位数的加法。高位的二进制加法需要考虑3个输入,就是还需要两个半加器组合起来,构成一个完整的“一位全加器”把8个这样的一位全加器组合起来,就构成了一个“八位全加器”:从最末尾开始相加,刚才的 5+7 :00000101+00000111反过来就变成:1110000000110000把最初的进位c_in设为0,得到

10、的结果反过来就是:00001100=12。至此,计算机好像拥有了人脑的部分智能。既然一组逻辑门,能计算加法,就一定能做减法,乘法,除法,和其他计算。第六季寄存器加减乘除远远不是逻辑门能做的全部事情。实际上电脑里出了硬盘,风扇,电池,其他几乎全是由逻辑电路和逻辑门组成的,包括我们说的内存。说内存先要说一下寄存器。这东西我觉得是比CPU更神奇的一个东西。绝对是一大黑魔法。用几个简单的逻辑门,就能在不断电的情况下一直”记住“上次的输入值。最简单的储存部件叫“SR锁存器(Latch)”。其实就是两个“或非门”。Q1 0 Set1 00 0 Undefinedb Funerton table再看眼或非门

11、的真值表:只有两个输入都为0,才输出10NOR0=11NOR0=00NOR1=01NOR1=0其中具体电流怎么通过互相博弈达到稳态的细节就不展开了。总之这个黑科技的最终效果就是:假设初始状态都是零:S=0,R=0。输出Q=0,=0当S端给个信号1,输出Q=1,=0凶当S端变回信号0,输出还是保持Q=1,=0也就是说,这个元件记住了之前S端的输入1。直到我们把R端设为1,输出Q才变回0虽然这个SR锁存器离我们真实的“RAM内存”还很遥远。但让逻辑门产生“记忆”的核心逻辑稳态锁就是这么简单的两个或非门当我们把SR锁存器的两个输入端捏合成一个D输入端,再加上一个由时钟信号控制端E,就得到一个更高级的

12、“时序D锁存器。如果不想头痛,只要记住这是一个能在时钟开关E打开的情况下,记住D输入端进来的信号的装置。之后我们一直可以从Q端得到之前D端的值EDQQ0latchatch0L jlatchlatch1。P 0L1Lt0如果再复杂一点,把两个相反的时序D锁存器组合在一起,就能构成一个“D触发器(DFlipFlop)触发器和之前的锁存器的区别是,只有当时钟信号处在上升沿(从1V向5V跃迁)的一瞬间,D端的输入值才能写入触发器。并在随后的时间内,只要没有新的D输入写入,Q一直保持这个值。D触发器离我们的内存就没那么远了。只要再套上一个用于寻址的“解码器”和之前说过的“选择器”,就能实现从特定一组触发

13、器中读取数据的效果啦。所以我们都知道CPU需要时钟来同步时序电路。但这个晶振时钟并不是像想象的那样直接作用在ALU(逻辑运算单元)上,而是通过寄存器来实现时序控制。感兴趣的可以看这个回答:第七季硬件.软件虽然,几乎所有计算都能设计出一个专门的逻辑运算器。但这样做似乎并不明智,否则逻辑部件的数量将以指数级增长。一个合理的方案,应该是用硬件实现部分必须的基础计算功能,然后已软件的方式,利用基础计算单元,完成复杂计算。就好像做乘法,不需要设计一个专门的“乘法器”,而是重复多次加法运算即可。这里就是所谓软件开始介入的地方。也就是所谓的“算法”开始放发挥作用,虽然并不是硬件无法胜任这项工作,而是把复杂性交给软件来处理似乎更合理。从此,在硬件这棵树上,开出了软件这朵花。也就有了”程序员“这个严重伤害颈椎和腰椎的职

展开阅读全文
温馨提示:
1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
2: 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
3.本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!