Efficient digital comparison technique for logic circuits by Mccarthy, C. E.
re 
1= Non-Compare) 
July 1971	 Brief 71-10218 
NASA TECH BRIEF 
Marshall Space Flight Center 
NASA Tech Briefs announce new technology derived from the U.S. space program. They are issued to encourage 
commercial application. Tech Briefs are available on a subscription basis from the National Technical Information 
Service, Springfield, Virginia 22151. Requests for individual copies or questions relating to the. Tech Brief program may 
be directed to the Technology Utilization Office, NASA, Code KT, Washington, D.C. 20546. 
Efficient Digital Comparison Technique for Logic Circuits 
The problem:	 by one unit of its low-order bit position. If the low-
Error detection and error masking schemes in highly 	 order bit is zero, the number is incremented to one 
reliable digital systems frequently involve comparing 	 and there is no carry. If the low-order bit is one, the 
the outputs of simultaneously operating redundant 	 number becomes a zero, as do all successive higher-
Figure 1. Logic for Four-Bit Word-Length Comoarator 
units. Predeterminable variations can occur between 
output values due to asynchronous device operation 
and analog device variations. Because of the carry 
.propagation characteristics of the binary numbering 
system, a bit-by-bit comparison of the binary output 
values may indicate significant discrepancies when the 
niiontitac thai, ranrcnt am	 a rIflcp tnlpranep
r r
Output 
Word 1
MLATCH N o^n - 
Compare) 
Word+2
L..i T
	
I
Figure 2. Two-Word Serial Compare 
order bit positions containing ones. The carry prop-
agates through all bit positions containing ones until 
a position containing zero is encountered. The zero 
becomes a one, and all higher-order bit positions re-
main unchanged. Using this definition property of the 
binary number system, a tolerance-compare algorithm 
of two binary numbers is implemented as follows: 
1. Determine the highest-order bit position of dis-
agreement between the two numbers, i.e., the 
MARK position. 
2. Define the following: If the two numbers agree 
within one lower-order unit value, then: 
A. The larger of the two numbers has a one in the 
The problem, then, is to devise a "tolerance compare" MARK position and zeros in all lower-order 
technique to indicate a "discompare" only when the positions. 
numerical difference value exceeds a prescribed limit. 	 B. The smaller number has a zero in the MARK 
The solution:	 position and all ones in positions of lower order 
An algorithm involving binary-number properties 	 than the MARK position 
is defined, in lieu of an arithmetic operation which	 This algorithm may be extended to encompass tol-
requires relatively complex circuitry. The binary-num- 	 erances other than one unit. In a given system of word 
her property concerned is described as follows: Given	 length n, if only the n-1, n-2, n-3, . . . higher-order 
a case where any binary number is to be incremented 	 bits are compared, the tolerance-compare circuitry will 
Lied	 eiIetI 
This documefct was prepared under the sponsorship of the National	 Government assumes any liability resulting from the use of the 
Aeronautics and Space Administration. Neither the United States 	 information contained in this document, or warrants that such use 
Government nor any person acting on behalf of the United States 	 will be free from privately owned rights. 
https://ntrs.nasa.gov/search.jsp?R=19710000217 2020-03-17T02:19:12+00:00Z
indicate a discompare only when the difference is 
greater than 2, 4, 8, . . . units, respectively. 
How it's done: 
Figure 1 shows the straightforward implenienta-
tion, in a parallel organized system, using AND, OR, 
and INVERT logic for a four-bit word length compar-
ator. Word 1 inputs, in high to low order, are on lines 
1, 2, 3, and 4. Word 2 inputs, in high to low order, are 
on lines 5, 6, 7, and 8. Three exclusive OR's compare 
the higher-order bit positions. No compare is neces-
sary for the low-order bit position. The AND gates 
immediately following the exclusive OR gates deter-
mine the MARK position and the larger word. This 
function is accomplished by the concurrence of: (1) 
a I from the exclusive OR (indicating a discompare 
of the bits in that position); (2) a I from the inverted 
output(s) from all higher-order exclusive OR's (in-
dicating all higher-order bits compare); and (3) a 1 
from the larger-word bit. Thus, only one of the AND 
gates will have an output, and that output will cor-
respond to the MARK position of the larger-valued 
word. 
When the MARK position (i.e., the larger-valued 
word) is identified, the OR gates 23 through 28 and 
the AND gates 29 through 34 logically determine that 
the lower-order bit values of the larger word are zeros 
and the lower-order bit values of the smaller words are 
complementary (i.e., ones). There is an OR gate and 
an AND gate for each bit position of each word being 
compared. Any AND gate which has a 1 output will 
cause a discompare; however, only that AND gate cor-
responding to the larger-word MARK position can 
have a logical 1 output. The remaining condition is ob-
tained from the OR gate (e.g., gate 26 above AND 
gate 32, OR gate 24 above AND gate 30, etc.). These 
OR gates have a logical 1 output whenever: (1) a cor-
responding lower OR gate has a 1 output; (2) the input 
word bit they represent is a logical 1; or (3) there is 
a compare of the word bits in the position they rep-
resent.
Application to serial systems illustrated in Figure 2, 
is also straightforward. Assume that two words of any 
length are to be compared and are transmitted 
synchronously over two serial data lines in high-order 
to low-order bit sequence. Though not essential to this 
application, the words are frequently gathered in shift 
registers (dotted in figure). The serial implementation 
shown uses two latches because all required informa-
tion on the words is not available simultaneously; 
therefore, a minimal memory capacity must be 
included. As the words are shifted into the first bit 
position of the register, a comparison is made of 
corresponding bits, using exclusive OR gates. The 
first discompare indicates the MARK position, and 
the respective AND gates set one of the two latches to 
correspond to the larger-valued word. Subsequently, 
any 1 bits in the larger word, or a failure to get a 1 
output from the exclusive OR (indicating a 0 in one of 
the smaller-valued word bits), will cause a 1 output 
from the final OR gate to the modulo 2 counter. The 
modulo 2 counter prevents the first OR gate discom-
pare from causing a discompare output. 
Note: 
No further documentation is available. Specific 
questions, however, may be directed to: 
Technology Utilization Officer 
Code A&TS-TU 
Marshall Space Flight Center 
Huntsville, Alabama 35812 
Reference: B71-10218 
Patent status: 
No patent action is contemplated by NASA. 
Source: C. E. McCarthy of
IBM Federal Systems Division
under contract to
Marshall Space Flight Center 
(MFS-2 1080) 
Brief 71-10218	 Category 02
