

# 80170NX

## ELECTRICALLY TRAINABLE ANALOG NEURAL NETWORK

- Ultrahigh Performance
  - 2 Billion Connections Per Second (CPS)
  - Low-Power CHMOS\* III EEPROM Technology
  - 300K Patterns Per Second (64- or 128-Input Patterns)
- Versatile Architecture
  - 64 Dot-Product Neurons with Sigmoid Functions
  - Separate Input and Feedback Arrays
  - Hold and Feedback Capability
  - Supports Hopfield, Multi-Layer and Recurrent Nets
  - 10,240 Nonvolatile Analog Synapse Weights
  - 6- to 7-Bit Typical Resolution
- 208-Pin PGA Package  
(See Packaging Specification, Order #231369)

- Compatible with Popular Training Methods
  - Back-Prop and Competitive Learning
  - Single-Neuron Perturb for Madaline III Learning
- Flexible I/O
  - 64 Physical Inputs and Outputs, Configurable for 128 Inputs
  - Supports I/O Cascading
  - I/O Referencing Supports TTL Operation
  - User-Controlled Gain on Neuron Sigmoid Functions
- Many Real-Time Applications
  - Signal Processing
  - Process Optimization
  - Robotic Motion
  - Associative Memory

### GENERAL DESCRIPTION

The 80170NX Electrically Trainable Analog Neural Network (ETANN) chip offers unprecedented single-chip bandwidth and storage capacity for pattern-recognition problems. The chip simulates the data processing functions of 64 neurons, each of which is influenced by up to 128 positively or negatively weighted "synapse" inputs. The chip's data inputs and outputs are analog; its control functions for setting and reading synapse weights are primarily digital.

As shown in Figure 1, inputs and synapse weights are organized in two processing arrays—a 64x64 Input Array and a 64x64 Feedback Array. The chip has 64 external analog inputs. These inputs can be routed either to the Input Array or to the Feedback Array. Using input-hold functions, sets of 64 inputs can be multiplexed to the two arrays for mapping 128 inputs into 64 neuron outputs. Using these inputs, clocked feedback functions can support many interesting processing options.

Both the Input and Feedback Arrays are accompanied by a 16x64 bias array, for a total of 10,240 synapses. The chip computes the dot product (inner product) of the analog inputs and the weights stored at the synapses. The results are summed along each of the 64 neurons, generating 64 scalars that are passed through a sigmoid function of each neuron to the outputs.

Fully-parallel processing using both the Input and Feedback Arrays yields performance in excess of 2 billion multiply-accumulate operations (connections) per second (CPS), well beyond the capability of conventional CPUs. By interconnecting eight 80170NX chips, systems can achieve more than 16 billion CPS, a performance level that exceeds most supercomputers.

Multiple neural network layers can be implemented with either a single 80170NX chip or with multiple chips. By segmenting the two 64x64 arrays, networks with more than two layers can be implemented on a single chip. Multiple 80170NX chips can be cascaded by feeding analog outputs of one chip directly into analog inputs of subsequent chips.

\*CHMOS is a patented process of Intel Corporation.



290408i1

Figure 1. 80170NX Chip Block Diagram

Interfacing flexibility is provided through voltage-controlled I/O referencing and sigmoid gain controls. A high sigmoid-gain control ( $H_{GAIN}$ ) supports fully digital 0-to-5-volt interfacing directly to digital CMOS or TTL logic.

The four-quadrant multiplier synapses, implemented with Intel's CHMOS III EEPROM technology, provide truly nonvolatile, reprogrammable weights without refreshing or battery-backup. EEPROM

reprogrammability supports iterative and application-specific learning, avoiding mask-process limitations.

A glossary of neural network terms is included at the back of this data sheet for your convenience.

## PIN DESCRIPTIONS

| Symbol                                   | Type             | Description and Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------------------------------------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| I <sub>0</sub> -I <sub>63</sub>          | I <sub>A</sub>   | <b>NEURON INPUTS</b> —fully buffered analog channels for stimulus-vector input, where input voltages range from 0V to V <sub>IA</sub> (see D.C. Characteristics). Input voltages above V <sub>REFI</sub> represent positive numbers while those below V <sub>REFI</sub> represent negative numbers. Inputs and stored synapse weights can be either positive or negative. Four-quadrant multiplications are performed on the inputs and stored synapse weights. External inputs drive the Input Array and, for PDP/128-input operation, can also be multiplexed to drive the Feedback Array, in which case V <sub>REFO</sub> defines ± inputs for the Feedback Array. |
| N <sub>0</sub> -N <sub>63</sub>          | I/O <sub>A</sub> | <b>NEURON OUTPUTS and FEEDBACK INPUTS</b> —fully buffered analog outputs, representing neuron activity levels, ranging from 0V to 2*V <sub>REFO</sub> (see D.C. Characteristics). For PDP/128-input operation, these same pins can be driven externally for clocked Feedback Array input when neuron outputs are disabled (see NE#).                                                                                                                                                                                                                                                                                                                                  |
| CE#                                      | I <sub>D</sub>   | <b>CHIP ENABLE#</b> —an active-low TTL input that enables the chip when CE# = 0. When CE# = 1, the chip is put into a power-down or standby state, and the outputs N <sub>0</sub> -N <sub>63</sub> are disabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| NE#                                      | I <sub>D</sub>   | <b>NEURON ENABLE#</b> —an active-low TTL input that enables neuron outputs N <sub>0</sub> -N <sub>63</sub> when NE# = 0. Output drivers are disabled when NE# = 1, allowing several 80170NX chips to share a bus. NE# allows clocking of data into the Feedback Array's sample and hold buffers from an off-chip source.                                                                                                                                                                                                                                                                                                                                              |
| V <sub>REFI</sub> ,<br>V <sub>REFO</sub> | I <sub>A</sub>   | <b>INPUT AND OUTPUT REFERENCE VOLTAGES</b> —voltage-reference inputs that define the 0 or null voltage levels independently for inputs and outputs. Voltages above these references represent positive numbers while those below are negative. The maximum output voltage is 2*V <sub>REFO</sub> (see D.C. Characteristics). Setting V <sub>REFI</sub> and V <sub>REFO</sub> to 1.4V allows TTL compatible operation. V <sub>REFO</sub> is equivalent to the Input Array's V <sub>REFI</sub> .                                                                                                                                                                        |
| V <sub>GAIN</sub>                        | I <sub>A</sub>   | <b>GAIN CONTROL VOLTAGE</b> —a voltage-reference input for controlling analog sigmoid gain. An input voltage from 0V to V <sub>CC</sub> adjusts the sigmoid gain from the minimum to the maximum. Sigmoid response to V <sub>GAIN</sub> saturates at about 3.5V. All neurons' gains are set simultaneously.                                                                                                                                                                                                                                                                                                                                                           |
| H <sub>GAIN</sub>                        | I <sub>D</sub>   | <b>HIGH GAIN MODE</b> —a TTL input that turns on the high-gain sigmoid characteristic when brought active-high. This in effect converts the sigmoid into a comparator for 0V or 5V output.                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| HOLD                                     | I <sub>D</sub>   | <b>HOLD INPUT</b> —a TTL input that causes neuron inputs to be sampled and held when taken high. Input levels are captured and capacitively stored on the rising edge of HOLD. The inputs are then driven into the Input Array while HOLD is high. I <sub>0</sub> -I <sub>63</sub> resume driving the Input Array directly when HOLD goes low.                                                                                                                                                                                                                                                                                                                        |

## PIN DESCRIPTIONS (Contd.)

| Symbol                              | Type           | Description and Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------------------------------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>RESET<sub>F</sub></b>            | I <sub>D</sub> | <b>RESET FEEDBACK</b> —a TTL input that resets the Feedback Array inputs and associated bias inputs to 0V when brought active-high. This effectively disconnects the Feedback Array from the neuron summing columns.                                                                                                                                                                                                                                                                                                                                                                         |
| <b>RESET<sub>I</sub></b>            | I <sub>D</sub> | <b>RESET INPUT</b> —a TTL input that resets the Input Array inputs and associated bias inputs to 0V when brought active-high. This effectively disconnects the Input Array from the neuron summing columns.                                                                                                                                                                                                                                                                                                                                                                                  |
| <b>CLK</b>                          | I <sub>D</sub> | <b>CLOCK</b> —the TTL input that causes outputs to be sampled and held at inputs to the Feedback Array on the rising edge of CLK. Outputs are never connected directly back to inputs of the Feedback Array; they are only transferred synchronously in successive CLK cycles. When A <sub>12</sub> = 1, the sample function in the input buffers for the Feedback Array is disabled. The CLK pin then behaves like the HOLD pin, but with inverted polarity. In addition, the feedback path is disconnected, and the external inputs are multiplexed into the Feedback Array input buffers. |
| <b>A<sub>12</sub></b>               | I <sub>D</sub> | <b>INPUT MULTIPLEXER</b> —in the forward-propagation mode, address pin A <sub>12</sub> has the function of enabling the multiplexing of input pins into the Feedback Array. When A <sub>12</sub> is brought active-high, the path from output pins to the Feedback Array is disconnected, while a path from the input pins to the Feedback Array is enabled. At the same time, the function of the CLK pin is modified so that it behaves like an inverted-polarity HOLD pin.                                                                                                                |
| <b>A<sub>12</sub>-A<sub>0</sub></b> | I <sub>D</sub> | <b>ADDRESSES</b> —TTL-compatible inputs used to select the individual synapses and neurons. The lower 6 bits (A <sub>5</sub> -A <sub>0</sub> ) are column/neuron addresses and the upper 7 (A <sub>12</sub> -A <sub>6</sub> ) are row/input addresses, which together select one synapse. A <sub>12</sub> has a special function as an address pin and input multiplexer pin as described above.                                                                                                                                                                                             |
| <b>LRN</b>                          | I <sub>D</sub> | <b>LEARN CONTROL</b> —a TTL input for enabling the learning modes used to change the values of the synapse weights.                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| <b>SSYN</b>                         | I <sub>D</sub> | <b>SYNAPSE SELECT</b> —a TTL input that enables the row-decoding circuitry for applying program, erase, or input voltages to the row selected by A <sub>12</sub> -A <sub>6</sub> and BIAS pins. SSYN also activates the column-select circuitry for accessing a single synapse (per addresses A <sub>5</sub> -A <sub>0</sub> ) through the neuron and summing-node multiplexers in SYNR (Synapse Read) mode.                                                                                                                                                                                 |

## PIN DESCRIPTIONS (Contd.)

| Symbol                                 | Type           | Description and Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|----------------------------------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| WT                                     | I <sub>D</sub> | <b>WEIGHT-CELL SELECT</b> —a TTL input for selecting one or the other of the two EEPROM cells in the selected synapse (referred to as the <i>weight</i> EEPROM cell or the <i>reference</i> EEPROM cell). WT = 1 selects the <i>weight</i> EEPROM cell, WT = 0 selects the <i>reference</i> EEPROM cell.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| INC                                    | I <sub>D</sub> | <b>INCREASE or DECREASE SYNAPSE WEIGHT</b> —a TTL signal that specifies whether to increase (INC = 1) or decrease (INC = 0) the threshold voltage of the floating-gate EEPROM cell selected by the WT pin. Increasing a synapse weight corresponds to decreasing (erasing) the threshold of the corresponding <i>weight</i> EEPROM cell and/or increasing (programming) the threshold of the corresponding <i>reference</i> EEPROM cell. Similarly, decreasing a synapse weight corresponds to increasing the threshold of the <i>weight</i> EEPROM cell and/or decreasing the threshold of the <i>reference</i> EEPROM cell. The difference in threshold voltages between the <i>weight</i> and <i>reference</i> EEPROM cells is called $V_{T\_DIFF}$ . The relationships are:<br>$\text{Weight} = [V_{T\_REF} - V_{T\_WT}]$ and<br>$V_{T\_DIFF} = -\text{Weight}$ Typically, the weight-setting algorithm maintains a constant common-mode threshold voltage for all EEPROM cells. |
| BIAS                                   | I <sub>D</sub> | <b>BIAS-SYNAPSE SELECT</b> —a TTL input to select the nonvolatile bias synapses. It is used in conjunction with the A <sub>5</sub> –A <sub>0</sub> addresses to select one of 64 neurons and with A <sub>9</sub> –A <sub>6</sub> addresses to select one of 16 rows of bias synapses. A <sub>12</sub> determines the group of 16 rows selected: A <sub>12</sub> = 0 for Input Array bias, A <sub>12</sub> = 1 for Feedback Array bias. Bias-row addresses 10–15 are reserved for Intel internal use. Users should make sure that these bias synapses are zeroed if using custom software.                                                                                                                                                                                                                                                                                                                                                                                            |
| V <sub>PP1</sub> ,<br>V <sub>PP2</sub> | S <sub>A</sub> | <b>PROGRAMMING VOLTAGE SUPPLIES</b> —V <sub>PP1</sub> and V <sub>PP2</sub> are high-voltage pulse inputs required for training (see A.C. and D.C. Characteristics and Weight Setting). V <sub>PP1</sub> and V <sub>PP2</sub> are set to V <sub>CC</sub> during normal operation. They are connected to the gate and source of the EEPROM device during the WVTR (Weight V <sub>T</sub> Read) or RVTR (Reference V <sub>T</sub> Read) modes.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| QUER                                   | I <sub>D</sub> | <b>QUERY</b> —a TTL input that enables the query mode when QUER = 1. QUER activates interrogation of synapse weight and sum measurement.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

## PIN DESCRIPTIONS (Contd.)

| Symbol     | Type           | Description and Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SMO+, SMO- | O <sub>A</sub> | <b>SUMMING-NODE OUTPUTS</b> —differential analog outputs of the neuron summing nodes in the SMR (Sum Read) mode. SMO+ and SMO- are connected to the selected neuron by the A <sub>5</sub> -A <sub>0</sub> addresses for direct measurement of the differential voltage representing:<br>$\text{Net}_j = (\text{SMO}+) - (\text{SMO}-) = \sum \{\text{Weights} * \text{inputs}\} + \text{bias}.$ Differential currents can also be read, but only for a very limited range.<br>In the SYNR (Synapse Read) mode, addresses A <sub>12</sub> -A <sub>0</sub> and BIAS select an individual synapse to obtain its response to a corresponding input. The output is a differential voltage or current across the SMO± pins. SMO+ and SMO- are also used in the SMR/P (Sum Read/Perturb) mode to allow adding or subtracting increments of differential current from a selected neuron's summing nodes for use with the Madaline learning algorithm (see Training). |
| NMO        | O <sub>A</sub> | <b>NEURON OUTPUT</b> —a multiplexed analog output connected to the neuron output selected by addresses A <sub>5</sub> -A <sub>0</sub> in the NR (Neuron Read) mode. Selective sensing of neuron outputs facilitates implementations of back propagation and other learning algorithms with minimal hardware overhead. NMO is essential for system debugging.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| SYNO       | O <sub>A</sub> | <b>SYNAPSE OUTPUT</b> —an analog output connected to one of the selected synapse's two EEPROM-cell drains for threshold measurement in WVTR, RVTR, or V <sub>T</sub> Read modes. The synapse is selected with the A <sub>12</sub> -A <sub>0</sub> , BIAS and WT inputs (see Weight Setting).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

KEY: S = Power Supply    A = Analog    O = Output  
 I = Input                      D = Digital

## PRINCIPLES OF OPERATION

Figure 2 is a simplified model of a typical biological neuron cell. The neuron has several inputs attached to its body at points called "synapses." The variable-strength synapse connections can be either output-exciting or output-inhibiting. Input signals reaching the neuron body through these variable-strength synapses are summed by the neuron body. When the sum exceeds a threshold, the neuron output is activated.

The 80170NX chip is designed around this basic neuron model. The chip normally operates as 64 parallel processors, where each such processor is analogous to this neuron model. Figure 3 illustrates the 80170NX chip architecture as an array of external inputs ( $\mu_i$ ) and neuron outputs ( $v_j$ ). The intersections of external inputs and neurons are connected through synapses that consist of a multiplier (X) and a weight-storage unit ( $W_{ij}$ ).  $W_{ij}$  is the weight of the connection from input  $\mu_i$  to output  $v_j$ . Figure 3 illustrates only one array of intersections; the chip has

two such arrays—an Input Array and a Feedback Array. In addition to these arrays, each neuron is connected to fixed-input bias synapses ( $B_{kj}$ ) in each of the two arrays.

This normal mode of operation is called Parallel Distributed Processing (PDP). In PDP operation, each neuron computes the dot (inner) product of the external inputs ( $\mu_i$ ) times their corresponding synapse weights ( $W_{ij}$ ), and adds the sum of the fixed-input bias synapses ( $B_{kj}$ ). This dot product is then compressed through a sigmoid function, as follows:

$$v_j = \text{sigmoid} \{ \sum_i (\mu_i * W_{ij}) + \sum_k B_{kj} \}$$

The neuron output ( $v_j$ ) is a scalar quantity that indicates how closely the input vector matches the stored-weight vector. The sigmoid function through which the result of the dot products pass is illustrated later in Figures 19, 20 and 21.

The Input and Feedback Arrays each have 16 fixed-input bias synapses. Mathematically, all of these bias synapses act as a single bias to provide the



290408/2

Figure 2. Model of Biological Neuron Cell



290408/3

Figure 3. Typical Neural Net

threshold for the neuron's sigmoid function and to cancel offsets due to physical non-linearities in the chip. However, since the dynamic range of a single EEPROM bias synapse is limited, 16 of them are used. All 16 contribute to the dot product performed by the neuron, although seven are set by the training program, and the other nine are set by Intel's chip-initialization process.

The weights of all synapses—external-input synapses and fixed-input bias synapses are programmed by an external training system. Intel provides such a training system, as described in the TRAINING OPERATIONS section on page 22.

The chip uses Intel's fast CHMOS-III EEPROM technology. Synapses are implemented as differential EEPROM cell pairs, as shown in Figure 4. This implementation provides much more compact storage than conventional digital EEPROM memory because synapse weights are stored as analog values on the gates, and because analog multipliers are more compact than digital multipliers. Typical weight resolution of the differential EEPROM cell pairs is 6 to 7 bits. Worst-case resolution over a lifetime of 10 years is at least 4 bits, and greater than 6 bits can be obtained if the Bake-Train-Bake

Method is used. (See the Bake-Train-Bake section on page 29.)

Synapse weights are stored as analog transconductance values, each producing an analog output current from an analog input voltage and a stored-weight voltage. Currents generated by each synapse along a pair of summing lines (shown as a single column in Figure 3) are summed, converted to a voltage, and passed through a sigmoid function with voltage-controlled gain. When both Input Array and Feedback Array are active, the output corresponds to the sum of their two dot products. Identical mechanisms in each of 64 columns correspond to the 64 neuron outputs. The sigmoid function (illustrated in Figure 19) is a threshold function where dot products below the neuron's output threshold indicate a poor match between input and stored weight vectors. Conversely, neuron output will be high for dot products above the neuron's threshold. Each neuron's threshold can be changed independently by the learning algorithm, allowing different match criteria for different vectors. Changing bias-synapse weights alters the sum of currents, shifting the neuron threshold.



Figure 4. Synapse Implementation

As Figure 4 illustrates, each synapse contains a multiplier and a stored weight, and calculates one product. The synapse product is summed with those from other synapses along the summing lines to produce the dot (inner) product in the form of a differential current,  $I_+$  and  $I_-$ . The synapse weights are stored as a difference in floating-gate thresholds of a pair of EEPROM cells. Changing weight values involves altering the charge stored on the floating gates. These modifications represent variable-weight strength as well as polarity. Since the floating gates of an EEPROM cell pair have equal capacitance, unequal charge causes differences in floating-gate voltages.

The synapse's multiplier circuit generates a differential current,  $I_+$  and  $I_-$ , proportional to the product of the differential floating-gate voltage, and the differential input voltage,  $\Delta V_{IN}$ . The larger the differential voltages, the larger the differential current generated. Thus, the input and weight products are mapped into associated differential currents. Taking advantage of Kirchoff's Law, many such currents can be summed along a pair of bit lines. The sum is converted to a voltage by load devices attached to the bit lines.

## PROCESSING CONFIGURATIONS

The chip supports many neural network configurations. For example, several 80170NX chips can share an input bus, capturing different time slices by sequential activation of the **HOLD** function. Taking the **HOLD** pin high capacitively stores 64 analog input levels for each time slice. Many forms of signal processing (such as speech processing) can use this sampling method in which input data is gathered from different points in time.

Similarly, 64 analog voltages can be directed to the lower half of the synapses—the Feedback Array. Figure 5 shows a simplified block diagram of the input multiplex circuits. The path from the input pins  $I_0$ – $I_{63}$  to the Input Array buffers is always connected. In addition these 64 signals can also be multiplexed from the input pins to the Feedback Array buffers. In PDP operation the  $A_{12}$  address pin enables input multiplexing by creating a path from the input pins to the Feedback Array buffers, and disables the path from the output pins to the Feedback Array buffers. The **HOLD** and **CLK** signals control the propagation of the input signal to the



Figure 5. Input Multiplexing Circuits

Input Array and Feedback Array, respectively. Similarly the **RESET<sub>I</sub>** and **RESET<sub>F</sub>** disable their respective arrays.

Figures 6 through 10 illustrate some basic processing configurations. The simplest example is a 64-input single-layer feedforward network, shown in Figure 6(A). Here, 64-dimension input vectors (or "patterns") are directly mapped into 64-dimension output vectors, as determined by the synapse weights in the Input Array. In this minimal configuration, the Input Array inputs are enabled and the Feedback Array inputs are disabled by setting the **RESET<sub>I</sub>** pin low and the **RESET<sub>F</sub>** pin high. This is called the 64-input parallel distributed processing mode (PDP/64-input operation).

Figure 6(B) shows another variant of the PDP/64-input feedforward configuration. Here, the Feedback Array is driven directly from the external input

pins by taking **A<sub>12</sub>** and **CLK** high, disabling the Input Array by taking **RESET<sub>I</sub>** high, and enabling the Feedback Array by taking **RESET<sub>F</sub>** low.

In addition to the chip's 64-input configuration (PDP/64-input operation), a 128-input configuration (PDP/128-input operation) can be implemented. In this configuration, shown in Figure 7, a second set of 64 inputs on input pins  $I_0 - I_{63}$  is multiplexed to the Feedback Array. Each of the 64 neurons then calculates the dot product of both the Input Array and Feedback Array input vectors with their corresponding synapse weights. Pin **A<sub>12</sub>** enables this multiplex mode. When **A<sub>12</sub>** and **CLK** are set TTL-high and **RESET<sub>I</sub>**, **RESET<sub>F</sub>**, and **HOLD** at TTL-low, the first half of the input vector is applied to the input pins and routed to both the Input Array buffers and the Feedback Array buffers. When **HOLD** goes to TTL-high, the Input Array buffers store the analog levels and disconnect from the input pins. The second half



Figure 6. 64-Input Feedforward Configurations



Figure 7. 128-Input Feedforward Configurations

of the input vector is applied to the input pins which propagates to the Feedback Array, and a valid output will appear at the output pins  $N_0 - N_{63}$  one processing-delay later.

A single chip can perform two-layer operation by using the feedback connections and the clocked sample-and-hold features. Alternate activation of the two reset pins, **RESET<sub>I</sub>**, and **RESET<sub>F</sub>**, disables the corresponding Input Array and Feedback Array inputs, as shown in Figure 8(A). During Input Array processing, Feedback Array inputs are reset by taking **RESET<sub>F</sub>** high. The outputs then reflect the dot product of the inputs and the synapse weights stored in the Input Array. After a **CLK** pulse, which initiates processing by the Feedback Array, neuron outputs are driven into the feedback inputs of the Feedback Array. To prevent the external inputs at input pins from interfering with Feedback Array processing, inputs are disconnected from the Input Array by taking **RESET<sub>I</sub>** high. The fixed internal inputs to the bias synapses are also reset when **RESET<sub>I</sub>** or **RESET<sub>F</sub>** are disabled.

Hopfield networks are supported with the clocked feedback capability shown in Figure 8(B). This requires applying alternating **CLK** and **NE#** pulses. Continuous feedback is also supported and can be obtained by driving the **A<sub>11</sub>** pin to  $12V \pm 0.5V$ , the **A<sub>12</sub>** pin to  $0V$  and the **CLK** pin to TTL high.

Feedback connections can be used to recognize time-dependent input sequences, as in Figure 9(A). Here, results from the Input Array are fed back for multiple clock cycles to the Feedback Array. Figure 9(B) shows a configuration capable of generating sequences from a fixed input pattern.

Figure 10 combines the PDP/128-input operation with two-layer processing. The Input and Feedback Arrays are combined to allow up to 128 inputs and up to 64 outputs, as shown in Figure 10(B). If a 128-by-j matrix is used for the first layer of processing then a j-by-(64-minus-j) matrix located in the Feedback Array, as shown in Figure 10(B), can be used for the second layer of processing. The number of processing elements in the hidden layer, j, is defined as an integer that is less than 64. The outputs of the first cycle are clocked back into the Feedback Array; only the first j outputs of this cycle are valid. These outputs are multiplied by the j-by-(64-minus-j) matrix in the second cycle. Then, the outputs of the second cycle are read at the output pins  $N_j - N_{63}$ . Those portions of the synapse array outside the two matrices defined above, marked by "0" in Figure 10(B), must be set to weights of zero.

## MULTI-CHIP CONFIGURATIONS

One of two multi-chip interconnection configurations can be used: direct pin-to-pin interconnection, as shown in Figure 11(A), or bus interconnection, as shown in Figure 11(B). Direct pin-to-pin wiring is the more straightforward since no multiplexing is required. The busing example in Figure 11(B) shows a common, multiplexed bus for all communication. Alternatively, separate buses could be used between processing layers and for inputs and outputs. Bus interconnection provides a more flexible development environment; the clocking sequence of the **NE#**, **HOLD**, and **CLK** pins allows changes in data routing. The bus configuration has two drawbacks compared to direct interconnect: (1) data can be moved only in complete 64-neuron blocks, and (2) multiplexing is somewhat slower.



Figure 8. 64-Input Feedback Configurations

Intel offers a multi-chip prototyping board for 80170NX chips—the *ETANN Multi-chip Board (EMB)*. The EMB supports both pin-to-pin and bus interconnection for prototyping up to eight chips. It is an add-on to the INNTS training system, described further on in the TRAINING section. Multi-chip versions of the required hardware drivers, linking subroutines, and network simulation programs are provided.

## SYNAPSE CHARACTERISTICS

### Synapse Weight Operation

To change a synapse weight, the difference in voltage between the two EEPROM floating-gate cells is changed by adding charge to one cell and removing charge from the other using Fowler-Nordheim tunneling. Tunneling is a physical mechanism commonly used in conventional EEPROM cells; high voltage applied across a thin dielectric causes elec-

trons to tunnel directly through the dielectric, to or from a floating gate. The weight-modification voltage pulses induce Fowler-Nordheim tunneling in a selected synapse (see Figure 12).

A measurable indicator of the floating-gate voltage is the threshold voltage ( $V_T$ ) of the floating-gate cell itself. Figure 12 shows the floating-gate cell's current-voltage characteristics before and after a weight modification, along with the corresponding  $V_T$ 's. The  $V_T$  is the control-gate voltage at which the cell begins conducting a given amount of current, typically 1 to 10  $\mu$ A. In this example, the floating-gate voltage becomes more negative as electrons are added, corresponding to an increase in the cell  $V_T$ , since a more positive control-gate voltage is required to overcome the effect of the added electrons on the floating gate.



Figure 9. 64-Input Sequence Recognition and Generation Configurations

Synapse weights are represented by threshold-voltage differentials ( $V_{T\text{DIFF}}$ ) between the reference and weight EEPROM cells, where Weight =  $[V_{T\text{REF}} - V_{T\text{WT}}]$  and  $V_{T\text{DIFF}} = -\text{Weight}$ . All weight-changing procedures refer to  $V_T$  changes, which are measured by using the  $V_T$  read modes, WVTR and RVTR, as described in the MODE DESCRIPTIONS section.

### Synapse Multiply Characteristics

Figure 13 shows a typical four-quadrant multiply characteristic of a synapse. The output differential current is plotted as a function of the input voltage for eleven values of weights. A constant common-mode  $V_T$  among the two EEPROM cells is maintained in these results. The response is linear over

most of the weight range. (See the DC CHARACTERISTICS section on page 35 for a definition of  $V_{T\text{DIFF}}$ ,  $V_{T\text{COM}}$ ,  $V_{T\text{WT}}$ , and  $V_{T\text{REF}}$ .)

## MODE DESCRIPTIONS

### Signature Read

The 80170NX chip contains a signature code to differentiate it from other chips. There are two ways to read the code. When  $A_9$  goes to high voltage ( $12V \pm 0.5V$ ), the device is recognized as an Intel component when 89H is read from pins  $N_0-N_7$ , and as an 80170NX chip when CFH is read from pins  $N_8-N_{15}$ . The other option is to toggle through 16 bits at the NMO pin, reading 89H followed by CFH.



Figure 10. 128-Input Feedback Configuration

### PDP—Parallel Distributed Processing Mode

Parallel distributed processing is the normal processing operation, described in the Principles of Operation section on page 6. As shown in the Processing Configurations section on page 8, the input derivation is configuration-dependent, yielding a number of different processing characteristics.

### WMI/WMD—Weight-Modify Increase and Weight-Modify Decrease Modes

When the **LRN** pin is set to 1 the chip enters the learning, or training, mode. A synapse is selected by addresses  $A_{12}$ – $A_0$  and **BIAS**. Synapse weights are changed by first measuring the EEPROM-cell threshold (the stored weight) by using the WVTR mode. A calculation is then made of the voltage and pulse width needed for the desired weight modification. By pulsing the calculated high voltages on pins  $V_{PP1}$  and  $V_{PP2}$ , the weights are modified one at a time. For details, see the next section, TRAINING OPERATIONS on page 22.

The weight-setting algorithm applies multiple pulses in the process of setting a weight by using the error observed after each pulse and then making a better estimate for the next pulse. The algorithm also carries what it has learned in the process of setting one weight to the setting of the next weight. This adaptation is important for reducing the number of pulses and hence the total weight-setting time.

### WVTR—Weight $V_T$ Read Mode

A specific floating-gate device storing a desired synapse weight is selected by addresses  $A_{12}$ – $A_0$ , **BIAS**, and **WT** when in WVTR mode. The device's drain terminal is connected to the **SYNO** pin by on-chip decoding circuitry to allow  $V_T$  measurement as shown in Figure 14.

As an example, during  $V_T$  measurement, 3.0 volts is applied to **SYNO** while monitoring the current into **SYNO**.  $V_{PP1}$  and  $V_{PP2}$  supply the gate and source voltages, respectively, to the selected floating-gate transistor.  $V_T$  is measured by setting  $V_{PP2}$  (device source) to 2.0 volts and incrementing  $V_{PP1}$  (the



Figure 11. Multi-Chip Configurations

gate) from 0 to 4V until the **SYNO** (drain) current reaches the specified level (typically 1 to 10  $\mu$ A). The gate-to-source voltage,  $V_{PP1}$  minus  $V_{PP2}$ , that generates this current is the  $V_T$ . For example, given a 0.25 volt *reference* EEPROM cell  $V_T$ , a 0.25 volt *weight* EEPROM cell  $V_T$  corresponds to a synapse weight of zero; *weight* EEPROM cell  $V_T$ 's below 0.25 volt correspond to positive weights. Better synapse multiply characteristics are obtained when a constant common mode is maintained.  $V_T$ 's ranging from -1.0 to 1.50 volts are attainable corresponding to a weight range of -2.5 to +2.5 volts.

Figure 15 shows synapse multiply characteristics versus floating-gate device weights at different fixed-input voltages (the inverse of Figure 13).

### RMI, RMD, and RVTR—Reference Modify and Read Modes

These modes are identical to the corresponding weight-related modes WMI, WMD, and WVTR except that they affect the *reference* EEPROM-cell threshold ( $V_{T\_REF}$ ) instead of the *weight* EEPROM-cell threshold ( $V_{T\_WT}$ ); see Figure 4.

Zero synapse-weight values occur when  $V_{T\_WT}$  is set equal to  $V_{T\_REF}$ . Alternatively, unused synapses can be zeroed by programming both *weight* and *reference* cells to maximum (and equal)  $V_T$ 's. This is simpler and faster than setting  $V_{T\_DIFF}$  precisely to zero, and it reduces power consumption by turning the synapse cells off.



290408i12

Figure 12. EEPROM Floating-Gate Cell Characteristics



290408i13

Figure 13. Four-Quadrant Synapse Multiply Characteristics vs. Input Voltage

Figure 14.  $V_T$  Measurement System

The *reference EEPROM* cell's floating gate can be set at a fixed value or to a value opposite from that of the *weight EEPROM* cell. For maximum dynamic range of weights,  $V_{T\text{REF}}$  should be set opposite to  $V_{T\text{WT}}$ , and the average of  $V_{T\text{WT}}$  and  $V_{T\text{REF}}$  ( $V_{T\text{COM}}$ ) should be held constant at 0.25 volt, approximately the intrinsic (UV-erased) threshold level, as follows:

$$V_{T\text{WT}} = V_{T\text{COM}} - \frac{\text{Weight}}{2}$$

and

$$V_{T\text{REF}} = V_{T\text{COM}} + \frac{\text{Weight}}{2}$$

See Weight Setting in the TRAINING OPERATIONS section on page 24 for details.

### SMR—Sum Read Mode

The differential voltage generated at a pair of summing nodes by the sum-of-products differential current can be measured directly in the SMR mode.

The differential current is converted to a differential voltage through the use of non-linear resistive loads. The effective resistance of these loads vary with the common-mode current through them (see Figure 16). The common-mode current varies with the number of active synapses in the neuron. Addresses  $A_5-A_0$  select the desired pair of summing nodes (see Figure 17). The selected summing nodes are switched to the **SMO+** and **SMO-** pins. This differential voltage is a physical representation of the sum of products,  $\Sigma\{\text{Weights} * \text{inputs}\} + \text{bias}$ , for the selected neuron. This voltage is very small and unbuffered; it may contain systematic offsets and is not intended for external use.

Figure 18(A) shows how a differential voltage would be measured between **SMO+** and **SMO-**. This mode may also be used to perturb the selected sum by drawing current either from pins **SMO+** or **SMO-**. Drawing current from **SMO+** will increase the sum while drawing current from **SMO-** will decrease the sum, which is useful for implementation of the Madaline III learning algorithm.



290408i15

Figure 15. Synapse Four-Quadrant Multiply Characteristics vs. Weight



290408i16

Figure 16. Non-Linear Resistive Summing Load



290408i17

Figure 17. Summing Nodes Selection and Output

### SYNR—Synapse Read Mode

A particular synapse is selected by addresses  $A_{12}-A_0$  and **BIAS** in the SYNR mode, while other synapses connected to the same pair of summing nodes are disabled. This allows measurement of a synapse product contribution at that particular synapse to the total sum through the **SMO $\pm$**  pins as a function of input level. Although a differential voltage can be measured at the pins **SMO $\pm$** , this is not an accurate representation because of the non-linear load characteristics. It is better to measure actual-cell current by forcing both pins to  $V_{cc}$  and measuring the difference in **SMO+** and **SMO-** current levels, as shown in Figure 18(B). Feedback Array synapses can be measured by using the input pads in the input multiplex mode. Rows used for threshold setting (a subset of the bias units) always have

their inputs set to an internal, constant, positive reference. The effective input varies with  $V_{REF_I}$  for the Input Array and with  $V_{REF_O}$  for the Feedback Array.

### NR—Neuron Read Mode

Addresses  $A_5-A_0$  select a neuron output to be connected to the **NMO** pin in NR mode. This allows the neuron outputs to be multiplexed out one at a time by the training system, eliminating the need for multiplexers between layers in a multi-layer network. Figures 19 and 20 show the neuron output's sigmoid transfer characteristics as a function of gain and reference control, versus summing-node current input. Figure 20 illustrates the neuron output transfer characteristics versus the summing current at various  $V_{REF_O}$ 's.



Figure 18. Summing Node Output Measurement

290408i18

Figure 19. Neuron Output Transfer Characteristic vs. Summing Current and  $V_{GAIN}$ 

290408i19



Figure 20. Neuron Output Transfer Characteristic vs. Summing Current and  $V_{REF}$



Figure 21. Sigmoid Characteristic in  $V_{GAIN}$  and  $H_{GAIN}$  Modes

The sigmoid has an input offset that varies slightly from chip to chip. The offset can be nulled during chip initialization by using one or more of the bias synapses. Figure 21 shows the  $H_{GAIN}$  sigmoid threshold mode.

### Mode Summary

Table 1 shows the signal states in the various operating modes. Valid **BIAS** addresses are  $A_9$  through  $A_0$  ( $A_5$ – $A_0$  are neuron addresses), with  $A_{11}$  and  $A_{10} = 0$  ( $A_{11}$  and  $A_{10}$  are only used for normal synapse selection). In all synapses (external input and bias),  $A_{12}$  selects between Input and Feedback Arrays (input = 0, feedback = 1). For AC waveforms, see Figures 30, 31 and 32 on pg. 35-36.

## TRAINING OPERATIONS

### Training Systems

Intel offers a complete development and training system for 80170NX chips—the *Intel Neural Network Training System (INNTS)* and the *ETANN Multi-chip Board (EMB)*. The INNTS and EMB are compatible with any personal computer based on an Intel 80286 (or later) processor with at least 1 MB of memory in addition to the 640K of conventional memory.

The INNTS includes a Personal Computer PROM Programmer (PCPP), 80170 Adapter, Generic Programmer Interface (GUPI) base, Confidence Test Module, two 80170NX chips, interface software, and two neural network simulation programs.

The simulation programs are *iBrainMaker* from California Scientific Software, and *iDynaMind* from NeuroDynamX, Inc. Both simulation programs incorporate the 80170NX chip's sigmoid threshold characteristics during simulation. Both programs provide menu-driven functions to download synapse weights to the chip, test through the chip, and perform chip-in-loop optimization to compensate for analog variations. The programs support partitioning of the Feedback Array to allow networks with multiple hidden layers to be implemented on a single chip.

Users who prefer to write their own simulation or training algorithms are provided with a Training System Interface Library (TSIL) containing over two dozen subroutines which can be used to control the operations of the chip. These routines are described in detail in the Programmer's Reference section of the *INNTS Neural Network Training System User's Guide*.

### Multi-Chip Training

The 80170 Adapter provides only one socket with which to program and train one chip. Multi-chip designs require the EMB add-on board, which attaches to the INNTS 80170 Adapter. An *EMB* includes an eight-socket prototyping board and two 80170NX chips. The INNTS software is upwardly compatible with the EMB board, and multi-chip versions of the two simulation programs, *iBrainMaker* and *iDynaMind*, are provided with the EMB. The TSIL library contains routines to access each socket of the EMB separately. The board is shipped with jumper blocks attached on the bottom side to configure two analog buses for multiplexing 64 analog inputs and outputs to a target socket. When the chips are trained, the user has the option of removing the jumper blocks and wirewrapping directly from pin to pin. By connecting one chip's output pins directly to another chip's input pins, real-time processing configurations can be prototyped.

### Chip-In-Loop Training

Due to fabrication variations, the characteristics of synapses and neurons vary within a single chip and within batches of chips. To compensate for these variations and to optimize chip performance, both the INNTS and the EMB support chip-in-loop training.

This method replaces the synapse weights that would otherwise be simulated by a simulation program, with actual weights stored in a chip. During training, weights are downloaded to the chip and outputs of the chip are fed back to the training simulator, which evaluates the result and updates the chip's weights accordingly.

### Weight Setting

Changes to synapse weights are accomplished by applying high-voltage pulses in the WMI and WMD modes. First, one of the two floating-gate devices in a single synapse is selected by the addresses  $A_{12}$ – $A_0$ , **BIAS**, and **WT**, then high-voltage pulses are applied on pins  $V_{PP1}$  and  $V_{PP2}$  (see Figure 32). An adaptive algorithm is used to give a precise target weight with a minimum number of pulses, independent of synapse-to-synapse variations.

The EEPROM cell's floating-gate charge is modified by applying a high-voltage pulse for tens of microseconds. The weight-setting algorithm determines the pulse voltage,  $V_{PP2}$ . After the pulse is applied, the algorithm reads the synapse weight. If there are differences from the target weight, a subsequent pulse is applied.

The synapse weight is directly related to the difference in threshold voltages of the two floating-gate

Table 1. Mode Summary

|                                               | CE# | NE# | HOLD               | CLK | RESET <sub>T</sub> | RESET <sub>F</sub> | H <sub>GAIN</sub> | QUER | LRN | SSYN | A <sub>0</sub> -A <sub>5</sub> | A <sub>6</sub> -A <sub>11</sub> | A <sub>12</sub> |
|-----------------------------------------------|-----|-----|--------------------|-----|--------------------|--------------------|-------------------|------|-----|------|--------------------------------|---------------------------------|-----------------|
| <b>Parallel Distributed Processing (PDP):</b> |     |     |                    |     |                    |                    |                   |      |     |      |                                |                                 |                 |
| PDP/64 Inputs                                 | 0   | 0   | X                  | X   | 0                  | 1                  | 0                 | 0    | 0   | 0    | X                              | X                               | 0               |
| PDP/128 Inputs                                | 0   | 0   | 0/1 <sup>(8)</sup> | 1   | 0                  | 0                  | 0                 | 0    | 0   | 0    | X                              | X                               | 1               |
| Neuron Disable                                | 0   | 1   | X                  | X   | 0                  | 1                  | 0                 | 0    | 0   | 0    | X                              | X                               | 0               |
| Power Down                                    | 1   | X   | X                  | X   | X                  | X                  | X                 | X    | X   | X    | X                              | X                               | X               |
| <b>Weight Modify:</b>                         |     |     |                    |     |                    |                    |                   |      |     |      |                                |                                 |                 |
| Wt Mod Increase (WMI)                         | 0   | 1   | X                  | X   | X <sup>(1)</sup>   | X <sup>(1)</sup>   | X                 | 0    | 1   | 1    | V                              | V                               | V               |
| Wt Mod Decrease (WMD)                         | 0   | 1   | X                  | X   | X <sup>(1)</sup>   | X <sup>(1)</sup>   | X                 | 0    | 1   | 1    | V                              | V                               | V               |
| Wt Vt Read (WVTR)                             | 0   | 1   | X                  | X   | X <sup>(1)</sup>   | X <sup>(1)</sup>   | X                 | 1    | 1   | 1    | V                              | V                               | V               |
| Ref Mod Increase (RMI)                        | 0   | 1   | X                  | X   | X <sup>(1)</sup>   | X <sup>(1)</sup>   | X                 | 0    | 1   | 1    | V                              | V                               | V               |
| Ref Mod Decrease (RMD)                        | 0   | 1   | X                  | X   | X <sup>(1)</sup>   | X <sup>(1)</sup>   | X                 | 0    | 1   | 1    | V                              | V                               | V               |
| Ref Vt Read (RVTR)                            | 0   | 1   | X                  | X   | X <sup>(1)</sup>   | X <sup>(1)</sup>   | X                 | 1    | 1   | 1    | V                              | V                               | V               |
| <b>Query:</b>                                 |     |     |                    |     |                    |                    |                   |      |     |      |                                |                                 |                 |
| Sum Read (SMR)                                | 0   | X   | V                  | V   | V                  | V                  | X                 | 1    | 0   | 0    | V                              | X                               | V               |
| Synapse Read (SYNR)                           | 0   | X   | V                  | V   | V                  | V                  | X                 | 1    | 0   | 1    | V                              | V                               | V               |
| Neuron Read (NR)                              | 0   | 0   | V                  | V   | V                  | V                  | V                 | 1    | 0   | 0    | V                              | X                               | V               |
| <b>Reset/Perturb:</b>                         |     |     |                    |     |                    |                    |                   |      |     |      |                                |                                 |                 |
| Erase Wt Column                               | 0   | 1   | X                  | X   | X <sup>(1)</sup>   | X <sup>(1)</sup>   | X                 | 0    | 1   | 0    | V                              | X                               | X               |
| Erase Ref Column                              | 0   | 1   | X                  | X   | X <sup>(1)</sup>   | X <sup>(1)</sup>   | X                 | 0    | 1   | 0    | V                              | X                               | X               |
| Prog Wt Column                                | 0   | 1   | X                  | X   | X <sup>(1)</sup>   | X <sup>(1)</sup>   | X                 | 0    | 1   | 0    | V                              | X                               | X               |
| Prog Ref Column                               | 0   | 1   | X                  | X   | X <sup>(1)</sup>   | X <sup>(1)</sup>   | X                 | 0    | 1   | 0    | V                              | X                               | X               |
| Sum Read/Perturb (SMR/P)                      | 0   | 0   | V                  | V   | V                  | V                  | V                 | 1    | 0   | 0    | V                              | X                               | V               |
| <b>Signature Modes:</b>                       |     |     |                    |     |                    |                    |                   |      |     |      |                                |                                 |                 |
| Standard                                      | 0   | 0   | X                  | X   | X                  | X                  | 0                 | 0    | 0   | X    | X                              | X <sup>(4)</sup>                | X               |
| NW vs NX                                      | 0   | 0   | X                  | X   | 1                  | 1                  | 1                 | 0    | 0   | X    | X                              | X <sup>(4)</sup>                | X               |
| NMO Signature                                 | 0   | 0   | X                  | X   | X                  | X                  | 1                 | 1    | 0   | X    | V                              | X <sup>(4)</sup>                | X               |
| <b>Continuous Feedback:</b>                   |     |     |                    |     |                    |                    |                   |      |     |      |                                |                                 |                 |
| With Input Array Disabled                     | 0   | 0   | X                  | 1   | 1                  | 0                  | 0                 | 0    | 0   | X    | X                              | X <sup>(6)</sup>                | X               |

- NOTES:**
- (1) Preferred RESET<sub>I</sub> = RESET<sub>F</sub> = 1, if RESET<sub>I</sub>/RESET<sub>F</sub> = 0, the selected synapse will conduct current. This may affect the programming conditions. The state of these pins must be consistent between programming and verifying.
  - (2) Force SMO± to V<sub>CC</sub> and measure current.
  - (3) Sink differential current from the SMO± pins.
  - (4) A<sub>9</sub> = V<sub>HH</sub>.
  - (5) V<sub>REF0</sub> is less than 0.7V.
  - (6) A<sub>11</sub> = V<sub>HH</sub>.
  - (7) Outputs may be active, depending on state of NE#.
  - (8) See Figure 7.

**SYMBOLS:**

- 0 = Logic "0"
- 0/1 = Transition from 0 to 1 (see Figure 7).
- 1 = Logic "1"
- X = Don't Care Inputs, Indeterminate State Outputs
- Q = Valid Data Output
- V = Valid Input
- Z = High Impedance
- V<sub>CC</sub> = Logic Supply Voltage
- V<sub>HH</sub> = 12 ± 0.5V
- V<sub>P1</sub> & V<sub>P2</sub> = High-Voltage Pulse Inputs
- V<sub>G</sub> & V<sub>S</sub> = Gate and Source Voltages—used in SYNR mode
- I<sub>D</sub> = EEPROM Cell Drain Current

Table 1. Mode Summary (Contd.)

|                                               | BIAS | WT | INC | V <sub>GAIN</sub> | V <sub>REFI</sub> | V <sub>REFO</sub> | I <sub>O-N<sub>63</sub></sub> | N <sub>O-N<sub>63</sub></sub> | SMO±                           | NMO | SYNO           | V <sub>PP1</sub> | V <sub>PP2</sub> |
|-----------------------------------------------|------|----|-----|-------------------|-------------------|-------------------|-------------------------------|-------------------------------|--------------------------------|-----|----------------|------------------|------------------|
| <b>Parallel Distributed Processing (PDP):</b> |      |    |     |                   |                   |                   |                               |                               |                                |     |                |                  |                  |
| PDP/64 Inputs                                 | X    | X  | X   | V                 | V                 | V                 | V                             | Q                             | Z                              | Z   | Z              | V <sub>CC</sub>  | V <sub>CC</sub>  |
| PDP/128 Inputs                                | X    | X  | X   | V                 | V                 | V                 | V                             | Q                             | Z                              | Z   | Z              | V <sub>CC</sub>  | V <sub>CC</sub>  |
| Neuron Disable                                | X    | X  | X   | V                 | V                 | V                 | V                             | Z                             | Z                              | Z   | Z              | V <sub>CC</sub>  | V <sub>CC</sub>  |
| Power Down                                    | X    | X  | X   | X                 | X                 | X                 | X                             | Z                             | Z                              | Z   | Z              | V <sub>CC</sub>  | V <sub>CC</sub>  |
| <b>Weight Modify:</b>                         |      |    |     |                   |                   |                   |                               |                               |                                |     |                |                  |                  |
| Wt Mod Increase (WMI)                         | V    | 1  | 1   | X                 | X                 | X                 | X                             | Z                             | Z                              | Z   | Z              | V <sub>P1</sub>  | V <sub>P2</sub>  |
| Wt Mod Decrease (WMD)                         | V    | 1  | 0   | X                 | X                 | X                 | X                             | Z                             | Z                              | Z   | Z              | V <sub>P1</sub>  | V <sub>P2</sub>  |
| Wt Vt Read (WVTR)                             | V    | 1  | X   | X                 | X                 | X                 | X                             | Z                             | Z                              | Z   | I <sub>D</sub> | V <sub>G</sub>   | V <sub>S</sub>   |
| Ref Mod Increase (RMI)                        | V    | 0  | 1   | X                 | X                 | X                 | X                             | Z                             | Z                              | Z   | Z              | V <sub>P1</sub>  | V <sub>P2</sub>  |
| Ref Mode Decrease (RMD)                       | V    | 0  | 0   | X                 | X                 | X                 | X                             | Z                             | Z                              | Z   | Z              | V <sub>P1</sub>  | V <sub>P2</sub>  |
| Ref Vt Read (RVTR)                            | V    | 0  | X   | X                 | X                 | X                 | X                             | Z                             | Z                              | Z   | I <sub>D</sub> | V <sub>G</sub>   | V <sub>S</sub>   |
| <b>Query:</b>                                 |      |    |     |                   |                   |                   |                               |                               |                                |     |                |                  |                  |
| Sum Read (SMR)                                | X    | X  | X   | X                 | V                 | V                 | V                             | X <sup>(7)</sup>              | Q                              | X   | Z              | V <sub>CC</sub>  | V <sub>CC</sub>  |
| Synapse Read (SYNR)                           | V    | X  | X   | X                 | V                 | V                 | V                             | X <sup>(7)</sup>              | V <sub>CC</sub> <sup>(2)</sup> | X   | Z              | V <sub>CC</sub>  | V <sub>CC</sub>  |
| Neuron Read (NR)                              | X    | X  | X   | V                 | V                 | V                 | V                             | Q                             | Q                              | Q   | Z              | V <sub>CC</sub>  | V <sub>CC</sub>  |
| <b>Reset/Perturb:</b>                         |      |    |     |                   |                   |                   |                               |                               |                                |     |                |                  |                  |
| Erase Wt Column                               | X    | 1  | 1   | X                 | X                 | X                 | X                             | Z                             | Z                              | Z   | Z              | V <sub>P1</sub>  | V <sub>P2</sub>  |
| Erase Ref Column                              | X    | 0  | 1   | X                 | X                 | X                 | X                             | Z                             | Z                              | Z   | Z              | V <sub>P1</sub>  | V <sub>P2</sub>  |
| Prog Wt Column                                | X    | 1  | 0   | X                 | X                 | X                 | X                             | Z                             | Z                              | Z   | Z              | V <sub>P1</sub>  | V <sub>P2</sub>  |
| Prog Ref Column                               | X    | 0  | 0   | X                 | X                 | X                 | X                             | Z                             | Z                              | Z   | Z              | V <sub>P1</sub>  | V <sub>P2</sub>  |
| Sum Read/Perturb (SMR/P)                      | X    | X  | X   | V                 | V                 | V                 | V                             | Q                             | Q <sup>(3)</sup>               | Q   | Z              | V <sub>CC</sub>  | V <sub>CC</sub>  |
| <b>Signature Modes:</b>                       |      |    |     |                   |                   |                   |                               |                               |                                |     |                |                  |                  |
| Standard                                      | X    | X  | X   | X                 | X                 | V                 | X                             | Q                             | Z                              | Z   | Z              | V <sub>CC</sub>  | V <sub>CC</sub>  |
| NW vs NX                                      | X    | X  | X   | X                 | X                 | V <sup>(5)</sup>  | X                             | Q                             | Z                              | Z   | Z              | V <sub>CC</sub>  | V <sub>CC</sub>  |
| NMO Signature                                 | X    | X  | X   | X                 | X                 | V                 | X                             | Q                             | Q                              | Q   | Z              | V <sub>CC</sub>  | V <sub>CC</sub>  |
| <b>Continuous Feedback:</b>                   |      |    |     |                   |                   |                   |                               |                               |                                |     |                |                  |                  |
| With Input Array Disabled                     | X    | X  | X   | V                 | X                 | V                 | X                             | Q                             | Z                              | Z   | Z              | V <sub>CC</sub>  | V <sub>CC</sub>  |

- NOTES:**
- (1) Preferred RESET<sub>I</sub> = RESET<sub>F</sub> = 1, if RESET<sub>I</sub>/RESET<sub>F</sub> = 0, the selected synapse will conduct current. This may affect the programming conditions. The state of these pins must be consistent between programming and verifying.
  - (2) Force SMO± to V<sub>CC</sub> and measure current.
  - (3) Sink differential current from the SMO± pins.
  - (4) A<sub>0</sub> = V<sub>HH</sub>.
  - (5) V<sub>REFO</sub> is less than 0.7V.
  - (6) A<sub>11</sub> = V<sub>HH</sub>.
  - (7) Outputs may be active, depending on state of NE#.
  - (8) See Figure 7.

**SYMBOLS:**

- 0 = Logic "0"
- 0/1 = Transition from 0 to 1 (see Figure 7).
- 1 = Logic "1"
- X = Don't Care Inputs, Indeterminate State Outputs
- Q = Valid Data Output
- V = Valid Input
- Z = High Impedance
- V<sub>CC</sub> = Logic Supply Voltage
- V<sub>HH</sub> = 12 ± 0.5V
- V<sub>P1</sub> & V<sub>P2</sub> = High-Voltage Pulse Inputs
- V<sub>G</sub> & V<sub>S</sub> = Gate and Source Voltages—used in SYNR mode
- I<sub>D</sub> = EEPROM Cell Drain Current

devices in that synapse (see  $V_T$  Read Mode description). Floating-gate threshold voltages are measured repeatedly during the weight-setting algorithm to assess how well the weight-change process is proceeding and to make better estimates of the voltage to be used in subsequent weight settings.

The difference between target  $V_T$  ( $V_{T,\text{target}}$ ) and real  $V_T$  ( $V_{T,\text{eo}}$ ) is  $\Delta V_T$ . The floating gate is programmed when  $\Delta V_T$  is positive and erased when  $\Delta V_T$  is negative. In other words, programming raises the EEPROM cell threshold, while erasing reduces its threshold:

$$\Delta V_T = V_{T,\text{target}} - V_{T,\text{eo}}$$

If  $\Delta V_T > 0$ , then program  
If  $\Delta V_T < 0$ , then erase

Figures 22 and 23 illustrate the calculated relationship between a desired synapse-weight change,  $\Delta V_T$ , and the high voltage which should be applied at  $V_{PP2}$  to achieve it. A family of calculated curves is shown for various initial thresholds,  $V_{T,\text{eo}}$ , for a fixed pulse width of 100  $\mu\text{s}$  to illustrate the relationship. The exact relationship may vary slightly from these values. Table 2 shows the equations from which the curves were generated.

Figure 24 is a flow chart of the weight-setting algorithm. The algorithm begins by initializing the address of the floating-gate device and two coefficients:  $B_{PGM}$  and  $B_{ERS}$  ( $B_{PGM}$  for programming,  $B_{ERS}$  for erase). The  $\Delta V_T$  for the next iteration is determined from the difference between the  $V_{T,\text{target}}$  and the most recently measured  $V_T$  ( $= V_{T,\text{eo}} = V_{T,\text{real}}$ ). The  $V_{PP2}$  for the next pulse is iteratively

solved for by using the functions given in Table 2,  $f(V_{PP,\text{old}})$  or  $g(V_{PP,\text{old}})$ , for programming and erasing, respectively. The functions  $f'$  and  $g'$  signify the derivatives of these functions, respectively.

After applying a pulse, the threshold is measured again and subtracted from the original threshold to arrive at the real  $\Delta V_T$ . If the measured  $\Delta V_T$  deviates by more than 1% from the desired  $\Delta V_T$ , a new  $B_{PGM}$  or  $B_{ERS}$  will be calculated based on the previous  $V_{PP}$  and  $B_{PGM}$  or  $B_{ERS}$ . This procedure is repeated until the measured  $V_T$  falls within 1% of the  $V_{T,\text{target}}$ . The final  $B_{PGM}$  and  $B_{ERS}$  will be stored for use by the next synapse in the same chip. Because synapses on a chip have very similar program and erase characteristics, the  $B$  coefficients do not change significantly after the first few synapse weights are modified.

The difference between the desired  $\Delta V_T$  and the actual  $\Delta V_T$  is reduced by each subsequent pulse as the adaptive algorithm learns from experience.

### Madaline Learning

Using SMO+ and SMO- in the SMR/P (Sum Read/Perturb) mode allows adding or subtracting incremental differential current from a selected neuron's summing nodes. Sum perturbation supports training by the Madaline learning algorithm. This involves the application of many perturbations followed by grading the improvements produced by each perturbation. Synapse weights are then changed to produce the same effects as the perturbations which caused the most significant improvements in the output responses.



Figure 22.  $V_{PP2}$  Voltage Curves for Positive  $\Delta V_T$  — Program

Figure 23.  $V_{PP2}$  Voltage Curves for Negative  $\Delta V_T$  - Erase

290408i23

### Function Simulation

Many standard neural network simulators can model the 80170NX chip's dot product neurons reasonably well. The constraints of the chip's analog circuits can be reflected by specific limits on input and weight-setting ranges and gain values. A first-order emulation allows evaluation of whether a chip or group of chips can be trained to perform the desired pattern-mapping application. Currently there are no effective analytical techniques or algorithms for determining appropriate neural network architectures by simply observing the training information set.

The following transfer characteristic simulates the chip's neuron output at typical operating conditions ( $V_{GAIN} = 5V$ ,  $V_{REF0} = 1.4V$ ,  $V_{REFI} = 1.4V$ , PDP/64-input operation):

$$V_j = \left\{ \frac{2}{(1 + e^{-8\sum_i \mu_i W_{ij}})} \right\} - 1$$

where

- $\mu_i$  Inputs, constrained so that  $-1 \leq (V_j - V_{REFI}) / V_{REF0} \leq +1$ .
- $W_{ij}$  Weights, constrained so that  $-1 \leq ((weight V_T - reference V_T)/2.5V) \leq +1$ .
- $V_j$  Outputs, constrained so that  $-1 \leq ((Output - V_{REF0}) / V_{REF0}) \leq +1$ .

These normalized input and synapse-weight values correspond to actual inputs of 0 to 2.8V and weights of -2.5 to 2.5V. The normalized output will also correspond to an actual range of 0 to 2.8V.

A more accurate model of the chip's output under the above conditions and with  $V_{GAIN} = 5V$  is:

$$V_j = \left\{ \frac{1.8}{(1 + e^{-8(\sum_i \mu_i(1.2 - 0.2\mu_i^2)W_{ij}(1.5 - 0.5W_{ij}^2) - \sum_k B_{kj})})} \right\} - 0.9$$

This model includes the roll-off in the synapse characteristic at large weight and input magnitudes, as well as the output range limitations. The estimated equation for  $V_{GAIN} = 3.3V$  (with  $V_{REFI} = V_{REF0} = 1.5V$ ) is:

$$V_j = \left\{ \frac{1.83}{1 + e^{-1.74 \times (\text{Synaptic Contributions})}} \right\} - 0.94$$

### Bake-Train-Bake

The chip's weight retention over extended periods of time can be significantly improved by a process called Bake-Train-Bake. Charge movement in the nitride layer between the EEPROM cell's control gate and floating gate creates dipoles. The dipoles compensate the electric field created by charges on the floating gates, thus affecting the effective floating-gate potential. This electrical reaction offsets the effective  $V_{T DIFF}$ 's from their original targets; thus, affecting the chip's processing accuracy. High-temperature bake operations accelerate this phenomenon. When combined with re-training, the

Table 2. Training/Weight Setting Algorithm Equations

|                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Program</b>                               | $\Delta V_T = V_{To} + V_{PP} - V_{Teo} - 1.375 \times 10^{-6} * B_{PGM} / \{ \ln[e^{(B_{PGM}/E_o)} + 3.242 \times 10^4 * B_{PGM} * T_p] \}$<br>and $E_o = 7.273 \times 10^5 * V_{PP} + 7.273 \times 10^5 * (V_{To} - V_{Teo})$                                                                                                                                                                                                                                                                          |
| <b>Erase</b>                                 | $\Delta V_T = V_{To} - 1.125 * V_{PP} - V_{Teo} + 1.375 \times 10^{-6} * B_{ERS} / \{ \ln[e^{(B_{ERS}/E_o)} + 3.242 \times 10^4 * B_{ERS} * T_E] \}$<br>and $E_o = 8.182 \times 10^5 * V_{PP} + 7.273 \times 10^5 * (V_{Teo} - V_{To})$                                                                                                                                                                                                                                                                  |
| <b>V<sub>PP</sub> (Program) Calculations</b> | $f(V_{PP}) = V_{To} + V_{PP} - \Delta V_T - V_{Teo} - 1.375 \times 10^{-6} * B_{PGM} / \{ \ln[e^{(B_{PGM}/E_o)} + 3.242 \times 10^4 * B_{PGM} * T_p] \}$<br>$f'(V_{PP}) = 1 - \{ B_{PGM}^2 * e^{(B_{PGM}/E_o)} / \{ [ \ln[e^{(B_{PGM}/E_o)} + 3.242 \times 10^4 * B_{PGM} * T_p] ]^2 * E_o^2 * [ e^{(B_{PGM}/E_o)} + 3.242 \times 10^4 * B_{PGM} * T_p ] \} \}$<br>where $V_{PP\_new} = V_{PP\_old} - f(V_{PP\_old}) / f'(V_{PP\_old})$ until $V_{PP\_new} = > \sim V_{PP\_old}$                         |
| <b>V<sub>PP</sub> (Erase) Calculations</b>   | $g(V_{PP}) = V_{To} - \Delta V_T - V_{Teo} - 1.125 * V_{PP}$<br>$+ 1.375 \times 10^{-6} * B_{ERS} / \{ \ln[e^{(B_{ERS}/E_o)} + 3.242 \times 10^4 * B_{ERS} * T_E] \}$<br>$g'(V_{PP}) = -1.125 + \{ 1.125 * B_{ERS}^2 * e^{(B_{ERS}/E_o)} / [ E_o^2 * [ \ln[e^{(B_{ERS}/E_o)} + 3.242 \times 10^4 * B_{ERS} * T_E] ]^2 * [ e^{(B_{ERS}/E_o)} + 3.242 \times 10^4 * B_{ERS} * T_E ] ] \}$<br>where $V_{PP\_new} = V_{PP\_old} - g(V_{PP\_old}) / g'(V_{PP\_old})$ until $V_{PP\_new} = > \sim V_{PP\_old}$ |
| <b>B<sub>PGM</sub> Calculations</b>          | $h(B_{PGM}) = 7.273 \times 10^5 * (V_{To} + V_{PP} - \Delta V_T - V_{Teo}) * \{ \ln[e^{(B_{PGM}/E_o)} + 3.242 \times 10^4 * B_{PGM} * T_p] \} - B_{PGM}$<br>$h'(B_{PGM}) = 7.273 \times 10^5 * (V_{To} + V_{PP} - \Delta V_T - V_{Teo}) *$<br>$\{ (e^{(B_{PGM}/E_o)}) / E_o + 3.242 \times 10^4 * T_p \} / (e^{(B_{PGM}/E_o)} + 3.242 \times 10^4 * B_{PGM} * T_p) - 1$<br>where $B_{PGM\_new} = B_{PGM\_old} - h(B_{PGM\_old}) / h'(B_{PGM\_old})$<br>until $B_{PGM\_new} = > \sim B_{PGM\_old}$        |
| <b>B<sub>ERS</sub> Calculations</b>          | $k(B_{ERS}) = (V_{Teo} + \Delta V_T - V_{To} + 1.125 * V_{PP}) *$<br>$\{ \ln[e^{(B_{ERS}/E_o)} + 3.242 \times 10^4 * B_{ERS} * T_E] \} - 1.375 \times 10^{-6} * B_{ERS}$<br>$k'(B_{ERS}) = (V_{Teo} + \Delta V_T - V_{To} + 1.125 * V_{PP}) *$<br>$\{ (e^{(B_{ERS}/E_o)}) / E_o * [ e^{(B_{ERS}/E_o)} + 3.242 \times 10^4 * T_E ] \} - 1.375 \times 10^{-6}$<br>where $B_{ERS\_new} = B_{ERS\_old} - k(B_{ERS\_old}) / k'(B_{ERS\_old})$<br>until $B_{ERS\_new} = > \sim B_{ERS\_old}$                   |

**NOTES:** $V_{To} \sim 0.5V$  $B_{PGM} = B_{pgm}$  = program mode constant $\Delta V_T = \text{del. } V_T$  = EEPROM cell threshold change ("threshold delta") $V_{TEO} = V_{Teo}$  = present EEPROM threshold  
 $B_{ERS} = B_{ers}$  = erase mode constant

net effect is to reduce this  $V_T$  shift, since the electrical field differences between re-trainings is much smaller than between the originally untrained and the first-training conditions. The change in synapse weight versus bake time is shown in Figure 25. The improvement in a single 24-hour 250°C bake-train operation represents 3 to 4 bits of resolution over the chip's minimum data-retention lifetime of 10 years. Two bake-train cycles compensate for lifetime  $V_T$  shifts well within the chip's intrinsic processing accuracy. The Acceleration Factor note at the top-left of the chart indicates that baking at 260°C causes the percent change shown on the vertical axis to occur 1000 times faster than it would occur if the chip were stored at 125°C, and 100000 times faster than it would occur if the chip were stored at 75°C.

**Temperature and  $V_{CC}$  Performance**

Figures 26 and 27 show a typical neuron's response to ambient temperature and  $V_{CC}$ , respectively. For typical input patterns and synapse weights, four inputs at weight = 0.5V are swept while monitoring the neuron output at  $V_{GAIN} = 5V$ .

In Figure 26, two temperature effects are visible in the high-gain region of the response: the offset of the neuron shifts and the slope (effective gain) of the neuron decreases. The offset change corresponds to a change in the sum of products of about 2  $\mu A$  or about 1/5 of one synapse at full weight and full input (0.25% out of 64 synapses) over the commercial temperature range. The offset change is highly dependent on the inputs and weights employed. The output slope decreases with temperature by 0.3% per degree Celsius over the nominal at 25°C (total 20% change over the commercial range).



290408i24

Figure 24. Weight-Setting Algorithm

In Figure 27, the slope in the high-gain region of the sigmoid characteristic does not change significantly with  $V_{CC}$ . The  $V_{CC}$  effect is characterized as almost exclusively as a change in offset. The offset shifts by about 0.26V which corresponds to less than  $2.5 \mu A$  in the total sum over the 4.75V to 5.25V  $V_{CC}$  range ( $\pm 5\%$ ).

For both the temperature and  $V_{CC}$  cases, the voltage change at the saturated regions of the extremes (of low and high inputs) is less than 10 mV.

## PERFORMANCE

### Weight-Cycling Performance

EEPROM cycling failures are a common concern. The strong electric field required by thin oxide

EEPROMs for tunneling can tear the oxide in defect regions. Several process and design improvements have been introduced to combat the problem.

Intel's ETOX-II flash memory technology is designed for extended cycling. An advanced tunnel oxide increases charge carrying capability ten-fold, minimizing the oxide area per synapse subjected to the tunneling electric field, and consequently reducing the probability of encountering an oxide defect.

During normal operation with the iNNTS training system, programming and erasing is performed by the weight-setting algorithm described above (see TRAINING OPERATIONS on page 22). Programming and erasing synapse weights is accomplished by cycling the transistors of the reference EEPROM cells and weight EEPROM cells. The 80170NX chip is specified for a minimum of 10,000 such cycles.

Figure 25. Reduction of  $V_T$  Shifts Through Bake-Train-Bake

290408i25



Figure 26. Sigmoid Temperature Sensitivity

290408i26



Figure 27. Sigmoid  $V_{cc}$  Sensitivity

Chip-cycling performance was verified by performing cycling experiments on 50 chips. A cycle was defined as first setting the weight to  $-2.5V$  (or less) and then setting it to  $+2.5V$  (or more). All 10,240 synapses of each chip were subjected to 10,000 cycles. After the experiment, the iNNTS still had no difficulty setting all weights to  $\pm 2.5V$ . Performance After Radiation Exposure

The 80170NX chip's behavior and recognition performance were evaluated after subjecting the chip to ionization radiation (see Castro, *et al.* 1992). The chips were irradiated with electrons at  $10\text{MeV}$  at a flux density between  $1.8 \times 10^{10}/\text{cm}^2$  and  $4.1 \times 10^{11}/\text{cm}^2$  up to an accumulated dose of about 26krad. Two pattern-recognition networks were involved in the study: a 64-45-52 character-recognition network and an 80-54-10 digit-recognition network.

Significant degradation in recognition performance occurred after about 6krad of irradiation. Figure 28 illustrates the mean-square-error (MSE) and misclassification statistics for the character-recognition network (for 104 patterns) as a function of radiation dose and elapsed time for one chip.

The degradation in performance can be attributed in part to the relaxation of the synapse weights shown for the same chip in Figure 29. The relaxation of synapse weights results from the combined effects of oxide charge generation and trapping, and the

photovoltaic effect caused by Bremsstrahlung radiation. Figures 28 and 29 show that the relaxation of weights continues after irradiation and has the most dominant effect on the degradation of recognition performance.

The chip-in-loop training method was employed on one of the character-recognition chips after each exposure to irradiation. 100% recognition was achieved within two such chip-in-loop training sessions, up until the last exposure at the accumulated dose of 26krad. Some permanent damage to the synapse weights occurred at that dose. Nevertheless, none of the irradiated chips exhibited total malfunction in performing classifications. Despite the failure of some synapses, most irradiated chips can be re-trained with the chip-in-loop method and/or by re-locating the weight array. However, the level of degradation in classification performance and the ability to be re-trained via chip-in-loop training are dependent on the particular network architecture, synapse weights, and reserve capacity of the synapse weights.

## ABSOLUTE MAXIMUM RATINGS

|                                   |                                                 |
|-----------------------------------|-------------------------------------------------|
| Operating Temperature.....        | $0^{\circ}\text{C}$ to $+70^{\circ}\text{C}$    |
| Storage Temperature .....         | $-65^{\circ}\text{C}$ to $+125^{\circ}\text{C}$ |
| Bake-Train-Bake Temperature ..... | $75^{\circ}\text{C}$ to $+260^{\circ}\text{C}$  |



Figure 28. Misclassified Patterns and MSE After Radiation Exposure

290408i28



Figure 29. Weight Distributions After Radiation Exposure

290408i29

|                                                                       |                                |
|-----------------------------------------------------------------------|--------------------------------|
| Voltage on Digital Inputs<br>with Respect to $V_{SS}$ .....           | -2.0V to +7.0V <sup>(1)</sup>  |
| Voltage on Analog Inputs and<br>Outputs with Respect to $V_{SS}$ .... | -2.0V to +7.0V <sup>(1)</sup>  |
| $V_{CC}$ Supply Voltage<br>with Respect to $V_{SS}$ .....             | -2.0V to +7.0V <sup>(1)</sup>  |
| $V_{PP1}, V_{PP2}$ Voltages<br>with Respect to $V_{SS}$ .....         | -2.0V to +21.0V <sup>(1)</sup> |
| Output Short Circuit Current .....                                    | 100 mA <sup>(2)</sup>          |

\* **NOTICE:** Stresses above those listed under Absolute Maximum Ratings may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any conditions above those indicated in the operational sections of this specification is not implied. Exposure to Absolute Maximum Rating conditions for extended periods may affect device stability.

All specifications contained within the following tables are subject to change.

#### NOTES:

1. Minimum D.C. input voltage is -0.5V. During transitions: digital and analog inputs may undershoot to -2.0V;  $V_{PP}$  supplies may overshoot to +21.0V; and analog inputs and outputs may overshoot to voltages of  $V_{CC} + 2.0V$ , but for time periods of only 20 ns or less.
2. Output Short Circuit is for no more than 1 second, with no more than 1 output shorted at a time.

#### OPERATING CONDITIONS

| Symbol     | Parameter               | Min  | Max  | Units | Conditions              |
|------------|-------------------------|------|------|-------|-------------------------|
| $T_A$      | Operating Temperature   | 0    | 70   | °C    | Processing and Training |
| $V_{CC}$ ™ | $V_{CC}$ Supply Voltage | 4.75 | 5.25 | V     |                         |

#### DC CHARACTERISTICS At Room Temperature

| Symbol    | Parameter                             | Min  | Max       | Units   | Conditions                           |
|-----------|---------------------------------------|------|-----------|---------|--------------------------------------|
| $I_{LI}$  | Input Leakage Current                 |      | $\pm 0.1$ | $\mu A$ | $V_{IN} = 3.5V$                      |
| $I_{LO}$  | Output Leakage Current                |      | $\pm 1.0$ | $\mu A$ | $V_{OUT} = 3.5V$                     |
| $I_{OH}$  | Output High Source Current            |      | -400      | $\mu A$ | $V_{OUT} \geq 2.4V, V_{REFO} = 1.4V$ |
| $I_{OL}$  | Output Low Sink Current               |      | 2.1       | mA      | $V_{OUT} \leq .45V, V_{REFO} = 1.4V$ |
| $V_{IA}$  | Analog Input Voltage                  | 0    | 3.5       | V       | $V_{CC} = 5.0V$                      |
| $V_{OA}$  | Analog Output Voltage                 | 0    | 4.0       | V       | $V_{CC} = 5.0V, R_L = 10K\Omega$     |
| $I_{CC}$  | $V_{CC}$ Active Supply Current        |      | 450       | mA      | $V_{CC} = 5.0V, CE\# = V_{IH}$       |
| $I_{CCS}$ | $V_{CC}$ Standby Supply Current       |      | 1         | mA      | $V_{CC} = 5.0V, CE\# = V_{IH}$       |
| $I_{P1}$  | $V_{PP1}$ Programming Supply Current  |      | 1         | mA      | $V_{PP1} = 20.0V, V_{CC} = 5.0V$     |
| $I_{P2}$  | $V_{PP2}$ Programming Supply Current  |      | 1         | mA      | $V_{PP2} = 18.0V, V_{CC} = 5.0V$     |
| $V_{P1}$  | $V_{PP1}$ High-Voltage Switch Voltage | 18   | 19        | V       | see Training Algorithm               |
| $V_{P2}$  | $V_{PP2}$ Weight Modify Pulse Voltage | 12.5 | 18        | V       | see Training Algorithm               |

**DC CHARACTERISTICS**  
At Room Temperature

| Symbol                                      | Parameter                                                                  | Min  | Max  | Units | Conditions                                                |
|---------------------------------------------|----------------------------------------------------------------------------|------|------|-------|-----------------------------------------------------------|
| $V_{PL}$                                    | $V_{PP1}, V_{PP2}$ Inactive/Low Voltage                                    | 4.75 | 5.25 | V     |                                                           |
| $V_{IL}$                                    | Digital Input Low Voltage                                                  | -0.1 | 0.8  | V     | $V_{CC} = 5.0V$                                           |
| $V_{IH}$                                    | Digital Input High Voltage                                                 | 2.0  | 5.5  | V     | $V_{CC} = 5.0V$                                           |
| $V_{REFI}$                                  | Input Reference Voltage                                                    | 0    | 1.7  | V     | $[V_{REFI(TTL)} = 1.4V]$                                  |
| $V_{REFo}$                                  | Output Reference Voltage                                                   | 0.5  | 2.0  | V     | For Symmetric operation<br>maximum $V_{REFo(TTL)} = 1.6V$ |
| $V_{GAIN}$                                  | Gain Control Voltage                                                       | 0.0  | 5.0  | V     |                                                           |
| $V_{T\_WT}, V_{T\_REF}$                     | Threshold Voltage ( $V_T$ ) of weight EEPROM cell or reference EEPROM cell | -1.0 | 1.5  | V     | $I_D = 10 \mu A @ SYNO$<br>$V_S = 2.0V @ V_{PP2}$         |
| $V_{T\_COM}$                                | $V_T$ Common Mode = $(V_{T\_WT} + V_{T\_REF})/2$                           | 0    | 0.5  | V     | $V_{T\_COM}$ typical = 0.25V                              |
| $V_{T\_DIFF}$                               | $V_T$ Difference = $(V_{T\_WT} - V_{T\_REF})$ , Weight Dynamic Range       | -2.5 | 2.5  | V     |                                                           |
| Weight                                      | Weight = $-V_{T\_DIFF}$                                                    |      |      |       |                                                           |
| See Figure 27 for power supply sensitivity. |                                                                            |      |      |       |                                                           |

**AC CHARACTERISTICS**

| Symbol          | Parameter                                           | Min | Max      | Units              | Conditions                                                                                                      |
|-----------------|-----------------------------------------------------|-----|----------|--------------------|-----------------------------------------------------------------------------------------------------------------|
| $t_{IVOV}$      | Processing Delay ( $T_P$ ) $V_{GAIN}$<br>$H_{GAIN}$ |     | 3<br>1.5 | $\mu s$<br>$\mu s$ | with 6- to 7-bit resolution at output pin, $Z_i = 100 \text{ pf}$ and $10K\Omega$ to ground.<br>$V_{REFo} = 2V$ |
| $t_{ELOV}$      | Chip Enable to Output Valid ( $T_{CE}$ )            |     | 20       | $\mu s$            |                                                                                                                 |
| $t_{NLOV}$      | Neuron Enable to Output Valid ( $T_{NE}$ )          |     | 5        | $\mu s$            |                                                                                                                 |
| $t_{RHQV}$      | RESET <sub>int</sub> High/Low to Valid Output       |     | 5        | $\mu s$            |                                                                                                                 |
| $t_{IVHH}$      | Input Valid to HOLD High Setup                      | 150 |          | ns                 |                                                                                                                 |
| $t_{CL-H/CH-L}$ | CLK Input Rise and Fall Time                        |     | 100      | ns                 |                                                                                                                 |
| $t_{CHCL}$      | CLK High Pulse Width                                | 150 |          | ns                 |                                                                                                                 |

**AC CHARACTERISTICS**

| Symbol          | Parameter                                       | Min | Max       | Units      | Conditions                                                                 |
|-----------------|-------------------------------------------------|-----|-----------|------------|----------------------------------------------------------------------------|
| $t_{OVCH}$      | Output Valid (Feedback Input) to CLK High Setup | 150 |           | ns         |                                                                            |
| $t_{IH}$        | CLK Overlap for Reset                           | 150 |           | ns         |                                                                            |
| $Vf_O$          | Output Slew Rate                                | 5   |           | V/ $\mu$ s | $C_L = 100 \text{ pF}$                                                     |
| $t_{HOLD}$      | Sample and Hold Circuit Hold Time               |     | 10<br>0.8 | s<br>s     | 1% droop @ $T_A = 25^\circ\text{C}$<br>1% droop @ $T_A = 70^\circ\text{C}$ |
| $t_{IVP1H}$     | Input Valid to $V_{PP1}$ Setup                  | 200 |           | ns         |                                                                            |
| $t_{P1HP2H}$    | $V_{PP1}$ Setup Time Before $V_{PP2}$           | 100 |           | ns         |                                                                            |
| $t_{P1L-H/H-L}$ | $V_{PP2}$ Pulse Rise/Fall Time                  | 500 |           | ns         |                                                                            |
| $t_{P1HP1L}$    | $V_{PP2}$ Pulse Width                           | 0.5 | 1000      | $\mu$ s    |                                                                            |
| $t_{PLIV}$      | $V_{PP1}, V_{PP2}$ Recovery Time                | 10  |           | $\mu$ s    |                                                                            |

**CAPACITANCE**

| Symbol    | Parameter          | Min | Max | Units | Conditions |
|-----------|--------------------|-----|-----|-------|------------|
| $C_{IN}$  | Input Capacitance  |     | 12  | pF    |            |
| $C_{OUT}$ | Output Capacitance |     | 12  | pF    |            |



290408|30

Figure 30. AC Waveforms for Parallel Processing



290408|31

Figure 31. AC Waveforms for QUERY Modes



Figure 32. AC Waveforms for Weight Modify

## PIN ASSIGNMENTS

|                                   |                                   |                                     |                                   |                                    |                                    |
|-----------------------------------|-----------------------------------|-------------------------------------|-----------------------------------|------------------------------------|------------------------------------|
| A <sub>1</sub> - N <sub>14</sub>  | C <sub>2</sub> - N <sub>13</sub>  | E <sub>3</sub> - N.C.               | J <sub>15</sub> - A <sub>3</sub>  | P <sub>1</sub> - I <sub>49</sub>   | R <sub>2</sub> - I <sub>40</sub>   |
| A <sub>2</sub> - N.C.             | C <sub>3</sub> - N <sub>12</sub>  | E <sub>4</sub> - N <sub>11</sub>    | J <sub>16</sub> - A <sub>1</sub>  | P <sub>2</sub> - I <sub>46</sub>   | R <sub>3</sub> - I <sub>39</sub>   |
| A <sub>3</sub> - N <sub>17</sub>  | C <sub>4</sub> - N.C.             | E <sub>14</sub> - N <sub>52</sub>   | J <sub>17</sub> - A <sub>4</sub>  | P <sub>3</sub> - N.C.              | R <sub>4</sub> - I <sub>37</sub>   |
| A <sub>4</sub> - N <sub>20</sub>  | C <sub>5</sub> - N <sub>19</sub>  | E <sub>15</sub> - N.C.              | K <sub>1</sub> - I <sub>61</sub>  | P <sub>4</sub> - N.C.              | R <sub>5</sub> - N.C.              |
| A <sub>5</sub> - V <sub>CC</sub>  | C <sub>6</sub> - V <sub>SS</sub>  | E <sub>16</sub> - N <sub>58</sub>   | K <sub>2</sub> - I <sub>59</sub>  | P <sub>5</sub> - N.C.              | R <sub>6</sub> - I <sub>29</sub>   |
| A <sub>6</sub> - N <sub>21</sub>  | C <sub>7</sub> - N <sub>26</sub>  | E <sub>17</sub> - N <sub>59</sub>   | K <sub>3</sub> - I <sub>62</sub>  | P <sub>6</sub> - N.C.              | R <sub>7</sub> - I <sub>30</sub>   |
| A <sub>7</sub> - N <sub>25</sub>  | C <sub>8</sub> - N <sub>30</sub>  | F <sub>1</sub> - N <sub>2</sub>     | K <sub>4</sub> - I <sub>60</sub>  | P <sub>7</sub> - I <sub>31</sub>   | R <sub>8</sub> - I <sub>26</sub>   |
| A <sub>8</sub> - N <sub>29</sub>  | C <sub>9</sub> - N <sub>32</sub>  | F <sub>2</sub> - H <sub>GAIN</sub>  | K <sub>14</sub> - A <sub>7</sub>  | P <sub>8</sub> - I <sub>25</sub>   | R <sub>9</sub> - I <sub>22</sub>   |
| A <sub>9</sub> - V <sub>CC</sub>  | C <sub>10</sub> - N <sub>33</sub> | F <sub>3</sub> - N <sub>3</sub>     | K <sub>15</sub> - A <sub>5</sub>  | P <sub>9</sub> - V <sub>SS</sub>   | R <sub>10</sub> - I <sub>17</sub>  |
| A <sub>10</sub> - N <sub>34</sub> | C <sub>11</sub> - N <sub>37</sub> | F <sub>4</sub> - N <sub>7</sub>     | K <sub>16</sub> - A <sub>8</sub>  | P <sub>10</sub> - I <sub>18</sub>  | R <sub>11</sub> - I <sub>13</sub>  |
| A <sub>11</sub> - N <sub>38</sub> | C <sub>12</sub> - V <sub>SS</sub> | F <sub>14</sub> - N <sub>56</sub>   | K <sub>17</sub> - A <sub>6</sub>  | P <sub>11</sub> - I <sub>12</sub>  | R <sub>12</sub> - I <sub>14</sub>  |
| A <sub>12</sub> - N <sub>42</sub> | C <sub>13</sub> - N <sub>44</sub> | F <sub>15</sub> - N <sub>60</sub>   | L <sub>1</sub> - I <sub>57</sub>  | P <sub>12</sub> - N.C.             | R <sub>13</sub> - N.C.             |
| A <sub>13</sub> - V <sub>CC</sub> | C <sub>14</sub> - N.C.            | F <sub>16</sub> - D.U.              | L <sub>2</sub> - I <sub>55</sub>  | P <sub>13</sub> - N.C.             | R <sub>14</sub> - I <sub>6</sub>   |
| A <sub>14</sub> - N <sub>43</sub> | C <sub>15</sub> - N <sub>51</sub> | F <sub>17</sub> - N <sub>61</sub>   | L <sub>3</sub> - I <sub>58</sub>  | P <sub>14</sub> - N.C.             | R <sub>15</sub> - I <sub>4</sub>   |
| A <sub>15</sub> - N <sub>46</sub> | C <sub>16</sub> - N <sub>50</sub> | G <sub>1</sub> - V <sub>GAIN</sub>  | L <sub>4</sub> - I <sub>54</sub>  | P <sub>15</sub> - N.C.             | R <sub>16</sub> - I <sub>3</sub>   |
| A <sub>16</sub> - N.C.            | C <sub>17</sub> - N <sub>55</sub> | G <sub>2</sub> - N <sub>0</sub>     | L <sub>14</sub> - BIAS            | P <sub>16</sub> - V <sub>PP2</sub> | R <sub>17</sub> - V <sub>PP1</sub> |
| A <sub>17</sub> - N <sub>49</sub> | D <sub>1</sub> - N <sub>6</sub>   | G <sub>3</sub> - V <sub>REF0</sub>  | L <sub>15</sub> - A <sub>9</sub>  | P <sub>17</sub> - INC              | S <sub>1</sub> - I <sub>41</sub>   |
| B <sub>1</sub> - N <sub>10</sub>  | D <sub>2</sub> - N <sub>9</sub>   | G <sub>4</sub> - N <sub>1</sub>     | L <sub>16</sub> - A <sub>12</sub> | Q <sub>1</sub> - I <sub>47</sub>   | S <sub>2</sub> - N.C.              |
| B <sub>2</sub> - N <sub>15</sub>  | D <sub>3</sub> - N.C.             | G <sub>14</sub> - N <sub>62</sub>   | L <sub>17</sub> - A <sub>10</sub> | Q <sub>2</sub> - I <sub>42</sub>   | S <sub>3</sub> - I <sub>38</sub>   |
| B <sub>3</sub> - N <sub>16</sub>  | D <sub>4</sub> - N.C.             | G <sub>15</sub> - SMO-              | M <sub>1</sub> - I <sub>53</sub>  | Q <sub>3</sub> - I <sub>43</sub>   | S <sub>4</sub> - I <sub>35</sub>   |
| B <sub>4</sub> - N <sub>18</sub>  | D <sub>5</sub> - N.C.             | G <sub>16</sub> - N <sub>63</sub>   | M <sub>2</sub> - I <sub>56</sub>  | Q <sub>4</sub> - N.C.              | S <sub>5</sub> - I <sub>34</sub>   |
| B <sub>5</sub> - N.C.             | D <sub>6</sub> - N.C.             | G <sub>17</sub> - NMO               | M <sub>3</sub> - I <sub>52</sub>  | Q <sub>5</sub> - I <sub>36</sub>   | S <sub>6</sub> - I <sub>32</sub>   |
| B <sub>6</sub> - N <sub>24</sub>  | D <sub>7</sub> - N <sub>22</sub>  | H <sub>1</sub> - V <sub>CC</sub>    | M <sub>4</sub> - I <sub>48</sub>  | Q <sub>6</sub> - I <sub>33</sub>   | S <sub>7</sub> - I <sub>28</sub>   |
| B <sub>7</sub> - N <sub>23</sub>  | D <sub>8</sub> - N <sub>28</sub>  | H <sub>2</sub> - V <sub>REF</sub>   | M <sub>14</sub> - LRN             | Q <sub>7</sub> - I <sub>27</sub>   | S <sub>8</sub> - I <sub>24</sub>   |
| B <sub>8</sub> - N <sub>27</sub>  | D <sub>9</sub> - V <sub>CC</sub>  | H <sub>3</sub> - RESET <sub>F</sub> | M <sub>15</sub> - NE#             | Q <sub>8</sub> - I <sub>23</sub>   | S <sub>9</sub> - V <sub>SS</sub>   |
| B <sub>9</sub> - N <sub>31</sub>  | D <sub>10</sub> - N <sub>35</sub> | H <sub>4</sub> - V <sub>SS</sub>    | M <sub>16</sub> - A <sub>11</sub> | Q <sub>9</sub> - I <sub>21</sub>   | S <sub>10</sub> - I <sub>19</sub>  |
| B <sub>10</sub> - N <sub>36</sub> | D <sub>11</sub> - N <sub>41</sub> | H <sub>14</sub> - V <sub>SS</sub>   | M <sub>17</sub> - WT              | Q <sub>10</sub> - I <sub>20</sub>  | S <sub>11</sub> - I <sub>15</sub>  |
| B <sub>11</sub> - N <sub>40</sub> | D <sub>12</sub> - N.C.            | H <sub>15</sub> - A <sub>0</sub>    | N <sub>1</sub> - I <sub>51</sub>  | Q <sub>11</sub> - I <sub>16</sub>  | S <sub>12</sub> - I <sub>11</sub>  |
| B <sub>12</sub> - N <sub>39</sub> | D <sub>13</sub> - N.C.            | H <sub>16</sub> - SMO+              | N <sub>2</sub> - I <sub>50</sub>  | Q <sub>12</sub> - I <sub>10</sub>  | S <sub>13</sub> - I <sub>9</sub>   |
| B <sub>13</sub> - N.C.            | D <sub>14</sub> - N.C.            | H <sub>17</sub> - V <sub>CC</sub>   | N <sub>3</sub> - N.C.             | Q <sub>13</sub> - I <sub>7</sub>   | S <sub>14</sub> - I <sub>8</sub>   |
| B <sub>14</sub> - N <sub>45</sub> | D <sub>15</sub> - N.C.            | J <sub>1</sub> - I <sub>63</sub>    | N <sub>4</sub> - I <sub>44</sub>  | Q <sub>14</sub> - N.C.             | S <sub>15</sub> - I <sub>5</sub>   |
| B <sub>15</sub> - N <sub>47</sub> | D <sub>16</sub> - N <sub>54</sub> | J <sub>2</sub> - CLK                | N <sub>14</sub> - SSYN            | Q <sub>15</sub> - I <sub>0</sub>   | S <sub>16</sub> - N.C.             |
| B <sub>16</sub> - N <sub>48</sub> | D <sub>17</sub> - N <sub>57</sub> | J <sub>3</sub> - HOLD               | N <sub>15</sub> - N.C.            | Q <sub>16</sub> - I <sub>1</sub>   | S <sub>17</sub> - I <sub>2</sub>   |
| B <sub>17</sub> - N <sub>53</sub> | E <sub>1</sub> - N <sub>4</sub>   | J <sub>4</sub> - RESET <sub>I</sub> | N <sub>16</sub> - QUER            | Q <sub>17</sub> - CE#              |                                    |
| C <sub>1</sub> - N <sub>8</sub>   | E <sub>2</sub> - N <sub>5</sub>   | J <sub>14</sub> - A <sub>2</sub>    | N <sub>17</sub> - SYNO            | R <sub>1</sub> - I <sub>45</sub>   |                                    |

N.C. = NO CONNECT

D.U. = DON'T USE (RESERVED)

## ORDERING INFORMATION

| Test/Temperature Category | Package Type | Performance Specification         | Order Code |
|---------------------------|--------------|-----------------------------------|------------|
| Commercial                | 208-PGA      | Standard t <sub>IVOV</sub> = 3 μS | A80170NX   |

## 208-PIN PGA PACKAGE



290408133

**REFERENCES****General**

- 80170NX Neural Network Technology and Applications. Intel Corp., 1992.
- Holler, M., S. Tam, H. Castro, and R. Benson, "An Electrically Trainable Artificial Neural Network (ETANN) with 10240 'Floating Gate' Synapses," *International Joint Conference on Neural Networks*, June 1989. Vol. II, 191.
- Roy, M., M. Holler, S. Tam, and H. Castro, "Testing An Analog VLSI Neural Network with 10240 'Floating Gate' Synapses," *1990 IEEE VLSI Test Symposium*.
- Tam, S., M. Holler, J. Brauch, A. Pine, A. Peterson, S. Anderson, and S. Deiss, "Reconfigurable Multi-Chip Analog Neural Network; Recognition and Back Propagation Training," *1992 International Joint Conference on Neural Networks*, Baltimore, Maryland. Vol. 2, 625.
- Tam, S., B. Gupta, H. Castro, and M. Holler, "Learning On An Analog VLSI Neural Network Chip," *Proceedings of the 1990 IEEE International Conference on Systems, Man, and Cybernetics*. November 1990, pp. 701-703.
- Calvin, J., S. Rogers, D. Zahirniak, "Characterization of the 80170NX (ETANN) Chip Sigmoidal Transfer Function for a Device  $V_{GAIN} = 3.3V$ " (available from Intel).
- Castro, H., et al, "Radiation Exposure Effects on the Performance of the ETANN (80170NX)," Intel Corporation, 1992.
- Kern, L., D. Andes, "Design and Development of a Real-Time Neural Processor Using the Intel 80170NX Electrically Trainable Artificial Neural Network (ETANN)," 1992 Government Microcircuit Application Conference, Digest of Papers, pp. 269-272.
- Badgett, W., K. Burkett, M. Campbell, D. Wu, B. Denby, C. Lindsey, R. Blair, S. Kuhlmann, J. Romano, "A Neural Network Calorimeter Trigger Used in CDF," *IEEE 1992 Nuclear Science Symposium and Medical Imaging Conference*, October 25-31, 1992, Orlando, Florida.
- Thorson, M., F. Warthman, M. Holler, "A Neural-Network Audio Synthesizer," *Dr. Dobb's Journal*, February, 1993.
- Brauch, J., S. Tam, M. Holler, A. Shmurun, "Analog VLSI Neural Networks for Impact Signal Processing," *IEEE MICRO* Dec., 1992, pp. 34-45.
- Akkila, T., T. Francke, T. Lindblad, A. Eide, "An Analog Neural Network Hardware Solution to Cherenkov Ring Imaging Particle Identifier," *Nuclear Instruments and Methods in Physics Research*, North-Holland, March 1993.
- Akkila, T., T. Lindblad, B. Lund-Jenson, G. Szekely, A. Eide, "A Hardware Implementation of an Analog Neural Network for Gaussian Peak-fitting," *Nuclear Instruments and Methods in Physics Research*, North-Holland, March 1993.
- Wang, C., C. Wu, "Analog Neural Networks Solve Ambiguity Problems in Medium PRF Radar Systems," *1993 IEEE International Conference on Neural Networks*, San Francisco, CA.
- Brown, J., E. DeRouin, E. Straub, "Integrated Detection and Segmentation for Hyperspectral Imagery Using Neural Networks," *Proc. International Symposium on Spectral Sensing Research*, Maui, Nov. 15-20, 1992.

**Cognitive Psychology**

- Rumelhart, D.E. and J.L. McClelland, *Parallel Distributed Processing Explorations in the Microstructure of Cognition*.  
Volume 1: Foundations  
Volume 2: Psychological and Biological Models  
MIT Press, Bradford Book, Cambridge, Mass, 1988. Original printing 1986.

Rumelhart, D.E. and J.L. McClelland, *Explorations in Parallel Distributed Processing: A Handbook of Models, Programs, and Exercises*. (Programs on floppy will run on an IBM PC. C Source code included). MIT Press, Bradford Book, Cambridge, Mass., 1988.

Rumelhart, David, Geoffrey E. Hinton, and Ronald J. Williams, "Learning Representations by Back-Propagating Errors," *Nature* Vol. 323 No. 9, October 1986.

### Neurobiology

Kandel, E. R., and J. H. Schwartz, *Principles of Neural Science*. 2nd edition. Elsevier, New York. Medical text with extensive detail on the function of the neuron and the human nervous system.

Burnod, Y., *An Adaptive Neural Network: The Cerebral Cortex*. Prentice Hall, London, 1990.

### Neural Network Models and Learning

Kohonen, T., *Self-Organization and Associative Memory*. Springer-Verlag, New York. 2nd edition 1988. First edition 1984. Good general reference.

Lippmann, R. P., "An Introduction to Computing with Neural Nets," *IEEE ASSP Magazine*, April 1987. Overview article of the various networks and learning paradigms for an issue of ASSP dedicated to neural networks.

Koch, C. and I. Jegev, ed. *Methods in Neuronal Modeling*. The MIT Press, Cambridge, Mass., 1989.

Hinton, G., and J. Anderson, ed. *Parallel Models of Associative Memory*. Lawrence Erlbaum Associates, Publishers, Hillsdale, New Jersey, 1989.

Kanerva, P., *Sparse Distributed Memory*. Bradford Book, The MIT Press, Cambridge, Mass., 1988.

Hopfield J. J. and D. W. Tank, "Computing with Neural Circuits: A Model," *Science* Vol. 233, August 1986: 625.

Anderson, J. and E. Rosenfeld, ed. *Neurocomputing Foundations of Research*. The MIT Press, Cambridge, Mass., 1988.

Andes, D., B. Widrow, M. Lehr, E. Wan, "Madaline Rule III: A Robust Algorithm for Training Neural Networks," *International Joint Conference on Neural Networks*, 1990, Vol. I: 533-536.

### Speech Recognition

Parsons, T., *Voice and Speech Processing*. McGraw-Hill, New York.

Waibel, A., T. Hanazawa, G. Hinton, K. Shikano, and K. Lang, "Phoneme Recognition Using Time-Delay Neural Networks," *IEEE Trans. on Acoustics, Speech and Signal Processing* Vol. 37, No. 3, March 1989. Work by Japanese Research consortium ATR in conjunction with Carnegie-Mellon University.

Waibel, A. and K. Lee, ed. *Readings in Speech Recognition*. Morgan Kaufmann Publishers Inc., San Mateo, California, 1990.

### Temporal Pattern Recognition

Wolf, L., *Recurrent Nets for the Storage of Cyclic Sequences*.

Williams, R. J. and D. Zipser, "A Learning Algorithm For Continually Running Fully Recurrent Neural Networks," *Institute for Cognitive Science Report #8805*, Oct. 1988, U.C. San Diego.

Pearlmutter, B. A., "Learning State Space Trajectories in Recurrent Neural Networks," *Proceedings of the International Joint Conference on Neural Networks*, June 1989, Vol. II: 365.

## Implementation

Mead, C., *Analog VLSI and Neural Systems*. Addison Wesley, New York, 1989.

Mead, C. and M. Ismail, ed. *Analog VLSI Implementation of Neural Systems*. Kluwer Academic Press, Boston, 1989.

von Neumann, J., *The Computer and the Brain*. Yale University Press, New Haven, Connecticut, 1958.

## Control

Nguyen, D. and B. Widrow, "The Truck Backer Upper: An Example of Self Learning in Neural Networks," *International Joint Conference on Neural Networks*, June 1989, Washington, D.C.

Miller, W., R. Sutton, P. Werbos, "Neural Networks for Control," *The MIT Press*, Cambridge MA, 1991.

Staib, W. and R. Staib, "The Intelligent Arc Furnace Controller: A Neural Network Electrode Position Optimization System for the Electric Arc Furnace," *International Joint Conference on Neural Networks*, June 1992, Vol. III: 1.

## GLOSSARY

**Bias Synapse**—See *fixed-input bias synapse*.

**Bake-Train-Bake**—An experimental procedure used to enhance the long-term stability of the 80170NX synapse weights. In this procedure, the chip is baked, then trained, then baked again.

**Chip-In-Loop Training**—A procedure used to train an 80170NX-based neural network, also known as chip-in-loop optimization. In this procedure, actual 80170NX neuron outputs are used in the training algorithm to arrive at the weight updates. The procedure compensates for non-ideal characteristics of the chip and the training algorithm.

**Dot Product**—The quantity obtained by multiplying the components of two vectors (the *external inputs* and their corresponding *synapse weights*) and adding the products. Also called *inner product* or *scalar product*. The equation is:

$$\text{Dot Product} = \sum_i \text{input}_i * \text{Weight}_i$$

**Erase**—To decrease the threshold voltage of a *weight EEPROM cell* or *reference EEPROM cell*.

**EEPROM**—Electrically Erasable Programmable Read-Only Memory.

**EEPROM Cell**—One of two floating-gate EEPROM cells that, together, store a synapse weight. The two cells are the *weight EEPROM cell* and the *reference EEPROM cell*. The synapse weight is the difference between the threshold voltages at each of these cells.

**External Input**—One of 64 input pins on the 80170NX chip.

**External-Input Synapse**—A synapse connected to an external input.

**Feedforward Neural Network**—A neural network in which inputs are received externally or from a previous layer, are processed, and are passed on to only one subsequent layer. Neurons in a given layer do not connect to one another.

**Fixed-Input Bias Synapse**—A synapse used to provide the threshold for the neuron's sigmoid function and to cancel offsets due to physical non-linearities in the chip. The Input and Feedback Arrays each have 16 fixed-input bias synapses. Mathematically, all of these bias synapses act as a single bias. However, since the dynamic range of a single EEPROM bias synapse is limited, 16 of them are used. All 16 contribute to the dot product performed by the neuron, although seven are set by the training program and the other nine are set by a chip-initialization process.

**Hidden Layer**—A group of neurons that is not connected directly to output pins on the chip. Any of the layers in a feedforward neural network that processes information prior to the output layer.

**Inner Product**—See *dot product*.

**Neuron**—In biology, a cell in the brain that produces an output signal in response to multiple input signals. In the 80170NX chip, a structure that computes the dot product of input signals and synapse weights, then computes a sigmoid threshold function to produce an output signal.

**Output Layer**—A group of neurons with outputs that are externally accessible.

**Output**—An input vector. The 80170NX can accept input vectors with up to 128 components.

**PDP**—Parallel distributed processing. A term for neural network processing. In PDP, a particular piece of information is represented by a distributed pattern of activity on a number of neurons rather than by the activity of a single neuron. This method of distributed representation is the source of a neural network's robustness to faults in individual neurons. The term was coined by Rumelhart, et. al.

**Program**—To increase the threshold voltage of a *weight* EEPROM cell or *reference* EEPROM cell.

**Reference EEPROM Cell**—One of two floating-gate EEPROM cells that, together, store a synapse weight. See EEPROM cell and *weight* EEPROM cell.

**Sigmoid Function**—A monotonically increasing function that is shaped like a stretched-out letter "S." This nonlinear function gives the neuron the ability to make "decisions" and perform nonlinearly separable classification tasks.

**Synapse**—In biology, a variable-strength connection between neurons that can be either output-exciting or output-inhibiting. In the 80170NX chip, a structure that includes a multiplier and a stored weight. The synapse multiplies an input by the weight stored in the synapse and contributes this product to the dot product calculated by the neuron.

**Synapse Weight**—A nonvolatile weight that is stored at a synapse. The value of the weight can be between +2.5 and -2.5.

**Two-Layer Neural Network**—A neural network consisting of one hidden layer and one output layer.

**Weight**—See *synapse weight*.

**Weight EEPROM Cell**—One of two floating-gate EEPROM cells that, together, store a synapse weight. See EEPROM cell and *reference* EEPROM cell.

**Weight Setting**—The process of programming one EEPROM cell and erasing another EEPROM cell, in a synapse cell-pair, so as to set a desired weight value for that synapse.

## NEURAL NET CUSTOMER SUPPORT

Intel Neural Net Group  
MS: RN3-17  
2200 Mission College Blvd.  
Santa Clara, CA 95052-8119  
Phone: (408) 765-9235  
Fax: (408) 765-9797



## NORTH AMERICAN SALES OFFICES

### ALABAMA

Intel Corp.  
600 Boulevard South  
Suite 104-1  
Huntsville 35802  
Tel: (800) 628-8686  
FAX: (205) 883-3511

### ARIZONA

Intel Corp.  
410 North 44th Street  
Suite 500  
Phoenix 85008  
Tel: (800) 628-8686  
FAX: (602) 244-0446

### CALIFORNIA

Intel Corp.  
1 Sierra Gate Plaza  
Suite 280C  
Roseville 95678  
Tel: (800) 628-8686  
FAX: (916) 782-8153

Intel Corp.  
9665 Chesapeake Dr.  
Suite 325  
San Diego 92123  
Tel: (800) 628-8686  
FAX: (619) 292-0628

Intel Corp.  
1781 Fox Drive  
San Jose 95131  
Tel: (800) 628-8686  
FAX: (408) 441-9540

\*Intel Corp.  
400 N. Justin Avenue  
Suite 450  
Santa Ana 92705  
Tel: (800) 628-8686  
TWX: 910-595-1114  
FAX: (714) 541-9157

Intel Corp.  
15260 Ventura Boulevard  
Suite 360  
Sherman Oaks 91403  
Tel: (800) 628-8686  
FAX: (818) 995-6624

### COLORADO

\*Intel Corp.  
600 S. Cherry St.  
Suite 700  
Denver 80222  
Tel: (800) 628-8686  
TWX: 910-931-2289  
FAX: (303) 322-8670

### CONNECTICUT

Intel Corp.  
103 Mill Plain Road  
Danbury 06811  
Tel: (800) 628-8686  
FAX: (203) 794-0339

### FLORIDA

Intel Corp.  
800 Fairway Drive  
Suite 160  
Deerfield Beach 33441  
Tel: (800) 628-8686  
FAX: (305) 421-2444

Intel Corp.  
2250 Lucien Way  
Suite 100-B, 27  
Mailand 32751  
Tel: (800) 628-8686  
FAX: (407) 660-1283

### GEORGIA

Intel Corp.  
20 Technology Parkway  
Suite 150  
Norcross 30092  
Tel: (800) 628-8686  
FAX: (404) 605-9762

### ILLINOIS

\*Intel Corp.  
Woodfield Corp. Center III  
300 N. Marlingale Road  
Suite 400  
Schaumburg 60173  
Tel: (800) 628-8686  
FAX: (708) 706-9762

### INDIANA

Intel Corp.  
8910 Purdue Road  
Suite 350  
Indianapolis 46268  
Tel: (800) 628-8686  
FAX: (317) 875-8938

### MARYLAND

\*Intel Corp.  
10010 Junction Dr.  
Suite 200  
Annapolis Junction 20701  
Tel: (800) 628-8686  
FAX: (410) 206-3678

### MASSACHUSETTS

\*Intel Corp.  
Westford Corp. Center  
5 Carlisle Road  
2nd Floor  
Westford 01886  
Tel: (800) 628-8686  
FAX: (508) 692-7867

### MICHIGAN

Intel Corp.  
7071 Orchard Lake Road  
Suite 100  
West Bloomfield 48322  
Tel: (800) 628-8686  
FAX: (313) 851-8770

### MINNESOTA

Intel Corp.  
3500 W. 80th St.  
Suite 360  
Bloomington 55431  
Tel: (800) 628-8686  
TWX: 910-576-2867  
FAX: (612) 831-6497

### NEW JERSEY

\*Intel Corp.  
Lincroft Office Center  
125 Half Mile Road  
Red Bank 07701  
Tel: (800) 628-8686  
FAX: (908) 747-0983

### NEW YORK

\*Intel Corp.  
850 Crosskeys Office Park  
Fairport 14450  
Tel: (800) 628-8686  
TWX: 510-253-7391  
FAX: (716) 223-2561

Intel Corp.  
300 Westage Business Center  
Suite 230  
Fishkill 12524  
Tel: (800) 628-8686  
FAX: (914) 897-3125

\*Intel Corp.  
2950 Express Dr., South  
Suite 130  
Islandia 11722  
Tel: (800) 628-8686  
TWX: 510-227-6236  
FAX: (516) 348-7939

### OHIO

\*Intel Corp.  
Four Commerce Park Square  
23200 Chagrin Blvd., Suite 600  
Beachwood 44122  
Tel: (800) 628-8686  
FAX: (216) 464-2270

\*Intel Corp.  
3401 Park Center Drive  
Suite 220  
Dayton 45414  
Tel: (800) 628-8686  
TWX: 810-450-2588  
FAX: (513) 890-8658

### OKLAHOMA

Intel Corp.  
6801 N. Broadway  
Suite 115  
Oklahoma City 73162  
Tel: (800) 628-8686  
FAX: (405) 840-9819

### OREGON

\*Intel Corp.  
15254 N.W. Greenbrier Pkwy.  
Building B  
Beaverton 97006  
Tel: (800) 628-8686  
TWX: 910-467-8741  
FAX: (503) 645-8181

### PENNSYLVANIA

\*Intel Corp.  
925 Harvest Drive  
Suite 200  
Blue Bell 19422  
Tel: (800) 628-8686  
FAX: (215) 641-0785

### SOUTH CAROLINA

Intel Corp.  
7403 Parklane Rd., Suite 3  
Columbia 29223  
Tel: (800) 628-8686  
FAX: (803) 788-7999

### TEXAS

\*Intel Corp.  
8911 N. Capital of Texas Hwy.  
Suite 4230  
Austin 78759  
Tel: (800) 628-8686  
FAX: (512) 338-9335

\*Intel Corp.  
5000 Quorum Drive  
Suite 750  
Dallas 75240  
Tel: (800) 628-8686

\*Intel Corp.  
20515 SH 249  
Suite 400  
Houston 77070  
Tel: (800) 628-8686  
TWX: 910-881-2490  
FAX: (713) 988-3660

### UTAH

Intel Corp.  
428 East 6400 South  
Suite 135  
Murray 84107  
Tel: (800) 628-8686  
FAX: (801) 268-1457

### WASHINGTON

Intel Corp.  
2900 156th Avenue S.E.  
Suite 105  
Bellevue 98007  
Tel: (800) 628-8686  
FAX: (206) 746-4495

Intel Corp.  
408 N. Julian Road  
Suite 105  
Spokane 99206  
Tel: (800) 628-8686  
FAX: (509) 928-9467

### WISCONSIN

Intel Corp.  
400 N. Executive Dr.  
Suite 401  
Brookfield 53005  
Tel: (800) 628-8686  
FAX: (414) 789-2746

### CANADA

BRITISH COLUMBIA  
Intel Semiconductor of  
Canada, Ltd.  
999 Canada Place  
Suite 404, #11  
Vancouver V6C 3E2  
Tel: (800) 628-8686  
FAX: (604) 844-2813

ONTARIO  
Intel Semiconductor of  
Canada, Ltd.  
2650 Queensview Drive  
Suite 250  
Ottawa K2B 8H6  
Tel: (800) 628-8686  
FAX: (613) 820-5936

\*Intel Semiconductor of  
Canada, Ltd.  
190 Athwell Drive  
Suite 500  
Rexdale M9W 6H8  
Tel: (800) 628-8686  
FAX: (416) 675-2438

QUEBEC  
Intel Semiconductor of  
Canada, Ltd.  
1 Rue Hélène  
Salaberry  
Tour East  
Pt. Claire H9R 5N3  
Tel: (800) 628-8686  
FAX: 514-694-0064



UNITED STATES  
Intel Corporation  
2200 Mission College Boulevard  
P.O. Box 58119  
Santa Clara, CA 95052-8119

JAPAN  
Intel Japan K.K.  
5-6 Tokodai, Tsukuba-shi  
Ibaraki, 300-26

FRANCE  
Intel Corporation S.A.R.L.  
1, Rue Edison, BP 303  
78054 Saint-Quentin-en-Yvelines Cedex

UNITED KINGDOM  
Intel Corporation (U.K.) Ltd.  
Pipers Way  
Swindon  
Wiltshire, England SN3 1RJ

GERMANY  
Intel GmbH  
Dornacher Strasse 1  
8016 Feldkirchen bei Muenchen

HONG KONG  
Intel Semiconductor Ltd.  
32/F Two Pacific Place  
88 Queensway  
Central

CANADA  
Intel Semiconductor of Canada, Ltd.  
190 Attwell Drive, Suite 500  
Rexdale, Ontario M9W 6H8

Printed in U.S.A./0393/3K/CG/NCG CC  
NUERAL NET PRODUCTS

CG/020293