大家好,今天我们来聊聊译码器(decoder)
译码器,又叫解码器,顾名思义在电路里起到的作用是解译编码。译码器通常用于将数字信号转换成控制信号。说到解码,让我们先来聊聊什么是编码吧。
简单的讲,编码是人类利用某种工具,对客观世界的一种描述。
在原始人类刚刚开始有计数的需求时,编码就出现了。
在我们生活的这片土地上,我们的祖先用在绳子上打结的方式来记录数字。
最初的编码,只表示数量和符号的对应关系,我们仔细看,可以发现这时候的计数,还没有产生进位的概念。
随着生产力的发展,人们对计算的要求越来越高,于是我们的祖先发明的更灵巧的计算工具,这个时候逢十进一的十进制编码方式开始出现。
到了近现代,我们用测得得高电压表示1,低电压表示0。在这种简单的工具之上,构建了一套完整的二进制计算理论。新的工具使我们拥有了更强的计算能力。
现在我们用一个例子来体会下什么是编码。
在远古时代,老王家的苹果树结了苹果,老王老婆想知道树上到底结了几个苹果。于是她就叫老王去数一数,老王来到苹果树下,一数,总共有16个。
老王在绳子上打上一个代表十的结,再打上一个代表六的结。回到家,老王老婆问今年苹果树上结了多少苹果,老王拿出绳结一数,总共16个,于是老王老婆很满意。
还好远古时代的老王家只有一棵苹果树,如果有十棵的话,老王整天除了在绳子上打结,就不用干别的事了。由此可见技术极大程度的限制了生产力。
后来,人们发明了算盘,还是老王家的苹果树,还是老王老婆想知道树上有多少果子,老王很从容的在算盘上拨了两下,数字马上就统计出来了,又好又快。这次老王家别说一棵苹果树
了,即便是个100棵的苹果园,轻轻拨几下算盘珠,也能轻松搞定。
后来老王的果园越来越大,苹果树已经有上百万棵了,算盘珠子也算不了这么多苹果,好在这个时候老王家也与时俱进的用上了电脑。管理果园也不在话下。
上面的故事我们随便胡诌几句,就是想说明一件事,无论编码的工具和方法如何改变,他们都只是对客观事物的一种描述方法,而译码器的作用,就是在不同的编码之间游走。
让我们可以用不同的视角,全面的看待客观的世界。
我们回到今天的主题
我们来看看学习计算机组成原理的时候,最先遇到的一种译码器—38译码器
38译码器的作用如图,它接受3位输入,8位输出,输入和输出的对应关系如图
为了讲清楚38译码器的工作原理,我们要回到事情最开始的地方,那时的世界还是一片混沌。一开始,只有1位需要译码。
我们将输入的信号一头接一个非门,同时也作为输出,于是我们得到两位输出,如图所示,译码完成
有了一位输入的译码,我们再来看两位输入的译码,先看如图的真值表,我们看到两位输入的译码有四位。我们分别来看下这四种输入的电路状态。
以上就是输入为两位时的的四种电路状态。
接下来就是今天的讨论的正主,3位输入的译码器,他有8位输出,因此我们称它为38译码器。它的电路如下。
以上我们看到了从一位的译码器到三位的译码器的电路实现。我们可以看到随着输入位数的增多,输出的位数随指数增长。如果我们增加输入到四位,那么输出就变成十六位。电路的复杂程度也呈指数增长。因此我们用电路直接实现得输入输出位数,必须和电路得复杂度之间达成一定得平衡,更多得输出位数,我们需要用输出位数少得电路来组合实现。这也是常用得译码芯片都是三位输入八位输出得原因。