## ANALOG INTEGRATED NEURAL-LIKE CIRCUITS FOR NONLINEAR PROGRAMMING

Angel Rodríguez-Vázquez 1, Rafael Domínguez-Castro 1, José L. Huertas 1 and Edgar Sánchez-Sinencio 2

Departamento de Electrónica y Electromagnetismo, Universidad de Sevilla, 41012-Sevilla, SPAIN
 Department of Electrical Engineering, Texas A&M University, College Station, TX 77843, USA

A systematic approach is presented for the design of analog "neural" nonlinear programming solvers using Switched-Capacitor (SC) integrated circuit techniques. The method is based on formulating a dynamic gradient system method is based on formulating a dynamic gradient system whose state evolves in time towards the solution point of the corresponding programming problem. A "neuron" cell for the linear and the quadratic problem suitable for monolithic implementation is introduced. The design of this "neuron" and its corresponding "synapses" using SC techniques are considered in detail. A SC circuit architecture based on a reduced set of basic building blocks with high modularity is presented. Simulation results using a mixed-mode simulator (DIANA) [1] and experimental results from the advantage of prototypes are included illustrating the breadboard prototypes are included, illustrating the validity of the proposed techniques.

## I. Introduction.

Linear and Nonlinear Programming Solvers are a class of analog "neural" optimizers intended for the solution of constrained optimization problems (also called nonlinear programming problems) in real time. Tank and Hopfield [2] proposed a linear programming solver with a "neural" organization. In more recent papers, [3] [4], it is demonstrated that the network of Tank and Hopfield obey the same unifying stationary theorem as the canonical the same unifying stationary theorem as the canonical nonlinear programming circuit previously reported by Chua and Lin [5]. Kennedy and Chua's analysis, [3] [4], also yields a relationship between the solution of the network and that of the optimization problem, thus providing the foundations of a synthesis procedure for "neural" nonlinear programming solvers.

The main drawback of the circuits by Kennedy and Chua and Tank and Hopfield is that they rely on conventional RCactive design techniques which are not the best suited for monolithic implementation, specially taking into account that accurate resistor ratios and large RC values are required. In this paper we try to overcome this drawback by focusing on the design of programming solvers using switched-capacitor techniques. The inherent programmability and reconfigurability of SC circuits together with the maturity of this technique [6] in the field of analog VLSI justify the interest of our approach.

## II. Synthesis technique.

# The unconstrained problem.

Multiparameter optimization can be defined as the process of finding, in the parameter space, a point  $\tilde{x}^r = \{x_1, x_2, \dots, x_N\}$  where a cost function  $\Psi(\tilde{x})$  is minimized. Optimization in classical analog computers, [7] [8], was accomplished by implementing the following companion dynamic gradient system,

$$\frac{d\mathbf{x}}{dt} = -\frac{1}{\iota} \nabla \Psi(\mathbf{x}) \qquad , \ \iota > 0 \tag{1}$$

When  $d\bar{x}/dt = \tilde{o}$  for this system, implies that  $\nabla \Psi = \tilde{o}$ , that is, the equilibrium of the gradient system coincides either with a local extreme (minimum or maximum) or with an inflection point of the corresponding cost function. On the other hand, since, for  $\tau > 0$ ,  $d\ddot{x}/dt$  and  $\nabla \Psi$  are opposite vectors, the time evolution of  $\ddot{x}$  will result in  $\Psi(\ddot{x})$  becoming smaller and smaller as time goes on. Therefore, the process of seeking for equilibrium of the companion gradient system of a cost function,  $\Psi(\tilde{\mathbf{x}})$ , actually yields minimization of this

#### The constrained problem.

Consider the following general nonlinear programming problem [9].

Minimize 
$$\Phi(x_p,x_2,\dots,x_N)$$
 subject to the constraints, 
$$F_k(x_p,x_2,\dots,x_N)\geq 0 \ ; \ 1\leq k\leq Q$$

where N and Q are two independent integers.

To solve this problem by a gradient scheme, like that in (1), we convert it in an equivalent unconstrained problem. The way to do this is to define a pseudo-cost function  $\Psi(\tilde{\mathbf{x}})$  as follows.

$$\Psi(\mathbf{x}) = \Phi(\mathbf{x}) + \mu P(\mathbf{x}) \tag{3}$$

where  $\Phi(\tilde{\mathbf{x}})$  is the original cost function,  $P(\tilde{\mathbf{x}})$  is referred to as the penalty function and µ is a real parameter called penalty multiplier.

Different penalty function alternatives can be used in practice. For a function to qualify as a valid penalty function it must monotonically increase as we move away from the region defined by the constraints (feasibility

region), that is, it must monotonically increase as the constraints  $F_k(\cdot)$  decrease from zero [10].

A drawback of the pseudocost function in (3) is that the penalty multiplier  $\mu$  has to be made large enough to yield penalty dominance outside the feasibility region and thus to guarantee that the minimum of the pseudo-cost function is inside the feasibility region. Here, we propose an alternative pseudo-cost function which does not require very large penalty parameter values,

$$\Psi_{m}(\mathbf{x}) = U(\mathbf{F})\Phi(\mathbf{x}) + \mu P(\mathbf{x})$$
 (4a)

where we define.

$$U(\mathbf{F}) = \begin{cases} 1, & \text{if } F_k \ge 0 & \text{for every } k \\ 0, & \text{otherwise} \end{cases}$$
 (4b)

In (4a), the function  $\Phi(\tilde{\mathbf{x}})$  is disconnected outside the region is guaranteed no matter what the actual value of p is. Besides, since the penalty gradient is different from zero at any point, the solution point is forced to be either inside the feasibility region or just at the boundaries.

# III. SC circuits for "neural" programming solvers.

# SC building blocks.

The basic SC "neuron": Figure 1a shows the basic switched-capacitor "neuron" for quadratic programming. The clock signals controlling the switches are shown in

Analysis of Fig.1 by using charge conservation principles

$$y_{out}^{o}(n+\frac{1}{2}) = \sum_{j=1}^{M} U_{j}(s_{j}) h_{j} [y_{j}^{e+}(n) - y_{j}^{e-}(n)] + y_{out}^{e}(n)$$

$$y_{out}^{e}(n+1) = y_{out}^{o}(n+\frac{1}{2})$$
(5)

both polarities of the weighting factors can be obtained by

grounding the appropriate input terminals. For instance, taking  $y_j^+ = 0$  yields a j-th negative weight.



FIGURE 1: a) Basic switched-capacitor integrating "neuron"; b)
Required clock signals.

Constraint evaluation summers: Constraint evaluation requires weighted summation. Figure 2 shows a switched-capacitor circuit to carry out such an evaluation. Observe that the input signals for this circuit are sensed during the odd clock phase while the output are defined only during the even clock phase. Analysis of Fig.2 allows us to obtain,

$$y_{out}^{e}(n+1) = \sum_{j=1}^{M} h_{j} \left[ y_{j}^{a+}(n+\frac{1}{2}) - y_{j}^{n-}(n+\frac{1}{2}) \right]$$
 (6)

$$y_{out}^{o}(n+\frac{1}{2})=0$$

As for Fig.1, both negative and positive weighting factors can be easily obtained.

Threshold generation and feasibility region encoder: This block is intended to generate the threshold functions that codify constraint violations. Figure 3 shows one implementation for this block. The threshold signals codifying single constraint violations are obtained to codifying single constraint violations are obtained at the



outputs of the comparators. On the other hand, the threshold signal that codifies whether the point is or not inside the feasibility region results as follows,

$$T_{\vec{F}}^{0}(\mathbf{F}) = \sum_{k=1}^{Q} T_{\vec{F}}(-F_{\vec{k}}) \wedge \theta^{0} = \begin{cases} I_{D}, & F_{\vec{k}} > 0 \quad \forall k \\ \theta_{D}, & \text{otherwise} \end{cases}$$
 (7)

where  $\Lambda$  here holds for the logical-AND operation.



# A "neural" SC quadratic programming solver.

Figure 4 shows a switched-capacitor implementation of the quadratic programming solver "neural" network. To simplify the circuit diagram, only the i-th "neuron" cell and the k-th constraint evaluator are shown. Furthermore, we have arbitrarily used absolute value penalties and have assumed that all the coefficients of both the scalar function



FIGURE 4: A switched-capacitor "neural" quadratic programming solver

and the constraint functions are positive. Analysis of Fig.4 by using (5), (6) and (7) gives,

$$x_{i}^{e}(n+1) = x_{i}^{e}(n) - \frac{1}{t_{o}} \left[ U(\mathbf{F}) \left\{ a_{i} + \sum_{i=1}^{N} g_{ij} x_{j}^{e}(n) \right\} - \mu \sum_{k=1}^{Q} U(-F_{k}) b_{ki} \right]$$
(8)

which corresponds to the Forward-Euler simulation [11] of the gradient system for the quadratic problem using the pseudo-cost function of (4) with absolute value penalties,

$$\Psi_m(\mathbf{x}) = U(\mathbf{F})\Phi(\mathbf{x}) + \mu \sum_{k=1}^{Q} U(-F_k)|F_k(\mathbf{x})|$$
(9)

Other types of pseudo-cost functions and penalties can be considered in a simple way [10]. Parameter  $\mu$  in (8)-(9) controls the strength of the

penalty. On the other hand, parameter  $\tau_0$  controls the integrator gain and hence the convergence speed of the solver. In practice, choosing  $\tau_0$  requires a tradeoff between convergence speed and stability. Although decreasing  $\tau_0$ increases the rate of convergence, it may produce instabilities.

## Alternative SC building blocks.

Parasitic-insensitive "neuron" and summer: All previously shown SC circuits are sensitive to parasitics [11]. Figure 5 shows a threshold-controlled "neuron" that is insensitive to both parasitic capacitors and opamp offset voltage [12]. Along with the figure we include a formula describing the operation of the circuit. Since appropriate operation of the "neural" architecture requires a half-period delay in the operation of the "neuron", only positive weights are allowed for the circuit in Fig.5. Negative weights can be realized by changing the sign of the input signals. It requires generation of the inverted version of the output of each neuron, what is done by the second amplifier in Fig.5. each neuron, what is done by the second amplifier in Fig.5.



FIGURE 5: A parasitic-insensitive "neuron".

Figure 6 shows a switched-capacitor summer which can be used for parasitic-insensitive constraint evaluation. As

be used for parasitic- insensitive constraint evaluation. As for Fig.5, only positive weights are allowed for this summer. The output signal of the "neuron" of Fig.5 is only valid at odd time instances. This imposes the necessity of changing the "synapses" strategy. The new strategy is illustrated in Fig.7. The integrator-summer Σ<sub>2</sub> has to be implemented by using Fig.5, while Fig.6 must be used for Σ<sub>1</sub>. The rest of the architectural concepts leading to Fig.4 are still valid for the parasitic-insensitive building blocks.



FIGURE 6: A parasitic-insensitive summer.



FIGURE 7: Stablishing "synapses" with parasitic-insensitive switched-capacitor building blocks.

## IV. Stability Properties

Computation in a "neural" programming solver is a dynamical process of seeking equilibrium. For proper computation, the equilibrium points of a programming solver must correspond to solutions of the problem being

computed; moreover, these equilibria must be stable.

The dynamic behavior of a switched-capacitor programming solver is determined by two factors, namely,

1) The reactive parasitics associated with the active

components and interconnection wires. 2) The parasitics introduced by the discretizing

numerical integration algorithm.

However, since the proposed architectures do not exhibit any global closed-loop during the computation cycle, there is no possibility for instabilities due to continuous-time parasitics to appear. Hence, only discrete-time parasitics must be taken into account for stability analysis.

A switched-capacitor programming solver is a discrete-time dynamic system which can be described by the following difference state equation,

$$\mathbf{x}(n+1) = \mathbf{G}(\mathbf{x}(n), \iota_{-}, \mu) \tag{10}$$

where  $\tilde{\mathbf{G}}$  is a vector function and  $\tau_0$  and  $\mu$  are positive real parameters (these parameters are used in Fig.4 as capacitor sizing parameters)

Equilibrium [13] occurs at the point x\* which is a constant solution of (10),

$$\mathbf{x}^* = \mathbf{G}(\mathbf{x}^*, \mathbf{t}_a, \mathbf{\mu}) \tag{11}$$

In general, the equilibrium points of (10) can be either: 1) inside the feasibility region or 2) on the boundary of this region.

Solution inside the feasibility region. Local asymptotic stability can be calculated by first linearizing (10) around the equilibrium point and then taking the z-transform. In order to obtain the equilibrium point to be stable, the root of the characteristic equation must be inside the unit circle [14]. Hence, parameter  $\tau_0$  has to be selected large enough for the local stability condition to be fulfilled.

Solution on the boundary the feasibility region. It is clear in this case that the system cannot stay static at  $\tilde{x}^*$ . However, the solution  $\dot{x}(n)$ ,  $\dot{x}(n+1)$ ,  $\dot{x}(n+2)$ ....can be made to stay inside an arbitrary small interval around this point. In other words, this system can be made to be stable in the sense that the variations of the solution remain bounded, although it is not asymptotically stable.

From (8), it can be seen that the maximum deviation from the equilibrium point towards the exterior of the acceptability region, for the quadratic problem, is given by

$$|\Delta \mathbf{x}_i| = \frac{1}{\iota_0} \left| a_i + \sum_{j=1}^N g_{ij} \mathbf{x}_j^* \right| \qquad \forall i$$
 (12)

while the maximum deviation towards the interior of this region is given by,

$$\left| \Delta \mathbf{x}_i \right| = \frac{\mu}{\iota_0} \left| \sum_{k=1}^M b_{ki} \right| \qquad \forall i$$
 (13)

where M is the number of constraints that are simultaneously violated.

From the previous equations, it can be seen that oscillations can be made as small as desired by simply varying, in a suitable way, the values of  $\tau_o$  and  $\mu$  and provided that these values fulfill the condition of stability in the acceptability region.

#### V. Practical results

## Linear Programming.

The architecture of Fig.4 has been breadboarded for the following two-dimensional linear problem

Minimize 
$$\Phi = a_1 x_1 + a_2 x_2$$
 to the constraints

subject to the constraints,

$$F_1 = -\frac{5}{12}x_1 + x_2 + \frac{35}{12} \ge 0 \quad F_2 = -\frac{5}{2}x_1 - x_2 + \frac{35}{2} \ge 0$$

$$F_2 = x_1 + 5 \ge 0 \quad F_3 = -x_2 + 5 \ge 0$$
(14)

Fig.8a,b correspond to this problem with  $a_1 = -1$ ,  $a_2 = 1$ . The theoretical solution is at  $x_1 = 7$ ,  $x_2 = 0$ . The evolution towards this point from two different initial points is illustrated. In a similar way Fig.8c,d correspond to  $a_1 = 1$ ,  $a_2 = -1$ , the theoretical solution being at  $x_1 = -5$ ,  $x_2 = 5$ . As before, the dynamic route of the actual circuit towards the theoretical equilibrium is observed for two different initial points.



FIGURE 8: a,b) Oscilloscope pictures showing two trajectories for the problem in (14) with a<sub>1</sub> = -1, a<sub>2</sub> = 1 c,d) The same for the problem in (14) with a<sub>1</sub> = 1, a<sub>2</sub> = -1 (horizontal signal: x<sub>1</sub>, 2V/dv; vertical signal: x<sub>2</sub>, 2V/dv)

## A Quadratic programming problem.

We have used parasitic-insensitive building blocks to solve the following quadratic problem

Minimize 
$$\Phi = x_1^2 + x_2^2 + x_1x_2 + 3x_1 + 3x_2$$

subject to the constraints,

$$F_{1} = -\frac{5}{12}x_{1} + x_{2} + \frac{35}{12} \ge 0 \qquad F_{2} = -\frac{5}{2}x_{1} - x_{2} + \frac{35}{2} \ge 0$$

$$F_{3} = x_{1} + 5 \ge 0 \qquad F_{4} = -x_{2} + 5 \ge 0$$
(15)

Table 1 shows the DIANA-simulated values of the variables  $x_1$  and  $x_2$  as functions of different parameters, namely: the *time instant* (measured as the number of clock periods from the initial point, rightmost column in Table 1); the DC gain of the opamps used in the integrating "neuron" (parameter  $A_o$  in the first row); and the size of the

integrating capacitors (parameter  $t_0$  at the left of the Table). In all the cases the initial point was at  $x_1 = x_2 = 0$ . As can be seen, the convergence speed increases as  $t_0$  decreases. Furthermore, decreasing the opamp DC gain does not significantly influence the performance of the circuit.

|               | $A_0 = 30000 \\ x_1, x_2$ | $A_0 = 100$ $x_1, x_2$ | Number of clock periods |
|---------------|---------------------------|------------------------|-------------------------|
|               | -1.27, -0.71              | -1.26, -0.72           | 100                     |
| $\tau_0 = 10$ | -1.03 , -0.97             | -1.03, -0.97           | 200                     |
| -0            | -1.002 , -0.995           | -1.002, -0.995         | 300                     |
|               | -1.03 , -0.97             | -1.025 , -0.97         | 100                     |
| $t_0 = 5$     | -0.999 , -0.998           | -0.999, -0.998         | 200                     |
|               | -0.998 , -0.998           | -0.998, -0.998         | 300                     |

TABLE 1: Evolution of the solution point as function of different circuit parameters

#### VI. Conclusions

A unified systematic approach has been presented for the design of "neural" quadratic programming solvers using SC techniques. This architecture is based on a reduced set of basic cells that are interconnected following a dense regular pattern. The resulting circuits exhibit a very high modularity and in this sense can be considered as members of the general family of analog "neural" networks. The proposed method is valid for both linear and quadratic programming problems, and the basic network architecture can be adapted to more general nonlinear problems.

#### References

- [1]
- G. Arnout, Ph. Reynaert, L. Claesen and D. Dumlugol: "DIANA V7E user's guide". ESAT Laboratory, Katholieke Universiteit Leuven, 1983. D.A. Tank and J.J. Hopfield: "Simple Neural Optimization Networks: An A/D Converter, Signal [2] Decision Circuit, and a Linear Programming Circuit". IEEE Trans. Circuits Systems, Vol. 33, pp 533-541, May 1986.
  M.P. Kennedy and L.O. Chua: "Neural Networks for
- [3]
- 533-541, May 1986.

  M.P. Kennedy and L.O. Chua: "Neural Networks for Nonlinear Programming". IEEE Trans. Circuits and Systems, Vol. 35, pp 554-562, May 1988.

  M.P. Kennedy and L.O. Chua: "Unifying the Tank and Hopfield Linear Programming Circuit and the Canonical Nonlinear Programming Circuit of Chua and Lin". IEEE Trans. Circuits and Systems, Vol. 34, pp 210-214, February 1987.

  L.O. Chua and G.N. Lin: "Nonlinear Programming without computation". IEEE Trans. Circuits Systems, Vol. 31, pp 182-188, Feb. 1984.

  C.W. Solomon: "Switched-Capacitor Filters". IEEE Spectrum, Vol 25, pp 28-32, June 1988.

  A. Hausner: "Analog and Analog/Hybrid Computer Programming". Prentice-Hall 1971.

  G.A. Korn and T.M. Korn: "Electronic Analog and Hybrid Computers-2nd Edition". Mc Graw-Hill 1972.

  G. V. Vanderplaats: "Numerical Optimization Techniques for Engineering Design: with Applications". McGraw-Hill 1984.

  R. Domínguez-Castro: "Switched-Capacitor Neural Networks for Optimization Problems". Master Thesis, University of Swills 1909. [4]
- [5]
- [6]
- [7]
- [8]
- [9]
- [10] Networks for Optimization Problems". Master Thesis,
- University of Seville 1989.
  R. Gregorian and G.C. Temes: "Analog MOS Integrated Circuits for Signal Processing". Wiley-Interscience 1986.
- F. Maloberti: "Switched-Capacitor building blocks for [12] Analogue Signal Processing", Electronics Letters, Vol. 19, pp 263-265, 1983
  B.C. Kuo: "Digital Control Systems". Holt, Rinehart and Winston 1980.