|Publication number||US4789956 A|
|Application number||US 06/788,054|
|Publication date||Dec 6, 1988|
|Filing date||Oct 16, 1985|
|Priority date||Oct 16, 1985|
|Publication number||06788054, 788054, US 4789956 A, US 4789956A, US-A-4789956, US4789956 A, US4789956A|
|Inventors||Eric A. Hildebrandt|
|Original Assignee||Harris Corp.|
|Export Citation||BiBTeX, EndNote, RefMan|
|Patent Citations (3), Referenced by (18), Classifications (9), Legal Events (7)|
|External Links: USPTO, USPTO Assignment, Espacenet|
The present invention relates in general to data processing apparatus and is particularly directed to a maximum negative number detector for use with a mantissa normalization circuit.
Customary encoding or numerical value representation in present day data processing apparatus adopt a binary representation in which the left-most bit of a given sequence is the sign bit and all bits to the right of the sign bit correspond to the operand. It is a generally employed practice that the sign bit be a zero for a positive number and a one for a negative number, with the remaining digits indicating the presence of absence of powers of two.
In order to carry out (floating point) arithmetic operations within the processor, it is necessary to normalize or scale the operands of the numbers to be processed. Examples of floating point control networks including associated normalization circuits are described in the U.S. Pat. Nos. to Tate et al 3,831,012, Voltin 3,193,669, Alrich et al 3,022,006, Hertz 3,304,417 and Marette 3,198,938. For positive numbers scaling is usually effected by counting (through a left shift process) the number of places (zeros) to the right of the left most bit until a one is encountered. Typically a counter within the normalizer circuit is incremented for each shift so as to provide a measure of the scale factor. For negative numbers, expressed in binary one's complement notation, the zeros represent significant digits and, after complementing the number, the same process described above for positive numbers is carried out to accomplish the normalizing. Namely the same normalization circuit can be used for both positive and negative numbers (with negative numbers being complemented prior to scaling). If, however, the number to be normalized is a maximum negative number (namely, one which cannot be represented as a positive number in the same precision), the value of the scale factor in the normalization counter will be in error. Conventionally, when a maximum negative number is encountered, correction for the above error is an after-the-fact exercise, requiring extra cycles of processing time during which renormalization of the maximum negative number is carried out.
In accordance with the present invention, there is provided, as part of the normalization circuit, a scheme for examining each number to be normalized and for providing an indication of the presence of a maximum negative number, prior to the actual normalization operation. For positive and ordinary negative numbers, the downstream scaling circuitry is permitted to operate in normal fashion. For a maximum negative number, the detection scheme affords a correction of the scaling counter prior to normalization, thereby enhancing processing speed.
In order to determine whether a number is a maximum negative number, the inventive scheme examines the left-most (most significant) bit of the bit sequence to be scaled. For positive numbers (where the bit is a zero) the normalize count is carried out without modification. Upon encountering a negative number the bits of the number are examined. Specifically, the detector contains logic circuitry that counts the displacement from the left-most bit position to the location of the first zero bit from that position. It also counts the displacement from the right-most bit position to the location of the first one bit from that position. For a maximum negative number (one or more ones followed only by one or more zeros) these two counts will differ by a single bit. This value is then used to prescale the normalization counter so that normalization may proceed.
FIG. 1 illustrates an example of a sixty-four bit (eight byte) maximum negative number bit sequence;
FIG. 2 shows the complement of the sequence of FIG. 1;
FIG. 3 is a schematic block diagram of a maximum number detector;
FIG. 4 shows the details of an individual stage of the controlled inversion logic unit 12 of FIG. 1; and
FIG. 5 illustrates an additional example of a sixty-four bit maximum negative number.
Before describing, in detail, the particular improved maximum negative number detection scheme in accordance with the present invention, it should be observed that the present invention resides primarily in a novel structure combination of conventional computer logic circuits and not in the particular detailed configurations thereof. Accordingly, the structure, control, and arrangement of such logic circuits have been illustrated in the drawings by readily understandable block representations and schematic diagrams, which show only those specific details that are pertinent to the present invention, in order not to obscure the disclosure with structural details which will be readily apparent to those skilled in the art having the benefit of the description herein. In addition, various components of an electronic data processing system have been appropriately consolidated and simplified in order to emphasize those portions that are most pertinent to the present invention. Thus, the block diagram illustrations of the Figures do not necessarily represent the mechanical structural arrangement of the exemplary system, but are primarily intended to illustrate the major structural components of the system in a convenient functional grouping, whereby the present invention can be more readily understood.
As pointed out briefly above, the detection scheme in accordance with the present invention examines each number (binary sequence) to be normalized. Positive numbers are passed through the detector without modification; however, negative numbers are examined to determine whether the number is a maximum negative number (which cannot be represented as a positive number in the same precision). Another way of defining a maximum negative number is a binary sequence that consists of one or more consecutive one bits (beginning with the most significant bit position) followed only by one or more consecutive zeros. For example, the maximum negative number 100(-4) cannot be represented as a positive number in the same precision as can the sequence of bits 011(+3), which is a maximum positive number with three bits.
For purposes of describing the present invention, the environment will be assumed to be a sixty-four bit (eight byte) processor. An example of a sixty-four bit (eight byte) maximum negative number to be used for explaining the present invention in the detailed description below is shown in FIG. 1. In the example chosen, the maximum negative number consists of nine one bits followed by fifty-five consecutive zeros. In accordance with the present invention, in order to determine whether or not a number is a maximum negative number, the detection scheme operates in response to the detection of a one bit in the most significant bit position, namely bit position zero, in byte zero (byte zero being the most significant byte and byte seven being the least significant byte) and proceeds to look for the first zero that may be encountered. Another way of describing this operation is the fact that the present invention operates to locate the first zero from the left most bit position. As shown in FIG. 1, the first zero occurs in byte position one in the second byte (byte 1).
In addition to locating the position of this first zero, from the left, the present invention operates to locate the first one from the right; namely the invention begins with the least significant bit position (bit position seven of byte seven) and procedes leftward from that position until it encounters a one bit. If the bit sequence defines a maximum negative number, that one bit position will always be one bit position greater than the bit position at which the first zero from the left is encountered. In the example shown, the first one occurs at bit position zero of byte number one, namely the ninth most significant bit position of the sixty-four bit sequence, while the first zero occurs in the tenth most significant bit position of the sixty-four bit sequence. For numbers other than maximum negative numbers, this relationship will not hold, so that it is simply a matter of locating the first zero bit from the left and the first one bit from the right and comparing the bit positions of these bits. For a maximum negative number, the location of the one bit position will always occur one significant bit position greater than the zero bit position.
In accordance with the implementation of the invention, the location of the first zero from the left and the first one from the right is effectively carried out in the same manner, by locating the position of the first one following a sequence of zero bits. This is partially illustrated in FIG. 2 which shows a bit sequence that is the complement of the bit sequence of FIG. 1. By inverting the sequence of FIG. 1, the location of the first zero bit from the left of FIG. 1 is equivalent to locating the first one bit from the left in FIG. 2. In effect, the invention operates to detect the first one bit following a sequence of zeros, as pointed out above, by locating the first one bit in the sequence of FIG. 2 following the zeros from the left and the first one bit in a sequence of FIG. 1 following the zeros from the right. The manner in which the invention accomplishes this will be explained below with reference to FIGS. 3 and 4.
Referring now to FIG. 3, there is shown a block diagram of the maximum negative number detector of the present invention. This maximum negative number detector is employed at the front end of a normalizer circuit which receives numbers to be normalized from upstream processing circuitry such as an arithmetic logic unit (ALU)10. Since, according to the present example, the environment of the processor is assumed to be a sixty-four bit machine, the output of the ALU is shown as being coupled over link 11 to supply a sixty-four bit (eight byte) sequence to a controlled inversion logic unit 12. Controlled inversion logic unit 12 consists of a set of eight individual logic units 12-0 . . . 12-7 (associated with bytes 0-7 of the sixty-four bit sequence), an individual one of which, unit 12-0 (associated with the most significant bytes, byte 0), is shown in FIG. 4. As shown therein, each controlled inversion logic unit has eight inputs b0 . . . b7 (the eight bits of the byte of interest) which are coupled to respective exclusive-OR gates 51-0 . . . 51-7. Another input of each of the exclusive OR gates is coupled to an invert control line 40. This line is used to selectively invert the state of each of the lines b0 . . . b7 when the output of ALU 10 is a negative number. Each exclusive OR gate has three outputs. A first output from the gates is respectively coupled over links 61-0 . . . 61-7 to a link 13-1 which represents the result of the exclusive-OR operation as controlled by the invert line 40. For a negative number, this means that link 13-1 contains the complement or inverse of bits b0-b7 on its respective bit lines. A second output of each of gates 51-0 . . . 51-3 is (respectively) coupled over one of links 81-0 . . . 81-3 to an inverter 52. Similarly, a second output of each of gates 51-4 . . . 51-7 is coupled over respective links 81-4 . . . 81-7 to an inverter 53. The outputs of inverters 52 and 53 are wire ORed at 54 to an output link 15-1. The state of link 15-1 will represent whether or not any of the bits b0-b7 is a one for a positive number or is a zero for a negative number. This is identified as a not-all-zeros positive number or a not all ones negative number representative link.
Another output of each of the exclusive-OR gates 51-0 . . . 51-7 is inverted and coupled over respective links 71-0 . . . 71-7 and wire-ORed to an output link 14-1 at 55. Namely, the state of line 14-1 is the inverse of line 15-1 and represents whether or not any of the gates has produced a one bit for a negative number. This is identified as a not-all-zeros negative number representative link in FIG. 4.
Referring again to FIG. 3, each of the respective logic unit stages 12-0 . . . 12-7 contains a controlled inversion logic unit as shown in FIG. 4 for each of the respective bits (bit 0 . . . bit7) of the bytes 0-7 with which the stages 12-0 . . . 12-7 are respectively associated. Thus, controlled inversion logic unit 12 has a sixty-four bit output link 13 containing the output links 13-1 . . . 13-7 for each of the respective stages, such as the stage 12-0 shown in FIG. 4; an eight bit output link 14, containing a set of output links 14-0 . . . 14-7 for the not-all-zeros negative number line, an individual one 14-0 of which is shown in FIG. 4; and an eight bit output link 15, representing not-all-zeros for positive number and not-all-ones for a negative number, such as the link 15-0 for the stage 12-0 shown in FIG. 4, described above.
As explained above with reference to FIG. 1, the present invention operates to determine whether a negative number is a maximum negative number. For a positive number, the contents of link 64 are essentially passed directly to downstream normalizing circuitry without modification by the circuit of FIG. 3 so an explanation of that operation will not be described here. When the output of ALU 10 is a negative number, however, which is the case under investigation here, the state of invert line 40 on each of the inversion logic units will cause the bit sequence supplied over link 11 to be inverted and coupled to output link 13. Namely, using the example shown in FIG. 1, output link 13 will produce the sixty-four bit sequence shown in FIG. 2. This sixty-four bit sequence is coupled to a look-from-left bit priority encoder unit 23. Unit 23 contains eight priority encoder stages respectively associates with bytes 0-7 that are coupled over link 13. Each priority encoder stage is comprised of conventional combinational logic which operates to detect the most significant bit position of any "one" bit in the byte that is applied to it. The location in the byte is identified as a three bit code on a respective one of output links 24-0 . . . 24-7. For the bit sequence shown in FIG. 2, there are no "one" bits in byte zero so that the output code on link 24-0 will be 000. For the second byte (byte 1) the seven bit sequence contains at least one 1 bit (here seven 1 bits) and the location of the most significant bit position of the first "one" bit is bit position number 1. Accordingly, link 24-1 will produce the binary code 001. The remaining bytes 2-7 contain no one bits so all of their output links 24-2 . . . 24-7 are all zeros. Links 24-0 . . . 24-7 are coupled to an 8:1 multiplexer 25. Multiplexer 25 is controlled by a select signal on link 22 to couple the 3 bits on one of input links 24-0 . . . 24-7 to a three bit output link 26.
The three bit control link 22 is coupled to the output of a look-from-the-left byte priority encoder 21, the input of which is coupled to output link 15 from controlled inversion logic unit 12. As described above, link 15 couples links 15-0 . . . 15-1 from each of the respective stages 12-0 . . . 12-7 of controlled inversion logic unit to supply an indication of whether or not the byte applied to each respective controlled logic unit stage contains all "ones" (for a negative number). In the example under consideration, FIG. 1 illustrates that byte 0 contains all ones. The first byte that contains a zero, beginning from the left or most significant bit position of the sixty-four bit sequence is byte one. Priority encoder 21, like each of the stages of priority encoder unit 23, contains combinational logic to provide an indication of which the eight input lines coupled to it contains the first zero. Because of the inversion carried out by the exclusive-OR gates within the inversion logic unit 12, this effectively means that priority encoder 21 locates the first byte from the left that contains a one bit. As shown in FIG. 2, which represents the inversion of the sequence of FIG. 1, this byte will be byte number one (in which the first one occurs at bit position number one). Thus, the state of output link 22 from encoder 21 is a three bit sequence into which the eight bit input link 15 has been encoded and contains the value (001) identifying byte number one.
As pointed out above, this code is supplied to the control input or multiplexer 25 and it is also supplied to a further multiplexer 31 and a comparator 41, the operation of which will be described below. In effect, the three bit sequence on link 22 identifies the fact that the first one bit in the sequence shown in FIG. 2 occurs within byte 1 and it instructs multiplexer 25 to couple the code on link 24-1, which specifies the exact bit position within byte one whereat the first one bit occurred, to output link 26.
Output link 26 is coupled with output link 22 from encoder 21 as inputs to a stage A of a comparator circuit 41. In effect, link 22 is a three bit code locating the byte in which the first one bit from the left (for the sequence shown in FIG. 2 has occurred), whereas the contents of link 26 are a three bit code identifying the actual bit position within that byte whereat the first one occurred. Thus, the code supplied to stage A of comparator 41 will be a six bit code 001001 the first three bits (the most significant three bits of this code) represent the contents of link 22 and identify the fact that the first one bit has occurred within byte one, whereas the last three bits 001 (the least significant three bits of the six bit code) identify the precise location within the byte one whereat the first one has occurred. Recapitulating, the circuitry described thus far operates to locate the first one bit from the left from the sequence shown in FIG. 2 (namely the first zero bit from the left for the actual negative number sequence shown in FIG. 1). The remaining circuitry to be described below, operates to locate the first one bit from the right for the negative number sequence shown in FIG. 1.
For this purpose, the not-all-zeros output link 14 from the controlled inversion logic unit 12 is coupled to a look from-the-right byte priority encoder 33. Like encoder 21 and the encoder stages of priority encoder unit 23, encoder 33 contains combinational logic to identify the most significant bit position of the eight bit input whereat a one first occurs. The eight bits are encoded as three bits on output link 35. For the negative number shown in FIG. 1, bytes 2-7 are all zeros whereas bytes 0 and 1 each contain at least one 1 bit. Since the purpose of the present exercise is to locate the first byte from the right which contains a 1 bit, links 14-0 . . . 14-7 of link 14 are coupled to the eight inputs of encoder 33 in an order reverse to that in which the links 13-0 . . . 13-7 and 15-0 . . . 15-7 are coupled to the stages of encoder 23 and priority encoder 21, respectively. Through this inverse connection, encoder 33 locates the first byte beginning with the least significant byte number 7 or from the right hand portion of the sequence shown in FIG. 1 and identified which byte is the first byte that contains a "one". For the negative number sequence shown in FIG. 1, the first byte containing a one from the right hand end of the bit sequence is byte number 1. Thus, encoder 33 will produce a three bit code on output link 35 representative of byte number 1. This code will correspond to the three most significant bytes of a six bit code to be applied to comparator stage B of comparator 41. This sequence corresponds to the code 001, identifying byte number 1, just as the three most significant bits of the six bit code applied to stage A applied by link 22.
To locate the precise bit position within byte 1 whereat the first one bit from the right has occurred, the logic circuitry of FIG. 3 contains a multiplexer 31 and a further priority encoder 34. Multiplexer 31 is an 8:1 multiplexer the outputs of which are inverted. The inputs of multiplexer 31 are coupled to each of the sixty-four bit lines of output link 13 from controlled inversion logic unit 12. Multiplexer 31 operates to couple the bit states of a respective one of the bytes 0-7 to an eight bit output link 32, after inverting the bit states. Selection of the appropriate byte is controlled by the state of link 22. It will be recalled that link 22 identifies which byte contains the first zero from the left for the sequence under consideration (shown in FIG. 1) or the first one from the left for the inverse of that maximum negative number (shown in FIG. 2). These three bits are chosen as the select control lines for multiplexer 31 because of the fact that for a maximum negative number the location of the first one bit from the right will always be exactly one bit position more significant than the first zero bit from the left, as shown in FIG. 1. This means that the same byte identification code for locating the first zero from the left for the maximum negative number can be used to identify that byte for locating the first one bit from the right.
More particularly, as shown in FIG. 1, the first zero bit from the left occurs within byte 1. As pointed out previously, the code identifying byte 1 is supplied over link 22 look-from-left byte priority encoder 21. The three least significant bits supplied over link 26 locate the bit position within byte 1 as being bit position number one whereat the first zero is located (or the first one is located for the inverse sequence shown in FIG. 2).
In the example chosen, it can be seen that the first one bit from the right for the maximum negative number sequence shown in FIG. 1 also occurs within byte 1, so that the same byte sequence can be employed for bit position identification. This feature of the invention also holds true even where the transition from a 1 to a 0 occurs at a boundary between bytes. If, for example, the maximum negative number under consideration were the number shown in FIG. 5, the first zero from the left is shown as occurring in byte 1, so that the three most significant bits of the six bit code supplied to comparator stage A of comparator 41 over link 22 would be the code 001. The bit position of the first 0 in that byte is the least significant bit position or the code 000 which would be supplied over link 26 to stage A of comparator 41, so that the entire six bit code supplied is the code 001000.
Now, looking from the right, the first byte to contain a one is byte 0 so that the six bit code supplied over link 35 from encoder 33 is the code 000. The byte identification code supplied over link 22 which identifies byte 1 as containing the first one from the right does not present a problem because of the inversion provided by multiplexer 31. Namely, the contents of byte 1, as examined by encoder 34, are all ones, so that the code 111 would be supplied over the least significant bit output link 36 to stage B of comparator 41. Thus, the code supplied to comparator stage B would be the code 000111 which differs from the code 001000 supplied to stage A by exactly 1 bit.
In the example under consideration, the code 001 as the three most significant bits is supplied over link 35 and the code 000 (locating bit position 0 in byte 1 as the occurrence of the first one from the right for the sequence shown in FIG. 1) is applied over link 36. Accordingly, stage B receives the six bit code 001000, whereas stage A receives the code 001001. Thus, the magnitude of the value supplied to stage A is one bit greater than the magnitude of the value supplied to stage B and comparator 41 recognizes this differential as a maximum negative number comparison and produces an output indicating the same over output link 42.
Where the number is not a maximum negative number, the first one bit encountered from the right will occur at a bit position producing a higher code supplied to stage B of comparator, 41 so that the output of comparator 41 will not produce a maximum negative number indication on output link 42.
Advantageously, because the circuitry of the present invention employs substantially the same components (each of the priority encoders is identically configured) and operates on the entire sixty-four bit sequence to carry out the look from-the-left and the look-from-the-right operations simultaneously, processing time is minimized. Moreover, because the operation occurs prior to normalization, extra cycles for renormalizing after correction are not required. In effect, the output of comparator 41 is supplied to the scaling register to offset its contents by one, taking into account what would otherwise be an erroneous shift for the maximum negative number situation. As a result, a correct normalization count is maintained for floating point processing.
While I have shown and described an embodiment in accordance with the present invention, it is understood that the same is not limited thereto but is susceptible of numerous changes and modifications as known to a person skilled in the art, and I therefore do not wish to be limited to the details shown and described herein but intend to cover all such changes and modifications as are obvious to one of ordinary skill in the art.
|Cited Patent||Filing date||Publication date||Applicant||Title|
|US3831012 *||Mar 28, 1973||Aug 20, 1974||Control Data Corp||Normalize shift count network|
|US4166271 *||Dec 23, 1977||Aug 28, 1979||Independent Broadcasting Authority||Digital recognition circuits|
|US4539549 *||Dec 30, 1982||Sep 3, 1985||International Business Machines Corporation||Method and apparatus for determining minimum/maximum of multiple data words|
|Citing Patent||Filing date||Publication date||Applicant||Title|
|US4875180 *||May 9, 1988||Oct 17, 1989||Unisys Corporation||Multi-function scaler for normalization of numbers|
|US4924421 *||May 17, 1988||May 8, 1990||Mitsubishi Denki Kabushiki Kaisha||Priority encoding system|
|US5023826 *||Jan 11, 1990||Jun 11, 1991||Bull Hn Information Systems Inc.||Apparatus for skipping arithmetic calculations involving leading zeros|
|US5091874 *||Jun 24, 1988||Feb 25, 1992||Mitsubishi Denki Kabushiki Kaisha||Encoder apparatus|
|US5153851 *||Jul 11, 1990||Oct 6, 1992||Nec Corporation||Method and arrangement of determining approximated reciprocal of binary normalized fraction of divisor|
|US5253349 *||Jan 30, 1991||Oct 12, 1993||International Business Machines Corporation||Decreasing processing time for type 1 dyadic instructions|
|US5422805 *||Oct 21, 1992||Jun 6, 1995||Motorola, Inc.||Method and apparatus for multiplying two numbers using signed arithmetic|
|US5440504 *||Feb 18, 1994||Aug 8, 1995||Matsushita Electric Industrial Co., Ltd.||Arithmetic apparatus for digital signal processor|
|US5574670 *||Aug 24, 1994||Nov 12, 1996||Advanced Micro Devices, Inc.||Apparatus and method for determining a number of digits leading a particular digit|
|US5727123 *||Dec 20, 1995||Mar 10, 1998||Qualcomm Incorporated||Block normalization processor|
|US5748516 *||Sep 26, 1995||May 5, 1998||Advanced Micro Devices, Inc.||Floating point processing unit with forced arithmetic results|
|US5761105 *||May 13, 1997||Jun 2, 1998||Advanced Micro Devices, Inc.||Reservation station including addressable constant store for a floating point processing unit|
|US5798953 *||Sep 24, 1996||Aug 25, 1998||Advanced Micro Devices, Inc.||Apparatus and method for determining a number of digits leading a particular digit|
|US5878266 *||Sep 26, 1995||Mar 2, 1999||Advanced Micro Devices, Inc.||Reservation station for a floating point processing unit|
|US5926786 *||Jun 11, 1997||Jul 20, 1999||Qualcomm Incorporated||Application specific integrated circuit (ASIC) for performing rapid speech compression in a mobile telephone system|
|US5940312 *||Oct 10, 1996||Aug 17, 1999||Microunity Systems Engineering, Inc.||Signed binary logarithm system|
|US6122721 *||Mar 1, 1999||Sep 19, 2000||Advanced Micro Devices, Inc.||Reservation station for a floating point processing unit|
|EP0703527A1 *||Jul 14, 1995||Mar 27, 1996||Advanced Micro Devices Inc.||An apparatus and method for determining a number of digits leading a particular digit|
|U.S. Classification||708/525, 708/205, 708/495|
|International Classification||G06F7/74, G06F5/01|
|Cooperative Classification||G06F5/012, G06F7/74|
|European Classification||G06F7/74, G06F5/01F|
|Oct 16, 1985||AS||Assignment|
Owner name: HARRIS CORPORATION, 1025 WEST NASA BOULEVARD MELBO
Free format text: ASSIGNMENT OF ASSIGNORS INTEREST.;ASSIGNOR:HILDEBRANDT, ERIC A.;REEL/FRAME:004717/0235
Effective date: 19850927
|Dec 11, 1986||AS||Assignment|
Owner name: HARRIS CORPORATION, 1025 WEST NASA BLVD., MELBOOUR
Free format text: ASSIGNMENT OF ASSIGNORS INTEREST.;ASSIGNOR:HILDEBRANDT, ERIC A.;REEL/FRAME:004712/0210
Effective date: 19861205
|Jun 5, 1992||FPAY||Fee payment|
Year of fee payment: 4
|Jun 6, 1996||FPAY||Fee payment|
Year of fee payment: 8
|Jun 27, 2000||REMI||Maintenance fee reminder mailed|
|Dec 3, 2000||LAPS||Lapse for failure to pay maintenance fees|
|Feb 6, 2001||FP||Expired due to failure to pay maintenance fee|
Effective date: 20001206