制作一个带按键输入的计算机
Last updated
Last updated
到目前为止,我们制作的计算机系统已经比较完整了,再加上一个输入设备就更完美了。所以,本节我们就给它增加两个按钮作为按键输入,有点类似电脑键盘的功能。和前一章节中的电路结构相比,改动很小,我们只增加了2个按钮和一个“断路控制器”即可,其电路图如下图所示。
我们给“只读存储器”增加了1个输出端用于控制“按钮”的数据输出。“断路控制器”的作用是防止多个信号同时输入到总线,而导致系统短路的情况发生。“断路控制器”由ROM中的D19来控制,它的作用是控制“按钮数据”是否连接到总线上。
现在我们编写指令来实现这样一个功能:当按下任何一个按钮时,就把按钮对应的数值呈现在“十六进制数码管”上。很简单的一个功能吧,我把编写好的指令绘制在如下的表格中。
0000
0001
0000
0
0
000000000
1
0x80001
0001
0010
0000
0
1
000000000
1
0x80202
0010
0000
0000
0
0
000000000
0
0x0
我们来逐条分析下这些指令是如何工作的。
它的演示动画如下图所示。
到此为止,我们就把整个计算机系统就讲完了。回顾一下,我们最终制作的计算机电路所使用的基础电子元件是不是只有逻辑门?我们用“逻辑门”制作了“锁存器”和“触发器”,而后使用“逻辑门”和“触发器”共同制作出了ROM、RAM等集成度更高的电子元件,最后使用它们组装成了一台4位的计算机。也许细心的你会有疑问“我们的电路中不是还使用了一个时钟信号发生器和一个断路控制器么?”。其实这两个电子元件我们也可以使用逻辑门来实现同样的功能。我们先来看“时钟信号发生器”如何使用“逻辑门”来制作?首先回顾下我们之前讲过的一种报错电路,如下图所示。
该电路由于产生了高频率的振荡信号,被Logisim软件停止仿真并报错。那么我们有没有办法把它的频率降低,比如降到4000HZ,这样Logisim软件就不会把它当成错误来看待了?其实很简单,我们知道信号经过逻辑门会有延时,只要我们串联成千上万个“非门”,就可以制作任何频率的“时钟信号发生器”了。就像下图所示的样子,只是由于电路图太小,我只使用了7个“非门”串联来演示一下。
其次,我们再看看如何使用“逻辑门”来替代电路中的“断路控制器”。我们知道,在电路中使用“断路控制器”的目的是通过它控制所有元件同时只能有一个元件被允许输出信号到总线,这样做可以防止出现两个信号不一致的元件同时输出到一根总线上,从而造成电路短路的问题。其实我们使用逻辑门同样可以解决这个问题。如下图所示,我使用“断路控制器”和“逻辑门”来作为对比。
至此,我们仅仅使用了“逻辑门”这个最基本的元件,从无到有的构建了一个计算机系统。而所有逻辑门都可以用“非门”和“或门”的串并联组合来获得,也就是说,只要我们有足够的“非门”和“或门”,就可以构筑起一个庞大的计算机帝国了。而逻辑门也不一定完全是电子元件。回想一下,前面的章节中,我提到过,在刘慈欣的《三体》世界中,冯诺依曼在秦始皇的帮助下使用了庞大数量的士兵来组建出一个人力计算机。现在我们来分析一下为什么使用士兵也能够制作计算机呢?这里的本质原因就是可以用士兵来制作逻辑门和导线。而导线中的信号就是他们手中所举的旗帜颜色,白色代表1,黑色代表0。首先,我们来看下在人力计算机中,士兵是如何充当逻辑门的呢?例如,当一个士兵看见前面的士兵举白旗,他则举黑旗,当看见前面的士兵举黑旗,他则举白旗,这不就是一个“非门”么?再例如,只有当一个士兵看见他前方的两名士兵同时举黑旗的时候,他才举黑旗,其它情况则举白旗,这不就是“或门”么?而有了这两种逻辑门,我们就可以制作出其它所有的逻辑门,最后再用导线将他们连接在一起。那么如何用士兵来充当导线呢?可以让士兵排成一排,第一个士兵举什么颜色的旗帜,后面的士兵就跟着他一个挨一个举相同顔色的旗帜,这样旗帜的颜色信号就像电流那样在士兵中传播开来。至此,有了“人力导线”和“人力逻辑门”,我们就可以按本书教程来制作出一个“人力计算机”了。言归正传,如果现实世界中,秦始皇真的使用士兵来制作计算机,那将会是一个巨慢无比的计算机。但是在小说中三体人的世界中就完全不同了,因为三体人不同于人类,信号在他们之间传递速度非常快,所以三体人才能够制造出“人力计算机”来预测3个太阳的运行轨迹。如果读者想了解小说中“人力计算机”部分的具体细节,可以去阅读《三体》原著。