# A New Efficient-Silicon Area MDAC Synapse 

Zied Gafsi, Nejib Hassen, Mongia Mhiri and Kamel Besbes<br>Microelectronic and Instrumentation Laboratory ( $\mu \mathrm{EI}$ ), Monastir University, Tunisia


#### Abstract

Using the binary representation $\sum_{i} D_{i} 2^{i}$ in the Multiplier digital to analog converter (MDAC) synapse designs have crucial drawbacks. Silicon area of transistors, constituting the MDAC circuit, increases exponentially according to the number of bits. This latter is generated by geometric progression of common ratio equal to 2 . To reduce this exponential increase to a linear growth, a new synapse named Arithmetic MDAC (AMDAC) is designed. It functions with a new representation based on arithmetic progressions. Using the AMS CMOS $0.35 \mu \mathrm{~m}$ technology the silicon area is reduced by a factor of $40 \%$.


Key words: MDAC, binary representation, efficient silicon area

## INTRODUCTION

Neural network are very suitable to resolve problems where conventional resolution methods fall ${ }^{[1-}$ ${ }^{3]}$. Synapses are the common bloc in neural network. It functions as multipliers. Their roles are to weight neural inputs by synaptic weights. Several research aims to implement synapses. Some use numeric implementation whereas others use analogue circuit. Each of these method implementations has its own advantages and drawbacks. Numeric multipliers are very suitable for applications that need high accuracy and precision results ${ }^{[4]}$. Unfortunately it occupies a considerable silicon area. Analogue synapses are efficient-silicon area and are able to operate at high frequency. However synaptic weights are badly saved in their analogue form ${ }^{[5-13]}$. To combine the advantages of these last implementation methods, a mixed implementation technique provides best performances ${ }^{[14-22]}$.

A mixed synapse named multiplier digital-toanalogue converter (MDAC) is a multiplier bloc that multiplies an analogue reference by a binary coded synaptic weight. This last is converted by a digital to analogue converter (DAC) to an analogue size, multiplied by the analogue reference and the result is routed to the output of the synapse. Current steering MDAC is the aim of this work for its capability to drive considerable charges at the output of synapses.

Several codes are used to represent the digital synaptic weights ${ }^{[14,15,17,20-22]}$. The most popular are the thermometer code and the weighted binary code. The advantage of the first cited one is its low glitches.


Fig. 1: p-input formal neuron
However to represent N -bits synaptic weight, $2^{\mathrm{N}-1}$ identical current sources are needed. To represent the same weight using binary weighted representation, N current sources, which values follow a geometric progression, are used. The use drawback of such representation is the exponential increase of the current source magnitudes. Face to this problem the design of a new MDAC synapse architecture, called AMDAC, using arithmetic progression will be presented.

Multiplication operation: Neural network are defined as the nonlinear function of weighted sum of signals. The p -inputs of neuron, $\mathrm{X}_{0}, \mathrm{X}_{1} \ldots \mathrm{X}_{\mathrm{p}-1}$ shown in Fig. 1, are multiplied by the p-synaptic weights, $\mathrm{W}_{0}, \mathrm{~W}_{1} \ldots, \mathrm{~W}_{\mathrm{p}-1}$.

The weighted sum is then forwarded to the neuron output via a nonlinear activation function $\mathrm{S}($.$) . Neuron$ output Y is then given by:
$\mathrm{Y}=\mathrm{S}\left(\sum_{\mathrm{i}=0}^{\mathrm{p}-1} \mathrm{X}_{\mathrm{i}} \mathrm{W}_{\mathrm{i}}\right)$
From the previous equation, multiplication operation of $\mathrm{X}_{\mathrm{i}} \mathrm{W}_{\mathrm{i}}$ and the addition $\Sigma_{\mathrm{i}} \mathrm{X}_{\mathrm{i}} \mathrm{W}_{\mathrm{i}}$ are the two arithmetic operation performed by the neuron. The implementation of the addition is easy if outputs of the synapses are currents. It is performed when synapse outputs are connected together according to kirchhoff law (KCL). The difficulty lies in the implementation of the multiplication operation.

The MDAC synapse shown in Fig. 2a is a bloc diagram that multiplies the analog voltage $\mathrm{V}_{\text {in }}$ by the binary coded synaptic weight $\mathrm{D}_{\mathrm{N}-1} \mathrm{D}_{\mathrm{N}-2} \ldots \mathrm{D}_{2} \mathrm{D}_{1} \mathrm{D}_{0}$. The transfer characteristics of MDAC synapse, shown in Fig. 2 b and 2 c , take two forms. On one hand, when $\mathrm{I}_{\text {out }}$ current is plotted according to the analog voltage $\mathrm{V}_{\text {in }}$, characteristics are straight lines which its slopes vary linearly. On the other hand, $\mathrm{I}_{\text {out }}$ is a staircase shaped curves when it is plotted according to synaptic weights. From these curves integral nonlinearity error (INL) and differential nonlinearity error (DNL) are concluded. INL is an error characterization between the real staircase shaped curve and the ideal characteristic generally obtained by linear approximation of the real curve.

DNL error give a measure of how well an MDAC can generate uniform smallest analog change LSB. Thus binary synaptic inputs $\mathrm{D}_{\mathrm{N}-1} \mathrm{D}_{\mathrm{N}-2} \ldots \mathrm{D}_{2} \mathrm{D}_{1} \mathrm{D}_{0}$ and analog input voltage are combined by the multiplication operation:

$$
\begin{equation*}
\mathrm{I}_{\text {out }}=\mathrm{K} \cdot \mathrm{C}\left(\mathrm{D}_{\mathrm{N}-1}, \mathrm{D}_{\mathrm{N}-2}, \cdots, \mathrm{D}_{2}, \mathrm{D}_{1}, \mathrm{D}_{0}\right) \cdot \mathrm{V}_{\text {in }} \tag{2}
\end{equation*}
$$

Where $\mathrm{I}_{\text {out }}$ is the output current of the synapse, K is a constant, $\mathrm{V}_{\text {in }}$ is the analog input voltage and $\mathrm{C}\left(\mathrm{D}_{\mathrm{N}-1}, \mathrm{D}_{\mathrm{N}}\right.$. ${ }_{2}, \ldots \mathrm{D}_{2}, \mathrm{D}_{1}, \mathrm{D}_{0}$ ) is to binary-to-decimal conversion law. For the weighted binary representation $\mathrm{C}\left(\mathrm{D}_{\mathrm{N}-1}, \mathrm{D}_{\mathrm{N}}\right.$. $\left.{ }_{2}, \ldots \mathrm{D}_{2}, \mathrm{D}_{1}, \mathrm{D}_{0}\right)$ is expressed by:

$$
\begin{equation*}
\mathrm{C}\left(\mathrm{D}_{\mathrm{N}-1}, \mathrm{D}_{\mathrm{N}-2}, \cdots, \mathrm{D}_{2}, \mathrm{D}_{1}, \mathrm{D}_{0}\right)=\sum_{\mathrm{i}=0}^{\mathrm{N}-1} 2^{i} \mathrm{D}_{\mathrm{i}} \tag{3}
\end{equation*}
$$

## Binary weighted current steering MDAC

MDAC circuit: The 6 -bits MDAC synapse, shown in Fig. 3 is composed of:

* An input circuit converting the analog input voltage $\mathrm{V}_{\text {in }}$ to a proportional current $\mathrm{I}_{\text {ref }}$.
* A series of scaled current mirror so that a mirror produces twice the current produced by the preceding one. Each of the stored bits $D_{0}$ to $D_{6}$ controls a switch transistor.
* An output circuit inverting the sign of the current $\mathrm{I}_{\text {sum }}$ issued from current mirrors. The sign circuit
determines the direction of the output current, i.e. $\mathrm{DI}=0$ creates a positive (excitatory) synaptic current and DI=1 sets a negative (inhibitory) synaptic current.
* The total output current resulting from the scaled current mirrors is expressed by:
$I_{\text {sum }}=\sum_{i=0}^{5} I_{i} \frac{V_{i}}{V_{d d}}$
Where $\mathrm{I}_{\mathrm{i}}(\mathrm{i}=0 \ldots 5)$ is the flowing current in the current mirror $i$ and $V_{i}$ is the gate voltage controlling the current $\mathrm{I}_{\mathrm{i}}$. $\mathrm{V}_{\mathrm{i}}$ takes only either of values $\mathrm{V}_{\mathrm{dd}}$ or zero. It is then expressed according to the binary value $D_{i}$ by:
$\mathrm{V}_{\mathrm{i}}=\mathrm{D}_{\mathrm{i}} \cdot \mathrm{V}_{\mathrm{dd}}$
In the case of $\mathrm{D}_{\mathrm{i}}=0$ then $\mathrm{V}_{\mathrm{i}}=0$. In the other case, when $D_{i}=1$ then $V_{i}=V_{d d}$. As the size ratio of different current mirrors follow a geometric progression having the common ratio equal to 2 , the current $I_{i}$ is done by:
$\mathrm{I}_{\mathrm{i}}=2^{\mathrm{i}} \mathrm{I}_{0}$
Substituting the equations 5 and 6 in 4 the expression of $\mathrm{I}_{\text {sum }}$ is done by:

$$
\begin{equation*}
I_{\text {sum }}=I_{0} \cdot \sum_{i=0}^{5} 2^{i} D_{i} \tag{7}
\end{equation*}
$$

From the previous equation, the weighted binary to decimal conversion law is shown. Furthermore multiplication operation is shown between the analog input current and the binary to decimal conversion law. Finally, considering the sign bit DI, $\mathrm{I}_{\text {out }}$ is expressed by:

$$
\begin{equation*}
I_{\text {sum }}=I_{0} \cdot\left(\left(-1^{\mathrm{DI}}\right) \sum_{\mathrm{i}=0}^{5} 2^{\mathrm{i}} D_{\mathrm{i}}\right) \tag{8}
\end{equation*}
$$

Simulation results of MDAC: Several simulations are carried out using $0.35 \mu \mathrm{~m}$ CMOS AMS process. Figure 4 shows good linearity of the V-I converter between input analog voltage $\mathrm{V}_{\text {in }}$ and the converted current $\mathrm{I}_{\text {in }}$ from $V_{i n}=2$ volt. The linearity of the V-I converter have an impact on the linear variation of the output characteristics. DC analysis show that synaptic output current versus analog input voltage, illustrated in Fig. 5a, follows a linear variation law for each synaptic weight. Linear variation of the slopes is depicted in Fig. 5 b. The MDAC output current versus 6 -bit synaptic weight is illustrated in Fig. 6. 127 states are represented. INL and DNL normalized to 1 LSB are 3D represented in Fig. 7. Maximum INL and DNL are respectively equal to 0.7 LSB and 0.6 LSB .


Fig. 2: Simplified schema of a MDAC synapse and its characteristics


Fig. 3: Weighted binary MDAC circuit


Fig. 4: $\quad$ DC analysis of $\mathrm{I}_{\mathrm{ref}}$ versus input voltage (solid line) and its linear approximation (dashed line)

(a)

(b)

Fig. 5: (a) DC analysis of MDAC synaptic output current versus input analogue voltage for different synaptic weights (63...63) (b) Slopes variation of MDAC synaptic output current (dotted curve) and its linear approximation (solid curve)

Arithmetic progression based MDAC: AMDAC From geometric to arithmetic progression:
The MDAC, circuit presented in the


Fig. 6:
MDAC Synapse output current versus synaptic weights $\left( \pm 63\right.$ level) for various input voltages $\mathrm{V}_{\text {in }}(2.0,2.1,2.2 \ldots$ 3.3 V )



Fig. 7: DNL and INL error of weight binary MDAC
previous paragraph, use binary-weighted current mirror widths implanting six current sources of various sizes. Since the current mirror widths are binary weighted, the input code is a simple binary number. The transition from an MDAC state to the following is due to the increase of the total transistor width in conduction by the least significant width (LSW). In the case of our MDAC synapse, LSW is equal to $0.4 \mu \mathrm{~m}$. This last is


Fig. 8: Circuit of AMDAC synaptic cell
Table 1: 9-bit A2 unsigned binary representation based on arithmetic progression

| $\boldsymbol{D}_{7}$ | $\boldsymbol{D}_{6}$ | $\boldsymbol{D}_{5}$ | $\boldsymbol{D}_{4}$ | $\boldsymbol{D}_{3}$ | $\boldsymbol{D}_{2}$ | $\boldsymbol{D}_{1}$ | $\boldsymbol{D}_{0}$ | $\mathbf{W}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 |
| 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 2 |
| 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 3 |
| 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 4 |
| 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 5 |
| 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 6 |
| 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 7 |
| 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 8 |
| 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 9 |
| 0 | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 10 |
| 0 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 11 |
| 0 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 12 |
| 0 | 0 | 1 | 0 | 0 | 0 | 0 | 1 | 13 |
| 0 | 1 | 0 | 0 | 0 | 0 | 0 | 1 | 14 |
| 1 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 15 |
| 1 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 16 |
| 1 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 17 |
| 1 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 18 |
| 1 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 19 |
| 1 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 20 |
| 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 21 |
| 0 | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 22 |
| 1 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 23 |
| 1 | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 24 |


| $\boldsymbol{D}_{7}$ | $\boldsymbol{D}_{6}$ | $\boldsymbol{D}_{5}$ | $\boldsymbol{D}_{4}$ | $\boldsymbol{D}_{3}$ | $\boldsymbol{D}_{\mathbf{2}}$ | $\boldsymbol{D}_{\mathbf{1}}$ | $\boldsymbol{D}_{0}$ | W |
| ---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 25 |
| 1 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 26 |
| 1 | 0 | 1 | 0 | 0 | 0 | 0 | 1 | 27 |
| 1 | 1 | 0 | 0 | 0 | 0 | 0 | 1 | 28 |
| 1 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | 29 |
| 1 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 30 |
| 1 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 31 |
| 1 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 32 |
| 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 33 |
| 1 | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 34 |
| 1 | 0 | 1 | 0 | 0 | 0 | 1 | 1 | 35 |
| 1 | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 36 |
| 1 | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 37 |
| 1 | 1 | 0 | 0 | 1 | 0 | 0 | 1 | 38 |
| 1 | 1 | 0 | 1 | 0 | 0 | 0 | 1 | 39 |
| 1 | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 40 |
| 1 | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 41 |
| 1 | 1 | 1 | 0 | 0 | 1 | 0 | 0 | 42 |
| 1 | 1 | 1 | 0 | 1 | 0 | 0 | 0 | 43 |
| 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 44 |
| 1 | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 45 |
| 1 | 1 | 0 | 0 | 1 | 0 | 1 | 1 | 46 |
| 1 | 1 | 0 | 1 | 0 | 0 | 1 | 1 | 47 |
| 1 | 1 | 1 | 0 | 0 | 0 | 1 | 1 | 48 |
| 1 | 1 | 1 | 0 | 0 | 1 | 0 | 1 | 49 |


| $D_{7}$ | $D_{6}$ | $D_{5}$ | $D_{4}$ | $D_{3}$ | $D_{2}$ | $D_{1}$ | $D_{0}$ | W |
| ---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | 1 | 1 | 0 | 1 | 0 | 0 | 1 | 50 |
| 1 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 51 |
| 1 | 1 | 1 | 1 | 0 | 0 | 1 | 0 | 52 |
| 1 | 1 | 1 | 1 | 0 | 1 | 0 | 0 | 53 |
| 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 54 |
| 1 | 1 | 0 | 0 | 1 | 1 | 1 | 1 | 55 |
| 1 | 1 | 0 | 1 | 0 | 1 | 1 | 1 | 56 |
| 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 57 |
| 1 | 1 | 1 | 0 | 1 | 0 | 1 | 1 | 58 |
| 1 | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 59 |
| 1 | 1 | 1 | 1 | 0 | 1 | 0 | 1 | 60 |
| 1 | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 61 |
| 1 | 1 | 1 | 1 | 1 | 0 | 1 | 0 | 62 |
| 1 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 63 |
| 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 64 |
| 1 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 65 |
| 1 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 66 |
| 1 | 1 | 1 | 0 | 1 | 1 | 1 | 1 | 67 |
| 1 | 1 | 1 | 1 | 0 | 1 | 1 | 1 | 68 |
| 1 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 69 |
| 1 | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 70 |
| 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 71 |

the first term of the geometric progression with which the scaled mirror sizes of the MDAC follow. Consequently, the series of scaled mirror width were:
$\{0.4 \mu \mathrm{~m}, 0.8 \mu \mathrm{~m}, 1.6 \mu \mathrm{~m}, 3.2 \mu \mathrm{~m}, 6.4 \mu \mathrm{~m}, 12.8 \mu \mathrm{~m}\}$ (9)
The common ratio of the last geometric progression is equal to 2 . To handle the transition of a weighted MDAC state to the following, an increase with the two's power of manufacturing grid is enough. Furthermore an arithmetic progression can limit the exponential increase of the geometric progression terms. Its common difference (CD) is equal to two's power of manufacturing grid. Let choose the common difference equal to $0.1 \mu \mathrm{~m}$ and the first terms equal to $0.7 \mu \mathrm{~m}$. the eight arithmetic terms are:

$$
\left\{\begin{array}{l}
0.7 \mu \mathrm{~m}, 0.8 \mu \mathrm{~m}, 0.9 \mu \mathrm{~m}, 1.0 \mu \mathrm{~m}  \tag{10}\\
1.1 \mu \mathrm{~m}, 1.2 \mu \mathrm{~m}, 1.3 \mu \mathrm{~m}, 1.4 \mu \mathrm{~m}
\end{array}\right\}
$$

The Fig. 8 shows the circuit of AMDAC. The V-I converter and the current inverter of the AMDAC are the same that the ones presented in Fig. 3. The scaled mirror sizes follow the arithmetic progression terms of the series-10. Obviously the number representation is not the weighted binary code. A new binary representation based on arithmetic progression named binary arithmetic representation and noted A2 must be established. To represent the first state, $0.7 \mu \mathrm{~m}$-current mirror width is activated. Thus the first number representation is:
$\left.1\right|_{10}=\left.00000001\right|_{A 2}$
Where, the $\left.1\right|_{10}$ and $\left.00000001\right|_{\mathrm{A} 2}$ are respectively the notations of the decimal value of one and its A2 binary representation. In this last the only one valued bit is at the least significant bit.

The following states are generated by adding each time the common difference $C D$ equal to $0.1 \mu \mathrm{~m}$. This corresponds to shifting the one valued bit to the more significant bits:
$\left.2\right|_{10}=\left.00000010\right|_{\mathrm{A} 2}$
$\left.3\right|_{10}=\left.00000100\right|_{\mathrm{A} 2}$
$\left.4\right|_{10}=\left.00001000\right|_{\mathrm{A} 2}$
$\left.5\right|_{10}=\left.00010000\right|_{\mathrm{A} 2}$
$\left.6\right|_{10}=\left.00100000\right|_{\mathrm{A} 2}$
$\left.7\right|_{10}=\left.01000000\right|_{\mathrm{A} 2}$
$\left.8\right|_{10}=\left.10000000\right|_{\mathrm{A} 2}$
The last value, $\left.8\right|_{10}$, corresponds to the activation of the current mirror having the width equal to $1.4 \mu \mathrm{~m}$. The next value must activate a current mirror width equal to
$1.5 \mu \mathrm{~m}$. This last size can be obtained by the activation of the two current mirrors sized $\mathrm{W}=0.7 \mu \mathrm{~m}$ and $\mathrm{W}=0.8 \mu \mathrm{~m}$. consequently A 2 representation of the decimal value $\left.9\right|_{10}$ is:
$\left.9\right|_{10}=\left.00000011\right|_{A 2}$
Higher decimal values are also obtained by shifting one valued bits from the less significant bits towards more significant bits. Table 1 shows the complete eightbit representation. 71 states are noted. A2 representation is redundant because a decimal value can be represented by several A2 binary codes. For example $\left.00011100\right|_{\mathrm{A} 2}$ and $\left.00101010\right|_{\mathrm{A} 2}$ activate the same total current mirror width. In fact, the mirrors widths activated by the code $\left.00011100\right|_{\mathrm{A} 2}$ are $0.9 \mu \mathrm{~m}, 1 \mu \mathrm{~m}$ and $1.1 \mu \mathrm{~m}$. the total width is then equal to $3 \mu \mathrm{~m}$. the same width can be obtained by the activation of $0.8 \mu \mathrm{~m}, 1 \mu \mathrm{~m}$ and $1.2 \mu \mathrm{~m}$ current mirrors. The only forbidden A2 code is 11111111 .

Because the first term in the arithmetic series 0.7, $0.8,0.9 \ldots 1.4$ is not equal to the common difference, a correction bloc must be placed in the circuit represented in Fig. 8 to substrate the equivalent of $0.6 \mu \mathrm{~m}$ current mirror width.
The $\mathrm{I}_{\text {sum }}$ current is expressed by:
$I_{\text {sum }}=\left(\sum_{i=0}^{7} I_{i} \frac{V_{i}}{V_{d d}}\right)-I_{C}$
Where, $\mathrm{I}_{\mathrm{C}}$ is the correction current. For the same length transistor of the scaled mirror, the $\mathrm{i}^{\text {th }}$ mirrored current $\mathrm{I}_{\mathrm{i}}$ is then equal to:
$\mathrm{I}_{\mathrm{i}}=\frac{\mathrm{W}_{\mathrm{i}}}{\mathrm{W}_{0}} \mathrm{I}_{0}=\frac{\mathrm{W}_{0}+\mathrm{i} \cdot \mathrm{CD}}{\mathrm{W}_{0}} \mathrm{I}_{0}$
Where, $\mathrm{W}_{0}$ and CD are respectively the common difference and the first term of the arithmetic progression and they are equal to $\mathrm{CD}=0.1 \mu \mathrm{~m}$ and $\mathrm{W}_{0}=0.7 \mu \mathrm{~m}$. substituting equation 5,15 in 14 and considering the sign bit DI the current $\mathrm{I}_{\text {sum }}$ is expressed by:

$$
\begin{equation*}
\mathrm{I}_{\text {sum }}=\frac{\mathrm{I}_{0}}{7}\left[(-1)^{\mathrm{DI}}\left(7 \sum_{\mathrm{i}=0}^{7} \mathrm{D}_{\mathrm{i}}-6+\sum_{\mathrm{i}=0}^{7} \mathrm{iD} \mathrm{D}_{\mathrm{i}}\right)\right] \tag{16}
\end{equation*}
$$

The previous equation is a multiplication between the analog current $\mathrm{I}_{0} / 7$ and 9 -signed-bit A2 representation.

Simulation results of AMDAC: Simulations AMDAC are done in the same conditions as the weighted MDAC simulations. Figure 9a illustrates linear variations of $\mathrm{I}_{\text {out }}$ versus the analog voltage $\mathrm{V}_{\text {in }}$. Figure 9 b shows the

Table 2: Performance comparison between 7-signed-bit MDAC and 9-signed-bit AMDAC

| Synapse | State number | Maximum full scale | INL error | DNL error | Silicone area |
| :--- | :--- | :--- | :--- | :--- | :--- |
| 7 -signed-bit MDAC | 127 | $166 \mu \mathrm{~A}$ | 0.7 LSB | 0.6 LSB | $909 \mu \mathrm{~m}^{2}$ |
| 9-signed-bit AMDAC | 143 | $70 \mu \mathrm{~A}$ | 0.7 LSB | 0.3 LSB | $589 \mu \mathrm{~m}^{2}$ |


(a)

(b)

Fig. 9: (a) DC analysis of AMDAC synaptic output current versus input analogue voltage for different synaptic weights (63...63) (b) Slopes variation of AMDAC synaptic output current (dotted curve) and its linear approximation (solid curve)


Fig. 10: AMDAC Synapse output current versus synaptic weights ( $\pm 63$ level) for various input voltages Vin (2.0, 2.1, 2.2... 3.3 V )


Fig. 11: DNL and INL error of weight binary AMDAC
slope linear variation of the straight line of Fig. 9a. Staircase shaped curves are shown in Fig. 10. From Fig. 11, INL and DNL measures concluded. Maximum INL and DNL error are respectively 0.7 LSB and 0.3 LSB as shown in Fig. 12.

Layout and comparative analysis: Using AMS $0.35 \mu \mathrm{~m}$ CMOS process, layouts of 127 -state MDAC and 143 -state AMDAC are shown in Fig. 12. While the resolution of the latter is higher, its silicon area is lower. Area of AMDAC synapse is $589 \mu \mathrm{~m}^{2}$ versus MDAC synapse area equal to $909 \mu \mathrm{~m}^{2}$. Table 2 summarizes the characteristics of the 7-signed-bit MDAC and the 9 -signed-bit AMDAC synapses. AMDAC synapse has the lowest silicon area for better precision. For the same INL error, the DNL error of MDAC synapse is higher than AMDAC synapse.


## CONCLUSION

In the present work we designed a new multiplier digitalto analog converter based on arithmetic progression called AMDAC. It functions with a new binary representation. We have demonstrated a gain in silicon area by almost of $40 \%$ for better resolution compared to classical MDAC.

## REFERENCES

1. Linares-Barranco, B., E. Sanchez-Sinencio, Rodriguez and J.L. Huertas, 1993. A CMOS analog adaptive BAM with on-chip learning and weight refreshing. IEEE Tran. Neural Networks, 4: 3.
2. Rossetto, O., C. Jutten, J. Heraut and I. Kerzer, 1989. Analog VLSI Synaptic Matrices as building blocks for neural networks. IEEE Micro, pp: 56-63.
3. Graf, H.P., L.D. Jackel and W.E. Hubbard, 1988. VLSI implementation of a neural network model. IEEE Computer, 21: 41-49.
4. Conti, M., P. Crippa, G. Guaitini, S. Orcioni and C. Turchertti, 1999. An analog CMOS approximate identity neural network with stochastic learning and multilevel weight storage. IEICE Trans. Fundamentals, E82 A: 7.
5. Schmid, A., 2000. VLSI realisation of mixed analogdigital artificial neural networks dedicated to autonomous systems with on chip learning capability. Thesis No. 2101. Federal Polytechnique School of Lausanne EPFL.
6. Arima, Y., M. Murasaki, T. Yamada, A. Maeda and H. Shinohara, 1992. A refreshable analog VLSI neural network chip with 400 neurons and 40k synapses. IEEE J. Solid-state Circuits, 27: 12.
7. Zornetzer, S., J. Davis, C. Lau and T. McKenna, 1995. An Introduction to Neural and Electronic Network. Academic Press.
8. Kinoshita, S., T. Morie, M. Nagata and A. Iwata, 1999. New non-volatile analog memory circuits using PWM methods. IEICE Trans. Electron, E82-C: 9.
9. Weber, W., S.J. Prange, R. Thewes, E. Wohlarb and A. Luck, 1996. On the application of the neuron MOS transistor principle for modern VLSI design. IEEE Trans. Electron Device, 43: 1700-1708.
10. Shibata, T. and T. Ohmi, 1992. A functional MOS transistor featuring gate level weighted sum and threshold operations. IEEE, Trans. on Elec. Devices, 39: 6.
11. Shibata, T., H. Kosak and T. Ohmi, 1995. A neuroneMOS neural network using self-learning compatible synapses circuits, IEEE JSSC, 30: 8.
12. Diorio, C., P. Hasler, B.A. Minch and C.A. Mead, 1996. A single transistor silicon synapse. IEEE, Trans. Electron Devices, 43: 11.
13. Fujita, O. and Y. Amemiya, 1993. A floating-gate analog memory device for neural networks. IEEE Trans. Electron Device, 40: 11.
14. Djahanshahi, H., A. Ahmadi, G.A. Jullien and W.C. Miller, 1996. Design and VLSI implementation of a unified synapse-neurone architecture. Proc. 6th Great Symp. VLSI, pp: 228-232.
15. Coggins, R., M. Jabri, B. Flower and S. Pickard, 1995. A hybrid analog and digital VLSI neural network for intracardiac morphology classification. IEEE J. Solidstate Circuits, 30: 5.
16. Duong, T., S.P. Eberhardt, M. Tran, T. Daud and A.P. Thakoor, 1989. Learning and optimization with cascaded VLSI neural network building-block chips. Proc. 3rd Ann. Parallel Processing Symp., 1: 257-267. Fullerton, CA, IEEE Orange County Computer Society.
17. Chen, C.H., 1996. Fuzzy Logic and Neural Network Handbook. IEEE Press.
18. Raffel, J.I., 1988. Electronic implementation of neuromorphic systems. Proc. IEEE Custom Integrated Circuits Conf., pp: 10.1.1.
19. Koosh, V.F. and R. Goodman, 2001. VLSI neural network with digital weight and analog multipliers. Proc. IEEE Intl. Symp. Circuit and Systems, Sidney Australia, 2: 233-236.
20. Mirhassani, M., M. Ahmadi and W.C. Miller, 2003. A mixed-signal VLSI neural network with on-chip learning. Proc. 2003 Canadian IEEE Conf. Electrical and Computer Engineering, 1: 591-595.
21. Mirhassani, M., M. Ahmadi and W.C. Miller, 2003. A feed-forward time-multiplexed neural network with mixed-signal neuron-synapse arrays. Proc. Intl. Conference on VLSI, Las Vegas, USA, pp: 339-342.
22. Mirhassani, M., M. Ahmadi and W.C. Miller, 2006. A feed-forward time-multiplexed neural network with mixed-signal neuron-synapse arrays. Elsevier Microelectronic Engineering.
