Abstract-In this paper, we have identified a second-order reaction-diffusion differential equation able to reproduce through parameter setting different complex spatio-temporal behaviors. We have designed a log-domain hardware that implements the spatially discretized version of the selected reaction-diffusion equation. The logarithmic compression of the state variables allows several decades of variation of these state variables within subthreshold operation of the MOS transistors. Furthermore, as all the equation parameters are implemented as currents, they can be adjusted several decades. As a demonstrator, we have designed a chip containing a linear array of ten second-order dynamics coupled cells. Using this hardware, we have experimentally reproduced two complex spatio-temporal phenomena: the propagation of travelling waves and of trigger waves, as well as isolated oscillatory cells.
I. INTRODUCTION

M
ANY pattern formation and wave propagation phenomena that appear in nature can be described by systems of coupled nonlinear differential equations, generally known as reaction-diffusion equations [1] . These wave propagation phenomena are exhibited by systems belonging to very different scientific disciplines. For example, in neurophysiology, the propagation of electrical impulses through the nervous system and the propagation of the cardiac movement through the cardiac muscle are classical examples of active wave propagation. It is known that anomalies causing disorganization of autowave structures result into patient's clinical syndromes [2] , [3] . Some groups have also investigated the application of active mediums in image processing tasks [4] . However, the huge amount of calculations involved in the simulations of these spatio/temporal phenomena makes the process tedious and extremely time consuming. In such an scenario, the existence of a specialized parallel/processing hardware able to reproduce these behaviors at very high speed, would be a valuable tool to study and understand more deeply these phenomena. Recently, there have been several research groups realizing circuit implementations of reaction-diffusion equations [5] - [7] .
Manuscript received September 15, 2002 . This work was supported by ONR under Research Grant "Design of High Density and Neuromorphic CNN Universal Chips as Image Microprocessors" and by a Spanish Grant TIC1999-0446-C02-02.
The authors are with the Instituto de Microelectrónica de Sevilla, Centro Nacional de Microelectrónica, Sevilla 41012, Spain (e-mail: terese@imse.cnm.es).
Digital Object Identifier 10.1109/TNN. 2003 .816374
The equations describing active wave propagation have the general form (1) where is an -dimensional vector which defines the system state at position (where ) at time . is a set of nonlinear functions of the state variable vector . is an matrix. The diagonal elements of , are known as the diffusion coefficients of the th state variable. And is the Laplacian operator, which defined in is (2) Table I contains some well-known reaction-diffusion equations commonly used in the literature [8] - [13] to model complex spatio-temporal behaviors that appear in several disciplines. All the equations in Table I correspond to the general form of (1) . These equations can generate patterns and waves including travelling waves, trigger waves, and spiral waves.
These phenomena have been also successfully reproduced in case where the continuum medium description is approximated by a discretely spaced one [14] - [16] . If we do this spatial discretization, in two dimensions , (1) takes the form (3) where is the vector of state variables for the cell located at spatial position ( ).
Equation (3) can be interpreted as a regular array of cells. Each cell has complex dynamics described by state variables and is coupled to its neighbors through linear synapses.
Equations in Table I , show different levels of complexity, that is, number of state variables, number and type of nonlinearities and number of couplings between state variables of adjacent cells. We selected an equation that captures all the complex spatio-temporal behaviors: Turing pattern formation, traveling waves, trigger waves and spiral waves propagation, while at the same time maintains the lowest possible level of complexity [16] .
The selected equation that fulfills the above requirements is
1045-9227/03$17.00 © 2003 IEEE where the nonlinear term has been approximated by the piecewise-linear nonlinearity depicted in Fig. 1 .
Through proper parameter setting, this equation is able to exhibit Turing's patterns formation, trigger wave, travelling wave propagation and spiral wave formation. As will be demonstrated in the next Section, all the behaviors are robust against random variations in the equation parameters higher than 20% [16] .
II. BEHAVIORAL SIMULATIONS
The spatially discretized version of (4) have been simulated in MATLAB to reproduce the different spatio-temporal phenomena and to check the tolerance of these behaviors to random fluctuations in the parameters of (4).
A one-dimensional (1-D) array of cells has been simulated in MATLAB. The cell parameters were set to obtain two different behaviors: a travelling wave propagating with constant amplitude through the array and a trigger wave behavior. We have found points in the parameter space where the traveling wave behavior is robust against cell parameters random deviations as wide as 20%. Deviations were introduced not only in the cell parameters, but also in the coupling parameters and . The robustness of the behavior has also been checked for the trigger wave propagation. A tolerance of a standard deviation of 20% in the cell parameters and coupling parameters has been found through MATLAB simulations.
Simulations of the different behaviors in a two dimensional array of cells have also been performed. Table II shows, for different spatio-temporal behaviors, the maximum standard deviations allowed simultaneously in all the cell parameters and coupling parameters that maintain the same qualitative behavior in all the cells in the array. Also shown in Table II , are the nominal cell and coupling parameters used in the different simulations.
The robustness of Turing's patterns formation against random parameter deviations is illustrated in Fig. 2 . Fig. 2(top) depicts the Turing's patterns developed in the two-dimensional (2-D) array when the cell parameters are set to the values , , ,
and coupling parameters and . Afterwards, a simulation with random parameters deviations of was performed. The deviations were introduced not only in the cell parameters but also in the coupling parameters between cells. Fig. 2(bottom) shows the result of this simulation. Fig. 2 shows the final patterns developed in the state variable with the values of the state variable coded as levels of gray.
As deduced from our system simulations, the transistors in our design must be dimensioned in order to ensure that the parameters in our hardware implementation have a standard deviation lower that 20%. This level of precision is achievable in subthreshold MOS implementations for moderate transistor sizes. MOS transistors operating in subthreshold have a relative current precision almost independent of the operating current level [17] . Transistors of size , fabricated in the AMS 0.35 technology have in the weak inversion regime a standard deviation [18] . In the rest of the paper, simulations of tolerance at the transistor level are omitted. The reason is that transient simulations of large arrays of cells have to be performed. These simulations at the transistor level would require days of computing.
III. CIRCUIT SYNTHESIS
Our target is to synthesize an array of second-order cells ( ) implementing the discretely spaced version of the nonlinear differential (4) (5) were the continuous 2-D Laplacian operator has been substituted by its discretized version [see (3) ].
In order to reproduce different spatio-temporal phenomena through parameter setting, the hardware must have the following properties.
1) Parameters must be tunable in a wide range without degrading the behaviors. 2) State variables and must have a wide range of operation without saturation of the behavior. 3) For some locomotion applications, the time constant must be scalable to arbitrarily low values. These requirements are met in a log-domain implementation [19] - [22] . In a log-domain circuit, the voltages in the circuit nodes are a logarithmically compressed version of the state variables. Thus, the state variables can vary several decades without saturation of the behavior. Also the cell parameters are currents that can be adjusted several decades in the MOS subthreshold regime [17] , [23] . Furthermore, it is possible to scale down simultaneously all the currents in the circuit making the operation arbitrarily slow.
In the proposed circuit implementation we have to distinguish between mathematical state variables and circuital state variables. In the log-domain circuit technique, state variables { } are currents and are related to node voltages { } through exponential relationships (6) This means that the circuital state variables { } cannot be negative. Consequently, a coordinate transformation is required [21] to map the mathematical state variables { } in (5) to the circuital ones { }
where is the translation vector and is the scaling factor.
After substituting the original state variables, and , of (4) by the scaled and translated variables and , the following differential equation results: (8) where
, and the breakpoints of the piecewise-linear nonlinearity have been redefined as (9) Terms and are two offset terms defined as follows:
Applying the log-domain mapping given by (6) to the discretely spaced version of (8) that results after the translation and scaling of the state variables, yields the following relation between circuit voltages:
Coupling Coupling (11) where the terms called Coupling account for the Laplacian operator and are given as
Coupling
Coupling (12) Notice that the translated and scaled state variables have been renamed as and for shortness of notation. Parameters in (11) and (12) are related with the ones in (8) through the following relations: (13) where, as it will become clear later, in our implementation is a free design current parameter that for a given capacitance controls the characteristic time constant of the response. Reducing current , the global response of the circuit can be appropriately slowed down. is also a current parameter that, for a given relation between capacitances , must be tuned to set the original parameter to its appropriate value.
Circuit implementation is focused on the realization of (11) and (12), and will be explained in two steps:
• implementation of the core cell dynamics (11), excluding coupling, • implementation of the coupling terms (12) .
A. Uncoupled Cell
Each uncoupled cell has a second-order dynamics described by (14) as derived from (11) by making the coupling terms null. Fig. 3 shows the block diagram of the circuit implementing (14) . The blocks denoted as and are transconductors obeying an exponential law called -elements [20] , [21] . That is, the output current of these transconductors depends exponentially on the difference between the positive and negative controlling voltages. Fig. 4(a) shows the schematics of the bipolar implementation of the -element. The circuit in Fig. 4 (a) belongs to the class of translinear networks [24] . Using a reformulation of the translinear principle [25] , this circuit can be easily analyzed. It is found that the circuit in Fig. 4(a) gives as output currents (15) where is the thermal voltage. The current is considered positive when it goes out of the -element; the corresponding -element is then considered a positive -element. The current is negative when it enters the -element, and the -element is then called a negative -element. Fig. 4 (b) and (c) shows two possible implementations of an -element using MOS transistors operating in the subthreshold regime. The circuit in Fig. 4(b) verifies also an exact translinear relationship giving an output current (16) where is a PMOS subthreshold parameter [17] . The output current of the circuit in Fig. 4 (c) would be (17) In our particular implementation we have chosen to implement all the -elements using the block shown in Fig. 4(c) . It is easy to show that with this selection of the transconductance elements, the circuit of Fig. 3 implements the system of differential equations given by (14) with (18) The block denoted as in Fig. 3 implements in current mode the piecewise-linear nonlinearity shown in Fig. 1 . A positive -element biased by a current and controlled by the voltage difference (see Fig. 3 ) provides a sourcing current . This current is used as the input of the nonlinear block . The output current of this nonlinear block is the bias current of a positive -element controlled by a voltage difference
. Hence, a current term is fed into the capacitor as required in (14) .
B. Piecewise-Linear Block
As shown in Fig. 1 , the PWL function can be decomposed as the sum of three components (19) where denotes the one-sided rectification operation ( if and zero if ), , , and are the slopes of the three pieces of the nonlinearity and and are the breaking points. Fig. 5 depicts the schematics of the current mode block that implements the PWL function of Fig. 1 [26] . The transistors are intended to operate in the subthreshold region, so that the slopes of the different pieces of the piecewise-linear characteristics can be controlled through the bias voltages , ,
. In particular (20) However, the large variability of the factors , and the current factors from run to run, makes impractical to control the slopes , , and by controlling directly the voltage biases. This inconvenience can be solved by using current biases to control the three slopes. Fig. 6 shows the biasing block which is common to all the cells in the chip. The amplifiers in Fig. 6 must deliver enough current for all the output branches in the different neurons. This means that the output stage of the amplifier must be scaled with the number of neurons in the chip. 
C. Coupling Between Cells
To implement the coupling terms among cells in (12) Fig. 7 shows a diagram of the extra blocks needed to implement the coupling terms that appear in (12) .
D. Initial Conditions Circuitry
To generate the different spatio-temporal behaviors, appropriate initial conditions must be set in the and state variables of all the cells in the array [16] . In our design, binary initial conditions are used. That is, for each cell in the array, we set the initial values of the and state variables to one of two possible continuously programmable states ( , ) or ( , ). Afterwards, the system switches to its normal evolution mode, and different spatio-temporal behaviors are generated on chip, depending on the parameters and initial condition settings.
A careful design of the initial conditions circuitry is needed in order to avoid erasing or modification of the stored initial states during this switching. This switching problem is particularly severe in log-domain operation where the and state variables depend exponentially on the log-compressed and voltages stored on capacitors and . Small deviations of or due to charge injection during the switching are exponentially amplified producing large errors in the initial state. Hence, avoiding any feedthrough injection during switching is essential for correct operation. Fig. 8 (a) depicts a block diagram of the circuitry added to set the initial conditions in the and voltages. A set of inverters configured as a shift register selects which initial conditions ( , ) or ( , ) are set in each cell. Fig. 8(b) shows the schematic of the boxed block in Fig. 8(a) that sets the initial voltage (or ) in cell capacitor (or ). In Fig. 8(b) , and are two switched voltages. switches from , when the initiation signal is high, to , when signal is low (normal operation mode). Signal switches from , when is high, to , when is low. When signal is high the initial conditions are being set in the cells. During this period, all the components in the circuit are disconnected from nodes (or ), except one of the boxed elements of Fig. 8(b) .
In the steady state, when the input current to capacitor (or ) is zero, the output current of the negative -element [current in Fig. 8(b) ], is forced to be equal to the supplied current (or ). Hence, the output voltage (which is connected to capacitor nodes or ) is forced to be (21) hence (22) When signal is low, currents (or ) and are cut off. The switching of the currents is done by switching the source terminals of the current supplying transistors, with their gate terminal being kept at constant voltages. This switching strategy avoids any undesired charge injection in the output node [27] .
As explained before, during the setting of the initial conditions all the other components in the circuit must be delivering a zero output current to the and nodes. This can be achieved by substituting all the -elements and current sources in Figs. 3 and 7 by switched -elements and switched current sources. The schematic of a switched positive -element is shown in Fig. 9(a) . Fig. 9(b) shows the schematic of the switched negative -element. And Fig. 9(c) depicts the schematic of a switched sinking current source. Note that all the switching is done through the sources of the output current supplying transistors to avoid any charge injection in the capacitors during switching [27] . Fig. 11 shows a microphotograph of the fabricated chip. In the prototype chip, we have also included an isolated current-mode piecewise-linear block and an isolated cell for characterization purposes.
IV. EXPERIMENTAL RESULTS
A. Current-Mode Piecewise-Linear Block
All the biasing currents , , ,
. 5 and 6) are derived from the same reference current , through 5-bit DAC converters. The value of each current can be varied between . The functionality of the block has been verified for at least four decades of variation of the working currents. Fig. 12(a) shows the measured input-output current characteristics of the block for , , , , , , , and pA. Fig. 12 (b) depicts the measured input-output current characteristics for the same parameters but with . Fig. 13(a) illustrates the controllability of the central slope . In the measurements of Fig. 13(a) nA, , , , , while is varied from 0 to . The values of and are simultaneously swept from to , so that as can be observed the and slopes remain constant and approximately equal to one. Fig. 13(b) illustrates the programmability of the slope. In these curves, , , , , , and , while is varied from 0 to . The controllability of the breaking point is demonstrated in the measurements of Fig. 13(c) . In the curves of Fig. 13(c) , , , , , , , , and varies from to . 
B. Isolated Cell
An isolated cell where the nodes and (see Fig. 3 ) are directly connected to external pins has been included in the prototype chip. This allows us to do a complete dc characterization of the different sub blocks in the cell. Fig. 14 shows measurements of the input-output characteristics of a positive -element. The measured -element is the one whose bias current is . In these measurements, bias currents and were set to zero. Fig . 15 shows measured results of a negative -element. The measured negative -element is the one with bias current in Fig. 3 . Bias currents and were set to zero is these measurements. Fig. 15(top) shows current versus the applied voltage for different values of the voltage applied to node with current at 1 nA. Fig. 15 (bottom) plots current versus the voltage applied to this node , for different values of the bias current . In these 32 curves, the bias current was varied linearly in the range [1 nA/16, 2 nA], while voltage was held constant at 1.5 V. The dots in Fig. 15 correspond to the experimentally measured points. The solid lines are the theoretically predicted curves (24) fitted for the same value . We have also measured the null isoclines of the isolated cell for different settings of the parameters. To obtain the null isoclines, the following procedure has been followed. 1) For the null isoclines corresponding to , we sweep the voltage (or equivalently the state variable) and measure the voltage that appears in dc in the node (or equivalently the state variable) when the current flowing through that node is zero. The measured pairs ( ) correspond to the points that belong to the isocline . 2) For the null isoclines corresponding to , a two-dimensional sweep of voltages and is done. The total current flowing through node is measured and its zero crossings are observed. For each value of (or equivalently the state variable), we look for the corresponding values of (or equivalently the state variable) such that current becomes zero. The measured pairs ( ) correspond to the points that belong to the isocline curve . Fig. 16 shows the null isoclines measured for different settings of the circuit parameters. They are compared versus the ones theoretically computed using (8) for the equivalent equation parameters. The equivalent parameters are computed using the relations given by (13) . Fig. 16(a) shows the null isoclines measured for the circuit parameters:
nA, nA, nA, while was varied from 0 nA to 2 45 nA in steps of 45 nA/16. Also shown in Fig. 16(a) are the null isoclines computed using (8) for and varying from 0 to 32 9 nA in steps of 9 nA. Fig. 16(b) shows the null isoclines measured for the circuit parameters:
nA, nA, , while was varied from 1/16 nA to 2 nA in steps of 1 nA/16. Also shown in Fig. 16(b) are the null isoclines computed using (8) for nA and varying from 0.2 to 6.4 in steps of 0.2. A valid agreement is observed between the measured null isoclines and the theoretically computed ones. Fig. 17 shows a comparison between the null isoclines measured experimentally for different values of the circuit parameters and the ones theoretically computed using (8) . In the measurements of Fig. 17(a) , nA, nA, nA, nA, nA, and . The dotted line was measured for , while the line marked with asterixs corresponds to the points measured for . The solid lines are the theoretically computed null isoclines using (8) for , and for the block parameters: nA, nA, , and , and . Fig. 17 (b) shows the null isoclines for different values of the parameter. In the measurements depicted in Fig. 17(b) the circuit parameters are set to nA, nA, nA, nA, , , and is set Fig. 16 . Comparison between the experimentally measured _ v = 0 null isoclines and the ones computed using (8) .
to 1 nA (dotted line), 2 nA (curve marked with diamonds) and 0.125 nA (curve marked with asterixs). The theoretically computed curves using (8) and the equivalent parameters given by (13) , are also shown in Fig. 17 with solid lines. Using the measured , null isoclines we can figure out how to set the cell parameters to obtain different qualitative behaviors. In the measurements of Fig. 18 (a) the cell parameters are set to emulate an excitable medium [28] . That is, each cell has a unique stable equilibrium point. Under perturbation, the cells become excited and go back to their stable equilibrium point after a refractory period. The circuit parameters in Fig. 18(a) are: nA, nA, nA, nA, nA, nA, and for the nonlinear block parameters, , , , nA, nA. The measurements of Fig. 18(b) correspond to the null isoclines , of a bistable medium [28] . That is, each uncoupled cell has two stable equilibrium points. Under perturbation the cells can trigger from one equilibrium point to the other. The circuit parameters were set to:
nA, nA, nA, nA, nA, , and the same parameters the parameters are the same used in Fig. 18(a), that is, , , , nA, nA. In the measurements shown in Fig. 18 (c) the cell parameters are set such that the cells have a unique equilibrium point which is unstable. It is therefore an oscillatory medium. The cell parameters were set in this case to:
nA, nA, nA, nA, nA, nA, and for the nonlinear block parameters , , , nA, and nA.
C. 1-D Array of Cells
We have measured the transient behavior of a linear array of ten coupled cells. Each cell is coupled to its two nearest neighbors with the coupling strategy shown in Fig. 7 . As shown in Fig. 19 , to observe the state variables , of each cell two additional positive -elements have been added per cell. They transform the circuit voltages , to the equation state variables (currents , ). The cell to be observed is selected through signal and connected to a buffering amplification current mirror. This mirror is an NMOS active input current mirror [29] . The low input impedance is intended to minimize the delay in the input node. The mirror has a current amplification factor around 1000. This way, the low currents in the cells (in the order of nano Amperes) are transformed into higher currents (in the order of micro Amperes) to be sensed and transformed into voltages by off-chip resistors. The off-chip resistors used were , , and for the coupling elements . Experimentally, we observed that each uncoupled cell has a unique equilibrium point (excitable medium) in which the state variables settle to the values , . All the cells in the array are initialized to their equilibrium state except for the first cell which is initialized to a nonresting state , . As can be observed in Fig. 20 , this cell becomes excited going back to the equilibrium state after a refractory period. The perturbation of the first cell affects (through the coupling synapses) the next cell, which becomes also excited and leaves its resting state during a refractory time, exciting also the third array cell. This way, a travelling wave propagates through the array. The total delay that occurs between the perturbation of the first cell (by the initial condition circuitry) and the perturbation affecting the tenth cell in the array is approximately 0.9 ms. For these biasing conditions, the power consumption of the circuits generating the common biasing currents is 5.5 W. The power consumption of each cell in the steady state is 3.5 W from a power supply voltage of 3.3 V. Fig. 21 shows results of a trigger wave propagating through the array. The reference currents were also set to , and . The circuit  parameters were set to:  ,  ,  ,  ,  ,  ,  for the nonlinear block,  ,  ,  ,  , , and for the coupling elements . Fig. 21(a) shows the waveforms of the state variable versus time, while Fig. 21(b) depicts the waveforms of the state variable versus time. Experimentally, we observed that the uncoupled cell has two equilibrium points (biestable medium) in which the state variables settle to one of the pair of values: ( , ), ( , ). All the cells in the array are initialized to the second equilibrium state ( , ) except for the first one which is initialized to a nonresting condition , ). The first cell evolves toward the equilibrium state ( , ) and perturbs (through the coupling synapses) the second cell which is triggered also to the ( , ) equilibrium state. The perturbation is propagated through the array until all the cells have been triggered to the ( , ) state. The time that occurs between the triggering of the second and the tenth cells in the array is approximately 0.5 ms. For these biasing conditions, the power consumption of the circuits generating the common biasing currents is 6.5 . The power consumption of each cell in the ( , ) equilibrium state is 5.6 . The power consumption is 3.9 for each cell in the ( , ) equilibrium state. Fig. 22 shows the measured waveforms of the (upper trace) and (lower trace) state variables of one of the cells in the array when the circuit parameters are set to emulate an oscillatory medium. In this case, each isolated cell has only one unstable equilibrium point. Independently of the initial conditions, during its normal operation each cell describes a limit cycle around the equilibrium point. The reference currents were again set to , and . The circuit parameters used in this measurement were: , , , , , , for the nonlinear block, , , , , , and for the coupling elements .
V. CONCLUSION
A second-order reaction-diffusion equation has been selected which is the simplest equation able to generate, through parameter setting, trigger wave, traveling wave propagation, spiral wave and Turing pattern formation.
A hardware implementing the spatially discretized version of the selected equation has been designed. In the hardware implementation the cell state variables are logarithmically encoded as voltages stored in some capacitors. This logarithmic compression of the state variables allows several decades of variation of these state variables without saturation of the elements and with low distortion. All the parameters of the implemented equation are set as biasing currents that can be adjusted several decades. Furthermore, by scaling some biasing currents of the circuit the time constant of the implemented equation can also be appropriately scaled. This can be helpful to make the waveforms generated on chip easily observable and for some applications where an extremely slow time constant may be needed (i.e., in locomotion applications).
A 1-D array of ten coupled cells has been integrated. The correct operation of the designed hardware has been verified through experimental measurements. We have performed a detailed characterization of the behavior of one isolated cell. Also, a traveling wave and a trigger wave propagating in the array have been experimentally measured.
