# **DVCC-Based Non-linear Feedback Neural Circuit for Solving System of Linear Equations**

**M. Samar Ansari · Syed Atiqur Rahman**

Received: 26 October 2009 / Revised: 20 April 2010 / Published online: 14 January 2011 © Springer Science+Business Media, LLC 2011

**Abstract** A neural circuit to solve a system of simultaneous linear equations is presented. The circuit employs non-linear feedback to achieve a transcendental energy function that ensures fast convergence to the exact solution while enjoying reduction in hardware complexity over existing schemes. A new building block for analog signal processing, the digitally controlled differential voltage current conveyor (DC-DVCC) is introduced and is utilized for the non-linear synaptic interconnections between neurons. The proof of the energy function has been given and it is shown that the gradient network converges exactly to the solution of the system of equations. PSPICE simulation results are presented for linear systems of equations of various sizes and are found to be in close agreement with the algebraic solution. The use of CMOS DC-DVCCs and operational amplifiers facilitates monolithic integration.

**Keywords** Neural network applications · Neural network hardware · Non-linear circuits · Linear algebra · Linear equations · Digitally Controlled DVCC

## **1 Introduction**

Solution of a system of simultaneous linear equations has been a primary goal for computation since the time of the abacus. References to word problems requiring the solution of a system of linear equations appear in ancient Babylonian texts dating back to *circa* 300 BC [\[3](#page-16-0)]. Some examples of applications requiring the solution of systems of linear equations are curve fitting, electrical circuit analysis, multiple cor-

M.S. Ansari (⊠) · S.A. Rahman

Department of Electronics Engineering, Aligarh Muslim University, Aligarh, India e-mail: [mdsamar@gmail.com](mailto:mdsamar@gmail.com)

S.A. Rahman e-mail: [syed.atiq.amu@gmail.com](mailto:syed.atiq.amu@gmail.com)

relation as well as real-time applications like real-time speech coding, image processing, stochastic modelling, and computer-aided realistic three-dimensional image synthesis  $[1, 3, 5, 10, 11]$  $[1, 3, 5, 10, 11]$  $[1, 3, 5, 10, 11]$  $[1, 3, 5, 10, 11]$  $[1, 3, 5, 10, 11]$  $[1, 3, 5, 10, 11]$  $[1, 3, 5, 10, 11]$  $[1, 3, 5, 10, 11]$  $[1, 3, 5, 10, 11]$  $[1, 3, 5, 10, 11]$  $[1, 3, 5, 10, 11]$ . Traditional methods for solving systems of linear equations typically involve an iterative process [[3\]](#page-16-0), but long computational time limits their usage. There is an alternative approach to the solution of this problem. It is to exploit the artificial neural networks (ANN's), which can be considered as an analog computer relying on a highly simplified model of neurons [[1,](#page-16-1) [5,](#page-16-2) [10,](#page-16-3) [11](#page-16-4)]. Massively parallel processing and fast convergence, which are inherent to neural networks, are utilized to reduce the time taken to arrive at the solution  $[1, 10, 11]$  $[1, 10, 11]$  $[1, 10, 11]$  $[1, 10, 11]$  $[1, 10, 11]$  $[1, 10, 11]$  $[1, 10, 11]$ . However, existing neural networks have variable penalty parameters which decrease to zero as time increases to infinity in order to get better accuracy of solution. Therefore, the time taken to arrive at the solution in such cases is not always short [[1,](#page-16-1) [10\]](#page-16-3).

Hardware solutions for solving a system of linear equations based on neural networks have been put forward by Xia, Wang and Hung [\[11](#page-16-4)], Cichocki and Unbehauen [\[1](#page-16-1)] and Wang [[10\]](#page-16-3). To solve an *n*-variable system of equations, the network of [\[10](#page-16-3)] uses three operational amplifiers, one capacitor and  $(n + 5)$  resistances to emulate a single neuron and the time to arrive at the solution is of the order of hundreds of milliseconds. The network of [[1\]](#page-16-1) provides a significantly improved solution time of around a microsecond but at the cost of increased hardware complexity. Each neuron in [\[1\]](#page-16-1) comprises three weighted summers and an inverting integrator. The architecture of [\[11](#page-16-4)], which is a generalized neural network based implementation of Censor and Elfving's method for linear inequalities, also uses an approach similar to [[10\]](#page-16-3), utilizing weighted adders and integrators to realize the neurons.

A new digital programmable architecture with fast convergence and reduced circuit complexity is presented. The proposed architecture uses non-linear feedback which leads to a new energy function that involves transcendental terms. This transcendental energy function is fundamentally different from the standard quadratic form associated with Hopfield network and its variations. The non-linear feedback is realized by utilizing a new building block viz. the digitally controlled differential voltage current conveyor (DC-DVCC). Along with presenting the analysis of the proposed circuit and the proof of the energy function, it is also shown that the stable state of the network corresponds exactly with the solution of the given system of linear equations. Further, the use of CMOS DC-DVCCs and opamps makes monolithic integration viable.

<span id="page-1-0"></span>This paper is organized as follows. A new digitally programmable analog building block (DC-DVCC) is presented in Sect. [2](#page-1-0). Section [3](#page-4-0) contains the details of the proposed network along with the design equations. Proofs of the energy function and validity of the solution are given in Sect. [4](#page-6-0). Section [5](#page-10-0) presents the results of SPICE simulation of the circuit applied to solve various sample equation sets. A discussion on VLSI implementability of the proposed circuit appears in Sect. [5](#page-10-0). Some conclusive remarks appear in Sect. [6.](#page-12-0)

## **2 Digitally Controlled DVCC**

The differential voltage current conveyor (DVCC) was proposed in 1997 [[2\]](#page-16-5) as a five terminal device characterized by the following port relations (Fig. [1](#page-2-0)):

<span id="page-2-0"></span>





<span id="page-2-2"></span><span id="page-2-1"></span>**Fig. 2** CMOS implementation of DVCC

$$
\begin{bmatrix} V_X \\ I_{Y_1} \\ I_{Y_2} \\ I_Z^+ \end{bmatrix} = \begin{bmatrix} 0 & 1 & -1 & 0 & 0 \\ 0 & 0 & 0 & 0 & 0 \\ 0 & 0 & 0 & 0 & 0 \\ k & 0 & 0 & 0 & 0 \\ k & 0 & 0 & 0 & 0 \end{bmatrix} \begin{bmatrix} I_X \\ V_{Y_1} \\ V_{Y_2} \\ V_Z^+ \end{bmatrix}
$$
 (1)

While the voltage on the *X*-terminal follows the difference in voltages of terminals *Y*<sup>1</sup> and *Y*2, a current injected at the *X*-terminal is replicated by a factor *k* to the *Z*terminals. For the  $Z^+$  terminal, the direction of the conveyed current is the same as that of the current flowing in the *X*-terminal whereas for the *Z*<sup>−</sup> terminal, the current flows in the opposite direction. Ideally, *k* is unity.

One possible CMOS realization of the DVCC is shown in Fig. [2](#page-2-1) [[6\]](#page-16-6). As can be seen, the current at  $Z^+$  port will be the same as the current in the X terminal and the current at the *Z*<sup>−</sup> terminal will have the same magnitude but opposite direction as the *X* port current.

Although both  $Z^+$  and  $Z^-$  types of current outputs are mentioned in ([1\)](#page-2-2), the DVCCs used in the proposed network use only  $Z^+$  type of outputs. Therefore, we next describe the proposed digitally controlled DVCC with only  $Z^+$  outputs. The technique is to control the current transfer gain parameter  $k$  of the DVCC by replacing the *Z* terminal transistors of the DVCC with transistor arrays associated with

<span id="page-3-0"></span>

**Fig. 3** CMOS realization of Digitally Controlled DVCC with gain *k*

switches [\[4](#page-16-7)]. The gain parameter *k* can take values from 1 to  $(2^n - 1)$ , where *n* represents the number of transistor arrays. Actually, the transistor arrays implement a current summing network (CSN) at the *Z* terminal. The circuit of DC-DVCC obtained after suitable modifications in the circuit of Fig. [2](#page-2-1) is presented in Fig. [3](#page-3-0).

The CSN consists of *n* transistor pairs, whose NMOS and PMOS aspect ratios are given by:

$$
\text{NMOS: } \left(\frac{W}{L}\right)_i = 2^i \left(\frac{W}{L}\right)_{11}, \quad i = 0, 1, 2, \dots, (n-1) \tag{2}
$$

PMOS: 
$$
\left(\frac{W}{L}\right)_i = 2^i \left(\frac{W}{L}\right)_7
$$
,  $i = 0, 1, 2, ..., (n-1)$  (3)

Therefore, the current at the *Z* terminal, assumed flowing out of the DC-DVCC, can be expressed by

$$
I_Z = \sum_{i=0}^{n-1} d_i 2^i (I_7 - I_{11})
$$
\n(4)

Therefore, the proposed DC-DVCC provides a current transfer gain equal to

$$
k = \frac{I_Z}{I_X} = \frac{\sum_{i=0}^{n-1} d_i 2^i (I_7 - I_{11})}{(I_7 - I_{11})} = \sum_{i=0}^{n-1} d_i 2^i
$$
 (5)

Parameter *di* represents the digital code-bit applied to the *i*th branch in the CSN. Depending upon its value, it enables or disables the current to flow in that particular branch. It is instructive to note the numbering of the transistors in the CSN. Transistors labeled  $M_{8(i)}$  and  $M_{12(i)}$  refer to the PMOS and NMOS transistors in the CSN that have been put there in the place of their counterparts of Fig. [2.](#page-2-1) Transistors  $MD_{8(i)}$ and  $M_{D12(i)}$  are the actual digital control transistors as the digital control bits  $d_0$ ,  $d_1$ and  $d_2$  are applied at their respective gate terminals.

<span id="page-4-3"></span><span id="page-4-1"></span>For the DC-DVCC, comparator action can be achieved by putting  $R_X \rightarrow 0$  i.e. by directly grounding the *X*-terminal [\[6](#page-16-6)]. For such a case, the current in the *X*-port will saturate and can be written as

$$
I_X = I_m \tanh \beta (V_{Y_1} - V_{Y_2})
$$
\n<sup>(6)</sup>

where  $\beta$  is the open-loop gain of the comparator (practically very high),  $\pm I_m$  are the saturated output current levels of the comparator and  $V_1, V_2, \ldots, V_n$  are the neuron outputs. Equation ([6\)](#page-4-1) can also be written in an equivalent notation as

$$
I_X = gV_m \tanh \beta (V_{Y_1} - V_{Y_2})
$$
\n<sup>(7)</sup>

where *g* is the transconductance from the input voltage ports  $(Y_1 \text{ and } Y_2)$  to the output current port *X* and is governed by the resistance at the *X* port; and  $\pm V_m$  are the biasing voltages of the DVCC-based comparator.

By virtue of DVCC action, this current will be transferred to the  $Z^+$  ports as

<span id="page-4-2"></span>
$$
I_Z^+ = kI_X = kg V_m \tanh \beta (V_{Y_1} - V_{Y_2})
$$
\n(8)

<span id="page-4-0"></span>Therefore, the current at the *Z* terminal can be made a digitally controlled scaled replica of the *X* port current. This property will be utilized in the design of the multioutput DVCCs needed for the proposed circuit. It may be mentioned that multiple *Z*<sup>+</sup> outputs can be obtained by repeating the output stage comprising transistors  $M_{8(i)}$ and  $M_{12(i)}$ .

#### **3 Proposed Neural Network**

Let the simultaneous linear equations to be solved are

$$
AV = B \tag{9}
$$

where

<span id="page-4-4"></span>
$$
\mathbf{A} = \begin{bmatrix} a_{11} & a_{12} & \dots & a_{1n} \\ a_{21} & a_{22} & \dots & a_{2n} \\ \vdots & \vdots & \dots & \vdots \\ a_{n1} & a_{n2} & \dots & a_{nn} \end{bmatrix}
$$
(10)  

$$
\mathbf{B} = \begin{bmatrix} b_1 \\ b_2 \\ \vdots \\ b_n \end{bmatrix}
$$
(11)  

$$
\Gamma V. \mathbf{I}
$$

$$
\mathbf{V} = \begin{bmatrix} V_1 \\ V_2 \\ \vdots \\ V_n \end{bmatrix}
$$
 (12)



<span id="page-5-0"></span>**Fig. 4** First neuron of the proposed digitally programmable, feedback neural circuit to solve simultaneous linear equations in *n*-variables

where  $V_1, V_2, \ldots, V_n$  are the variables and  $a_{ij}$  and  $b_i$  are constants. We will assume that the coefficient matrix **A** is invertible, and hence, the system of linear equations [\(9](#page-4-2)) is consistent and not under-determined. In other words, the linear system [\(9](#page-4-2)) has a uniquely determined solution.

The proposed neural network based circuit to solve the system of equations of [\(9](#page-4-2)) is presented in Fig. [4](#page-5-0). As can be seen from Fig. [4,](#page-5-0) individual equations from the set of equations to be solved are passed through non-linear synapses which are realized using multi-output DC-DVCC based comparators.

<span id="page-5-1"></span>The outputs of the comparators are fed to neurons having weighted inputs. These weighted neurons are realized by using opamps where the scaled currents coming from various comparators act as weights.  $R_{pi}$  and  $C_{pi}$  are the input resistance and capacitance of the opamp corresponding to the *i*th neuron. These parasitic components are included to model the dynamic nature of the opamp.

<span id="page-5-2"></span>Node equation for node '*Ni*' gives the equation of motion of the *i*th neuron as

$$
C_{pi} \frac{du_i}{dt} = k_{1i} I_{X_1} + k_{2i} I_{X_2} + \dots + k_{ni} I_{X_n} - u_i \left[ \frac{1}{R_{pi}} \right] \tag{13}
$$

where  $u_i$  is the internal state of the *i*th neuron and  $k_{ji}$  is the current scaling factor at the *j* th output of *i*th DVCC. Using [\(7\)](#page-4-3) in [\(13](#page-5-1)) results in

$$
C_{pi} \frac{du_i}{dt} = k_{1i} g V_m \tanh \beta (a_{11} V_1 + a_{12} V_2 + \dots + a_{1n} V_n - b_1)
$$
  
+  $k_{2i} g V_m \tanh \beta (a_{21} V_1 + a_{22} V_2 + \dots + a_{2n} V_n - b_2) + \dots$   
+  $k_{ni} g V_m \tanh \beta (a_{n1} V_1 + a_{n2} V_2 + \dots + a_{nn} V_n - b_n) - \frac{u_i}{R_{pi}}$  (14)

<span id="page-6-2"></span><span id="page-6-1"></span>Moreover, as has been shown in Sect. [4,](#page-6-0) the network in Fig. [4](#page-5-0) can be associated with an Energy Function '*E*' given by

$$
E = V_m \sum_{i=1}^{n} \ln \cosh \beta \left( \sum_{j=1}^{n} a_{ij} V_j - b_i \right) - \sum_{i=1}^{n} \frac{1}{R_i} \int_0^{V_i} u_i \, dV_i \tag{15}
$$

From [\(15](#page-6-1)), it follows that

<span id="page-6-3"></span>
$$
\frac{\partial E}{\partial V_1} = V_m a_{11} \tanh \beta (a_{11} V_1 + a_{12} V_2 + \dots + a_{1n} V_n - b_1)
$$
  
+  $V_m a_{21} \tanh \beta (a_{21} V_1 + a_{22} V_2 + \dots + a_{2n} V_n - b_2) + \dots$   
+  $V_m a_{n1} \tanh \beta (a_{n1} V_1 + a_{n2} V_2 + \dots + a_{nn} V_n - b_n) - u_1 \left[ \frac{1}{R_{p1}} \right]$  (16)

Also, if  $E'$  is the energy function, it must satisfy the following condition [\[8](#page-16-8)].

$$
\frac{\partial E}{\partial V_i} = K_R C_{pi} \frac{du_i}{dt}
$$
 (17)

where  $K_R$  is a constant of proportionality having the dimensions of resistance and is normalized to  $(1/g)$  for simplicity.

<span id="page-6-0"></span>Comparing  $(14)$  $(14)$  and  $(16)$  $(16)$  according to  $(17)$  $(17)$  yields

$$
\begin{bmatrix} k_{11} & k_{12} & \dots & k_{1n} \\ k_{21} & k_{22} & \dots & k_{2n} \\ \vdots & \vdots & \dots & \vdots \\ k_{n1} & k_{n2} & \dots & k_{nn} \end{bmatrix} = \begin{bmatrix} a_{11} & a_{12} & \dots & a_{1n} \\ a_{21} & a_{22} & \dots & a_{2n} \\ \vdots & \vdots & \dots & \vdots \\ a_{n1} & a_{n2} & \dots & a_{nn} \end{bmatrix}
$$
 (18)

#### **4 Energy Function**

## 4.1 Proof of the Energy Function

Differentiating the energy function of  $(15)$  $(15)$  w.r.t.  $V_i$ , we get

$$
\frac{\partial E}{\partial V_i} = V_m a_{1i} \tanh \beta (a_{11} V_1 + a_{12} V_2 + \dots + a_{1n} V_n - b_1)
$$
  
+  $V_m a_{2i} \tanh \beta (a_{21} V_1 + a_{22} V_2 + \dots + a_{2n} V_n - b_2) + \dots$   
+  $V_m a_{ni} \tanh \beta (a_{n1} V_1 + a_{n2} V_2 + \dots + a_{nn} V_n - b_n) - \frac{u_i}{R_{pi}}$  (19)

Further, the time derivative of the energy function is given by

$$
\frac{dE}{dt} = \sum_{i=1}^{N} \frac{\partial E}{\partial V_i} \frac{dV_i}{dt} = \sum_{i=1}^{N} \frac{\partial E}{\partial V_i} \frac{dV_i}{du_i} \frac{du_i}{dt}
$$
(20)

Using  $(12)$  $(12)$  in  $(15)$  $(15)$  we get

<span id="page-7-0"></span>
$$
\frac{dE}{dt} = \sum_{i=1}^{N} KC_i \left(\frac{du_i}{dt}\right)^2 \frac{dV_i}{du_i}
$$
\n(21)

The transfer characteristics of the output opamp used in Fig. [4](#page-5-0) implements the activation function of the neuron. With  $u_i$  being the inverting terminal, it is monotonically decreasing and it can be seen that [[8\]](#page-16-8)

$$
\frac{dV_i}{du_i} \le 0\tag{22}
$$

thereby resulting in

$$
\frac{dE}{dt} \le 0\tag{23}
$$

with the equality being valid for

$$
\frac{du_i}{dt} = 0; \quad \text{for all } i \tag{24}
$$

Equation [\(23\)](#page-7-0) shows that the energy function can never increase with time which is one of the conditions for a valid energy function. The second criterion viz. the energy function must have a lower bound is also satisfied for the circuit of Fig. [4](#page-5-0) wherein it may be seen that  $V_1, V_2, \ldots, V_n$  are all bounded (as they are the outputs of opamps) amounting to '*E*', as given in [\(15](#page-6-1)), having a defined lower bound.

#### 4.2 Stable States of the Network

Convergence of the network to the global minimum of the energy function, which is exactly the solution of the set of linear equations, and the fact that there are no other minima, can be shown as follows.

For *n* variables, the second term in the energy function expression  $(15)$  $(15)$  is significant only near the saturating values of the opamp and is usually neglected [\[9](#page-16-9)]. The energy function can therefore be expressed as

$$
E = V_m \sum_{i=1}^{n} \ln \cosh \beta \left( \sum_{j=1}^{n} a_{ij} V_j - b_i \right)
$$
 (25)

from which it follows that

$$
\frac{\partial E}{\partial V_1} = V_m a_{11} \tanh \beta (a_{11} V_1 + a_{12} V_2 + \dots + a_{1n} V_n - b_1)
$$
  
+ 
$$
V_m a_{21} \tanh \beta (a_{21} V_1 + a_{22} V_2 + \dots + a_{2n} V_n - b_2) + \dots
$$
  
+ 
$$
V_m a_{n1} \tanh \beta (a_{n1} V_1 + a_{n2} V_2 + \dots + a_{nn} V_n - b_n)
$$
 (26)

$$
\frac{\partial E}{\partial V_2} = V_m a_{12} \tanh \beta (a_{11} V_1 + a_{12} V_2 + \dots + a_{1n} V_n - b_1)
$$
  
+  $V_m a_{22} \tanh \beta (a_{21} V_1 + a_{22} V_2 + \dots + a_{2n} V_n - b_2) + \dots$   
+  $V_m a_{n2} \tanh \beta (a_{n1} V_1 + a_{n2} V_2 + \dots + a_{nn} V_n - b_n)$  (27)  
:  

$$
\frac{\partial E}{\partial V_n} = V_m a_{1n} \tanh \beta (a_{11} V_1 + a_{12} V_2 + \dots + a_{1n} V_n - b_1)
$$
  
+  $V_m a_{2n} \tanh \beta (a_{21} V_1 + a_{22} V_2 + \dots + a_{2n} V_n - b_2) + \dots$   
+  $V_m a_{nn} \tanh \beta (a_{n1} V_1 + a_{n2} V_2 + \dots + a_{nn} V_n - b_n)$  (28)

For a stationary point, we have

$$
\begin{aligned}\n\frac{\partial E}{\partial V_1} &= 0\\ \n\frac{\partial E}{\partial V_2} &= 0\\ \n\vdots\\
\frac{\partial E}{\partial V_n} &= 0\n\end{aligned}
$$
\n(29)

which yields

$$
a_{11} \tanh \beta (a_{11}V_1 + a_{12}V_2 + \dots + a_{1n}V_n - b_1)
$$
  
+ 
$$
a_{21} \tanh \beta (a_{21}V_1 + a_{22}V_2 + \dots + a_{2n}V_n - b_2) + \dots
$$
  
+ 
$$
a_{n1} \tanh \beta (a_{n1}V_1 + a_{n2}V_2 + \dots + a_{nn}V_n - b_n) = 0
$$
 (30)

$$
a_{12} \tanh \beta (a_{11} V_1 + a_{12} V_2 + \dots + a_{1n} V_n - b_1)
$$
  
+ 
$$
a_{22} \tanh \beta (a_{21} V_1 + a_{22} V_2 + \dots + a_{2n} V_n - b_2) + \dots
$$
  
+ 
$$
a_{n2} \tanh \beta (a_{n1} V_1 + a_{n2} V_2 + \dots + a_{nn} V_n - b_n) = 0
$$
 (31)

$$
a_{1n} \tanh \beta (a_{11}V_1 + a_{12}V_2 + \dots + a_{1n}V_n - b_1)
$$
  
+ 
$$
a_{2n} \tanh \beta (a_{21}V_1 + a_{22}V_2 + \dots + a_{2n}V_n - b_2) + \dots
$$
  
+ 
$$
a_{nn} \tanh \beta (a_{n1}V_1 + a_{n2}V_2 + \dots + a_{nn}V_n - b_n) = 0
$$
 (32)

Denoting

$$
\tanh \beta (a_{11}V_1 + a_{12}V_2 + \dots + a_{1n}V_n - b_1) = A_1
$$
\n(33)

$$
\tanh \beta (a_{21}V_1 + a_{22}V_2 + \dots + a_{2n}V_n - b_2) = A_2 \tag{34}
$$

$$
\vdots
$$
\n
$$
\tanh \beta (a_{n1}V_1 + a_{n2}V_2 + \dots + a_{nn}V_n - b_n) = A_n
$$
\n(35)

<span id="page-9-0"></span>Therefore, for a stationary point we have

$$
\begin{bmatrix} a_{11} & a_{12} & \dots & a_{1n} \\ a_{21} & a_{22} & \dots & a_{2n} \\ \vdots & \vdots & \dots & \vdots \\ a_{n1} & a_{n2} & \dots & a_{nn} \end{bmatrix} \begin{bmatrix} A_1 \\ A_2 \\ \vdots \\ A_n \end{bmatrix} = \begin{bmatrix} 0 \\ 0 \\ \vdots \\ 0 \end{bmatrix}
$$
 (36)

This is a homogeneous system of linear equations in variables  $A_1, A_2, \ldots, A_n$ . Since the coefficient matrix of the set of  $(36)$  $(36)$  is the same as that of  $(9)$  $(9)$  which is invertible, it follows that ([36\)](#page-9-0) will have a uniquely determined solution which is the trivial solution of the homogeneous system.

Therefore,

$$
\begin{bmatrix} A_1 \\ A_2 \\ \vdots \\ A_n \end{bmatrix} = \begin{bmatrix} 0 \\ 0 \\ \vdots \\ 0 \end{bmatrix}
$$
 (37)

which results in

$$
a_{11}V_1 + a_{12}V_2 + \dots + a_{1n}V_n - b_1 = 0
$$
  
\n
$$
a_{21}V_1 + a_{22}V_2 + \dots + a_{2n}V_n - b_2 = 0
$$
  
\n
$$
\vdots
$$
  
\n
$$
a_{n1}V_1 + a_{n2}V_2 + \dots + a_{nn}V_n - b_n = 0
$$
\n(38)

Thus, the energy function of the proposed neural network has a unique stationary point which coincides exactly with the solution of the given system of linear equations.

This energy function can be visualized in three dimensions for a two-variable problem and is shown in Fig. [5.](#page-9-1) From the plot, it can be seen that there exists only one minimum, to which the network must converge.



<span id="page-9-1"></span>**Fig. 5** Typical energy function plot for a two-variable problem

## <span id="page-10-1"></span><span id="page-10-0"></span>**5 PSPICE Simulation Results**

The proposed circuit was tested using PSPICE simulation program for solving sets of two, three, four, five and 10 simultaneous linear equations. The application of the proposed circuit to a chosen three-variable problem ([39\)](#page-10-1) is presented below.

$$
\begin{bmatrix} 2 & 1 & 1 \ 3 & 2 & 1 \ 1 & 1 & 2 \end{bmatrix} \begin{bmatrix} V_1 \ V_2 \ V_3 \end{bmatrix} = \begin{bmatrix} 5 \ 10 \ 6 \end{bmatrix}
$$
 (39)

The circuit to solve ([39\)](#page-10-1) as obtained from Fig. [4](#page-5-0) is presented in Fig. [6](#page-10-2). The values of the current scaling coefficients  $k_{ji}$  are given as

$$
\begin{bmatrix} k_{11} & k_{12} & k_{13} \\ k_{21} & k_{22} & k_{23} \\ k_{31} & k_{32} & k_{33} \end{bmatrix} = \begin{bmatrix} 2 & 1 & 1 \\ 3 & 2 & 1 \\ 1 & 1 & 2 \end{bmatrix}
$$
 (40)

For implementing these values of  $k_{ji}$  appropriate values of the control words were selected. For the first DC-DVCC, the three control words were kept as [010], [001]



<span id="page-10-2"></span>**Fig. 6** The proposed circuit applied to a three-variable problem



<span id="page-11-0"></span>**Fig. 7** Simulation results for the chosen three-variable problem

and  $[0\ 0\ 1]$ . Similarly, the control words for the second DC-DVCC were  $[0\ 1\ 1]$ , [0 1 0] and [0 0 1]. Finally, for the third DC-DVCC the control words were [0 0 1], [0 0 1] and [0 1 0]. Thus, a proper selection of the control words can be used to achieve any current scaling factor between 1 and 7 and therefore this particular realization is restricted to solving systems of equations with coefficients in that range. However, that range may be widened further by having four control bits in the CSN.

As can be seen, some additional circuitry is needed to generate the inputs to the non-linear synapses. Routine analysis yields the following values of the resistors at the input of the non-linear synapses.

$$
R_{e11} = 2.5 \text{ K}, \quad R_{e12} = R_{e13} = R_{e14} = 5 \text{ K}, \quad R_{e21} = 3.33 \text{ K}, \quad R_{e22} = 5 \text{ K},
$$
  
\n $R_{e23} = 10 \text{ K}, \quad R_{e24} = 2.5 \text{ K}, \quad R_{e31} = R_{e32} = 6 \text{ K}, \quad R_{e33} = R_{e34} = 3 \text{ K},$   
\n $R_{c11} = R_{c21} = R_{c31} = 1 \text{ K}, \quad R_{c12} = 4 \text{ K}, \quad R_{c22} = 9 \text{ K}, \quad R_{c32} = 5 \text{ K}.$ 

Algebraic analysis of ([39\)](#page-10-1) gives the solution as  $V_1 = -0.5$  V,  $V_2 = 5.5$  V and  $V_3 = 0.5$  V. The results of PSPICE simulation of the circuit of Fig. [6,](#page-10-2) shown in Fig. [7,](#page-11-0) are found to match perfectly with the algebraic solution. The initial node voltages were kept as  $V(1) = 10$  mV,  $V(2) = -10$  mV and  $V(3) = 20$  mV. The circuit for DVCC was taken from [\[6](#page-16-6)] and standard 0.5 micron CMOS parameters were used for simulation purposes. The DVCCs were biased with  $\pm$ 2.5 V supplies. For the opamp, use was made of the LMC7101A CMOS opamp from National Semiconductor. The sub-circuit file for this opamp is available in Orcad Model Library. The



<span id="page-12-1"></span>**Fig. 8** Transfer characteristics of the DC-DVCC used to realize the comparator

biasing voltages for the opamps were taken to be  $\pm 15$  V. The transfer characteristics of the DVCC-based comparator, shown in Fig. [8,](#page-12-1) were also plotted using SPICE simulation and value of ' $\beta$ ' was found to be  $2.4 \times 10^3$ .

<span id="page-12-0"></span>The proposed circuit was further tested in PSPICE for solving systems of linear equations in two, four, five, and ten variables. Results of simulation runs for these problems are presented in Table [1.](#page-13-0) Each of the simulations was run using various initial conditions in the millivolt range. As can be seen from Table [1](#page-13-0), the proposed network always converges to the solution of the given system of linear equations. As can be seen, the obtained results are quite near the algebraic solutions with the maximum error being approximately 6% and the average error being 0.49%.

## **6 Performance Evaluation**

This section deals with the effect of component mismatches and device non-idealities on the accuracy of the solution obtained from the circuit proposed.

If the proposed circuit is implemented using discrete resistances, variations in the values of the resistances need to be considered keeping in mind the tolerances associated with discrete resistors. However, if the proposed network is targeted for monolithic integration, *random* variations in the resistance values need not be considered. In that case, all the resistances are expected to deviate from their assigned values by the same factor [\[7](#page-16-10)]. Therefore, a worthy performance appraisal of the circuit could be obtained by testing the circuit with all resistances having the same percentage deviation from their assigned values. Such an assessment of the quality of the obtained solution is presented in Table [2](#page-13-1) from which it can be seen that the percentage error

| [A]                                                                                                                                          | $[\mathbf{B}]$                                                                             | Algebraic<br>Solution<br>[V]                                                                                      | Simulated Results<br>(Using PSPICE)<br>[V]                                                      | Percentage Error<br>in the solution $(\%)$                                                       |
|----------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------|
| $\begin{bmatrix} 1 & 2 \\ 2 & 1 \end{bmatrix}$                                                                                               | $\left[\begin{smallmatrix} 3.5\\4 \end{smallmatrix}\right]$                                | $\begin{bmatrix} 1.5 \\ 1 \end{bmatrix}$                                                                          | $\left[\begin{smallmatrix} 1.51\ 1.02 \end{smallmatrix}\right]$                                 | $\begin{bmatrix} -0.66 \\ -2.00 \end{bmatrix}$                                                   |
| 211<br>321<br>111                                                                                                                            | $\begin{bmatrix} 5 \\ 10 \end{bmatrix}$<br>$6-$                                            | $-0.5$<br>5.5<br>0.5                                                                                              | $-0.52$<br>5.54<br>0.48                                                                         | $\begin{bmatrix} -4.00 \\ -0.72 \end{bmatrix}$<br>4.00                                           |
| 2361<br>3254<br>2552<br>$.2425$ $\Box$                                                                                                       | $48.75 -$<br>67.5<br>54<br>$59.25 -$                                                       | 3.5<br>1.5<br>5<br>$7.25 -$                                                                                       | $3.51$ <sup>-</sup><br>1.53<br>5.09<br>$7.19 -$                                                 | $-0.28$ <sup>-</sup><br>$-2.00$<br>$-1.80$<br>0.83                                               |
| 23925<br>26995<br>26245<br>24783<br>$\lfloor 53635 \rfloor$                                                                                  | $-54.9$ <sup>-</sup><br>$-91.0$<br>$-54.9$<br>$-74.8$<br>$-70.0$                           | $-6.7$<br>$-4.3$<br>$-2.8$<br>$-3.3$<br>$0.64 -$                                                                  | $-6.65$ <sup>-</sup><br>$-4.33$<br>$-2.63$<br>$-3.19$<br>0.63                                   | 0.75<br>$-0.69$<br>6.07<br>3.33<br>1.56                                                          |
| -1213421112-<br>2113122123<br>1143311441<br>4215331122<br>1151212252<br>3312115211<br>5514113422<br>1112223341<br>4221325432<br>└1231231234┘ | 10 <sub>7</sub><br>$-11$<br>10<br>$\frac{2}{-7}$<br>$-9$<br>$-8$<br>$-3$<br>$\frac{-3}{7}$ | $\cdot$ 2<br>$\mathbf{1}$<br>3<br>$-1$<br>$\sqrt{2}$<br>$\overline{7}$<br>$-3$<br>$\overline{4}$<br>$-5$<br>$-4-$ | $-1.91$<br>1.04<br>3.05<br>$-0.95$<br>1.94<br>7.04<br>$-3.06$<br>3.99<br>$-4.91$<br>$-3.95$ $-$ | $4.50 -$<br>$-4.00$<br>$-1.66$<br>5.00<br>3.00<br>$-0.57$<br>$-2.00$<br>0.25<br>1.80<br>$1.25 -$ |

<span id="page-13-0"></span>Table 1 PSPICE Simulation results for the proposed circuit applied to different systems of linear equations

<span id="page-13-1"></span>**Table 2** Effect of variation in resistances on the obtained results

| Percentage Variation<br>in Resistances | Simulated Results<br>(Using PSPICE)<br>[V]               | Percentage Error in<br>the Solution $(\%)$            |
|----------------------------------------|----------------------------------------------------------|-------------------------------------------------------|
| $+2\%$                                 | $\begin{bmatrix} -0.508 \\ 5.602 \\ 0.499 \end{bmatrix}$ | $\begin{vmatrix} +1.0 \\ +1.85 \\ -0.2 \end{vmatrix}$ |
| $+5\%$                                 | $\begin{bmatrix} -0.509 \\ 5.619 \\ 0.501 \end{bmatrix}$ | $\begin{vmatrix} +1.8 \\ +2.16 \\ +0.2 \end{vmatrix}$ |
| $+10%$                                 | $\begin{bmatrix} -0.514 \\ 5.681 \\ 0.507 \end{bmatrix}$ | $\begin{vmatrix} +2.8 \\ +3.29 \\ +1.4 \end{vmatrix}$ |
| $-2\%$                                 | $\begin{bmatrix} -0.507 \\ 5.601 \\ 0.505 \end{bmatrix}$ | $\begin{vmatrix} +1.4 \\ +1.83 \\ +1 \end{vmatrix}$   |
| $-5\%$                                 | $\begin{bmatrix} -0.518 \\ 5.679 \\ 0.506 \end{bmatrix}$ | $\begin{vmatrix} +3.6 \\ +3.25 \\ +1.2 \end{vmatrix}$ |
| $-10\%$                                | $\begin{bmatrix} -0.516 \\ 5.678 \\ 0.504 \end{bmatrix}$ | $\begin{bmatrix} +3.2 \\ +3.23 \\ +0.8 \end{bmatrix}$ |

<span id="page-14-0"></span>

in the solution varies with the percentage errors specified in the values of the resistances and even for  $\pm 10\%$  variation in the values of the resistors, the solution point changes by approximately 3%.

Further, the gains of the DVCC-based comparators were varied to investigate their effect on the solution quality. Toward that end, a resistance was connected between the *X*-terminal of each DVCC and ground. Ideally, these resistances were assumed to have zero value. However, by assigning different values to these resistances, the gains of the DVCCs were varied. The solutions, as obtained for the three-variable problem of Fig. [6,](#page-10-2) are presented in Table [3](#page-14-0). It can be seen that small variations in the gains of the comparators do not affect the quality of the solution.

Next, the effect of offset voltages in the DVCC-based comparators was explored. Offset voltages were applied at the  $Y_2$  inputs of the DVCCs of Fig. [6](#page-10-2) and the results of PSPICE simulations were compared with the algebraic solution as given in Table [4](#page-15-0). As can be seen, the offset voltages of the comparators do not affect the obtained solutions to any appreciable extent. However, the error does tend to increase with increasing offset voltages.

Finally, offset voltages for the opamps were also considered. Offset voltages were applied at the non-inverting inputs of the opamps of Fig. [6](#page-10-2) and the results of PSPICE simulations were compared with the algebraic solution as given in Table [5.](#page-15-1) As can be seen, the offset voltages of the opamps have little effect on the obtained solutions.

## **7 Conclusion**

In this paper we have described a novel approach to solve *n* simultaneous linear equations in *n* variables, which uses *n* neurons and *n* synapses. Each neuron requires one opamp and each synapse is implemented using one comparator. The comparators were realized using a new digitally controlled DVCC. This results in significant reduction in hardware over the existing schemes [[1,](#page-16-1) [5](#page-16-2), [10](#page-16-3), [11\]](#page-16-4). From VLSI implementation point of view, use of CMOS DC-DVCCs and opamps facilitates viability for monolithic integration.

The working of the proposed network was verified using PSPICE for various sample problem sets of two to 10 simultaneous linear equations. While the simulation

<span id="page-15-0"></span>

<span id="page-15-1"></span>



results confirm the validity of the approach, issues such as the network response to a system of equations which do *not* have a unique solution are yet to be explored. It may be mentioned that the technique can be extended to the standard linear and quadratic programming problems.

## <span id="page-16-7"></span><span id="page-16-5"></span><span id="page-16-1"></span><span id="page-16-0"></span>**References**

- <span id="page-16-2"></span>1. A. Cichocki, R. Unbehauen, Neural networks for solving systems of linear equations and related problems. IEEE Trans. Circuits Syst.—I **39**(2), 124–138 (1992)
- <span id="page-16-6"></span>2. H.O. Elwan, A.M. Soliman, Novel CMOS differential voltage current conveyor and its applications. IEE Proc. Circuits Devices Syst. **144**(3), 195–200 (1997)
- <span id="page-16-10"></span>3. J.L. Gustafson, The quest for linear equation solvers and the invention of electronic digital computing, in *Proc. JVA'06, IEEE John Vincent Atanasoff 2006 International Symposium on Modern Computing* (2006)
- <span id="page-16-9"></span><span id="page-16-8"></span>4. T.M. Hassan, S.A. Mahmoud, Fully programmable universal filter with independent gain-*ωo*-*Q* control based on new digitally programmable CMOS CCII. J. Circuits Syst. Comput. **18**(5), 875–897 (2009)
- <span id="page-16-3"></span>5. D. Jiang, Analog computing for real-time solution of time-varying linear equations. Proc. ICCCAS **2**, 27–29 (2004)
- <span id="page-16-4"></span>6. S. Maheshwari, A canonical voltage-controlled VM-APS with a grounded capacitor. Circuits Syst. Signal Process. **27**, 123–132 (2008)
- 7. J.D. Plummer, M.D. Deal, P.B. Griffin, *Silicon VLSI Technology: Fundamentals, Practices and Modeling* (Pearson Education, Upper Saddle River, 2009)
- 8. S.A. Rahman, Jayadeva, S.C. Duttaroy, Neural network approach to graph colouring. Electron. Lett. **35**(14), 1173–1175 (1999)
- 9. D.W. Tank, J.J. Hopfield, Simple neural optimization networks: an A/D converter, signal decision network, and linear programming circuit. IEEE Trans. Circuits Syst. CAS **33**(5), 533–541 (1986)
- 10. J. Wang, Electronic realization of recurrent neural network for solving simultaneous linear equations. Electron. Lett. **28**(5), 493–495 (1992)
- 11. Y. Xia, J. Wang, D.L. Hung, Recurrent neural networks for solving linear inequalities and equations. IEEE Trans. Circuits Syst.—I **46**(4) (1999)