Login| Sign Up| Help| Contact|

Patent Searching and Data


Title:
PROGRAMMABLE METHODS OF PERFORMING COMPLEX OPTICAL COMPUTATIONS USING DATA PROCESSING SYSTEM
Document Type and Number:
WIPO Patent Application WO/1986/005608
Kind Code:
A1
Abstract:
Methods of performing complex optical computations, preferably using a programmable optical data processor. The performance of optical computations is accomplished using a plurality of spatial light modulators to impress data onto a data beam, the method of performing the computations comprising the steps of: (a) applying data to a subset of the modulators so as to impress a corresponding data image onto the beam; and (b) applying uniform data to the remaining ones of the modulators so as to impress corresponding uniform data images onto the beam such that the computation performed is dependent on the data applied to the subset of the modulators.

Inventors:
GRINBERG JAN (US)
NUDD GRAHAM R (GB)
SOFFER BERNARD H (US)
Application Number:
PCT/US1985/002396
Publication Date:
September 25, 1986
Filing Date:
December 05, 1985
Export Citation:
Click for automatic bibliography generation   Help
Assignee:
HUGHES AIRCRAFT CO (US)
International Classes:
G02F3/00; G02F1/03; G06E3/00; (IPC1-7): G06G9/00
Foreign References:
US3989355A1976-11-02
DE3121436A11982-04-08
DE3218244A11983-11-17
Other References:
Applied Optics, Volume 23, No. 6, March 1984, New York, (US) VERBER et al.: "Pipelined Polynomial Processors Implemented with Integrated Optical Components", see figure 6; page 819, left-hand column, line 14 - page 820, left-hand column, line 35
PATENTS ABSTRACTS OF JAPAN, Volume 7, No. 51 (P-179) (1196), 26 February 1983 & JP, A, 57 198 434 (Yokogawa) 6 December 1982
Download PDF:
Claims:
CLAIMS
1. What is Claimed is: A method of performing optical computations using a plurality of spatial light modulators to impress images corresponding to data onto a data beam, said method comprising the steps of: a) applying respective data to a subset of said modulators to impress corresponding data images onto said beam; and b) applying uniform data to the remaining ones of said modulators so as to impress corresponding uniform data images onto said beam such that the computation performed is dependent on the data applied to the subset of said modulators.
2. The method of Claim 1 further comprising the steps of: a) sequentially providing data to be applied to a first one of said subset of said modulators; b) sequentially providing data to be applied to a second one of said subset of said modulators; and c) continuously providing uniform data to be applied to a third one of said modulators.
3. The method of Claim 2 wherein said modulators spatially represent the data applied thereto, wherein an accumulator is used to sum the spatially represented data as impressed onto said beam and wherein said modulators include one and twodimensional spatial light modulators for selectively impressing data images onto said beam as rows and columns oriented mutually orthogonal to said beam, said method further comprising the steps of: a) sequentially shifting the data summed into said accumulator with respect to the rows of said modulators; and b) summing the data spatially represented on said beam with the corresponding shifted spatially summed data of said accumulator.
4. The method of Claim 3 further comprising the step recirculating the data provided to selected ones of said subset of said modulators so as to periodically reapply the data to the selected ones of said modulators.
5. A method of performing an optical computation using an optical processor capable of impressing a. plurality of data images onto a data beam using spatial light modulators, including crossed onedimensional spatial light modulators, said method comprising the steps of: a) sequentially providing first data to a first onedimensional spatial light modulator so as to impress a first data image onto said beam; b) sequentially providing second data to a second onedimensional spatial light modulator so as to impress a second data image onto said beam; and c) spatially summing the data represented by the combination of said first and second data images on said data beam with a sequential provision of said first and second data.
6. The method of Claim 5 further comprising the step of respectively shifting the spatially summed data with a sequential provision of said first and second data.
7. The method of Claim 6 wherein said step of respectively shifting the spatially summed data is further characterized as occurring with each sequential provision of said first and second data.
8. The method of Claim 5, 6 or 7 further comprising the step of providing uniform data to any unused ones of said spatial light modulators of said optical processor so as to correspondingly impress uniform data images onto said beam.
9. The method of Claim 6 wherein said optical processor further includes a twodimensional spatial light modulator, said method further comprising the step of providing third data to said twodimensional modulator so as to impress a third data image onto said beam.
10. The method of Claim 9 wherein said two dimensional spatial light modulator is characterized as impressing said third data onto said beam as data image rows and columns thereof and wherein the step of providing said third data further includes the step of shifting said third data along the rows of said two dimensional spatial light modulator with each sequential provision of said first and second data.
11. The method of Claim 10 wherein the step of providing said third data further includes the step of recirculating that portion of said third data effectively shifted from the last row of said twodimensional spatial light modulator so as to provide that portion of said third data to the first row of said two dimensional spatial light modulator.
12. The method of Claim 10 or 11 further comprising the step of providing uniform data to any unused ones of said spatial light modulators so as to correspondingly impress uniform data images onto said data beam.
13. A method of performing a twodimensional Fourier transform of twodimensional data on a data beam using a plurality of spatial light modulators and a spatial accumulator, said method comprising the steps of: a) buffering the Fourier transform coefficient matrix for the first data dimension; b) buffering the twodimensional data matrix to be transformed; c) applying the last matrix column buffered coefficients to the respective rows of a first one dimensional spatial light modulator; d) applying the last matrix row of the buffered data to be transferred to the respective columns of a second onedimensional spatial light modulator; e) providing uniform data to all remaining ones of said spatial light modulators; f) summing into the accumulator the products of the intersecting data provided on said first and second onedimensional spatial light modulator as effectively impressed on, combined, and received from said data beam; g) respectively recirculating said two dimensional data matrix and said coefficient matrix so as to provide new last columns and rows of respective coefficients and data to be applied to said first and second onedimensional spatial light modulators; h) repeating steps c) through g) for each row of the twodimensional data; i) buffering the summed first data dimension resultant data from said accumulator in place of the original twodimensional data; j) buffering the Fourier transform coefficient matrix for the second data dimensional in place of that for the first data dimension; and k) repeating steps c) through g) for each row of the summed first data dimension resultant data, modulators.
14. A method of performing a twodimension cross correlation of twodimensional data on a data beam using a plurality of spatial light modulators and a spatial accumulator, said method comprising the steps of: a) buffering the twodimensional correlation mask data matrix; b) buffering the twodimensional data matrix to be correlated; c) applying the buffered mask data matrix to the corresponding spatial positions of a twodimensional spatial light modulator; d) applying a datum of the data matrix to be correlated, obtained from a predetermined row and column buffer position, to a zerodimensional spatial light modulator; e) providing uniform data to all remaining ones of said spatial light modulators; f) summing into said accumulator the products of the intersecting correlation mask data matrix and said datum of the data matrix to be correlated, as provided to said two and said zerodimensional spatial light modulators, respectively, to produce thereby cumulative twodimensional resultant data; g) recirculating said buffered twodimensional data matrix to be correlated in a first data matrix direction so as to provide a new datum at said predetermined row and column buffer position; h) recirculating said cumulative two dimensional resultant data similarly in said first data matrix direction; i) repeating steps c) through h) for each row or column in said first data matrix direction of the twodimensional data matrix to be correlated; j) recirculating said buffered twodimensional data to be correlated in a second data dimension so as to provide a new datum at said predetermined row and column buffer position; k) recirculating said cumulative two dimensional resultant data similarly in said second data matrix dimension; and repeating steps i) through k) for each row or column in said second data matrix direction of said twodimensional data matrix to be correlated.
15. A method of performing a onedimensional, sliding window cross ambiguity function calculation for onedimensional data on a data beam using a plurality of spatial light modulators and a spatial accumulator, comprising the steps of: a) buffering a twodimensional Fourier transform coefficient mask data matrix; b) row buffering a onedimensional reference data template; c) row buffering an initial portion of a one dimensional input data stream; d) applying the respective last matrix column buffered coefficients to respective rowsof a first one dimensional spatial light modulator; e) applying the respective buffered row reference template data to the corresponding columns of a second onedimensional spatial light modulator; f) applying to the respective columns of a third onedimensional spatial light modulator, corresponding datum from a contiguous portion of said input data stream; g) providing uniform data to all remaining ones of said spatial light modulators; h) summing into said accumulator the products of the intersecting coefficient mask matrix data, said row reference template data, and said contiguous portion of said input data stream as provided to said first, second, and third onedimensional spatial light modulators, respectively, to produce thereby cumulative twodimensional resultant data matrix; i) sequentially shifting the next input data stream datum into said buffered portion so as to shift the application of said contiguous portion of said input stream in a predetermined row data shift direction; j) recirculating said buffered coefficient mask data matrix in said predetermined row shift data direction so as to provide the next sequential column of coefficient matrix to be applied to said first one dimensional spatial light modulator; k) shifting said cumulative twodimensional resultant data matrix in said predetermined row data shift direction and clearing the first matrix column of the resultant data matrix corresponding to the column of said third onedimensional spatial light modulator to which the next input data stream datum is applied; and repeating steps d) through k) and sequentially buffering the last matrix column data of said twodimensional resultant data matrix shifted out during step k) to form a twodimensional most recent sliding window crossambiguity resultant data matrix.
Description:
PROGRAMMABLE METHODS OF PERFORMING COMPLEX OPTICAL COMPUTATIONS USING DATA PROCESSING SYSTEM

FIELD OF THE INVENTION

The present invention generally relates to methods of operating optical computing and data processing systems and, in particular, to methods of operating a multistage lensless optical processor that is electrically programmable to perform a wide variety of complex computations on optical data.

BACKGROUND OF THE INVENTION Optical processing of vector and matrix data is known for its potential high effective computational performance capabilities and its natural adaptability to computationally intensive image processing. Images, or other spatially relatable data, may be treated as matrices composed of rastor or vector scans of data elements that, at their real or effective resolution limit, are generally referred to as pixels. An ordinary image is typified by an analog picture frame taken as a cross section of an optical beam formed of a continuous series of such images. Each analog image frame typically contains an effectively continuous spatially distributed array of pixel data. Alternately, discrete matrix data may be impressed onto a data beam by spatially modulating the cross section of a data beam in terms of, for example, either its localized intensity or polarization vector.

In any case, optical processing is of great potential value due to its fundamentally parallel processing nature. The parallelism, of course, arises due to the processing of complete images at a time. As 5 each pixel is a separate datum, the volume of data processed in parallel is generally equivalent to the effective resolution of the image. Additionally, optical processing has the virtue of processing data in the same format that it is conventionally obtained.

10 Typically, and for such applications as image enhancement and recognition, the data to be processed is generally obtained as a single image or as a rastor scan of an image frame. Potentially then, an optical processor may receive data directly without conventional or other 5 intermediate processing. Since the informative value of image data increases with the effective resolution of the image and the number of images considered, the particular and unique attributes of optical processing become quite desirable.

2 Q Conventionally, optical processing is performed by projecting an image to be processed through a selected spatial mask onto an appropriate optical detector. The mask itself is, in its simplest form, only an image fixed in a film. Even as such, relatively complex

25 optical processing computations may be performed.

Optical processor projection systems, however, generally require a variety of highly specialized components including arc lamps as illuminating point sources, collimating and focusing lenses, polarizing . and polarization rotation plates, beam splitters, and mirrors. In addition to their respective fabrication complexities, these components must be assembled and maintained, often in critical alignment, spatially separated from one another. Consequently, the optical

-_ processing apparatus is large and bulky, sensitive to

its environment, particularly in terms of vibration and contamination, and specifically limited to performing one or only a few quite closely related optical processing calculations. In addition to photographic films, a temporally variable mask for optical processors has been realized as a two-dimensional spatial light modulator (SLM) that, through electronic activation, effects selective alteration of the spatially distributed data impressed on a data beam by the mask. A typical two-dimensional (2D) SLM is realized through the use of a photo- electrically activated reflective type liquid crystal light valve which may be coupled to a cathode ray tube. Aside from the inefficiency of the dual serial electric- to-optical conversion of the image, such 2D SLM devices perform well for many applications within specific limits. Unfortunately, these performance limits include a relatively slow liquid crystal light valve response time of typically greater than 10 milliseconds. This naturally directly impacts the high speed processing capability of an optical processor. Additionally, the use of this type of mask requires further focusing, beam splitting and support components with the end result being a mechanically complex optical processor. Two-dimensional SLM masks have also been realized in the form of a solid electro-optical element activated by a two-dimensional spatially distributed array of electrodes. The modulating image is effectively formed by separately establishing the voltage potential of each of the electrodes at an analog corresponding to their respective intended data values. As may be well expected, the complexity level of such a two-dimensional SLM increases proportionally to the square of its pixel resolution (N). Complexity further increases where the N-2 electrodes must be independently addressable to

permit operation at data rates sufficiently high to be of utility in optical data processing (for instance, for N = 1000, one has to address 1 million electrodes). The current level of fabrication technology, unfortu- nately, stands as a practical barrier to the reproducible fabrication of even moderately high resolution independent pixel addressable two-dimensional SLM devices. Alter¬ nately using a low effective resolution mask would directly impact the high speed data processing capabi- lities of the optical processor.

In view of the foregoing limitations of conventional optical data processing apparatus, the methods of performing optical computations have been correspondingly constrained. Intermediate results of a computation must be stored or otherwise fixed in a medium while the processing apparatus is modified or adjusted to perform most any significantly different computational stop or utilize a different spatial mask in the computation.

SUMMARY OF THE INVENTION

A purpose for the present invention is, therefore, to provide methods of continuously, iteratively operating an optical data processor to perform a wide variety of complex data processing functions while avoiding or overcoming most, if not all, of the processing limitations incurred in the prior art.

This is attained in the present invention by providing for the performance of optical computations using a plurality of spatial light modulators to impress data onto a data beam, the methods of performing the computations comprising the steps of: (a) applying respective data to a subset of the modulators so as to impress corresponding data images onto the beam; and (b) applying uniform data to the remaining ones of the

modulators so as to impress corresponding uniform data onto the beam such that the computation performed is dependent on the data applied to the subset of the modulators.

The methods of the present invention are preferably performed using an apparatus comprising a plurality of modulators for spatially modulating the optical data beam, means for the lensless interconnection of each of the modulators to provide for the focusless transfer of the optical data beam between the modulators, and means for controlling the plurality of modulators so as to permit the programmable processing of the optical data beam.

Thus, an advantage of the present invention is ς that it can be utilized to perform a wide variety of optical data processing computations. -

Another advantage of the present invention is that it permits the continuously iterative processing of temporally changing optical data. Q A further advantage of the present invention is that it effectively provides for the dynamic modification and reconfiguration of the processing apparatus by data programming.

Still another advantage of the present invention 5 is that it is readily adaptable to the performance of any desired optical computation.

Yet another advantage of the present invention is that it can conveniently implement such computationally intensive optical data processing functions as multi¬ 0 dimensional Fourier transform, cross correlation, and sliding window cross-ambiguity functions for example.

BRIEF DESCRIPTION OF THE DRAWINGS

Other attendant advantages of the present invention will become apparant and readily appreciated as the same becomes better understood by reference to the following detailed description when considered in connection with the accompanying drawings in which like reference numerals designate like parts throughout the figures, and wherein:

FIG. 1 is a perspective block diagram of a preferred optical data processing system in accordance with the present invention;

FIG. 2 is a side view of a preferred generic embodiment of an optical data processor constructed for use in accordance with the present invention; FIG. 3 is a perspective detail of an electro- optical spatial light modulator.

FIG. 4 is a perspective view of another electro-optical spatial light modulator; and

FIG. 5 is an exploded perspective representation of a preferred embodiment of an optical processor for illustrating the preferred methods of operation in accordance with the present invention.

DETAILED DESCRIPTION OF THE INVENTION The preferred system embodiment for use with the present invention, generally indicated by the reference numeral 10, is shown in FIG. 1. In particular, the preferred multistage optical data processor (ODP), generally indicated by the reference numeral 20, is operatively supported by the microcontroller 12 and interface registers 18, 22, 24, 26, 30, 32 and 34. While the preferred structure of the ODP 20 will be described in greater detail below, the principle operative

components of the ODP 20 are shown in FIG. 1 as including a flat panel light source 14, matrix array accumulator 16 and a plurality of spatial light modulators (SLMs) 36, 38, 40, 42, 44 and 46. Preferably, the light source 14, accumulator 16 and the SLMs 36, 38, 40, 42, 44, 46 are provided in closely adjacent parallel planes with respect to one another such that a relatively uniform beam sourced by the light source 14 travels through each of the spatial light modulators in succession and is ultimately received by the accumulator 16. The light beam is effectively used as a data transport mechanism acquiring data provided by each of the spatial light modulators that is subsequently delivered to the accumulator 16. The operation of each of the spatial light modulators can be explained in terms of their spatial transmissivity variation with respect to corresponding spatially distributed activating voltage potentials. To a first approximation at least, the transmissivity of a spatial light modulator is directly proportional to the applied voltage potential. Thus, the combined transmissivity (TQ) of two serially coupled spatial light modulators is proportional to the product of the respective transmissivities of the spatial light modulators. The combined transmissivity T Q can thus be written as:

To = o β Vi V 2 (2)

where Vi and V2 are the respectively applied voltage potentials, and α and β are the transmissivity to applied voltage coefficients for the respective spatial light modulators. Where an extended series of spatial light modulators are serially coupled, in accordance with the present invention, the combined transmissivity

To of the multistage spatial light modulator stack is proportional to the product of the respective transmis- sivities of the individual spatial light modulators. A light beam sourced by the flat panel 14 can thus be directed to acquire spatially distributed data corres¬ ponding to the spatially distributed relative transmis- sivities of each of the spatial light modulators 36, 38, 40, 42, 44 and 46.

In accordance with the preferred embodiment of the optical processor used in accordance with the present invention, spatially relatable data is provided to the spatial light modulators 36, 38, 4*0, 42, 44 and 46 via the interface registers 22, 24, 26, 30, 32 and 34. These registers preferably operate as high speed digital data storage registers, buffers and digital-to- analog data converters. As will be discussed in greater detail below, the stack of spatial light modulators preferably includes a plurality of one-dimensional spatial light modulators and one or more two-dimensional spatial light modulators. As shown in FIG. 1, one- dimensional spatial light modulators 36, 38, 40, 42 and 44 are coupled to respective registers 22, 30, 24, 32 and 26 via interface data lines 60, 78, 62, 80 and 64. A two-dimensional spatial light modulator 46 receives data from register 34 via the interface data line 82.

The interface registers 22, 24, 26, 30, 32 and 34 in turn preferably receive data in a parallel form provided by external sensors. The microcontroller 12 via the processor control buses 50, 70 provides the control signals. While the processor control buses 50, 70 are shown as separate and respectively connected to the registers by the register control lines 52, 54, 56, 72, 74 and 76, the interface registers may alternately be

coupled via control multiplexers to a single, common control bus driven by the microcontroller 12. In either case, however, it is essential only that the micro¬ controller 12 possess sufficient control over the registers 22, 24, 26, 30, 32 and 34 to selectively provide its predetermined data thereto.

The optical data processor system 10 is completed with the provision of the output register 18 coupled between the accumulator 16 and the processor output. The accumulator 16 itself is a matrix array photosensitive device capable of converting incident light intensity into a corresponding voltage potential representative of the data beam at an array resolution at least matching that of the spatial light modulators 36, 38, 40, 42, 44 and 46. As will be described in greater detail below, the accumulator 16 accumulates light beam data that can then be shifted by means of a clock signal supplied by a clock generator 83 to the data output register 18 via the output interface bus 88. The accumulator 16 also includes circular shift bus 86 and lateral shift bus 84 to permit a wide variety of shift and sum operations to be performed within the accumulator 16 during the operation of the optical data processor 20.

The data output register 18 is preferably a high speed analog-to-digital converter, shift register and buffer that channels the shifted output data from the accumulator 16 to the processor output via the processor data output bus 90.

As should be well apparent from the foregoing, the microcontroller 12 possesses full control over the optical data processor 20. Any desired data can be provided to any specific combination of spatial light modulators to implement a desired data processing algorithm. Of particular facility is that only those spatial light modulators required for the performance

of any particular optical data processing algorithm need be actively utilized in the optical data processor 20 in accordance with the present invention. Spatial light modulators within the optical data processor 20 may be provided with appropriate data via their respective data registers to uniformly maintain the spatial light modulators at their maximum transmissivity. Consequently, selected spatial light modulators may be effectively removed from the optical data processor by their 0 appropriate data programming. Thus, the optical data processing system 10 provides an extremely flexible environment for the performance of optical data processing computations.

- The structure of an exemplary optical data processor 5 20 fabricated in accordance with the preferred optical processor embodiment of the present invention is shown in FIG. 2. The embodiment shown is exemplary as including substantially all of the principle components that may be incorporated into any preferred embodiment of the o optical processor.

The components of the optical data processor may be functionally grouped as parts of a light source 91, SLM stage 92 and data beam receiver 93. The light source 91 essentially includes the flat panel light 5 source 14 and, optionally, a light beam buffer component 94. The flat panel light source 14 is preferably an electroluminescent display panel or, alternately, a gas plasma display panel or LED or LED array or laser diode or laser diode array. The buffer component 94 is 0 preferably utilized to grade the light produced by the flat panel display panel into a spatially uniform optical beam. Where a gas plasma display is utilized, the buffer component 94 may further function to insulate the remainder of the optical data processor 20 from any 5 heat generated by the plasma display 14. In either

case, the buffer component 94 is preferably an optical glass plate having a thickness of approximately 0.25 inch.

The bulk of the optical data processor 10 is formed by a serial stack of SLM stages, of which SLM stage 92 is representative. While each stage is preferably identical in terms of their component composition, the SLM of each is the only essential component. Preferably, the SLM is a rigid structure requiring no additional support. In such embodiments, the SLMs may be placed immediately adjacent one another, separated only by a thin insulating optically transparent layer, yielding an optimally compact multistage stack of spatial light modulators. However, where the spatial. light modulators are, for example, of a material possessing insufficient structural strength to provide for their own support, the stage 92 preferably further includes a supporting fiber optic plate 102. The fibers of the fiber optic plate 102 are, of course, aligned with their cylindrical axes parallel the major axis of the optical data processor 20. Also, in such embodiments utilizing a fiber optic plate 102 and where the significant operation of the spatial light modulator is accomplished through the polarization modulation of the light beam, a polarizer 64 is preferably interposed between the SLM 44 and fiber optic plate 102. The polarizer 64 further permits the utilization of an unpolarized optical data beam source 14 in local polarization vector data representation embodiments of the present invention. If the principle of operation of the spatial light modulation is light absorption (instead of polarization rotation), then there is no need for the polarizers.

The data beam receiver 93 essentially includes an accumulator component 16. The accumulator 16 is preferably a solid state matrix array of optical detectors. In particular, the optical detector array is preferably a two-dimensional shift register array of conventional charge coupled devices (CCDs) provided at an array density equivalent to the effective resolution of the optical data processor 20. The use of a CCD array is preferred both for its charge accumulation, i.e., data summing, capability as well as for the ease of fabricating CCD shift register circuitry that can be directly controlled by the microcontroller 12. Further, the use of the CCD array permits substantial flexibility in the operation of the accumulator 16 by permitting data shifted out of the accumulator 16 and onto the data return bus 88 to be cycled back into the accumulator 16 via the circular shift data bus 86. Additionally, the accumulator 16 possesses the desirable flexibility through the use of adjacent register propagation path interconnections to permit lateral cycling of the data contained therein via the lateral shift data bus 84 generally as indicated in FIG. 1. Consequently, the accumulator 16 can be effectively utilized in the execution of quite complex optical data processing algorithms involving shift and sum operations under the direct control of the microcontroller 12.

The data beam receiver 93 may optionally include a fiber optic plate 122 as may be desirable in interconnecting the accumulator 16 with the SLM 44 of the last stage 92 of the optical data processor 20.

The preferred embodiments of the two one-dimensional spatial light modulators are shown in FIGS. 3 and 4. The spatial light modulator 130 shown in FIG. 3 includes an electro-optic element 132 preferably having two major parallel opposing surfaces upon which stripe

electrodes 136 and potential reference plane 140 are provided respectively. The electro-optic element 132 may be a transmission mode liquid crystal light valve though preferably it is a solid state electro-optic material, such as KD2PO4 or BaTiθ3. This latter material polarization modulates light locally in propor¬ tion to the longitudinal and transverse voltage pOtential applied across that portion of the material that the light passes through. This material characteristically possesses sufficient structural strength to be adequately self-supporting for purposes of the present invention when utilized as electro-optic elements 132 provided at a thickness of approximately 5 to 10 mil for a major surface area of approximately one square inch. As the active regions of the electro-optic element 132 necessarily lay between each of the stripe electrodes 136 and the reference plane electrode 140, the electrodes 136, 140 are preferably of a highly conductive transparent material such as indium tin oxide. Contact to the electrodes 136, 140 is preferably accomplished through the use of separate electrode leads 134, 138, respec¬ tively, that are attached using conventional wire bonding or solder bump interconnect technology.

A variation of the spatial light modulator 130 provides a zero dimensional, or uniform, spatial light modulator that is of particular utility in the present invention. By commonly connecting the stripe electrode leads 134, the transmissivity of the electro-optic material 132 will be uniformly modulated at all pixel locations. Alternately, a single electrode covering the entire major surface of the electro-optic material 132 may be substituted for the stripe electrodes 136.

FIG. 4 illustrates an alternate one-dimensional spatial light modulator. This spatial light modulator significantly differs from that of FIG. 3 by the relative placement of the signal 156 and potential reference 158 electrodes on the two major surfaces of the electro- optic element 152. On each major surface, a reference potential electrode 158 is interposed between pairs of the signal electrodes 156 to form an interdigitated electrode structure that is essentially identical on 0 both major surfaces of the electro-optic element 152. The active portions of the electro-optic element 152 lie between each of the signal electrodes 156 and their surface neighboring reference potential electrodes 158. . Thus, the achievable electro-optic effect is 5 enhanced through the utilization of both surfaces of the electro-optic element 152. Further, as the active portions of the electro-optic element 152 are not shadowed by the signal electrodes 156, all of the electrodes 156, 168 may be of an opaque conductive o material, such as aluminum, that may be further advantageously utilized to effectively mask the active regions of the electro-optic element 152. That is, the electrodes 156, 158 may be utilized to block the respective pixel edge portions of the data beam as 5 they diverge while passing through the electro-optic element 152.

Similar to the spatial light modulators 130 of FIG. 3, the electro-optic element 152 may be either a liquid crystal light valve or a solid state electro- 0 optic material. For reasons of faster electro-optic response time, greater structural strength, and ease of fabrication, transverse field polarization modulation electro-optic materials, such as represented by Li bθ3, LiTaθ3, BaTiθ3, Sr x Ba(ι_ x ) bθ3 and PLZT are preferred. 5

These materials are believed to possess the generally equivalent structural strength characteristics as the polarization modulation material KD2 O4 described above. Electrode leads to the electrode strips 156, 158 are again preferably attached using conventional wire bonding or solder bump interconnect technology.

The versatility of the present invention in providing for the performance of a wide variety of complex data processing functions, as embodied in unique optical processing algorithms, is best illustrated with reference to FIG. 5. In order to facilitate the description of the present invention, a preferred embodi¬ ment of the optical data processor 20 is functionally illustrated as a series of planes A, B, C, D, E and F, each plane parallel to the X and Y axis and distributed along the Z axis of the coordinate system 200. For the sake of simplicity of description, the optical data processor 20 is shown as having an effective resolution of three by three pixels. As illustrated, planes A, B and C contain registers 212, 214, 218 interconnected by buses 234, 236, 238 to one-dimensional spatial light modulators 202, 204, 206 and to the microcontroller 12 by buses 222, 224, 226, respectively. The registers 212, 214, 216 each preferably includes a three by three pixel buffer array. The A and B plane one-dimensional spatial light modulators 202, 204 provide for the modulation of three pixel rows (parallel to the X axis) . The spatial light modulator 206 of plane C is distinguished as providing for the modulation of three pixel columns (parallel to the Y axis).

A two-dimensional spatial light modulator 208 driven by register 218 via bus 240 is provided in plane D with both being interconnected with the microcontroller 12 by the bus 230. Since, as will be demonstrated below, the operation of the two-dimensional spatial light modulator is effectively static with respect to the other planes of the optical data processor, the necessity of high speed independent addressing of the array electrodes is substantially obviated. Rather, simpler shift register mode propagation of data may be utilized in the operation of the two-dimensional spatial light modulator 208. Consequently, the construction constraints and complexity limitations in the reliable fabrication of high resolution matrix spatial light modulators are greatly eased for purposes of the present invention.

Plane E includes the three by three pixel register 220 that is interconnected with a uniform, zero- dimensional spatial light modulator 210 via the single pixel bus 242 and both with the microcontroller 12 via the bus 232.

Finally, a matrix array accumulator 14 is provided in plane F. As above, circular 86 and lateral 84 shift buses are provided to permit flexible sum and shifting operations to be performed under the control of the microcontroller 12.

The flexibility and versatility of the present invention is illustrated by its adaptation to perform the representative algorithms described below. Each algorithm functions to process data representable as an optical image. While the functions realized by the generation of the resultant optical images may be well known, their respective algorithmic performance is unique and particular to the present invention.

Function 1 :

A two-dimensional Fourier transform of two- dimensional data, appropriate for two-dimensional spectral analysis, is performed by: Initialize

1. load the two-dimensional data into the register 216 of plane C, apply the row 3 data to the respective columns of the SLM 206; 2. load the Fourier transform coefficients for the first dimension analysis into the register 212 of plane A, apply the column 3 data to the respective rows of the SLM 202;

3. load all other registers 214, 218, 220 of the optical data processor 20 with uniform data corresponding to maximum spatial light modulator 204, 208, 210 transmissivity;

4. clear the accumulator 14 of plane F;

Process

5. sum the current optical pixel products of the optical data beam with the corresponding previous pixel product sums;

6. column shift the data present in the register 212 by one column in a given (for example, right) direction, apply the new column 3 data to the respective rows of the SLM 202;

7. row shift the data present in the register 216 by one row in a given (for example, up) direction, apply the new row 3 data to the respective columns of the SLM 206;

8. repeat steps 5 through 7 for each row of the * two-dimensional data stored in register 216 of plane C;

18

9. transfer the matrix array data summed into the accumulator 14 of plane F into the register 216 of plane C, apply the row 3 data to the respective columns of SLM 206; 10. load the Fourier transform coefficients for the second dimension analysis into the register 212 of plane A, apply the column 3 data to the respective rows of the SLM 202; 11. repeat steps 5 through 7 for each row of the two-dimensional data stored in register 216 of plane C; and

Provide resultant image

.12. transfer the matrix array data summed into the accumulator 14 of plane F to the microcontroller 12.

Function 2:

A two-dimensional cross correlation of two- dimensional data, appropriate for image recognition, is performed by:

Initialize

1. load the two-dimensional data into the register 220 of plane E, apply the data from a given single pixel corresponding location (for example, 1,3) and apply to the uniform electrode of the SLM 210;

2. load the two-dimensional correlation mask data into the register 218 of plane D, apply the data to the respective pixel locations of the SLM 208;

3. load all other registers 212, 214, 216 with uniform data corresponding to maximum spatial light modulator 202, 204, 206 transmissivity; 4. clear the accumulator 14 of plane F;

Process

5. sum the current optical pixel products of the optical data beam with the corresponding previous pixel product sums; 6. column shift the data present in the register

220 by one column in a given direction (for example, right), apply the new data from the given single pixel corresponding location to the SLM 210; 7. column shift the sums present in the accumulator

14 by one column in the same direction as register 220 is shifted; 8. repeat steps 5 through 7 for each column of data stored in the register 220 of plane E; 9. row shift the data present in the register

220 by one row in a given direction (for example, up) , apply the new data from the given pixel corresponding location to the SLM

210; 10. row shift the sums present in the accumulator

14 by one row in the same direction as register

220 is shifted;

11. repeat steps 8 through 10 for each row of data stored in the register 220 of plane E; and

Provide resultant images

12. transfer the matrix array data summed into the accumulator 14 of plane F to the microcontroller 12.

Function 3 :

A one-dimensional sliding window cross ambiguity function calculation with respect to one-dimensional data is performed by: Initialize

1. load the real part of the Fourier transform coefficient matrix into the register 212 of plane A, apply the column 3 data to the respective rows of the SLM 202; 2. load each row of the register 216 of plane C with the i-dentical fixed length, one-dimensional reference data template, apply the row 3 data to the respective columns of the SLM 206;

3. load each row of the register 214 of plane B with an identical portion of the continuously running one-dimensi nal input data, apply the column 3 data to the respective rows of the SLM 204;

4. load all other registers 218, 220 of the optical data processor 20 with uniform data corresponding to maximum spatial light modulator 208, 210 transmissivity;

5. clear the accumulator 14 of plane F;

Process

6. sum the current optical pixel products of the optical data beam with the corresponding previous pixel product sums;

7. column shift the data present in the register 212 of plane A by one column toward column 3, apply the new data present in column 3 to the respective rows of the SLM 202, recirculate the column data shifted out of column 3 and store in column 1 of the register 212;

8. column shift the data present in the register 214 of plane B by one column toward column 3, load each pixel location of column 1 of register 214 with the next sequential input datura, apply the new data present in column 3 to the respective rows of the SLM 204; 9. column shift the sums present in the accumulator 14 by one column toward column 3, clear the pixel corresponding sums of column 1 of the accumulator 14, retain external to the optical data processor 20 the data shifted out of column 3 as to last column of the most recent sliding window cross-ambiguity function matrix calculated for the corresponding portion of the input data stream; and

10. repeat steps 6 through 9 for each datum taken from the input data stream as buffered through the register 214 of plane B updating the most recent sliding window across ambiguity function matrix with each column of data shifted out of the accumulator 14.

Each of the above algorithmic examples of the methods of the present invention progressively build on the particular aspects of the present invention as may be illustrated in their preceding examples. Accordingly, the present invention is readily extensible to the performance of other specific optical data processing computations. Thus, a method of performing complex optical data processing calculations that is adaptable to the performance of a wide variety of specific optical data processing functions has been described.

In view of the above teachings, persons of skill in the optical arts will readily appreciate that many modifications and variations of the method of the present invention are possible and contemplated. Accordingly, the present invention may be practiced other than as specifically described above without departing from the nature and scope of the present invention as set forth in the appended claims.