# Anahtarlamalı Nano Dizinler ile Lojik Devre Tasarımı ve Boyut Optimizasyonu Logic Circuit Design with Switching Nano Arrays and Area Optimization

Muhammed Ceylan Morgül<sup>1</sup>, Mustafa Altun<sup>1</sup>

<sup>1</sup>Elektronik ve Haberleşme Mühendisliği İstanbul Teknik Üniversitesi mcmorgul@yahoo.com, altunmus@itu.edu.tr

## Özet

Bu çalışmada, yeni ve gelişen teknolojilerden olan kendiliğinden üretilen (self-assembled) nano-dizinler için lojik devre tasarımı gerçekleştirilmiştir. Bu kapsamda çalışmanın ilk bölümünde, diyot, CMOS ve dört-uçlu anahtar tabanlı olmak üzere üç farklı nano-dizin türü analiz edilmiştir. Her nano-dizin türü için, fonksiyon sentez teknikleri ortaya konmuştur. Ortaya konan bu teknikler ile gerçeklenen dizinlerin boyutlarını ifade eden formüller oluşturulmuştur. Altı farklı fonksiyonun üç farklı nano-dizin ile gerçeklendikleri tasarımların boyutları karşılaştırılmıştır. Bu karşılaştırma sonucu dört-uçlu anahtarlı nano-dizinlerin daha iyi sonuçlar verdiği gözlenmiştir. Bu sebeple, çalışmanın ikinci bölümünde XOR fonksiyonlarının sentezi bu tür nano-dizinler ile yapılmıştır ve bir sentez metodu geliştirilmiştir. Geliştirilen metot, dizin bovutu acısından literatürdeki diğer teknikler ile karşılaştırılmış ve daha iyi sonuçlar verdiği gözlenmiştir. Aynı zamanda, elde edilen sonuçların geleneksel CMOS anahtarlı devre boyutlarından da küçük olduğu ifade edilmiştir.

#### Abstract

In this paper, logic circuit design with self-assembled nanoarray, which is one of the future and emerging technologies, was studied. In this context, three different nano-array types, namely diode, CMOS and four-terminal switch-based nanoarrays are analyzed in the first stage of the study. Function synthesis techniques for each type of nano-arrays are presented. Expressions for the size formula of the nano-arrays designed using these techniques are derived. The sizes of the nano-arrays realizing six example functions implemented using the three types of nano-arrays are compared. The comparison reveals that four-terminal switch based nanoarrays lead to the smallest size. Therefore in the second stage of the study, synthesis of XOR functions are made with this type of nano-arrays and a synthesis method is developed. It is concluded that the developed method performs better than the methods in the literature in terms of size, after the comparison between. Moreover, the sizes of designs are also smaller than the sizes of traditional CMOS based circuits.

#### 1. Giriş

CMOS tansistörlerin icadından beri üreticiler ve tasarımcılar, transistör boyutlarının küçültülmesi üzerine çalışmalar yapmışlardır. Ancak transistör boyutlarının fiziksel limitlerine ulaşılması sebebiyle bu yaklaşımın yakın bir gelecekte sonlanacağı tahmin edilmektedir [1]. Gordon Moore'un kendisi bile, CMOS tarnsistörlerin boyutları ve tümleşik devreler içindeki sayıları hakkında yaptığı -geniş çevrelerce kabul edilmiş- öngörüsünün geçerliliğini yitireceğini ifade etmiştir [2]. Elektronik hesaplamalara uygun yeni teknoloji arayışları; DNA ve moleküler hesaplama, quantum kapılar ve nano boyutlarda kendiliğinden üretilen (self-assembled) nanodizin devreleri gibi ürünleri ortaya çıkarmıştır [3, 4]. Bu çalışmada, bu teknolojilerden Şekil 1'de örnekleri verilen kendiliğinden üretilen (self-assembled) nano-dizinlerin tasarım teknikleri araştırılmış ve bu teknikler yapılan hesaplamalarla karşılaştırılmıştır.



Şekil 1: Üretilmiş nanodizin örnekleri (a) [5] ve (b) [6].

Nano boyutta üretilen bu dizinleri diyot, CMOS ve dört-uçlu anahtar tabanlı olmak üzere üç farklı türde incelemek mümkündür (Şekil 2). Bu türler henüz ticari kullanıma geçmemekle birlikte hali hazırda üretilmektedirler [8-10].

Araştırmanın ilk aşamasında bu üç farklı nano-dizin türü analiz edilmiştir. İstenilen lojik-fonksiyonların bu devreler ile gerçekleme teknikleri ortaya çıkarılmıştır. Bu teknikler kullanılarak bir fonksiyonu gerçekleştirmek için gereken nano-dizin boyut denklemi, giriş/çıkış sayısı ve çarpım terim sayısı cinsinden formülüze edilmiştir. Üretilen formüller sayesinde herhangi bir hedef fonksiyonu gerçekleyen nanodizin tasarımının boyutları kesin olarak bulunmuş olmaktadır.

Altı örnek fonksiyonun üç nano-dizin türü için tasarım boyutları elde edilen formüller kullanılarak hesaplanmıştır. Elde edilen hesaplamaların karşılaştırması sonucunda, dörtuçlu nano-dizinlerin bu fonksiyonlar için devre boyutu açısından daha avantajlı olduğu gözlenmiştir. Bu avantajın birçok fonksiyon için de geçerli olabileceği ampirik olarak öngörülmüştür. Dört-uçlu anahtar tabanlı nano-dizinlerin boyut avantajı sebebiyle, araştırmanın sentez aşamasında bu nano-dizin türü tercih edilmiştir.

Sentezi yapılmak üzere XOR (özel-OR) fonksiyonları tercih edilmiştir. Karşılaştırma algoritmalarının temelini oluşturan bu fonksiyonlar, toplama ve doğruluk test devreleri gibi birçok elektronik ve haberleşme sistemlerinde geniş ölçekli olarak kullanılmaktadır [7]. Dört-uçlu nano-dizinler ile XOR fonksiyonlarının literatürde önceden sunulan iki sentez tekniği incelenmiş ve devre boyutu açışından daha iyi sonuç veren yeni bir teknik geliştirilmiştir [10]. Tümevarım yaklaşımıyla gerçekleştirilen bu teknik, alt devre tasarımlarının iyileştirilmesiyle geliştirilmiştir. Bu iyileştirilmelerden biri, XOR4 fonksiyonun 3x5 (satır sayısı üç, sütün sayısı 5) boyutlarında bir nano-dizin ile sentezlenmesi olmuştur.

Örnek vermek gerekirese; XOR5 fonksiyonu dört-uçlu nanodizinler ile literatürdeki tekniklerin biriyle (genel fonksiyonlar için geliştirilmiş teknik) 16x16, diğeriyle (XOR için özel teknik) 5x16 boyutlarında gerçeklenmesine rağmen, geliştirilen teknik sayesinde 4x10 boyutunda gerçeklenebilmektedir.

Önceki tekniklere göre dizin boyutu açışından çok daha avantajlı olan bu teknik, geleneksel CMOS devre boyutlarıyla da karşılaştırılmıştır. Bazı varsayımlar kullanılarak yapılan bu karşılaştırmada dört-uçlu nano-dizin tasarımlarının CMOS devrelere nazaran çok küçük boyutlara ulaşabildikleri belirtilmiştir.



*Şekil* 2: Diyot tabanlı (a) [8], CMOS tabanlı (b) [9] ve döruçlu anahtar tabanlı nano-dizinler (c) [10].

Bildiri giriş bölümünü takiben; ikinci bölümde üç farklı tür nano-dizinin analizleri yapılarak, dizin boyut denklemlerinin nasıl formülüze edildiklerinden bahsedilmiştir. Yapılan analiz sonucu dört-uçlu anahtarlı nano-dizinlerin daha iyi sonuçlar verdiği gösterilmiştir. Üçüncü bölümde ise, dört-uçlu anahtar tabanlı nano-dizinler ile XOR fonksiyonlarının nasıl sentezlendiği detaylı bir şekilde anlatılmıştır. Geliştirilen teknik ile elde edilen tasarımların boyutları ile geleneksel CMOS tabanlı devrelerin boyutları karşılaştırılmıştır. Dördüncü bölümde elde edilen sonuçlar ve araştırmanın geliştirilmeye açık tarafları tartışılmıştır.

## 1.1. Açıklamalar ve Kısaltmalar

Bildiri içerisinde geçen bazı ifadeler için açıklamalar aşağıda verilmiştir.

**Kesme İşareti ('):** Bir değişken veya fonksiyonun değilini ifade etmek için kullanılmaktadır. Örneğin A değişkeninin değili "A' "şeklinde ifade edilmektedir.

**Giriş Sayısı:** Bir fonksiyonda bulunan birbirinden farklı değerler alabilen, birbirine bağımlı veya bağımsız değişkenlerin toplam sayısı. Örneğin bir fonksiyon içerisinde A, A' ve B değişkenleri var ise; bu fonksiyonun giriş sayısı 3'tür.

Çıkış Sayısı: Bir devrenin çıkışında elde edilebilen fonksiyonların sayısı. Diyot ve CMOS tabanlı nano-dizin devreler birden fazla çıkış değeri elde etmek için kullanılabilmektedir.

**Çarpım Sayısı:** Çarpımların toplamı formatında yazılmış fonksiyonların ifadelerinde bulunan çarpım terimlerinin toplam sayısı. Elde edilen denklemler fonksiyonların kendilerinin ve eşleniklerinin (dual) çarpım sayıları cinsinden ifade edilmiştir.

## 2. Nano-Dizinlerin Analizi ve Dizin Boyut Formülasyonu

Diyot tabanlı, CMOS tabanlı ve dört-uçlu anahtar tabanlı nano-dizinler ayrı ayrı incelenmiş, boyut formülleri çıkarılmış ve sonuçlar karşılaştırılmıştır.

#### 2.1. Diyot Tabanlı Nano-Dizin

Diyot tabanlı nano-dizin ile temel "VE" ve "VEYA" fonsiyonlarının nasıl gerçekleştirildiği Şekil 3'de gösterilmiştir.



*Şekil* 3: f = AB (a) ve f = A + B (b) fonksiyonlarının diyot tabanlı nano-dizin tasarımları.

Bu tasarımlardan yola çıkarak çarpımların toplamı olarak yazılmış fonksiyonlar için devre tasarımı direk olarak yapılabilir. Şekil 3.a'da gösterildiği gibi p-tipi nano-tel üzerinde oluşturulmuş çarpım terimlerini Şekil 3.b'deki toplama devresine giriş olarak verilmesiyle, toplama devresinin çıkışında fonksiyon elde edilmiş olur [8, 11]. Bu teknik ile f = AB + CD fonksiyonu için yapılmış tasarım Şekil 4'de gösterilmiştir.



*Şekil* 4: f = AB + CD fonksiyonunun diyot tabanlı nanodizinler ile tasarımı.

Şekil 4'de görüldüğü üzere f = AB + CD fonksiyonunu gerçeklemek için 3x5 boyutunda bir nano-dizin gerekmektedir.

Şekil 4'deki en soldaki sütun toplama işlemi için kullanılmaktadır. Toplama işleminin yapıldığı bu sütun fonksiyon çıkış değerini göstermektedir. Çıkış sütunu ile kesişen satırların değerleri çarpım terimleri veya yalnız haldeki değişkenlerdir. Satır sayısı, çarpım terimlerinin ve fonksiyonlar için çıkış değer sayısının toplamına eşittir.

Çıkış sütunlarının dışında kalan sütunlar giriş sütunlarıdır. Çarpım terimlerinde bulunan A, A' ve B gibi girişler devreye bu sütunlar üzerinden aktarılır. Böylece gereken sütun sayısı giriş sayısı ve çıkış sayısının toplamına eşittir. Şekil 4'de verilen örnekte sadece f fonksiyonu çıkış olarak bulunmaktadır. Bu örnekte çıkış sayısı 1'dir. Böylece diyot tabanlı nano-dizin boyut denklemi Denklem 1'de gösterilmiştir.

Dizin Boyutu = (Çarpım Sayısı + Çıkış Sayısı) x (Giriş Sayısı + Çıkış Sayısı) (1)

Eğer fonksiyon ifadesinde toplama işlemine bir giriş yalnız halde katılıyorsa (ör: f=A+BC); bu giriş direk olarak satır teline verilir ve tasarımda bir sütun eksilmiş olur.

## 2.2. CMOS Tabanlı Nano-Dizin

CMOS tabanlı nano-dizin devre tasarımı, standart transistör tabanlı devreler ile benzerlik göstermektedir. Şekil 2'de gösterilen nano-dizinlerin nFETS bölgesi "pull-down" devresi, pFETS bölgesi "pull-up" devresi olarak tasarlanır [9]. Ancak bu nano-dizinlerde, standart CMOS transistör devrelerin aksine, her bir çarpım teriminin ayrı bir hat üzerinde gerçeklenmesi gerekmektedir. Şekil 5'de örnek olarak f = (AB + CD)' fonksiyonu için CMOS tabanlı nano-dizin tasarımı gösterilmiştir.



*Şekil* 5: f = (AB + CD)' fonksiyonunun CMOS tabanlı nanodizinler ile tasarımı [9].

Şekil 5'de görüleceği gibi nFETS bölgesi  $f_D$  (f fonksiyonunun eşleniği) fonksiyonu için ve pFETS bölgesi f fonksiyonu için tasarlanırken her bir çarpım terimi bir sütun ile gerçeklenmiştir. Böylece bir fonksiyon için yapılan nano-dizin tasarımında gereken sütun sayısı fonksiyonun kendisi ve eşleniğinde bulunan çarpım terim sayısı kadardır. Satır sayısı ise giriş ve çıkış elemanları kadardır. Şekil 5'de verilen örnekte dört giriş ve bir çıkış elemanı vardır. Denklem 2'de dizin boyutu ifade edilmiştir.

Dizin Boyutu = (Giriş Sayısı + Çıkış Sayısı) x (f fonksiyonu Çarpım Sayısı +  $f_D$  fonksiyonu Çarpım Sayısı) (2)

#### 2.3. Dört-Uçlu Anahtar Tabanlı Nano-Dizin

Altun ve Reidel'in geliştirmiş oldukları metot verilen herhangi bir hedef fonksiyonu için dört-uçlu anahtar tabanlı nano-dizin tasarımı yapılmasını sağlamaktadır [10]. Dört-uçlu anahtarlı nano-dizinlerde, diyot ve CMOS tabanlı nano-dizinlerin aksine, giriş değerleri anahtarları kontrol etmek için kullanılmaktadır. Şekil 6'da Altun ve Reidel'in makalesinden alınmış örnek gösterilmiştir. Geliştirilen teknik ile verilen  $f = x_1x_2x_3 + x_1x_4 + x_1x_5$  fonksiyonunun kendisi ve eşleniği  $f_D = x_1 + x_1x_3 + x_1x_4 + x_1x_5$   $x_{2}x_{4}x_{5} + x_{3}x_{4}x_{5}$  kullanılarak f fonksiyonu için Şekil 6'daki tasarım oluşturulmuştur [10].

| {:                  | $x_1, x_2, x_3$           | $\{x_1, x_4\}$            | $\{x_1, x_5\}$            |
|---------------------|---------------------------|---------------------------|---------------------------|
| $\{x_1\}$           | $\{x_1\}$                 | $\{x_1\}$                 | $\{x_1\}$                 |
| $\{x_2, x_4, x_5\}$ | $\{x_2\}$                 | { <i>x</i> <sub>4</sub> } | { <i>x</i> <sub>5</sub> } |
| $\{x_3, x_4, x_5\}$ | { <i>x</i> <sub>3</sub> } | ${x_4}$                   | ${x_5}$                   |

*Şekil* 5:  $f = x_1x_2x_3 + x_1x_4 + x_1x_5$  fonksiyonunun dört-uçlu anahtar tabanlı nano-dizinler ile tasarımı [10].

Metodun ilk aşamasında sütunlar üzerine fonksiyon ve satırlar üzerine eşleniğindeki çarpım terimleri yazılır. İkinci aşamada ise bu satır ve sütunların üzerindeki çarpım terimlerinde ortak olarak bulunan değişkenler, o kesişimdeki anahtarların kontrol uçlarına atanır. Eğer çarpım terimlerinde ortak olan birden fazla değişken var ise; rasgele bu değişkenlerden birinin seçilmesi yeterlidir. Şekil 2.c'de gösterilen nano-dizin modelinde gösterilen kontrol uçlarına girişlerin atanmasıyla, "ÜST-ALT" arasında f fonksiyonu gerçeklenmiş olur. Sütun ve satır sayılarını sırasıyla f ve  $f_D$  fonksiyonlarının çarpım terimlerinin sayısı belirlemiş olur [10]. Denklem 3'de dizin boyutu gösterilmiştir.

Dizin Boyutu = (f fonksiyonu Çarpım Sayısı) x (fb fonksiyonu Çarpım Sayısı) (3)

Üç nano-dizin türü ile altı adet örnek fonksiyonu gerçeklemek için gereken dizin boyutları, temel teknikler ile ortaya çıkarılmış formüller yardımıyla hesaplanmıştır. Tablo 1'de dört-uçlu anahtar tabanlı nano-dizin tasarımları incelenen tüm örnek fonksiyonlar için en küçük boyutlarda sonuç verdiği görülmektedir.

Devre boyutu açısından değerlendirildiğinde üç tür arasında en avantajlı sonucu veren tür dört-uçlu anahtarlı nano-dizinler olmuştur. Bu sebeple XOR fonksiyonlarının sentezi bu tür nano-dizinler üzerinde yapılmıştır.

| Tablo 1: Farklı fonksiyonlar için üç tür nano-dizin tasarım |
|-------------------------------------------------------------|
| boyutları karşılaştırması.                                  |

|                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | J                |                     |                                   |  |  |
|---------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|---------------------|-----------------------------------|--|--|
| Fonksiyon                                                                                   | Diyot                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | CMOS             |                     | Dört-uçlu anahtar                 |  |  |
|                                                                                             | tabanlı                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | tabanlı          |                     | tabanlı                           |  |  |
| $f_1$                                                                                       | 4x6=24                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 6x6=36           |                     | 3x3=9                             |  |  |
| f2                                                                                          | 3x5=15                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                  | 5x6=30              | 4x2=8                             |  |  |
| $f_3$                                                                                       | 6x8=48                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                  | 8x9=72              | 4x5=20                            |  |  |
| $f_4$                                                                                       | 3x6=18                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                  | 6x6=36              | 4x2=8                             |  |  |
| f5 (XOR3)                                                                                   | 5x7=35                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                  | 7x8=56              | 4x4=16                            |  |  |
| $f_6$ (XOR <sub>4</sub> )                                                                   | 9x9=81                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 9                | x16=144             | 8x8=64                            |  |  |
| $f_1 = x_1 x_2 x_3 +$                                                                       | $x_1x_4 + x_1x_5$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                  | $f_4 = x_1 x_2' +$  | <i>x</i> 1' <i>x</i> 2 <i>x</i> 3 |  |  |
| $f_2 = x_1 x_2 + x_2$                                                                       | 3X4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                  | $XOR_3 = .$         | $x_1x_2'x_3' + x_1'x_2x_3' +$     |  |  |
| $f_3 = x_1 x_2' x_3 +$                                                                      | $+x_1x_4'+x_2x_3x_4'+x_2x_3x_4'+x_2x_3x_4'+x_2x_3x_4'+x_2x_3x_4'+x_2x_3x_4'+x_2x_3x_4'+x_2x_3x_4'+x_2x_3x_4'+x_2x_3x_4'+x_2x_3x_4'+x_2x_3x_4'+x_2x_3x_4'+x_2x_3x_4'+x_2x_3x_4'+x_2x_3x_4'+x_2x_3x_4'+x_2x_3x_4'+x_2x_3x_4'+x_2x_3x_4'+x_2x_3x_4'+x_2x_3x_4'+x_2x_3x_4'+x_2x_3x_4'+x_2x_3x_4'+x_2x_3x_4'+x_2x_3x_4'+x_2x_3x_4'+x_2x_3x_4'+x_2x_3x_4'+x_2x_3x_4'+x_2x_3x_4'+x_2x_3x_4'+x_2x_3x_4'+x_2x_3x_4'+x_2x_3x_4'+x_2'+x_2'+x_3x_4'+x_2'+x_2'+x_2'+x_3x_4'+x_2'+x_2'+x_2'+x_2'+x_2'+x_2'+x_2'+x_2$ | κ <sub>4</sub> ' | $x_1'x_2'x_3 + x_3$ | 1 <i>X</i> 2 <i>X</i> 3           |  |  |
| $+x_{2}x_{4}x_{5}+x_{3}x_{4}x_{5}+x_{5}x_{4}x_{5}+x_{5}x_{5}x_{5}x_{5}x_{5}x_{5}x_{5}x_{5}$ | 25                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                  | $XOR_4 = x_4 X$     | $XOR_3' + x_4'XOR_3$              |  |  |
| Fonksiyon                                                                                   | Giriş                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Çarpım (Kendi)   |                     | Çarpım (Eşlenik)                  |  |  |
| $f_1$                                                                                       | 5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 3                |                     | 3                                 |  |  |
| $f_2$                                                                                       | 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 2                |                     | 4                                 |  |  |
| f3                                                                                          | 7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 5                |                     | 4                                 |  |  |
| $f_4$                                                                                       | 5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 2                |                     | 4                                 |  |  |
| $f_5$                                                                                       | 6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 4                |                     | 4                                 |  |  |
| $f_6$                                                                                       | 8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                  | 8                   | 8                                 |  |  |
| Tüm fonksiyonlar için çıkış sayısı 1'dir.                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                  |                     |                                   |  |  |
| Diyot T. = (Ç                                                                               | arpım S. + 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Çıkış S          | S.) x (Giriş S.     | + Çıkış S.)                       |  |  |
| CMOS T.=(Giriş S. + Çıkış S.) x ( $f$ fonk. Çarp. S. + $f_D$ fonk. Çarp. S.)                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                  |                     |                                   |  |  |
| Dört-uçlu Anahtar T. = ( $f$ fonk. Çarp. S.) x ( $f_D$ fonk. Çarp. S.)                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                  |                     |                                   |  |  |

## 3. Dört-Uçlu Anahtar Tabanlı Nano-Dizinler ile XOR Fonksiyonları Sentezi

Altun ve Reidel, XOR fonksiyonları için Bölüm 2.3.'de özetlenen genel fonksiyon sentezi metodu yerine daha verimli bir metot öne sürmüşlerdir. Geliştirilen metot sayesinde nanodizin üzerinde istenilmeyen yollar iptal edilerek her bir çarpım terimi bir sütun ile gerçeklenmektedir [10]. Bu ardışık metot temelde XOR fonksiyonlarının Denklem 4'de gösterilen karakteristiğine dayanmaktadır. Şekil 6'da bu metot ile gerçekleştirilmiş XOR<sub>1</sub>, XOR<sub>2</sub> ve XOR<sub>3</sub> fonksiyonları için tasarımlar yer almaktadır.



Şekil 6: Altun ve Reidel'in XOR fonksiyonları için nano-dizin tasarım metodu [10].

Bu metot sayesinde, XOR<sub>3</sub> için 4x4=16 olan nano-dizin boyutu 3x4=12'ye, XOR<sub>4</sub> için 8x8=64 olan nano-dizin boyutu 4x8=32'ye düşmüştür. Satır satısını çarpım terimlerinin uzunluğu (değişken sayısı), sütun sayısını çarpım sayısı belirlemektedir. Her bir çarpım terimi farklı bir sütun üzerinde oluşan yol ile gerçeklenmektedir. Ancak bu teknik anahtarların dört komşusu ile iletişime girebilme özelliğini kullanmamaktadır. Dört-uçlu nano-dizinlerin yapısı bu boyutların daha da küçülmesine imkân vermektedir. Bu tür nano-dizinler üzerindeki anahtarların dört-uçlu yapıya sahip olmaları, hedef fonksiyonun çarpım terimlerinin ortak olarak kullandıkları anahtar sayısının artmasını sağlamaktadır. Bu özelliğin kullanılmasıyla tasarımlar çok daha küçük boyutlara ulaşabilmektedir.

XOR4 fonksiyonu için anahtarların dört uçlu olma özelliği kullanılarak, 3x5 boyutlarında bir nano-dizin tasarımı yapılmıştır. Şekil 7'de bu tasarım gösterilmiştir.

| Terminal A              |                         |            |                         |                         |  |
|-------------------------|-------------------------|------------|-------------------------|-------------------------|--|
| <i>x</i> <sub>1</sub>   | <i>x</i> <sub>4</sub> ' | $x_1$ '    | <i>X</i> 4              | <i>x</i> 1              |  |
| <i>x</i> <sub>2</sub> ' | <i>x</i> <sub>3</sub>   | $x_2$      | <i>x</i> <sub>3</sub> ' | <i>x</i> <sub>2</sub> ' |  |
| $x_1$ '                 | <i>X</i> 4              | <i>x</i> 1 | <i>x</i> 4'             | $x_1$ '                 |  |
| Terminal B              |                         |            |                         |                         |  |

Şekil 7: XOR4 fonksiyonu için dört-uçlu anahtar tabanlı nanodizin tasarımı.

Şekil 7'deki tasarımda, herhangi bir sütundan başlayıp komşu sütunda biten her yol bir çarpım terimini gerçeklemektedir. Bu kurala uyan 8 farklı yola 8 farklı çarpım terimi atanmıştır. XOR4 fonksiyonunun simetrik olması ve birbiri ile ortak elemanı olmayan iki farklı çarpım terimi bulundurması, tasarımın boyutunun optimum olduğunu ispat etmektedir. Son sütun ilk sütunun aynısıdır. Birinci ve dördüncü sütunların birbirine direk bağlanmaları halinde son sütuna ihtiyaç duyulmayacak ve tasarım 3x4=12 boyutlarına ulaşabilceketir. XOR4 fonksiyonu için tasarlanan iki-uçlu anahtar tabanlı geleneksel devrelerde kullanılması gereken anahtar sayısı 16'dır. XOR4 için 4x8=32 boyutları yerine 3x5=15 boyutlarında yapılan tasarım, geleneksel devre tasarımda kullanılan anahtar sayısından bile daha az anahtar sayısına sahiptir.

Altun ve Reidel'in öne sürdükleri metot, Denklem 5 kullanılarak daha iyi sonuçlar verecek şekilde geliştirilmiştir. Denklem 5, Denklem 4'ün genelleştirilmiş halidir. Denklem 5'in Şekil 8'deki tasarım ile sentezlenmesiyle, tümevarım yaklaşımıyla bütün XOR fonksiyon tasarımlarına elde edilir.

$$XOR_{k=l+m} = XOR_{l}XOR_{m}' + XOR_{l}'XOR_{m}$$
(5)

| Terminal A |    |      |    |    |  |  |
|------------|----|------|----|----|--|--|
| £          |    | 0    | f3 |    |  |  |
| $f_1$      |    | 0    |    |    |  |  |
| 1 1        |    | 0    | 1  | 1  |  |  |
| 4          | c. | 0    |    | ¢. |  |  |
| $J^2$      |    | 0 54 |    | 4  |  |  |
| Terminal B |    |      |    |    |  |  |

*Şekil 8*:  $f_{\rm T} = f_1 f_2 + f_3 f_4$  fonksiyonunun nano-dizinler ile gerçeklenmesi.

Örneğin; XOR<sub>6</sub> = XOR<sub>4</sub>XOR<sub>2</sub>' + XOR<sub>4</sub>'XOR<sub>2</sub> eşitliği yazılabilmektedir. Bu dört alt fonksiyon (XOR<sub>4</sub>, XOR<sub>2</sub>', XOR<sub>4</sub>' ve XOR<sub>2</sub>) Şekil 8'da gösterilen fonksiyon blokları üzerinde gerçeklenerek, nano-dizin XOR<sub>6</sub> için tasarlanmış olur.

Tümevarım yaklaşımıyla gerçekleştirilen bu yöntem ile Şekil 6'daki alt XOR tasarımları kullanılarak üçten büyük XOR fonksiyonları için tasarlanan nano-dizin boyutları Tablo 2'de belirtilmiştir. Bu yaklaşımda XOR fonksiyonlarını en küçük alanda gerçeklemek için birbirine en yakın alt XOR fonksiyonları seçilmelidir.

*Tablo* 2: XOR<sub>1</sub>, XOR<sub>2</sub> ve XOR<sub>3</sub> alt fonksiyonları ile gerceklenen XOR fonksiyonlarının tasarım boyutları.

| <u> </u>          |       |       |      |                                     |
|-------------------|-------|-------|------|-------------------------------------|
|                   | Satır | Sütun | Alan | Alt Fonksiyonlar                    |
| XOR <sub>1</sub>  | 1     | 1     | 1    | XOR <sub>1</sub>                    |
| XOR <sub>2</sub>  | 2     | 2     | 4    | XOR <sub>1</sub> , XOR <sub>1</sub> |
| XOR <sub>3</sub>  | 3     | 4     | 12   | XOR <sub>1</sub> , XOR <sub>2</sub> |
| XOR <sub>4</sub>  | 5     | 5     | 25   | XOR <sub>2</sub> , XOR <sub>2</sub> |
| XOR <sub>5</sub>  | 7     | 7     | 49   | XOR <sub>2</sub> , XOR <sub>3</sub> |
| XOR <sub>6</sub>  | 7     | 9     | 63   | XOR <sub>3</sub> , XOR <sub>3</sub> |
| XOR <sub>7</sub>  | 11    | 10    | 110  | XOR3, XOR4                          |
| XOR <sub>8</sub>  | 11    | 11    | 121  | XOR4, XOR4                          |
| XOR <sub>9</sub>  | 15    | 13    | 195  | XOR4, XOR5                          |
| XOR <sub>10</sub> | 15    | 15    | 225  | XOR5                                |

Metot tümevarım yaklaşımını kullandığı için; her alt fonksiyon için yapılacak iyileştirme, daha büyük ölçekli fonksiyon tasarımların boyutlarının da küçülmesini sağlamaktadır. XOR4 fonksiyonun Şekil 7'deki tasarım ile gerçeklenmesi bu iyileştirmelerden biridir.

Tasarımlar için bir diğer iyileştirme XOR<sub>2</sub> fonksiyonunun karakteristik özelliği kullanılarak yapılmaktadır. Eğer tasarım bloklarında XOR<sub>2</sub> fonksiyonu kullanılıyorsa; bu blok ile bu bloğun komşusu olan blok arasına "sıfır" yerleştirilmesine gerek yoktur. Çünkü XOR<sub>2</sub> fonksiyonu iki değişkenden oluşan çarpım terimlerine sahiptir. Bu terim elemanlarının sütun üzerine ardışık olarak yazılmasıyla oluşabilecek istenmeyen yollar engellenmiş olmaktadır. Böylece XOR<sub>2</sub> kullanılan

tasarımların XOR<sub>2</sub>'nin kullanıldığı bölgelerinde birer sütun azalmış olmaktadır. Örneğin, XOR<sub>4</sub> fonksiyonu Tablo 2'de ifade edilen 5x5=25 yerine 5x4=20 boyutlu bir nano-dizin ile gerçeklenebilmektedir.

XOR<sub>1</sub>, XOR<sub>2</sub> ve XOR<sub>3</sub> alt fonksiyonlarının kullanıldığı Şekil 8'da ifade edilen yönteme Şekil 7'deki XOR<sub>4</sub> tasarımının ilave edilmesi ve XOR<sub>2</sub> fonksiyonun özel durumunun kullanılmasıyla tasarımların geliştirilmiş son halleri Tablo 3'de gösterilmiştir.

|                   | Alt<br>Fonksiyonlar                 | Satır | Sütun | Alan | Geleneksel<br>devrelerde<br>iki-uçlu<br>anahtar S. | Tablo 2'de<br>belirtilmiş<br>sonuçlar |
|-------------------|-------------------------------------|-------|-------|------|----------------------------------------------------|---------------------------------------|
| $XOR_1$           | XOR <sub>1</sub>                    | 1     | 1     | 1    | 1                                                  | 1                                     |
| XOR <sub>2</sub>  | XOR <sub>1</sub>                    | 2     | 2     | 4    | 4                                                  | 4                                     |
| XOR <sub>3</sub>  | XOR <sub>1</sub> , XOR <sub>2</sub> | 3     | 4     | 12   | 10                                                 | 12                                    |
| XOR <sub>4</sub>  | özel tasarım                        | 3     | 5     | 15   | 16                                                 | 25                                    |
| XOR <sub>5</sub>  | XOR <sub>1</sub> , XOR <sub>4</sub> | 4     | 10    | 40   | 28                                                 | 49                                    |
| XOR <sub>6</sub>  | XOR <sub>2</sub> , XOR <sub>4</sub> | 7     | 7     | 49   | 40                                                 | 63                                    |
| XOR <sub>7</sub>  | XOR <sub>3</sub> , XOR <sub>4</sub> | 7     | 10    | 70   | 52                                                 | 110                                   |
| XOR <sub>8</sub>  | XOR <sub>4</sub>                    | 7     | 11    | 77   | 64                                                 | 121                                   |
| XOR <sub>9</sub>  | XOR4, XOR5                          | 8     | 16    | 128  | 88                                                 | 195                                   |
| XOR <sub>10</sub> | XOR <sub>5</sub>                    | 9     | 21    | 189  | 112                                                | 225                                   |

*Tablo* 3: XOR<sub>1</sub>, XOR<sub>2</sub>, XOR<sub>3</sub> ve XOR<sub>4</sub> alt fonksiyonları ile gerçeklenen XOR fonksiyonlarının tasarım boyutları.

Tablo 3'de iki-uçlu anahtarlı geleneksel devre tasarımlarında gerekli olan anahtar sayıları da verilmiş ve bu anahtar sayıları ile elde edilen sonuçlar karşılaştırılmıştır. Bu karşılaştırımada geleneksel CMOS devre tasarımları, dört-uçlu anahtarlı nanodizin tasarımlarına göre daha az anahtar sayısına sahip olmalarına rağmen; daha büyük alanda gerçeklenmektedir. Dört-uçlu anahtarlar 5-20 nm boyutlarında olmalarına rağmen, CMOS transistörler tasarım kurallarıyla beraber 50-60 nm boyutlarına ulaşabilmektedirler [8-13]. Yapılan kaba bir hesapla aynı sayıda anahtar sayısına sahip olsalar bile; geleneksel devreler, nano-dizinlerden en az  $50^2/20^2 = 6,25$  kat daha fazla yer kaplamaktadır [9].

### 4. Sonuçlar ve Gelecek Çalışmalar

Bu çalışma diyot, CMOS ve dört-uçlu anahtar tabanlı olmak üzere üç farklı nano-dizin türü ile yapılmıştır. Verilen herhangi bir hedef fonksiyon için, her üç tür ile yapılacak sentez teknikleri ortaya çıkarılmıştır. Bu teknikler ile tasarlanan nano-dizinlerin boyut formülleri, ayrı ayrı üç tür için elde edilmiştir. Bu sayede verilen bir hedef fonksiyonu gerçekleyen nano-dizinin boyutu hesaplanabilir olmaktadır. Bu formüller kullanılarak yapılan tasarımların boyut karşılaştırmalarında dört-uçlu anahtar tabanlı nano-dizinler avantaj göstermişlerdir. Bu sebeple XOR fonksiyonlarının sentezi bu tür nano-dizinler ile yapılmıştır.

Literatürdeki dört-uçlu anahtarlı nano-dizinler ile XOR fonksiyonları için geliştirilmiş iki sentez tekniği incelenmiş ve yeni bir teknik geliştirilmiştir. Bu iki teknikten daha iyi sonuçlar veren bu teknik, XOR fonksiyonlarının karakteristiğinden yararlanılarak tümevarım yaklaşımıyla geliştirilmiştir. Bu teknik ile XOR4 fonksiyonu için elde edilen optimum tasarım, geleneksel CMOS anahtarlı devrelerde kullanılması gereken anahtar sayısından daha az anahtar sayısına sahiptir. Elde edilen sonuçlar tahmini olarak geleneksel devrelerle karşılaştırılmış ve her tasarım için dörtuçlu anahtarlı nano-dizinlerin daha küçük boyutlarda olduğu sonucuna varılmıştır.

XOR fonksiyonları sentezi üzerine yoğunlaşılmış bu çalışma da kullanılan tüme varım yaklaşımı, genel lojik fonksiyonlarına tatbik edilmesi ile, genişletilebilir. Yapılacak çalışmalarla literatürdeki tekniklerden daha iyi sonuç veren metotların bulunması öngörülmektedir.

Bu çalışma TÜBİTAK 2209/A projesi kapsamında desteklenmiş ve TÜBİTAK 3501 (Kariyer) projesi ile geniş kapsamlı olarak desteklenmeye devam etmektedir.

## 5. Kaynaklar

- Schaller, R. R., "Moore's law: past, present and future.", Spectrum, IEEE34.6 52-59 (1997).
- [2] Dubash, M., "Moore's Law is dead, says Gordon Moore", *Techworld. com*, 13 (2005).
- [3] Whitesides G. M. and Grzybowski B., "Self-assembly at all scales", *Science*, 295(5564):2418-2421, (2002).
- [4] Yan H., Park S. H., Finkelstein G., Reif J. H., and LaBean T. H., "DNA-templated self-assembly of protein arrays and highly conductive nanowires", *Science*, 301(5641):1882-1884, (2003).
- [5] Palmer, Jason, "Solar cells made through oil-and-water 'self-assembly", http://news.bbc.co.uk, Tuesday, 12 January 2010
- [6] Hong, I-.H., Liao, Y-.C. & Yen, S-.C. "Self-organization of a highly integrated silicon nanowire network on a Si(110)-16x2 surface by controlled domain growth." Adv. Funct. Mater. 19, 3389 (2009).
- [7] S. Wairya, R. K. Nagaria, and S. Tiwari, "Comparative performance analysis of XOR-XNOR function based high speed CMOS full adder circuits for low voltage VLSI design," International Journal of VLSI Design and Communication Systems, vol. 3, no. 2, pp. 221–242, 2012.
- [8] DeHon, A., "Array-based architecture for FET-based, nanoscale electronics", *Nanotechnology*, IEEE Transactions on, vol.2, no.1, pp.23,32, Mar 2003.
- [9] Greg Snider et al, "CMOS-like logic in defective, nanoscale crossbars", *Nanotechnology*, 15 881, June 2004.
- [10] Altun M. and Riedel, Marc D., "Logic Synthesis for Switching Lattices," IEEE Transactions on Computers, vol. 61, no. 11, pp. 1588-1600, Nov. 2012.
- [11] Y. Cui and C. M. Lieber, "Functional nanoscale electronic devices assembled using silicon nanowire building blocks," Science, vol. 291, no. 5505, pp. 851– 853, 2001.
- [12] Kang S-M, Leblebici Y. CMOS Digital Integrated Circuits Analysis & Design: Analysis and Design. 3rd ed. McGraw-Hill Professional, New York, 2002.
- [13] Clark, Robert D., "Emerging Applications for High K Materials in VLSI Technology." Materials 7, no. 4: 2913-2944.,2014