

## HALF-ADDER & FULL-ADDER

Full-Adder (Tam-Toplayıcı), donanım modüllerinde kullanılan temel 1-bitlik toplayıcıya verilen isimdir. Half-Adder (Yarı-Toplayıcı), Full-Adder'ın daha basit bir formudur. Bu haftaki tutorialde önce Half-Adder, daha sonra da bu Half-Adder'ı kullanarak hiyerarşik bir Full-Adder tasarımları gerçekleştireceğiz. Half-Adder iki biti toplar ve bir toplam biti bir de elde biti üretir. Full-Adder'da ise iki bitin yanında elde girişi de vardır ve sonuçta bir toplam ve bir elde çıkışı mevcuttur. Half-Adder ve Full-Adder'ın black box gösterimi şekilde verilmiştir.

Half-Adder Doğruluk Tablosu

| A | B | Carry | Sum |
|---|---|-------|-----|
| 0 | 0 | 0     | 0   |
| 0 | 1 | 0     | 1   |
| 1 | 0 | 0     | 1   |
| 1 | 1 | 1     | 0   |



Full-Adder Doğruluk Tablosu

| A <sub>k</sub> | B <sub>k</sub> | C <sub>k-1</sub> | C <sub>k</sub> | S <sub>k</sub> |
|----------------|----------------|------------------|----------------|----------------|
| 0              | 0              | 0                | 0              | 0              |
| 0              | 0              | 1                | 0              | 1              |
| 0              | 1              | 0                | 0              | 1              |
| 0              | 1              | 1                | 1              | 0              |
| 1              | 0              | 0                | 0              | 1              |
| 1              | 0              | 1                | 1              | 0              |
| 1              | 1              | 0                | 1              | 0              |
| 1              | 1              | 1                | 1              | 1              |



Karnough haritası yöntemi mantık devrelerinin sadeleştirilmesinde en çok kullanılan metodlardan birisidir. Aşağıda Half-Adder devresinin Karnough harita metodu kullanılarak sadeleştirilmesi gösterilmiştir.

| Carry | B' | B |
|-------|----|---|
| A'    | 0  | 0 |
| A     | 0  | 1 |

| Sum | B' | B |
|-----|----|---|
| A'  | 0  | 1 |
| A   | 1  | 0 |

$$\text{Carry} = AB$$

$$\text{Sum} = A'B + AB' = A \wedge B \quad (\wedge \text{ işaretini Verilogda XOR demektir})$$



Half-Adder devresi yandaki şekilde gösterilmiştir.

Full-Adder tasarımda da Half-Adder'daki Karnaugh metodu uygulanarak çözüme gidilebilir. Fakat bu tutorialdeki amacımız '*hierarchical*' çözüm yolunu göstermektir. Full-Adder tasarıımızda iki adet Half-Adder kullanarak çözüme ulaşacağız. Aşağıdaki şekilde iki adet Half-Adder kullanılarak bir Full-Adder yapılmıştır.



Şimdi Xilinx ISE'de *hierarchy* metodu kullanarak Full\_Adder tasarımları nasıl yapılır onu göstereceğiz.

1) Önce aşağıdaki şekilde gösterildiği gibi bir Half\_Adder çiziyoruz. Dikkat edin *ibuf obuf* koymadık sinyallerin önlerine. Bufferlar sadece top module dediğimiz bloklarda bulunacak. Bizim sistemimizde Full\_Adder top module olarak kullanılmaktadır.



Half\_Adder modülünü çizdıktan sonra sentezleme işlemini gerçekleştiriyoruz. Hata almadığımızdan emin oluyoruz. Daha sonra Tools'dan Symbol Wizard seçeneğine tıklıyoruz. Karşımıza çıkan tabloyu aşağıdaki biçimde dolduruyoruz.



Sonra önlüğümüze çıkan bütün pencerelere *Next* diyoruz ve karşımıza Half\_Adder bloğu çıkıyor.



Artık Half\_Adder bloğunu symbols kısmında seçip bunu devre çizimlerimizde kullanabiliriz.

Full\_Adder tasarımlı için yeni bir *source*'a ihtiyacımız vardır. Bunun için *Project* sekmesinden *New Source* seçiyoruz. Aşağıdaki penceredeki gibi işlemleri bitiriyoruz.



Full\_Adder tasarıımı aşağıda gösterilmiştir. IBUF ve OBUF kullanımlarına dikkat ediniz! Daha sonra Full\_Adder dosyasını sentezleyip daha önceki deneylerde yaptığım işlemeleri Full\_Adder modülü için de yapabiliriz.



NOT: Haftaya laboratuvara gelmeden önce bu tutoriali evde çalışın, testbench yazmaya çalışın ve testbench simülasyonlarını görün. Haftaya laboratuvara testbench konusunda artık kendiniz yazmakla yükümlüsünüz.