Silicon nanowires are a promising solution to address the increasing 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 organization onto regular crossbars, the problem of designing the nanowire decoder is still challenging and highly dependent on the nanowire fabrication technology. In this paper, we introduce a novel design style and encoding scheme for decoding nanowires fabricated with the Multi-Spacer-Patterning Technique (MSPT); and we present a method based on Gray codes that reduces the fabrication cost and improves the decoder reliability. We show that by arranging the code in a Gray code fashion, we decrease the fabrication 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 nm 2 .
INTRODUCTION
Despite the large efforts spent to develop novel solutions in order 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 devices, which needs innovative defect tolerance methods at all design levels. In order to go beyond the 22 nm milestone, alternative devices to bulk Metal-Oxide-Semiconductor Field Effect Transistor (MOSFET) are currently being investigated, and their design 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 parallel nanowires. At the crossing areas, specific materials are deposited or grafted in order to functionalize the circuit [10] . A major issue has been reported with the integration of crossbar circuits, consisting in interfacing them with a decoder to the outer Complementary 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 nanowire fabrication techniques is the Multi-Spacer Patterning Technique (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 technology 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 design 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 different 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 problem of the decoder design in an abstract way. In Section 5 we derive 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.
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.
Fabrication Technologies
Silicon nanowires are quasi one-dimensional long structures fabricated 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 recently 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 directly on the functional substrate by accurately controlling the deposition, oxidation and etching rates [12, 4] , or by using nanometerscale molds [11] . Because of the small dimensions of these devices and the difficulty 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 arrangement of these devices in a crossbar architecture where the device placement is easier and the redundancy is higher. Since the nanowires cannot perform computation or information storage, the use of other emerging materials has been proposed to enhance the device 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 nanowires in order to functionalize the circuit.
Nanowire Circuits and Decoders
The baseline organization of a nanowire crossbar circuit is depicted in Fig 1. a. An arrangement of two orthogonal layers of parallel nanowires defines a regular grid of intersections called crosspoints. 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 performed 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 contact group to the outer CMOS circuit. In order to fully bridge the scales and make every nanowire within this set uniquely addressable 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 conductive ( 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 nanoimprint. For other bottom-up fabrication techniques, a gate-allaround decoder was suggested in [12] .
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
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 ∈ AE 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 complementary 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, giving 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 because 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 every 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.
FABRICATION AND DESIGN OPPOR-TUNITIES OF NANOWIRE DECODERS
In this section we present the nanowire array fabrication technology that we are currently experimentally investigating. Then, we introduce the decoder fabrication method and we focus on the decoder design opportunities and challenges.
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 fabrication technique using only standard CMOS steps. It yields large arrays of parallel poly-crystalline Silicon (poly-Si) spacers separated by silicon dioxide (SiO2) as insulator. The essential fabrication 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 deposition 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 research purposes in our fabrication facilities, we could obtain dense arrays of poly-Si spacers with a sub-lithographic pitch. These spacers 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 planarization technique if needed. A Scanning Electron Microscopy (SEM) of a cross-section of the obtained nanowire arrays is presented in Fig. 3 . The nanowire pitch exclusively depends on the thickness of deposited poly-Si and on the etch, but not on the lithography 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 3.
5.
2.
4.
6. 
The Decoder Fabrication Technique
While a pattern can be easily defined during the growth of nanowires 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 sublithographic scale, it is difficult to pattern it with standard photolithographic means, unless expensive high-resolution and timecostly 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. 
4.

Cross-section
Top-View 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 (decrease) 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.
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 nanowires lie within parallel caves having a symmetry axis going through their central axis (Sec. 3.1). The unique addressing of every nanowire 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 regions each. Recall that the pattern is the sequence of threshold voltages and the doping profile is the sequence of dopant concentrations along the doping regions of the nanowire.
i˜b e the pattern and doping profile of the nanowire i respectively. For the considered technique, 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 therefore need to determine the analytical multivariable application that links P Assuming that a set of doping profiles exists for any set of patterns, it is possible to optimize the choice of patterns according to different cost functions. We consider first the impact of this decoding technique on the fabrication cost. The nanowire profile implies 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 lithography/doping steps, i.e. P φi. We therefore need to establish the link between P j i 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 doping 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 deviation of the threshold voltage of this region Σ j i , accordingly increases. It is therefore desirable to establish the link between P j i and Σ j i and to optimize the choice of the patterns in order to minimize 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 threshold voltage variability. These cost functions will be minimized by choosing the best code type for the decoder.
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 matrices describe the most relevant design and fabrication aspects. Using these definitions, we will derive the cost functions of the fabrication complexity and the circuit variability. Further, we assume a multi-valued logic addressing with n values. Every VT needs a unique doping level ND fixed by the device physics and geometry [14] .
18 cm −3 . The patterns are represented with the first N code words of the n-ary tree code. With V the matrix covering all VT's, we obtain: 
PROPOSITION 1. A non-linear bijective application h maps P onto D as follows:
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. , i = 0, . . . , N − 1) represents the doping doses used in a single step doping procedure. The number of unequal non-zero elements in Si represents the number of different doses used at this doping step. The more doping doses, the more lithography steps are needed and the more complex is the fabrication. Let φi (i = 0, . . . , N − 1) be the number of unequal non-zero elements in Si, then the total number of lithography/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 voltages 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 every 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 ν 
Example 4. For S given in Example 2, we have:
Optimizing the decoder fabrication complexity consists in finding the best pattern P that minimizes Φ. Optimizing 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.
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 functions. 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. 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 chosen 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.
The Gray Code
Example 5. Instead of P given in Example 1, which includes a tree code sequence with the cost Σ 1 = 22·σ 2 T (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 · σ 2 T :
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 S j i is unequal to zero if there is a transition P j i ⇒ P j i+1 between two successive code words in P 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).
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.
SIMULATIONS OF THE DECODER
In this section, the yield and area of crossbar circuits are simulated for different code types and the improvement resulting from the optimized decoder design (defined as its size and the code type) is demonstrated.
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 happening at the decoder part due to the variability of the VT's in the doping regions were considered. We neglected the probability that 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 nanowires in every half cave N was fixed according to the raw crosspoint 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 simulation 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 nanowire is addressed was calculated from the Gaussian distributions of VT's with the standard deviations given by Σ. We accounted for nanowires 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 .
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 overhead.
The variability matrix was calculated for various types of binary codes. N was set to 20 and the plots in Fig. 6 show the variability 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 arranged 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 normalized by the raw crossbar density of 16 kB. The crossbar yield 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 arranged 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 nanowires at adjacent contact groups, which have to be removed from the set of addressable nanowires; and ii) the dependency of the variability 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 adjacent 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 crossbar 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. 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 nm 2 for the balanced Gray code, followed by the arranged hot code with 175 nm 2 .
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 fabrication technique, the MSPT, that yields very dense parallel arrays of silicon nanowires and we introduced a design style for the nanowire decoder using the same fabrication technique. We identified the design challenges for the MSPT-decoder that result from the interdependence of the nanowire patterns. We quantified these challenges in terms of fabrication cost and decoder variability. Then we proved that the arrangement of the code space in a Gray code fashion minimizes these costs. We performed simulations with different decoder design parameters and code types, including the Gray code, the balanced Gray code and the arranged hot codes. The results 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 covers 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 nm 2 for the optimized codes: the balanced Gray code and the arranged hot code.
