

Zadanie 1. Rozważmy n-bitowy sumator z przeniesieniem szeregowym (ang. ripple-carry adder, RCA). Sumuje on dwie liczby n-bitowe bez znaku, dając w wyniku również liczbę

Zakładając, że każda bramka działa w czasie jednostkowym, jaki jest czas działania tego sumatora (tzn. ile jednostek czasu potrzeba by na wyjściach sumatora pojawił się poprawny wynik dodawania)?
W jaki sposób wykryć, że wynik sumowania nie mieści się Q)

w n bitach (przepełnienie)?





Full odder ma 3 "Fozy" bramek, z zotożenia kożdo bromka = jednostko czosu

Musimy przejść po kolej body obler = focznie 3n Przepełnienie > cout =1

Zadanie 2. Pokaż, że n-bitowy sumator RCA poprawnie wykonuje operacje sumowania, jeśli argumenty interpretujemy jako liczby ze znakiem w kodzie uzupełnień do dwóch.

Overflow przy dwoch dodatnich = znak; przy dwoch ujemnych -> znak na 0 i cout na 1

Lierby U2 poprownie sig sumaje pisemnie RCA dzioko tolz somo jok dodowonie pisemne xor bitów i przenicsienie wpobujemy joko wynik olysjunkyż koniunkyń por bitów joko corry-over Zadanie 3. Zaprojektuj układ kombinacyjny (w postaci tabelki oraz grafu bramek), który wykrywa przepełnienie podczas dodawania liczb n-bitowych w kodzie uzupełnień do dwóch, za pomocą sumatora RCA. Układ powinien wyprowadzać na wyjście wartość 01, jeśli nastąpiło przeniesienie dodatnie (suma jest liczbą dodatnią niemieszczącą się w n bitach), wartość 10 jeśli nastąpiło przeniesienie ujemne (suma jest liczbą ujemną niemieszczącą się w n bitach) oraz wartość 00 w przeciwnym przypadku.

on by -noistorsze bity dobawonych liczb (1-16. ujemno, O dodolnie)
chri - wyjście ostotniego preniesienia

Cheeny otrzymac's

OO jeślis o, b rożnych znalów lub o,b,c tego somego

O li o,b wiemne, c obdotnie

10: o,b olod, c wjemne

|            |    |                             | result        |      |
|------------|----|-----------------------------|---------------|------|
| Q          | Ь  | C                           | c.1.          | c.2. |
| $\bigcirc$ | 0  | $\mathcal{O}_{\mathcal{O}}$ | 0             | O    |
| 0          | 0  | 1                           | $\circ$       | 1    |
| $\bigcirc$ | 1  | 0                           | 0             | 0    |
| O          | 1  | 1                           | 0             | 0    |
| 1          | 0  | 0                           | $\mathcal{O}$ | 0    |
| 1          | 0. | I                           | 0             | 0    |
| Λ          | 1  | 0                           | 1             | 0    |
| 1          | 1  | 1                           | Ö             | 0    |

C.1: 401761C C.2: 01617C



Zadanie 4. Na rysunku poniżej przedstawiono 19-bitowy sumator z wyborem przeniesień (ang. carry-select adder). Sumator ten składa się z siedmiu sumatorów RCA (szare bloki), multiplekserów (trójkaty) oraz bramek. Każdy sumator RCA przyjmuje, oprócz bitów do zsumowania, pewne przeniesienie wejściowe. Produkuje natomiast, oprócz bitów sumy, przeniesienie wyjściowe. Każdy z trzech par sumatorów RCA liczy swój fragment sumy, przy założeniu, że przeniesienie wejściowe jest równe odpowiednio 0 lub l. Następnie, po ustaleniu faktycznej wartości tego przeniesienia, multipleksery wybierają odpowiednie bity do wyprowadzenia na

wyjście jako bity sumy. Produkowane jest też przeniesienie dla następnej pary sumatorów RCA.



Przeanalizuj działanie tego układu i upewnij się, że dobrze je rozumiesz. Wylicz jego czas działania. Następnie załóż, że mamy zaprojektować n-bitowy sumator według tego schematu, przy czym wszystkie sumatory RCA mają mieć tą samą liczbę wyjść k. Jaka powinna być wartość k, by czas działania zaprojektowanego układu był możliwie najmniejszy?

Wskazówka: "Appendix J", str. 43.



Zadanie 5. Powtórz zadanie 4. dla sumatora z przeskokiem przeniesień (ang. carry-skip adder) przedstawionego poniżej.



Szare bloki oznaczają sumatory RCA z dodatkowym układem liczącym wartości propagacji przeniesienia przez dany blok  $P_{i,j}$ , gdzie  $P_{i,j}=pp_{i+1}p_{i+2}$ -- $p_{j'}$  a każda z wartości  $p_k$  jest propagacja przeniesienia przez pozycje k ( $p_k=a_k+b_k$ ). Np.  $P_{4,7}$  oznacza iloczyn logiczny  $p_4p_5p_6p_7$ , a  $p_4=a_4+b_4$ .

Zadanie 6. Opracuj sumator złożony z bloków (podobnie jak w poprzednim zadaniu), w którym każdy blok jest sumatorem RCA z dodatkowym układem obliczającym przeniesienie z tego bloku. Ten dodatkowy układ może korzystać jedynie z przeniesienia wejściowego danego bloku oraz bitów argumentów do zsumowania w danym bloku. Idee tego układu oprzyj na liczeniu propagacji

Zadanie 6. Opracuj sumator złożony z bloków (podobnie jak w poprzednim zadaniu), w którym każdy blok jest sumatorem RCA z dodatkowym układem obliczającym przeniesienie z tego bloku. Ten dodatkowy układ może korzystać jedynie z przeniesienia wejściowego danego bloku oraz bitów argumentów do zsumowania w danym bloku. Idee tego układu oprzyj na liczeniu propagacji przeniesienia i generowania przeniesienia przez dany blok. Bedzie to tzw. blokowy sumator z przeniesieniem równoległym (ang. carry-lookahead adder, CLA). Narysuj swój n-bitowy sumator dla n=16 i rozmiaru bloku k=4.

Wskazówka: "Appendix J", str. 37.



Zadanie 7. Bazując na algorytmie mnożenia pisemnego, opracuj układ mnożący liczby 4-bitowe. Jako podstawowe elementy układu możesz użyć dowolnych bramek i sumatorów.

Wskazówka: np. "Appendix J", str. 50

