Simplified, reliable circuit sorts binary numbers in order of magnitude by Anderson, T. O.
Control 
.
October 1969
	 Brief 69-10503 
NASA TECH BRIEF 
NASA Tech Briefs are issued to summarize specific innovations derived from the U.S. space program, 
to encourage their commercial application. Copies are available to the public at 15 cents each 
from the Clearinghouse for Federal Scientific and Technical Information, Springfield, Virginia 22151. 
Simplified, Reliable Circuit Sorts

Binary Numbers in Order of Magnitude 
A relatively simple, highly reliable circuit has been 
designed to sort binary numbers in order of magnitude. 
This circuit operates at high speed and can be built at 
low cost. Although any computer is capable of sort-
ing binary numbers utilizing well-known subroutines, 
and some special-purpose devices have been de-
veloped for this purpose, these are unduly complex 
and are, therefore, not suitable for applications in 
which small size and high reliability are essential. 
The new circuit includes a single-word input/output 
register and a multiword serial memory which are 
circulated in synchronism. The outputs of the register 
and the memory are applied to a serial comparator 
which determines whether the register output word 
is larger than the memory output word. If it is, the 
memory output word is coupled to the register input, 
and the register output word is coupled to the memory 
input. Thus, each new word loaded into the register 
will be transferred into the proper position in the 
memory to maintain the words in order of magnitude.
A significant feature of the circuit is its ability to 
put out data at a rate compatible with relatively slow-
speed electromechanical devices, such as line printers. 
The circuit can be switched from the high-speed sort 
mode to the low-speed output mode merely by chang-
ing the criteria of the comparator so that the memory 
output words are loaded into the register only when 
they exceed the register output word in magnitude. 
In this manner, N memory words can be read out in N 
full memory cycles, each word being held in the reg-
ister for one full cycle. 
The circuit, represented by the block diagram, func-
tions to insert a binary word from the data source 
into its proper position (by magnitude) in the serial 
memory. The latter can be any one of such devices as 
a magnetic drum, a magnetic tape loop, or a delay 
line. The output of the data source is connected 
through gate no. 1 to the input of the single-word 
input/output register. From this register, the out-
put is connected through gate no. 2 to the input of the 
(continued overleal) 
Now
This document 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=19690000483 2020-03-16T18:06:58+00:00Z
serial memory. The outputs of both the register and 
the serial memory are connected to the inputs of both 
gates and also to the inputs of the comparator, whose 
output controls these gates. 
To explain the operation of the circuit, assume that 
the serial memory contains several words arranged 
in order of decreasing magnitude, so that the largest 
word is put out first during each memory cy1e. Prior 
to each memory cycle, a word to be inserted in the 
proper position in the memory is delivered by the data 
source through gate no. I to the register. During the 
memory cycle, each word put out by the memory is 
compared with the word in the register by the com-
parator. As long as the word from the memory ex-
ceeds the word stored in the register, the two gates 
will be controlled to recycle the contents of the 
register and the memory, respectively. On the other 
hand, when the comparator recognizes that the word 
in the register exceeds in magnitude a word output 
from the memory, it will switch the gates to couple 
the output of the memory to the input of the register 
and the output of the latter to the input of the memory. 
Accordingly, the world in the register will be inserted 
into its proper position in the memory, and all of the 
succeeding words in the memory will be passed 
through the register prior to returning to the memory, 
thereby being shifted one word time backward in the 
memory. 
The comparator contains sort and read terminals. 
To define a sort mode, a logically true signal is applied 
to the sort terminal. The words in the memory can be
read out at a relatively slow speed at the output term-
inal of the register by applying a logically true signal 
to the read terminal of the comparator. In the output 
mode, the criteria applied to the comparator is re-
versed, so that the output of the memory is coupled 
to the input of the register when the memory output 
word exceeds the register output word in magnitude. 
Therefore, if the words in the memory are arranged in 
order of decreasing magnitude, each word will remain 
stored in the register for a full memory cycle, thus 
enabling it to be easily coupled to slower-speed 
peripheral devices (e.g., electromechanical line 
printers). 
Note: 
Documentation is available from: 
Clearinghouse for Federal Scientific 
and Technical Information 
Springfield, Virginia 22151 
Price $3.00 
Reference: TSP69- 10503 
Patent status: 
This invention is owned by NASA, and a patent
application has been filed. Royalty-free nonexclusive 
licenses for its commercial use will be granted by 
NASA. Inquiries concerning license rights should be 
made to NASA, Code GP, Washington, D.C. 20546. 
Source: T. 0. Anderson of
Caltech/JPL
under contract to
NASA Pasadena Office
(NPO-101 12)
E 
Brief 69-10503	 Category 01
