WO2000052639A2 - Two architectures for integrated realization of sensing and processing in a single device - Google Patents

Two architectures for integrated realization of sensing and processing in a single device Download PDF

Info

Publication number
WO2000052639A2
WO2000052639A2 PCT/US2000/005785 US0005785W WO0052639A2 WO 2000052639 A2 WO2000052639 A2 WO 2000052639A2 US 0005785 W US0005785 W US 0005785W WO 0052639 A2 WO0052639 A2 WO 0052639A2
Authority
WO
WIPO (PCT)
Prior art keywords
array
cell
output
cells
sensor
Prior art date
Application number
PCT/US2000/005785
Other languages
French (fr)
Other versions
WO2000052639A3 (en
Inventor
Gamze Erten
Fathi M. Salam
Original Assignee
Clarity, Llc
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Clarity, Llc filed Critical Clarity, Llc
Priority to CA002364182A priority Critical patent/CA2364182A1/en
Priority to JP2000602988A priority patent/JP2002538557A/en
Priority to AU36167/00A priority patent/AU3616700A/en
Priority to US09/914,030 priority patent/US6735482B1/en
Priority to EP00914830A priority patent/EP1175659A2/en
Publication of WO2000052639A2 publication Critical patent/WO2000052639A2/en
Publication of WO2000052639A3 publication Critical patent/WO2000052639A3/en
Priority to HK02101234.2A priority patent/HK1039992A1/en

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06NCOMPUTING ARRANGEMENTS BASED ON SPECIFIC COMPUTATIONAL MODELS
    • G06N3/00Computing arrangements based on biological models
    • G06N3/02Neural networks
    • G06N3/06Physical realisation, i.e. hardware implementation of neural networks, neurons or parts of neurons
    • G06N3/063Physical realisation, i.e. hardware implementation of neural networks, neurons or parts of neurons using electronic means

Definitions

  • the present invention relates to an integrated sensing and processing device. More specifically, the present invention relates to an architecture for the integrated realization of sensing and processing within a single device.
  • CNN Cellular Neural Networks
  • Equations 1 -3 canonical differential equations
  • There are several degrees of freedom in setting up these interactions in the form of feedback and feedforward weights (namely the values A and B in Equation 1) and the initial conditions of the states (x(t 0) in Equation 1) and the bias currents (I in Equation 3).
  • CNN is in fact programmed by way of manipulating these values.
  • the nonlinearity comes from the nonlinear nature of the function ( in Equation 2).
  • the function "f ' can take on different shapes and characteristics.
  • CNN is a hybrid of Cellular Automata and Neural Networks (hence the name Cellular Neural Networks) and it incorporates the best features of both concepts. Like Neural Networks, its continuous time feature allows real-time signal processing, and like Cellular Automata its local interconnection feature makes physical realization in VLSI possible. Its grid-like structure is suitable for the solution of a high-order system of first order nonlinear differential equations on-line and in real-time.
  • CNN can be viewed as an analog nonlinear dynamic processor array.
  • the basic unit of CNN is called a cell. Each cell receives input from its immediate neighbors (and itself via feedback), and also from external sources (e.g., the sensor array points and/or previous layers).
  • ⁇ ⁇ x, l (t) -x ⁇ ( ⁇ ) + ⁇ A, ,, ( u (xyford (0)+ ⁇ B, lM u kl Ontended ( + 1, klcN r l) lr_N r (,j)
  • u represents the input
  • x represents the state
  • y represents a nonlinear function of the state associated with a cell (or neuron)
  • a and B represent the cloning templates.
  • Equations (1-3) are not suitable for direct VLSI implementation.
  • the summation equation is a current based computation, as the circuit model in Figure 1 suggests.
  • the intrinsic resistance values ( R ) are very large and capacitance values are very small, little charge is required to maintain a particular voltage. This also means that the current required to alter the voltage value of the state is relatively very small.
  • the values of the noise currents are of sufficient magnitude to make significant difference.
  • An integrated sensing device comprising an array of sensor processor cells capable of being arranged into a detection array.
  • Each sensor processor cell comprises a sensing medium; at least one transconductance amplifier configured for feedforward template multiplication; at least one transconductance amplifier configured for feedback template weights; a plurality of local dynamic memory cells; a data bus for data transfer; and a local logic unit.
  • the array of sensor processor cells by responding to data control signals, is capable of transforming, reshaping, and modulating the original sensed image into varied represenations which include (and extend) traditional spatial and temporal processing transformations.
  • Figure 1 (Prior Art) illustrates an existing embodiment of an architecture of a physical realization of the cellular neural network canonical equations.
  • Figure 2 illustrates an embodiment of an adaptation of a dynamic cellular computation model to the VLSI domain in accordance with the teachings of one embodiment of the present invention.
  • Figure 3 illustrates an alternate embodiment of an adaptation of a dynamic cellular computation model to the VLSI domain in accordance with the teachings of one embodiment of the present invention.
  • Figure 4 illustrates an alternate embodiment of an adaptation of a dynamic cellular computation model to the VLSI domain employing analog multipliers in accordance with the teachings of one embodiment of the present invention.
  • Figure 5 illustrates an embodiment of an operational process in flow chart format for a dynamic cellular architecture in accordance with the teachings of one embodiment of the present invention.
  • Figure 6 illustrates an embodiment of a cellular architecture element or cell in accordance with the teachings of one embodiment of the present invention.
  • Figure 7 illustrates an embodiment of the layout of a CMOS chip comprising several types of cellular units in accordance with the teachings of one embodiment of the present invention.
  • Figure 8 illustrates an embodiment of a one input - one output cell with initialization in accordance with the teachings of one embodiment of the present invention.
  • Figure 9 illustrates an embodiment of a programmable type feedback cell in accordance with the teachings of one embodiment of the present invention.
  • Figure 10 illustrates an embodiment of a positive and negative feedback hardwired and state initializable cells in accordance with the teachings of one embodiment of the present invention.
  • Figure 1 1(a) illustrates an embodiment of two (+/-) hardwired feedback and floating state cells in accordance with the teachings of one embodiment of the present invention.
  • Figure 1 1(b) illustrates one embodiment of a one feedforward only cell in accordance with the teachings of one embodiment of the present invention.
  • Figure 12 illustrates an embodiment of digital input accommodation via parallel transistor cascading in accordance with the teachings of one embodiment of the present invention.
  • Figure 13 illustrates an embodiment of a feedforward cell in accordance with the teachings of one embodiment of the present invention.
  • Figure 14 illustrates an embodiment of the results from a three input one output cell with no feedback connections in accordance with the teachings of one embodiment of the present invention.
  • Figure 15 illustrates an embodiment of a dual distributed cellular architecture in accordance with the teachings of one embodiment of the present invention.
  • Figure 16 illustrates an embodiment of the layout of a signed sensor in accordance with the teachings of one embodiment of the present invention.
  • Figure 17 illustrates an embodiment of a dual output light sensing pixel in accordance with the teachings of one embodiment of the present invention.
  • Figure 18 illustrates an embodiment of a schematic diagram of a cell of a programable convolutiuon array (PCA) in accordance with the teachings of one embodiment of the present invention.
  • PCA programable convolutiuon array
  • Figure 19 illustrates an embodiment of the layout of a single cell of the programable convolutiuon array (PCA) in accordance with the teachings of one embodiment of the present invention.
  • PCA programable convolutiuon array
  • Figure 20 illustrates an embodiment of the outputs of the programable convolutiuon array (PCA) elements in accordance with the teachings of one embodiment of the present invention.
  • Figure 21 illustrates an embodiment of a 5 x 5 programable convolutiuon array (PCA) with I/O pads in accordance with the teachings of one embodiment of the present invention.
  • Figure 22 illustrates an embodiment of an operational process in flow chart format for a programmable convolution array (PCA) of the dual distributed architecture in accordance with the teachings of one embodiment of the present invention.
  • PCA programmable convolution array
  • Figure 23 illustrates an embodiment of an element of the programmable cellular logic array (PCLA) in accordance with the teachings of one embodiment of the present invention.
  • Figure 24 illustrates an embodiment of an operational process in flow chart format for a programmable cellular logic array (PCLA) of the dual distributed architecture in accordance with the teachings of one embodiment of the present invention.
  • Figure 25 illustrates an embodiment of an operational process in flow chart format for using the programmable convolution array (PCA) and programmable cellular logic array (PCLA) of the dual distributed architecture cooperatively in accordance with the teachings of one embodiment of the present invention.
  • PCA programmable convolution array
  • PCLA programmable cellular logic array
  • Figure 26 illustrates an embodiment of a computing environment in which the invention may be implemented in accordance with the teachings of one embodiment of the present invention.
  • Figure 27 illustrates an embodiment of a network environment in which the invention may be implemented in accordance with the teachings of one embodiment of the present invention.
  • the steps or process of the present invention are embodied in machine-executable instructions, such as computer instructions.
  • the instructions can be used to cause a general-purpose or special-purpose processor that is programmed with the instructions to perform the steps of the present invention.
  • the steps of the present invention might be performed by specific hardware components that contain hardwired logic for performing the steps, or by any combination of programmed computer components and custom hardware components.
  • the present invention is generally directed to a new cellular network architecture that can be implemented successfully using electronic circuits and integrated microelectronic chips, and a new distributed architecture comprising two separate arrays, namely a programmable convolution array PCA and a programmable logic array PLA for processing one. two or three dimensional array (physical) sensor data.
  • One embodiment of the present invention introduces a self-normalizing feedback structure for the computation of the inputs and feedforward template. Similarly, the present invention also introduces the same structure to the feedback portion of the architecture. These modifications create a new set of equations, and correspondingly a new set of dynamics, and thus represent a new structure, form, and architecture.
  • the feedback in the feedforward input weight multiplication process and the feedback in the feedback weight multiplication are employed to keep the state node ( x ) from quickly accumulating or losing charge to saturate to a power rail.
  • Figure 2 illustrates one embodiment of the present invention implemented in circuitry.
  • Figure 2(a) illustrates one embodiment of a self regulating mechanism, wherein rather than multiplying the input by B (as in the prior art), a function of the input minus the state is defined per node and that quantity is multiplied by that B.
  • the stabilizing and self scaling feedback elements around an amplifier keep the output of the amplifier from saturating.
  • the gain of the amplifier is manipulated to obtain a factor which is a scaled (normalized) version of B.
  • the output is consistently the input times a normalized vesrion of "B" and the plural (collective) inputs from the cell neighborhood will not cause the cell's aggregate state or output to saturate or be overdriven with slight fluctuations of the input.
  • Figure 2(b) illustrates one embodiment of an adaptation of the dynamic cellular computation model to the VLSI domain using the concept shown in Figure 2(a).
  • both u (unsigned) and x (signed) are represented as analog voltages u and x;
  • template weights can be digitally stored and are programmable;
  • the transfer function f ( ), such as that illustrated in Equation 2 can in fact become a programmable tri-level saturation function, f '( ) that produces zero output in a local region of the input (rather than only at a point).
  • the capacitor C and the resistor R may be due to the parasitics of the micro-electronic implementation process.
  • capacitances in the order of pico-farads may be implemented on chip. Any larger capacitance may be implemented off- chip with the likely consequent cost of limiting the size of the cellular array.
  • the input (feedforward) weights (B) are implemented in a negative feedback structure.
  • the feedback structure stabilizes the state (x) node, which otherwise has a tendency to charge all the way up or down to a rail limited by the power supply, and the structure is far more resilient to manufacturing related issues such as transistor mismatches.
  • the modified dynamic cellular architecture model is shown, wherein some assumptions have been made about the polarity of inputs and weights, such as B is nonnegative and A is nonpositive.
  • Equation 9 Equation 9 where the hyperbolic tangent (tanh) represents a basic (or wide-range) transconductance amplifier circuit.
  • the indices kl runs over a neighborhood of the cell location ij for the feedback term A, while kl run over a neighborhood of the location ij in the feedforward term associated with the B parameters.
  • the input (feedforward) weights (B) are implemented in a negative state- feedback structure. Accordingly, in this implementation, the feedback structure stabilizes the state (x) node, which otherwise has a tendency to charge all the way up or down to a rail limited by the power supply, and the present structure is far more resilient to manufacturing related issues such as transistor mismatches.
  • Figure 3 illustrates this modified dynamic cellular architecture model is shown, wherein some assumptions have been made about the polarity of inputs and weights, such as each elements of B and A is nonnegative.
  • Figure 4 illustrates yet another embodiment that employs the usage of analog multipliers (rather than amplifiers with gain).
  • analog multipliers rather than amplifiers with gain
  • the feedback connected amplifiers of the embodiment of Figure 3 may be replaced by analog multipliers to implement weights of positive or negative sign, as illustrated in Figure 4(b).
  • digital gains can also be built by way of modifying the analog multipliers gain with the digital input accommodation via parallel transistor cascading method shown in Figure 9. By adding a multiplier that is capable of sign representation, the restrcitions on template weights are eliminated.
  • FIG. 5 illustrates one embodiment of the operational process of the
  • Dynamic Cellular Architecture illustrated above.
  • the necessary A, B, x(0), and bias values for all of the operations to be performed is determined.
  • a program is made of operations needed to complete the task, such that each step of the program specifies an operation, where each operation is defined by the pattern of A, B, x(0), and bias values to be applied to the cellular architecture.
  • the program may be stored externally or on the same chip where the architecture is implemented.
  • each cell of the architecture may contain its own program memory.
  • These inputs may come from continuous or discretely sampled data from sensors built into the architecture, or alternately, they can be scanned into the input nodes (u) from an external data source by employing an appropriate scanning mechanism.
  • Figure 6 illustrates one embodiment of a pragmatic implementation of the Dynamic Cellular Architecture, as a simple 5x5 array.
  • Figure 6 illustrates an integrated light sensing and processing architecture implemented within cellular chip based on the dynamic cellular architecture of this invention. It is understood that the inventive concepts of the present invention may be applied to a variety of different technologies and implemented in a variety of different physical architectures, and as such, the present invention is not meant to be limited to integrated light sensing and processing architectures.
  • the integrated light sensing and processing architecture based on the dynamic cellular architecture of this invention is comprised of an array of identical sensor processor cells, each of which contain: (1) a photodiode and circuits for active light sensing; (2) transconductance amplifiers for feedforward template weight multiplication; (3) wide range transconductance amplifiers for feedback template weights; (4) analog/ single bit digital local dynamic memory cells; (5) a data bus for transfers; (6) local programmable logic; and (7) read/write data controls.
  • a variety of operations of the cellular paradigm may be performed using, for instance, a pair of 3 x 3 cloning templates, defined by the A and B of Equations (4) or (7).
  • each operation can be completed in a short time while it is carried out in each of the elements over the entire image. This implies unprecedented processing rate improvements of sequential processors.
  • the operations include linear transformations of the input (convolution operations), plus connected component detection and other types of data manipulation allowed for by the feedback weights.
  • some example operations are edge location, morphology operators such as dilation, thinning, and erosion, light adaptation, scratch removal, texture, color and shape analysis.
  • temporal operations such as motion analysis, e.g., local velocity detection, motion direction detection.
  • the overall cellular chip is illustrated as a system.
  • an external (or international core) microcontroller generates the necessary command signals to the integrated sensor processor, such as sensor timing, row select, and program code.
  • the microcontroller can be replaced by a processor or a digital signal processor depending on the computing needs of the particular application at hand.
  • the program memory can be internal, where a more compact address gets horizontally coded into bit level microinstructions and determine template values and data transfers within the architecture.
  • the contents of a cell are illustrated in greater detail.
  • the feedforward and feedback weights which also integrate the transfer function are shown in outline format.
  • the local logic and memory functions are likewise illustrated in a similar fashion.
  • two way connections can be made between the data bus and the two analog and four digital memory units, the state (x) and input (u).
  • connection can be made from the logic output and the reference voltage to the data bus.
  • the logic can be implemented by programming, similar to that of programmable logic arrays.
  • the emerging reconfigurable logic arrays represent another option or embodiment.
  • the inventive concepts of the present invention may be applied to a variety of different technologies and implemented in a variety of different physical architectures, and as such, the present invention is not meant to be limited to integrated light sensing and processing architectures.
  • the same architectures can be applied to any system, such as an acoustic or sound based system, where there are multiple sensors arranged in a one. two, or three dimensional grid. Each sensor element on the grid may then respond to the same single physical quantity (e.g., frequencies of the audible sound spectrum). As such, each sensor may sense a different attribute of the same signal (e.g., each sensor tuned to a different frequency of the audible sound spectrum). This will measure the frequency pattern of the sound incident on the array. Further, one can also imagine hybrids of these two, such as measuring a color pattern.
  • Figure 7 illustrates one embodiment of the layout of a CMOS chip comprising several types of cellular units (e.g., VLSI adapted cellular dynamic architecture cell prototypes), in accordance with the concepts of the present invention.
  • the CMOS chip design may be manufactured to the MOSIS 2 micron ORBIT ANALOG process.
  • the die size is implemented through the "TINYCHIP" package that is a 2.3 mm x 2.3 mm area bonded to a 40 pin DIP.
  • the CMOS chip comprise eleven types of cells: Four One Feedforward - One Feedback Cells with Initialization; Two Programmable Type (Positive or Negative) Feedback Cells; Two Hardwired Feedback and State Initializable Cells; Two (+/-) Flardwired Feedback and Floating State Cells; and One Feedforward only Cell.
  • all outputs are made available through wide range followers at the outputs and all programmable cell parameters, i.e., feedforward and feedback weights, and bias are at 3 bit resolution (plus sign bit). External inputs are available via pins to set these weights through the pins.
  • Figures 8-1 1 illustrate these respective cells schematically.
  • Figure 8 illustrates one embodiment of the schematics of the four cells in a compact manner: Four One Feedforward - One Feedback Cells with Initialization.
  • Both the feedforward and the feedback amplifiers have three bit programmable gain in this specific implementation.
  • Figure 9 illustrates one embodiment of the schematics of the Two Programmable Type (Positive or Negative) Feedback Cells. Two three-input one-output selectable kind (+ or -) of feedback cells may be implemented. One of these also allowed for initialization of the state in a manner identical to the one illustrated in Figure 8.
  • Figure 9 shows this type of cell without initialization.
  • the two signals (the state node x and Vref) are directed to the terminals of the feedback weight amplifier based on the feedback sign select bit. In one embodiment, all amplifiers have three bit programmable gain.
  • Figure 10 illustrates one embodiment of the schematics of the Two Hardwired Feedback and State Initializable Cells.
  • Figure 1 1(a) illustrates one embodiment of the schematics of the Two (+/-) Hardwired Feedback and Floating State Cells. In one embodiment, these cells are identical to the ones described in Figure 10 but do not contain state initialization circuits. Initial value of the state is thus undefined.
  • Figure 1 1(b) illustrates one embodiment of the schematics of the One Feedforward only Cell. This is a three input one output cell with programmable bias. In one embodiment, the feedback component is eliminated. Thus the cell diverges from the cellular neural network paradigm and instead is useful for feedforward operations only.
  • Figure 13 illustrates one embodiment of a Feedforward cell.
  • the input u is always nonnegative but has a signed representation and positive entries of the B template select u+ and negative ones select u ⁇ .
  • Convolution is a very common image processing step that precedes many vision tasks. It is often used as a technique to generate a second (different) image from the original where desired features are enhanced and/or undesired characteristics (e.g., noise.) are suppressed.
  • convolution can be described as a continuous spatial or temporal operation, but its application to sampled images is discrete and involves a convolution kernel with discrete values. This discrete convolution operation denoted by ⁇ S>, between an image I and kernel k can be described as :
  • Equation 10 where I is the input image, x and y are the two dimensional image coordinates, and k is an (2N+1 x 2N+1) square kernel.
  • Equation (1) B kl (u kl (t), U ⁇ (t),) in Equation (1) and the sum in Equation (10). kl ⁇ N r ( ⁇ )
  • Normalized convolution denoted by ® n is very similar to the conventional convolution operation, except that the output is normalized by the sum of kernel entries. Because kernels are the same across the whole image, the result is essentially division by a normalization factor common to the entire image. The advantage is that the dynamic range of the resulting image is essentially the same as that of the input image.
  • input voltage values are loaded with input voltages corresponding to the image, and gains from the entries of the kernel. Since the conductances for gain values) are necessarily positive, to implement negative kernel values with this approach, one needs to be able to define negative input voltages and select negative polarity for the input to the transconductance amplifier for which a negative kernel value is desired. This cuts the dynamic range of images in half, although the range of kernel entries remain unaffected. One can view the cell arrangement in Figure 1 1 (b) in this light, provided that the bias amplifier is ignored.
  • a four bit plus sign representation shown in Figure 12 (digital input accommodation via parallel transistor cascading), may used as entries of the B template in Equations (1) and (4) and take on values equivalent to the range of -3.75 and 3.75 in increments of 0.25.
  • the cell is equivalent to the feedforward configuration shown in Figure 1 1(a) provided that the gain of the amplifiers are sent by the B template. With more area and more bits higher resolution and dynamic range would be possible.
  • other parameters may be as follows:
  • V ref may be the representation of zero in this architecture.
  • One suggested value for Vref are the midpoint between the power supply ranges ground and the power supply of the microelectronic implementation.
  • the state node (x) is referenced to V ref and does not need a signed representation.
  • Positive entry values for the feedback template "A" can be used to steer x to the + terminal and negative entries steer it to the - terminal of the wide range differential amplifier.
  • a values may likewise take on values in the range -3.75 and 3.75 in increments of 0.25. With more area and more bits higher resolution and dynamic range would be possible.
  • Other parameters are as follows: -3.75 ⁇ aij ⁇ 3.75 and 0 ⁇ x ⁇ Vdd.
  • the feedback configuration of the feedforward weights provides for some safety against the tendency of active current computation units to be attracted to a power supply rail.
  • Dual Distributed Architecture illustrated as a 5x5 array.
  • the Dual Distributed Architecture contains two distinct structures: (i) programmable convolution array PCA, a sensing grid with convolution capability, which may also include some short term memory, and (ii) PLA, a programmable logic array and memory area on which transformations or alternate representations of the sensory data can be recreated.
  • both areas compute in parallel and communicate with each other as needed in a serial but random access fashion.
  • PCLA programmable cellular logic array
  • PCLA programmable cellular logic array
  • the dual distributed architecture generally provides three significant advantages as compared to currently implemented or existing architectures.
  • the computational concept of the architecture is simpler and far more conventional than the concept of the cellular neural network of prior art, which employ nonlinear circuit dynamics. Moreover, practicing engineers already will need far less training to implement this architecture.
  • the way operations in the dual distributed architecture are programmed is far more straightforward than the way in which one needs to go about determining or finding the correct A, B, x(0), and I parameters, as compared to currently implemented or existing architectures.
  • the architecture of the dual distributed architecture comprises two parts, and each of those parts serves a separate function. In other words, each part is functional on its own and can be implemented without the other.
  • the first part of the dual distributed architecture is the programmable convolution array PCA, which in one embodiment comprises a sensing grid with convolution capability, which could also include some short- term memory.
  • the programmable convolution array PCA part performs arbitrary linear transformations of the whole sensory data or parts of the sensory data. The desired weights of the individual elements can be directly programmed.
  • the second part dual distributed architecture is the Programmable
  • PCLA Cellular Logic Array
  • the PCLA is cellular, which means that each of the elements of the array connected to a set of its neighbors.
  • the PCLA is not a neural network and in one embodiment relies on conventional logic to perform its operations.
  • the actual logic can be implemented with conventional digital logic or non-conventional analog logic gates, such as but not limited to AND OR XOR.
  • there can be a state-machine i.e., a mini computing engine at each of the elements.
  • each element of the PCLA could be equipped with a sensor, or data could be scanned in from an external source.
  • SOS Signed Output Sensor
  • the convolution function e.g., those using non-negative gain amplifier circuits
  • sensors that measure non-negative values referenced to zero e.g., light
  • Positive (+) output is used for feeding into the amplifier if it contains a positive kernel value.
  • the negative (-) pixel output may used for negative kernel value.
  • a one dimensional example is given below.
  • Figure 16 illustrates one embodiment of an exemplary layout of such a single signed output active sensor.
  • the active area is a square of 100 ⁇ x 100 ⁇ and the whole cell covers a 195 ⁇ x 130 ⁇ area.
  • the (grounded) METAL2 layer covering the areas of the cell that should not be exposed to light is not shown.
  • the corresponding schematic of the signed sensor is illustrated in Figure 17, where the positive and negative pixel representations are marked.
  • the additional follower is employed since the photocurrent is very small and the photosensing node should not be perturbed.
  • PCA Programmable Convolution Array
  • Figure 18 illustrates one embodiment of a design of one element of a light sensing PCA.
  • each pixel cell can be addressed by the combination of row and column select signals.
  • weight bits can also thus be written to selected pixels.
  • Pixel midpoint determines the "0" value - i.e., no light, of the signed pixel value representation. Reset pixel will charge the pixel output to that value.
  • a dedicated ground signal need not be routed since a metal layer covering the circuits (with opening at light sensitive areas) can be grounded.
  • each cell contains: (1) one signed output sensor (SOS); (2) four D flip flops for storage of three bit weight and sign; (3) four multiplexers; (4) one wide range transconductance amplifier connected in the unity follower configuration; and (5) a three input AND gate.
  • SOS signed output sensor
  • D flip flops for storage of three bit weight and sign
  • multiplexers for multiplexers
  • (5) a three input AND gate a three input AND gate.
  • the size of the cell can be reduced significantly, since as the layout of the single cell in Figure 19 shows, there are some empty spaces. Smaller feature sizes and added metal layers will no doubt compact the cell further. A significant area savings would result from a dynamic memory cell, since each kernel would be used for a short period of time. Several data and control signals are generally routed to each cell.
  • the controls signals common to all cells include: (1) clock weight, (2) reset photodiode (or sensor), and (3) sign. Addressing signals are row and column.
  • the data signals common to all cells include: (1) pixel reference, (2) inverter reference, (3) weight high, (4) weight low, (5) weight MSB, (6) weight MID, (7) weight LSB.
  • elements of each row have a common row select signal and elements of each column have a common column select signal. Accordingly, the output of each cell may be summed onto a common line. Alternately, outputs can be combined along columns, rows, or block-vor along alternate designations.
  • Figure 21 illustrates an example PCA layout of 5 x 5 pixels.
  • each of the 25 elements use four weight bits (three magnitude and one sign) which are stored in D-flip-flops. Accordingly, the weight bits are clocked in only when both the row and the column are selected, as well as when the weight clock bit is active. The outputs of the weight flip flops the select between the weighthigh and weightlow.
  • the wide range transconductance amplifier at the output stage has three bias transistors with W/L ratios of VA, Vi, and 1, each corresponding to the magnitude bits. If all weights are zero, the pixel does not contribute any current to the output.
  • the pixel makes a positive or negative current contribution to the overall reading.
  • the data signal, weighthigh also determines the gain on the photosensor.
  • the D flip flops could be replaced with dynamic memory to save silicon area.
  • the design may be implemented in a 2 micron CMOS technology design with its pads configured to fit into an area of 2.3 mm x 2.3 mm. and is embedded in a 40 pin DIP chip package. All 25 pixel outputs are summed on a common output line in this example implementation. One can select different signs and weights for each of the cells and thus perform arbitrary convolution operations. Arbitrary 4-bit kernels up to 5 x 5 can be programmed in this particular example implementation.
  • PCA Process Figure 22 illustrates one embodiment of the operational process of the
  • PCA Programmable Convolution Array
  • the necessary weight patterns to be applied to the array for all of the operations to be performed is determined. Accordingly, in one nembodiment, a program is made of operations needed to complete the task, such that each step of the program specifies an operation, where each operation is defined by the pattern of weights to be applied to the array. In one embodiment, it is possible to simply obtain the weight pattern from results of previous operations.
  • the program may be stored externally or on the same chip where the array is implemented. In an alternate embodiment, each cell of the array can have its own program memory. Referring back to Figure 22, one embodiment of the operational process of the Programmable Convolution Array (PCA) illustrated above, may be implemented through the following process:
  • PCLA Programmable Cellular Logic Array
  • PCA programmable cellular logic array
  • the PCLA is a processing device that processes binary or digital data using a set of fixed or programmable logic elements arranged on a cellular grid. Accordingly, if the PCLA is used with a PCA, the sizes of the two arrays could be the same or different.
  • the PCLA grid can function as a "scratch-pad" for a set of iconic operations, such as shape detection, contour following, pattern matching, all performed using the outputs of the PCA or external outputs, potentially at different resolutions than the data received.
  • each element of the PCLA can be addressed like a memory array to which the input (e.g., outputs from the PCA) can be applied or stored, and from which results can be retrieved.
  • Added functionality would result from the ability to transfer bits between neighbors (analogous to shift operations) or to arbitrary locations of the cellular logic grid (random access transfers).
  • the embodiment of Figure 23 illustrates a simple implementation of the elements of the programmable cellular logic array (PCLA).
  • PCLA programmable cellular logic array
  • all operations are strictly local. This is not a limitation of the invention.
  • global operations such as matching with a global pattern, reset, set, and other can also be implemented into the PCLA.
  • added functionality could be realized (1) with increased connectivity, where each cell receives more inputs, such as those from additional cells in the neighborhood, or from arbitrary cells on the array via memory-like addressing; and (2) with increased cell memory, where the results of previous operations can be stored in the cell.
  • the logic within the cell should be programmable. In fact, the program may change many times during the operation. Sample logic functions could be AND, OR, INVERT, XOR etc. of a set of the available inputs.
  • the PCLA would benefit from the use of the emerging reconfigurable field programmable gate arrays (FGPA's).
  • FGPA's reconfigurable field programmable gate arrays
  • Figure 24 illustrates one embodiment of the operational process of the Programmable Cellular Logic Array (PCLA) illustrated above.
  • PCLA Programmable Cellular Logic Array
  • a program is made of the sequence of operations needed to complete the task, such that each step of the program specifies one or more functions to be performed by each element of the array.
  • all elements may be performing the same function or different functions.
  • the program may be stored externally or on the same chip where the array is implemented.
  • the program memory may be local, i.e., each cell of the array can have its own program memory.
  • These inputs may come from continuous or discretely sampled data from sensors built into the array, or they can be scanned into the input nodes from an external data source, including, but not limited to the PCA, by employing an appropriate scanning mechanism.
  • the output can be stored externally or internally. If the PCLA is used in tandem with a PCA, then the output can also be sent to PCA.
  • the row select and column select signals of the PCA are reminiscent of memory addressing diagrams. Only when both signals are logic high's, a specific pixel is selected. These signals may be used to load the weights to the cell.
  • Figure 25 illustrates one embodiment of the operational process of using the Programmable Convolution Array (PCA) and the Programmable Cellular Logic Array (PCLA) in tandem.
  • PCA Programmable Convolution Array
  • PCLA Programmable Cellular Logic Array
  • the necessary weight patterns to be applied to the PCA for all of the operations to be performed is determined.
  • the necessary local and global logic functions that are needed for the PCLA is determined.
  • an operation is defined by the pattern of weights for the PCA and the pattern of logic functions carried out by the individual elements of the PCLA.
  • a program is made of the sequence of operations needed to complete the task, such that each step of the program specifies one or more operations to be performed by either the PCA or the PCLA, or both.
  • the program may be stored externally or on the same chip or multichip module where the two arrays is implemented.
  • the program memory may be central or local, i.e., each cell of the arrays can have its own program memory.
  • PCA Programmable Convolution Array
  • PCLA Programmable Cellular Logic Array
  • These inputs may come from continuous or discretely sampled data from sensors built into one or more of the arrays, or they can be scanned into the input nodes from an external data source, including, but not limited to from one array to the other, by employing an appropriate scanning mechanism.
  • the operation code that specifies the operation can be applied from either an external source or from internal stored program memory. 4. Allow sufficient time for the operation to complete, i.e., for the electronic circuits to reach a point where the change of the value of the output of the array equals zero or by some other criteria, the operation is deemed to be complete. 5. Read and store the output(s) of the array (s). The output can be stored externally or internally. The output can also be sent from one array to the other.
  • Finger print systems currently require a sensor, memory, processor, and loads of software, which in turn limits their practical application.
  • a lock on a door or a drawer or power button that has a fingerprint key are examples. The latch remains in position until one of the "authorized" fingerprints are impressed on the lock.
  • the image of the fingerprint is binary
  • the logic program to manipulate the image and decide whether this is the right fingerprint or not could be built directly into the device.
  • the programs could be the combinations of the weights, which may be stored on the device.
  • using both the PCLA and the PCA may enhance the features, increase the resolution, or offer more security.
  • Figure 26 and the above description are intended to provide a general description of a suitable computing environment in which the invention may be implemented.
  • one embodiment of the present invention may be implemented as a set of general context of computer-executable instructions, such as program modules, being executed by a computer, such as a client workstation or a server.
  • program modules include routines, programs, objects, components, data structures and the like that perform particular tasks or implement particular abstract data types.
  • program modules may be practiced with other computer system configurations, including hand-held devices, multi-processor systems, microprocessor-based or programmable consumer electronics, communication devices, network PCs, minicomputers, mainframe computers and the like.
  • the invention may also be practiced in distributed computing environments where tasks are performed by remote processing devices that are linked through a communications network.
  • program modules may be located in both local and remote memory storage devices.
  • an exemplary general purpose computing system may include a conventional personal computer 20 or the like, including a processing unit 21 , a system memory 22, and a system bus 23 that couples various system components including the system memory 22 to the processing unit 21.
  • the system bus 23 may be any of several types of bus structures including a memory bus or memory controller, a peripheral bus, and a local bus using any of a variety of bus architectures.
  • the system memory 22 may include read-only memory (ROM) 24 and random access memory (RAM) 25.
  • ROM read-only memory
  • RAM random access memory
  • a basic input/output system 26 (BIOS), containing the basic routines that help to transfer information between elements within the personal computer 20, such as during start-up, may be stored in ROM 24.
  • the personal computer 20 may further include a hard disk drive 27 for reading from and writing to a hard disk (not shown), a magnetic disk drive 28 for reading from or writing to a removable magnetic disk 29, and an optical disk drive 30 for reading from or writing to a removable optical disk 31 such as a CD-ROM or other optical media.
  • the hard disk drive 27, magnetic disk drive 28, and optical disk drive 30 may be connected to the system bus 23 by a hard disk drive interface 32, a magnetic disk drive interface 33, and an optical drive interface 34, respectively.
  • the drives and their associated computer-readable media provide non-volatile storage of computer readable instructions, data structures, program modules and other data for the personal computer 20.
  • exemplary embodiment described herein may employ a hard disk, a removable magnetic disk 29, and a removable optical disk 31 , or combination thereof, it should be appreciated by those skilled in the art that other types of computer readable media which can store data that is accessible by a computer, such as magnetic cassettes, flash memory cards, digital video disks, Bernoulli cartridges, random access memories (RAMs), read-only memories (ROMs) and the like may also be used in the exemplary operating environment.
  • RAMs random access memories
  • ROMs read-only memories
  • a number of program modules may be stored on the hard disk, magnetic disk 29, optical disk 31 , ROM 24 or RAM 25, including an operating system 35, one or more application programs 36, other program modules 37 and program data 38.
  • a user may enter commands and information into the personal computer 20 through input devices such as a keyboard 40 and pointing device 42.
  • Other input devices may include a microphone or microphones, joystick, game pad, satellite disk, scanner, or the like.
  • These and other input devices are often connected to the processing unit 21 through a serial port interface 46 that is coupled to the system bus 23, but may be connected by other interfaces, such as a parallel port, game port, or universal serial bus (USB).
  • a monitor 47 or other type of display device may also be connected to the system bus 23 via an interface, such as a video adapter 48.
  • personal computers may typically include other peripheral output devices (not shown), such as speakers and printers.
  • the personal computer 20 may operate in a networked environment using logical connections to one or more remote computers, such as a remote computer 49.
  • the remote computer 49 may be another personal computer, a server, a router, a network PC, a peer device or other common network node, and typically includes many or all of the elements described above relative to the personal computer 20, although only a memory storage device 50 has been illustrated in Figure 26.
  • the logical connections depicted in Figure 26 include a local area network (LAN) 51 and a wide area network (WAN) 52.
  • LAN local area network
  • WAN wide area network
  • the personal computer 20 When used in a LAN networking environment, the personal computer 20 is connected to the LAN 51 through a network interface or adapter 53. When used in a WAN networking environment, the personal computer 20 typically includes a modem 54 or other means for establishing communications over the wide area network 52, such as the Internet.
  • the modem 54 which may be internal or external, is connected to the system bus 23 via the serial port interface 46.
  • program modules depicted relative to the personal computer 20, or portions thereof may be stored in the remote memory storage device. It will be appreciated that the network connections shown are exemplary and other means of establishing a communications link between the computers may be used.
  • FIG. 27 illustrates one such exemplary network environment in which the present invention may be employed.
  • a number of servers 10a, 10b, etc. are interconnected via a communications network 160 (which may be a LAN, WAN, Intranet or the Internet) with a number of client computers 20a, 20b, 20c, etc.
  • the servers 10 can be Web servers with which the clients 20 communicate via any of a number of known protocols such as, for instance, hypertext transfer protocol (HTTP).
  • HTTP hypertext transfer protocol
  • Each client computer 20 can be equipped with a browser 180 to gain access to the servers 10, and client application software 185.
  • server 10a includes or is coupled to a dynamic database 12.
  • the database 12 may include database fields 12a, which contain information about items stored in the database 12.
  • the database fields 12a can be structured in the database in a variety of ways.
  • the fields 12a could be structured using linked lists, multi-dimensional data arrays, hash tables, or the like. This is generally a design choice based on ease of implementation, amount of free memory, the characteristics of the data to be stored, whether the database is likely to be written to frequently or instead is likely to be mostly read from, and the like.
  • a generic field 12a is depicted on the left side.
  • a field generally has sub-fields that contain various types of information associated with the field, such as an ID or header sub-field, type of item sub-field, sub-fields containing characteristics, and so on.
  • These database fields 12a are shown for illustrative purposes only, and as mentioned, the particular implementation of data storage in a database can vary widely according to preference.
  • the present invention can be utilized in a computer network environment having client computers for accessing and interacting with the network and a server computer for interacting with client computers and communicating with a database with stored inventory fields.
  • the present invention can be implemented with a variety of network-based architectures, and thus should not be limited to the examples shown.

Abstract

An integrated sensing device comprising an array of sensor processor cells capable of being arranged into a detection array. Each sensor processor cell comprises a sensing medium; at least one transconductance amplifier configured for feedforward template multiplication; at least one transconductance amplifier configured for feedback template weights; a plularity of local dynamic memory cells; a data bus for data transfer; and a local logic unit. The array of sensor processor cells, by responding to data control signals, is capable of transforming, reshaping, and modulating the original sensed image into varied represenations which include (and extend) traditional spatial and temporal processing transformations.

Description

TWO ARCHITECTURES FOR INTEGRATED REALIZATION OF SENSING AND PROCESSING IN A SINGLE DEVICE
FIELD OF THE INVENTION
The present invention relates to an integrated sensing and processing device. More specifically, the present invention relates to an architecture for the integrated realization of sensing and processing within a single device.
BACKGROUND
Currently, Cellular Neural Networks (CNN) build a paradigm based on a set of canonical differential equations (Equations 1 -3 below) that define a set of nonlinear dynamic interactions between cells in a (usually two dimensional) grid. There are several degrees of freedom in setting up these interactions in the form of feedback and feedforward weights (namely the values A and B in Equation 1) and the initial conditions of the states (x(t=0) in Equation 1) and the bias currents (I in Equation 3). CNN is in fact programmed by way of manipulating these values. The nonlinearity comes from the nonlinear nature of the function ( in Equation 2). The function "f ' can take on different shapes and characteristics. Programming a particular function is then delegated to finding the right combination of A, B, x(t=0), and I that yields the desired outcome or outputs (y) given a pattern of inputs (u). This type of programmability is quite flexible. CNN is a hybrid of Cellular Automata and Neural Networks (hence the name Cellular Neural Networks) and it incorporates the best features of both concepts. Like Neural Networks, its continuous time feature allows real-time signal processing, and like Cellular Automata its local interconnection feature makes physical realization in VLSI possible. Its grid-like structure is suitable for the solution of a high-order system of first order nonlinear differential equations on-line and in real-time. In summary, CNN can be viewed as an analog nonlinear dynamic processor array. The basic unit of CNN is called a cell. Each cell receives input from its immediate neighbors (and itself via feedback), and also from external sources (e.g., the sensor array points and/or previous layers).
The canonical CNN equation summarizes these relationships:
τι x,l (t) = -xη (ι) + ∑ A, ,, ( u (xy„ (0)+ ∑ B,lM ukl O „ ( + 1, klcNr l) lr_Nr (,j)
Equation 1 yM- = f (χ,j )
Equation 2 and /,_, =
Equation 3
where u represents the input, x represents the state, and y represents a nonlinear function of the state associated with a cell (or neuron), and A and B represent the cloning templates.
In a typical CNN. local connections between the neighbors (feedback weights, or the entries of the matrix A in Equation 1 ), along with connections form the sensory array (input weights, or entries of the matrix B in Equation 1) form the programmable cloning templates. Cloning templates to perform numerous types of visual processing tasks have been developed. Each template is specific to a particular application, e.g., a cloning template for edge detection or binocular stereo. Cellular neural networks are attractive in image processing because of their programmability: One needs to change only the template to perform a different iconic task.
Despite such flexibility, critical problems arise when one tries to implement CNN in electronic circuits. The CNN model described in Equations (1-3), however, is not suitable for direct VLSI implementation. In an integrated circuit implementation of the CNN model, the summation equation is a current based computation, as the circuit model in Figure 1 suggests. By Kirchoff s law, all currents coming into the node that defines the state of the cell ( x ) must add to zero. As the intrinsic resistance values ( R ) are very large and capacitance values are very small, little charge is required to maintain a particular voltage. This also means that the current required to alter the voltage value of the state is relatively very small. The values of the noise currents are of sufficient magnitude to make significant difference. When one adds to that the fact that the transistor characteristics can generally vary as much as 20% within the same chip substrate, it becomes clear that the ( x ) node is highly likely to charge up or down to a power rail. One remedy is adding significant capacitance to each node. This is not desirable at all since it requires precious VLSI real estate and furthermore increases the response time of the cell. The VLSI implementations of the current CNN models have not addressed this issue, and as such, the current CNN model described in Equations (1-3) is not suitable for direct VLSI implementation.
SUMMARY
An integrated sensing device comprising an array of sensor processor cells capable of being arranged into a detection array. Each sensor processor cell comprises a sensing medium; at least one transconductance amplifier configured for feedforward template multiplication; at least one transconductance amplifier configured for feedback template weights; a plurality of local dynamic memory cells; a data bus for data transfer; and a local logic unit. The array of sensor processor cells, by responding to data control signals, is capable of transforming, reshaping, and modulating the original sensed image into varied represenations which include (and extend) traditional spatial and temporal processing transformations.
BRIEF DESCRIPTION OF THE DRAWINGS
The present invention is illustrated by way of example in the following drawings in which like references indicate similar elements. The following drawings disclose various embodiments of the present invention for purposes of illustration only and are not intended to limit the scope of the invention.
Figure 1 (Prior Art) illustrates an existing embodiment of an architecture of a physical realization of the cellular neural network canonical equations.
Figure 2 illustrates an embodiment of an adaptation of a dynamic cellular computation model to the VLSI domain in accordance with the teachings of one embodiment of the present invention.
Figure 3 illustrates an alternate embodiment of an adaptation of a dynamic cellular computation model to the VLSI domain in accordance with the teachings of one embodiment of the present invention.
Figure 4 illustrates an alternate embodiment of an adaptation of a dynamic cellular computation model to the VLSI domain employing analog multipliers in accordance with the teachings of one embodiment of the present invention.
Figure 5 illustrates an embodiment of an operational process in flow chart format for a dynamic cellular architecture in accordance with the teachings of one embodiment of the present invention.
Figure 6 illustrates an embodiment of a cellular architecture element or cell in accordance with the teachings of one embodiment of the present invention.
Figure 7 illustrates an embodiment of the layout of a CMOS chip comprising several types of cellular units in accordance with the teachings of one embodiment of the present invention. Figure 8 illustrates an embodiment of a one input - one output cell with initialization in accordance with the teachings of one embodiment of the present invention.
Figure 9 illustrates an embodiment of a programmable type feedback cell in accordance with the teachings of one embodiment of the present invention.
Figure 10 illustrates an embodiment of a positive and negative feedback hardwired and state initializable cells in accordance with the teachings of one embodiment of the present invention. Figure 1 1(a) illustrates an embodiment of two (+/-) hardwired feedback and floating state cells in accordance with the teachings of one embodiment of the present invention.
Figure 1 1(b) illustrates one embodiment of a one feedforward only cell in accordance with the teachings of one embodiment of the present invention. Figure 12 illustrates an embodiment of digital input accommodation via parallel transistor cascading in accordance with the teachings of one embodiment of the present invention.
Figure 13 illustrates an embodiment of a feedforward cell in accordance with the teachings of one embodiment of the present invention. Figure 14 illustrates an embodiment of the results from a three input one output cell with no feedback connections in accordance with the teachings of one embodiment of the present invention.
Figure 15 illustrates an embodiment of a dual distributed cellular architecture in accordance with the teachings of one embodiment of the present invention.
Figure 16 illustrates an embodiment of the layout of a signed sensor in accordance with the teachings of one embodiment of the present invention.
Figure 17 illustrates an embodiment of a dual output light sensing pixel in accordance with the teachings of one embodiment of the present invention. Figure 18 illustrates an embodiment of a schematic diagram of a cell of a programable convolutiuon array (PCA) in accordance with the teachings of one embodiment of the present invention.
Figure 19 illustrates an embodiment of the layout of a single cell of the programable convolutiuon array (PCA) in accordance with the teachings of one embodiment of the present invention.
Figure 20 illustrates an embodiment of the outputs of the programable convolutiuon array (PCA) elements in accordance with the teachings of one embodiment of the present invention. Figure 21 illustrates an embodiment of a 5 x 5 programable convolutiuon array (PCA) with I/O pads in accordance with the teachings of one embodiment of the present invention.
Figure 22 illustrates an embodiment of an operational process in flow chart format for a programmable convolution array (PCA) of the dual distributed architecture in accordance with the teachings of one embodiment of the present invention.
Figure 23 illustrates an embodiment of an element of the programmable cellular logic array (PCLA) in accordance with the teachings of one embodiment of the present invention. Figure 24 illustrates an embodiment of an operational process in flow chart format for a programmable cellular logic array (PCLA) of the dual distributed architecture in accordance with the teachings of one embodiment of the present invention.
Figure 25 illustrates an embodiment of an operational process in flow chart format for using the programmable convolution array (PCA) and programmable cellular logic array (PCLA) of the dual distributed architecture cooperatively in accordance with the teachings of one embodiment of the present invention.
Figure 26 illustrates an embodiment of a computing environment in which the invention may be implemented in accordance with the teachings of one embodiment of the present invention. Figure 27 illustrates an embodiment of a network environment in which the invention may be implemented in accordance with the teachings of one embodiment of the present invention.
DETAILED DESCRIPTION
The following detailed description sets forth numerous specific details to provide a thorough understanding of the invention. However, those of ordinary skill in the art will appreciate that the invention may be practiced without these specific details. In other instances, well-known methods, procedures, protocols, components, algorithms, and circuits have not been described in detail so as not to obscure the invention.
In one embodiment, the steps or process of the present invention are embodied in machine-executable instructions, such as computer instructions.
The instructions can be used to cause a general-purpose or special-purpose processor that is programmed with the instructions to perform the steps of the present invention. Alternatively, the steps of the present invention might be performed by specific hardware components that contain hardwired logic for performing the steps, or by any combination of programmed computer components and custom hardware components.
The present invention is generally directed to a new cellular network architecture that can be implemented successfully using electronic circuits and integrated microelectronic chips, and a new distributed architecture comprising two separate arrays, namely a programmable convolution array PCA and a programmable logic array PLA for processing one. two or three dimensional array (physical) sensor data.
DYNAMIC CELLULAR ARCHITECTURE
One embodiment of the present invention introduces a self-normalizing feedback structure for the computation of the inputs and feedforward template. Similarly, the present invention also introduces the same structure to the feedback portion of the architecture. These modifications create a new set of equations, and correspondingly a new set of dynamics, and thus represent a new structure, form, and architecture. The feedback in the feedforward input weight multiplication process and the feedback in the feedback weight multiplication are employed to keep the state node ( x ) from quickly accumulating or losing charge to saturate to a power rail.
Figure 2 illustrates one embodiment of the present invention implemented in circuitry. Figure 2(a) illustrates one embodiment of a self regulating mechanism, wherein rather than multiplying the input by B (as in the prior art), a function of the input minus the state is defined per node and that quantity is multiplied by that B. As such, the stabilizing and self scaling feedback elements around an amplifier keep the output of the amplifier from saturating. The gain of the amplifier is manipulated to obtain a factor which is a scaled (normalized) version of B. In this way, the output is consistently the input times a normalized vesrion of "B" and the plural (collective) inputs from the cell neighborhood will not cause the cell's aggregate state or output to saturate or be overdriven with slight fluctuations of the input. Figure 2(b) illustrates one embodiment of an adaptation of the dynamic cellular computation model to the VLSI domain using the concept shown in Figure 2(a).
In one embodiment, it is assumed that all input weights (or, all entries of B weights are nonnegative) and all feedback weights (all entries of A) are nonpositive.
As illustrated in the embodiment of Figure 2, within the circuit implementation shown in Figure 2(b): (1) both u (unsigned) and x (signed) are represented as analog voltages u and x; (2) template weights can be digitally stored and are programmable; and (3) the transfer function f ( ), such as that illustrated in Equation 2, can in fact become a programmable tri-level saturation function, f '( ) that produces zero output in a local region of the input (rather than only at a point).
The particular equations that incorporate the characteristics of the circuit structure of Figure 2 are listed below.
Cxu(t) = -^ I s + klε ∑Nr (,jA) klyk,(t)+ Ue ∑Nr (.ij ) Bu h [^ *" '- uu(t)- x > ))] + I,,
Equation 4 qK y = /(*) = tanh KJX^ sX - VRkl. ))
Equation 5
and Iy = 1
Equation 6
where the hyperbolic tangent (tanh) describes a basic transconductance circuit. Moreover, the differential equations need to be initialized from the cells initial conditions:
*w(0)
We observe that the capacitor C and the resistor R may be due to the parasitics of the micro-electronic implementation process. However, in cases where larger capacitance than the parasitics is desired in order to slow down or reshape the temporal processing, then capacitances in the order of pico-farads may be implemented on chip. Any larger capacitance may be implemented off- chip with the likely consequent cost of limiting the size of the cellular array. In one embodiment, the input (feedforward) weights (B) are implemented in a negative feedback structure. Accordingly, in this implementation, the feedback structure stabilizes the state (x) node, which otherwise has a tendency to charge all the way up or down to a rail limited by the power supply, and the structure is far more resilient to manufacturing related issues such as transistor mismatches. In the embodiment of Figure 2, the modified dynamic cellular architecture model is shown, wherein some assumptions have been made about the polarity of inputs and weights, such as B is nonnegative and A is nonpositive.
Figure 3 illustrates an alternate embodiment, illustrating a revision or modification that enhances the implementation scales and the contributions of the states as well. Accordingly, the particular equations represent the circuit architecture which is implementable in integrated micro-electronic chips are: Ci,( = -^+ Λ( + Sle N Σr () (,j ) Λu yjt) + kl ∑Nr Vj ) 5λ, tanh[ ^ l K 1 (^;( - J ( )]+ /v
Equation 7
y,J = f( ) = an (^(VRI I - xll))
Equation 8 qK
J>« = /(**/) = tanh( 2 tr ( *„))
and j ~ )) Equation 9
Figure imgf000014_0001
where the hyperbolic tangent (tanh) represents a basic (or wide-range) transconductance amplifier circuit.
In one embodiment, the indices kl runs over a neighborhood of the cell location ij for the feedback term A, while kl run over a neighborhood of the location ij in the feedforward term associated with the B parameters. As before, the input (feedforward) weights (B) are implemented in a negative state- feedback structure. Accordingly, in this implementation, the feedback structure stabilizes the state (x) node, which otherwise has a tendency to charge all the way up or down to a rail limited by the power supply, and the present structure is far more resilient to manufacturing related issues such as transistor mismatches. As such, Figure 3 illustrates this modified dynamic cellular architecture model is shown, wherein some assumptions have been made about the polarity of inputs and weights, such as each elements of B and A is nonnegative.
Figure 4 illustrates yet another embodiment that employs the usage of analog multipliers (rather than amplifiers with gain). As such, the feedback connected amplifiers of the embodiment of Figure 3 (Illustrated as Figure 4(a)) may be replaced by analog multipliers to implement weights of positive or negative sign, as illustrated in Figure 4(b). Moreover, digital gains can also be built by way of modifying the analog multipliers gain with the digital input accommodation via parallel transistor cascading method shown in Figure 9. By adding a multiplier that is capable of sign representation, the restrcitions on template weights are eliminated.
Dynamic Cellular Architecture Process
Figure 5 illustrates one embodiment of the operational process of the
Dynamic Cellular Architecture illustrated above. In one embodiment, before the process begins, the necessary A, B, x(0), and bias values for all of the operations to be performed is determined. Accordingly, in one embodiment, a program is made of operations needed to complete the task, such that each step of the program specifies an operation, where each operation is defined by the pattern of A, B, x(0), and bias values to be applied to the cellular architecture. In one embodiment, it is possible to simply obtain these values from the results of previous operations. In one embodiment, the program may be stored externally or on the same chip where the architecture is implemented. In an alternate embodiment, each cell of the architecture may contain its own program memory.
Referring back to Figure 5, one embodiment of the operational process of the Dynamic Cellular Architecture illustrated above, may be implemented through the following process:
1. START
2. If previous operation is complete or if new data is needed, get new inputs. These inputs (values of the nodes labeled u) may come from continuous or discretely sampled data from sensors built into the architecture, or alternately, they can be scanned into the input nodes (u) from an external data source by employing an appropriate scanning mechanism.
3. Apply the A, B, and bias to the correct nodes, either externally or from internal stored program memory. 4. Apply the initial states (x(t=0)) to the state nodes.
5. Allow sufficient time for the computation to complete, i.e., for the electronic circuits to reach a point where the change of the values of the states equals zero or have sufficiently responded to the input stimulus. For active sensors, which do not produce a static output, there may be a specific optimum or desired time instant to sample their output. Another option is that the output itself is a time variant waveform.
6. Read and store the states (x) or the output nodes (y). The state or output can be stored externally or internally per node.
7. If end of program, go to (END).
8. Go to (2).
9. END
As such, the aforementioned process steps illustrate one embodiment of the operational process of the Dynamic Cellular Architecture.
Dynamic Cellular Architecture- Sample Implementation
Figure 6 illustrates one embodiment of a pragmatic implementation of the Dynamic Cellular Architecture, as a simple 5x5 array. Figure 6 illustrates an integrated light sensing and processing architecture implemented within cellular chip based on the dynamic cellular architecture of this invention. It is understood that the inventive concepts of the present invention may be applied to a variety of different technologies and implemented in a variety of different physical architectures, and as such, the present invention is not meant to be limited to integrated light sensing and processing architectures. In one embodiment, the integrated light sensing and processing architecture based on the dynamic cellular architecture of this invention is comprised of an array of identical sensor processor cells, each of which contain: (1) a photodiode and circuits for active light sensing; (2) transconductance amplifiers for feedforward template weight multiplication; (3) wide range transconductance amplifiers for feedback template weights; (4) analog/ single bit digital local dynamic memory cells; (5) a data bus for transfers; (6) local programmable logic; and (7) read/write data controls. In the embodiment of the structure illustrated by Figure 6, a variety of operations of the cellular paradigm may be performed using, for instance, a pair of 3 x 3 cloning templates, defined by the A and B of Equations (4) or (7). Generally, each operation can be completed in a short time while it is carried out in each of the elements over the entire image. This implies unprecedented processing rate improvements of sequential processors. In one embodiment, the operations include linear transformations of the input (convolution operations), plus connected component detection and other types of data manipulation allowed for by the feedback weights. For instance, some example operations are edge location, morphology operators such as dilation, thinning, and erosion, light adaptation, scratch removal, texture, color and shape analysis. In addition, in one embodiment, by using the initialization of the states by previously obtained frames, it is also possible to use the two template array to implement temporal operations, such as motion analysis, e.g., local velocity detection, motion direction detection.
In the embodiment of Figure 6, the overall cellular chip is illustrated as a system. In this embodiment, an external (or international core) microcontroller generates the necessary command signals to the integrated sensor processor, such as sensor timing, row select, and program code. In an alternate embodiment, the microcontroller can be replaced by a processor or a digital signal processor depending on the computing needs of the particular application at hand. Likewise, in one embodiment, the program memory can be internal, where a more compact address gets horizontally coded into bit level microinstructions and determine template values and data transfers within the architecture.
In the embodiment of Figure 6, the contents of a cell are illustrated in greater detail. For instance, the feedforward and feedback weights which also integrate the transfer function are shown in outline format. In addition, the local logic and memory functions are likewise illustrated in a similar fashion. In one embodiment, there is a main data bus across which data transfers can occur. As such, two way connections can be made between the data bus and the two analog and four digital memory units, the state (x) and input (u). Also, connection can be made from the logic output and the reference voltage to the data bus. Additionally, the logic can be implemented by programming, similar to that of programmable logic arrays. Similarly, the emerging reconfigurable logic arrays represent another option or embodiment.
As mentioned above, it is understood that the inventive concepts of the present invention may be applied to a variety of different technologies and implemented in a variety of different physical architectures, and as such, the present invention is not meant to be limited to integrated light sensing and processing architectures. For example, the same architectures can be applied to any system, such as an acoustic or sound based system, where there are multiple sensors arranged in a one. two, or three dimensional grid. Each sensor element on the grid may then respond to the same single physical quantity (e.g., frequencies of the audible sound spectrum). As such, each sensor may sense a different attribute of the same signal (e.g., each sensor tuned to a different frequency of the audible sound spectrum). This will measure the frequency pattern of the sound incident on the array. Further, one can also imagine hybrids of these two, such as measuring a color pattern.
Implementation of Several Cellular Model Circuits
Figure 7 illustrates one embodiment of the layout of a CMOS chip comprising several types of cellular units (e.g., VLSI adapted cellular dynamic architecture cell prototypes), in accordance with the concepts of the present invention. In one embodiment, the CMOS chip design may be manufactured to the MOSIS 2 micron ORBIT ANALOG process. Likewise, in one embodiment, the die size is implemented through the "TINYCHIP" package that is a 2.3 mm x 2.3 mm area bonded to a 40 pin DIP.
In one embodiment of the CMOS chip, as illustrated in the embodiment of Figure 7, the CMOS chip comprise eleven types of cells: Four One Feedforward - One Feedback Cells with Initialization; Two Programmable Type (Positive or Negative) Feedback Cells; Two Hardwired Feedback and State Initializable Cells; Two (+/-) Flardwired Feedback and Floating State Cells; and One Feedforward only Cell. In one embodiment, all outputs are made available through wide range followers at the outputs and all programmable cell parameters, i.e., feedforward and feedback weights, and bias are at 3 bit resolution (plus sign bit). External inputs are available via pins to set these weights through the pins.
Figures 8-1 1 illustrate these respective cells schematically. Figure 8 illustrates one embodiment of the schematics of the four cells in a compact manner: Four One Feedforward - One Feedback Cells with Initialization. At the top of the chip of Figure 7, there are four one input one output cells. There are four versions of this simple one input - one output simple cell. The four versions arise due to the four ways in which the permutations of the positive and negative feedbacks can be implemented. Four combinations of +/- terminals are possible and all of these may have been implemented. Moreover, all four cells include a state initialization mechanism to define x at the initial time instant (t = 0). This means that the state can be initialized at any voltage that can be carried by on the specific microelectronic implementation. This is equivalent to defining an initialization point x 1 1=0 in Equations (4) and (7). Both the feedforward and the feedback amplifiers have three bit programmable gain in this specific implementation.
Figure 9 illustrates one embodiment of the schematics of the Two Programmable Type (Positive or Negative) Feedback Cells. Two three-input one-output selectable kind (+ or -) of feedback cells may be implemented. One of these also allowed for initialization of the state in a manner identical to the one illustrated in Figure 8. Figure 9 shows this type of cell without initialization. In one embodiment of the cell, as illustrated, there is an added delay of a pass-through transistor in feedback of the state. The two signals (the state node x and Vref) are directed to the terminals of the feedback weight amplifier based on the feedback sign select bit. In one embodiment, all amplifiers have three bit programmable gain. Figure 10 illustrates one embodiment of the schematics of the Two Hardwired Feedback and State Initializable Cells. Two three input one output cells illustrated in Figure 10 were included with initialization. These cells differ from the ones described in Figure 9 only slightly. In one embodiment, the type of feedback is directly implemented rather than being programmable. Two combinations of +/- terminals are possible and both have been implemented. In one embodiment, both amplifiers have three bit programmable gain.
Figure 1 1(a) illustrates one embodiment of the schematics of the Two (+/-) Hardwired Feedback and Floating State Cells. In one embodiment, these cells are identical to the ones described in Figure 10 but do not contain state initialization circuits. Initial value of the state is thus undefined.
Figure 1 1(b) illustrates one embodiment of the schematics of the One Feedforward only Cell. This is a three input one output cell with programmable bias. In one embodiment, the feedback component is eliminated. Thus the cell diverges from the cellular neural network paradigm and instead is useful for feedforward operations only.
Figure 13 illustrates one embodiment of a Feedforward cell. In one embodiment, the input u is always nonnegative but has a signed representation and positive entries of the B template select u+ and negative ones select u~.
Feedforward Weights and Image Convolution: Sample Operation
Convolution is a very common image processing step that precedes many vision tasks. It is often used as a technique to generate a second (different) image from the original where desired features are enhanced and/or undesired characteristics (e.g., noise.) are suppressed. In one embodiment, convolution can be described as a continuous spatial or temporal operation, but its application to sampled images is discrete and involves a convolution kernel with discrete values. This discrete convolution operation denoted by <S>, between an image I and kernel k can be described as :
- = -Nj=-N
Equation 10 where I is the input image, x and y are the two dimensional image coordinates, and k is an (2N+1 x 2N+1) square kernel.
One can easily see the similarity between the feedforward weight input product sum
∑ Bkl (ukl (t), Uη (t),) in Equation (1) and the sum in Equation (10). klεNr (ι )
Thus, if one sets, 1=0 and A=0, the steady state solution to Equation (1) is
.,(') = uu(t) , uη(t))
Figure imgf000021_0001
which is in fact equivalent to I Θ kl , where the second term is a normalized kernal. The described VLSI adapted model performs a normalized operation which replaces the feedforward weights time the input values summation terms of the canonical model in Equation (1)
∑ Bkl (ukl (t))
with
∑ Bkl tanh[ ^r(w., (0 - X Xt))] in Equation (4). leN (IJ) ^kl
Normalized convolution, denoted by ®n is very similar to the conventional convolution operation, except that the output is normalized by the sum of kernel entries. Because kernels are the same across the whole image, the result is essentially division by a normalization factor common to the entire image. The advantage is that the dynamic range of the resulting image is essentially the same as that of the input image.
N N y y i • - k. .
_ i = -N j = -N k χ.y " N
Σ Σ ki, j
Equation 11
For the implementation of the normalized convolution described above, input voltage values are loaded with input voltages corresponding to the image, and gains from the entries of the kernel. Since the conductances for gain values) are necessarily positive, to implement negative kernel values with this approach, one needs to be able to define negative input voltages and select negative polarity for the input to the transconductance amplifier for which a negative kernel value is desired. This cuts the dynamic range of images in half, although the range of kernel entries remain unaffected. One can view the cell arrangement in Figure 1 1 (b) in this light, provided that the bias amplifier is ignored.
Sample Operation:
For instance, in a sample operation, a four bit plus sign representation, shown in Figure 12 (digital input accommodation via parallel transistor cascading), may used as entries of the B template in Equations (1) and (4) and take on values equivalent to the range of -3.75 and 3.75 in increments of 0.25. In one embodiment, the cell is equivalent to the feedforward configuration shown in Figure 1 1(a) provided that the gain of the amplifiers are sent by the B template. With more area and more bits higher resolution and dynamic range would be possible. In the sample operation, other parameters may be as follows:
0 < u < 1 u + = V ref + u u - = V ref - u
-3.75 < b < 3.75 u min < x < u max
V ref may be the representation of zero in this architecture. One suggested value for Vref are the midpoint between the power supply ranges ground and the power supply of the microelectronic implementation.
Implementation of sign is based on selection of the u + or u -. Note that this also creates the opportunity to implement negative u. In other words, it is possible to accommodate u < 0 values in this structure, as well. In that case, the parameters may be as follows:
-1 < u < l u + = Vref + u u - = V ref - u
Specific realization of the -3.75 to 3.75 range realizing different values of template B in the architecture yields the following:
b = b sign (v) b 3 (MSB) b 2 b 1 b 0 (LSB)
-3.75 0V 1 V 1 V 1 V 1 V
-2.00 ov 1 V ov ov ov
-1.00 0V OV 1 V ov ov
-0.50 ov OV ov 1 V ov
-0.25 ov ov ov ov 1 V
0.25 5 V ov ov ov 1 V
0.50 5 V ov ov 1 V ov
1.00 5 V ov 1 V ov ov
2.00 5 V 1 V ov ov ov
3.75 5 V 1 V 1 V 1 V 1 V
where Power = 5 V and logic 1 = 5 V. We can select 1 V as bias to operate the bias transistors around threshold. In one embodiment, the state node (x) is referenced to V ref and does not need a signed representation. Positive entry values for the feedback template "A" can be used to steer x to the + terminal and negative entries steer it to the - terminal of the wide range differential amplifier. In the four bit plus sign representation A values may likewise take on values in the range -3.75 and 3.75 in increments of 0.25. With more area and more bits higher resolution and dynamic range would be possible. Other parameters are as follows: -3.75 < aij < 3.75 and 0 < x < Vdd.
As such, the feedback configuration of the feedforward weights provides for some safety against the tendency of active current computation units to be attracted to a power supply rail.
Two real images were captured using a CCD camera and presented to the chip three inputs at a time. Three weights for the inputs are set to represent the one dimensional vertical edge kernel of 1 0 -1. In the present sample operation, each pixel is presented in this fashion. In the sample operation, the whole image was presented three pixels at a time along the horizontal direction to the model circuit shown in Figure 11 (b) with the bias amplifier disabled, the result is shown in Figure 14.
DUAL DISTRIBUTED ARCHITECTURE
One embodiment of the present invention, as illustrated in Figure 15. introduces a Dual Distributed Architecture, illustrated as a 5x5 array. In one embodiment, the Dual Distributed Architecture contains two distinct structures: (i) programmable convolution array PCA, a sensing grid with convolution capability, which may also include some short term memory, and (ii) PLA, a programmable logic array and memory area on which transformations or alternate representations of the sensory data can be recreated. In one embodiment, both areas compute in parallel and communicate with each other as needed in a serial but random access fashion. Also, it is primarily the programmable cellular logic array (PCLA) that communicates with the outside realm, which potentially includes a conventional digital signal processor, microprocessor or microcontroller. In view of the ideal of leveraging the speed of the implementation medium (most commonly silicon microelectronic circuits) against the large area requirements of a cellular processor, we view again the components of the cell of a specific implementation, which are listed in Dynamic Cellular Architecture above, namely: (1) a photodiode and circuits for active light sensing; (2) transconductance amplifiers for feedforward template weight multiplication; (3) wide range transconductance amplifiers for feedback template weights; (4) analog/ single bit digital local dynamic memory cells; (5) a data bus for transfers; (6) local programmable logic; and (7) read/write data controls. Practical real-world concerns and implementations for integrated cellular sensor-processor systems generally dictate consideration of the following: (1) the sensors be manufacturable and embedded into the processing system; (2) the resolution of the sensory part of the system be close to that available commercially; (3) the fill factor (ratio of sensor area to the total area of each cell) be reasonable for the application; (4) the sensor performance be maintained with shrinking technology size; (5) a set of operator sizes that take in data from a large neighborhood. These are simply factors to consider when implementing an integrated cellular sensor-processor system, but do not have to be specifically adhered to, and as such, the aforementioned factors are not intended to limit the scope of the present invention
Nevertheless, taking a systematic approach to meeting the objectives itemized above, the following factors, likewise, should generally be noted: (1) to improve the resolution one needs to shrink the cell; (2) to improve the fill factor, one needs to increase the light sensitive areas; (3) to keep the sensor operational, one may need to build the sensors (or the whole chip) using a larger technology which again means that one needs to make the cell yet smaller; and (4) to increase the neighborhood size, one may need to build yet a larger cell that connects to more of its neighbors. Again, these are simply factors to consider when implementing an integrated cellular sensor-processor system, but do not have to be specifically adhered to, and as such, the aforementioned factors are not intended to limit the scope of the present invention. In this manner, one can also implement (in the feedfoward connections) arbitrary size neighborhood, or kernels, as they are commonly called in image processing, including a kernel that is as large as the whole sensor array itself, but only with one such kernel at a time. This leverages the speed of the implementation medium against area requirements of the processor.
The dual distributed architecture generally provides three significant advantages as compared to currently implemented or existing architectures.
First, the computational concept of the architecture is simpler and far more conventional than the concept of the cellular neural network of prior art, which employ nonlinear circuit dynamics. Moreover, practicing engineers already will need far less training to implement this architecture. The way operations in the dual distributed architecture are programmed is far more straightforward than the way in which one needs to go about determining or finding the correct A, B, x(0), and I parameters, as compared to currently implemented or existing architectures.
Second, since the role of nonlinear dynamics is minimized, electronic circuit anomalies, such as mismatches or noise inherent to the substrate on which the architecture is built, have far less impact on the outcome of the computation. This makes the implementation a lot easier and cost effective to manufacture.
Third, the architecture of the dual distributed architecture, as the name implies, comprises two parts, and each of those parts serves a separate function. In other words, each part is functional on its own and can be implemented without the other. The first part of the dual distributed architecture is the programmable convolution array PCA, which in one embodiment comprises a sensing grid with convolution capability, which could also include some short- term memory. The programmable convolution array PCA part performs arbitrary linear transformations of the whole sensory data or parts of the sensory data. The desired weights of the individual elements can be directly programmed. The second part dual distributed architecture is the Programmable
Cellular Logic Array (PCLA). In one embodiment, the PCLA is cellular, which means that each of the elements of the array connected to a set of its neighbors. The PCLA, however, is not a neural network and in one embodiment relies on conventional logic to perform its operations. In one embodiment, the actual logic can be implemented with conventional digital logic or non-conventional analog logic gates, such as but not limited to AND OR XOR. Additionally, in one embodiment, there can be a state-machine (i.e., a mini computing engine) at each of the elements. For stand-alone operation, each element of the PCLA could be equipped with a sensor, or data could be scanned in from an external source.
The Signed Output Sensor (SOS)
As for some types of implementations of the convolution function, e.g., those using non-negative gain amplifier circuits, it may be necessary for each sensor to produce dual outputs. Accordingly, depending on the nature of the sensor, the way such dual output is produced may be different. For sensors that measure non-negative values referenced to zero (e.g., light), there may need to be a (+) and a (-) pixel output. Positive (+) output is used for feeding into the amplifier if it contains a positive kernel value. Correspondingly, the negative (-) pixel output may used for negative kernel value. A one dimensional example is given below.
Suppose that one needs to implement a one dimensional edge kernel of [ 1 0 -1] on a light sensitive grid. The equivalent arithmetic operation is the sum pixel[i-l] + (- pixel[i+l]). Since current summation can be used, one needs to add the current for the positive representation of pixel [i-1] to the current for negative representation of pixel[i+l].
Figure 16 illustrates one embodiment of an exemplary layout of such a single signed output active sensor. In the embodiment of Figure 16, the active area is a square of 100 λ x 100 λ and the whole cell covers a 195 λ x 130 λ area. The (grounded) METAL2 layer covering the areas of the cell that should not be exposed to light is not shown. Likewise, the corresponding schematic of the signed sensor is illustrated in Figure 17, where the positive and negative pixel representations are marked. In one embodiment, the additional follower is employed since the photocurrent is very small and the photosensing node should not be perturbed.
Programmable Convolution Array (PCA)
Figure 18 illustrates one embodiment of a design of one element of a light sensing PCA. In one embodiment, each pixel cell can be addressed by the combination of row and column select signals. Likewise, weight bits can also thus be written to selected pixels. Pixel midpoint determines the "0" value - i.e., no light, of the signed pixel value representation. Reset pixel will charge the pixel output to that value. In one embodiment, a dedicated ground signal need not be routed since a metal layer covering the circuits (with opening at light sensitive areas) can be grounded. In the embodiment of Figure 18, each cell contains: (1) one signed output sensor (SOS); (2) four D flip flops for storage of three bit weight and sign; (3) four multiplexers; (4) one wide range transconductance amplifier connected in the unity follower configuration; and (5) a three input AND gate.
In one embodiment, the size of the cell can be reduced significantly, since as the layout of the single cell in Figure 19 shows, there are some empty spaces. Smaller feature sizes and added metal layers will no doubt compact the cell further. A significant area savings would result from a dynamic memory cell, since each kernel would be used for a short period of time. Several data and control signals are generally routed to each cell.
In one embodiment, the controls signals common to all cells include: (1) clock weight, (2) reset photodiode (or sensor), and (3) sign. Addressing signals are row and column. In one embodiment, the data signals common to all cells include: (1) pixel reference, (2) inverter reference, (3) weight high, (4) weight low, (5) weight MSB, (6) weight MID, (7) weight LSB. Furthermore, in one embodiment, as illustrated in Figure 20, elements of each row have a common row select signal and elements of each column have a common column select signal. Accordingly, the output of each cell may be summed onto a common line. Alternately, outputs can be combined along columns, rows, or block-vor along alternate designations.
Figure 21 illustrates an example PCA layout of 5 x 5 pixels. In the embodiment of Figure 21 , each of the 25 elements use four weight bits (three magnitude and one sign) which are stored in D-flip-flops. Accordingly, the weight bits are clocked in only when both the row and the column are selected, as well as when the weight clock bit is active. The outputs of the weight flip flops the select between the weighthigh and weightlow. In one embodiment, the wide range transconductance amplifier at the output stage has three bias transistors with W/L ratios of VA, Vi, and 1, each corresponding to the magnitude bits. If all weights are zero, the pixel does not contribute any current to the output. If any of the weights is non-zero, based on the sign, the pixel makes a positive or negative current contribution to the overall reading. The data signal, weighthigh also determines the gain on the photosensor. In one embodiment, the D flip flops could be replaced with dynamic memory to save silicon area. In one embodiment, the design may be implemented in a 2 micron CMOS technology design with its pads configured to fit into an area of 2.3 mm x 2.3 mm. and is embedded in a 40 pin DIP chip package. All 25 pixel outputs are summed on a common output line in this example implementation. One can select different signs and weights for each of the cells and thus perform arbitrary convolution operations. Arbitrary 4-bit kernels up to 5 x 5 can be programmed in this particular example implementation.
PCA Process Figure 22 illustrates one embodiment of the operational process of the
Programmable Convolution Array (PCA) illustrated above. In one embodiment, before the process begins, the necessary weight patterns to be applied to the array for all of the operations to be performed is determined. Accordingly, in one nembodiment, a program is made of operations needed to complete the task, such that each step of the program specifies an operation, where each operation is defined by the pattern of weights to be applied to the array. In one embodiment, it is possible to simply obtain the weight pattern from results of previous operations. In one embodiment, the program may be stored externally or on the same chip where the array is implemented. In an alternate embodiment, each cell of the array can have its own program memory. Referring back to Figure 22, one embodiment of the operational process of the Programmable Convolution Array (PCA) illustrated above, may be implemented through the following process:
1. START
2. If previous operation is complete or if new data is needed, get new inputs. These inputs may come from continuous or discretely sampled data from sensors built into the array, or alternately, they can be scanned into the input nodes from an external data source by employing an appropriate scanning mechanism.
3. Apply the weight pattern of the instruction, either externally or from internal stored program memory.
4. Allow sufficient time for the computation to complete, i.e., for the electronic circuits to reach a point where the change of the value of the output of the array equals zero. For active sensors, which do not produce a static output, there may be a specific optimum time instant to sample their output. Another option is that the output itself is a time variant waveform.
5. Read and store the output(s) of the array. The output can be stored externally or internally. If the PCA is used in tandem with a PCLA, then the output can also be sent to PCLA. 6. Wait for next operation.
7. If end of program, go to (END). 8. Go to (2).
9. END.
Programmable Cellular Logic Array (PCLA)
The output of a convolution operation performed by the PCA is usually an analog current or voltage value. While this rapid arbitrary size kernel convolution operation is extremely useful, there are many early vision operations that require further processing of the results of many convolution operations. The programmable cellular logic array (PCLA) is a way of implementing this stage.
In one embodiment, the PCLA is a processing device that processes binary or digital data using a set of fixed or programmable logic elements arranged on a cellular grid. Accordingly, if the PCLA is used with a PCA, the sizes of the two arrays could be the same or different. In one embodiment, the PCLA grid can function as a "scratch-pad" for a set of iconic operations, such as shape detection, contour following, pattern matching, all performed using the outputs of the PCA or external outputs, potentially at different resolutions than the data received.
Furthermore, each element of the PCLA can be addressed like a memory array to which the input (e.g., outputs from the PCA) can be applied or stored, and from which results can be retrieved. Added functionality would result from the ability to transfer bits between neighbors (analogous to shift operations) or to arbitrary locations of the cellular logic grid (random access transfers).
The embodiment of Figure 23 illustrates a simple implementation of the elements of the programmable cellular logic array (PCLA). In the embodiment illustrated in Figure 23, only the center cell connections are shown to prevent clutter, also in the embodiment shown, the cell output has been staged to prevent race conditions. In this embodiment, all operations are strictly local. This is not a limitation of the invention. In one embodiment, global operations such as matching with a global pattern, reset, set, and other can also be implemented into the PCLA. Furthermore, added functionality could be realized (1) with increased connectivity, where each cell receives more inputs, such as those from additional cells in the neighborhood, or from arbitrary cells on the array via memory-like addressing; and (2) with increased cell memory, where the results of previous operations can be stored in the cell. In one embodiment, the logic within the cell should be programmable. In fact, the program may change many times during the operation. Sample logic functions could be AND, OR, INVERT, XOR etc. of a set of the available inputs.
In one embodiment, the PCLA would benefit from the use of the emerging reconfigurable field programmable gate arrays (FGPA's). This is a relatively new field, however, researchers are keenly looking at ways to capitalize on the inherent flexibility in these devices to facilitate the building of a better computing paradigm.
One specific concept in this domain, termed the plastic cell architecture, brings forth a new circuit type that is laid out as an array of identical computing elements or cells which could dynamically reconfigure themselves for specific problems. This new computing paradigm offers a novel feature beyond the common reconfigurable FPGA concept, where so far, it's been possible to reconfigure circuits only via software downloaded to one or more FPGA and the chips then directly execute the prescribed functions as hardwired circuits. This added feature is the ability of one circuit to dynamically configure another circuit. The resulting processing array is able to mimic the ability to create specialized cells, which in turn allow a cellular array like the PCLA to configure itself based on outputs of its neighbors, or of itself. This level of data driven performance allow for implementation of very complex functions from very simple rules. PCLA Process
Figure 24 illustrates one embodiment of the operational process of the Programmable Cellular Logic Array (PCLA) illustrated above. In one embodiment, before the process begins, the necessary local and global logic functions that are needed is determined. These logic functions should already be implemented in each element of the array where they need to be performed, or it should be possible to program the logic contained in each element of the array to perform the logic function needed. In general, an operation is defined by the pattern of operations carried out by the individual elements of the array.
Accordingly, a program is made of the sequence of operations needed to complete the task, such that each step of the program specifies one or more functions to be performed by each element of the array. In one embodiment, at any given time, all elements may be performing the same function or different functions. Likewise, in one embodiment, it is also possible to obtain the next operation conditional upon or based on results of one or more previous operations. In one embodiment, the program may be stored externally or on the same chip where the array is implemented. In an alternate embodiment, the program memory may be local, i.e., each cell of the array can have its own program memory. Referring back to Figure 24, one embodiment of the operational process of the Programmable Cellular Logic Array (PCLA) illustrated above, may be implemented through the following process:
1. START
2. If previous operation is complete or if new data is needed, get new inputs. These inputs may come from continuous or discretely sampled data from sensors built into the array, or they can be scanned into the input nodes from an external data source, including, but not limited to the PCA, by employing an appropriate scanning mechanism.
3. Carry out the specified operation. The operation code that specifies the operation can be applied from either an external source or from internal stored program memory. 4. Allow sufficient time for the operation to complete, i.e., for the electronic circuits to reach a point where the change of the value of the output of the array equals zero. Output of active sensors should have been digitized a priori.
5. Read and store the output(s) of the array. The output can be stored externally or internally. If the PCLA is used in tandem with a PCA, then the output can also be sent to PCA.
6. Wait for next operation.
7. If end of program, go to (END).
8. Go to (2).
9. END
Communication between the PCA and PCLA
It is evident that in addition to power and ground signals, many other data, control and address signals common need to be distributed all across the chip. As is the case with many photosensor chips, the PCA portion of the chip should be covered with a layer of metal with openings only at the photosensitive areas to allow for the exposure to light of the package. Typically, one would ground that layer of metal that covers the whole chip. A similar layer could also be used on the PCLA portion of the dual architecture to carry the output of the
PCA to all points of the logic array.
The row select and column select signals of the PCA are reminiscent of memory addressing diagrams. Only when both signals are logic high's, a specific pixel is selected. These signals may be used to load the weights to the cell.
Elements of the PCLA can also be addressed as one would address memory cells. A row of cells could be thought of as a long word. A set of write and shift operations could replace the need to route multiple address signals across the PCLA. PCA and PCLA Tandem Process
Figure 25 illustrates one embodiment of the operational process of using the Programmable Convolution Array (PCA) and the Programmable Cellular Logic Array (PCLA) in tandem. In one embodiment, before the process begins, the necessary weight patterns to be applied to the PCA for all of the operations to be performed is determined. Likewise, the necessary local and global logic functions that are needed for the PCLA is determined. In one embodiment, an operation is defined by the pattern of weights for the PCA and the pattern of logic functions carried out by the individual elements of the PCLA.
Accordingly, in one embodiment, a program is made of the sequence of operations needed to complete the task, such that each step of the program specifies one or more operations to be performed by either the PCA or the PCLA, or both. In one embodiment, the program may be stored externally or on the same chip or multichip module where the two arrays is implemented. In an alternate embodiment, the program memory may be central or local, i.e., each cell of the arrays can have its own program memory.
Referring back to Figure 25, one embodiment of the operational process using the Programmable Convolution Array (PCA) and the Programmable Cellular Logic Array (PCLA) in tandem, may be implemented through the following process:
1. START
2. If previous operation is complete or if new data is needed, get new inputs. These inputs may come from continuous or discretely sampled data from sensors built into one or more of the arrays, or they can be scanned into the input nodes from an external data source, including, but not limited to from one array to the other, by employing an appropriate scanning mechanism.
3. Carry out the specified operation. The operation code that specifies the operation can be applied from either an external source or from internal stored program memory. 4. Allow sufficient time for the operation to complete, i.e., for the electronic circuits to reach a point where the change of the value of the output of the array equals zero or by some other criteria, the operation is deemed to be complete. 5. Read and store the output(s) of the array (s). The output can be stored externally or internally. The output can also be sent from one array to the other.
6. Wait for next operation.
7. If end of program, go to (END). 8. Go to (2).
9. END
Application Example: Single chip finger print lock control An application of the concepts of the present invention may be applied to finger print recognition systems. Finger print systems currently require a sensor, memory, processor, and loads of software, which in turn limits their practical application. There would be a myriad of applications for a single chip, however, that can accomplish the same task with no external processor, memory, or program. For instance, a lock on a door or a drawer or power button that has a fingerprint key are examples. The latch remains in position until one of the "authorized" fingerprints are impressed on the lock.
In this example, since the image of the fingerprint is binary, it may be practical to equip the PCLA with binary sensors and use it on its own. The logic program to manipulate the image and decide whether this is the right fingerprint or not, could be built directly into the device. Alternately, if only a linear transformation of the fingerprint image suffices, one can build a stand alone PCA. The programs could be the combinations of the weights, which may be stored on the device. As another option, using both the PCLA and the PCA may enhance the features, increase the resolution, or offer more security. Computer Environment
Figure 26 and the above description are intended to provide a general description of a suitable computing environment in which the invention may be implemented. Although not necessarily required, one embodiment of the present invention may be implemented as a set of general context of computer-executable instructions, such as program modules, being executed by a computer, such as a client workstation or a server. Generally, program modules include routines, programs, objects, components, data structures and the like that perform particular tasks or implement particular abstract data types. Moreover, those skilled in the art will appreciate that the invention may be practiced with other computer system configurations, including hand-held devices, multi-processor systems, microprocessor-based or programmable consumer electronics, communication devices, network PCs, minicomputers, mainframe computers and the like. The invention may also be practiced in distributed computing environments where tasks are performed by remote processing devices that are linked through a communications network. In a distributed computing environment, program modules may be located in both local and remote memory storage devices.
As shown in Figure 26, an exemplary general purpose computing system may include a conventional personal computer 20 or the like, including a processing unit 21 , a system memory 22, and a system bus 23 that couples various system components including the system memory 22 to the processing unit 21. The system bus 23 may be any of several types of bus structures including a memory bus or memory controller, a peripheral bus, and a local bus using any of a variety of bus architectures. The system memory 22 may include read-only memory (ROM) 24 and random access memory (RAM) 25. A basic input/output system 26 (BIOS), containing the basic routines that help to transfer information between elements within the personal computer 20, such as during start-up, may be stored in ROM 24. The personal computer 20 may further include a hard disk drive 27 for reading from and writing to a hard disk (not shown), a magnetic disk drive 28 for reading from or writing to a removable magnetic disk 29, and an optical disk drive 30 for reading from or writing to a removable optical disk 31 such as a CD-ROM or other optical media. The hard disk drive 27, magnetic disk drive 28, and optical disk drive 30 may be connected to the system bus 23 by a hard disk drive interface 32, a magnetic disk drive interface 33, and an optical drive interface 34, respectively. The drives and their associated computer-readable media provide non-volatile storage of computer readable instructions, data structures, program modules and other data for the personal computer 20.
Although the exemplary embodiment described herein may employ a hard disk, a removable magnetic disk 29, and a removable optical disk 31 , or combination thereof, it should be appreciated by those skilled in the art that other types of computer readable media which can store data that is accessible by a computer, such as magnetic cassettes, flash memory cards, digital video disks, Bernoulli cartridges, random access memories (RAMs), read-only memories (ROMs) and the like may also be used in the exemplary operating environment.
A number of program modules may be stored on the hard disk, magnetic disk 29, optical disk 31 , ROM 24 or RAM 25, including an operating system 35, one or more application programs 36, other program modules 37 and program data 38. A user may enter commands and information into the personal computer 20 through input devices such as a keyboard 40 and pointing device 42. Other input devices (not shown) may include a microphone or microphones, joystick, game pad, satellite disk, scanner, or the like. These and other input devices are often connected to the processing unit 21 through a serial port interface 46 that is coupled to the system bus 23, but may be connected by other interfaces, such as a parallel port, game port, or universal serial bus (USB). A monitor 47 or other type of display device may also be connected to the system bus 23 via an interface, such as a video adapter 48. In addition to the monitor 47, personal computers may typically include other peripheral output devices (not shown), such as speakers and printers.
The personal computer 20 may operate in a networked environment using logical connections to one or more remote computers, such as a remote computer 49. The remote computer 49 may be another personal computer, a server, a router, a network PC, a peer device or other common network node, and typically includes many or all of the elements described above relative to the personal computer 20, although only a memory storage device 50 has been illustrated in Figure 26. The logical connections depicted in Figure 26 include a local area network (LAN) 51 and a wide area network (WAN) 52. Such networking environments are commonplace in offices, enterprise-wide computer networks, Intranets, and the Internet.
When used in a LAN networking environment, the personal computer 20 is connected to the LAN 51 through a network interface or adapter 53. When used in a WAN networking environment, the personal computer 20 typically includes a modem 54 or other means for establishing communications over the wide area network 52, such as the Internet. The modem 54, which may be internal or external, is connected to the system bus 23 via the serial port interface 46. In a networked environment, program modules depicted relative to the personal computer 20, or portions thereof, may be stored in the remote memory storage device. It will be appreciated that the network connections shown are exemplary and other means of establishing a communications link between the computers may be used.
It is further understood that different elements or components may be included or excluded from the general computing environment, or otherwise combined, to implement the concepts and teachings of the present invention as defined in the appended claims.
Network Environment
As noted, the general-purpose computer described above can be deployed as part of a computer network. In general, the above description applies to both server computers and client computers deployed in a network environment. Figure 27 illustrates one such exemplary network environment in which the present invention may be employed. As shown in Figure 27, a number of servers 10a, 10b, etc., are interconnected via a communications network 160 (which may be a LAN, WAN, Intranet or the Internet) with a number of client computers 20a, 20b, 20c, etc. In a network environment in which the communications network 160 is, e.g., the Internet, the servers 10 can be Web servers with which the clients 20 communicate via any of a number of known protocols such as, for instance, hypertext transfer protocol (HTTP). Each client computer 20 can be equipped with a browser 180 to gain access to the servers 10, and client application software 185. As shown in the embodiment of Figure 27, server 10a includes or is coupled to a dynamic database 12.
As shown, the database 12 may include database fields 12a, which contain information about items stored in the database 12. For instance, the database fields 12a can be structured in the database in a variety of ways. The fields 12a could be structured using linked lists, multi-dimensional data arrays, hash tables, or the like. This is generally a design choice based on ease of implementation, amount of free memory, the characteristics of the data to be stored, whether the database is likely to be written to frequently or instead is likely to be mostly read from, and the like. A generic field 12a is depicted on the left side. As shown, a field generally has sub-fields that contain various types of information associated with the field, such as an ID or header sub-field, type of item sub-field, sub-fields containing characteristics, and so on. These database fields 12a are shown for illustrative purposes only, and as mentioned, the particular implementation of data storage in a database can vary widely according to preference.
Thus, the present invention can be utilized in a computer network environment having client computers for accessing and interacting with the network and a server computer for interacting with client computers and communicating with a database with stored inventory fields. Likewise, the present invention can be implemented with a variety of network-based architectures, and thus should not be limited to the examples shown.
From the above description and drawings, it will be understood by those of ordinary skill in the art that the particular embodiments shown and described are for purposes of illustration only and are not intended to limit the scope of the invention. Those of ordinary skill in the art will recognize that the invention may be embodied in other specific forms without departing from its spirit or essential characteristics. References to details of particular embodiments are not intended to limit the scope of the claims.

Claims

CLAIMSWhat is claimed is:
1. An integrated sensing device comprising: an array of sensor processor cells capable of being arranged into a detection array, each sensor processor cell comprising: a sensing medium; at least one transconductance amplifier configured for feedforward template multiplication; at least one transconductance amplifier configured for feedback template weights; a plurality of local dynamic memory cells; a data bus for data transfer; a local logic unit; and wherein the array of sensor processor cells, by responding to data control signals, is capable of transforming, reshaping, and modulating the original sensed image into varied represenations which include (and extend) traditional spatial and temporal processing transformations.
2. An integrated sensor processing cell device comprising: a sensing medium configured to produce a signed pixel output; at least one memory device configured for the storage of weight bits, wherein at least one memory device is configured to store the signed pixel output; a plurality of multiplexers operatively associated with at least one of the memory device; at least one transconductance amplifier operatively associated with at least one of the plurality of multiplexers, the at least one transconductance amplifier configured for operation in the unity follower configuration with variable gain; a multiple input logic gate associated with the at least one of said memory devices that is configured to store the signed pixel output; and wherein the integrated sensor processing cell, by responding to data control signals, is capable of transforming, reshaping, and modulating the original sensed image into varied represenations which include (and extend) traditional spatial and temporal processing transformations.
3. An integrated sensing and imaging device comprising: an array of sensor processor cells capable of being arranged into a detection array, each said sensor processor cell comprising: a sensing medium configured to produce an electrically representable signal output; a means of quantifying the said sensor output, a means of storing the said sensor output, a plurality of programmable logic elements arranged on a cellular grid, wherein each logic element is capable of receiving inputs from the output of neighboring cells and outputs from itself; and wherein the integrated imaging device, by responding to internal or external data control signals, is capable of transforming, reshaping, and modulating the original sensed signals into varied represenations which include (and extend) traditional spatial and temporal processing transformations.
PCT/US2000/005785 1999-03-05 2000-03-06 Two architectures for integrated realization of sensing and processing in a single device WO2000052639A2 (en)

Priority Applications (6)

Application Number Priority Date Filing Date Title
CA002364182A CA2364182A1 (en) 1999-03-05 2000-03-06 Two architectures for integrated realization of sensing and processing in a single device
JP2000602988A JP2002538557A (en) 1999-03-05 2000-03-06 Two architectures for integrated implementation of sensing and processing in a single device
AU36167/00A AU3616700A (en) 1999-03-05 2000-03-06 Two architectures for integrated realization of sensing and processing in a single device
US09/914,030 US6735482B1 (en) 1999-03-05 2000-03-06 Integrated sensing and processing
EP00914830A EP1175659A2 (en) 1999-03-05 2000-03-06 Two architectures for integrated realization of sensing and processing in a single device
HK02101234.2A HK1039992A1 (en) 1999-03-05 2002-02-20 Two architectures for integrated realization of sensing and processing in a single device

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US12317799P 1999-03-05 1999-03-05
US60/123,177 1999-03-05

Publications (2)

Publication Number Publication Date
WO2000052639A2 true WO2000052639A2 (en) 2000-09-08
WO2000052639A3 WO2000052639A3 (en) 2001-02-15

Family

ID=22407147

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/US2000/005785 WO2000052639A2 (en) 1999-03-05 2000-03-06 Two architectures for integrated realization of sensing and processing in a single device

Country Status (7)

Country Link
EP (1) EP1175659A2 (en)
JP (1) JP2002538557A (en)
CN (1) CN1457471A (en)
AU (1) AU3616700A (en)
CA (1) CA2364182A1 (en)
HK (1) HK1039992A1 (en)
WO (1) WO2000052639A2 (en)

Cited By (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6614911B1 (en) 1999-11-19 2003-09-02 Gentex Corporation Microphone assembly having a windscreen of high acoustic resistivity and/or hydrophobic material
WO2004042822A1 (en) * 2002-11-04 2004-05-21 Innovaciones Microelectronicas, S.L. Programmable mixed-signal integrated circuit architecture for the production of autonomous vision systems in a single chip and/or pre-processing of images in higher-level systems
US7120261B1 (en) 1999-11-19 2006-10-10 Gentex Corporation Vehicle accessory microphone

Families Citing this family (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6278377B1 (en) 1999-08-25 2001-08-21 Donnelly Corporation Indicator for vehicle accessory
US10346944B2 (en) * 2017-04-09 2019-07-09 Intel Corporation Machine learning sparse computation mechanism
CN111368253B (en) * 2018-12-26 2023-09-26 兆易创新科技集团股份有限公司 Convolution operation method and device based on nonvolatile memory
CN111539178B (en) * 2020-04-26 2023-05-05 成都市深思创芯科技有限公司 Chip layout design method and system based on neural network and manufacturing method
CN111983629B (en) * 2020-08-14 2024-03-26 西安应用光学研究所 Linear array signal target extraction device and extraction method

Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5140670A (en) * 1989-10-05 1992-08-18 Regents Of The University Of California Cellular neural network
US5355528A (en) * 1992-10-13 1994-10-11 The Regents Of The University Of California Reprogrammable CNN and supercomputer

Patent Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5140670A (en) * 1989-10-05 1992-08-18 Regents Of The University Of California Cellular neural network
US5355528A (en) * 1992-10-13 1994-10-11 The Regents Of The University Of California Reprogrammable CNN and supercomputer

Non-Patent Citations (2)

* Cited by examiner, † Cited by third party
Title
ERTEN G ET AL: "Modified cellular neural network architecture for integrated image sensing and processing" ISCAS'99. PROCEEDINGS OF THE 1999 IEEE INTERNATIONAL SYMPOSIUM ON CIRCUITS AND SYSTEMS VLSI (CAT. NO.99CH36349), ISCAS'99. PROCEEDINGS OF THE 1999 IEEE INTERNATIONAL SYMPOSIUM ON CIRCUITS AND SYSTEMS. VLSI, ORLANDO, FL, USA, 30 MAY-2 JUNE 1999, pages 120-123 vol.5, XP002149482 1999, Piscataway, NJ, USA, IEEE, USA ISBN: 0-7803-5471-0 *
ERTEN G ET AL: "Two cellular architectures for integrated image sensing and processing on a single chip" JOURNAL OF CIRCUITS, SYSTEMS AND COMPUTERS, OCT.-DEC. 1998, WORLD SCIENTIFIC, SINGAPORE, vol. 8, no. 5-6, pages 637-659, XP000952076 ISSN: 0218-1266 *

Cited By (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6614911B1 (en) 1999-11-19 2003-09-02 Gentex Corporation Microphone assembly having a windscreen of high acoustic resistivity and/or hydrophobic material
US7120261B1 (en) 1999-11-19 2006-10-10 Gentex Corporation Vehicle accessory microphone
US7130431B2 (en) 1999-11-19 2006-10-31 Gentex Corporation Vehicle accessory microphone
US7136494B2 (en) 1999-11-19 2006-11-14 Gentex Corporation Vehicle accessory microphone assembly having a windscreen with hydrophobic properties
US7443988B2 (en) 1999-11-19 2008-10-28 Gentex Corporation Vehicle accessory microphone
US8224012B2 (en) 1999-11-19 2012-07-17 Gentex Corporation Vehicle accessory microphone
WO2004042822A1 (en) * 2002-11-04 2004-05-21 Innovaciones Microelectronicas, S.L. Programmable mixed-signal integrated circuit architecture for the production of autonomous vision systems in a single chip and/or pre-processing of images in higher-level systems
ES2209642A1 (en) * 2002-11-04 2004-06-16 Innovaciones Microelectronicas, S.L. Programmable mixed-signal integrated circuit architecture for the production of autonomous vision systems in a single chip and/or pre-processing of images in higher-level systems

Also Published As

Publication number Publication date
EP1175659A2 (en) 2002-01-30
HK1039992A1 (en) 2002-05-17
JP2002538557A (en) 2002-11-12
CA2364182A1 (en) 2000-09-08
CN1457471A (en) 2003-11-19
WO2000052639A3 (en) 2001-02-15
AU3616700A (en) 2000-09-21

Similar Documents

Publication Publication Date Title
Moini Vision chips or seeing silicon
Suarez et al. CMOS-3D smart imager architectures for feature detection
Andreou et al. Analog VLSI neuromorphic image acquisition and pre-processing systems
Roska et al. Toward visual microprocessors
US6768515B1 (en) Two architectures for integrated realization of sensing and processing in a single device
WO2000052639A2 (en) Two architectures for integrated realization of sensing and processing in a single device
Higuchi et al. Evolvable hardware chips for industrial applications
Fakhraie et al. VLSI—Compatible Implementations for Artificial Neural Networks
US6735482B1 (en) Integrated sensing and processing
Andreou et al. A 590,000 transistor 48,000 pixel, contrast sensitive, edge enhancing, CMOS imager-silicon retina
US5305250A (en) Analog continuous-time MOS vector multiplier circuit and a programmable MOS realization for feedback neural networks
Dogaru et al. The simplicial neural cell and its mixed-signal circuit implementation: an efficient neural-network architecture for intelligent signal processing in portable multimedia applications
Laiho et al. MIPA4k: Mixed-mode cellular processor array
Lange et al. Optical neural chips
Ruckert ULSI architectures for artificial neural networks
Lee et al. VLSI image processor using analog programmable synapses and neurons
US20040037464A1 (en) Unconstrained handwriting recognition
Vittoz Present and future industrial applications of bio-inspired VLSI systems
Bridges et al. A reconfigurable VLSI learning array
Porter et al. Optimizing digital hardware perceptrons for multi-spectral image classification
Hasler et al. High fill-factor imagers for neuromorphic processing enabled by floating-gate circuits
Erten et al. Modified cellular neural network architecture for integrated image sensing and processing
Chang et al. Compact mixed-signal convolutional neural network using a single modular neuron
Van der Spiegel et al. Biologically inspired vision sensors
Zavidovique et al. Generic functions for on-chip vision

Legal Events

Date Code Title Description
WWE Wipo information: entry into national phase

Ref document number: 00807117.9

Country of ref document: CN

AK Designated states

Kind code of ref document: A2

Designated state(s): AE AL AM AT AU AZ BA BB BG BR BY CA CH CN CR CU CZ DE DK DM EE ES FI GB GD GE GH GM HR HU ID IL IN IS JP KE KG KP KR KZ LC LK LR LS LT LU LV MA MD MG MK MN MW MX NO NZ PL PT RO RU SD SE SG SI SK SL TJ TM TR TT TZ UA UG US UZ VN YU ZA ZW

AL Designated countries for regional patents

Kind code of ref document: A2

Designated state(s): GH GM KE LS MW SD SL SZ TZ UG ZW AM AZ BY KG KZ MD RU TJ TM AT BE CH CY DE DK ES FI FR GB GR IE IT LU MC NL PT SE BF BJ CF CG CI CM GA GN GW ML MR NE SN TD TG

121 Ep: the epo has been informed by wipo that ep was designated in this application
DFPE Request for preliminary examination filed prior to expiration of 19th month from priority date (pct application filed before 20040101)
AK Designated states

Kind code of ref document: A3

Designated state(s): AE AL AM AT AU AZ BA BB BG BR BY CA CH CN CR CU CZ DE DK DM EE ES FI GB GD GE GH GM HR HU ID IL IN IS JP KE KG KP KR KZ LC LK LR LS LT LU LV MA MD MG MK MN MW MX NO NZ PL PT RO RU SD SE SG SI SK SL TJ TM TR TT TZ UA UG US UZ VN YU ZA ZW

AL Designated countries for regional patents

Kind code of ref document: A3

Designated state(s): GH GM KE LS MW SD SL SZ TZ UG ZW AM AZ BY KG KZ MD RU TJ TM AT BE CH CY DE DK ES FI FR GB GR IE IT LU MC NL PT SE BF BJ CF CG CI CM GA GN GW ML MR NE SN TD TG

ENP Entry into the national phase

Ref document number: 2364182

Country of ref document: CA

Ref document number: 2364182

Country of ref document: CA

Kind code of ref document: A

WWE Wipo information: entry into national phase

Ref document number: 36167/00

Country of ref document: AU

WWE Wipo information: entry into national phase

Ref document number: 09914030

Country of ref document: US

ENP Entry into the national phase

Ref document number: 2000 602988

Country of ref document: JP

Kind code of ref document: A

WWE Wipo information: entry into national phase

Ref document number: 2000914830

Country of ref document: EP

REG Reference to national code

Ref country code: DE

Ref legal event code: 8642

WWP Wipo information: published in national office

Ref document number: 2000914830

Country of ref document: EP

WWW Wipo information: withdrawn in national office

Ref document number: 2000914830

Country of ref document: EP