Tennessee State University

Digital Scholarship @ Tennessee State University
Computer Science Faculty Research

Department of Computer Science

2-9-2014

Nanosensor Data Processor in Quantum-Dot Cellular Automata
Fenghui Yao
Tennessee State University

Mohamed Saleh Zein-Sabatto
Tennessee State University

Guifeng Shao
Tennessee State University

Mohammad Bodruzzaman
Tennessee State University

Mohan Malkani
Tennessee State University

Follow this and additional works at: https://digitalscholarship.tnstate.edu/computerscience
Part of the Computer Engineering Commons, Computer Sciences Commons, and the Nanoscience
and Nanotechnology Commons

Recommended Citation
Fenghui Yao, Mohamed Saleh Zein-Sabatto, Guifeng Shao, Mohammad Bodruzzaman, Mohan Malkani,
"Nanosensor Data Processor in Quantum-Dot Cellular Automata", Journal of Nanotechnology, vol. 2014,
Article ID 259869, 14 pages, 2014. https://doi.org/10.1155/2014/259869

This Article is brought to you for free and open access by the Department of Computer Science at Digital
Scholarship @ Tennessee State University. It has been accepted for inclusion in Computer Science Faculty
Research by an authorized administrator of Digital Scholarship @ Tennessee State University. For more
information, please contact XGE@Tnstate.edu.

Hindawi Publishing Corporation
Journal of Nanotechnology
Volume 2014, Article ID 259869, 14 pages
http://dx.doi.org/10.1155/2014/259869

Research Article
Nanosensor Data Processor in Quantum-Dot Cellular Automata
Fenghui Yao,1 Mohamed Saleh Zein-Sabatto,2 Guifeng Shao,1
Mohammad Bodruzzaman,2 and Mohan Malkani2
1

Department of Computer Science, College of Engineering, Tennessee State University,
3500 John A Merritt Blvd, Nashville, TN 37209, USA
2
Department of Electrical and Computer Engineering, College of Engineering, Tennessee State University,
3500 John A Merritt Blvd, Nashville, TN 37209, USA
Correspondence should be addressed to Fenghui Yao; fyao@tnstate.edu
Received 7 August 2013; Accepted 14 December 2013; Published 9 February 2014
Academic Editor: Valery Khabashesku
Copyright © 2014 Fenghui Yao et al. This is an open access article distributed under the Creative Commons Attribution License,
which permits unrestricted use, distribution, and reproduction in any medium, provided the original work is properly cited.
Quantum-dot cellular automata (QCA) is an attractive nanotechnology with the potential alterative to CMOS technology. QCA
provides an interesting paradigm for faster speed, smaller size, and lower power consumption in comparison to transistor-based
technology, in both communication and computation. This paper describes the design of a 4-bit multifunction nanosensor data
processor (NSDP). The functions of NSDP contain (i) sending the preprocessed raw data to high-level processor, (ii) counting
the number of the active majority gates, and (iii) generating the approximate sigmoid function. The whole system is designed and
simulated with several different input data.

1. Introduction
Nanotechnology is a multidisciplinary field that brings
together many science and engineering disciplines including
physics, chemistry, biosciences, material science, computer
science, and electrical and mechanical engineering. Nanotechnology will radically affect all these disciplines and
their application areas. The economic impact is foreseen to
be comparable to information technology and telecommunication industries [1]. Nanotechnology has direct applications in sensing, sensor miniaturization, and new materials
development as well as in electronics and electromechanical
devices. Substantial advances in nanotechnology development have been achieved in the fields of engineering and
bioscience [2–4]. For example, integrating a large number
(496) of programmable FET nodes in a small area of about
960 𝜇m2 and programing them into a full adder, subtractor,
multiplexer, and demultiplexer has been reported. Work
reported in [3] demonstrated that a lateral integration of
700 rows of Z𝑛 O nanowires produces a peak voltage of
1.26 V at a low strain of 0.19%, which is potentially sufficient to recharge an AA battery. The nanosensor development described in [5], based on nanowires, is emerging as

a powerful and general class of ultrasensitive, electrical
sensors for the direct detection of biological and chemical
species, from proteins and DNA to drug molecules and
viruses down to the ultimate level of a single molecule. It also
shows that a nanosensor array that contains 100 addressable
elements provides unique opportunities for label-free multiplexed detection of biological and chemical species. The literature [6] provides an in-depth view of nanosensor technology
and electromagnetic communication among nanosensors.
With the integration of the technologies described in [3,
5, 6], that is, the integration of nanosensors, self-powered
nanodevices, and wireless nanosensors, many nanosensor
applications can be considered. These applications can be
classified into four groups: biomedical, environmental, industrial, and military applications. In biomedical applications,
health monitoring systems and drug delivery systems are
some of the examples. In environmental applications, plant
monitoring systems and plague defeating systems can be
given as examples. In industrial and consumer goods applications, the examples are ultrahigh sensitivity touch surfaces
and haptic interfaces. For military and defense applications,
examples are nuclear, biological, and chemical defenses and
damage detection systems.

2

Journal of Nanotechnology

In the above-mentioned applications, although the total
number of nanosensors used in each case depends on the
scale of the deployed devices, generally this number ranges
from 103 to 107 or higher. These application devices have the
following common characteristics.
(i) Simple Data. Each nanosensor delivers only simple
data. The processing of the data provided by each
individual nanosensor does not need complicated
operation.
(ii) Ambiguity. Because some of the nanosensors may
work at charging phase (self-powered) or the power
may be low, nanosensors may provide ambiguous
signals. The receiver (processing) side cannot obtain
accurate data at all times. Also, like any other communication system, the signal may fade because of
environment conditions and noise.
(iii) Massive Data. Nanosensing devices contain a large
number of nanosensors (103 –107 or higher) which
generate data continuously. The data from each
nanosensor may be primitive and ambiguous. However, massive amount of this type of data, if processed
correctly, delivers useful and meaningful information
from the device as a whole.
To analyze data from the nanosensing devices mentioned
above, classical computing and processing models, such
as loosely coupled distributed systems or tightly coupled
parallel systems, can be employed. However, in the classical
computing and processing models, the number of processors
is usually in the range of 101 –103 . This number of processors
can be increased, but it will bring tremendous increase of
cost and system dimensions. Each processing unit usually
has a local memory and can conduct complex operation
independently. Also, they consume large amounts of energy
(power) and heat dissipation becomes a critical issue. The
above-mentioned computing and processing models are not
suitable for processing data provided by nanosensors. The
computing and processing models for nanosensing should
meet the following three principles.
(i) Simplicity. The basic processing element (PE), that
is, the cell, is simple. PE does not need complicated
operations and does not need many instructions, as
those in the existing general-purpose CPUs. It only
needs a small number of operations because it will
function as a bridge between nanosensors and highlevel processors.
(ii) Parallelism. There will be a vast number of cells
operating in parallel. Hence, the processing must be
distributed.
(iii) Locality. All interactions take place on a purely local
basis. A cell can interact with a few other cells.
ITRS report [7] summarizes several possible technology solutions for nanosensor data processing. Quantum-dot
cellular automata (QCA) is an interesting possibility. Since
QCAs were introduced in 1993 [8], several experimental
devices have been developed [9–13]. Although they are

certainly “not ready for prime time,” recent papers show that
QCAs may eventually achieve high density [14], fast switching
speed [15], and room temperature operation [10, 16].
This paper describes the design of a PE for nanosensor data processing, named as nanosensor data processor
(NSDP), based on QCA. NSDP works as a bridge between
the nanosensors and high-level processor. Its functions are
limited to three: (i) sending the preprocessed raw data to
high-level processor, (ii) counting the number of the active
majority gates (the active means that the output of a majority
gate is 1), and (iii) generating the approximate sigmoid function for postprocessing based on artificial neural network.
This paper is organized as follows. Section 2 presents the
background of QCA focusing on its unique clocking scheme.
Section 3 shows the details design of NSDP. Simulation results
are shown in Section 4. Conclusions and future works are
given in Section 5.

2. QCA Background
2.1. QCA Cells and Wires. A QCA cell is a square nanostructure with a quantum dot in each of the four corners [17], as
shown schematically in Figure 1. The cell is populated with
two electrons that can tunnel between two pairs of quantum
dots connected via a tunnel junction. The two electrons
occupy antipodal sites within the cell due to Coulombic
repulsion. Tunneling action only occurs within the cell
and no tunneling happens between cells. The combination
of quantum confinement, Coulombic repulsion, and the
discrete electronic charge produces bistable behavior. The two
charge configurations can be used to represent binary “0” and
“1” with polarization of −1 and +1, respectively. In contrast to
a physical wire, a QCA “wire” is a chain of cells where the cells
are adjacent to each other, as shown in Figure 1(b). Since no
electrons tunnel between cells, QCA provides a mechanism
for transferring information without current flow.
2.2. QCA Logic Gates. In QCA, three-input majority gates
and inverters serve as the fundamental gates. A majority gate,
as shown in Figure 2(a), consists of five QCA cells that realize
the function of 𝑀(𝑎, 𝑏, 𝑐) = 𝑎𝑏+𝑏𝑐+𝑎𝑐. An inverter, as shown
in Figure 2(b), is made by positioning cells diagonally from
each other to achieve the inversion functionality. Figures 2(c)
and 2(d) show the variation layouts of an inverter. Majority
gates and inverters form a universal set; that is, any logic
function can be implemented by using this set. For example,
a two-input AND gate is realized by fixing one of the majority
gate inputs to “0,” that is, AND(𝑎, 𝑏) = 𝑀(𝑎, 𝑏, 0) = 𝑎𝑏.
Similarly, an OR gate is realized by fixing one input to “1,” that
is, OR(𝑎, 𝑏) = 𝑀(𝑎, 𝑏, 1) = 𝑎𝑏 + 𝑏 ⋅ 1 + 𝑎 ⋅ 1 = 𝑎 + 𝑏.
2.3. QCA Clocking Scheme. Adiabatic switching is used for
QCA clocking, which significantly reduces metastability
issues and enables deep pipelines [18]. During each clock
cycle, half of the wire is active for signal propagation, while
the other half is unpolarized. During the next clock cycle,
half of the previous active clock zone is deactivated and the
remaining active zone cells trigger the newly activated cells to

Journal of Nanotechnology
Quantum dot

3
Electron

Tunnel
junction

Tunnel
junction
Polarization = 1
(binary 1)

Polarization = −1
(binary 0)

(a)

(b)

Figure 1: Basic QCA cell and wire.
Input a
Output
M

Output

Input x

Input b

F

Input c
a
b
c

M

x

F

(a)

(b)

Input x

Input x

Output F

Output F

(c)

(d)

Figure 2: (a) Majority gate and its symbol; (b) inverter and its symbol; (c) and (d) variation layout of an inverter.

2.4. QCA Design Rules. A nominal cell size of 20 nm by 20 nm
is assumed. The cell has a width and height of 18- and 5-nmdiameter quantum dots. The cells are placed on a grid with a
cell center-to-center distance of 20 nm. QCA design rules are
well studied in [19–21] and are summarized in the following.
(A) Layout Design Rules
(1) Maximum Number of Cells in a Single Clocking Zone.
It can be as large as 47 cells; the maximum length of
QCA wire is 25 cells. Any long QCA wire exceeding
the length of 25 needs to be partitioned into different
clocking zones.

Sw
itc
h
Hold

se
lea
Re

Relax

Clock signal

be polarized. Thus, signals propagate from one clock zone to
the next. The circuit area is divided into four sections and they
are driven by four phase clock signals, as shown in Figure 3.
In each zone, the clock signal has four states: high-to-low, low,
low-to-high, and high. The cell begins computing during the
high-to-low state and holds the value during the low state. The
cell is released when the clock is in the low-to-high state and
inactive during the high state.

Clock
zone 0
Clock
zone 1
Clock
zone 2
Clock
zone 3

Time

Figure 3: QCA clocking scheme.

(2) Minimum Number of Cells in a Single Clocking Zone. It
can be one cell. However, the waveform of a one-cell
clocking zone can become distorted and cascading
of this kind of clocking zone could lead to incorrect

4

Journal of Nanotechnology
results [22]. To observe correct outputs from a circuit,
it is recommended that clocking zones should consist
of at least two cells.
(3) Minimum Wire Spacing for Signal Separation. A space
of one QCA cell size is sufficient separation between
two wires carrying different signals.
(4) Wire Crossover. A unique property of QCA layout is
the possibility of implementing crossovers by using
only one layer, known as coplanar crossing. Coplanar
crossing uses both 45∘ and 90∘ cells. However, they
can easily fail due to low robustness [23] and fabrication issues [24]. Another alternative is multilayer
crossing, which uses more than one layer of cells
similar to the routing of metal wires in CMOS
technology. The extra layers of QCA are believed to
be useful as active components of the circuits and
consume less area compared to coplanar circuits [23].
(5) QCA Equivalent 𝜆-Rule. “𝜆-rule” for QCA circuit
design could be defined according to the size of a
QCA cell, or perhaps the cell size itself could be used
as the equivalent 𝜆.

(B) Timing Design Rules
(1) Logic Component Timing Rule. The timing constraint
on a QCA majority gate is that all three inputs are
expected to reach the device cell (central cell) at the
same time in order to have fair voting.
(2) Clocking Zone Assignment Rule. In QCA circuits, cells
in each clocking zones should be synchronized.
(C) Special Rules for QCA
(1) Majority Logic Reduction. The logic primitive used in
QCA is the majority gate. The majority logic-based
reduction method [25] can significantly reduce the
complexity of QCA circuits.
(2) Systolic Design. The features of systolic architecture
in terms of synchrony, deep pipelines, and local
interconnection are particularly suitable for accommodating the special timing requirement in QCA
circuits. When applying systolic architecture to QCA,
significant benefits can be achieved, even more than
when applied to CMOS-based technology [26].
In the design of NSDP, the second rule (i.e., Minimum
number of cells in a single clocking zone) in layout design
is applied in the following way. For the fixed-value input,
such as fixing one input of a majority gate to “−1.00” (binary
0) to make it an AND gate, it uses one-cell clocking zone.
Or for the limited space, it uses one-cell clocking zone,
but no cascading. For the 4th rule (i.e., wire crossover), it
employs the multilayer crossing technique. The following
section shows the details design of NSDP.

3. NSDP Architecture
NSDP is a processor that works as a bridge between
nanosensors and the high-level processor. Its functions are

(i) sending the preprocessed raw data to high-level processor,
(ii) counting the number of the active majority gates, and
(iii) generating the approximate sigmoid function. Among
these functions, the last one is the focus of NSDP because
it provides the sigmoid function output for the high-level
processor to conduct the processing based on the artificial
neural network (ANN). The block diagram of NSDP is shown
in Figure 4. The detail of each block is explained below.
3.1. Preprocessing. Considering that a large number of nanosensors will generate a great amount of “0” or “1” data,
and some nanosensors may generate ambiguous data, the
first processing in NSDP computer is the majority operation
that determines which one (“0” or “1”) takes the majority.
Generally, the number of the inputs of this unit can be any
number. The larger the number of the inputs is, the better the
majority operation is. However, considering the capability of
the available QCA design tool, QCADesigner, the number
of the inputs in NSDP is set at 12. This processing unit
consists of four majority gates, and it has 12 inputs and 4
outputs. Figure 5(a) shows the schematic, Figure 5(b) shows
the QCA layout, and Figure 5(c) shows the simulation result
by QCADesigner, respectively. The output of this unit is given
by
𝑚0 = 𝑀 (𝑎0 , 𝑏0 , 𝑐0 ) ,
𝑚1 = 𝑀 (𝑎1 , 𝑏1 , 𝑐1 ) ,
𝑚2 = 𝑀 (𝑎2 , 𝑏2 , 𝑐2 ) ,

(1)

𝑚3 = 𝑀 (𝑎3 , 𝑏3 , 𝑐3 ) .
As shown in Figure 5(c), for the input 𝑎0 𝑏0 𝑐0 = {000,
001, 010, 001, 100, 101, 110, 111}, 𝑎1 𝑏1 𝑐1 = {000, 100, 110, 101,
100, 011, 010, 011}, 𝑎2 𝑏2 𝑐2 = {000, 111, 110, 101, 100, 011, 010,
001}, and 𝑎3 𝑏3 𝑐3 = {000, 001, 010, 011, 100, 101, 110, 111}, the
output 𝑚0 = {0, 0, 0, 0, 0, 1, 1, 1}, 𝑚1 = {0, 0, 1, 1, 0, 1, 0, 1},
𝑚2 = {0, 1, 1, 1, 0, 1, 0, 0}, 𝑚3 = {0, 0, 0, 1, 0, 1, 1, 1}, respectively, and the delay is 3/4 clock.
3.2. Counter. The output of the preprocessing unit is separated into two, one goes to M-Latch and the other goes to the
input of the counter. This unit is to count “1” in the output
of the preprocessing unit. To count “1” from 4 parallel bits
of the output of the preprocessing unit, it employs three full
adders, as shown in Figure 6(a). QCA full adder has been well
studied. Some representative QCA adders are [19, 27–31]. The
QCA carry flow adder reported in [19] is a layout optimized
multilayer full adder. In QCA, the path from carry-in to
carry-out uses one majority gate that requires one clocking
zone per bit in a ripple carry adder. This adder (referred to as
Cho adder in this paper) consumes only one clocking zone
delay per bit, which significantly reduces the delay for large
adders. Three Cho adders are employed to implement the
counter. The QCA layout is shown in Figure 6(b), and the
simulation result shown in Figure 6(c). The output is given
by
𝑠2 𝑠1 𝑠0 = 𝑚3 + 𝑚2 + 𝑚1 + 𝑚0 .

(2)

Journal of Nanotechnology

5
Function control: c1 c0
Input:
a0 b0 c0 a1 b1 c1 a2 b2 c2 a3 b3 c3
Function control

Preprocessing

M-latch

Counter

S-latch

Decoder

G-latch

Output

o3 o2 o1 o0

Sigmoid pattern
generator

Figure 4: Block diagram of NSDP.

As shown in Figure 6(c), for the input 𝑚0 = {0, 0, 0, 1,
0, 1, 1, 1}, 𝑚1 = {0, 1, 1, 1, 0, 1, 0, 0}, 𝑚2 = {0, 1, 1, 1, 0, 1, 0, 0},
𝑚3 = {0, 0, 0, 1, 0, 1, 1, 1}, the output 𝑠2 𝑠1 𝑠0 = {0, 2, 2, 4, 0,
4, 2, 2}. The delay is 2 clocks. Note that the “+” operator here
means arithmetic addition. In the following, “+” means logic
OR operation if there is no specific notation.
3.3. Decoder. The decoder unit and the sigmoid pattern
generator unit are used to approximate the sigmoid function
𝑦 = 1/(1 + 𝑒−𝑥 ). As shown in Table 1, NSDP employs 4 points
to approximate the sigmoid function. This is 3-to-4 decoder;
the inputs are 𝑠2 , 𝑠1 , and 𝑠0 , and the outputs are 𝑓4 , 𝑓3 , 𝑓2 , and
𝑓1 . The output 𝑓1 corresponds to that 𝑠2 𝑠1 𝑠0 is equal to 0 or 1;
that is, it corresponds to that 𝑚3 𝑚2 𝑚1 𝑚0 equals to 1000, 0100,
0010, 0001, or 0000. It is worth to note that the position of “1”
does not matter. For the four inputs, 𝑚3 , 𝑚2 , 𝑚1 , and 𝑚0 , of
the counter, 𝑚3 does not mean the most significant bit and
𝑚0 does not mean the least significant bit because the twelve
input sensors can only be considered “fired” or “not fired” and
the majority gate can be numbered in any order. This is the
same here and after. Likewise, the output 𝑓2 corresponds to
that 𝑠2 𝑠1 𝑠0 which is equal to 2, that is, it corresponds to that
𝑚3 𝑚2 𝑚1 𝑚0 which is equal to 1100, 0110, 0011, 1010, 0101, or
1001. The output 𝑓3 corresponds to that 𝑠2 𝑠1 𝑠0 , is equal to 3,
that is, it corresponds to that 𝑚3 𝑚2 𝑚1 𝑚0 which is equal to
1110, or 0111. The output 𝑓4 corresponds to that 𝑠2 𝑠1 𝑠0 is equal
to 4; that is, it corresponds to that 𝑚3 𝑚2 𝑚1 𝑚0 equals to 1111.
The outputs 𝑓4 , 𝑓3 , 𝑓2 , and 𝑓1 are given by

𝑓3 = 𝑠2 𝑠1 𝑠0 ,

𝑠2 𝑠1 𝑠0
The number of “1” is less than or equal to 1
(the position does not matter).
The number of “1” is equal to 2
(the position does not matter).
The number of “1” is equal to 3
(the position does not matter).
The number of “1” is equal to 4.

(3)

𝑓4 = 𝑠2 𝑠1 𝑠0 .
Figure 7(a) shows the schematic of this 3-to-4 decoder.
Figure 7(b) shows the QCA layout, and Figure 7(c) shows the
simulation result. As shown in Figure 7(c), when the input
𝑠2 𝑠1 𝑠0 (sum) is equal 0, 1, 2, 4, 0, 3, 1, and 2, the output

Output:
𝑓4 𝑓3 𝑓2 𝑓1

Sigmoid
function
pattern

0001

0000

0010

0011

0100

1101

1000

1111

𝑓4 𝑓3 𝑓2 𝑓1 will be equal to 0001, 0001, 0010, 1000, 0001, 0100,
0001, and 0010, respectively, and the delay is one clock.
3.4. Pattern Generator. The output of the decoder is used to
generate four patterns, 1111, 1101, 0011, and 0000, as listed in
the third column in Table 1, which are used to approximate
the sigmoid function. These four patterns are generated in the
following way:
𝑓4𝑎 = 𝑓4 ⋅ 1,
𝑓4𝑏 = 𝑓4 ⋅ 1,
𝑓4𝑐 = 𝑓4 ⋅ 1,
𝑓4𝑑 = 𝑓4 ⋅ 1,

𝑓1 = 𝑠2 𝑠1 ,
𝑓2 = 𝑠2 𝑠1 𝑠0 ,

Table 1: Decoding of the output of the counter.

𝑓3𝑎 = 𝑓3 ⋅ 1,
𝑓3𝑏 = 𝑓3 ⋅ 1,
𝑓3𝑐 = 𝑓3 ⋅ 0,
𝑓3𝑑 = 𝑓3 ⋅ 1,
𝑓2𝑎 = 𝑓2 ⋅ 0,
𝑓2𝑏 = 𝑓2 ⋅ 0,

6

Journal of Nanotechnology

c3 b3 a3

c2 b2 a2

c1 b1 a1

c0 b0 a0

c b a

c b a

c b a

c b a

M

M

M

M

m3

m2

m1

m0

(a)

(b)

(c)

Figure 5: Preprocessing. (a) Schematic; (b) QCA layout; (c) simulation result.

𝑓2𝑐 = 𝑓2 ⋅ 1,
𝑓2𝑑 = 𝑓2 ⋅ 1,
𝑓1𝑎 = 𝑓1 ⋅ 0,
𝑓1𝑏 = 𝑓1 ⋅ 0,
𝑓1𝑐 = 𝑓1 ⋅ 0,
𝑓1𝑑 = 𝑓1 ⋅ 0.
(4)
The schematics for 𝑓4𝑎 𝑓4𝑏 𝑓4𝑐 𝑓4𝑑 , 𝑓3𝑎 𝑓3𝑏 𝑓3𝑐 𝑓3𝑑 , 𝑓2𝑎 𝑓2𝑏 𝑓2𝑐 𝑓2𝑑
and 𝑓1𝑎 𝑓1𝑏 𝑓1𝑐 𝑓1𝑑 are shown in Figure 8(a). The QCA layout

for 𝑓4𝑎 𝑓4𝑏 𝑓4𝑐 𝑓4𝑑 is shown in Figure 8(b). The layout for
𝑓3𝑎 𝑓3𝑏 𝑓3𝑐 𝑓3𝑑 , 𝑓2𝑎 𝑓2𝑏 𝑓2𝑐 𝑓2𝑑 and 𝑓1𝑎 𝑓1𝑏 𝑓1𝑐 𝑓1𝑑 is similar to the
one in Figure 8(b), except that the pattern to be generated
is 1101, 0011, and 0000, respectively. The simulation result is
shown in Figure 8(c). When the input 𝑠2 𝑠1 𝑠0 (sum) is equal
to 0, 1, 2, 4, 0, and 3, the generated pattern is 0000 (0) and
0000 (0) for 𝑓1𝑎 𝑓1𝑏 𝑓1𝑐 𝑓1𝑑 , 0011 (3) for 𝑓2𝑎 𝑓2𝑏 𝑓2𝑐 𝑓2𝑑 , 1111 (15)
for 𝑓4𝑎 𝑓4𝑏 𝑓4𝑐 𝑓4𝑑 , 0000 (0) for 𝑓1𝑎 𝑓1𝑏 𝑓1𝑐 𝑓1𝑑 , and 1101 (13)
for 𝑓3𝑎 𝑓3𝑏 𝑓3𝑐 𝑓3𝑑 , respectively. The delay is 3/4 clock. Note
that the delay for 𝑓2𝑎 𝑓2𝑏 𝑓2𝑐 𝑓2𝑑 and 𝑓1𝑎 𝑓1𝑏 𝑓1𝑐 𝑓1𝑑 is one clock
longer than of 𝑓4𝑎 𝑓4𝑏 𝑓4𝑐 𝑓4𝑑 and 𝑓3𝑎 𝑓3𝑏 𝑓3𝑐 𝑓3𝑑 . This is because
that the input for 𝑓2𝑎 𝑓2𝑏 𝑓2𝑐 𝑓2𝑑 and 𝑓1𝑎 𝑓1𝑏 𝑓1𝑐 𝑓1𝑑 is delayed by
one clock.

Journal of Nanotechnology

7

m3

m2

a

b

m1

m0

Sum

Cout Full Cin
adder

0
a

a

b

0

Sum

Sum

s2

b

Cout Full Cin
adder

Cout Full Cin
adder

s1

s0
(a)

(b)

(c)

Figure 6: Counter. (a) Schematic; (b) QCA layout; (c) simulation result.

(5)

changed to 𝑓4𝑐 , 𝑓3𝑐 , 𝑓2𝑐 , 𝑓1𝑐 , 𝑔1 , 𝑓4𝑏 , 𝑓3𝑏 , 𝑓2𝑏 , 𝑓1𝑏 , 𝑔2 and 𝑓4𝑎 ,
𝑓3𝑎 , 𝑓2𝑎 , 𝑓1𝑎 , 𝑔3 , correspondingly. The simulation result is
shown in Figure 9(c). When the input 𝑠2 𝑠1 𝑠0 (sum) is equal to
0, 1, 2, 4, 0, and 3, the output 𝑔3 𝑔2 𝑔1 𝑔0 is 0000 (0), 0000 (0),
0011 (3), 1111 (15), 0000 (0), and 1101 (13), correspondingly.
The delay from the output of the counter to the output of
the sigmoid function is 2(3/4) clocks. Figure 10 shows the
graph of the approximated sigmoid function, generated by
the decoder and pattern generator unit described above.

The schematics for 𝑔𝑖 (𝑖 = 0, 1, 2, and 3) are shown in
Figure 9(a). The QCA layout for 𝑔0 are shown in Figure 9(b). This layout is also for other outputs 𝑔𝑖 (𝑖 =
1, 2, and 3), except that the inputs and output will be

3.6. Function Control. NSDP is a multifunction nanosensor
data processor. The function selection of NSDP is determined
by the function control unit, which is a 2-to-3 decoder. The
truth table of the function control unit is shown in Table 2.
When control bus 𝑐1 𝑐0 is equal to 00, the output of NSDP
is the raw majority gate output, that is, 𝑚3 𝑚2 𝑚1 𝑚0 from 4

3.5. Sigmoid Function Output. The output of the sigmoid function is one of the four patterns, 𝑓4𝑎 𝑓4𝑏 𝑓4𝑐 𝑓4𝑑 ,
𝑓3𝑎 𝑓3𝑏 𝑓3𝑐 𝑓3𝑑 , 𝑓2𝑎 𝑓2𝑏 𝑓2𝑐 𝑓2𝑑 , and 𝑓1𝑎 𝑓1𝑏 𝑓1𝑐 𝑓1𝑑 , depending on
the number of 1’s of the counter. Therefore, the output
𝑔3 𝑔2 𝑔1 𝑔0 of the sigmoid function can be written as
𝑔3 = 𝑓4𝑎 + 𝑓3𝑎 +𝑓2𝑎 + 𝑓1𝑎 ,
𝑔2 = 𝑓4𝑏 + 𝑓3𝑏 +𝑓2𝑏 + 𝑓1𝑏 ,
𝑔1 = 𝑓4𝑐 + 𝑓3𝑐 +𝑓2𝑐 + 𝑓1𝑐 ,
𝑔0 = 𝑓4𝑑 + 𝑓3𝑑 +𝑓2𝑑 + 𝑓1𝑑 .

8

Journal of Nanotechnology
s0 s1 s2

f3

f2

f1

f0

(a)

(b)

(c)

Figure 7: 3-to-4 Decoder. (a) Schematic; (b) QCA layout; (c) simulation result.

independent majority gates. The bit position does not matter;
that is, 𝑚3 does not mean MSB and 𝑚0 does not mean LSB.
When control bus 𝑐1 𝑐0 is equal to 01, the output of NSDP is
the number of 1s of the majority gate output, given by 0𝑠2 𝑠1 𝑠0 .
Note that here 𝑠0 is LSB and MSB is always 0. When control
bus is 𝑐1 𝑐0 equal to 10, the output of NSDP is the sigmoid
function output. The output of the function control unit is
given by

Table 2: Truth table for function control unit.
𝑐1 𝑐0
00
01
10
11

Output of NSDP
Majority of raw sensor data, 𝑚3 𝑚2 𝑚1 𝑚0
Number of active outputs (i.e., 1s), 0𝑠2 𝑠1 𝑠0
Sigmoid output, 𝑔3 𝑔2 𝑔1 𝑔0
Reserved

𝑠00 = 𝑐1 𝑐0 ,
𝑠01 = 𝑐1 𝑐0 ,

(6)

𝑠10 = 𝑐1 𝑐0 .
The schematic of the function control unit is shown in
Figure 11(a), the QCA layout is shown in Figure 11(b), and the
simulation result is shown in Figure 11(c). When input 𝑐1 𝑐0 is
equal to 00, 01, and 10, the output 𝑠10 𝑠01 𝑠00 is equal to 001, 010,

and 001, respectively. The delay from the input to output is 1
clock.

3.7. NSDP Output. The function control unit of NSDP determines which output of the three function units (raw majority
data, the number of the active majority gates, and sigmoid

Journal of Nanotechnology
f4

9
f3

f4a

f3a
1

1
f4a

f3a
1

1
f4c

f3c

1

0
f4d

f3d

1
f2

1
f1

f2a
0

f1a
0

f2a

f1a

0

0
f2c

f1c

1

0
f2d

f1d

1

0
(a)

(b)

(c)

Figure 8: Pattern generator. (a) Schematic for 1111, 1101, 0011, and 0000 generators; (b) QCA layout for 1111 generator (this QCA layout can
generate other patterns by changing the standard pattern to 1101, 0011, or 0000); (c) simulation result for 1111 (15), 1101 (13), 0011 (3), and 0000
(0) generators.

function) will be the output 𝑜3 𝑜2 𝑜1 𝑜0 of NSDP. 𝑜3 𝑜2 𝑜1 𝑜0 is
given by
𝑜3 = 𝑚3 𝑠00 + 0 ⋅ 𝑠01 + 𝑔3 𝑠10 ,
𝑜2 = 𝑚2 𝑠00 + 𝑠2 ⋅ 𝑠01 + 𝑔2 𝑠10 ,
𝑜1 = 𝑚1 𝑠00 + 𝑠1 ⋅ 𝑠01 + 𝑔1 𝑠10 ,

(7)

respectively, which are not shown in Figure 12(b) (refer to
Figure 13 for details).
The complete QCA layout of NSDP is shown in Figure 13.
NSDP consists of the following units: preprocessing, counter,
3-to-4 decoder, pattern generator, sigmoid function output,
function control, M-latch, S-latch, G-latch, and NSDP output.
Each unit is surrounded by a red dotted line in Figure 13. The
complete experiment results are given in the next section.

𝑜0 = 𝑚0 𝑠00 + 𝑠0 ⋅ 𝑠01 + 𝑔0 𝑠10 .
The schematic of NSDP output unit is shown in Figure 12(a), and the partial QCA layout of 𝑜0 in is shown
Figure 12(b). Note that 𝑚0𝑎 , 𝑠0𝑎 , and 𝑔0𝑎 are the outputs of
M-latch, S-latch, and G-latch for the inputs 𝑚0 , 𝑠0 , and 𝑔0 ,

4. Results
NSDP is designed and simulated by using QCADesigner Ver.
2.0.3. NSDP contains 4436 cells. Its dimension is 3𝜇m ×
2.3 𝜇m (6.9 𝜇m2 ). The simulation employs the coherence

10

Journal of Nanotechnology
f4d
f3d
f2d
f1d

g0

f4c
f3c
f2c
f1c

g1

f4b
f3b
f2b
f1b

g2

f4a
f3a
f2a
f1a

g3

(a)

(b)

(c)

Figure 9: Output of sigmoid function. (a) Schematic for the output of the sigmoid function; (b) QCA layout for 𝑔0 of the sigmoid function
(this QCA layout is applicable to 𝑔1 , 𝑔2 , and 𝑔3 by changing to the corresponding input); (c) simulation result of the sigmoid function output.

The majority output on 𝑀 bus (𝑚3 𝑚2 𝑚1 𝑚0 ) is equal to
1111 (15), 0000 (0), 1110 (14), 1000 (8), 1001 (9), . . .. When 𝑐1 𝑐0
is equal to 00, 𝑠00 becomes 1, and 𝑠01 and 𝑠10 both become
0. NSDP picks the data on 𝑀 bus as the final output. This is
shown in 6th row, in Figure 15; that is, Output (𝑜3 𝑜2 𝑜1 𝑜0 ) is
equal to 1111 (15), 0000 (0), 1110 (14), 1000 (8), 1001 (9), . . ., in
accompany with the clocked 𝑠00 .

16

14
12
10
8
6
4
2
0

−2

−1

1

2

Figure 10: Approximate sigmoid function generated by NSDP.

vector engine. Figure 14 shows the parameter setting for
coherence vector simulation engine.
4.1. Raw Majority Data Output (𝑐1 𝑐0 = 00). In this mode,
the data flow path is Preprocessing → M-Latch → NSDP
Output (refer to Figure 13 for details).
As shown in Figure 15, 12 inputs are grouped into 4
groups: Input 3 (𝑎3 𝑏3 𝑐3 ), Input 2 (𝑎2 𝑏2 𝑐2 ), Input 1 (𝑎1 𝑏1 𝑐1 ), and
Input 0 (𝑎0 𝑏0 𝑐0 ). The input data are as follows:
Input 3: 011 (3), 100 (4), 101 (5), 110 (6), 111 (7), . . .
Input 2: 101 (5), 100 (4), 011 (3), 010 (2), 001 (1),. . .
Input 1: 101 (5), 100 (4), 011 (3), 010 (2), 001 (1), . . .
Input 0: 011 (3), 100 (4), 001 (1), 010 (2), 110 (6), . . .

4.2. Counter Output (𝑐1 𝑐0 = 01). In this mode, the data flow
path is Preprocessing → Counter → S-Latch → NSDP
Output (refer to Figure 13 for details).
As shown in Figure 16, the input data are as follows:
Input 3: 000 (0), 001 (1), 010 (2), 011 (3), 100 (4), 101
(5), 110 (6), 111 (7), . . .
Input 2: 000 (0), 111 (7), 110 (6), 101 (5), 100 (4), 011 (3),
010 (2), 001 (1), . . .
Input 1: 000 (0), 100 (4), 110 (6), 101 (5), 100 (4), 011 (3),
010 (2), 001 (1), . . .
Input 0: 000 (0), 001 (1), 010 (2), 011 (3), 100 (4), 001
(1), 010 (2), 110 (6), . . .
The counter output on sum bus (𝑠2 𝑠1 𝑠0 ) is equal to 000 (0),
001 (1), 010 (2), 100 (4), 000 (0), 011 (3), 001 (1), 010 (2), . . ..
When 𝑐1 𝑐0 is equal to 01, 𝑠01 becomes 1, and 𝑠00 and 𝑠10 both
become 0. NSDP picks the data on 𝑆 bus and extends to 4
bits by padding leftmost bit with 0, as the final output. This is
shown in 6th row, in Figure 16; that is, the Output (𝑜3 𝑜2 𝑜1 𝑜0 )

Journal of Nanotechnology

11

c1 c0
s00

s01

s10

(a)

(b)

c1 c0 = 01

c1 c0 = 00

c1 c0 = 10

(c)

Figure 11: Function control unit. (a) Schematic; (b) QCA layout; (c) Simulation result for 𝑐1 𝑐0 = 00, 𝑐1 𝑐0 = 01, and 𝑐1 𝑐0 = 10.

s10
g0

g1
G-latch

o0

g2

g3

s00

s01
s0

s1

s2

0

m0

S-latch

o1

m1

m2

m3

M-latch

o2

(a)

o3
(b)

Figure 12: NSDP output. (a) Schematic; (b) Partial QCA layout for 𝑜0 .

is equal to 0000 (0), 0001 (1), 0010 (2), 0100 (4), 0000 (0), 0011
(3), 0001 (1), 0010 (2), . . ., in accompany with the clocked 𝑠01 .
4.3. Sigmoid Function Output (𝑐1 𝑐0 = 10). In this mode,
the data flow path is Preprocessing → Counter → 3-to-4
Decoder, → Pattern Generator → Sigmoid Function Output
→ G-Latch → NSDP Output (refer to Figure 13 for details).
As shown in Figure 17, the input data are as follows:

Input 3: 000 (0), 001 (1), 010 (2), 011 (3), 100 (4), 101
(5), 110 (6), 111 (7), . . .
Input 2: 000 (0), 111 (7), 110 (6), 101 (5), 100 (4), 011 (3),
010 (2), 001 (1), . . .
Input 1: 000 (0), 100 (4), 110 (6), 101 (5), 100 (4), 011 (3),
010 (2), 001 (1), . . .
Input 0: 000 (0), 001 (1), 010 (2), 011 (3), 100 (4), 001
(1), 010 (2), 110 (6), . . .

12

Journal of Nanotechnology

Function control

Preprocessing

NSDP
output
G-latch

M-latch
S-latch

Counter

Sigmoid function output

3-to-4 decoder

Pattern generator

Figure 13: Complete QCA layout of NSDP.

Figure 15: Simulation result for 𝑐1 𝑐0 = 00.

Figure 14: Parameters for coherence vector engine.

The counter output on sum bus (𝑠2 𝑠1 𝑠0 ) is equal to 000 (0),
001 (1), 010 (2), 100 (4), 000 (0), 011 (3), 001 (1), 010 (2), . . ., as
shown in 5th row, in Figure 17. The sigmoid function converts
these inputs to 0000 (0), 0000 (0), 0011 (3), 1111 (15), 0000 (0),
1101 (13), 0000 (0), 0000 (0), . . ., and outputs on the Sigmoid
bus, as shown in 6th row. When 𝑐1 𝑐0 is equal to 10, 𝑠10 becomes
1, and 𝑠00 and 𝑠01 both become 0. NSDP picks the data on the

Figure 16: Simulation result for 𝑐1 𝑐0 = 01.

sigmoid bus as the final output. This is shown in 7th row, in
Figure 17; that is, the Output (𝑜3 𝑜2 𝑜1 𝑜0 ) is equals to 0000 (0),
0000 (0), 0011 (3), 1111 (15), 0000 (0), 1101 (13), 0000 (0), 0000
(0), . . ., in accompany with the clocked 𝑠10 .

Journal of Nanotechnology

13

Acknowledgments
This work is partially supported by a Grant from AFRL under
Minority Leaders Program, Contract no. TENN13-S567-01902-C2. The authors would like to thank the anonymous
reviewers for their careful review and valuable comments.

References

Figure 17: Simulation result for 𝑐1 𝑐0 = 10.

In above experiments, the processing in sigmoid function
is the most complicated and the delay from input to the
output is the longest. For the raw majority data output and
the counter output, the delay is inserted to make them
synchronize with the output of the sigmoid function output.
Therefore, the delay of NSDP from the Input 3 (𝑎3 𝑏3 𝑐3 ), Input
2 (𝑎2 𝑏2 𝑐2 ), Input 1 (𝑎1 𝑏1 𝑐1 ), and Input 0 (𝑎0 𝑏0 𝑐0 ) to the Output
(𝑜3 𝑜2 𝑜1 𝑜0 ) is 8(3/4) clocks.

5. Conclusions and Future Works
This paper presents the design of a 4-bit nanosensor data
processor (NSDP) which has 3 functions: (i) sending the
result of 4 majority gates to high-level processor; (ii) counting
the number of active majority gates (i.e., the output of the
majority gate is 1); (iii) generating the approximate sigmoid
function for the postprocessing based on the artificial neural
network. QCA circuits have significant wire delays. For a
fast design in QCA, it is generally necessary to minimize
the complexity. The design uses systolic array structures to
produce an output on every clock cycle with low latency to
the first output. The layouts and functionality checks were
done using QCADesigner. NSDP is a relatively complicated
system. The simulation results show that its three functions
work correctly. It is hoped that this paper will inspire further
ideas on developing application systems based on QCA
circuits.
As mentioned in Section 1, the nanosensor system generates a large number of nanosensor data. This type of
system needs 103 –107 PEs to process the real-time data. NSDP
described in this paper works as a PE. A large number of PEs
(103 –107 ) need to be arranged in a parallel and distributed
manner to handle the huge amount of nanosensor data.
NSDP is a 4-bit processor. It will be more convenient to
handle large amount of nanosensor data, by extending it to
a 8-bit processor. All these are our future works.

Conflict of Interests
The authors declare that there is no conflict of interests
regarding the publication of this paper.

[1] V. Ermolov, M. Heino, A. Kärkkäinen et al., “Significance of
nanotechnology for future wireless devices and communications,” in Proceedings of the 18th Annual IEEE International Symposium on Personal, Indoor and Mobile Radio Communications
(PIMRC ’07), Athens, Greece, September 2007.
[2] J. N. Anker, W. P. Hall, O. Lyandres, N. C. Shah, J. Zhao, and R. P.
Van Duyne, “Biosensing with plasmonic nanosensors,” Nature
Materials, vol. 7, no. 6, pp. 442–453, 2008.
[3] S. Xu, Y. Qin, C. Xu, Y. Wei, R. Yang, and Z. L. Wang, “Selfpowered nanowire devices,” Nature Nanotechnology, vol. 5, no.
5, pp. 366–373, 2010.
[4] H. Yan, H. S. Choe, S. Nam et al., “Programmable nanowire
circuits for nanoprocessors,” Nature, vol. 470, no. 7333, pp. 240–
244, 2011.
[5] F. Patolsky and C. M. Lieber, “Nanowire nanosensors,” Materials
Today, vol. 8, no. 4, pp. 20–28, 2005.
[6] I. F. Akyildiz and J. M. Jornet, “Electromagnetic wireless
nanosensor networks,” Nano Communication Networks, vol. 1,
no. 1, pp. 3–19, 2010.
[7] International Technology Roadmap for Semiconductors
(ITRS), 2007, http://www.itrs.net/.
[8] C. S. Lent, P. D. Tougaw, W. Porod, and G. H. Bernstein,
“Quantum cellular automata,” Nanotechnology, vol. 4, no. 1, pp.
49–57, 1993.
[9] I. Amlani, A. O. Orlov, R. K. Kummamuru, G. H. Bernstein,
C. S. Lent, and G. L. Snider, “Experimental demonstration of
a leadless quantum-dot cellular automata cell,” Applied Physics
Letters, vol. 77, no. 5, pp. 738–740, 2000.
[10] R. P. Cowburn and M. E. Welland, “Room temperature magnetic quantum cellular automata,” Science, vol. 287, no. 5457, pp.
1466–1468, 2000.
[11] R. K. Kummamuru, A. O. Orlov, R. Ramasubramaniam, C.
S. Lent, G. H. Bernstein, and G. L. Snider, “Operation of
a quantum-dot cellular automata (QCA) shift register and
analysis of errors,” IEEE Transactions on Electron Devices, vol.
50, no. 9, pp. 1906–1913, 2003.
[12] A. O. Orlov, I. Amlani, G. Toth, C. S. Lent, G. H. Bernstein, and
G. L. Snider, “Experimental demonstration of a binary wire for
quantum-dot cellular automata,” Applied Physics Letters, vol. 74,
no. 19, pp. 2875–2877, 1999.
[13] H. Qi, S. Sharma, Z. Li et al., “Molecular quantum cellular
automata cells. Electric field driven switching of a silicon surface
bound array of vertically oriented two-dot molecular quantum
cellular automata,” Journal of the American Chemical Society,
vol. 125, no. 49, pp. 15250–15259, 2003.
[14] A. DeHon and M. J. Wilson, “Nanowire-based sublithographic
programmable logic arrays,” in Proceedings of the ACM/SIGDA
12th ACM International Symposium on Field-Programmable
Gate Arrays (FPGA ’04), pp. 123–132, February 2004.
[15] J. M. Seminario, P. A. Derosa, L. E. Cordova, and B. H.
Bozard, “A molecular device operating at terahertz frequencies:
theoretical simulations,” IEEE Transactions on Nanotechnology,
vol. 3, no. 1, pp. 215–218, 2004.

14
[16] Y. Wang and M. Lieberman, “Thermodynamic behavior of
molecular-scale quantum-dot cellular automata (QCA) wires
and logic devices,” IEEE Transactions on Nanotechnology, vol.
3, no. 3, pp. 368–376, 2004.
[17] A. O. Orlov, I. Amlani, G. H. Bernstein, C. S. Lent, and G. L.
Snider, “Realization of a functional cell for quantum-dot cellular
automata,” Science, vol. 277, no. 5328, pp. 928–930, 1997.
[18] C. S. Lent and P. D. Tougaw, “A device architecture for computing with quantum dots,” Proceedings of the IEEE, vol. 85, no. 4,
pp. 541–557, 1997.
[19] H. Cho and E. E. Swartzlander Jr., “Adder and multiplier
design in quantum-dot cellular automata,” IEEE Transactions on
Computers, vol. 58, no. 6, pp. 721–727, 2009.
[20] W. Liu, L. Lu, M. O’Neill, and E. E. Swartzlander, “Design rules
for quantum-dot cellular automata,” in Proceedings of the IEEE
International Symposium of Circuits and Systems (ISCAS ’11), pp.
2361–2364, May 2011.
[21] W. Liu, L. Lu, M. Orneill, E. E. Swartzlander Jr., and R. Woods,
“Design of quantum-dot cellular automata circuits using cut-set
retiming,” IEEE Transactions on Nanotechnology, vol. 10, no. 5,
pp. 1150–1160, 2011.
[22] K. Kim, K. Wu, and R. Karri, “Towards designing robust
QCA architectures in the presence of sneak noise paths,” in
Proceedings of the Design, Automation and Test in Europe (DATE
’05), vol. 2, pp. 1214–1219, March 2005.
[23] K. Walus and G. A. Jullien, “Design tools for an emerging SoC
technology: quantum-dot cellular automata,” Proceedings of the
IEEE, vol. 94, no. 6, pp. 1225–1243, 2006.
[24] M. Crocker, M. Niemier, X. S. Hu, and M. Lieberman, “Molecular QCA design with chemically reasonable constraints,” ACM
Journal on Emerging Technologies in Computing Systems, vol. 4,
no. 2, article 9, 2008.
[25] R. Zhang, K. Walus, W. Wang, and G. A. Jullien, “A method
of majority logic reduction for quantum cellular automata,”
IEEE Transactions on Nanotechnology, vol. 3, no. 4, pp. 443–450,
2004.
[26] L. Lu, W. Liu, M. O’Neill, and E. E. Swartzlander Jr., “QCA
systolic matrix multiplier,” in Proceedings of the IEEE Computer
Society Annual Symposium on VLSI (ISVLSI ’10), pp. 149–154,
July 2010.
[27] I. Hanninen and J. Takala, “Robust adders based on quantumdot cellular automata,” in Proceedings of the IEEE International
Conference on Application-Specific Systems, Architecture Processors, pp. 391–396, 2007.
[28] V. Pudi and K. Sridharan, “Low complexity design of ripple
carry and brent-kung adders in QCA,” IEEE Transactions on
Nanotechnology, vol. 11, no. 1, pp. 105–119, 2012.
[29] P. D. Tougaw and C. S. Lent, “Logical devices implemented
using quantum cellular automata,” Journal of Applied Physics,
vol. 75, no. 3, pp. 1818–1825, 1994.
[30] W. Wang, K. Walus, and G. Jullien, “Quantum-dot cellular
automata adders,” in Proceedings of the 3rd IEEE International
Conference on Nanotechnology, pp. 461–464, 2003.
[31] R. Zhang, K. Walus, W. Wang, and G. A. Jullien, “Performance
comparison of quantum-dot cellular automata adders,” in Proceedings of the IEEE International Symposium on Circuits and
Systems (ISCAS ’05), pp. 2522–2526, May 2005.

Journal of Nanotechnology

Journal of

Nanotechnology
Hindawi Publishing Corporation
http://www.hindawi.com

Volume 2014

International Journal of

International Journal of

Corrosion
Hindawi Publishing Corporation
http://www.hindawi.com

Polymer Science
Volume 2014

Hindawi Publishing Corporation
http://www.hindawi.com

Volume 2014

Smart Materials
Research
Hindawi Publishing Corporation
http://www.hindawi.com

Journal of

Composites
Volume 2014

Hindawi Publishing Corporation
http://www.hindawi.com

Volume 2014

Journal of

Metallurgy

BioMed
Research International
Hindawi Publishing Corporation
http://www.hindawi.com

Volume 2014

Nanomaterials

Hindawi Publishing Corporation
http://www.hindawi.com

Volume 2014

Submit your manuscripts at
http://www.hindawi.com
Journal of

Materials
Hindawi Publishing Corporation
http://www.hindawi.com

Volume 2014

Journal of

Nanoparticles
Hindawi Publishing Corporation
http://www.hindawi.com

Volume 2014

Nanomaterials
Journal of

Advances in

Materials Science and Engineering
Hindawi Publishing Corporation
http://www.hindawi.com

Volume 2014

Journal of

Hindawi Publishing Corporation
http://www.hindawi.com

Volume 2014

Journal of

Nanoscience
Hindawi Publishing Corporation
http://www.hindawi.com

Scientifica

Hindawi Publishing Corporation
http://www.hindawi.com

Volume 2014

Journal of

Coatings
Volume 2014

Hindawi Publishing Corporation
http://www.hindawi.com

Crystallography
Volume 2014

Hindawi Publishing Corporation
http://www.hindawi.com

Volume 2014

The Scientific
World Journal
Hindawi Publishing Corporation
http://www.hindawi.com

Volume 2014

Hindawi Publishing Corporation
http://www.hindawi.com

Volume 2014

Journal of

Journal of

Textiles

Ceramics
Hindawi Publishing Corporation
http://www.hindawi.com

International Journal of

Biomaterials

Volume 2014

Hindawi Publishing Corporation
http://www.hindawi.com

Volume 2014

