

## TMC2302A

# Image Manipulation Sequencer

### **Features**

- · Asynchronous loading of control parameters
- Rapid (25ns per pixel) rotation, warping, panning, and scaling of images
- Three-dimensional image addressing capability
- General third-order polynomial transformations in two dimensions on-chip
- Three-dimensional transformation of up to order 1.5 also supported
- Flexible, user-configurable pixel datapath timing structure
- Static convolutional filtering of up to 16 x 16 Pixel (one-pass), 256 x 256 pixel (two-pass) or 256 x 256 x 256 pixel (three-pass) windows
- User-selectable source image subpixel resolution of 2<sup>-8</sup> to 2<sup>-16</sup>
- Pin-compatible upgrade to TMC2302
- 24-bit (optional 36-bit) positioning precision within the source image space, 48-bit internal precision
- · Low power CMOS process
- Available in a 120-pin Plastic Pin Grid Array and 120-lead Metric Quad Flat Pack

### **Applications**

- · High-performance video special-effects generators
- · Guidance systems
- Image recognition
- Robotics
- · High-precision image registration

### Description

The TMC2302A, a pin-compatible replacement for the TMC2302, is a high-speed self-sequencing address generator which supports image manipulations such as rotation, rescaling, warping, filtering, and resampling. It remaps the pixel locations of a target (display) space back into those of a source image space. The degree and type of image manipulation is determined by the remapping selected.

To remap from the target to the source space, this integrated circuit computes a series of polynomials of the target space coordinates, based on user-assigned coefficients. Two TMC2302A chips can generate third-order warps of a two-dimensional image, whereas three can second-order warp a three-dimensional image.

## Simplified Block Diagram



### **Description** (continued)

A system based on two TMC2302As can nearest-neighbor resample a two-dimensional 512 x 512 pixel image in 6.5 milliseconds, translating, rotating, or warping it, depending on the user-selected transformation parameters. A complete bilinear interpolation of the sample image can be completed in 26 milliseconds (or 6.5ms with a TMC2246A companion chip), while a nearest-neighbor resampling of a 3D image 128 pixels on a side takes only 53 milliseconds with three TMC2302As. Image resampling speed is independent of angle of rotation, degree of warp, or amount of zoom specified.

The TMC2302A can process image data fields with up to 24 bits of binary resolution ( $2^{24}$  pixels) per dimension, with 0 to 16-bit subpixel resolution.

Along with the original Plastic Pin Grid Array (PPGA) package, the TMC2302A is offered in a 120-lead Metric Quad FlatPack (MQFP) as well. All TMC2302 electrical, functional, and environmental specifications are improved or remain unchanged in the TMC2302A.

## **Block Diagram**



### **Functional Description**

### **General Information**

The TMC2302A is a versatile, high-performance address generator which can control, under user direction, filtering or remapping of two or three-dimensional images by resampling them from one set of Cartesian coordinates (x, y, z) into a new, transformed set (u, v, w). Most applications utilize two identical devices for two-dimensional, or three devices for three-dimensional, image processing. The host CPU initializes the system by loading the input image buffer RAM with the source image pixel data and the TMC2302As with the image transformation and system configuration control parameters. These parameters are loaded by a separate, asynchronous input clock. The IMS-based system then executes the entire transformation as programmed, generating a DONE flag upon completion of the transform. The user can program the chip to repeat the transform continuously or to halt at the end.

The IMSs continuously compute the target bit plane (u, v) or bit space addresses (u, v, w) in typical line-by-line, raster-scan serial sequence. For each output pixel address, they compute the corresponding remapped source image coordinates, each of whose upper 24 bits become the source bit plane addresses (x, y). An additional lower twelve bits are available through the target address port in the optional extended address mode. Source image addresses may be generated at up to 40MHz, with the corresponding target image addresses then appearing at up to (40/k)MHz, where "k" is the size of the interpolation kernel implemented. In the two-IMS system, one TMC2302A computes the horizontal coordinates x and u while the other generates the y and v

(vertical) addresses. In a three-dimensional system, one additional IMS would provide the z and w (depth or time) coordinates.

To support a wide range of image transformations, the "row" or x/u device implements a 16-term polynomial of the form:

$$x = a + bu + cu^{2} + du^{3} + ev + fvu + gvu^{2} + hvu^{3} + iv^{2}$$
  
+  $iv^{2}u + kv^{2}u^{2} + lv^{2}u^{3} + mv^{3} + nv^{3}u + ov^{3}u^{2} + pv^{3}u^{3}$ 

where "a" through "p" are the user-defined image transformation parameters. The TMC2302A steps sequentially through the pixels within a user-defined rectangle in the target image space, computing the "old" source image address (x, y, z) corresponding to each "new" target image pixel (u, v, w). User-programmable flags are available to indicate when the source and target image addresses have fallen outside of a defined rectangular area, simplifying the generation of complex images or image windows. Here, u = U-UMIN and v = V-VMIN, where (u,v) is the target address output by the TMC2302A.

In the three-dimensional mode, the x/u transformation equation is:

$$x = a + bu + ev + kw + fuv + ivw + luw + juvw$$

See "The Image Transformation Polynomial" section of the Applications Discussion.



2. Bilinear pixel interpolation walk. New U, V pixel intensity calculated from surrounding X, Y pixel neigborhood.

Figure 1. Image resampling geometry showing two-dimensional image rotation and expansion

The TMC2302A utilizes an external multiplier-accumulator or interpolator, connected to the system clock, to calculate the interpolated pixel value for each color. The products of the original source image pixel values surrounding the remapped pixel location (interpolation kernel) and the appropriate weights stored in the coefficient lookup table are summed. The resulting new interpolated image pixel value is then stored in the corresponding (u, v, w) memory location in the target image memory buffer. Next, the target image address is incremented by one in the "u" direction until UMAX is reached (end of line), when u is reset to UMIN, and the v counter is incremented to give the first pixel location in the next line. The process is repeated, proceeding line-by-line through the image, until VMAX is reached. In the case of three-dimensional images, the IMS system also steps through each page in the image, incrementing in the "w" direction with the completion of each image plane until WMAX is reached, and the transformation is complete.

The Image Manipulation Sequencer can support any nearestneighbor, bilinear interpolation, or cubic convolution resampling. Interpolation kernels of more than one pixel require an external interpolation coefficient lookup table and multiplieraccumulator or multiple multiplier array. One, two, and three-pass algorithms are supported. For each output point in a typical two-dimensional single-pass static image filter, the TMC2302A implements a spiralling pixel resampling algorithm, "walking" around the resampling neighborhood in two dimensions and generating the appropriate coefficient table addresses to sum up the interpolated pixel value in the external pixel interpolator. At the end of each walk, the TMC2302A will advance one pixel along the output scan line and then execute the walk for that next pixel. When performing multiple-pass interpolation, the TMC2302A system proceeds along only one dimension per pass, which requires dimensionally separable, preferably orthogonal, coefficients.

A basic, two-dimensional TMC2302A-based system is shown in Figure 2. In this typical arrangement, two Image Manipulation Sequencers process the image. The only other components needed beyond the source and target image buffer memories are a multiplier-accumulator or pixel interpolator such as the TMC2246A Image Mixer or TMC2250A Matrix Multiplier, and the Interpolation Coefficient Lookup Table RAM or ROM.



Figure 2. Basic two-dimensional image convolver using TMC2302A IMS with typical 8-bit data path

4

## **Pin Assignments**

## 120 Pin Plastic Pin Grid Array, PPGA



65-2302-05

| A1         GND         C5         SADR19         G11         GND         L10         DON           A2         SADR16         C6         SADR22         G12         VDD         L11         VDD           A3         SADR17         C7         IADR5         G13         IDAT0         L12         GND           A4         VDD         C8         IADR1         H1         SADR5         L13         NOO           A5         SADR21         C9         IDAT14         H2         SADR4         M1         ACC           A6         OES         C10         IDAT10         H3         GND         M2         OEK           A7         IADR6         C11         GND         H11         GND         M3         KADR           A8         IADR3         C12         GND         H12         VDD         M4         KADR           A9         IADR0         C13         IDAT6         H13         SYNC         M5         KADR           A10         IDAT15         D1         SADR11         J1         SADR3         M6         OET           A11         IDAT9         D3         GND         J3         VDD         M     | 5<br>          |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| A3         SADR17         C7         IADR5         G13         IDAT0         L12         GND           A4         VDD         C8         IADR1         H1         SADR5         L13         NOO           A5         SADR21         C9         IDAT14         H2         SADR4         M1         ACC           A6         OES         C10         IDAT10         H3         GND         M2         OEK           A7         IADR6         C11         GND         H11         GND         M3         KADI           A8         IADR3         C12         GND         H12         VDD         M4         KADI           A9         IADR0         C13         IDAT6         H13         SYNC         M5         KADI           A10         IDAT15         D1         SADR11         J1         SADR3         M6         OET           A11         IDAT12         D2         SADR12         J2         SADR2         M7         TADI           A12         IDAT9         D3         GND         J3         VDD         M8         TADI           A13         VDD         D11         VDD         J11         VDD              | 3 <sub>6</sub> |
| A4         VDD         C8         IADR1         H1         SADR5         L13         NOO           A5         SADR21         C9         IDAT14         H2         SADR4         M1         ACC           A6         OES         C10         IDAT10         H3         GND         M2         OEK           A7         IADR6         C11         GND         H11         GND         M3         KADI           A8         IADR3         C12         GND         H12         VDD         M4         KADI           A9         IADR0         C13         IDAT6         H13         SYNC         M5         KADI           A10         IDAT15         D1         SADR11         J1         SADR3         M6         OET           A11         IDAT12         D2         SADR11         J1         SADR3         M7         TADI           A12         IDAT9         D3         GND         J3         VDD         M8         TADI           A13         VDD         D11         VDD         J11         VDD         M9         TADI           B1         SADR14         D12         IDAT5         J12         CLK         M     | 3 <sub>6</sub> |
| A5         SADR21         C9         IDAT14         H2         SADR4         M1         ACC           A6         OES         C10         IDAT10         H3         GND         M2         OEK           A7         IADR6         C11         GND         H11         GND         M3         KADR           A8         IADR3         C12         GND         H12         VDD         M4         KADR           A9         IADR0         C13         IDAT6         H13         SYNC         M5         KADR           A10         IDAT15         D1         SADR11         J1         SADR3         M6         OET           A11         IDAT12         D2         SADR11         J1         SADR2         M7         TADR           A12         IDAT9         D3         GND         J3         VDD         M8         TADR           A13         VDD         D11         VDD         J11         VDD         M9         TADR           B1         SADR14         D12         IDAT5         J12         CLK         M10         TADR           B2         SADR15         D13         IDAT4         J13         IWR         < | 3 <sub>6</sub> |
| A5         SADR21         C9         IDAT14         H2         SADR4         M1         ACC           A6         OES         C10         IDAT10         H3         GND         M2         OEK           A7         IADR6         C11         GND         H11         GND         M3         KADR           A8         IADR3         C12         GND         H12         VDD         M4         KADR           A9         IADR0         C13         IDAT6         H13         SYNC         M5         KADR           A10         IDAT15         D1         SADR11         J1         SADR3         M6         OET           A11         IDAT12         D2         SADR11         J1         SADR2         M7         TADR           A12         IDAT9         D3         GND         J3         VDD         M8         TADR           A13         VDD         D11         VDD         J11         VDD         M9         TADR           B1         SADR14         D12         IDAT5         J12         CLK         M10         TADR           B2         SADR15         D13         IDAT4         J13         IWR         < | 4              |
| A7         IADR6         C11         GND         H11         GND         M3         KADR           A8         IADR3         C12         GND         H12         VDD         M4         KADR           A9         IADR0         C13         IDAT6         H13         SYNC         M5         KADR           A10         IDAT15         D1         SADR11         J1         SADR3         M6         OET           A11         IDAT12         D2         SADR11         J1         SADR2         M7         TADR           A12         IDAT9         D3         GND         J3         VDD         M8         TADR           A13         VDD         D11         VDD         J11         VDD         M9         TADR           B1         SADR14         D12         IDAT5         J12         CLK         M10         TADR           B2         SADR15         D13         IDAT4         J13         IWR         M11         GND           B4         SADR18         E2         SADR10         K2         SADR0         M13         TVAL                                                                                   | 4              |
| A8         IADR3         C12         GND         H12         VDD         M4         KADR           A9         IADR0         C13         IDAT6         H13         SYNC         M5         KADR           A10         IDAT15         D1         SADR11         J1         SADR3         M6         OET           A11         IDAT12         D2         SADR12         J2         SADR2         M7         TADR           A12         IDAT9         D3         GND         J3         VDD         M8         TADR           A13         VDD         D11         VDD         J11         VDD         M9         TADR           B1         SADR14         D12         IDAT5         J12         CLK         M10         TADR           B2         SADR15         D13         IDAT4         J13         IWR         M11         GND           B4         SADR18         E2         SADR10         K2         SADR0         M13         TVAL                                                                                                                                                                                      | 4              |
| A9         IADR <sub>0</sub> C13         IDAT <sub>6</sub> H13         SYNC         M5         KADR           A10         IDAT <sub>15</sub> D1         SADR <sub>11</sub> J1         SADR <sub>3</sub> M6         OET           A11         IDAT <sub>12</sub> D2         SADR <sub>12</sub> J2         SADR <sub>2</sub> M7         TADR           A12         IDAT <sub>9</sub> D3         GND         J3         V <sub>DD</sub> M8         TADR           A13         V <sub>DD</sub> D11         V <sub>DD</sub> J11         V <sub>DD</sub> M9         TADR           B1         SADR <sub>14</sub> D12         IDAT <sub>5</sub> J12         CLK         M10         TADR           B2         SADR <sub>15</sub> D13         IDAT <sub>4</sub> J13         IWR         M11         GND           B3         V <sub>DD</sub> E1         SADR <sub>9</sub> K1         SADR <sub>1</sub> M12         GND           B4         SADR <sub>18</sub> E2         SADR <sub>10</sub> K2         SADR <sub>0</sub> M13         TVAL                                                                                          | <u> </u>       |
| A10         IDAT15         D1         SADR11         J1         SADR3         M6         OET           A11         IDAT12         D2         SADR12         J2         SADR2         M7         TADR           A12         IDAT9         D3         GND         J3         VDD         M8         TADR           A13         VDD         D11         VDD         J11         VDD         M9         TADR           B1         SADR14         D12         IDAT5         J12         CLK         M10         TADR           B2         SADR15         D13         IDAT4         J13         IWR         M11         GND           B3         VDD         E1         SADR9         K1         SADR1         M12         GND           B4         SADR18         E2         SADR10         K2         SADR0         M13         TVAL                                                                                                                                                                                                                                                                                            | 2              |
| A11         IDAT <sub>12</sub> D2         SADR <sub>12</sub> J2         SADR <sub>2</sub> M7         TADR           A12         IDAT <sub>9</sub> D3         GND         J3         V <sub>DD</sub> M8         TADR           A13         V <sub>DD</sub> D11         V <sub>DD</sub> J11         V <sub>DD</sub> M9         TADR           B1         SADR <sub>14</sub> D12         IDAT <sub>5</sub> J12         CLK         M10         TADR           B2         SADR <sub>15</sub> D13         IDAT <sub>4</sub> J13         IWR         M11         GND           B3         V <sub>DD</sub> E1         SADR <sub>9</sub> K1         SADR <sub>1</sub> M12         GND           B4         SADR <sub>18</sub> E2         SADR <sub>10</sub> K2         SADR <sub>0</sub> M13         TVAL                                                                                                                                                                                                                                                                                                                           |                |
| A12         IDAT9         D3         GND         J3         VDD         M8         TADE           A13         VDD         D11         VDD         J11         VDD         M9         TADE           B1         SADR14         D12         IDAT5         J12         CLK         M10         TADE           B2         SADR15         D13         IDAT4         J13         IWR         M11         GND           B3         VDD         E1         SADR9         K1         SADR1         M12         GND           B4         SADR18         E2         SADR10         K2         SADR0         M13         TVAL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                |
| A13         VDD         D11         VDD         J11         VDD         M9         TADR           B1         SADR14         D12         IDAT5         J12         CLK         M10         TADR           B2         SADR15         D13         IDAT4         J13         IWR         M11         GND           B3         VDD         E1         SADR9         K1         SADR1         M12         GND           B4         SADR18         E2         SADR10         K2         SADR0         M13         TVAL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0_             |
| B1         SADR14         D12         IDAT5         J12         CLK         M10         TADR           B2         SADR15         D13         IDAT4         J13         IWR         M11         GND           B3         VDD         E1         SADR9         K1         SADR1         M12         GND           B4         SADR18         E2         SADR10         K2         SADR0         M13         TVAL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 3              |
| B2         SADR <sub>15</sub> D13         IDAT <sub>4</sub> J13         IWR         M11         GND           B3         V <sub>DD</sub> E1         SADR <sub>9</sub> K1         SADR <sub>1</sub> M12         GND           B4         SADR <sub>18</sub> E2         SADR <sub>10</sub> K2         SADR <sub>0</sub> M13         TVAL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 6              |
| B3         VDD         E1         SADR9         K1         SADR1         M12         GND           B4         SADR18         E2         SADR10         K2         SADR0         M13         TVAL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 9              |
| B4 SADR <sub>18</sub> E2 SADR <sub>10</sub> K2 SADR <sub>0</sub> M13 TVAL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                |
| R5 SADROD E3 CND K3 CND N1 CND                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                |
| DO JOADINZO EO JOND NO GIND NO GIND                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                |
| B6 SADR <sub>23</sub> E11 GND K11 V <sub>DD</sub> N2 KADR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 7              |
| B7 IADR <sub>4</sub> E12 IDAT <sub>3</sub> K12 INIT N3 KADR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 5              |
| B8 IADR <sub>2</sub> E13 IDAT <sub>2</sub> K13 GND N4 KADR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | <br> 3         |
| B9 ICS F1 SADR <sub>7</sub> L1 SVAL N5 KADR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 1              |
| B10 IDAT <sub>13</sub> F2 SADR <sub>8</sub> L2 V <sub>DD</sub> N6 TWR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                |
| B11 IDAT <sub>11</sub> F3 V <sub>DD</sub> L3 NC N7 TADE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 1              |
| B12 IDAT <sub>8</sub> F11 V <sub>DD</sub> L4 V <sub>DD</sub> N8 TADF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 2              |
| B13 IDAT <sub>7</sub> F12 GND L5 GND N9 TADE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | _              |
| C1 SADR <sub>13</sub> F13 IDAT <sub>1</sub> L6 KADR <sub>0</sub> N10 TADR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 5_             |
| C2 V <sub>DD</sub> G1 SADR <sub>6</sub> L7 V <sub>DD</sub> N11 TADR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                |
| C3 V <sub>DD</sub> G2 GND L8 TADR <sub>4</sub> N12 TADR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 7              |
| C4 GND G3 V <sub>DD</sub> L9 TADR <sub>8</sub> N13 END                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 17<br>10       |

## Pin Assignments (continued)

## 120 Lead Metric Quad Flat Pack, MQFP



| Pin | Name               | Pin | Name               | Pin | Name              | Pin | Name               |  |
|-----|--------------------|-----|--------------------|-----|-------------------|-----|--------------------|--|
| 1   | $V_{\mathrm{DD}}$  | 31  | <u>OEK</u>         | 61  | $V_{DD}$          | 91  | GND                |  |
| 2   | SADR <sub>15</sub> | 32  | KADR <sub>7</sub>  | 62  | GND               | 92  | IDAT <sub>8</sub>  |  |
| 3   | SADR <sub>14</sub> | 33  | $V_{DD}$           | 63  | TVAL              | 93  | IDAT <sub>9</sub>  |  |
| 4   | GND                | 34  | KADR <sub>6</sub>  | 64  | $V_{DD}$          | 94  | IDAT <sub>10</sub> |  |
| 5   | $V_{\mathrm{DD}}$  | 35  | KADR <sub>5</sub>  | 65  | GND               | 95  | IDAT <sub>11</sub> |  |
| 6   | SADR <sub>13</sub> | 36  | KADR4              | 66  | NOOP              | 96  | IDAT <sub>12</sub> |  |
| 7   | SADR <sub>12</sub> | 37  | GND                | 67  | INIT              | 97  | IDAT <sub>13</sub> |  |
| 8   | GND                | 38  | KADR <sub>3</sub>  | 68  | $V_{DD}$          | 98  | IDAT <sub>14</sub> |  |
| 9   | SADR <sub>11</sub> | 39  | KADR <sub>2</sub>  | 69  | GND               | 99  | IDAT <sub>15</sub> |  |
| 10  | SADR <sub>10</sub> | 40  | KADR <sub>1</sub>  | 70  | CLK               | 100 | īcs                |  |
| 11  | SADR <sub>9</sub>  | 41  | KADR <sub>0</sub>  | 71  | ĪWR               | 101 | IADR <sub>0</sub>  |  |
| 12  | $V_{\mathrm{DD}}$  | 42  | OET                | 72  | 72 GND            |     | IADR <sub>1</sub>  |  |
| 13  | SADR <sub>8</sub>  | 43  | TWR                | 73  | $V_{DD}$          | 103 | IADR <sub>2</sub>  |  |
| 14  | SADR <sub>7</sub>  | 44  | TADR <sub>0</sub>  | 74  | SYNC              | 104 | IADR <sub>3</sub>  |  |
| 15  | GND                | 45  | $V_{DD}$           | 75  | $V_{DD}$          | 105 | IADR4              |  |
| 16  | $V_{\mathrm{DD}}$  | 46  | TADR <sub>1</sub>  | 76  | GND               | 106 | IADR <sub>5</sub>  |  |
| 17  | SADR <sub>6</sub>  | 47  | TADR <sub>2</sub>  | 77  | IDAT <sub>0</sub> | 107 | IADR <sub>6</sub>  |  |
| 18  | SADR <sub>5</sub>  | 48  | TADR <sub>3</sub>  | 78  | IDAT <sub>1</sub> | 108 | ŌES                |  |
| 19  | SADR <sub>4</sub>  | 49  | TADR <sub>4</sub>  | 79  | GND               | 109 | SADR <sub>23</sub> |  |
| 20  | GND 5              |     | TADR <sub>5</sub>  | 80  | $V_{DD}$          | 110 | SADR <sub>22</sub> |  |
| 21  | SADR <sub>3</sub>  | 51  | TADR <sub>6</sub>  | 81  | IDAT <sub>2</sub> | 111 | SADR <sub>21</sub> |  |
| 22  | SADR <sub>2</sub>  | 52  | TADR <sub>7</sub>  | 82  | IDAT3             | 112 | SADR <sub>20</sub> |  |
| 23  | SADR <sub>1</sub>  | 53  | TADR <sub>8</sub>  | 83  | IDAT <sub>4</sub> | 113 | $V_{\mathrm{DD}}$  |  |
| 24  | $V_{\mathrm{DD}}$  | 54  | TADR <sub>9</sub>  | 84  | GND               | 114 | SADR <sub>19</sub> |  |
| 25  | SADR <sub>0</sub>  | 55  | TADR <sub>10</sub> | 85  | IDAT <sub>5</sub> | 115 | SADR <sub>18</sub> |  |
| 26  | SVAL               | 56  | TADR <sub>11</sub> | 86  | IDAT <sub>6</sub> | 116 | SADR <sub>17</sub> |  |
| 27  | ACC                | 57  | DONE               | 87  | IDAT <sub>7</sub> | 117 | SADR <sub>16</sub> |  |
| 28  | GND                | 58  | GND                | 88  | $V_{DD}$          | 118 | GND                |  |
| 29  | $V_{\mathrm{DD}}$  | 59  | NC                 | 89  | GND               | 119 | V <sub>DD</sub>    |  |
| 30  | GND                | 60  | ENDD               | 90  | $V_{DD}$          | 120 | GND                |  |

## **Pin Descriptions**

|          | Pin N                                                                                                     | umber                      |                                                                                             |
|----------|-----------------------------------------------------------------------------------------------------------|----------------------------|---------------------------------------------------------------------------------------------|
| Pin Name | PPGA                                                                                                      | MQFP                       | Pin Function Description                                                                    |
| Power    |                                                                                                           |                            |                                                                                             |
| VDD      | G3, J3, L2,<br>L4, L7, L11,<br>K11, J11,<br>H12, G12,                                                     | 45, 61, 64,<br>68, 73, 75, | Supply Voltage. The TMC2302A operates from a single +5V supply. All pins must be connected. |
| GND      | D3, E3, G2,<br>H3, K3, N1,<br>L5, M11,<br>M12, L12,<br>K13, H11,<br>G11, F12,<br>E11, C12,<br>C11, C4, A1 | 69, 72, 76,                | Ground.                                                                                     |

|                      | Pin N                                                                                                               | umber                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |
|----------------------|---------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| Pin Name             | PPGA                                                                                                                | MQFP                                                                                                                      | Pin Function Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |
| Clocks               |                                                                                                                     |                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |
| CLK                  | J12                                                                                                                 | 70                                                                                                                        | System Clock . The pixel clock of the TMC2302A strobes all internal registers except the control parameter preload registers. All timing specifications except those are referenced to the rising edge of CLK.                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |
| īWR                  | J13                                                                                                                 | 71                                                                                                                        | Input Parameter Write Clock. The internal image transformation and configuration control parameter registers are double buffered to simplify interfacing with system controllers. Depending on the state of the chip selects ICS, control words input to IDAT <sub>15-0</sub> and the corresponding addresses presented to IADR <sub>6-0</sub> are strobed into the outer preload registers on the rising edge of the Input parameter Write clock IWR. The last parameter must be loaded twice on two consecutive rising edges of IWR. |  |  |  |  |  |  |
| Inputs               |                                                                                                                     | •                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |
| IDAT <sub>15-0</sub> | A10, C9,<br>B10, A11,<br>B11, C10,<br>A12, B12,<br>B13, C13,<br>D12, D13,<br>E12, E13,<br>F13, G13                  | 99, 98, 97,<br>96, 95, 94,<br>93, 92, 87,<br>86, 85, 83,<br>82, 81, 78,<br>77                                             | Input Parameter Data. Configuration and transformation parameter Input Data are presented, along with the appropriate input register address word IADR <sub>6-0</sub> , to the parameter Input Data port, and are latched into the preload registers on the next rising edge of IWR. Preload register updates are disabled by the chip select control ICS. See Figure 3.                                                                                                                                                               |  |  |  |  |  |  |
| IADR <sub>6-0</sub>  | A7, C7, B7,<br>A8, B8, C8,<br>A9                                                                                    | 107, 106,<br>105, 104,<br>103, 102,<br>101                                                                                | Input Parameter Address. The input parameter preload register currently indicated by the Input parameter register Address IADR <sub>6-0</sub> is loaded with the data presented to input port IDAT on the rising edge of IWR, as demonstrated in Figure 3.                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |
| Outputs              | •                                                                                                                   | •                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |
| SADR <sub>23-0</sub> | B6, C6, A5,<br>B5, C5, B4,<br>A3, A2, B2,<br>B1, C1, D2,<br>D1, E2, E1,<br>F2, F1, G1.<br>H1, H2, J1,<br>J2, K1, K2 | 109, 110,<br>111, 112,<br>114, 115,<br>116, 117, 2,<br>3, 6, 7, 9,<br>10, 11, 13,<br>14, 17, 18,<br>19, 21, 22,<br>23, 25 | <b>Source Address</b> . The 24-bit address of one dimension (X, Y, Z) of the source image pixel value currently being resampled is output through the Source Address port SADR <sub>23-0</sub> . This port can be forced to the high-impedance state by the enable control $\overline{OES}$ .                                                                                                                                                                                                                                          |  |  |  |  |  |  |
| KADR <sub>7-0</sub>  | N2, M3, N3,<br>M4, N4, M5,<br>N5, L6                                                                                | 32, 34, 35,<br>36, 38, 39,<br>40, 41                                                                                      | Coefficient Address. The integer address steps for each dimension of the spiral interpolation walk performed by the TMC2302A, as determined by the transform parameter KERNEL, are generated by the internal walk counter and output at the Coefficient Address output port KADR <sub>7-0</sub> . This port can be forced to the high-impedance state by the enable control OEK.                                                                                                                                                       |  |  |  |  |  |  |

|                      | Pin N                                                          | umber                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |  |
|----------------------|----------------------------------------------------------------|---------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| Pin Name             | PPGA                                                           | MQFP                                                    | Pin Function Description  Target Address. The 12-bit address of one dimension (U, V, W) of the target image pixel value just resampled is output through the Target Address Port TADR <sub>11-0</sub> . This port is forced into the high-impedance state by the enable control OET. TADR <sub>11-0</sub> can be delayed up to seven clock cycles after the nominal sequence shown in Table 4 by utilization of the pipeline delay parameter PIPTAD. For systems requiring greater spatial resolution in the source image than that offered by the SADR <sub>23-0</sub> alone, the Target Address Port can be reconfigured to output 12 additional LSBs of the source address by placing the device into the Extended mode, in which case the pipeline delay parameter must be set to 0 to maintain alignment with the current source address port output. See the Device Configuration and Control Parameters section.        |  |  |  |  |  |  |  |
| TADR <sub>11-0</sub> | N12, N11,<br>M10, L9,<br>N10, M9,<br>N9, L8, M8,<br>N8, N7, M7 | 56, 55, 54,<br>53, 52, 51,<br>50, 49, 48,<br>47, 46, 44 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |  |
| Controls             |                                                                |                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |  |
| INIT                 | K12                                                            | 67                                                      | Initialize. The TMC2302A control logic is cleared and initialized for the start of a new image transformation, and the internal working registers are updated with the contents of the current control parameter preload registers when the registered control input INIT is HIGH. The image transformation then commences with the first source image pixel address nine clocks after INIT is returned low.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |  |
| SYNC                 | H13                                                            | 74                                                      | Run/Halt. The user can select between continuous or one-frame operation with the registered input control SYNC. Assuming that INIT remains LOW and NOOP remains HIGH, if SYNC remains HIGH at the end of a transform the TMC2302A will begin the next image transformation without interruption. This assumes either that the user is not changing the parameter set, or that a new set of parameters has already been loaded into the preload registers midframe, prior to the beginning of the last line in the transform. If SYNC is LOW during the last clock cycle of a transform, the device will complete the image, having loaded the new transform parameter set during the first clock of the final line of the transform, and halt in the state set on the first clock cycle of the next transform. These outputs are held until SYNC is again brought HIGH, and operation resumes on the next clock. See Figure 5. |  |  |  |  |  |  |  |
| ICS                  | B9                                                             | 100                                                     | Input Parameter Chip Select. The input parameter preload register write clock $\overline{IWR}$ , and thus the preloading of all configuration and transformation parameters, is disabled on the next clock when the registered Input parameter Chip Select input is HIGH. When $\overline{ICS}$ returns LOW, they are enabled on the next clock. See Figure 3.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |  |
| ACC                  | M1                                                             | 27                                                      | Accumulate. The external pixel interpolator or multiplier-accumulator is initialized for a new accumulation of products by the registered Accumulator Control output ACC. On the first cycle of each interpolation walk, this output goes LOW for one cycle, effectively clearing the register by loading in only the first new resampled pixel value. When performing nearest-neighbor resampling, this control will remain LOW throughout the entire transform. This output can be delayed up to seven clock cycles after the nominal sequence shown in Table 4 by the pipeline dela parameter PIPACC. See the Device Configuration and Control Parameters section.                                                                                                                                                                                                                                                          |  |  |  |  |  |  |  |

|          | Pin  | Number |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |  |
|----------|------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| Pin Name | PPGA | MQFP   | Pin Function Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |  |
| TWR      | N6   | 43     | Target Memory Write Enable. On the last cycle of each interpolation walk, the Target Write Enable goes LOW for one clock cycle, returning HIGH for all but the last cycle of the next walk. When performing nearest-neighbor resampling, this control will remain LOW throughout the entire transform. This output can be forced to the high-impedance state by the enable control OET, and can be delayed up to seven clock cycles after the nominal sequence shown in Table 4 by the pipe-line delay parameter PIPTWR. See the Device Configuration and Control Parameters section.                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |  |
| NOOP     | L13  | 66     | No Operation. Assuming that INIT remains LOW, the internal system clock of the TMC2302A will be disabled on the next clock, halting the current transform, when the registered control input NOOP goes LOW. When NOOP returns HIGH, normal operation resumes on the next clock. This control does not affect the loading of the configuration and transformation parameter preread registers.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |  |
| ŌES      | A6   | 108    | Source Address Output Enable. The source address port SADR <sub>23-0</sub> is enabled when the asynchronous output enable OES is LOW. When OES is HIGH, the port is in the high-impedance state.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |  |
| OEK      | M2   | 31     | Coefficient Address Output Enable. The interpolation coefficient address port KADR <sub>7-0</sub> is enabled when the asynchro- nous output enable OEK is LOW. When OEK is HIGH, the port is in the high-impedance state.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |  |
| ŌĒT      | M6   | 42     | <b>Target Address Output Enable.</b> The target address port TADR <sub>11-0</sub> and target write enable TWR are enabled when the asynchronous Target Output Enable OET is LOW. When OET is HIGH, these outputs are in the high-impedance state. This control functions in both the normal and extended addressing modes.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |  |
| Flags    |      |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |  |
| SVAL     | L1   | 26     | Source Address Valid. When the current source image address component output is within the working space defined by the parameters XMIN and XMAX (or YMIN, YMAX for the column (Y/V) device or ZMIN, ZMAX for the page (Z/W) device), the Source Address Valid flag SVAL for that device is LOW. This flag will go HIGH on the clock in which the corresponding component address falls outside the defined region. In a typical system, the SVAL outputs of all IMS devices are OR'ed together to generate a global boundary violation flag. The user might then insert zeroes into the pixel interpolator to ignore that portion of the image outside the defined space, or insert a background color or image. This output can be delayed up to seven clock cycles after the nominal sequence shown in Table 4 by the pipeline delay parameter PIPSVA. See the Device Configuration and Control Parameters section. |  |  |  |  |  |  |  |

|            | Pin N | umber |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------|-------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Pin Name   | PPGA  | MQFP  | Pin Function Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| TVAL       | M13   | 63    | Target Address Valid. When the current target image addresses are within the working space defined by the parameters UMINI and UMAXI, and VMINI and VMAXI (and WMINI and WMAXI for systems processing three-dimensional images), the Target Address Valid flag TVAL for that device is LOW. This flag will go HIGH on the clock in which the current target address outputs fall outside the defined region, which must fall inside the target area defined by UMIN, UMAX, etc. Since each TMC2302A device is programmed with distinct MINI/MAXI parameters and generates a separate TVAL flag, the user may define separate two or three-dimensional target space windows for each device. TVAL can be delayed up to seven clock cycles after the nominal sequence shown in Table 4 by the pipeline delay parameter PIPTVA. See the Device Configuration and Control Parameters section. |
| ENDD       | N13   | 60    | End of Dimension. During the last pixel interpolation walk of a row (X/U device), the last row in a page (Y/V device), or the last page in a three-dimensional transform (Z/W device), the flag ENDD goes HIGH for the entire walk, indicating End of the transform in that dimension. It remains LOW otherwise. This output can be delayed up to seven clock cycles after the nominal sequence shown in Table 4 by the pipeline delay parameter PIPEND. See the Device Configuration and Control Parameters section.                                                                                                                                                                                                                                                                                                                                                                     |
| DONE       | L10   | 57    | Done. On the last clock cycle of the current image transform, the DONE flags on all TMC2302As go HIGH for one clock cycle. On the next clock cycle, all devices output the first addresses and control signals for the next image transform. If SYNC is LOW, the IMS system halts. If SYNC is HIGH, operation continues without interruption. See "SYNC," in the Controls section. This flag can be delayed up to seven clock cycles after the nominal sequence shown in Table 4 by the pipeline delay parameter PIPDON. Also see "PFLS," in the Device Configuration and Control Parameters section.                                                                                                                                                                                                                                                                                     |
| No Connect | s     |       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| NC         | L3    | 59    | No Connect.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|            | D4    |       | Index Pin.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

# Transformation Coefficient and Configuration and Control Parameters

The TMC2302A is intended to act as a co-processor, requiring only that the user program the device to perform the image transformation desired by loading in the appropriate device configuration and transformation control parameters discussed in this section. The user then issues an "Init" command, allowing his system to run unattended until the completion of the image when a "Done" flag is generated to inform the host system.

The capabilities and flexibility of the TMC2302A Image Manipulation Sequencer are apparent when reviewing the following tables which define the transformation coefficient and configuration and control parameters. These tables are broken up into two separate groups. The first parameters discussed are the control words which select the dimension calculated, the functional configuration of each device, the working space in which they will operate, the size of the interpolation kernel desired, and the timing of the various address and control signals involved in handling the pixel data pipeline. The second parameters are the polynomial transform coefficients used in performing image manipulation. The TMC2302A utilizes three levels of internal 48-bit accumulators to calculate these values by forward difference accumulation, generating no significant cumulative spatial error for most applications. The user must be aware that all internal parameter and coefficient registers must be set by the user, including resetting after powerup any unused control words or coefficients.

As mentioned above, the TMC2302A also features user-programmable image data pipeline configuration controls. All output signals except the source and coefficient address outputs can be individually delayed by the user up to seven clocks after the nominal system timing illustrated in Table 4. This allows the user to software-configure the TMC2302As in his system to match his pixel interpolator, image buffer, and interpolation coefficient RAM structure timing.

The user can also program the device to continue into the next image for a set number of clock cycles after the Done flag has appeared. First, this "flushes" the final resampled pixel data word through the interpolation pipeline, all the way to the target image RAM. Also, valid pixel data will then appear on the first clock of the next transform independent of the length of the pixel pipeline, incurring no lost clock cycles.

## Device Configuration and Control Parameters

UMIN, VMIN, WMIN The memory addresses of the target image boundaries corresponding to the top, left side, and front page of the new image being generated are defined in all devices of the user's system by the parameters UMIN, VMIN, and WMIN, respectively. At the beginning of the transformation, the initial source image coordinate  $(X_0,Y_0,Z_0)$  will be mapped to this coordinate set. The numeric format assumed is 12-bit unsigned binary integer.

UMAX, VMAX, WMAX The memory addresses of the target image boundaries corresponding to the bottom, right side, and last page of the image being generated are defined in all devices by the parameters UMAX, VMAX, and WMAX, respectively. These values should be greater than the UMIN/VMIN/WMIN values defined above. Numeric format assumed is unsigned 12-bit binary integer.

Note: The parameter UMAX must exceed UMIN so as to ensure that a minimum of 5 system clock cycles in two-dimensional operation, or 15 clock cycles in three-dimensional operation, pass between the periods in which these two target address values are generated. Thus in 2D nearest neighbor operation UMAX must be 5 greater than UMIN. In 2D bilinear interpolation mode (4-pixel two-dimensional kernel) the distance must be two pixels in the target image (actually enforcing a spacing of 8 system clocks).

UMINI, VMINI, WMINI The target image addresses corresponding to those of the top, left side, and front page of the 2 or 3 dimensional region indicated by the valid target address flag TVAL are UMINI, VMINI, and WMINI, respectively. Thus, to define a valid region beginning at "m," the MINI parameter value is "m," These parameters are assumed to be in 12-bit unsigned binary integer format. Proper TVAL operation requires UMIN < UMINI < UMAXI < UMAX, etc.

UMAXI, VMAXI, WMAXI The target image addresses one more than those of the right side, bottom and back page of the region indicated by the valid target address flag TVAL are UMAXI, VMAXI, and WMAXI, respectively. Thus, to define a valid region ending at "n," the MAXI parameter value is "n+1". These parameters are assumed to be in 12-bit unsigned integer format.

XMIN. **XMAX**  The source image boundaries are defined for each device by the parameters XMIN and XMAX, in the case of the row device. The column device then contains YMIN and YMAX, and the page device (in systems performing three-dimensional operations) ZMIN and ZMAX. The value of XMAX should be greater than XMIN if the boundary violation flag SVAL is to operate correctly. These values are assumed to be in 32-bit unsigned binary integer format.

**PFLS** 

The user can set the number of clock cycles that the TMC2302A continues in to the next image following the DONE flag, allowing his system to Flush all control and data pipeline paths and halt after a maximum of seven cycles. The numeric format assumed is threebit unsigned binary integer.

PTAD. PDON, PEND. PTVA. PSVA. PTWR, PACC

As mentioned above, the control signals and target image pixel addresses generated by the TMC2302A can be delayed up to seven clock cycles after the nominal timing shown in Table 4 by setting the appropriate Pipeline delay word. The numeric format assumed for all delay words is three-bit unsigned binary integer.

XTND

When the user sets the control bit XTND to 1, the TMC2302A operates in an extendedresolution source address bus configuration. Assuming that the user has his own raster scan generator available elsewhere to manage the flow of output pixels from the TMC2302A system, the target address output bus TADR<sub>11-0</sub> is reconfigured internally into an extension of the source address bus, as SADR<sub>11-0</sub>. The original source address bus SADR23-0 is then SADR<sub>35-12</sub>, providing 36 bits of spatial resolution in the source address space. An XTND of 0 puts the device in the standard 24-bit source, 12-bit target address configuration.

E3D

Setting this control bit to 0 indicates a two-dimensional image transform is to be performed. When the E3D is set to 1, a threedimensional image is assumed, using three TMC2302A devices.

DIM

The user sets each TMC2302A to operate in a specific dimension as follows:

| DIM <sub>1,0</sub> | Dimension           |
|--------------------|---------------------|
| 00                 | X/U (Row) Device    |
| 01                 | Y/V (Column) Device |
| 10                 | Z/W (Page) Device   |
| 11                 | No Operation        |

MODE

In systems performing the standard two-dimensional spiral interpolation walk, MODE is set to 11, indicating single-pass operation. When performing multiple-pass resampling, the user must set this two-bit control word pass-by-pass in all IMSs, to implement each pass direction. For instance, setting MODE to 00 causes the TMC2302A system to increment only in the X-direction, holding the Y (and Z) addresses constant until the end of that pixel walk. On the next pass through the image, the user sets MODE = 01, with the kernel increment in Y only. In 3D, the IMS system then proceeds again through the (U, V) target image space, walking kernels only along the Z direction.

| Mode <sub>1,0</sub> | Resampling Performed      |
|---------------------|---------------------------|
| 00                  | X-Pass                    |
| 01                  | Y-Pass                    |
| 10                  | Z-Pass                    |
| 11                  | Two-Dimension Spiral Walk |

KERNEL This parameter determines the size of the interpolation walk performed. To implement a convolutional sum of K+1 pixels, the parameter KERNEL is set to K, up to a maximum of 255. In single-pass operation, this value must be identical in all devices, giving a square interpolation kernel. In multiple-pass operation, however, non-square kernels may be implemented, with different K values in each dimension. Or. the user could utilize a banded memory architecture in two-pass mode to access an entire row or column of a kernel in one clock, completing the entire sum in a single pass through the other dimension of the kernel. Numeric format is 8-bit unsigned integer.

**FOV** 

The user determines the size of each step in an interpolation walk, in terms of the number of source image pixels, by setting the Field Of View control. The binary weighting of the image transformation parameters and source address must be taken into account when determining this value. See Table 6 and the Applications Discussion section. The numeric format assumed is unsigned 16-bit integer.

Table 1. Control Parameter Registers Binary Format (Row, Column or Page Device)

| A      | ddr |                     |                |                     |                     |                |                     |                |                |                       |                |                 | Format          | t                |                       |                   |                 | L                  | imits        |
|--------|-----|---------------------|----------------|---------------------|---------------------|----------------|---------------------|----------------|----------------|-----------------------|----------------|-----------------|-----------------|------------------|-----------------------|-------------------|-----------------|--------------------|--------------|
| Name   | Hex | MSE                 | 3              |                     |                     |                |                     |                |                |                       |                |                 |                 |                  |                       |                   | LSB             | Dec                | Hex          |
| UMIN   | 30  |                     |                |                     |                     | 2 <sup>1</sup> | 2 <sup>1</sup>      | 2 <sup>9</sup> | 2 <sup>8</sup> | <b>2</b> <sup>7</sup> | 2 <sup>6</sup> | 2 <sup>5</sup>  | 2 <sup>4</sup>  | 2 <sup>3</sup>   | <b>2</b> <sup>2</sup> | 2 <sup>1</sup>    | 2 <sup>0</sup>  | 4095<br>0          | FFF<br>000   |
| UMAX   | 31  |                     |                |                     |                     | 2 <sup>1</sup> | 2 <sup>1</sup>      | 2 <sup>9</sup> | 2 <sup>8</sup> | <b>2</b> <sup>7</sup> | 2 <sup>6</sup> | 2 <sup>5</sup>  | 2 <sup>4</sup>  | 2 <sup>3</sup>   | <b>2</b> <sup>2</sup> | 2 <sup>1</sup>    | 2 <sup>0</sup>  | 4095<br>0          | FFF<br>000   |
| UMINI  | 32  |                     |                |                     |                     | 2 <sup>1</sup> | 2 <sup>1</sup>      | 2 <sup>9</sup> | 2 <sup>8</sup> | <b>2</b> <sup>7</sup> | 2 <sup>6</sup> | 2 <sup>5</sup>  | 2 <sup>4</sup>  | 2 <sup>3</sup>   | 2 <sup>2</sup>        | 2 <sup>1</sup>    | 2 <sup>0</sup>  | 4095<br>0          | FFF<br>000   |
| UMAXI  | 33  |                     |                |                     |                     | 2 <sup>1</sup> | 2 <sup>1</sup>      | 2 <sup>9</sup> | 2 <sup>8</sup> | <b>2</b> <sup>7</sup> | 2 <sup>6</sup> | 2 <sup>5</sup>  | 2 <sup>4</sup>  | 2 <sup>3</sup>   | <b>2</b> <sup>2</sup> | 2 <sup>1</sup>    | 2 <sup>0</sup>  | 4095<br>0          | FFF<br>000   |
| VMIN   | 34  |                     |                |                     |                     | 2 <sup>1</sup> | 2 <sup>1</sup>      | 2 <sup>9</sup> | 2 <sup>8</sup> | <b>2</b> <sup>7</sup> | 2 <sup>6</sup> | 2 <sup>5</sup>  | 2 <sup>4</sup>  | 2 <sup>3</sup>   | 2 <sup>2</sup>        | 2 <sup>1</sup>    | 2 <sup>0</sup>  | 4095<br>0          | FFF<br>000   |
| VMAX   | 35  |                     |                |                     |                     | 2 <sup>1</sup> | 2 <sup>1</sup>      | 2 <sup>9</sup> | 2 <sup>8</sup> | <b>2</b> <sup>7</sup> | 2 <sup>6</sup> | 2 <sup>5</sup>  | 2 <sup>4</sup>  | 2 <sup>3</sup>   | 2 <sup>2</sup>        | 2 <sup>1</sup>    | 2 <sup>0</sup>  | 4095<br>0          | FFF<br>000   |
| VMINI  | 36  |                     |                |                     |                     | 2 <sup>1</sup> | 2 <sup>1</sup>      | 2 <sup>9</sup> | 2 <sup>8</sup> | <b>2</b> <sup>7</sup> | 2 <sup>6</sup> | 2 <sup>5</sup>  | 2 <sup>4</sup>  | 2 <sup>3</sup>   | 2 <sup>2</sup>        | 2 <sup>1</sup>    | 2 <sup>0</sup>  | 4095<br>0          | FFF<br>000   |
| VMAXI  | 37  |                     |                |                     |                     | 2 <sup>1</sup> | 2 <sup>1</sup>      | 2 <sup>9</sup> | 2 <sup>8</sup> | 2 <sup>7</sup>        | 2 <sup>6</sup> | 2 <sup>5</sup>  | 2 <sup>4</sup>  | 2 <sup>3</sup>   | 2 <sup>2</sup>        | 21                | 2 <sup>0</sup>  | 4095<br>0          | FFF<br>000   |
| WMIN   | 38  |                     |                |                     |                     | 2 <sup>1</sup> | 2 <sup>1</sup>      | 2 <sup>9</sup> | 2 <sup>8</sup> | 2 <sup>7</sup>        | 2 <sup>6</sup> | 2 <sup>5</sup>  | 2 <sup>4</sup>  | 2 <sup>3</sup>   | 2 <sup>2</sup>        | 21                | 20              | 4095<br>0          | FFF<br>000   |
| WMAX   | 39  |                     |                |                     |                     | 2 <sup>1</sup> | 2 <sup>1</sup><br>0 | 29             | 2 <sup>8</sup> | 2 <sup>7</sup>        | 2 <sup>6</sup> | 2 <sup>5</sup>  | 2 <sup>4</sup>  | 2 <sup>3</sup>   | 2 <sup>2</sup>        | 21                | 20              | 4095<br>0          | FFF<br>000   |
| WMINI  | 3A  |                     |                |                     |                     | 2 <sup>1</sup> | 2 <sup>1</sup><br>0 | 2 <sup>9</sup> | 2 <sup>8</sup> | 2 <sup>7</sup>        | 2 <sup>6</sup> | 2 <sup>5</sup>  | 2 <sup>4</sup>  | 2 <sup>3</sup>   | 2 <sup>2</sup>        | 21                | 20              | 4095<br>0          | FFF<br>000   |
| WMAXI  | 3B  | -1                  | _1             | -1                  | _1                  | 2 <sup>1</sup> | 2 <sup>1</sup><br>0 | 2 <sup>9</sup> | 2 <sup>8</sup> | <b>2</b> <sup>7</sup> | 2 <sup>6</sup> | 2 <sup>5</sup>  | 2 <sup>4</sup>  | 2 <sup>3</sup>   | 2 <sup>2</sup>        | 2 <sup>1</sup>    | 2 <sup>0</sup>  | 4095<br>0          | FFF<br>000   |
| XMINL  | 3C  | 2 <sup>1</sup>      | 21             | 2 <sup>1</sup>      | 2 <sup>1</sup>      | 2 <sup>1</sup> | 2 <sup>1</sup>      | 2 <sup>9</sup> | 28             | 2 <sup>7</sup>        | 2 <sup>6</sup> | 2 <sup>5</sup>  | 2 <sup>4</sup>  | 2 <sup>3</sup>   | 2 <sup>2</sup>        | 21                | 2 <sup>0</sup>  | 0                  | 00000000     |
| XMINM  | 3D  | 2 <sup>3</sup>      | 2 <sup>3</sup> | 2 <sup>2</sup>      | 2 <sup>2</sup>      | 2 <sup>2</sup> | 2 <sup>2</sup>      | 2 <sup>2</sup> | 242            | 2 <sup>2</sup>        | 2 <sup>2</sup> | 2 <sup>21</sup> | 2 <sup>20</sup> | 2 <sup>19</sup>  | 2 <sup>18</sup>       | 2 <sup>17</sup>   | 2 <sup>16</sup> | 2 <sup>32</sup> -1 | FFFFFF       |
| XMAXL  | 3E  | 2 <sup>1</sup><br>5 | 2 <sup>1</sup> | 2 <sup>1</sup><br>3 | 2 <sup>1</sup>      | 2 <sup>1</sup> | 2 <sup>1</sup>      | 2 <sup>9</sup> | 2 <sup>8</sup> | 27                    | 2 <sup>6</sup> | 2 <sup>5</sup>  | 2 <sup>4</sup>  | 2 <sup>3</sup>   | 2 <sup>2</sup>        | 21                | 20              | 0                  | 00000000     |
| XMAXM  | 3F  | 2 <sup>3</sup><br>1 | 2 <sup>3</sup> | 2 <sup>2</sup><br>9 | 2 <sup>2</sup><br>8 | 2 <sup>2</sup> | 2 <sup>2</sup>      | 2 <sup>2</sup> | 2 <sup>2</sup> | 2 <sup>2</sup><br>3   | 2 <sup>2</sup> | 2 <sup>21</sup> | 2 <sup>20</sup> | 2 <sup>19</sup>  | 2 <sup>18</sup>       | 2 <sup>17</sup>   | 2 <sup>16</sup> | 2 <sup>32</sup> -1 | FFFFFF       |
| PFLS   | 40  |                     | 2 <sup>2</sup> | 21                  | 2 <sup>0</sup>      |                |                     |                |                |                       |                |                 |                 |                  |                       |                   |                 | 7<br>0             | 7<br>0       |
| PTAD   | 40  |                     |                |                     |                     | 2 <sup>2</sup> | 2 <sup>1</sup>      | 2 <sup>0</sup> |                |                       |                |                 |                 |                  |                       |                   |                 | 7<br>0             | 7<br>0       |
| PDON   | 40  |                     |                |                     |                     |                |                     |                | 2 <sup>2</sup> | 2 <sup>1</sup>        | 2 <sup>0</sup> |                 |                 |                  |                       |                   |                 | 7<br>0             | 7<br>0       |
| PEND   | 40  |                     |                |                     |                     |                |                     |                |                |                       |                | 2 <sup>2</sup>  | 2 <sup>1</sup>  | 2 <sup>0</sup>   |                       |                   |                 | 7<br>0             | 7<br>0       |
| PTVA   | 40  |                     |                |                     |                     |                |                     |                |                |                       |                |                 |                 |                  | 2 <sup>2</sup>        | 2 <sup>1</sup>    | 2 <sup>0</sup>  | 7<br>0             | 7<br>0       |
| PSVA   | 41  |                     | 2 <sup>2</sup> | 2 <sup>1</sup>      | 2 <sup>0</sup>      |                |                     |                |                |                       |                |                 |                 |                  |                       |                   |                 | 7<br>0             | 7<br>0       |
| PTWR   | 41  |                     |                |                     |                     | 2 <sup>2</sup> | 21                  | 2 <sup>0</sup> |                |                       |                |                 |                 |                  |                       |                   |                 | 7<br>0             | 7<br>0       |
| PACC   | 41  |                     |                |                     |                     |                |                     |                | 2 <sup>2</sup> | 2 <sup>1</sup>        | 2 <sup>0</sup> |                 |                 |                  |                       |                   |                 | 7<br>0             | 7<br>0       |
| XTND   | 41  |                     |                |                     |                     |                |                     |                |                |                       |                | XTND            |                 |                  |                       |                   |                 |                    |              |
| E3D    | 41  |                     |                |                     |                     |                |                     |                |                |                       |                |                 | E3D             |                  |                       |                   |                 |                    |              |
| DIM    | 41  |                     |                |                     |                     |                |                     |                |                |                       |                |                 |                 | DIM <sub>1</sub> | DIM <sub>0</sub>      |                   |                 |                    |              |
| MODE   | 41  |                     |                |                     |                     |                |                     |                |                |                       |                |                 |                 |                  |                       | MODE <sub>1</sub> |                 | 1                  |              |
| KERNEL | 42  |                     |                |                     |                     |                |                     |                |                | <b>2</b> <sup>7</sup> | 2 <sup>6</sup> | 2 <sup>5</sup>  | 2 <sup>4</sup>  | 2 <sup>3</sup>   | 2 <sup>2</sup>        | 2 <sup>1</sup>    | 2 <sup>0</sup>  | 255<br>0           | FF<br>00     |
| FOV    | 43  | 2 <sup>1</sup>      | 2 <sup>1</sup> | 2 <sup>1</sup>      | 2 <sup>1</sup>      | 2 <sup>1</sup> | 2 <sup>1</sup>      | 2 <sup>9</sup> | 2 <sup>8</sup> | <b>2</b> <sup>7</sup> | 2 <sup>6</sup> | 2 <sup>5</sup>  | 2 <sup>4</sup>  | 2 <sup>3</sup>   | 2 <sup>2</sup>        | 2 <sup>1</sup>    | 2 <sup>0</sup>  | 2 <sup>16</sup> -1 | FFFF<br>0000 |

## **Transformation Parameter Registers**

The Transformation Parameter Word storage register addresses for the X/U device are listed in Table 2, along with the differential terms for each polynomial coefficient for both two and three-dimensional transforms. The polynomial terms for the other IMS device(s) are found by replacing every "X" in the table with a Y (or Z). A TMC2302A-based system can perform image manipulations of up to third order in two dimensions, and three-dimensional transforms of up to order 1.5 ("first-and-a-half order"). Also, see "The Image Transformation Polynomial", in the Applications Discussion section.

The notation used to define each polynomial coefficient term in Table 2 is easily interpreted. Each differential is of course defined by a differential in X, followed by the corresponding dependent U, V, or W terms. Thus,

DXUV is equivalent to d<sup>2</sup>X/dUdV

and DXUUUV to  $d^4X/dU^3dV$ .

**Table 2. Transformation Polynomial Coefficient Register Addresses** 

|      | Parai          | meter          | Coeffici | ient Word Address | es (hex) |  |
|------|----------------|----------------|----------|-------------------|----------|--|
| Name | 2D Term        | 3D Term        | MSW      | CSW               | LSW      |  |
| A    | X <sub>0</sub> | X <sub>0</sub> | 00       | 01                | 02       |  |
| В    | DXU            | DXU            | 03       | 04                | 05       |  |
| С    | DXUU           |                | 06       | 07                | 08       |  |
| D    | DXUUU          |                | 09       | 0 <b>A</b>        | 0B       |  |
| E    | DXV            | DXV            | 0C       | 0D                | 0E       |  |
| F    | DXUV           | DXUV           | 0F       | 10                | 11       |  |
| G    | DXUUV          | X <sub>0</sub> | 12       | 13                | 14       |  |
| Н    | DXUUUV         | DXU            | 15       | 16                | 17       |  |
| I    | DXVV           | DXVW           | 18       | 19                | 1A       |  |
| J    | DXUVV          | DXUVW          | 1B       | 1C                | 1D       |  |
| K    | DXUUVV         | DXW            | 1E       | 1F                | 20       |  |
| L    | DXUUUVV        | DXU <b>W</b>   | 21       | 22                | 23       |  |
| М    | DXVVV          |                | 24       | 25                | 26       |  |
| N    | DXUVVV         |                | 27       | 28                | 29       |  |
| 0    | DXUUVVV        |                | 2A       | 2B                | 2C       |  |
| Р    | DXUUUVVV       |                | 2D       | 2E                | 2F       |  |

#### Note

Table 3. Integer Binary Weighting of Transformation Parameters

|     | Format           |                 |                 |                 |                        |                 |                 |                 |                       |                 |                 |                 |                 |                 | Limits          |                 |                    |             |
|-----|------------------|-----------------|-----------------|-----------------|------------------------|-----------------|-----------------|-----------------|-----------------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|--------------------|-------------|
|     | MSB              |                 |                 |                 |                        |                 |                 |                 |                       |                 |                 |                 |                 |                 |                 | LSB             | Dec                | Hex         |
| MSB | -2 <sup>47</sup> | 2 <sup>46</sup> | 2 <sup>45</sup> | 2 <sup>44</sup> | 2 <sup>43</sup>        | 2 <sup>42</sup> | 2 <sup>41</sup> | 2 <sup>40</sup> | 2 <sup>39</sup>       | 2 <sup>38</sup> | $2^{37}$        | 2 <sup>36</sup> | 2 <sup>35</sup> | 2 <sup>34</sup> | 2 <sup>33</sup> | 2 <sup>32</sup> | 2 <sup>48</sup> -1 | FFFFFFFFFF  |
| CSW | 2 <sup>31</sup>  | 2 <sup>30</sup> | 2 <sup>29</sup> | 2 <sup>28</sup> | <b>2</b> <sup>27</sup> | 2 <sup>26</sup> | 2 <sup>25</sup> | 2 <sup>24</sup> | 2 <sup>23</sup>       | 2 <sup>22</sup> | 2 <sup>21</sup> | 2 <sup>20</sup> | 2 <sup>19</sup> | 2 <sup>18</sup> | 2 <sup>17</sup> | 2 <sup>16</sup> |                    |             |
| LSW | 2 <sup>15</sup>  | 2 <sup>14</sup> | 2 <sup>13</sup> | 2 <sup>12</sup> | 2 <sup>11</sup>        | 2 <sup>10</sup> | 2 <sup>9</sup>  | 2 <sup>8</sup>  | <b>2</b> <sup>7</sup> | $2^{6}$         | 2 <sup>5</sup>  | 2 <sup>4</sup>  | 2 <sup>3</sup>  | 2 <sup>2</sup>  | 2 <sup>1</sup>  | 2 <sup>0</sup>  | 0                  | 00000000000 |

### Note:

1. A minus sign indicates a sign bit.

<sup>1.</sup> The X<sub>0</sub> and DXU terms must each be loaded into two different registers when performing 3D transforms. Table 2 shows the binary weighting of all of the Transformation Parameter words, which are 48-bit signed fractional binary.



65-2302-07

Figure 3. Image transformation and configuration control parameters register structure

Figure 3 depicts the control preload register structure and Figure 4B gives the corresponding timing relationships.

**Table 4. Nominal Output Signal Timing** 

| SADR <sub>23-0</sub> 1 | ACC | TADR <sub>11-0</sub> | TWR | END | DONE |
|------------------------|-----|----------------------|-----|-----|------|
| X <sub>I-1,J,0</sub>   | 0   | U <sub>L-1,M</sub>   | 1   | 0   | 0    |
| $X_{I-1,J,1}$          | 1   | U <sub>L-1,M</sub>   | 1   | 0   | О    |
| $X_{I-1,J,2}$          | 1   | U <sub>L-1,M</sub>   | 1   | 0   | О    |
| •                      |     |                      |     |     |      |
| •                      |     |                      |     |     |      |
| •                      |     |                      |     |     |      |
| $X_{I-1,J,K}$          | 1   | U <sub>L-1,M</sub>   | 0   | 1   | 0    |
| $X_{I,J,0}$            | 0   | U <sub>L,M</sub>     | 1   | 1   | 0    |
| $X_{I,J,1}$            | 1   | U <sub>L,M</sub>     | 1   | 1   | 0    |
| $X_{I,J,2}$            | 1   | U <sub>L,M</sub>     | 1   | 1   | 0    |
| •                      |     |                      |     |     |      |
| •                      |     |                      |     |     |      |
| •                      |     |                      |     |     |      |
| $X_{I,J,K}$            | 1   | $U_{L,M}$            | 0   | 1   | 1    |

### Note:

1. KADR<sub>7-0</sub> timing identical.

The nominal sequence of address and control signals of a two-dimensional, single-pass-programmed TMC2302A system, with all PIPE parameters set to 0, is shown in Table 4. Here, the values of the last two new target image pixels  $U_{L-l,M}$  and  $U_{L,M}$  are being calculated, and the beginning and end of the interpolation walks of length K which sample source image pixels in the neighborhod of locations  $(X_{I-l,J}, X_{I,J})$  can be seen. Utilizing the arrival of the source image address  $(SADR_{3l-0})$  as a reference point, the other

signals shown can be delayed up to seven clock cycles from the nominal timing shown here, allowing the user to configure these outputs to match the timing latencies of his pixel data path structure. Considerable speed and timing variations in image buffer memory, data register, and pixel interpolator structure can thus be accommodated, with minimal corresponding support hardware. Also see "PFLS," in the Device Configuration and Control Parameters section.

TMC2302A

## **Equivalent Circuits and Threshold Levels**





Figure 5. Equivalent Input Circuit

Figure 6. Equivalent Output Circuit



Figure 7. Threshold Levels for Three-State Measurements

## **Absolute Maximum Ratings**

(beyond which the device may be damaged)<sup>1</sup>

| Parameter                                                      | Min. | Max.                  | Units  |
|----------------------------------------------------------------|------|-----------------------|--------|
| Supply Voltage                                                 | -0.5 | + 7.0                 | ٧      |
| Input Voltage                                                  | -0.5 | V <sub>DD</sub> + 0.5 | V      |
| Output applied voltage                                         | -0.5 | V <sub>DD</sub> + 0.5 | ٧      |
| Short-circuit duration (single output in HIGH state to ground) |      | 1                     | second |
| Operating, case temperature                                    | -60  | 130°                  | С      |
| Junction temperature                                           |      | 175°                  | С      |
| Lead, soldering temperature (10 seconds)                       |      | 300°                  |        |
| Storage temperature                                            | -65  | +150°                 | С      |

### Notes:

1. Absolute maximum ratings are limiting values applied individually while all other parameters are within specified operating conditions. Functional operation under any of these conditions is NOT implied.

## **Operating Conditions**

|               |                                |                       |      |      |      |      | -1   |      |       |
|---------------|--------------------------------|-----------------------|------|------|------|------|------|------|-------|
| Param         | eter                           | Test Conditions       | Min. | Nom. | Max. | Min. | Nom. | Max. | Units |
| VDD           | Supply Voltage                 |                       | 4.75 | 5.0  | 5.25 | 4.75 | 5.0  | 5.5  | V     |
| VIL           | Input Voltage, Logic LOW       |                       |      |      | 0.8  |      |      | 0.8  | V     |
| VIH           | Input Voltage, Logic HIGH      |                       | 2.0  |      |      | 2.0  |      |      | V     |
| loL           | Output Current, Logic LOW      |                       |      |      | 8.0  |      |      | 8.0  | mA    |
| ЮН            | Output Current, Logic HIGH     |                       |      |      | -4.0 |      |      | -4.0 | mA    |
| tcy           | Cycle Time                     | V <sub>DD</sub> = Min | 33   |      |      | 25   |      |      | ns    |
| tp <b>W</b> L | Clock Pulse Width, LOW         | V <sub>DD</sub> = Min | 15   |      |      | 12.5 |      |      | ns    |
| tp <b>w</b> H | Clock Pulse Width, HIGH        | V <sub>DD</sub> = Min | 15   |      |      | 10   |      |      | ns    |
| ts            | Input Setup Time               |                       | 10   |      |      | 8    |      |      | ns    |
| tH            | Input Hold Time                |                       | 2    |      |      | 2    |      |      | ns    |
| TA            | Ambient Temperature, Still Air |                       | 0    |      | 70   | 0    |      | 70   | °C    |

## Electrical Characteristics<sup>1</sup>

| Parame | eter                                         | Test Conditions                                                     | Min. | Max. | Units |
|--------|----------------------------------------------|---------------------------------------------------------------------|------|------|-------|
| IDDQ   | Supply Current Quiescent                     | V <sub>DD</sub> = Max, V <sub>IN</sub> = 0V                         |      | 10   | mA    |
| IDDU   | Supply Current, Unloaded                     | V <sub>DD</sub> = Max, f = 20MHz,<br>OES = OEK = OET = 5V           |      | 70   | mA    |
| lı∟    | Input Current, Logic LOW                     | V <sub>DD</sub> = Max, V <sub>IN</sub> = 0V                         | -10  |      | μА    |
| lін    | Input Current, Logic HIGH                    | $V_{DD} = Max, V_{IN} = V_{DD}$                                     |      | 10   | μA    |
| Vol    | Output Voltage, Logic LOW                    | V <sub>DD</sub> = Min, I <sub>OL</sub> = Max                        |      | 0.4  | V     |
| Vон    | Output Voltage, Logic HIGH                   | VDD = Min, IOH = Max                                                | 2.4  |      | V     |
| lozL   | High-Z Output Leakage Current,<br>Output LOW | V <sub>DD</sub> = Max, V <sub>IN</sub> = 0V                         | -40  |      | μА    |
| lozh   | Hi-Z Output Leakage Current, Output<br>HIGH  | V <sub>DD</sub> = Max, V <sub>IN</sub> = V <sub>DD</sub>            |      | 40   | μА    |
| los    | Short-Circuit Output Current                 | VDD = Max, Output HIGH, one pin to ground, one second duration max. | -20  | -70  | mA    |
| Cı     | Input Capacitance                            | T <sub>A</sub> = 25°C, f = 1MHz                                     |      | 10   | pF    |
| Co     | Output Capacitance                           | TA = 25°C, f = 1MHz                                                 |      | 10   | pF    |

### Note:

1. Actual test conditions may vary from those shown, but guarantee operation as specified.

## **Switching Characteristics**

|       |                                               |                                                 |      |      | -    | 1    |       |
|-------|-----------------------------------------------|-------------------------------------------------|------|------|------|------|-------|
| Param | eter                                          | Test Conditions                                 | Min. | Max. | Min. | Max. | Units |
| tDO   | Output Delay                                  | VDD = Min, CLOAD = 25pF                         |      | 15   |      | 12   | ns    |
| tHO   | Output Hold Time                              | V <sub>DD</sub> = Max, C <sub>LOAD</sub> = 25pF | 4    |      | 4    |      | ns    |
| tENA  | Three-State Output Enable Delay <sup>1</sup>  | VDD = Min, CLOAD = 25pF                         |      | 12   |      | 12   | ns    |
| tDIS  | Three-State Output Disable Delay <sup>1</sup> | VDD = Min, CLOAD = 25pF                         |      | 15   |      | 15   | ns    |

#### Note

1. All transitions are measured at a 1.5V level except for tDIS and TEMA.

### **Timing Diagrams**



- 1. Except OES, OET, and OEK.
- Assumes OES, OET, and OEK = LOW. All pipeline latency parameters set to 0.

Figure 4a. Timing Diagram, Pixel Clock, Control, and Outputs



Value "DAT 1" is loaded into address "ADR 1" on the second rising edge of  $\overline{IWR}$ , since  $\overline{ICS}$  = 0, having been acquired by the input register on the first edge.

Figure 4b. Timing Diagram, Preload Parameters

## **Applications Discussion**

### The Image Transformation Polynomial

On any given clock cycle, when performing a two-dimensional geometric transformation the addresses output by the row (X/U) TMC2302A are generated by forward difference accumulation according to the following third-order polynomial:

$$x(u,v) = a + bu + cu^{2} + du^{3} + ev + fvu + gvu^{2} + hvu^{3}$$
  
+  $iv^{2} + jv^{2}u + kv^{2}u^{2} + Iv^{2}u^{3} + mv^{3} + nv^{3}u + ov^{3}u^{2}$   
+  $pv^{3}u^{3} + FOV \cdot CAX(ca)$ 

The polynomial utilized for three-dimensional transforms is:

$$x(u,v,w) = a + bu + ev + kw + fuv + ivw + luw + juvw + FOV \cdot CAX$$
 (ca)

where  $0 \le u \le UMAX-UMIN$ ,  $0 \le v \le VMAX-VMIN$ ,  $0 \le w \le WMAX-WMIN$ , and the polynomials for the column or page devices are obtained by replacing the x by a y or z, as appropriate.

FOV is the 16-bit field-of-view parameter, normally set so that the spiral walk proceeds in single-pixel steps. FOV can be increased to expand the step size and thus the spiral walk, subsampling the image. See Table 1 and Table 6. Also, CAX(ca) is the current value of the coefficient address. See the Interpolation Coefficient Lookup Table Addressing. If the spiral walk isn't used, CAX = 0 and FOV is ignored.

We can reform the two-dimensional polynomial as:

$$x(u,v) = (a + ev + iv^2 + mv^3) + (b + fv + jv^2 + nv^3)u + (c + gv + kv^2 + ov^3)u^2 + (d + hv + Iv^2 + pv^3)u^3,$$

and retain the simpler three-dimensional form:

x(u, v, w) = a + bu + ev + kw + fuv + ivw + luw + juvw

and define each of the polynomial coefficients in arithmetic terms as shown in Table 5.

**Table 5. Transformation Polynomial Coefficients** 

|      |                | Parame                      | eter           |             |
|------|----------------|-----------------------------|----------------|-------------|
|      |                | Two-Dimensional             | Three-Dim      | ensional    |
| Name | Term           | Coefficient                 | Term           | Coefficient |
| Α    | X <sub>0</sub> | а                           | X <sub>0</sub> | а           |
| В    | DXU            | b+c+d                       | DXU            | b           |
| С    | DXUU           | 2c + 6d                     | _              | 0           |
| D    | DXUUU          | 6d                          | _              | 0           |
| Е    | DXV            | e+i+m                       | DXV            | е           |
| F    | DXUV           | f+g+h+j+k+l+n+o+p           | DXUV           | f           |
| G    | DXUUV          | 2(g + k + o) + 6(h + l +p)  | X <sub>0</sub> | а           |
| Н    | DXUUUV         | 6(h + l + p)                | DXU            | b           |
| I    | DXVV           | 2i + 6m                     | DXVW           | i           |
| J    | DXUVV          | 2(j + k + l) + 6(n + o + p) | DXUVW          | j           |
| K    | DXUUVV         | 4k + 12l + 12o + 36p        | DXW            | k           |
| L    | DXUUUVV        | 12l + 36p                   | DXU <b>W</b>   | 1           |
| М    | DXVVV          | 6m                          | _              | 0           |
| N    | DXUVVV         | 6(n + o + p)                | _              | 0           |
| 0    | DXUUVVV        | 12o + 36p                   | _              | 0           |
| Р    | DXUUUVVV       | 36p                         | _              | 0           |

## Understanding the Polynomial Coefficients

### **An Overview**

As the formulae indicate, the source address is a polynomial function of the two (or three) dimensions of the target address. Each of the 16 terms of the equation is of the form:

$$\frac{d^{m+n+p}x}{du^mdv^ndw^p}$$

and may be treated approximately as a mixed partial difference of order m, n, and p.

The simplest term,  $X_0$ , is a zeroeth (non-) function of the target addresses; it specifies the source address point corresponding to the upper left point in the target space.  $X_0$  generates image translation or "pan."

The next-simplest terms, dX/dU and dY/dV, govern the relative scales of the source and target images, i.e., how large a step in source space corresponds to a unit step in the corresponding direction in the target space. As long as the crossterms, dX/dV and dY/dU, are zero, this is a straight scale ("zoom") operation, without rotation or shear.

The first-order cross terms, dX/dV and dY/dU, generate source space displacements perpendicular to unit displacements in the target space, thereby causing shearing of the image. In conjunction with the parallel source terms described above, they govern rotation, shear, and scaling of the image.

Although the actions of the higher-order terms become progressively difficult to describe, all terms behave essentially as partial differences of various orders, and a little thought and common sense will generally lead the user to the proper conclusions. For example, the term dXUU (using the notation of Table 2) is a horizontal scale factor which increases as one progresses across each row, causing a quadratic horizontal warp. In fact, all terms of the form d<sup>m</sup>x/du<sup>m</sup> or d<sup>n</sup>y/dv<sup>n</sup> cause only stretching of the image, never rotation.

## Interpolation Coefficient Lookup Table Addressing

The external coefficient lookup table RAM stores the interpolation coefficient values used to calculate the value of the new pixel. These values are selected by the user, allowing maximum filtering flexibility. In simple filtering applications, the source and target pixel addresses map one-to-one, and only one interpolation coefficient set is required. These integer addresses are generated for each dimension by the internal walk counters of each TMC2302A.

However, applications performing a coordinate transformation will almost always generate non-integer source pixel addresses; that is, the U (or V) locations will not map to the X (or Y) addresses exactly, and a fractional source address components are generated. The user must then expand the interpolation coefficient lookup table to include spatially-corrected values, as determined by the subpixel resolution of the system.

The TMC2301 Image Resampling Sequencer allows the user to trade subpixel resolution against interpolation step size by obtaining the interpolation coefficient addresses directly from the fractional part of the source address. The TMC2302A gives the user 16 different interpolation bit weighting positions. The complete Interpolation Coefficient Address for that dimension then consists of both the 8-bit interpolation walk address KADR<sub>7-0</sub>, weighted to match the source address binary point by the parameter FOV, and the fractional portion of the source pixel address SADR<sub>23-0</sub>, to the desired subpixel resolution. See Table 6.

### Internal and External Data Formats

The source address value output by the TMC2302A is a 24-bit two's complement number, with binary point assignable by the user anywhere in the 16 lower bits. The Extended mode appends 12 additional fractional bits for greater output precision. All internal computations include these 24 plus 12 bits, plus an additional 12 lower bits, for 48-bit precision. See Table 6.

Internally, each TMC2302A's source address (X, Y, or Z) generator computes a 48-bit address through a mode-specific accumulation of the sixteen 48-bit user-specified resampling parameters. The 24 most significant bits of the final accumulation emerge via the source address port whereas the "extend" mode makes the 12 next most-significant bits available at the target address port. The 12 least significant bits are truncated internally.

## Source Address Bit Weighting and Setting the Binary Point

When performing nearest-neighbor resampling, the user may arbitrarily trade source image size against subpixel resolution merely by adhering to a single binary point position for all resampling parameters. For example, if the binary point follows the 16 most significant bits in each resampling parameter, then it will appear following the source address' 16 most significant bits, leaving 8 (20 in extended mode) bits of subpixel resolution on SADR<sub>n</sub>.

Since the TMC2302A has no internal limiter, the user should select the source address weighting appropriately. Moving the source address connections to the right and reducing the resampling parameters accordingly, reduces the chance of arithmetic overflow while increasing arithmetic round-error.

In any filtering or resampling operation performing an interpolation walk, the user should set the Field or View (FOV) parameter according to the desired binary point position determined above, as follows. To provide  $2^{24}$  integral pixel positions per dimension, with no subpixel resolution, set FOV = 001 (hex). For  $2^{23}$  positions with 1-bit (0,5) subpixel resolution, FOV = 0010 (hex). Similarly, for  $2^9$  positions and 15-bit subpixel resolution. FOV = 8000 (hex). As shown in Table 6, using the parameter FOV the user effectively "shifts" the bit weight of the coefficient address word KADR7-0 to match the established location of his source address binary point. In each case, the EXTEND mode provides 12 additional bits of subpixel resolution but eliminates the separate target or raster address, which must then be generated elsewhere in the user's system.

| Weight Word                             | 2 <sup>47</sup> | 2 <sup>46</sup> | 2 <sup>40</sup> | 2 <sup>39</sup> | 2 <sup>32</sup> | 2 <sup>31</sup> | 2 <sup>25</sup> | 2 <sup>24</sup> | 2 <sup>23</sup> 2 <sup>16</sup> | 2 <sup>15</sup> 2 <sup>12</sup> 2 <sup>8</sup> | 2 <sup>7</sup> | 2 <sup>0</sup> |
|-----------------------------------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|---------------------------------|------------------------------------------------|----------------|----------------|
| Transform<br>Parameters                 | -47             | 46              | 40              | 39              | 32              | 31              | 25              | 24              | 23 16                           |                                                | 7              | 0              |
| Internal Source<br>Address Generator    | -47             | 46              | 40              | 39              | 32              | 31              | 25              | 24              | 23 16                           |                                                | 7              | 0              |
| Source Address<br>Output SADR23-0       | -23             | 22              | 16              | 15              | 8               |                 |                 |                 |                                 |                                                |                |                |
| Extended Mode Only TADR <sub>11-0</sub> |                 |                 |                 |                 |                 |                 |                 |                 | 11 4                            | 3 0                                            |                |                |
| KADR <sub>7-0</sub>                     |                 |                 |                 |                 |                 |                 |                 |                 |                                 |                                                |                |                |
| FOV = 0001                              |                 |                 |                 |                 |                 | 2 <sup>7</sup>  | 2 <sup>1</sup>  | 2 <sup>0</sup>  |                                 |                                                |                |                |
| FOV = 0002                              |                 |                 |                 |                 | 2 <sup>7</sup>  | 2 <sup>6</sup>  | 2 <sup>0</sup>  |                 |                                 |                                                |                |                |
| •                                       |                 |                 |                 |                 |                 |                 |                 |                 |                                 |                                                |                |                |
| FOV = 8000                              |                 | 2 <sup>7</sup>  | 2 <sup>1</sup>  | 2 <sup>0</sup>  |                 |                 |                 |                 |                                 |                                                |                |                |

#### Note:

1. A minus sign indicates a sign bit.

## Utilization of the Image Boundary Flags SVAL and TVAL

As mentioned above, the TMC2302A provides two programmable valid address, or boundary flags. The source valid flag \$\overline{SVAL}\$ is asserted when the current source image address output for that device's source image dimension is within the space defined by the configuration parameters XMIN and XMAX, or YMIN and YMAX, or ZMIN and ZMAX, as appropriate. Also, the target valid flag \$\overline{TVAL}\$ is available to indicate when the current target image address values fall within the space defined by the configuration parameters UMINI, UMAXI, VMINI, VMAXI, and also WMINI and WMAXI in three-dimensional systems. Note that all of these parameters are each programmed into each individual TMC2302A. Thus, the user could define two (or three) different working spaces, one indicated by each IMS device.

Figure 8 may help clarify the relationships among  $(X_0, Y_0, Z_0)$ , (UMIN, VMIN, WMIN), and (UMAX, VMAX, WMAX), for the two-dimensional case. With positive first derivatives,  $(X_0, Y_0)$  and (UMIN, VMIN) represent the upper left corners of the original image and the new destination field, respectively. The lower right corner of the new transformed image is located at (UMAX, VMAX); the location of the corresponding corner of the original image depends on the values of the derivatives.

Not to be confused with  $(X_0, Y_0)$ , the points (XMIN, YMIN) and (XMAX, YMAX) define the "usable" rectangular portion of the original image which is indicated by the valid address flag  $\overline{SVAL}$ ; points (X, Y) lying outside this region are ignored in most resampling and filtering applications.

Specifically, the point  $(X_0, Y_0)$  is the location from which the TMC2302A system begins the image resampling sequence. Every step beyond that point in the source image space is defined by the address generators implementing the image transformation polynomials.

The valid source address flag feature permits one to construct a mosaic of several abutting subimages in the (X,Y) plane, without danger of edge effect interference between adjacent subimages. Note in the figure that the upper right corner of the resampled source image lies outside the admissible region; in practice, the values fetched at these locations will not be included in the convolutional sums. One might, for instance, program these boundary values to alert the system that an edge is being approached and to modify the interpolation coefficients appropriately, or simply to ignore pixel values outside the defined space.

The TVAL however is utilized somewhat differently. Working in unison with the target address working space defined by UMIN/UMAX, etc. the target address valid flag could be programmed to delineate image areas other than the immediate working space, and the flag of each TMC2302A to indicate the unique regions anywhere within the target image. With this flexibility, the user can generate windows, "picture-in-picture" composite multiple images, or simply switch to a background image or border color. To make TVAL function properly, the used must set UMIN < UMINI < UMAXI < UMAX; likewise for V and, if used, W.



Figure 8. Pixel maps demonstrating source and destination image boundaries, violation flags, and image clipping (note shaded areas)

## Real-Time Bilinear Interpolation Using the TMC2302A or TMC2301

Image transformations and translations in bit mapped systems are done by taking an original (source) image, performing coordinate remapping and interpolation, then restoring the image into a new (destination) image space. The coordinates are remapped according to a transformation polynomial. The polynomial, evaluated at destination pixel addresses, maps the transformed pixel addresses (U, V) to pixel addresses in the original image addresses (U, V) to pixel addresses in the original image (X, Y), i.e., (X, Y) is a polynomial function of (U, V).



- 1. Coordinate transformation: Each pixel in (U, V) space is mapped to a location in (X,Y) space.
- 2. Interpolation: Unless the pixel in (U, V) space coincides with one in (X, Y) space, its amplitude must be estimated as a weighted average of those of the surrounding pixels in (X, Y) space. If the interpolation is done serially, throughput suffers in proportion to the size of the interpolation kernel. However, the interpolation can also be performed in parallel to preserve throughput, as discussed here.

## The TMC2302A Image Manipulation Sequencer

The TMC2302A is a controller/address generator, around which an image filtering and resampling system can be built. Under limited supervision from an external controller, the TMC2302A will generate the sequence of memory read and write addresses to transform, resample, and/or filter an image. In all cases, it fetches data from one image buffer, governs its convolution with a user-specified kernel of coefficients, and directs the results to another image memory space. With 24-bit source address buses the device can operate from a source frame size of, for example, 64K X 64K pixels with spatial resolution of 1/256th pixel. A simplified block diagram of the TMC2302A is shown in

Figure 9. Although the 24 source addresses bits of each TMC2302A can be designed arbitrarily with the source image address bus, assume for the current discussion that bits SADR (19:8) will correspond to the source image address and that SADR (7:4) therefore denote subpixel postponing to 1/16 pixel resolution.

The basic 2-D system, shown in Figure 10, consists of data source and destination memories, coefficient lookup table, multplier-accumulator, TMC2302A parameters to define the transform and starts the operation. It may also control the loading of the source image into RAM and provide the screen refresh, if needed.



Figure 9. TMC2302A Block Diagram



Figure 10. Basic 2-D Image Transformation Systems

### **Inexact Transformations**

In many cases, evaluation of the transformation polynomial results in a non-integer result (non-integer address in the X, Y image space). In such cases, the mapping from original image to transformed image will be inexact. When this occurs, the user has the option of accepting the pixel "nearest" to the address generated, or performing interpolation, a weighted average of nearby pixel values. Using the pixel nearest the address generated is the fastest method since one transformed pixel can be generated on every cycle. The resulting image will include jagged biasing artifacts, however. Performing several transformations on the same image will further degrade the resulting image.

### One Cycle Bilinear Interpolation

A better image can be obtained by finding the four pixels nearest the address generated and performing a weighted averaging to determine the new pixel value. This is known as bilinear interpolation. The TMC2302A eases the control logic required for such a function by performing a "walk" around the four closest pixels in the source image space. Essentially, the TMC2302A generates the addresses of the four walk cycles, and the current source pixel is multiplied by a weighting factor and accumulated by the external multi-

plier accumulator. At the end of the walk, the accumulated result from the four nearest pixels is written into the destination image RAM and the TMC2302A proceeds to the next group. The obvious disadvantage to using bilinear interpolation is that one new destination pixel is generated only on every fourth cycle, reducing the output bandwidth by a factor of four.

One method of "real-time" bilinear interpolation consists of using four memories, each containing the entire source image. The storage arrangement of the pixels within each bank is staggered so that a single address fed to the memories will result in the access of the proper four pixel group. The TMC2302A is programmed to generate the nearest neighbor address and the four nearest pixels are accessed simultaneously and input to the four independent multipliers of a TMC2246 quad multiplier chip. The four pixels are multiplied by their associated weighting factors and added to determine the destination pixel sum. The major drawback of this method is the prohibitive cost for additional memory required to store four copies of the entire source image. For large images, the memory cost and additional board space makes this method unattractive.

A more efficient method is to divide the original source image into a "four-color checker board" and to store it into four separate pixel memory banks, each containing 14th of the source image. Since the image is separated into four memories rather than duplicated, no additional image memory is required. The goal is to separate the image so that any square of four adjacent pixel locations can be accesssed simultaneously. Thus, the user must organize the memory such that the four pixels of any cluster will reside in separate memory banks. With this method, only one set of address generators (TMC2302As) is necessary, and only a slight address modification is necessary to guarantee that the correct group of pixels is accessed and output to the multipliers. Since all pixels are accessed simultaneously, no "walk" is performed, and the TMC2302A system is able to generate one destination pixel on each clock cycle. For example, a 1024 x 768 image can be generated every 20ms for a frame refresh rate of 50Hz. This method which will be described below.

## **Using Banded Pixel Memory**

The TMC2302A should be programmed to do "nearest-neighbor" transformations (Kernel, K=0 and the  $X_0$  and  $Y_0$  start boundaries programmed without 1/2-LSB truncation debiasing to force address truncation when evaluating the transformation polynomial for the nearest-pixel address). The biased  $X_0$  and  $Y_0$  guarantee that when the exact pixel address falls within the region of four pixels, the upper leftmost pixel will always be selected as "nearest-neighbor."

The key to performing real-time bilinear interpolation is to arrange the pixels in memory so that the four pixels of every grouping will be stored in separate memories. The four nearest pixels will form a square. Figure 11 shows a sample 512 x 512 pixel image and the arrangement into four separate memory banks designated A, B, C, and D. It can be seen from the figure that any (square) grouping of four pixels will have one pixel located in each bank. Thus, one memory sector will hold even row-even column pixels, another, even-row-add column pixels, etc.

| A <sub>0,0</sub><br>(0,0) | B <sub>0,0</sub><br>(1,0) | A <sub>1,0</sub> (2,0) | B <sub>1,0</sub><br>(3,0) | A <sub>2,0</sub> (4,0)    | B <sub>2,0</sub><br>(5,0) | A <sub>3,0</sub> A <sub>255,0</sub><br>(6,0)(510, 0) | B <sub>255.0</sub><br>(511, 0) |
|---------------------------|---------------------------|------------------------|---------------------------|---------------------------|---------------------------|------------------------------------------------------|--------------------------------|
| C <sub>0,0</sub>          | D <sub>0,0</sub>          | C <sub>1,0</sub>       | D <sub>1,0</sub>          | C <sub>2,0</sub>          | D <sub>2,0</sub>          | $C_{3,0}C_{255,0}$                                   | D <sub>255,0</sub>             |
| (0,1)                     | (1,1)                     | (2,1)                  | (3,1)                     | (4,1)                     | (5,1)                     | (6,1)(510,1)                                         | (511,1)                        |
| A <sub>0,1</sub> (0,2)    | B <sub>0,1</sub><br>(1,1) | A <sub>1,1</sub> (2,1) | B <sub>1,1</sub><br>(3,2) | A <sub>2,1</sub><br>(4,2) | B <sub>2,1</sub><br>(5,2) | $A_{3,1}A_{255,1}$<br>(6,2)(510,2)                   | B <sub>255,1</sub><br>(511,2)  |
| C <sub>0,1</sub>          | D <sub>0,1</sub>          | C <sub>1,1</sub> (2,3) | D <sub>1,1</sub>          | C <sub>2,1</sub>          | D <sub>2,1</sub>          | $C_{3,1}C_{255,1}$                                   | D <sub>255,1</sub>             |
| (0,3)                     | (1,3)                     |                        | (3,3)                     | (4,3)                     | (5,3)                     | (6,3)(510,3)                                         | (511,3)                        |
| A <sub>0,2</sub> (0,4)    | B <sub>0,2</sub> (1,4)    | A <sub>1,2</sub> (2,4) | B <sub>I,2</sub><br>(3,4) | A <sub>2,2</sub> (4,4)    | B <sub>2,2</sub><br>(5,4) | $A_{3,2}A_{255,2}$<br>(6,4)(510,4)                   | B <sub>255,2</sub><br>(511,4)  |
| C <sub>0,2</sub>          | D <sub>0,2</sub>          | C <sub>1,2</sub>       | D <sub>1,2</sub>          | C <sub>2,2</sub>          | D <sub>2,2</sub>          | C <sub>3,2</sub> C <sub>255,2</sub>                  | D <sub>255,2</sub>             |
| (0,5)                     | (1,5)                     | (2,5)                  | (3,5)                     | (4,5)                     | (5,5)                     | (6,5)(510,5)                                         | (511,5)                        |
|                           |                           |                        |                           | •••                       |                           | •••                                                  | •••                            |
| A <sub>0,255</sub>        | B <sub>0,255</sub>        | A <sub>1,255</sub>     | B <sub>1,255</sub>        | A <sub>2,255</sub>        | B <sub>2,255</sub>        | $A_{3,255}A_{255,255}$                               | B <sub>255,255</sub>           |
| (0,510)                   | (1,510)                   | (2,510)                | (3,510)                   | (4,510)                   | (5,510)                   | (6,510)(510,510)                                     | (511,510)                      |
| C <sub>0,255</sub>        | D <sub>0,255</sub>        | C <sub>1,255</sub>     | D <sub>1,255</sub>        | C <sub>2,255</sub>        | D <sub>2,255</sub>        | $C_{3,255}C_{255,255}$                               | D <sub>255,255</sub>           |
| (0,511)                   | (1,511)                   | (2,511)                | (3,511)                   | (4,511)                   | (5,511)                   | (6,511)(510,511)                                     | (511,511)                      |

Figure 11. Source Image Pixel Arrangement

Subscripts i, j for A, B, C, and D denote relative addresses in memory respectively.

The ordered pairs (a, b) denote the physical (X,Y) pixel locations and the TMC2302A SAPR(X) and SADR(Y) address outputs.

The pixels of the original image should be stored in the source RAM banks as shown in Figure 12. The original source image can be loaded by decoding the TMC2302A least significant address bits  $(SADR_X(8), SADR_Y(8))$  to determine the memory bank for the pixel while the most-significant address bits  $(SADR_X(19:9), SADR_Y(19:9))$  are used as common address lines to all four memory banks.

| TMC230  | 02A Ad-    | Bank A               | Bank B               | Bank C               | Bank D               |
|---------|------------|----------------------|----------------------|----------------------|----------------------|
| XA      | $YA_{\mu}$ | $XA_0YA_0 = 00$      | $XA_0YA_0 = 10$      | $XA_0YA_0 = 01$      | $XA_0YA_0 = 11$      |
| $\mu$ : |            |                      |                      |                      |                      |
| 0       | 0          | A <sub>0,0</sub>     | B <sub>0,0</sub>     | C <sub>0,0</sub>     | $D_{0,0}$            |
| 0       | 1          | A <sub>0,1</sub>     | B <sub>0,1</sub>     | C <sub>0,1</sub>     | D <sub>0,1</sub>     |
| 0       | 2          | A <sub>0,2</sub>     | B <sub>0,2</sub>     | C <sub>0,2</sub>     | D <sub>0,2</sub>     |
| 0       | 255        | A <sub>0,255</sub>   | B <sub>0,255</sub>   | C <sub>0,255</sub>   | D <sub>0,255</sub>   |
| 1       | 0          | A <sub>1,0</sub>     | B <sub>1,0</sub>     | C <sub>1,0</sub>     | $D_{I,O}$            |
| 1       | 1          | A <sub>1,1</sub>     | B <sub>1,1</sub>     | C <sub>1,1</sub>     | D <sub>1,1</sub>     |
| 1       | 2          | A <sub>1,2</sub>     | B <sub>1,2</sub>     | C <sub>1,2</sub>     | D <sub>1,2</sub>     |
| 255     | 254        | A <sub>255,254</sub> | B <sub>255,254</sub> | C <sub>255,254</sub> | D <sub>255,254</sub> |
| 255     | 255        | A <sub>255,254</sub> | B <sub>255,254</sub> | C <sub>255,254</sub> | D <sub>255,254</sub> |

In the following discussion, the TMC2302A address outputs  $SADR_X$  and  $SADR_Y$  will be designated as:

#### Horizontal Source

| $XA_0$ | Least-Significant Horizontal Source X-Address |
|--------|-----------------------------------------------|
|        | Bit $SADR_X(8)$                               |

$$YA_0$$
 Least-Significant Vertical Source Y-Address Bit  $SADR_X(8)$ 

## Interpolation Kernel

$$\begin{aligned} &P_{i,\,j} &&P_{i,\,j+1}\\ *-& \text{actual Pixel}\\ &P_{i+1,\,j} &&P_{i+1,\,j+1} \end{aligned}$$

Figure 13. TMC2302A Serial Walk Sequence in real time bilinear resampling, this is executed in parallel

When the transformation polynomial is evaluated and the resulting pixel address falls within a group of four nearby pixels (non-integer result), the TMC2302A will always choose the upper leftmost pixel  $(P_{ij})$  as the nearest neighbor (due to the fractional address truncation in the X and Y directions). Since the four pixels will reside in independent banks, the upper leftmost pixel might be located in any of the four memory banks (A,B,C, or D). The bank which contains the nearest neighbor must be known, since in each case, different memory address modification is required to select the correct pixel from each bank.



Figure 14. Possible Selections for Nearest Neighbor

## **Memory Address Modification**

Using the address LSBs  $(XA_0,YA_0)$  from each TMC2302A external logic can determine which bank contains the nearest neighbor. (This same decoding is used when loading the original image into the source image RAMs.)

| Case* | XA <sub>0</sub> | YA <sub>0</sub> | Nearest Neighbor (Upper Leftmost)<br>Pixel |
|-------|-----------------|-----------------|--------------------------------------------|
| 1     | 0               | 0               | A Memory Bank contains Nearest<br>Neighbor |
| 2     | 1               | 0               | B Memory Bank contains Nearest<br>Neighbor |
| 3     | 0               | 1               | C Memory Bank contains Nearest<br>Neighbor |
| 4     | 1               | 1               | D Memory Bank contains Nearest<br>Neighbor |

<sup>\*</sup>from Figure 14 above

Addressing for each memory bank (A, B, C, D) is done using the uppermost address bits ( $XA_{\mu}$ ) of the TMC2302As. The LSB of each TMC2302A is used to determine both the upper leftmost pixel and the address modification required. In the following paragraphs, the lower case subscripts (i,j) denote the address of a pixel within a given memory bank (A, B, C, or D), and XA, YA are used to denote physical address outputs of the TMC2302A pairs.

Pixel address modification use to access the correct four pixel group is determined as follows:

#### Case A:

 $A_{i,j}$  is nearest upperleft neighbor, (No address modifications) ( $XA_0 = YA_0 = 0$ )

$$\begin{array}{ccc} A_{i,j} & & B_{i,j} \\ & * & \\ C_{i,j} & & D_{i,j} \end{array}$$

Figure 15. Pixel Memory Mapping for A = Upper Leftmost

Memory Addressing Becomes:

A address =  $XA_{\mu}$ ,  $YA_{\mu}$ 

B address =  $XA_{\mu}$ ,  $YA_{\mu}$ 

C address =  $XA_{\mu}$ ,  $YA_{\mu}$ 

D address =  $XA_{\mu}$ ,  $YA_{\mu}$ 

i.e., no modification is required.

### Case B:

 $B_{i,j}$  is upperleft neighbor, (Modify X component of A & C memory addresses) ( $XA_0=1,YA_0=0$ )

$$\begin{array}{ll} B_{i,j} & \quad A_{i+1,j} \\ * & \\ \\ D_{i,j} & \quad C_{i+1,j} \end{array}$$

Figure 16. Pixel Memory Pattern for B = Upper Leftmost

Memory Addressing Becomes:

A address =  $(XA_{\mu} + 1, YA_{\mu})$ 

B address =  $(XA_{\mu}, YA_{\mu})$ 

C address =  $(XA_{\mu} + 1, Ya_{\mu})$ 

D address =  $(XA_{\mu}YA_{\mu})$ 

### Case C:

Ci,j is upperleft neighbor, (Modify Y component of A & B memory addresses)  $(XA_0 = 0, YA_0 = 1)$ 

$$\begin{array}{ll} C_{i,J} & D_{i,j} \\ * & \\ A_{i,i+1} & B_{i,j+1} \end{array}$$

Figure 17. Pixel Pattern for C = Upper Leftmost

Memory Addressing Becomes:

A address =  $XA_{\mu}YA_{\mu} + 1$ 

B address =  $XA_{\mu}$ ,  $Ya_{\mu} + 1$ 

C address =  $XA_{\mu}$ ,  $YA_{\mu}$ 

D address =  $XA_{\mu}$ ,  $YA_{\mu}$ 

#### Case D:

Di,j is the nearest neighbor (Modify A, B & C addresses, X and Y components) ( $XA_0 = 1, YA_0 = 1$ )

$$\begin{array}{ll} D_{i,j} & \quad C_{i+1,j} \\ * & \\ B_{i,\,j+1} & \quad A_{i+1,j+1} \end{array}$$

Figure 18. Pixel Pattern for D = Upper Leftmost

Memory Addressing Becomes:

 $A \text{ address} = XA_{\mu} + 1, YA_{\mu} + 1$ 

B address =  $XA_{\mu}$ ,  $Ya_{\mu} + 1$ 

C address =  $XA_{\mu} + 1$ ,  $YA_{\mu}$ 

D address =  $XA_{\mu}$ ,  $YA_{\mu}$ 

Taking a close look at the address modifications required for each case above, a simple pattern can be seen. This pattern leads to a set of address modification "rules" based on the values of the least-significant address bits from the TMC2301s  $(XA_0)$  and  $YA_0$ . These rules are:

When  $YA_0 = 0$ . (Case A & B)

No modificaton to the Y address component  $(Y\!A_{\mu})$  is necessary.

When  $YA_0 = 1$ , (Case C & D)

The Y component  $(YA_{\mu})$  of addresses to the A & B memory banks must be incremented by 1.

When  $XA_0 = 0$ . (Case A & C)

No modification to the X address component  $(XA_{\mu})$  is necessary.

When  $XA_0 = 1$ , (Case B & D)

The X component  $(XA_{\mu})$  of addresses to the A & C memory banks must be incremented by 1.

A system can easily be designed to modify the pixel memory addresses according to the above criteria, to select the correct four pixels to be interpolated. Rather than actually performing a "conditional" address increment as discussed above. It requires less logic simply to add the LSB address bit to the memory bank addresses (XA $_{\mu}$ , YA $_{\mu}$ ). Figure 12 shows the logic to perform the required above modifications. The addition (XA $_{\mu}$ , + XA $_{0}$ , YA $_{\mu}$ , +YA $_{0}$ ) can be done using half-adders with the XA $_{0}$  (YA $_{0}$ ) address output of the TMC2302A connected to the carry-in of each adder. It can also be done using high-speed programmable logic.

Note: Only modifications to the source image memory are necessary. The destination image memory may be arranged in a linear or other type array as required by the refresh circuitry.

## **Coefficient Memory**

Typically, the 4 highest fractional source address bits from each TMC2302A (SADR (7:4) in the example) are used to reflect the offset from the nearest XA (YA) pixel location.

With spatial resolution of 4 bits in both the X and Y directions, there can be as many as 256 unique coefficient values. This requires a coefficient memory of at least 256 bytes. However, as shown below, each of the four different cases requires its own set of 256 coefficients.

One-cycle bilinear interpolation requires four independent coeffficient memories, so that a parallel multiplication can be performed with the four pixel values.



\*Number of bits of intensity per pixel, per column component, typically 8 to 12.

Figure 19. Memory Address Modification



Figure 20. Intrapixel Resolution

Similar to determining the correct four pixel group, the coefficients must take into account the memory bank (A, B, C, or D) that contains the upper leftmost pixel, and adjust the coefficients accordingly. These adjustments are necessary since the fractional address outputs (SADR $_{\rm X}$  7:4), SADR $_{\rm Y}$  (7,4) from the TMC2302As reflect the spatial distance only from the upper leftmost pixel within the pixel group. Assuming that the fractional addresses SADR $_{\rm X}$  (7:4) and SADR $_{\rm Y}$  (7:4) plus the integer LSBs SADR $_{\rm X}$  (8) and SADR $_{\rm Y}$  (8) are to be used directly to address the 1024-byte coefficient memory, the loading of the coefficients is shown below with  $F_{\rm X}$  = SADR $_{\rm X}$  (7:4) and  $F_{\rm Y}$  = SADR $_{\rm Y}$  (7:4) Case A through D are the same as discussed previously for the pixel address modifications.

### Case A:

A is nearest neighbor  $(XA_0 = 0, YA_0 = 0)$ 

Coeff A = 
$$(1 - f_X) * (1 - f_Y)$$
  
Coeff B =  $(f_X) * (1 - f_Y)$   
Coeff C =  $(1 - f_X) * (f_Y)$   
Coeff D =  $f_X * f_Y$ 

#### Case B:

B is nearest neighbor  $(XA_0 = 1, YA_0 = 0)$ 

Coeff 
$$A = f_X * (1-f_Y)$$
  
Coeff  $B = (1-f_X) * (1-f_Y)$   
Coeff  $C = f_X * f_Y$   
Coeff  $D = (1-f_X)f_Y$ 

### Case C:

C is nearest neighbor  $(XA_0 = 0, YA_0 = 1)$ 

Coeff A = 
$$(1 - f_X) f_Y$$
  
Coeff B =  $f_X f_Y$   
Coeff C =  $(1 - f_X) (1 - f_Y)$ Coeff D =  $f_X * (1 - f_Y)$ 

#### Case D

D is nearest neighbor  $(XA_0 = 1, YA_0 = 1)$ 

Coeff A = 
$$f_X f_Y$$
  
Coeff B =  $(1 - f_X) f_Y$   
Coeff C =  $f_X * (1 - f_Y)$   
Coeff D =  $(1 - f_X) (1 - f_Y)$ 

Incorporating the concepts outlined in this discussion, the final system for one-cycle blinear interpolation is shown in Figure 21. This figure shows a small increase in logic over the basic 2-D system shown in Figure 10. The additional logic required includes: TMC2246 (rather than a single multiply/accumulate), and three additional coefficient memories. Some additional decoding logic is required to load the four pixel memory banks as well as some data and address pipelining (registering) to meet timing requirements. The solution, however, provides an increased pixel bandwidth, by a factor of four, and only a small increase in part count.



Figure 14. One-Cycle Bilinear Interpolation System

## **Related Products**

- TMC2301 Image Resampling Sequencer
- TMC2246A Image Filter
- TMC2249A Digital Mixer
- TMC2242B Half-Band Filter

### **Mechanical Dimensions**

### 121-Lead PPGA Package

| Symbol | Inches    |       | Millimeters |       | Notes |
|--------|-----------|-------|-------------|-------|-------|
|        | Min.      | Max.  | Min.        | Max.  | Notes |
| Α      | .080      | .160  | 2.03        | 4.06  |       |
| A1     | .040      | .060  | 1.01        | 1.53  |       |
| A2     | .125      | .215  | 3.17        | 5.46  |       |
| øΒ     | .016      | .020  | 0.40        | 0.51  | 2     |
| øB2    | .050 NOM. |       | 1.27 NOM.   |       | 2     |
| D      | 1.340     | 1.380 | 33.27       | 35.05 | SQ    |
| D1     | 1.200 BSC |       | 30.48 BSC   |       |       |
| е      | .100 BSC  |       | 2.54 BSC    |       |       |
| L      | .110      | .145  | 2.79        | 3.68  |       |
| L1     | .170      | .190  | 4.31        | 4.83  |       |
| М      | 13        |       | 13          |       | 3     |
| N      | 120       |       | 120         |       | 4     |
| Р      | .003      | _     | .076        |       |       |

- 1. Pin #1 identifier shall be within shaded area shown.
- 2. Pin diameter excludes solder dip finish.
- 3. Dimension "M" defines matrix size.
- 4. Dimension "N" defines the maximum possible number of pins.
- 5. Orientation pin is at supplier's option.
- 6. Controlling dimension: inch.





## Mechanical Dimensions (continued)

### 120-Lead MQFP Package

| Symbol | Inches    |       | Millimeters |       | Notes |
|--------|-----------|-------|-------------|-------|-------|
|        | Min.      | Max.  | Min.        | Max.  | Notes |
| Α      | _         | .154  | _           | 3.92  |       |
| A1     | .010      | _     | .25         | _     |       |
| A2     | .125      | .144  | 3.17        | 3.67  |       |
| В      | .012      | .018  | .30         | .45   | 3, 5  |
| С      | .005      | .009  | .13         | .23   | 5     |
| D/E    | 1.219     | 1.238 | 30.95       | 31.45 |       |
| D1/E1  | 1.098     | 1.106 | 27.90       | 28.10 |       |
| е      | .0315 BSC |       | .80 BSC     |       |       |
| L      | .026      | .037  | .65         | .95   | 4     |
| N      | 120       |       | 120         |       |       |
| ND     | 30        |       | 30          |       |       |
| α      | 0°        | 7°    | 0°          | 7°    |       |
| ccc    | _         | .004  | _           | .10   |       |

- 1. All dimensions and tolerances conform to ANSI Y14.5M-1982.
- 2. Controlling dimension is millimeters.
- Dimension "B" does not include dambar protrusion. Allowable dambar protrusion shall be .08mm (.003in.) maximum in excess of the "B" dimension. Dambar cannot be located on the lower radius or the foot.
- 4. "L" is the length of terminal for soldering to a substrate.
- 5. "B" & "C" includes lead finish thickness.



## **Ordering Information**

| Product<br>Number | Temperature<br>Range | Speed<br>Grade | Screening  | Package                        | Package Marking |
|-------------------|----------------------|----------------|------------|--------------------------------|-----------------|
| TMC2302AH5C       | 0°C to 70°C          | 30 MHz         | Commercial | 120 Pin Plastic Pin Grid Array | 2302AH5C        |
| TMC2302AH5C1      | 0°C to 70°C          | 40 MHz         | Commercial | 120 Pin Plastic Pin Grid Array | 2302AH5C1       |
| TMC2302AKEC       | 0°C to 70°C          | 30 MHz         | Commercial | 120 Lead Metric Quad FlatPack  | 2302AKEC        |
| TMC2302AKEC1      | 0°C to 70°C          | 40 MHz         | Commercial | 120 Lead Metric Quad FlatPack  | 2302AKEC1       |

### LIFE SUPPORT POLICY

FAIRCHILD'S PRODUCTS ARE NOT AUTHORIZED FOR USE AS CRITICAL COMPONENTS IN LIFE SUPPORT DEVICES OR SYSTEMS WITHOUT THE EXPRESS WRITTEN APPROVAL OF THE PRESIDENT OF FAIRCHILD SEMICONDUCTOR CORPORATION. As used herein:

- Life support devices or systems are devices or systems which, (a) are intended for surgical implant into the body, or (b) support or sustain life, and (c) whose failure to perform when properly used in accordance with instructions for use provided in the labeling, can be reasonably expected to result in a significant injury of the user.
- A critical component in any component of a life support device or system whose failure to perform can be reasonably expected to cause the failure of the life support device or system, or to affect its safety or effectiveness.

www.fairchildsemi.com