在一些数字系统(例如数字计算机)当中经常要求比较两个数值的大小。为完成这一功能所设计的各种逻辑电路统称为数值比较器。
1位二进制数值比较器
首先讨论两个1位二进制数A和B相比较的情况。这时有三种可能:
(1)A > B(即:A = 1、B = 0),则A
B
‾
\overline{B}
B = 1,故可以用A
B
‾
\overline{B}
B作为A > B的输出信号Y(A>B)
(2)A < B(即:A = 0、B = 1),则
A
‾
\overline{A}
AB = 1,故可以用
A
‾
\overline{A}
AB作为A < B的输出信号Y(A<B)
(3)A = B,则A ⊙ B=1,故可以用A ⊙ B作为A = B的输出信号Y(A=B) =
A
⊕
B
‾
\overline{ A ⊕ B}
A⊕B。
画出逻辑图为
多位比较器
在比较两个多位数的大小时,必须自高而低地逐位比较,而且只有在高位相等时,才需要比较低位。
例如:
比较两个四位二进制:A = A3A2A1A0和B = B3B2B1B0的大小
- 若A3>B3,则A > B;若A3 < B3,则A < B;若A3 = B3,则需比较次高位。
- 若次高位A2 > B2,则A > B;若A2 < B2,则A < B;若A2 = B2,则再去比较更低位。
- 依次类推,直至最低位比较结束。
由此可得A>B,A = B ,A<B的逻辑表达式为
4位数值比较器74LS85
功能表(其中AGTB = I(A>B),AEQB = I(A=B),ALTB = I(A<B),OGTB = F(A>B),OEQB = F(A=B),OLTB = F(A<B))
使用说明:
(1)只比较两个4位二进制数时,或不使用扩展端时,将扩展端I(A<B)接1,I(A=B)和I(A>B)接0。
(2)当比较两个4位以上8位以下的二进制数时,应先比较两个高4位的二进制数,在高位相等时,才能比较低4位数。只有在两个4位二进制数相等时,输出才由扩展端I(A<B)、I(A=B)、I(A>B)决定。
两片74LS85组成8位数值比较器