Decoding Nanowire Arrays Fabricated with the Multi-Spacer Patterning Technique by Jamaa, Ben et al.
Decoding Nanowire Arrays
Fabricated with the Multi-Spacer Patterning Technique
M. Haykel Ben Jamaa, Yusuf Leblebici and Giovanni De Micheli
Swiss Federal Institute of Technology (EPFL)
1015 Lausanne, Switzerland
haykel.benjamaa@epfl.ch
ABSTRACT
Silicon nanowires are a promising solution to address the increas-
ing challenges of fabrication and design at the future nodes of the
Complementary Metal-Oxide-Semiconductor (CMOS) Technology
roadmap. Despite the attractive opportunity that offers their orga-
nization onto regular crossbars, the problem of designing the nano-
wire decoder is still challenging and highly dependent on the na-
nowire fabrication technology. In this paper, we introduce a novel
design style and encoding scheme for decoding nanowires fabri-
cated with the Multi-Spacer-Patterning Technique (MSPT); and we
present a method based on Gray codes that reduces the fabrica-
tion cost and improves the decoder reliability. We show that by
arranging the code in a Gray code fashion, we decrease the fabri-
cation complexity by 17% and the variability by 18% on average.
By optimizing the decoder parameters, the simulations showed an
improvement of the crossbar yield by 40% and a reduction of the
effective bit area by 51% to 169 nm2.
Categories and Subject Descriptors
B.8.1 [Performance and Reliability]: Reliability, Testing, and
Fault-Tolerance
General Terms
Design
Keywords
Emerging Technologies, Nanowires, Decoder, Crossbar, Spacer
Technique, MSPT
1. INTRODUCTION
Despite the large efforts spent to develop novel solutions in or-
der to reach the future nodes of the technology roadmap, several
hurdles are still challenging the evolution of the semiconductor
industry. A major issue is the high variability of nanoscale de-
vices, which needs innovative defect tolerance methods at all de-
sign levels. In order to go beyond the 22 nm milestone, alternative
devices to bulk Metal-Oxide-Semiconductor Field Effect Transis-
tor (MOSFET) are currently being investigated, and their design
1This work is supported by the CCMX/MMNS project, the CSI
Center and the Swiss FNS Research Grant 200021-109450/1
Permission to make digital or hard copies of all or part of this work for
personal or classroom use is granted without fee provided that copies are
not made or distributed for profit or commercial advantage and that copies
bear this notice and the full citation on the first page. To copy otherwise, to
republish, to post on servers or to redistribute to lists, requires prior specific
permission and/or a fee.
DAC 2009, July 26 - 31, 2009, San Francisco, California, USA.
Copyright 2009 ACM ACM 978-1-60558-497-3-6/08/0006 ...$10.00.
methodologies are being optimized. Such devices include quasi
one-dimensional silicon nanowires [9, 15]. A promising approach
to integrate them is the crossbar architecture [10].
Crossbar circuits are formed by two perpendicular layers of par-
allel nanowires. At the crossing areas, specific materials are de-
posited or grafted in order to functionalize the circuit [10]. A ma-
jor issue has been reported with the integration of crossbar circuits,
consisting in interfacing them with a decoder to the outer Com-
plementary Metal-Oxide-Semiconductor (CMOS) circuit, which is
defined on a much larger pitch [6]. Several types of decoders
have been suggested [6, 13, 1, 8]. They are strongly dependent
on the nanowire fabrication technology, and some of them bridge
the sublitho- to litho-scales in a stochastic way. One of the na-
nowire fabrication techniques is the Multi-Spacer Patterning Tech-
nique (MSPT), which has many advantages in terms of density and
compatibility with standard CMOS processing [4]. However, no
specific design style for the decoder of MSPT-based nanowires has
been proposed so far. And the impact on yield of the encoding
scheme, i.e., the code used to identify the nanowires, is not known.
In this paper, we propose a novel design style for decoders of
MSPT-based nanowire arrays. The first novelty of this design style
is that it is the first specific decoder for this fabrication technol-
ogy that uniquely addresses every nanowire. The second novelty
is that it assigns a deterministic address to every nanowire, unlike
other decoders [6, 8]. Furthermore, we suggest an innovative de-
sign method based on Gray codes, which reduces the fabrication
complexity and improves the fault-tolerance of the decoder.
This paper is organized as follows. The next section surveys dif-
ferent nanowire fabrication technologies and circuits, the decoder
design and the nanowire codes. Section 3 presents the MSPT that is
currently being studied through experimentation, and the decoder
design style that we are suggesting. Section 4 formulates the prob-
lem of the decoder design in an abstract way. In Section 5 we de-
rive the optimal code types with respect to different optimization
criteria. Section 6 presents the simulation platform and results for
nanowire decoders with different encoding schemes. We finally
conclude the paper in Section 7.
2. BACKGROUND
This section surveys nanowire fabrication techniques reported in
literature. Then, it explains the baseline architecture of nanowire
crossbars and highlights the decoder part. Finally, it introduces the
code types that will be used in the rest of the paper.
2.1 Fabrication Technologies
Silicon nanowires are quasi one-dimensional long structures fab-
ricated on a sub-lithographic scale; the lithographic (or meso-)
scale being the one defined by the photolithography used to convert
the circuit design into physical masks. Many techniques were re-
cently shown to be promising ways to fabricate silicon nanowires.
We can distinguish between bottom-up and top-down techniques.
Bottom-up techniques are based on the growth of nanowires on a
silicon substrate from catalyst seeds. The as-grown nanowires are
then collected in a solution and dispersed on the substrate to be
functionalized [9, 15]. Top-down approaches define the nanowires
Decoder
CrosspointsMesowires
Nanowires
Contact Group
Mesowire
VT2VT1 Nanowire
VA1 VA2 VA3 VA4
Nanowire
a) b)
c)
Figure 1: Baseline architecture of a crossbar circuit (a) and
highlights of the decoder layout (b) and circuit (c)
directly on the functional substrate by accurately controlling the de-
position, oxidation and etching rates [12, 4], or by using nanometer-
scale molds [11].
Because of the small dimensions of these devices and the dif-
ficulty of placing them accurately, a high variability is expected
with respect to the electrical properties of the fabricated circuits.
Consequently, a general tendency is in favor of a regular arrange-
ment of these devices in a crossbar architecture where the device
placement is easier and the redundancy is higher. Since the nano-
wires cannot perform computation or information storage, the use
of other emerging materials has been proposed to enhance the de-
vice functionality. For instance, molecular switches [10] or phase
change materials [16] whose on- and off-states can be electrically
controlled may be inserted between two layers of crossing nanowi-
res in order to functionalize the circuit.
2.2 Nanowire Circuits and Decoders
The baseline organization of a nanowire crossbar circuit is de-
picted in Fig 1.a. An arrangement of two orthogonal layers of par-
allel nanowires defines a regular grid of intersections called cross-
points. The separation between the two layers can be filled with
a phase change material or molecular switches at the crosspoints.
Information storage, interconnection or computation can be per-
formed with these crosspoints [10, 5]. A set of contact groups is
defined on top of the nanowires. Every contact group makes an
ohmic contact to a corresponding distinct set of nanowires, which
represents the smallest set of nanowires that can be contacted by
the lithographically defined lines (mesowires).
This configuration bridges every set of nanowires within a con-
tact group to the outer CMOS circuit. In order to fully bridge
the scales and make every nanowire within this set uniquely ad-
dressable by the outer circuit, a decoder is needed. It is formed
by a series of transistors along the nanowire body, controlled
by the mesowires and having different threshold voltages VT [2]
(Fig. 1.b). The distributions of VT’s is called the nanowire pattern.
Depending on this pattern and the pattern of applied voltages in the
decoder (VA’s), one single nanowire in the array can be made con-
ductive (Fig. 1.c). In this case, this nanowire is said to be addressed
by the applied voltage pattern.
Many decoders have been suggested for nanowire arrays. Their
design strongly depends on the nanowire fabrication technology.
Axial and radial decoders were suggested for in-situ patterned
nanowires [6, 13]. Mask-based decoder [1] and random-contact
decoders [8] were proposed for nanowires fabricated with nano-
imprint. For other bottom-up fabrication techniques, a gate-all-
around decoder was suggested in [12].
2.3 Code Types
We will consider in this paper hot codes (HC), tree codes (TC),
Gray codes (GC) and balanced Gray codes (BGC). More details
about these codes can be found in [2, 7, 3]. In the following, we
remind the reader of their basic concepts. A code space means the
set of all code words of a given code.
HCs are defined for the multi-valued logic n with the parameters
(M,k) ∈  2 such that M = k · n. Every code word has M
digits, such that every digit takes the value ∈ {0, . . . , n − 1} and
every value exists in the code word exactly k times. For instance,
the code words 001122 and 012120 belong to the same HC space
with (M,k) = (6, 2) and n = 3; but 000121 does not belong to
this code space because the values 0 and 2 are not repeated exactly
k= 2 times.
TCs are defined by the parameter M ∈   for the multi-valued
logic n. Every code is represented by M digits such that every digit
takes the value in ∈ {0, . . . , n − 1}. For instance, for n = 3 and
M = 4, we obtain the codes: 0000, 0001, 0002, 0010,. . . ,2222. In
order to address nanowires with TCs, it was shown that the codes
have to be reflected [2], i.e., every code word gets its complemen-
tary code word appended to it. The complement is obtained by
subtracting the code word from the largest code word in the same
code space. For instance, the complement of 0010 in this example
is 2222 − 0010 = 2212. Then, 2212 is appended to 0010, giv-
ing the reflected code word 00102212. In a similar way, 0000 and
0001 give 00002222 and 00012221 respectively. In the rest of the
paper, all TCs are implicitly considered to be reflected.
GCs are an arrangement of TCs where successive code words
differ in only one digit. For instance, the sequence of code words
0000 ⇒ 0001 ⇒ 0002 ⇒ 0010 does not belong to the GC be-
cause the last two code words differ in two digits. But the sequence
0000 ⇒ 0001 ⇒ 0002 ⇒ 0012 is eligible.
BGCs are a type of GCs with an additional constraint that ev-
ery digit is allowed to change at most a given number of times.
In the BGCs considered in this paper, the limit on number of
changes is set to 2 [3]. In the previously presented GC sequence
0000 ⇒ 0001 ⇒ 0002 ⇒ 0012, the first and second digits (from
the left) do not change, the third digit changes once and the last
digit changes twice. Thus, this sequence fulfills the conditions of a
BGCs with a limit set to 2.
GCs and BGCs are special arrangements of code words in TC
spaces. So, GCs and BGCs will be used implicitly in the reflected
form by appending their complement, as explained previously for
reflected TCs.
3. FABRICATION AND DESIGN OPPOR-
TUNITIES OF NANOWIRE DECODERS
In this section we present the nanowire array fabrication tech-
nology that we are currently experimentally investigating. Then,
we introduce the decoder fabrication method and we focus on the
decoder design opportunities and challenges.
3.1 The Multi-Spacer Patterning Technique
In order to fabricate nanowire arrays with a pitch independent on
the photolithography limit, we are currently using the Multi-Spacer
Patterning Technique (MSPT), which is a CMOS-compatible fabri-
cation technique using only standard CMOS steps. It yields large
arrays of parallel poly-crystalline Silicon (poly-Si) spacers sepa-
rated by silicon dioxide (SiO2) as insulator. The essential fabri-
cation steps are illustrated in Fig. 2 and were described in detail
elsewhere [4]. The processing starts with the definition of caves
limited by a sacrificial layer. Then, by a series of conformal depo-
sition of thin poly-Si and SiO2 layers and their anisotropic etching
iteratively, it is possible to obtain parallel poly-Si spacers separated
by SiO2 spacers. The technique yields a symmetrical structure with
a symmetry axis parallel to the edge of the sacrificial layer.
With the 0.8 μm photolithography available for academic re-
search purposes in our fabrication facilities, we could obtain dense
arrays of poly-Si spacers with a sub-lithographic pitch. These spac-
ers represent nanowires having a pitch of a few tens of nanometer,
a height of ∼ 300 nm and a length of tens of microns. Since the
height does not influence the pitch, it was kept as it is; but it can
be shrunk by applying the standard chemical and mechanical pla-
narization technique if needed. A Scanning Electron Microscopy
(SEM) of a cross-section of the obtained nanowire arrays is pre-
sented in Fig. 3. The nanowire pitch exclusively depends on the
thickness of deposited poly-Si and on the etch, but not on the lithog-
raphy resolution. The technique yields reliable and reproducible
results. It is not intended to compete with bottom-up nanowire
fabrication techniques, but it represents a CMOS-compatible and
Conformal layer
Sacrificial layer
Cave
Substrate
Spacers
Multi-spacers
Mesowires Via (metal 1)
1.
3.
5.
2.
4.
6.
Figure 2: Cave cross-section illustrating the multi-spacer pat-
terning technique. Cave definition (1), conformal poly-Si de-
position (2), anisotropic poly-Si etch (3), iteration of 2-3 with
poly-Si and SiO2 (4), gate patterning (5), metallization (6)
cost-efficient technique (possible parallelization of spacer defini-
tion steps) with an opportunity to investigate the combined design
and fabrication aspects of nanowire decoders.
a) b) poly-Si/SiO2sacrificial layer
cave
300 nm
SiO2
sacr.
layer
poly-Si
cave
Figure 3: Scanning Electron Microscopy (SEM) of a nanowire
array cross-section (a), and a 3-dimensional representation of
the full structure (b).
3.2 The Decoder Fabrication Technique
While a pattern can be easily defined during the growth of na-
nowires in a bottom-up process (Sec. 2.1), it is more difficult to
define it with top-down processes. For instance, the MSPT, yields
a regular array of undifferentiated nanowires if the bare procedure
depicted in Fig. 2 is applied. Once the array is defined on a sub-
lithographic scale, it is difficult to pattern it with standard pho-
tolithographic means, unless expensive high-resolution and time-
costly methods, such as electron-beam lithography, are applied.
Consequently, it is desirable to pattern the nanowires while they
are defined: i.e., whenever a new spacer is defined, it has to be
patterned before the next spacer is defined.
1.
2.
CaveSpacers
Sacrificial layer
Photoresist
Implantation
Doped regions: 2ND
3.
4.
Cross-section Top-View
Doped regions: ND
Undoped regions: 0
poly-Si nanowire
SiO2 nanowire
Doped regions
Figure 4: Decoder-aware enhanced fabrication flow: Definition
of first poly-Si nanowire (1), photolithography and doping of
first poly-Si nanowire (2), photolithography and doping of sec-
ond poly-Si nanowire (3), final doping patterns (4).
The fabrication flow that includes the decoder is illustrated in
Fig. 4 and should be understood as an extension inserted between
steps 3 and 4 in Fig. 2. The other steps remain unchanged. The
additional steps are lithography patterning and doping after every
spacer definition step, using p-type (n-type) doping to increase (de-
crease) the total doping level. Specific regions from every poly-Si
nanowire are defined and doped in this way. Nanowires are fragile
and thin structures, and they should be doped carefully with light
doses. The total doping level of a specific region is the sum of
all (positive and negative) doping levels accumulated in this region
throughout the definition of the whole array, as illustrated in step 4
of Fig. 4. An optimized choice of the lithography/doping sequences
and the doping doses may result in the desired nanowire pattern.
3.3 Design of the Decoder
The decoder fabrication technique introduced in the previous
section yields a decoder operation identical to the description in
Sec. 2.2. However, the layout differs in the fact the the nanowi-
res lie within parallel caves having a symmetry axis going through
their central axis (Sec. 3.1). The unique addressing of every nano-
wire in a half cave insures the unique addressing of every nanowire
in the whole array. We will therefore consider only half caves in
the rest of the paper.
Every half cave contains N nanowires having M doping re-
gions each. Recall that the pattern is the sequence of threshold
voltages and the doping profile is the sequence of dopant con-
centrations along the doping regions of the nanowire. Let Pi =ˆ
P 0i . . . P
M−1
i
˜
andDi =
ˆ
D0i . . . D
M−1
i
˜
be the pattern and dop-
ing profile of the nanowire i respectively. For the considered tech-
nique, whenever a nanowire i is patterned by receiving a doping
dose, all nanowires k = 0, . . . , i− 1 receive the same doping dose
simultaneously. Consequently, the doping profile of a nanowire i
depends not only on its own doping dose but also on all doping
doses received by the nanowires k = i + 1, . . . ,M − 1. We there-
fore need to determine the analytical multivariable application that
links P ji and D
j
i for i = 0, . . . , N − 1 and j = 0, . . . ,M − 1, in
order to specify whether we can find a set of doping profiles that
results in a given set of patterns.
Assuming that a set of doping profiles exists for any set of pat-
terns, it is possible to optimize the choice of patterns according to
different cost functions. We consider first the impact of this de-
coding technique on the fabrication cost. The nanowire profile im-
plies a certain number of lithography/doping steps per nanowire,
φi for i = 0, . . . , N − 1. From the fabrication point of view, it
is of the highest importance to reduce the total number of lithog-
raphy/doping steps, i.e.
P
φi. We therefore need to establish the
link between P ji and φi in order to minimize
P
φi.
Then, we consider the impact of this decoding technique on the
circuit yield by analyzing the variability of the decoder. Every dop-
ing region j of the nanowire i, referred to as region (i, j), receives
successive doping doses bit by bit. With every additional doping
dose, the variability of region (i, j), quantified as the standard de-
viation of the threshold voltage of this region Σji , accordingly in-
creases. It is therefore desirable to establish the link between P ji
and Σji and to optimize the choice of the patterns in order to mini-
mize the variability.
In the following section, we will derive the analytical mapping
between patterns and doping profiles. Then, we will define the cost
functions related to the fabrication complexity and to the thresh-
old voltage variability. These cost functions will be minimized by
choosing the best code type for the decoder.
4. PROBLEM FORMULATION OF MSPT-
BASED NANOWIRE DECODER
In this section we provide an abstract description of the decoder
part of the nanowire array in a single half cave. The defined matri-
ces describe the most relevant design and fabrication aspects. Using
these definitions, we will derive the cost functions of the fabrica-
tion complexity and the circuit variability. Further, we assume a
multi-valued logic addressing with n values.
Definition 1. The pattern matrix P is an N × M matrix in
{0, . . . , n − 1}N×M representing the patterns of N nanowires
within a half cave, where every nanowire has M doping regions.
We assume that the N nanowires within every half cave are
patterned and have M doping regions each. The pattern corre-
sponds to a set of M VT’s having any one of the n possible values
VT(0), . . . , VT(n−1). The patterns are represented by the discrete
values 0, . . . , n−1, which correspond to the ordered discretization
of the threshold voltages VT(0), . . . , VT(n − 1). Consequently,
the set of patterns on the N nanowires forming one half cave can
be represented by an N×M-matrix in {0, . . . , n− 1}N×M.
Definition 2. The final doping matrix D is an N × M matrix
in N×M representing the doping level distribution along the N
nanowires within a half cave after the definition of the whole array.
Every VT needs a unique doping level ND fixed by the device
physics and geometry [14]. Consequently, the pattern matrix, that
is uniquely mapped onto a set of VT’s, defines a unique final doping
matrix.
Example 1. For n = 3, N = 3 and M = 4, we assume that
VT can have the values 0.1 V, 0.3 V and 0.5 V corresponding to the
digits 0, 1 and 2 and to the doping levels 2, 4 and 9 ×1018 cm−3.
The patterns are represented with the first N code words of the
n-ary tree code. WithV the matrix covering all VT’s, we obtain:
P =
"0 1 2 1
0 2 2 0
1 0 1 2
#
V =
"1 3 5 3
1 5 5 1
3 1 3 5
#
· 0.1 V D =
"2 4 9 4
2 9 9 2
4 2 4 9
#
·
1018
cm3
PROPOSITION 1. A non-linear bijective application h maps P
ontoD as follows: Dji = h(P ji ) ∀ i, j
PROOF. The mapping between digits of the patterns and VT is a
discrete ordering, which is a bijective application g. The mapping
between VT’s and ND’s is a monotonic non-linear function f, which
is also a a bijection. The interested reader is invited to look into [14]
to obtain the exact expression of f. Since h is a composition of f and
g, it is bijective as well.
Definition 3. The step doping matrix S is an N × M matrix in

N×M representing the additional doping levels after every lithog-
raphy/doping step.
There is a lithography/doping procedure that follows the def-
inition of every one of the N nanowires. Every procedure
i = 0, . . . , n − 1 is characterized by M doping levelsˆ
N0D,i, . . . , N
M−1
D,i
˜
along the M doping regions of the nanowi-
res. The set of M doping levels in the N steps can be represented
by the matrix S inN×M.
PROPOSITION 2. A multi-linear application maps the elements
of S onto those ofD as follows: Dji =
N−1P
k=i
Sjk
PROOF. Every nanowire j that is defined, is subsequently pat-
terned by means of doping doses
ˆ
S0j , . . . , S
M−1
j
˜
. Any nanowire
i defined before the nanowire j (i < j) receives the same dose si-
multaneously. Thus, the doping level of the nanowire i is the sum
of all the levels defined in the steps i, . . . , N − 1 following the
definition of the nanowire i.
Example 2. The following step and final doping matrices verify
the property stated in Proposition 2. Negative and positive doping
levels correspond to the doses with n- and p-type dopants respec-
tively:
D =
"
2 4 9 4
2 9 9 2
4 2 4 9
#
·
1018
cm3
S =
"
0 −5 0 2
−2 7 5 −7
4 2 4 9
#
·
1018
cm3
Definition 4. The technology complexity is quantified by Φ rep-
resenting the total number of additional lithography/doping steps
needed to pattern the nanowires.
Every row in S (Si =
ˆ
S0i . . . S
M−1
i
˜
, i = 0, . . . , N − 1) repre-
sents the doping doses used in a single step doping procedure. The
number of unequal non-zero elements in Si represents the num-
ber of different doses used at this doping step. The more doping
doses, the more lithography steps are needed and the more com-
plex is the fabrication. Let φi (i = 0, . . . , N − 1) be the number of
unequal non-zero elements in Si, then the total number of lithogra-
phy/doping steps is Φ =
P
i φi.
Example 3. For S given in Example 2, we have: φ1 = 2, φ2 =
4 and φ3 = 3. Then, Φ = 9 holds.
Definition 5. The decoder variability is quantified by a N ×M
matrix Σ, describing the standard deviation of the threshold volt-
ages in every doping region in the decoder of a half cave.
Every doping operation yields a VT with a given variability σT,
measured as the standard deviation. In the proposed technique ev-
ery doping region is doped at most N times (Proposition 2). We
expect the variability to increase with increasing number of doping
operations. The number of times a doping regions (i, j) receives
a doping dose decreases with increasing i and increasing number
of zero-elements in the column j of S. Let νji be this number,
then νji =
P
k=i...N−1
(1 − δ(Sjk)), where δ(x) is the Kronecker
delta function: δ(x) = 1 ⇔ x = 0, otherwise δ(x) = 0. Dop-
ing operations are assumed to be stochastically independent. The
addition of two independent stochastic variables with standard de-
viations σ1 and σ2 respectively yields a stochastic variable with the
standard deviation σ0 =
p
σ21 + σ
2
2 . Therefore, if we define Σ as
the N ×M-matrix describing the variability of the decoder by set-
ting Σji to the square of the standard deviation of the doping region
(i, j), we obtain: Σji = σ
2
T · νji .
Example 4. For S given in Example 2, we have:
S =
"
0 −5 0 2
−2 7 5 −7
4 2 4 9
#
·
1018
cm3
Σ =
"
2 3 2 3
2 2 2 2
1 1 1 1
#
· σ2T
PROPOSITION 3. Optimizing the decoder fabrication complex-
ity consists in finding the best pattern P that minimizes Φ. Opti-
mizing the decoder reliability consists in finding the best pattern P
that minimizes ‖Σ‖1, where ‖Σ‖1 is the sum of all elements of Σ,
known as its entrywise 1-norm.
PROOF. This follows directly from Def. 4 and 5.
5. OPTIMIZING NANOWIRE CODES
In Sec. 2.3 we reviewed the code types that we are considering
to uniquely address the nanowires in any logic with n values: hot
codes, tree codes and the arrangement of the tree code words called
Gray codes and arranged Gray codes. The last 3 code types are
used implicitly in a reflected form. The length of the whole code
word–including the reflected part–is M .
In the following, we will prove that the Gray code is the optimal
arrangement of the tree code with respect to the defined cost func-
tions. Then, we will investigate the opportunity of arranging the
hot codes in a similar fashion to Gray codes in order to optimize
the costs of the decoders designed with hot codes.
5.1 The Gray Code
PROPOSITION 4. Among all arrangements of tree codes, the
Gray code minimizes the decoder cost in terms of variability ‖Σ‖1.
PROOF. For i = N−1, SjN−1 = DjN−1 = h−1(P jN−1) is fixed
by the pattern of the last nanowire, i.e. by P jN−1. Thus, ν
j
N−1 =
1 − δ(SjN−1) = 1, because SjN−1 = 0 ∀ j, since every region
receives a doping dose in order to define the pattern of VT’s of the
last nanowire P jN−1. For i = N − 1, νji − νji+1 = 1 − δ(Sji ) =
1− δ(Dji −Dji+1). This difference is 1 if Dji = Dji+1, i.e. P ji =
P ji+1, and 0 if P
j
i = P
j
i+1. Then, ν
j
i can only increase by steps
of 1 or remain constant with decreasing i for a fixed j. It remains
unchanged if and only if the pattern P ji remains unchanged.
Consequently, ‖Σ‖1 monotonically increases with increasing
transitions in the pattern matrix P between every two successive
rows. Given that the rows of P are the code words in the cho-
sen code space, it is desirable to use the code that minimizes the
number of transitions between successive code words in order to
minimize ‖Σ‖1. This condition is fulfilled by the Gray code.
Example 5. Instead of P given in Example 1, which includes a
tree code sequence with the cost ‖Σ‖1 = 22·σ2T (from Example 4),
we use a sequence from the Gray code that avoids the forbidden
transition in P 0220⇒1012. Then we obtain ‖Σ‖1 = 18 · σ2T:
P =
"
0 1 2 1
0 2 2 0
1 2 1 0
#
S =
"
0 −5 0 2
−2 0 5 0
4 9 4 2
#
·
1018
cm3
Σ =
"
2 2 2 2
2 1 2 1
1 1 1 1
#
· σ2T
PROPOSITION 5. Among all arrangements of tree codes, the
Gray code minimizes the fabrication cost Φ.
PROOF. In a similar way to the proof of Proposition 4, we notice
that the value of Sji is unequal to zero if there is a transition P
j
i ⇒
P ji+1 between two successive code words inP at the digit j. Then,
any φi, and consequently Φ, increase with the number of transitions
in P. Since the Gray code minimizes the number of transitions,
then it is optimal with respect to Φ.
Example 6. The Gray code in Example 1 has a fabrication cost
Φ = 9 (Example 3). By using the Gray code in Example 5, the
fabrication cost was reduced to Φ = 7 (φ1 = 2, φ2 = 2 and
φ3 = 3).
5.2 Arranged Hot Codes
The previous section demonstrated that the arrangement of the
TC words into a sequence that minimizes the number of transitions
between every successive code words, defined a the GC, which
minimizes the decoder variability and the fabrication cost. We
therefore considered the question whether the code words of HCs
can be arranged in a similar way to the GC, such that the number of
transitions is minimized, and to assess the possible benefits of such
codes, that we called Arranged Hot Code (AHC).
Since the number of values in every HC word (M,k) is fixed
(Sec. 2.3), then the minimum number of transitions is 2. We used
an exhaustive algorithm for most of the hot codes with a reasonable
code space size ( 100) for nanowire arrays, and we found that the
arrangement in a Gray-code-fashion always exists.
It is possible to show in a very similar way to Proposition 4 and 5
that, when an arrangement of a given hot code exists, in such a way
that the number of transitions between every successive code words
is minimized, then this arrangement is the optimal hot code with
respect to ‖Σ‖1 and Φ compared to all possible arrangements of
the same hot code. In the next section we will therefore assess the
performance of the optimized versions of both tree and hot codes
in terms of fabrication complexity and circuit costs.
6. SIMULATIONS OF THE DECODER
In this section, the yield and area of crossbar circuits are simu-
lated for different code types and the improvement resulting from
the optimized decoder design (defined as its size and the code type)
is demonstrated.
6.1 Simulation Platform
In order to assess the impact of the decoder design (meaning
the choice of the code type) on the fabrication complexity and the
circuit features, we performed a statistical analysis of a crossbar
circuit (Fig. 1.a). The function of the crossbar circuit was assumed
to be a memory. The defects affecting the molecular switches or
the phase change layer were not simulated. Only the defects hap-
pening at the decoder part due to the variability of the VT’s in the
doping regions were considered. We neglected the probability that
18
19
20
21
22
23
24
Binary Ternary Quaternary
Code and Logic Type
F
ab
ri
ca
ti
o
n
 C
o
m
p
le
xi
ty
TC
GC
Figure 5: Fabrication complexity in terms of number of addi-
tional steps for different code types and logic levels
nanowires can be broken; we actually noticed that the fabricated
nanowires (Fig. 3.a) had a yield close to unit.
Both layers forming the crossbar have the same number of caves
for a square-shaped crossbar. The cave count and the number of na-
nowires in every half cave N was fixed according to the raw cross-
point density set to DRAW=16 kB. The number of contact groups
per half cave was minimized with respect to the code type (code
space size Ω and code length M ) and geometry (lithography pitch
PL and nanowire pitch PN). While Ω and M were used as simula-
tion parameters, PL was set to 32 nm and PN to 10 nm. According
to standard layout rules, the minimum width of every contact group
had to be set to 1.5 × PL. The maximum width of every contact
group was limited by the width of Ω nanowires at most that can fit
in every contact group.
The threshold voltages VT’s are distributed within the range 0 to
1 V, in order to account for a maximum supply voltage of 1 V. The
doping levels were estimated from VT’s by using the assumptions
in [14] for the most common materials used in standard CMOS
processes. The variability σT of VT was set to 50 mV. A nanowire
is addressable if VT at every doping region varies within a small
range as specified in [2]. In this way, the probability that a nano-
wire is addressed was calculated from the Gaussian distributions of
VT’s with the standard deviations given by Σ. We accounted for na-
nowires that may be addressed by two adjacent contact groups, as
explained in [6], and we removed them from the set of addressable
nanowires. This gives the estimate for the yield of every cave Y .
Consequently, the effective array density that denotes the number
of working crosspoints can be estimated as: DEFF = DRAW · Y 2.
6.2 Simulation Results
We calculated the technology complexity Φ for different code
and logic types. The results, plotted in Fig. 5 for N = 10 show
that Φ is constant for all binary codes and equal to the double of
the number of nanowires in a half cave. Higher logic level was
suggested as a way to reduce the area overhead of the decoder [2].
However, Fig. 5 shows that the higher logic level comes with some
fabrication cost: 20% more steps for the tree code. For ternary and
quaternary logic, the Gray code performs better than the tree code
(17%) by completely canceling the fabrication complexity over-
head.
The variability matrix was calculated for various types of binary
codes. N was set to 20 and the plots in Fig. 6 show the variabil-
ity level at every digit in the N ×M -matrix Σ, as square roots of
elements of Σ normalized to σT. By comparing Fig. 6.a, c and
e, we see that the Gray code and its balanced version reduce the
variability level at every digit in comparison to the tree code. The
balanced Gray code distributes the variability more evenly than the
other codes. In this way, the average variability ‖Σ‖1/(N · M)
could be reduced by 18%. Similar results were obtained for these
codes with a higher logic level, as well as for hot codes and their ar-
ranged version. Next, we compared the distribution of the elements
of Σ for a fixed code type and different code lengths (Fig. 6.a, c and
e vs. Fig. 6.b, d and f). We noticed that longer codes have less digit
transitions and help reduce the average variability.
The elements of Σ provide the inputs to estimate the crossbar
yield, that we quantified as the effective crossbar density normal-
ized by the raw crossbar density of 16 kB. The crossbar yield
1 2 3
4 5 6
7 85
10
15
20
1
1.5
2
2.5
3
3.5
4
4.5
Digit
TC (L=8)
Nanowire
Σ/
σ
2
1 2 3 4
5 6 7 8
9 105
10
15
20
1
1.5
2
2.5
3
3.5
4
4.5
Digit
TC (L=10)
Nanowire
Σ/
σ
2
1 2 3
4 5 6
7 85
10
15
20
1
1.5
2
2.5
3
3.5
4
4.5
Digit
GC (L=8)
Nanowire
Σ/
σ
2
1 2 3 4
5 6 7 8
9 105
10
15
20
1
1.5
2
2.5
3
3.5
4
4.5
Digit
GC (L=10)
Nanowire
Σ/
σ
2
1 2 3
4 5 6
7 85
10
15
20
1
1.5
2
2.5
3
3.5
4
4.5
Digit
BGC (L=8)
Nanowire
Σ/
σ
2
1 2 3 4
5 6 7 8
9 105
10
15
20
1
1.5
2
2.5
3
3.5
4
4.5
Digit
BGC (L=10)
Nanowire
Σ/
σ
2
a)
b)
c)
d)
e)
f)
Figure 6: Square root of elements of variability matrix Σ for
different binary code types and lengths
0%
20%
40%
60%
80%
6 8 10
Code Length
C
ro
ss
b
ar
 Y
ie
ld
TC
BGC
0%
20%
40%
60%
80%
4 6 8
Code Length
C
ro
ss
b
ar
 Y
ie
ld
HC
AHC
Figure 7: Crossbar yield in terms of percentage of addressable
crosspoints for different binary code types and lengths
is plotted in Fig. 7 for various binary code types and lengths.
The yield generally increases with increasing code length, until it
reaches the maximum (M ∼ 10 for TC/BGC and M ∼ 6 for
HC/AHC). The yield improvement of the tree code and the ar-
ranged hot codes, by increasing the code length from 6 to 10 and 4
to 8 respectively, is ∼ 40%. For a fixed code length, the optimized
codes (i.e. BGC and AHC) perform better than their non-optimized
versions (i.e. TC and HC respectively). For instance, the balanced
Gray code yields 42% more than the tree code, and the arranged hot
code 19% better than the hot code with the same length M = 8.
The dependency of the yield on the code length is explained by
two factors: i) the variation with M of the percentage of nanowi-
res at adjacent contact groups, which have to be removed from the
set of addressable nanowires; and ii) the dependency of the vari-
ability on M . On one hand, by increasing M and keeping the code
type fixed, the code space size increases and less contact groups are
needed, so less nanowires are removed at adjacent contact groups
and the yield increases. This effect saturates when the code space
size is large enough to neglect the number of nanowires at adja-
cent contact groups. On the other hand, the average variability
‖Σ‖1/(N ·M) decreases with increasing M , because longer codes
have less digit transitions, as we showed previously. So, for a fixed
code type, the yield, first, increases with increasing M , then it starts
decreasing for larger M because the increasing number of digits
cancels the benefits of decreasing variability of each digit taken
separately. This decrease is just slightly seen for the hot code when
M increases beyond 6; and for other code types, it starts appearing
from M ∼ 10.
From the geometrical data, we estimated the crossbar area; then,
by considering the effective density, we estimated the bit area for
different code types and lengths (Fig. 8). For the tree code and its
optimized versions (Gray and balanced Gray codes), the bit area
decreases with increasing code length mainly due to the vanishing
effect of adjacent contact regions, as explained previously. An area
saving by 51% can be achieved by setting M to 10 instead of 6
for the tree code. The balanced Gray code yields a denser cross-
bar than the Gray code, which in turns yields better than the tree
code; for instance crossbars with the balanced Gray code are 30%
denser than those with the tree code (for M = 8). The hot and
arranged hot codes yield the most dense crossbars with M = 6.
0
50
100
150
200
250
300
350
400
TC GC BGC HC AHC
Code Type and Length (6, 8 and 10)
B
it
 A
re
a 
[n
m
²]
6
8
10
Figure 8: Average area per functional bit for different binary
code types and lengths
For larger M , the bit area slightly start to increase, as the yield
starts to decrease because of higher variability of longer codes, as
explained previously. The arranged hot code performs better than
the hot code with 13% less bit area for M = 6. Among all these
codes, the smallest bit area is 169 nm2 for the balanced Gray code,
followed by the arranged hot code with 175 nm2.
7. CONCLUSIONS
Silicon nanowires are promising devices that may help tackle
many design challenges by means of their organization into regular
crossbar circuits. In this paper we presented our validated fabrica-
tion technique, the MSPT, that yields very dense parallel arrays of
silicon nanowires and we introduced a design style for the nano-
wire decoder using the same fabrication technique. We identified
the design challenges for the MSPT-decoder that result from the in-
terdependence of the nanowire patterns. We quantified these chal-
lenges in terms of fabrication cost and decoder variability. Then we
proved that the arrangement of the code space in a Gray code fash-
ion minimizes these costs. We performed simulations with differ-
ent decoder design parameters and code types, including the Gray
code, the balanced Gray code and the arranged hot codes. The re-
sults showed that the technology cost can be reduced by 17% by
using the Gray code. The Gray code and its balanced version help
reduce and balance the variability throughout the whole nanowire
decoder, resulting in 18% less variability. The decoder design cov-
ers not only the code type but also its length: the yield improves
by 40% by adding redundancy to the code length and by 19 to 42%
by using the optimized code types. The smallest effective area per
bit was found to be around 170 nm2 for the optimized codes: the
balanced Gray code and the arranged hot code.
8. REFERENCES
[1] R. Beckman et al. Bridging dimensions: Demultiplexing ultrahigh density
nanowire circuits. Science, 310(5747):465–468, 2005.
[2] M. H. Ben Jamaa et al. Variability-aware design of multi-level logic decoders
for nanoscale crossbar memories. Trans. CAD, 27(11):2053–2067, Nov. 2008.
[3] G. S. Bhat and C. D. Savage. Balanced Gray codes. The Electronic Journal of
Combinatorics, 3(1):R25, 1996.
[4] G. Cerofolini. Realistic limits to computation. II. The technological side.
Applied Physics A, 86(1):31–42, 2007.
[5] A. DeHon. Design of programmable interconnect for sublithographic
programmable logic arrays. In Proc. Int. Symp. on FPGA, pages 127–137, 2005.
[6] A. DeHon et al. Stochastic assembly of sublithographic nanoscale interfaces.
IEEE Trans. on Nanotechnology, 2(3):165–174, 2003.
[7] F. Gray. Pulse code communication. US Patent No. 2632058, 1953.
[8] T. Hogg et al. Assembling nanoscale circuits with randomized connections.
Trans. on Nanotechnology, 5(2):110–122, 2006.
[9] J. D. Holmes et al. Control of thickness and orientation of solution-grown
silicon nanowires. Science, 287(5457):1471–1473, 2000.
[10] Y. Luo et al. Two-dimensional molecular electronics circuits. ChemPhysChem,
3:519–525, 2002.
[11] N. A. Melosh et al. Ultrahigh-density nanowire lattices and circuits. Science,
300(5616):112–115, 2003.
[12] K. E. Moselund et al. Prospects for logic-on-a-wire. Microelectronic
Engineering, (85):1406–1409, 2008.
[13] J. E. Savage et al. Radial addressing of nanowires. Journal on Emerging
Technologies in Computing Systems, 2(2):129–154, 2006.
[14] S. M. Sze and K. K. Ng. Physics of Semiconductor Devices. 2007.
[15] D. Whang et al. Large-scale hierarchical organization of nanowire arrays for
integrated nanosystems. Nano Letters, 3(9):1255–1259, 2003.
[16] Y. Zhang et al. An integrated phase change memory cell with ge nanowire diode
for cross-point memory. VLSI Technology, pages 98–99, June 2007.
