Download presentation
Presentation is loading. Please wait.
1
Combinational Circuits
by Dr. Amin Danial Asham
2
References Digital Design 5th Edition, Morris Mano
3
DESIGN PROCEDURE (continue)
Adder (continue) Binary adder The binary adder is a digital combinational circuit that perform arithmetic summation for two binary numbers. A binary adder can be implemented using cascaded full adders with the output carry of a full adder is connected to the input carry of the next full adder. A four bit binary ripple adder can be constructed from 4 full adders as shown. The bits of binary number A and binary number B are designated by subscript numbers starting from right to left with the subscript 0 for the least significant bit. Carries are connected in a chain through the adders. The input C0 propagate through the adders to the output carry C4
4
DESIGN PROCEDURE (continue) Adder (continue)
Binary adder (continue) As in any combinational circuit the signal must propagate through the gates before the correct output is available in the output terminals. The total propagation time is equal to the propagation delay of a typical gate, times the number of gate levels in the circuit. The longest propagation delay time in an adder is the time it takes the carry to propagate through the full adders. For example: Inputs A3 and B3 are available as soon as input signals are applied to the adder. However, input carry C3 does not settle to its find value until C2 is available from the previous stage. Similarly, C2 has to wait for C1 and so on down to C0. Thus, only after the carry propagates and ripples through all stages will the last output S3 and carry C4 settle to their final correct value.
5
DESIGN PROCEDURE (continue) Adder (continue) Binary adder (continue)
Form the following full adder circuit diagram we find: The signals π π and πΊ π settle to their steady state values after their propagation through their respective gates. These two signals depend only on the input signals π΄ π and π΅ π which may be applied to all stages simultaneously. The signal from the input πΆ π to the output signal πΆ π+1 propagate through an AND and an OR gates, which constitute two gate levels. Therefore, if there is 4 full adder stages the output carry πΆ 4 would have 2Γ4=8 gate levels from πΆ 0 to πΆ 4 . Similarly, for n-bit adder the carry signal propagates through 2n gate levels. The carry propagation delay is very important since it limits the speed of an adder.
6
DESIGN PROCEDURE (continue)
Adder (continue) Binary adder (continue) π π = π΄ π β¨ π΅ π π π = π π β¨ πΆ π Therefore, πΆ 1 = π 0 πΆ 0 + πΊ 0 πΆ 2 = π 1 πΆ 1 + πΊ 1 = π 1 π 0 πΆ 0 + π 1 πΊ 0 + πΊ 1 πΆ 3 = π 2 πΆ 2 + πΊ 2 = π 2 π 1 π 0 πΆ 0 + π 2 π 1 πΊ 0 + π 2 πΊ 1 + πΊ 2 In the same way πΆ 4 can be driven. As shown, the Boolean functions of the carries are sum of products which can be implemented by only two level gates in parallel for all carries and hence πΆ π+1 does not have to wait for the previous carries. This circuit is called Carry Lookahead Generator. πΊ π = π΄ π π΅ π πΆ π+1 = π π πΆ π + πΊ π
7
DESIGN PROCEDURE (continue)
Adder (continue) Binary adder (continue)
8
DESIGN PROCEDURE (continue)
Adder (continue) Binary adder (continue) From The construction of a four-bit adder with a carry lookahead generator we find that : Each sum output requires two exclusive-OR gates. The output of the first exclusive-OR gate generates the π π variable, and the AND gate generates the πΊ π variable. The carries are propagated through the carry lookahead generator and applied as inputs to the second exclusive-OR gate. All output carries are generated after a delay through two levels of gates. Thus, outputs π π βs have equal propagation delay times.
9
DESIGN PROCEDURE (continue) Binary Adder -Subtractor
To calculate the subtraction A-B, the 2βs complement of B is added to A. The 2βs complement of B can be obtained from the 1βs complement of B adding 1. Noting that the 1βs complement of binary digit π΅ π β²= π΅ π β¨1. Therefore the subtractor can be built using binary adder as shown in the following figure, where π=1 to get the 1βs complement of B and convert it to 2βs complement by adding input carry πΆ 0 =π=1. In case of π=0, the circuit acts as normal binary adder. 4-bit Adder-Subtractor
10
DESIGN PROCEDURE (continue) Binary Adder βSubtractor (continue)
Overflow occurs in two n-bits numbers are added and the result needs n+1 bits. This case occurs if two positive or two negative numbers are added. Whereas no overflow occur if positive number is added to negative number since the result is smaller in magnitude than the larger of the original numbers. In the next example adding two positive or negative 8-bits numbers where the 8th bit is the sign, the sum is 9-bits number where the 9th bit is the correct sign bit. From the former example an overflow is detected by checking the carry into the sign bit and carry out from the sign bit, if they are not equal then there is an overflow. This method of detection is valid in case of 2βcomplement.
11
DESIGN PROCEDURE (continue)
Binary Adder βSubtractor (continue) Therefore, in case of unsigned in the adder-subtractor circuit, if the added numbers are considered unsigned C is the carry out after addition operation or the borrow after subtraction. In case of signed numbers the V detects the overflow, If V=0 no overflow occurred and the n-bit result is correct. If V=1, an overflow has occurred and the operations needs n+1 bit and only the right most n bits are available. And the (n+1)th bit is the actual sign and shifted out of position.
12
DESIGN PROCEDURE (continue)
BCD Adder A decimal adder performs the arithmetic summation on decimal numbers in the Binary Coded Decimal (BCD) form. A decimal adder for BCD receives the two numbers in BCD and calculate the sum in the BCD form. This adder is called BCD Adder For adding two decimal digits the adder receives 9 bits; 4 bits for each input BCD and 1 bit for carry in, and produces 5 bits where 4 bits for the output BCD and 1 bit for carry out. Since each BCD digit ranges from 0 to 9, therefore the maximum output is 9+9+1=19, where 1 is for carry in. To design the decimal adder, the truth table must first be listed and then the relations between inputs and outputs can be deduced .
13
DESIGN PROCEDURE (continue)
BCD Adder (continue) The summation will be first performed as normal binary operation and after that converted in to BCD form. The binary sum is listed in the left part of the table and the output bits are labeled π 1 , π 2 , π 4 , and π 8 . K is the carry out. The subscript is indicating the weights of the bits.
14
DESIGN PROCEDURE (continue)
BCD Adder (continue) The BCD sum is listed in the right part of the table and the output bits are labeled π 1 , π 2 , π 4 , and π 8 . C is the carry out. The subscript is indicating the weights of the bits. From the table the binary sum is identical to the BCD sum where the sum is less then or equal to
15
DESIGN PROCEDURE (continue)
BCD Adder (continue) For the values grater than the addition of 6(01102) converts to BCD and produces the carry as required.
16
DESIGN PROCEDURE (continue)
BCD Adder (continue) It is clear from the table the correction is needed if πΎ=1, π 8 =1 and π 2 =1, or π 8 =1 and π 4 =1. As shown in the right part of the table all the values that need corrections have a carry out πΆ=1. Therefore, πͺ=π²+ π π π π + π π π π . This carry out signal is used to convert the binary sum to BCD sum by adding 6(01102) to the binary sum.
17
The upper binary adder produces the binary sum.
DESIGN PROCEDURE (continue) BCD Adder(continue) The upper binary adder produces the binary sum. The lower binary adder receives the binary sum and adds if the output carry C=1 to produce BCD sum. The carry of the lower adder can be ignored since the output carry is already calculated C . A decimal parallel adder that adds n BCD digits needs n BCD adder stages. C 0110
18
DESIGN PROCEDURE (continue) Binary Multiplier
Multiplication of two binary numbers is performed in a similar way as decimal multiplications. For two 2-bits numbers A ( π΄ 1 π΄ 0 ) and B ( π΅ 1 π΅ 0 ). A has two bits π΄ 0 and π΄ 1 and B has two bits π΅ 0 and π΅ 1 . The product is C, which has four bits πΆ 0 , πΆ 1 , πΆ 2 , and πΆ 3 . The arithmetic multiplication is performed as follows: Therefore the logic circuit that can perform this function is: As shown it is needed 4 AND gates to perform this function and two HA.
19
DESIGN PROCEDURE (continue) Binary Multiplier (Continue)
Therefore, to build a multiplier that multiplies 4-bits number π΅ 3 π΅ 2 π΅ 1 π΅ 0 by 3-bits number π΄ 2 π΄ 1 π΄ 0 , we need 12-AND gates as shown: To construct a multiplier that multiplies J -bits multiplier by K -bits multiplicand we need π½ΓπΎ AND gates and (π½β1) k-bits adders to produce a product (π½+πΎ) bits. Multiplicand π΅ π΅ π΅ π΅ 0 π΄ π΄ π΄ 0 Multiplier π΄ 0 π΅ π΄ 0 π΅ π΄ 0 π΅ π΄ 0 π΅ 0 π΄ 1 π΅ π΄ 1 π΅ π΄ 1 π΅ π΄ 1 π΅ 0 πΆ ππ’π‘ π π π π 0 π΄ 2 π΅ π΄ 2 π΅ π΄ 2 π΅ π΄ 2 π΅ 0 πΆ ππ’π‘ π 3 π 2 π 1 π 0 πΆ 6 πΆ 5 πΆ 4 πΆ 3 πΆ 2 πΆ 1 πΆ 0
20
DESIGN PROCEDURE (continue) Magnitude Comparator
Magnitude comparator is used to compare between to numbers to decide of they are equal or not and if not which one is greater. To build a truth table for comparing two n-bits numbers we need to get 2 2π entries which is a huge quantity of entries. Therefore, a direct application of the procedure a person uses to compare the relative magnitude of two numbers is adopted here. For comparing two 4-bits numbers π΄= π΄ 3 π΄ 2 π΄ 1 π΄ 0 and π΅= π΅ 3 π΅ 2 π΅ 1 π΅ 0 , we first check if the corresponding bits in each numbers are equal, which leads to π΄ =π΅. In other words to check if π΄ 3 = π΅ 3 , π΄ 2 = π΅ 2 , β¦ so on Therefore to check if ππ‘ββbit in A is equal to ππ‘ββbit in B X-NOR function can be used to produce 1 in case of equality π₯ π = π΄ π π΅ π + π΄ π β² π΅ π β² for π=0,1,2,3. Hence π΄=π΅ = π₯ 3 π₯ 2 π₯ 1 π₯ 0 , which gives 1 in case of equality. Then to check if π΄>π΅ we start by checking the most significant pair of bits π΄ 3 and π΅ 3 if they are not equal and π΄ 3 is 1 then π΄ > π΅. If this pair of bits are equal then we check the next lower pair π΄ 2 and π΅ 2 . The comparison continues until a pair of unequal digits is reached. Therefore: π΄>π΅ = π΄ 3 π΅ 3 β²+ π₯ 3 π΄ 2 π΅ 2 β²+ π₯ 3 π₯ 2 π΄ 1 π΅ 1 β²+ π₯ 3 π₯ 2 π₯ 1 π΄ 0 π΅ 0 β² In the same way: π΅>π΄ = π΄ 3 β² π΅ 3 + π₯ 3 π΄ 2 β² π΅ 2 + π₯ 3 π₯ 2 π΄ 1 β² π΅ 1 + π₯ 3 π₯ 2 π₯ 1 π΄ 0 β² π΅ 0
21
DESIGN PROCEDURE (continue)
Magnitude Comparator (continue)
22
Thanks
Similar presentations
© 2025 SlidePlayer.com. Inc.
All rights reserved.