Contents lists available at [ScienceDirect](www.sciencedirect.com/science/journal/09252312)

## Neurocomputing

 $j$  is a companion of  $\alpha$  is a companion of  $\alpha$ 

# Area-efficient robust Madaline based on continuous valued number system

### Babak Zamanlooy<sup>\*</sup>, Mitra Mirhassani

Department of Electrical and Computer Engineering, University of Windsor, Windsor, ON, Canada

#### article info

#### ABSTRACT

the product of neuron multiplied by NSR.

Article history: Received 18 August 2013 Received in revised form 24 February 2014 Accepted 2 March 2014 Communicated by R.W. Newcomb Available online 13 April 2014

Keywords: Neural networks VLSI implementation Noise-to-Signal Ratio (NSR) Continuous Valued Number System (CVNS)

#### 1. Introduction

Since the advent of artificial neural networks, software and hardware implementation methods have been used for their realization. The hardware implementation methods have been exploited in applications that require real-time and energyefficient processing [\[1](#page--1-0)–5].

Neural network hardware implementation methods may be classified as analog, digital or mixed-signal. In the analog implementation, both weight storage and processing are in the analog domain. When implemented by analog circuits, neural networks typically maintain a higher energy efficiency, a lower number of interconnections, and require less area, in comparison with its equivalent digital implementation. However, the capacitor-based weight storage methods require a refresh signal and are sensitive to process and power supply variations [\[6\].](#page--1-0) In the digital implementation of a neural network, both weight storage and processing are done in the digital domain. The third implementation method, mixed-signal, uses digital registers for weight storage and analog circuits for signal processing. This method exploits the ease of weight storage in digital registers while capitalizing on the advantages of analog domain such as compact addition and nonlinear neuron.

The basic theory behind the neural network can be essentially described as a series of weights, that when applied to distinct

E-mail addresses: [zamanlo@uwindsor.ca](mailto:zamanlo@uwindsor.ca) (B. Zamanlooy), [mitramir@uwindsor.ca](mailto:mitramir@uwindsor.ca) (M. Mirhassani).

<http://dx.doi.org/10.1016/j.neucom.2014.03.029> 0925-2312/© 2014 Elsevier B.V. All rights reserved. inputs, provide the appropriate corresponding output. Due to the limited word length available in hardware implementations of neural networks, inputs and weights are represented with finite precision; this degrades the output response. Therefore, the robustness to input and weight errors becomes a key issue in neural network architectures. To quantify this issue, the sensitivity of neural networks to input and weight imprecisions has been studied extensively [7–[14\]](#page--1-0).

Achieving a low Noise-to-Signal Ratio (NSR) is one of the major concerns when implementing hardwarebased neural networks. Continuous Valued Number System (CVNS) features have been exploited to improve the NSR. The efficiency of the network model in terms of area, power consumption, and NSR is measured using the product of the total number of neurons in the network multiplied by the network NSR, which indicates the number of neurons required for a specific NSR. The network proposed in this paper stores the weights in digital registers while the processing is done in the analog domain using CVNS arithmetic. The mathematical analysis and comparison between the proposed network and the previous structures prove that the proposed architecture improves upon in terms of both the NSR and

> The sensitivity analysis can be classified as one of the two approaches: the geometrical approach or the statistical approach. The geometrical method uses a hypersphere or a hyper-rectangle model to analyze the output sensitivity, while the statistical method determines the sensitivity by calculating the Noise-to-Signal Ratio (NSR). The NSR is defined as the ratio of the variance of output error to the variance of ideal output. Therefore, a network with a lower NSR is more tolerant to input and weight errors. In this paper, the statistical approach is utilized to study the effects of input and synaptic weight perturbations on the output.

> Alternative number system can be exploited to design low NSR neural network architectures. The Continuous Valued Number System (CVNS) is a mixed-signal number system in which its analog digits share information. This feature enables multiple error correction in a digit set  $[15]$  and makes this number system a candidate for implementing analog/mixed-signal neural networks with a low NSR  $[16-18]$  $[16-18]$ .

> A CVNS neural network is presented in [\[16\].](#page--1-0) This structure is analog, in which the synaptic weights are stored in the CVNS format and processing is accomplished using CVNS arithmetic. To decrease the output error, the output of the Adaline is







 $*$  Corresponding author. Tel.:  $+1$  519 992 0240.



generated based on the Reverse Evolution (RE) process [\[15\].](#page--1-0) This architecture is referred to as CVNS-RE in the rest of this paper.

Using the information redundancy present in the CVNS and the distributed neuron structure, two architectures named CVNS-DNN and CVNS-FDNN were developed in [\[17\]](#page--1-0). Similar to the CVNS-RE architecture, both of these structures store the weights in the CVNS format while the processing is carried out using CVNS arithmetic.

The previously developed CVNS neural network architectures [16–[18\]](#page--1-0) store synaptic weights in analog memories which require a refresh signal and are sensitive to process and power supply variations. Moreover, the NSR improvement of the previous architectures is achieved at the cost of extra neurons, which results in area overhead and increased power consumption. Although NSR is generally a suitable measure to show the effect of input and weight errors on the network output, the efficiency of different architectures cannot be measured by this quantity alone. A better indicator of the efficiency of a network model is the product of the total number of neurons in the network multiplied by the network NSR, this provides a better estimate in terms of area and power consumption for a specific NSR level.

To investigate the efficiency of various Madaline architectures based on the previous CVNS Adalines, mathematical analysis of NSR and neuron  $\times$  NSR of these architectures is required. It is<br>worth noting that only the NSR of CVNS Adalines has been worth noting that only the NSR of CVNS Adalines has been considered previously. The mathematical analysis performed in this paper allows the efficiency evaluation of different neural network architectures.

In this paper, a new mixed-signal Adaline is proposed. The proposed architecture stores the weights in digital registers while the arithmetic is based on the CVNS number system. Using digital registers to store weights eliminates the need for a refresh signal and provides a process and power supply variation tolerant storage mechanism, eliminating the problems caused by the analog weight storage methods used in the previous CVNS structures [16–[18\].](#page--1-0)

In the previously developed CVNS networks, the total number of analog memories required for each Adaline is proportional to the number of CVNS digits representing the synaptic weights. However, the total number of registers in the proposed CVNS Adaline is independent of the number of CVNS digits. This in turn results in reduced weight storage elements which lead to lower area overhead and lower power consumption. Furthermore, the RE process is used to decrease the error in the CVNS digits, which improves the NSR.

Using the proposed Adaline, a Madaline named CVNSdistributed is proposed. The CVNS-distributed Madaline uses the proposed CVNS Adaline at its output layer. The NSR and the neuron × NSR of the proposed Madaline is formulated and com-<br>nared with conventional lumped and distributed as well as pared with conventional lumped and distributed as well as previous CVNS structures. This analysis proves that the proposed architecture is more immune to input and weight errors while simultaneously requiring a lower number of neurons for a specific NSR, resulting in an architecture with a lower area overhead and lower power consumption. In this research, a three-layer Madaline is implemented in TSMC CMOS 0:18 μm. The implementation results confirm the advancement of the proposed Madaline in terms of NSR and the area consumption required for a specific NSR.

The rest of this paper is organized as follows. In the next section, CVNS is briefly introduced. The NSR and the stochastic model proposed by Piche [\[10\]](#page--1-0) is briefly discussed in [Section 3.](#page--1-0) Moreover, the NSR of previous Adalines is summarized in this section. The mathematical derivation of the total number of neurons and NSR of a Madaline, based on the previous structures, is provided in [Section 4,](#page--1-0) where the related equations are developed. The proposed Adaline and Madaline structure is explained in [Section 5.](#page--1-0) Comparisons with existing structures are carried out in [Section 6](#page--1-0). The VLSI implementation of a three-layer Madaline and comparisons with previous structures are conducted in [Section 7.](#page--1-0) Finally, conclusions are drawn in [Section 8.](#page--1-0)

#### 2. Continuous Valued Number System (CVNS)

The absolute value of a real number  $x$  using fixed-point number representation with a radix of B can be shown as follows:

$$
x = \sum_{i = -N_f}^{N_i - 1} x_i \times B^i
$$
 (1)

where  $N_i$  and  $N_f$  are the number of integer and fractional digits, respectively while  $x_i$  is the digit.

CVNS is a number system with continuous valued digits. CVNS analog digits representing the real number  $x$  can be generated as follows [\[15\]:](#page--1-0)

$$
((x))_i = (x \times B^{-i}) \text{mod } B
$$
 (2)

where  $((x))_i$  is the CVNS digit and  $-N_f \le i \le N_i - 1$ . An ensemble of CVNS digits  $((x))_{{}^{-1}((x))_{N_i-1},...,((x))_0,((x))_{-1},...,((x))_{-N_f}$  represents the input  $x$  in CVNS format.

Example: Finding the CVNS digit set of  $x=81.92$  with a radix of 10.

Download English Version:

# <https://daneshyari.com/en/article/406675>

Download Persian Version:

<https://daneshyari.com/article/406675>

[Daneshyari.com](https://daneshyari.com)